update code

dev_xds
haha 2024-04-08 01:54:00 +08:00
parent c067dacc84
commit 73690ae5c2
15 changed files with 771 additions and 1584 deletions

View File

@ -92,7 +92,20 @@
animation: spin 1.5s linear infinite; animation: spin 1.5s linear infinite;
} }
.div-txt-2 {
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
text-overflow: ellipsis;
}
.div-txt-3 {
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
text-overflow: ellipsis;
}
@-webkit-keyframes spin { @-webkit-keyframes spin {
0% { 0% {
-webkit-transform: rotate(0deg); -webkit-transform: rotate(0deg);

View File

@ -1,42 +1,17 @@
<template> <template>
<div class="app-container"> <div class="app-container">
<el-drawer <el-drawer v-if="onOpen" :visible.sync="onOpen" direction="rtl" size="60%" style="padding-left: 20px">
v-if="onOpen"
:visible.sync="onOpen"
direction="rtl"
size="60%"
style="padding-left: 20px"
>
<template slot="title"> <template slot="title">
<div>{{ drawerTitle + " 【材料取样复试】" }}</div> <div>{{ drawerTitle + " 【材料取样复试】" }}</div>
</template> </template>
<el-tabs <el-tabs v-model="unitActiveName" style="margin-left: 20px; margin-right: 20px" @tab-click="getList">
v-model="unitActiveName" <el-tab-pane v-for="(it, idx) in nodes" :label="it.unitName + ''" :name="it.unitId + ''"
style="margin-left: 20px; margin-right: 20px" :key="idx"></el-tab-pane>
@tab-click="getList"
>
<el-tab-pane
v-for="(it, idx) in nodes"
:label="it.unitName + ''"
:name="it.unitId + ''"
:key="idx"
></el-tab-pane>
</el-tabs> </el-tabs>
<el-row <el-row :gutter="10" class="mb8" style="margin-left: 25px; margin-top: 10px; margin-right: 0px" v-if="canCreated">
:gutter="10"
class="mb8"
style="margin-left: 25px; margin-top: 10px; margin-right: 0px"
>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
type="primary" v-hasPermi="['project:checkDetection:add']">添加</el-button>
plain
icon="el-icon-plus"
size="mini"
@click="handleAdd"
v-hasPermi="['project:checkDetection:add']"
>添加</el-button
>
</el-col> </el-col>
<!-- <el-col :span="1.5"> <!-- <el-col :span="1.5">
<el-button <el-button
@ -62,63 +37,32 @@
>删除</el-button >删除</el-button
> >
</el-col> --> </el-col> -->
<right-toolbar <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
:showSearch.sync="showSearch"
@queryTable="getList"
></right-toolbar>
</el-row> </el-row>
<el-tabs <el-tabs v-model="queryParams.activeName" @tab-click="getList" style="margin-left: 25px; margin-right: 25px">
v-model="queryParams.activeName"
@tab-click="getList"
style="margin-left: 25px; margin-right: 25px"
>
<el-tab-pane :label="tabs.all" name="all"></el-tab-pane> <el-tab-pane :label="tabs.all" name="all"></el-tab-pane>
<el-tab-pane :label="tabs.jxz" name="jxz"></el-tab-pane> <el-tab-pane :label="tabs.jxz" name="jxz"></el-tab-pane>
<el-tab-pane :label="tabs.ywc" name="ywc"></el-tab-pane> <el-tab-pane :label="tabs.ywc" name="ywc"></el-tab-pane>
<el-table <el-table v-loading="loading" :data="checkDetectionList" @selection-change="handleSelectionChange" stripe>
v-loading="loading"
:data="checkDetectionList"
@selection-change="handleSelectionChange" stripe
>
<el-table-column label="送检类型" align="center" prop="checkType"> <el-table-column label="送检类型" align="center" prop="checkType">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag :options="dict.type.check_detection_check_type" :value="scope.row.checkType" />
:options="dict.type.check_detection_check_type"
:value="scope.row.checkType"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="材料名称" align="center" prop="materialName" width="160">
label="材料名称"
align="center"
prop="materialName"
width="160"
>
<template slot-scope="scope"> <template slot-scope="scope">
<div>{{ scope.row.materialName }}</div> <div>{{ scope.row.materialName }}</div>
<div>{{ scope.row.usePosition }}</div> <div>{{ scope.row.usePosition }}</div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="取样数量" align="center" prop="sampleNum" width="80" show-overflow-tooltip />
label="取样数量"
align="center"
prop="sampleNum"
width="80"
show-overflow-tooltip
/>
<el-table-column label="合格证" align="center" prop="qualifiedFlag"> <el-table-column label="合格证" align="center" prop="qualifiedFlag">
<template slot-scope="scope"> <template slot-scope="scope">
<el-tag v-if="scope.row.qualifiedFlag == 'Y'" type="success"></el-tag> <el-tag v-if="scope.row.qualifiedFlag == 'Y'" type="success"></el-tag>
<el-tag v-if="scope.row.qualifiedFlag == 'N'" type="danger"></el-tag> <el-tag v-if="scope.row.qualifiedFlag == 'N'" type="danger"></el-tag>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="监理专员" align="left" prop="witnessUser" width="120" show-overflow-tooltip>
label="监理专员"
align="left"
prop="witnessUser"
width="120"
show-overflow-tooltip
>
<template slot-scope="scope"> <template slot-scope="scope">
<div>{{ scope.row.witnessUserName }}</div> <div>{{ scope.row.witnessUserName }}</div>
<div>{{ scope.row.witnessUser }}</div> <div>{{ scope.row.witnessUser }}</div>
@ -140,112 +84,41 @@
</el-table-column> --> </el-table-column> -->
<el-table-column label="审批状态" align="center" prop="approveStatus" width="120"> <el-table-column label="审批状态" align="center" prop="approveStatus" width="120">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag :options="dict.type.project_check_status" :value="scope.row.approveStatus" />
:options="dict.type.project_check_status"
:value="scope.row.approveStatus"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="操作" align="center" width="180" fixed="right" class-name="small-padding fixed-width">
label="操作"
align="center"
width="180"
fixed="right"
class-name="small-padding fixed-width"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button v-if="scope.row.checkState == '2'" size="mini" type="text" icon="el-icon-paperclip"
v-if="scope.row.checkState == '2'" @click="handleDownload(scope.row)" v-hasPermi="['project:surProjectSpecial:list']">下载检测报告</el-button>
size="mini" <el-button v-if="scope.row.approveStatus != '4'" size="mini" type="text" icon="el-icon-edit-outline"
type="text" @click="handleUpdateResult(scope.row)" style="margin-left: 8px"
icon="el-icon-paperclip" v-hasPermi="['project:checkDetection:editResult']">登记检测结果</el-button>
@click="handleDownload(scope.row)" <el-button v-if="scope.row.approveStatus != null" size="mini" type="text" icon="el-icon-tickets"
v-hasPermi="['project:surProjectSpecial:list']" @click="handleAuditinfo(scope.row)">审批日志</el-button>
>下载检测报告</el-button <el-button v-if="scope.row.approveStatus != '4'" size="mini" type="text" icon="el-icon-edit"
> @click="handleUpdate(scope.row)" v-hasPermi="['project:checkDetection:edit']">修改</el-button>
<el-button <el-button v-if="scope.row.approveStatus != '4'" size="mini" type="text" icon="el-icon-delete"
v-if="scope.row.approveStatus != '4'" @click="handleDelete(scope.row)" v-hasPermi="['project:checkDetection:remove']">删除</el-button>
size="mini"
type="text"
icon="el-icon-edit-outline"
@click="handleUpdateResult(scope.row)"
style="margin-left: 8px"
v-hasPermi="['project:checkDetection:editResult']"
>登记检测结果</el-button
>
<el-button
v-if="scope.row.approveStatus != null"
size="mini"
type="text"
icon="el-icon-tickets"
@click="handleAuditinfo(scope.row)"
>审批日志</el-button
>
<el-button
v-if="scope.row.approveStatus != '4'"
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['project:checkDetection:edit']"
>修改</el-button
>
<el-button
v-if="scope.row.approveStatus != '4'"
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['project:checkDetection:remove']"
>删除</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<pagination <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum"
v-show="total > 0" :limit.sync="queryParams.pageSize" @pagination="getList" />
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
</el-tabs> </el-tabs>
<el-dialog <el-dialog :title="title" v-if="open" :visible.sync="open" width="680px" append-to-body
:title="title" :close-on-click-modal="false" :close-on-press-escape="false">
v-if="open"
:visible.sync="open"
width="680px"
append-to-body
:close-on-click-modal="false"
:close-on-press-escape="false"
>
<el-form ref="form" :model="form" :rules="rules" label-width="120px"> <el-form ref="form" :model="form" :rules="rules" label-width="120px">
<el-form-item label="项目名称" prop="projectName"> <el-form-item label="项目名称" prop="projectName">
<el-input <el-input v-model="form.projectName" placeholder="请输入项目名称" :disabled="true" />
v-model="form.projectName"
placeholder="请输入项目名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="单位名称" prop="deptName"> <el-form-item label="单位名称" prop="deptName">
<el-input <el-input v-model="form.deptName" placeholder="请输入单位名称" :disabled="true" />
v-model="form.deptName"
placeholder="请输入单位名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="送检类型" prop="checkType"> <el-form-item label="送检类型" prop="checkType">
<el-select <el-select v-model="form.checkType" placeholder="请选择送检类型" style="width: 100%">
v-model="form.checkType" <el-option v-for="dict in dict.type.check_detection_check_type" :key="dict.value" :label="dict.label"
placeholder="请选择送检类型" :value="dict.value"></el-option>
style="width: 100%"
>
<el-option
v-for="dict in dict.type.check_detection_check_type"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="材料名称" prop="materialName"> <el-form-item label="材料名称" prop="materialName">
@ -258,38 +131,18 @@
<el-input v-model="form.sampleNum" placeholder="请输入取样数量" /> <el-input v-model="form.sampleNum" placeholder="请输入取样数量" />
</el-form-item> </el-form-item>
<el-form-item label="提供合格证" prop="qualifiedFlag"> <el-form-item label="提供合格证" prop="qualifiedFlag">
<el-select <el-select v-model="form.qualifiedFlag" placeholder="请选择提供合格证" style="width: 100%">
v-model="form.qualifiedFlag" <el-option v-for="dict in dict.type.sys_yes_no" :key="dict.value" :label="dict.label"
placeholder="请选择提供合格证" :value="dict.value"></el-option>
style="width: 100%"
>
<el-option
v-for="dict in dict.type.sys_yes_no"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="监理专员" prop="witnessUser"> <el-form-item label="监理专员" prop="witnessUser">
<el-select <el-select v-model="form.witnessUser" placeholder="请选择监理专员" filterable style="width: 100%"
v-model="form.witnessUser" @change="selectWitnessUser">
placeholder="请选择监理专员" <el-option-group v-for="group in deptUserData" :key="group.unitId + ''"
filterable :label="group.unitName + ' [' + group.unitTypeName + '] '">
style="width: 100%" <el-option v-for="(item, index) in group.userinfoList" :key="index"
@change="selectWitnessUser" :label="item.nickName + ' [' + item.jobTypeName + '] '" :value="item.phonenumber">
>
<el-option-group
v-for="group in deptUserData"
:key="group.unitId + ''"
:label="group.unitName + ' [' + group.unitTypeName + '] '"
>
<el-option
v-for="(item,index) in group.userinfoList"
:key="index"
:label="item.nickName + ' [' + item.jobTypeName + '] '"
:value="item.phonenumber"
>
</el-option> </el-option>
</el-option-group> </el-option-group>
</el-select> </el-select>
@ -298,13 +151,8 @@
<el-input v-model="form.laboratoryName" placeholder="请输入实验室名称" /> <el-input v-model="form.laboratoryName" placeholder="请输入实验室名称" />
</el-form-item> </el-form-item>
<el-form-item label="送检时间" prop="checkTime"> <el-form-item label="送检时间" prop="checkTime">
<el-date-picker <el-date-picker clearable v-model="form.checkTime" type="date" value-format="yyyy-MM-dd"
clearable placeholder="请选择送检时间">
v-model="form.checkTime"
type="date"
value-format="yyyy-MM-dd"
placeholder="请选择送检时间"
>
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -315,89 +163,37 @@
</el-dialog> </el-dialog>
<!-- 材料取样复试等级结果 --> <!-- 材料取样复试等级结果 -->
<el-dialog <el-dialog :title="title" v-if="resultopen" :visible.sync="resultopen" width="680px" append-to-body
:title="title" :close-on-click-modal="false" :close-on-press-escape="false">
v-if="resultopen" <el-form ref="resultform" :model="resultform" :rules="resultrules" label-width="100px">
:visible.sync="resultopen"
width="680px"
append-to-body
:close-on-click-modal="false"
:close-on-press-escape="false"
>
<el-form
ref="resultform"
:model="resultform"
:rules="resultrules"
label-width="100px"
>
<el-form-item label="项目名称"> <el-form-item label="项目名称">
<el-input <el-input v-model="resultform.projectName" placeholder="请输入项目名称" :disabled="true" />
v-model="resultform.projectName"
placeholder="请输入项目名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="单位名称"> <el-form-item label="单位名称">
<el-input <el-input v-model="resultform.deptName" placeholder="请输入单位名称" :disabled="true" />
v-model="resultform.deptName"
placeholder="请输入单位名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="送检类型"> <el-form-item label="送检类型">
<el-select <el-select v-model="resultform.checkType" placeholder="请选择送检类型" style="width: 100%" :disabled="true">
v-model="resultform.checkType" <el-option v-for="dict in dict.type.check_detection_check_type" :key="dict.value" :label="dict.label"
placeholder="请选择送检类型" :value="dict.value"></el-option>
style="width: 100%"
:disabled="true"
>
<el-option
v-for="dict in dict.type.check_detection_check_type"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="材料名称"> <el-form-item label="材料名称">
<el-input <el-input v-model="resultform.materialName" placeholder="请输入材料名称" :disabled="true" />
v-model="resultform.materialName"
placeholder="请输入材料名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="实验室名称"> <el-form-item label="实验室名称">
<el-input <el-input v-model="resultform.laboratoryName" placeholder="请输入实验室名称" :disabled="true" />
v-model="resultform.laboratoryName"
placeholder="请输入实验室名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="送检时间"> <el-form-item label="送检时间">
<el-input <el-input v-model="resultform.checkTime" placeholder="请输入实送检时间" :disabled="true" />
v-model="resultform.checkTime"
placeholder="请输入实送检时间"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="检测结果" prop="detectionResult" v-if="false"> <el-form-item label="检测结果" prop="detectionResult" v-if="false">
<el-radio <el-radio v-model="resultform.detectionResult" v-for="dict in dict.type.project_checking_result"
v-model="resultform.detectionResult" :label="dict.value" :key="dict.value" border size="small">{{ dict.label }}</el-radio>
v-for="dict in dict.type.project_checking_result"
:label="dict.value"
:key="dict.value"
border
size="small"
>{{ dict.label }}</el-radio
>
</el-form-item> </el-form-item>
<el-form-item label="检测报告" prop="detectionFile"> <el-form-item label="检测报告" prop="detectionFile">
<FileUpload <FileUpload v-model="resultform.detectionFile" :limit="2" @input="fileInput"
v-model="resultform.detectionFile" :fileType="['pdf', 'png', 'jpg', 'jpeg']" />
:limit="2"
@input="fileInput"
:fileType="['pdf', 'png', 'jpg', 'jpeg']"
/>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
@ -406,7 +202,7 @@
</div> </div>
</el-dialog> </el-dialog>
</el-drawer> </el-drawer>
<indexDrawer ref="indexDrawer"/> <indexDrawer ref="indexDrawer" />
</div> </div>
</template> </template>
@ -427,9 +223,10 @@ export default {
indexDrawer, indexDrawer,
}, },
props: {}, props: {},
dicts: ["sys_yes_no","project_check_status", "project_checking_result", "check_detection_check_type"], dicts: ["sys_yes_no", "project_check_status", "project_checking_result", "check_detection_check_type"],
data() { data() {
return { return {
canCreated:true,
showViewer: false, showViewer: false,
// //
loading: true, loading: true,
@ -500,7 +297,7 @@ export default {
jxz: "进行中0", jxz: "进行中0",
ywc: "已完成0", ywc: "已完成0",
}, },
checkDetectionList:[], checkDetectionList: [],
project: null, project: null,
nodes: [], nodes: [],
unitActiveName: "", unitActiveName: "",
@ -510,9 +307,9 @@ export default {
}, },
computed: {}, computed: {},
watch: {}, watch: {},
created() {}, created() { },
mounted() {}, mounted() { },
beforeDestroy() {}, beforeDestroy() { },
methods: { methods: {
fileInput(files) { fileInput(files) {
let fileUrls = ""; let fileUrls = "";
@ -530,13 +327,13 @@ export default {
this.drawerTitle = project.projectName; this.drawerTitle = project.projectName;
this.onOpen = true; this.onOpen = true;
this.queryParams.projectId = project.id; this.queryParams.projectId = project.id;
this.tabs.all="全部数据0"; this.tabs.all = "全部数据0";
this.tabs.jxz="进行中0"; this.tabs.jxz = "进行中0";
this.tabs.ywc="已完成0"; this.tabs.ywc = "已完成0";
this.$api.publics this.$api.publics
.queryUnitList({ .queryUnitList({
projectId: project.id, projectId: project.id,
unitType: 2 unitTypes: [2,4]
}) })
.then((d) => { .then((d) => {
this.nodes = d.rows; this.nodes = d.rows;
@ -550,6 +347,8 @@ export default {
}, },
/** 查询特种人员列表 */ /** 查询特种人员列表 */
getList() { getList() {
let tmps=this.nodes.filter(d=>d.unitId==this.unitActiveName);
this.canCreated=tmps.length>0 && tmps[0].unitType==4?false:true;
this.loading = true; this.loading = true;
this.queryParams.deptId = this.unitActiveName; this.queryParams.deptId = this.unitActiveName;
this.queryCount(); this.queryCount();
@ -661,7 +460,7 @@ export default {
if (valid) { if (valid) {
if (this.form.id) { if (this.form.id) {
// //
if(this.form.checkState=="2"){ if (this.form.checkState == "2") {
this.resultform.approveStatus = "1"; this.resultform.approveStatus = "1";
} }
updateCheckDetection(this.form).then((response) => { updateCheckDetection(this.form).then((response) => {
@ -706,7 +505,7 @@ export default {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}) })
.catch(() => {}); .catch(() => { });
}, },
/** 选择监理专员*/ /** 选择监理专员*/
selectWitnessUser(val) { selectWitnessUser(val) {
@ -727,8 +526,8 @@ export default {
}, },
/** 审批日志 */ /** 审批日志 */
handleAuditinfo(row) { handleAuditinfo(row) {
row.title="材料取样复试"; row.title = "材料取样复试";
row.logType="1"; row.logType = "1";
this.$refs.indexDrawer.show(row); this.$refs.indexDrawer.show(row);
} }
}, },

View File

@ -1,42 +1,17 @@
<template> <template>
<div class="projectect-attendance-drawer"> <div class="projectect-attendance-drawer">
<el-drawer <el-drawer v-if="isOpen" :visible.sync="isOpen" direction="rtl" size="65%" style="padding-left: 20px">
v-if="isOpen"
:visible.sync="isOpen"
direction="rtl"
size="65%"
style="padding-left: 20px"
>
<template slot="title"> <template slot="title">
<div>{{ title + " 【材料封样管理】" }}</div> <div>{{ title + " 【材料封样管理】" }}</div>
</template> </template>
<el-tabs <el-tabs v-model="unitActiveName" style="margin-left: 20px; margin-right: 20px" @tab-click="getList">
v-model="unitActiveName" <el-tab-pane v-for="(it, idx) in nodes" :label="it.unitName + ''" :name="it.unitId + ''"
style="margin-left: 20px; margin-right: 20px" :key="idx"></el-tab-pane>
@tab-click="getList"
>
<el-tab-pane
v-for="(it, idx) in nodes"
:label="it.unitName + ''"
:name="it.unitId + ''"
:key="idx"
></el-tab-pane>
</el-tabs> </el-tabs>
<el-row <el-row :gutter="10" class="mb8" style="margin-left: 20px; margin-top: 10px; margin-right: 20px" v-if="canCreated">
:gutter="10"
class="mb8"
style="margin-left: 20px; margin-top: 10px; margin-right: 20px"
>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
type="primary" v-hasPermi="['project:materialSeal:add']">新增</el-button>
plain
icon="el-icon-plus"
size="mini"
@click="handleAdd"
v-hasPermi="['project:materialSeal:add']"
>新增</el-button
>
</el-col> </el-col>
<!-- <el-col :span="1.5"> <!-- <el-col :span="1.5">
<el-button <el-button
@ -62,52 +37,27 @@
>删除</el-button >删除</el-button
> >
</el-col> --> </el-col> -->
<right-toolbar <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
:showSearch.sync="showSearch"
@queryTable="getList"
></right-toolbar>
</el-row> </el-row>
<el-tabs <el-tabs v-model="queryParams.activeName" @tab-click="getList" style="margin-left: 25px; margin-right: 25px">
v-model="queryParams.activeName"
@tab-click="getList"
style="margin-left: 25px; margin-right: 25px"
>
<el-tab-pane :label="tabs.all" name="all"></el-tab-pane> <el-tab-pane :label="tabs.all" name="all"></el-tab-pane>
<el-tab-pane :label="tabs.jxz" name="jxz"></el-tab-pane> <el-tab-pane :label="tabs.jxz" name="jxz"></el-tab-pane>
<el-tab-pane :label="tabs.ywc" name="ywc"></el-tab-pane> <el-tab-pane :label="tabs.ywc" name="ywc"></el-tab-pane>
</el-tabs> </el-tabs>
<el-table <el-table v-loading="loading" :data="projectMaterialSealList" @selection-change="handleSelectionChange" stripe>
v-loading="loading"
:data="projectMaterialSealList"
@selection-change="handleSelectionChange" stripe
>
<el-table-column label="封样图片" align="center" prop="mainImage" width="80"> <el-table-column label="封样图片" align="center" prop="mainImage" width="80">
<template slot-scope="scope"> <template slot-scope="scope">
<el-image <el-image ref="preview" style="width: 50px; height: 50px" :src="getImageUrl(scope.row.mainImage)"
ref="preview" @click="onPreview(scope.row.imageUrls)"></el-image>
style="width: 50px; height: 50px"
:src="getImageUrl(scope.row.mainImage)"
@click="onPreview(scope.row.imageUrls)"
></el-image>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="封样名称" align="center" prop="materialName" width="250">
label="封样名称"
align="center"
prop="materialName"
width="250"
>
<template slot-scope="scope"> <template slot-scope="scope">
<div>{{ scope.row.materialName }}</div> <div>{{ scope.row.materialName }}</div>
<div>{{ scope.row.usePosition }}</div> <div>{{ scope.row.usePosition }}</div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="品牌" align="center" prop="contractBrand" width="200">
label="品牌"
align="center"
prop="contractBrand"
width="200"
>
<template slot-scope="scope"> <template slot-scope="scope">
<div>指定{{ scope.row.contractBrand }}</div> <div>指定{{ scope.row.contractBrand }}</div>
<div>拟用{{ scope.row.useBrand }}</div> <div>拟用{{ scope.row.useBrand }}</div>
@ -118,14 +68,8 @@
<span>{{ parseTime(scope.row.sealDate, "{y}-{m}-{d} {h}:{i}") }}</span> <span>{{ parseTime(scope.row.sealDate, "{y}-{m}-{d} {h}:{i}") }}</span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="监理专员" align="center" prop="witnessUser" width="120" show-overflow-tooltip>
label="监理专员" <template slot-scope="scope">
align="center"
prop="witnessUser"
width="120"
show-overflow-tooltip
>
<template slot-scope="scope">
<div>{{ scope.row.witnessUserName }}</div> <div>{{ scope.row.witnessUserName }}</div>
<div>{{ scope.row.witnessUser }}</div> <div>{{ scope.row.witnessUser }}</div>
</template> </template>
@ -142,94 +86,43 @@
</el-table-column> </el-table-column>
<el-table-column label="会签单" align="center" prop="signFiles" width="100"> <el-table-column label="会签单" align="center" prop="signFiles" width="100">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button v-if="scope.row.signFiles != null" size="mini" type="text" icon="el-icon-paperclip"
v-if="scope.row.signFiles != null" @click="handledownloadSignFiles(scope.row)" v-hasPermi="['project:materialSeal:list']">下载会签单</el-button>
size="mini"
type="text"
icon="el-icon-paperclip"
@click="handledownloadSignFiles(scope.row)"
v-hasPermi="['project:materialSeal:list']"
>下载会签单</el-button
>
<span v-if="scope.row.signFiles == null"> - </span> <span v-if="scope.row.signFiles == null"> - </span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="变更单" align="center" prop="alterationFiles" width="100"> <el-table-column label="变更单" align="center" prop="alterationFiles" width="100">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button v-if="scope.row.alterationFiles != null" size="mini" type="text" icon="el-icon-paperclip"
v-if="scope.row.alterationFiles != null"
size="mini"
type="text"
icon="el-icon-paperclip"
@click="handledownloadAlterationFiles(scope.row)" @click="handledownloadAlterationFiles(scope.row)"
v-hasPermi="['project:materialSeal:list']" v-hasPermi="['project:materialSeal:list']">下载变更单</el-button>
>下载变更单</el-button
>
<span v-if="scope.row.signFiles == null"> - </span> <span v-if="scope.row.signFiles == null"> - </span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="操作" align="center" fixed="right" class-name="small-padding fixed-width" width="150">
label="操作"
align="center"
fixed="right"
class-name="small-padding fixed-width"
width="150"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button v-if="scope.row.approveStatus != null" size="mini" type="text" icon="el-icon-tickets"
v-if="scope.row.approveStatus != null" @click="handleAuditinfo(scope.row)">审批日志</el-button>
size="mini" <el-button v-if="scope.row.approveStatus != '4'" size="mini" type="text" icon="el-icon-edit"
type="text" @click="handleUpdate(scope.row)" v-hasPermi="['project:materialSeal:edit']">修改</el-button>
icon="el-icon-tickets" <el-button v-if="scope.row.approveStatus != '4'" size="mini" type="text" icon="el-icon-delete"
@click="handleAuditinfo(scope.row)" @click="handleDelete(scope.row)" v-hasPermi="['project:materialSeal:remove']">删除</el-button>
>审批日志</el-button
>
<el-button
v-if="scope.row.approveStatus!='4'"
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['project:materialSeal:edit']"
>修改</el-button
>
<el-button
v-if="scope.row.approveStatus!='4'"
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['project:materialSeal:remove']"
>删除</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<pagination <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
v-show="total > 0" @pagination="getList" />
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<!-- 添加或修改项目材料封样对话框 --> <!-- 添加或修改项目材料封样对话框 -->
<el-dialog :title="title" :visible.sync="open" width="780px" append-to-body :close-on-click-modal="false" :close-on-press-escape="false"> <el-dialog :title="title" :visible.sync="open" width="780px" append-to-body :close-on-click-modal="false"
:close-on-press-escape="false">
<el-form ref="form" :model="form" :rules="rules" label-width="80px"> <el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="项目名称" prop="projectName"> <el-form-item label="项目名称" prop="projectName">
<el-input <el-input v-model="form.projectName" placeholder="请输入项目名称" :disabled="true" />
v-model="form.projectName"
placeholder="请输入项目名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="单位名称" prop="deptName"> <el-form-item label="单位名称" prop="deptName">
<el-input <el-input v-model="form.deptName" placeholder="请输入单位名称" :disabled="true" />
v-model="form.deptName"
placeholder="请输入单位名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="封样图片" prop="imageUrls"> <el-form-item label="封样图片" prop="imageUrls">
<image-upload v-model="form.imageUrls" :limit="9" /> <image-upload v-model="form.imageUrls" :limit="9" />
@ -241,69 +134,34 @@
<el-input v-model="form.usePosition" placeholder="请输入使用部位" /> <el-input v-model="form.usePosition" placeholder="请输入使用部位" />
</el-form-item> </el-form-item>
<el-form-item label="指定品牌" prop="contractBrand"> <el-form-item label="指定品牌" prop="contractBrand">
<el-input <el-input v-model="form.contractBrand" placeholder="请输入指定品牌" @change="onlyFile" />
v-model="form.contractBrand"
placeholder="请输入指定品牌"
@change="onlyFile"
/>
</el-form-item> </el-form-item>
<el-form-item label="拟用品牌" prop="useBrand"> <el-form-item label="拟用品牌" prop="useBrand">
<el-input <el-input v-model="form.useBrand" placeholder="请输入拟用品牌" @change="onlyFile" />
v-model="form.useBrand"
placeholder="请输入拟用品牌"
@change="onlyFile"
/>
</el-form-item> </el-form-item>
<el-form-item label="封样时间" prop="sealDate"> <el-form-item label="封样时间" prop="sealDate">
<el-date-picker <el-date-picker clearable v-model="form.sealDate" type="datetime" default-time="10:00:00"
clearable value-format="yyyy-MM-dd HH:mm:ss" placeholder="请选择封样时间" style="width: 100%">
v-model="form.sealDate"
type="datetime"
default-time="10:00:00"
value-format="yyyy-MM-dd HH:mm:ss"
placeholder="请选择封样时间"
style="width: 100%"
>
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
<el-form-item label="监理专员" prop="witnessUser"> <el-form-item label="监理专员" prop="witnessUser">
<el-select <el-select v-model="form.witnessUser" placeholder="请选择监理专员" filterable style="width: 100%"
v-model="form.witnessUser" @change="selectWitnessUser">
placeholder="请选择监理专员" <el-option-group v-for="group in deptUserData" :key="group.unitId + ''"
filterable :label="group.unitName + ' [' + group.unitTypeName + '] '">
style="width: 100%" <el-option v-for="item in group.userinfoList" :key="item.phonenumber"
@change="selectWitnessUser" :label="item.nickName + ' [' + item.jobTypeName + '] '" :value="item.phonenumber">
> </el-option>
<el-option-group </el-option-group>
v-for="group in deptUserData" </el-select>
:key="group.unitId + ''" </el-form-item>
:label="group.unitName + ' [' + group.unitTypeName + '] '"
>
<el-option
v-for="item in group.userinfoList"
:key="item.phonenumber"
:label="item.nickName + ' [' + item.jobTypeName + '] '"
:value="item.phonenumber"
>
</el-option>
</el-option-group>
</el-select>
</el-form-item>
<el-form-item label="会签单" prop="signFiles"> <el-form-item label="会签单" prop="signFiles">
<file-upload <file-upload v-model="form.signFiles" :limit="1" :fileType="['pdf', 'png', 'jpg', 'jpeg']"
v-model="form.signFiles" @input="fileInputSign" />
:limit="1"
:fileType="['pdf', 'png', 'jpg', 'jpeg']"
@input="fileInputSign"
/>
</el-form-item> </el-form-item>
<el-form-item label="变更单" prop="alterationFiles" v-show="true"> <el-form-item label="变更单" prop="alterationFiles" v-show="true">
<file-upload <file-upload v-model="form.alterationFiles" :limit="1" :fileType="['pdf', 'png', 'jpg', 'jpeg']"
v-model="form.alterationFiles" @input="fileInputAlteration" />
:limit="1"
:fileType="['pdf', 'png', 'jpg', 'jpeg']"
@input="fileInputAlteration"
/>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
@ -312,12 +170,7 @@
</div> </div>
</el-dialog> </el-dialog>
</el-drawer> </el-drawer>
<el-image-viewer <el-image-viewer v-if="showViewer" :on-close="closeViewer" :url-list="previewList" style="z-index: 2050" />
v-if="showViewer"
:on-close="closeViewer"
:url-list="previewList"
style="z-index: 2050"
/>
<indexDrawer ref="indexDrawer"></indexDrawer> <indexDrawer ref="indexDrawer"></indexDrawer>
</div> </div>
</template> </template>
@ -343,6 +196,7 @@ export default {
dicts: ["project_check_status"], dicts: ["project_check_status"],
data() { data() {
return { return {
canCreated:true,
showViewer: false, showViewer: false,
open: false, open: false,
isOpen: false, isOpen: false,
@ -405,13 +259,13 @@ export default {
jxz: "进行中0", jxz: "进行中0",
ywc: "已完成0", ywc: "已完成0",
}, },
deptUserData:[], deptUserData: [],
previewList: [], previewList: [],
isOnly: false, isOnly: false,
}; };
}, },
computed: {}, computed: {},
mounted() {}, mounted() { },
methods: { methods: {
fileInputSign(files) { fileInputSign(files) {
@ -467,14 +321,14 @@ export default {
this.project = project; this.project = project;
this.title = project.projectName; this.title = project.projectName;
this.isOpen = true; this.isOpen = true;
this.tabs.all="全部数据0"; this.tabs.all = "全部数据0";
this.tabs.jxz="进行中0"; this.tabs.jxz = "进行中0";
this.tabs.ywc="已完成0"; this.tabs.ywc = "已完成0";
this.queryParams.projectId = project.id; this.queryParams.projectId = project.id;
this.$api.publics this.$api.publics
.queryUnitList({ .queryUnitList({
projectId: project.id, projectId: project.id,
unitType: 2, unitTypes: [2,4],
}) })
.then((d) => { .then((d) => {
this.nodes = d.rows; this.nodes = d.rows;
@ -491,6 +345,8 @@ export default {
}, },
// //
getList() { getList() {
let tmps=this.nodes.filter(d=>d.unitId==this.unitActiveName);
this.canCreated=tmps.length>0 && tmps[0].unitType==4?false:true;
this.queryParams.deptId = this.unitActiveName; this.queryParams.deptId = this.unitActiveName;
this.queryCount() this.queryCount()
this.loading = true; this.loading = true;
@ -608,7 +464,7 @@ export default {
submitForm() { submitForm() {
this.$refs["form"].validate((valid) => { this.$refs["form"].validate((valid) => {
if (valid) { if (valid) {
this.form.approveStatus="1"; this.form.approveStatus = "1";
if (this.form.id != null) { if (this.form.id != null) {
updateMaterialSeal(this.form).then((response) => { updateMaterialSeal(this.form).then((response) => {
this.$modal.msgSuccess("修改成功"); this.$modal.msgSuccess("修改成功");
@ -639,7 +495,7 @@ export default {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}) })
.catch(() => {}); .catch(() => { });
}, },
/** 导出按钮操作 */ /** 导出按钮操作 */
handleExport() { handleExport() {
@ -684,8 +540,8 @@ export default {
}, },
/** 审批日志 */ /** 审批日志 */
handleAuditinfo(row) { handleAuditinfo(row) {
row.title="材料封样"; row.title = "材料封样";
row.logType="4"; row.logType = "4";
this.$refs.indexDrawer.show(row); this.$refs.indexDrawer.show(row);
} }
}, },

View File

@ -1,42 +1,17 @@
<template> <template>
<div class="projectect-attendance-drawer"> <div class="projectect-attendance-drawer">
<el-drawer <el-drawer v-if="isOpen" :visible.sync="isOpen" direction="rtl" size="65%" style="padding-left: 20px">
v-if="isOpen"
:visible.sync="isOpen"
direction="rtl"
size="65%"
style="padding-left: 20px"
>
<template slot="title"> <template slot="title">
<div>{{ title + " 【举牌验收管理】" }}</div> <div>{{ title + " 【举牌验收管理】" }}</div>
</template> </template>
<el-tabs <el-tabs v-model="unitActiveName" style="margin-left: 20px; margin-right: 20px" @tab-click="getList">
v-model="unitActiveName" <el-tab-pane v-for="(it, idx) in nodes" :label="it.unitName + ''" :name="it.unitId + ''"
style="margin-left: 20px; margin-right: 20px" :key="idx"></el-tab-pane>
@tab-click="getList"
>
<el-tab-pane
v-for="(it, idx) in nodes"
:label="it.unitName + ''"
:name="it.unitId + ''"
:key="idx"
></el-tab-pane>
</el-tabs> </el-tabs>
<el-row <el-row :gutter="10" class="mb8" style="margin-left: 20px; margin-top: 10px; margin-right: 20px" v-if="canCreated">
:gutter="10"
class="mb8"
style="margin-left: 20px; margin-top: 10px; margin-right: 20px"
>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
type="primary" v-hasPermi="['project:projectChecking:add']">新增</el-button>
plain
icon="el-icon-plus"
size="mini"
@click="handleAdd"
v-hasPermi="['project:projectChecking:add']"
>新增</el-button
>
</el-col> </el-col>
<!-- <el-col :span="1.5"> <!-- <el-col :span="1.5">
<el-button <el-button
@ -62,100 +37,45 @@
>删除</el-button >删除</el-button
> >
</el-col> --> </el-col> -->
<right-toolbar <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
:showSearch.sync="showSearch"
@queryTable="getList"
></right-toolbar>
</el-row> </el-row>
<el-tabs <el-tabs v-model="queryParams.activeName" @tab-click="getList" style="padding-left: 20px; padding-right: 20px">
v-model="queryParams.activeName"
@tab-click="getList"
style="padding-left: 20px; padding-right: 20px"
>
<el-tab-pane :label="tabs.all" name="all"></el-tab-pane> <el-tab-pane :label="tabs.all" name="all"></el-tab-pane>
<el-tab-pane :label="tabs.jxz" name="jxz"></el-tab-pane> <el-tab-pane :label="tabs.jxz" name="jxz"></el-tab-pane>
<el-tab-pane :label="tabs.ywc" name="ywc"></el-tab-pane> <el-tab-pane :label="tabs.ywc" name="ywc"></el-tab-pane>
</el-tabs> </el-tabs>
<el-table <el-table v-loading="loading" :data="projectCheckingList" @selection-change="handleSelectionChange"
v-loading="loading" style="padding-left: 20px; padding-right: 20px" stripe>
:data="projectCheckingList"
@selection-change="handleSelectionChange"
style="padding-left: 20px; padding-right: 20px"
stripe
>
<el-table-column label="验收图片" align="center" prop="mainImage" width="80"> <el-table-column label="验收图片" align="center" prop="mainImage" width="80">
<template slot-scope="scope"> <template slot-scope="scope">
<el-image <el-image ref="preview" style="width: 50px; height: 50px" :src="getImageUrl(scope.row.mainImage)"
ref="preview" @click="onPreview(scope.row.imageUrls)"></el-image>
style="width: 50px; height: 50px"
:src="getImageUrl(scope.row.mainImage)"
@click="onPreview(scope.row.imageUrls)"
></el-image>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="验收类型" align="center" prop="dataTypeLvl1" show-overflow-tooltip>
label="验收类型"
align="center"
prop="dataTypeLvl1"
show-overflow-tooltip
>
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag :options="dict.type.project_checking_data_type_lvl1" :value="scope.row.dataTypeLvl1" />
:options="dict.type.project_checking_data_type_lvl1" <dict-tag :options="dict.type.project_checking_data_type_lvl2" :value="scope.row.dataTypeLvl2" />
:value="scope.row.dataTypeLvl1"
/>
<dict-tag
:options="dict.type.project_checking_data_type_lvl2"
:value="scope.row.dataTypeLvl2"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="验收工序部位" align="left" prop="checkWorkingPosition" show-overflow-tooltip />
label="验收工序部位"
align="left"
prop="checkWorkingPosition"
show-overflow-tooltip
/>
<el-table-column <el-table-column label="验收描述" align="left" prop="intro" show-overflow-tooltip />
label="验收描述" <el-table-column label="质量专员" align="left" prop="qualityUser" width="120" show-overflow-tooltip>
align="left"
prop="intro"
show-overflow-tooltip
/>
<el-table-column
label="质量专员"
align="left"
prop="qualityUser"
width="120"
show-overflow-tooltip
>
<template slot-scope="scope"> <template slot-scope="scope">
<div>{{ scope.row.qualityUserName }}</div> <div>{{ scope.row.qualityUserName }}</div>
<div>{{ scope.row.qualityUser }}</div> <div>{{ scope.row.qualityUser }}</div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="监理专员" align="left" prop="superviseUser" width="120" show-overflow-tooltip>
label="监理专员"
align="left"
prop="superviseUser"
width="120"
show-overflow-tooltip
>
<template slot-scope="scope"> <template slot-scope="scope">
<div>{{ scope.row.superviseUserName }}</div> <div>{{ scope.row.superviseUserName }}</div>
<div>{{ scope.row.superviseUser }}</div> <div>{{ scope.row.superviseUser }}</div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="验收时间" align="center" prop="checkingDate" width="140" show-overflow-tooltip>
label="验收时间"
align="center"
prop="checkingDate"
width="140"
show-overflow-tooltip
>
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ parseTime(scope.row.checkingDate, "{y}-{m}-{d} {h}:{i}") }}</span> <span>{{ parseTime(scope.row.checkingDate, "{y}-{m}-{d} {h}:{i}") }}</span>
</template> </template>
@ -170,200 +90,88 @@
</el-table-column> --> </el-table-column> -->
<el-table-column label="审批状态" align="center" prop="approveStatus"> <el-table-column label="审批状态" align="center" prop="approveStatus">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag :options="dict.type.project_check_status" :value="scope.row.approveStatus" />
:options="dict.type.project_check_status"
:value="scope.row.approveStatus"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="操作" align="center" fixed="right" class-name="small-padding fixed-width" width="150">
label="操作"
align="center"
fixed="right"
class-name="small-padding fixed-width"
width="150"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button v-if="scope.row.checkingFiles != null" size="mini" type="text" icon="el-icon-paperclip"
v-if="scope.row.checkingFiles != null" @click="handledownload(scope.row)" v-hasPermi="['project:projectChecking:list']">下载附件</el-button>
size="mini" <el-button v-if="scope.row.approveStatus != null" size="mini" type="text" icon="el-icon-tickets"
type="text" @click="handleAuditinfo(scope.row)">审批日志</el-button>
icon="el-icon-paperclip" <el-button v-if="scope.row.approveStatus != '4'" size="mini" type="text" icon="el-icon-edit"
@click="handledownload(scope.row)" @click="handleUpdate(scope.row)" v-hasPermi="['project:projectChecking:edit']">修改</el-button>
v-hasPermi="['project:projectChecking:list']" <el-button v-if="scope.row.approveStatus != '4'" size="mini" type="text" icon="el-icon-delete"
>下载附件</el-button @click="handleDelete(scope.row)" v-hasPermi="['project:projectChecking:remove']">删除</el-button>
>
<el-button
v-if="scope.row.approveStatus != null"
size="mini"
type="text"
icon="el-icon-tickets"
@click="handleAuditinfo(scope.row)"
>审批日志</el-button
>
<el-button
v-if="scope.row.approveStatus != '4'"
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['project:projectChecking:edit']"
>修改</el-button
>
<el-button
v-if="scope.row.approveStatus != '4'"
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['project:projectChecking:remove']"
>删除</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<pagination <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
v-show="total > 0" @pagination="getList" />
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<!-- 添加或修改项目举牌验收对话框 --> <!-- 添加或修改项目举牌验收对话框 -->
<el-dialog <el-dialog :title="title" :visible.sync="open" width="780px" append-to-body :close-on-click-modal="false"
:title="title" :close-on-press-escape="false">
:visible.sync="open"
width="780px"
append-to-body
:close-on-click-modal="false"
:close-on-press-escape="false"
>
<el-form ref="form" :model="form" :rules="rules" label-width="80px"> <el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="项目名称" prop="projectName"> <el-form-item label="项目名称" prop="projectName">
<el-input <el-input v-model="form.projectName" placeholder="请输入项目名称" :disabled="true" />
v-model="form.projectName"
placeholder="请输入项目名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="单位名称" prop="deptName"> <el-form-item label="单位名称" prop="deptName">
<el-input <el-input v-model="form.deptName" placeholder="请输入单位名称" :disabled="true" />
v-model="form.deptName"
placeholder="请输入单位名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="验收图片" prop="imageUrls"> <el-form-item label="验收图片" prop="imageUrls">
<image-upload v-model="form.imageUrls" :limit="9" /> <image-upload v-model="form.imageUrls" :limit="9" />
</el-form-item> </el-form-item>
<el-form-item label="验收类型" prop="dataTypeLvl1"> <el-form-item label="验收类型" prop="dataTypeLvl1">
<el-select <el-select v-model="form.dataTypeLvl1" placeholder="请选择验收类型" style="width: 100%">
v-model="form.dataTypeLvl1" <el-option v-for="dict in dict.type.project_checking_data_type_lvl1" :key="dict.value" :label="dict.label"
placeholder="请选择验收类型" :value="dict.value"></el-option>
style="width: 100%"
>
<el-option
v-for="dict in dict.type.project_checking_data_type_lvl1"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="类型分类" prop="dataTypeLvl2" v-if="form.dataTypeLvl1"> <el-form-item label="类型分类" prop="dataTypeLvl2" v-if="form.dataTypeLvl1">
<el-select <el-select v-model="form.dataTypeLvl2" placeholder="请选择类型分类" style="width: 100%">
v-model="form.dataTypeLvl2" <el-option v-for="dict in dict.type.project_checking_data_type_lvl2"
placeholder="请选择类型分类" v-show="form.dataTypeLvl1 == dict.raw.remark" :key="dict.value" :label="dict.label"
style="width: 100%" :value="dict.value"></el-option>
>
<el-option
v-for="dict in dict.type.project_checking_data_type_lvl2"
v-show="form.dataTypeLvl1 == dict.raw.remark"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="质量专员" prop="qualityUser"> <el-form-item label="质量专员" prop="qualityUser">
<el-select <el-select v-model="form.qualityUser" placeholder="请选择质量专员" filterable style="width: 100%"
v-model="form.qualityUser" @change="selectQualityUser">
placeholder="请选择质量专员" <el-option-group v-for="group in deptUserData2" :key="group.unitId + ''"
filterable :label="group.unitName + ' [' + group.unitTypeName + '] '">
style="width: 100%" <el-option v-for="item in group.userinfoList" :key="item.phonenumber"
@change="selectQualityUser" :label="item.nickName + ' [' + item.jobTypeName + '] '" :value="item.phonenumber">
>
<el-option-group
v-for="group in deptUserData2"
:key="group.unitId + ''"
:label="group.unitName + ' [' + group.unitTypeName + '] '"
>
<el-option
v-for="item in group.userinfoList"
:key="item.phonenumber"
:label="item.nickName + ' [' + item.jobTypeName + '] '"
:value="item.phonenumber"
>
</el-option> </el-option>
</el-option-group> </el-option-group>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="监理专员" prop="superviseUser"> <el-form-item label="监理专员" prop="superviseUser">
<el-select <el-select v-model="form.superviseUser" placeholder="请选择监理专员" filterable style="width: 100%"
v-model="form.superviseUser" @change="selectSuperviseUser">
placeholder="请选择监理专员" <el-option-group v-for="group in deptUserData" :key="group.unitId + ''"
filterable :label="group.unitName + ' [' + group.unitTypeName + '] '">
style="width: 100%" <el-option v-for="item in group.userinfoList" :key="item.phonenumber"
@change="selectSuperviseUser" :label="item.nickName + ' [' + item.jobTypeName + '] '" :value="item.phonenumber">
>
<el-option-group
v-for="group in deptUserData"
:key="group.unitId + ''"
:label="group.unitName + ' [' + group.unitTypeName + '] '"
>
<el-option
v-for="item in group.userinfoList"
:key="item.phonenumber"
:label="item.nickName + ' [' + item.jobTypeName + '] '"
:value="item.phonenumber"
>
</el-option> </el-option>
</el-option-group> </el-option-group>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="工序部位" prop="checkWorkingPosition"> <el-form-item label="工序部位" prop="checkWorkingPosition">
<el-input <el-input type="textarea" v-model="form.checkWorkingPosition" placeholder="请输入验收工序部位" />
type="textarea"
v-model="form.checkWorkingPosition"
placeholder="请输入验收工序部位"
/>
</el-form-item> </el-form-item>
<el-form-item label="验收描述" prop="intro"> <el-form-item label="验收描述" prop="intro">
<el-input v-model="form.intro" type="textarea" placeholder="请输入内容" /> <el-input v-model="form.intro" type="textarea" placeholder="请输入内容" />
</el-form-item> </el-form-item>
<el-form-item label="验收时间" prop="checkingDate"> <el-form-item label="验收时间" prop="checkingDate">
<el-date-picker <el-date-picker style="width: 100%" v-model="form.checkingDate" type="datetime" placeholder="选择日期时间"
style="width: 100%" default-time="10:00:00" value-format="yyyy-MM-dd HH:mm:ss">
v-model="form.checkingDate"
type="datetime"
placeholder="选择日期时间"
default-time="10:00:00"
value-format="yyyy-MM-dd HH:mm:ss"
>
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
<el-form-item label="验收结果" prop="checkResult" v-if="false"> <el-form-item label="验收结果" prop="checkResult" v-if="false">
<el-radio <el-radio v-model="form.checkResult" v-for="dict in dict.type.project_checking_result" :label="dict.value"
v-model="form.checkResult" :key="dict.value" border size="small">{{ dict.label }}</el-radio>
v-for="dict in dict.type.project_checking_result"
:label="dict.value"
:key="dict.value"
border
size="small"
>{{ dict.label }}</el-radio
>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
@ -372,12 +180,7 @@
</div> </div>
</el-dialog> </el-dialog>
</el-drawer> </el-drawer>
<el-image-viewer <el-image-viewer v-if="showViewer" :on-close="closeViewer" :url-list="previewList" style="z-index: 2050" />
v-if="showViewer"
:on-close="closeViewer"
:url-list="previewList"
style="z-index: 2050"
/>
<index-drawer ref="indexDrawer"></index-drawer> <index-drawer ref="indexDrawer"></index-drawer>
</div> </div>
</template> </template>
@ -403,6 +206,7 @@ export default {
dicts: ["project_check_status", "project_checking_result", "project_checking_data_type_lvl1", "project_checking_data_type_lvl2"], dicts: ["project_check_status", "project_checking_result", "project_checking_data_type_lvl1", "project_checking_data_type_lvl2"],
data() { data() {
return { return {
canCreated:true,
showViewer: false, showViewer: false,
open: false, open: false,
isOpen: false, isOpen: false,
@ -461,7 +265,7 @@ export default {
}; };
}, },
computed: {}, computed: {},
mounted() {}, mounted() { },
methods: { methods: {
getImageUrl(url) { getImageUrl(url) {
@ -488,7 +292,7 @@ export default {
this.$api.publics this.$api.publics
.queryUnitList({ .queryUnitList({
projectId: project.id, projectId: project.id,
unitType: 2, unitTypes: [2,4],
}) })
.then((d) => { .then((d) => {
this.nodes = d.rows; this.nodes = d.rows;
@ -521,6 +325,8 @@ export default {
}, },
// //
getList() { getList() {
let tmps=this.nodes.filter(d=>d.unitId==this.unitActiveName);
this.canCreated=tmps.length>0 && tmps[0].unitType==4?false:true;
this.queryParams.deptId = this.unitActiveName; this.queryParams.deptId = this.unitActiveName;
this.queryCount(); this.queryCount();
this.loading = true; this.loading = true;
@ -562,7 +368,7 @@ export default {
createTime: null, createTime: null,
updateBy: null, updateBy: null,
updateTime: null, updateTime: null,
remark: null, remark: null,
}; };
this.resetForm("form"); this.resetForm("form");
}, },
@ -651,7 +457,7 @@ export default {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}) })
.catch(() => {}); .catch(() => { });
}, },
/** 导出按钮操作 */ /** 导出按钮操作 */
handleExport() { handleExport() {

View File

@ -432,14 +432,7 @@ export default {
.sp-orange { .sp-orange {
color: orange; color: orange;
} }
.div-txt-2 {
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
text-overflow: ellipsis;
}
} }
} }
} }

View File

@ -1,42 +1,17 @@
<template> <template>
<div class="projectect-attendance-drawer"> <div class="projectect-attendance-drawer">
<el-drawer <el-drawer v-if="isOpen" :visible.sync="isOpen" direction="rtl" size="65%" style="padding-left: 20px">
v-if="isOpen"
:visible.sync="isOpen"
direction="rtl"
size="65%"
style="padding-left: 20px"
>
<template slot="title"> <template slot="title">
<div>{{ title + " 【实测实量管理】" }}</div> <div>{{ title + " 【实测实量管理】" }}</div>
</template> </template>
<el-tabs <el-tabs v-model="unitActiveName" style="margin-left: 20px; margin-right: 20px" @tab-click="getList">
v-model="unitActiveName" <el-tab-pane v-for="(it, idx) in nodes" :label="it.unitName + ''" :name="it.unitId + ''"
style="margin-left: 20px; margin-right: 20px" :key="idx"></el-tab-pane>
@tab-click="getList"
>
<el-tab-pane
v-for="(it, idx) in nodes"
:label="it.unitName + ''"
:name="it.unitId + ''"
:key="idx"
></el-tab-pane>
</el-tabs> </el-tabs>
<el-row <el-row :gutter="10" class="mb8" style="margin-left: 20px; margin-top: 10px; margin-right: 20px" v-if="canCreated">
:gutter="10"
class="mb8"
style="margin-left: 20px; margin-top: 10px; margin-right: 20px"
>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
type="primary" v-hasPermi="['project:projectMeasure:add']">新增</el-button>
plain
icon="el-icon-plus"
size="mini"
@click="handleAdd"
v-hasPermi="['project:projectMeasure:add']"
>新增</el-button
>
</el-col> </el-col>
<!-- <el-col :span="1.5"> <!-- <el-col :span="1.5">
<el-button <el-button
@ -62,71 +37,39 @@
>删除</el-button >删除</el-button
> >
</el-col> --> </el-col> -->
<right-toolbar <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
:showSearch.sync="showSearch"
@queryTable="getList"
></right-toolbar>
</el-row> </el-row>
<el-tabs <el-tabs v-model="queryParams.activeName" @tab-click="getList" style="margin-left: 25px; margin-right: 25px">
v-model="queryParams.activeName"
@tab-click="getList"
style="margin-left: 25px; margin-right: 25px"
>
<el-tab-pane :label="tabs.all" name="all"></el-tab-pane> <el-tab-pane :label="tabs.all" name="all"></el-tab-pane>
<el-tab-pane :label="tabs.jxz" name="jxz"></el-tab-pane> <el-tab-pane :label="tabs.jxz" name="jxz"></el-tab-pane>
<el-tab-pane :label="tabs.ywc" name="ywc"></el-tab-pane> <el-tab-pane :label="tabs.ywc" name="ywc"></el-tab-pane>
</el-tabs> </el-tabs>
<el-table <el-table v-loading="loading" :data="projectMeasureList" @selection-change="handleSelectionChange" stripe>
v-loading="loading"
:data="projectMeasureList"
@selection-change="handleSelectionChange" stripe
>
<el-table-column label="测量图片" align="center" prop="mainImage" width="80"> <el-table-column label="测量图片" align="center" prop="mainImage" width="80">
<template slot-scope="scope"> <template slot-scope="scope">
<el-image <el-image ref="preview" style="width: 50px; height: 50px" :src="getImageUrl(scope.row.mainImage)"
ref="preview" @click="onPreview(scope.row.imageUrls)"></el-image>
style="width: 50px; height: 50px"
:src="getImageUrl(scope.row.mainImage)"
@click="onPreview(scope.row.imageUrls)"
></el-image>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="测量类型" align="center" prop="measureType"> <el-table-column label="测量类型" align="center" prop="measureType">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag :options="dict.type.project_measure_type" :value="scope.row.measureType" />
:options="dict.type.project_measure_type"
:value="scope.row.measureType"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="测量内容" align="center" prop="measureInfo"> <el-table-column label="测量内容" align="center" prop="measureInfo">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag :options="dict.type.project_measure_info_type" :value="scope.row.measureInfo" />
:options="dict.type.project_measure_info_type"
:value="scope.row.measureInfo"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="测量部位" align="center" prop="measurePosition" width="150" show-overflow-tooltip />
label="测量部位"
align="center"
prop="measurePosition"
width="150"
show-overflow-tooltip
/>
<el-table-column label="测量时间" align="center" prop="measureTime" width="160"> <el-table-column label="测量时间" align="center" prop="measureTime" width="160">
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ parseTime(scope.row.measureTime, "{y}-{m}-{d}") }}</span> <span>{{ parseTime(scope.row.measureTime, "{y}-{m}-{d}") }}</span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="测量点位" align="center" prop="measurePointPosition" show-overflow-tooltip />
label="测量点位"
align="center"
prop="measurePointPosition"
show-overflow-tooltip
/>
<!-- <el-table-column label="测量结果" align="center" prop="measureResult"> <!-- <el-table-column label="测量结果" align="center" prop="measureResult">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag
@ -140,133 +83,58 @@
<dict-tag :options="dict.type.project_check_status" :value="scope.row.approveStatus" /> <dict-tag :options="dict.type.project_check_status" :value="scope.row.approveStatus" />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="质量专员" align="center" prop="qualityUser" width="100" show-overflow-tooltip>
label="质量专员"
align="center"
prop="qualityUser"
width="100"
show-overflow-tooltip
>
<template slot-scope="scope"> <template slot-scope="scope">
<div>{{ scope.row.qualityUserName }}</div> <div>{{ scope.row.qualityUserName }}</div>
<div>{{ scope.row.qualityUser }}</div> <div>{{ scope.row.qualityUser }}</div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="监理专员" align="left" prop="superviseUser" width="100" show-overflow-tooltip>
label="监理专员"
align="left"
prop="superviseUser"
width="100"
show-overflow-tooltip
>
<template slot-scope="scope"> <template slot-scope="scope">
<div>{{ scope.row.superviseUserName }}</div> <div>{{ scope.row.superviseUserName }}</div>
<div>{{ scope.row.superviseUser }}</div> <div>{{ scope.row.superviseUser }}</div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="操作" align="center" fixed="right" class-name="small-padding fixed-width" width="150">
label="操作"
align="center"
fixed="right"
class-name="small-padding fixed-width"
width="150"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button v-if="scope.row.measureFiles != null" size="mini" type="text" icon="el-icon-paperclip"
v-if="scope.row.measureFiles != null" @click="handledownload(scope.row)" v-hasPermi="['project:projectMeasure:list']">下载附件</el-button>
size="mini" <el-button v-if="scope.row.approveStatus != null" size="mini" type="text" icon="el-icon-tickets"
type="text" @click="handleAuditinfo(scope.row)">审批日志</el-button>
icon="el-icon-paperclip" <el-button v-if="scope.row.approveStatus != '4'" size="mini" type="text" icon="el-icon-edit"
@click="handledownload(scope.row)" @click="handleUpdate(scope.row)" v-hasPermi="['project:projectMeasure:edit']">修改</el-button>
v-hasPermi="['project:projectMeasure:list']" <el-button v-if="scope.row.approveStatus != '4'" size="mini" type="text" icon="el-icon-delete"
>下载附件</el-button @click="handleDelete(scope.row)" v-hasPermi="['project:projectMeasure:remove']">删除</el-button>
>
<el-button
v-if="scope.row.approveStatus != null"
size="mini"
type="text"
icon="el-icon-tickets"
@click="handleAuditinfo(scope.row)"
>审批日志</el-button
>
<el-button
v-if="scope.row.approveStatus != '4'"
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['project:projectMeasure:edit']"
>修改</el-button
>
<el-button
v-if="scope.row.approveStatus != '4'"
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['project:projectMeasure:remove']"
>删除</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<pagination <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
v-show="total > 0" @pagination="getList" />
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<!-- 添加或修改实测实量对话框 --> <!-- 添加或修改实测实量对话框 -->
<el-dialog :title="title" :visible.sync="open" width="780px" append-to-body :close-on-click-modal="false" :close-on-press-escape="false"> <el-dialog :title="title" :visible.sync="open" width="780px" append-to-body :close-on-click-modal="false"
:close-on-press-escape="false">
<el-form ref="form" :model="form" :rules="rules" label-width="80px"> <el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="项目名称" prop="projectName"> <el-form-item label="项目名称" prop="projectName">
<el-input <el-input v-model="form.projectName" placeholder="请输入项目名称" :disabled="true" />
v-model="form.projectName"
placeholder="请输入项目名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="单位名称" prop="deptName"> <el-form-item label="单位名称" prop="deptName">
<el-input <el-input v-model="form.deptName" placeholder="请输入单位名称" :disabled="true" />
v-model="form.deptName"
placeholder="请输入单位名称"
:disabled="true"
/>
</el-form-item> </el-form-item>
<el-form-item label="测量图片" prop="imageUrls"> <el-form-item label="测量图片" prop="imageUrls">
<image-upload v-model="form.imageUrls" :limit="9" /> <image-upload v-model="form.imageUrls" :limit="9" />
</el-form-item> </el-form-item>
<el-form-item label="测量类型" prop="measureType"> <el-form-item label="测量类型" prop="measureType">
<el-select <el-select v-model="form.measureType" placeholder="请选择测量类型" style="width: 100%" @change="selectMeasureType">
v-model="form.measureType" <el-option v-for="dict in dict.type.project_measure_type" :key="dict.value" :label="dict.label"
placeholder="请选择测量类型" :value="dict.value"></el-option>
style="width: 100%"
@change="selectMeasureType"
>
<el-option
v-for="dict in dict.type.project_measure_type"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="测量内容" prop="measureInfo"> <el-form-item label="测量内容" prop="measureInfo">
<el-select <el-select v-model="form.measureInfo" placeholder="请选择测量内容" style="width: 100%">
v-model="form.measureInfo" <el-option v-for="dict in dict.type.project_measure_info_type" v-show="showInfoType(dict)"
placeholder="请选择测量内容" :key="dict.value" :label="dict.label" :value="dict.value"></el-option>
style="width: 100%"
>
<el-option
v-for="dict in dict.type.project_measure_info_type"
v-show="showInfoType(dict)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="测量部位" prop="measurePosition"> <el-form-item label="测量部位" prop="measurePosition">
@ -276,64 +144,34 @@
<el-input v-model="form.measurePointPosition" placeholder="请输入测量点位" /> <el-input v-model="form.measurePointPosition" placeholder="请输入测量点位" />
</el-form-item> </el-form-item>
<el-form-item label="质量专员" prop="qualityUser"> <el-form-item label="质量专员" prop="qualityUser">
<el-select <el-select v-model="form.qualityUser" placeholder="请选择质量专员" filterable style="width: 100%"
v-model="form.qualityUser" @change="selectQualityUser">
placeholder="请选择质量专员" <el-option-group v-for="group in deptUserData2" :key="group.unitId + ''"
filterable :label="group.unitName + ' [' + group.unitTypeName + '] '">
style="width: 100%" <el-option v-for="item in group.userinfoList" :key="item.phonenumber"
@change="selectQualityUser" :label="item.nickName + ' [' + item.jobTypeName + '] '" :value="item.phonenumber">
>
<el-option-group
v-for="group in deptUserData2"
:key="group.unitId + ''"
:label="group.unitName + ' [' + group.unitTypeName + '] '"
>
<el-option
v-for="item in group.userinfoList"
:key="item.phonenumber"
:label="item.nickName + ' [' + item.jobTypeName + '] '"
:value="item.phonenumber"
>
</el-option> </el-option>
</el-option-group> </el-option-group>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="监理专员" prop="superviseUser"> <el-form-item label="监理专员" prop="superviseUser">
<el-select <el-select v-model="form.superviseUser" placeholder="请选择监理专员" filterable style="width: 100%"
v-model="form.superviseUser" @change="selectSuperviseUser">
placeholder="请选择监理专员" <el-option-group v-for="group in deptUserData" :key="group.unitId + ''"
filterable :label="group.unitName + ' [' + group.unitTypeName + '] '">
style="width: 100%" <el-option v-for="item in group.userinfoList" :key="item.phonenumber"
@change="selectSuperviseUser" :label="item.nickName + ' [' + item.jobTypeName + '] '" :value="item.phonenumber">
>
<el-option-group
v-for="group in deptUserData"
:key="group.unitId + ''"
:label="group.unitName + ' [' + group.unitTypeName + '] '"
>
<el-option
v-for="item in group.userinfoList"
:key="item.phonenumber"
:label="item.nickName + ' [' + item.jobTypeName + '] '"
:value="item.phonenumber"
>
</el-option> </el-option>
</el-option-group> </el-option-group>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="测量时间" prop="measureTime"> <el-form-item label="测量时间" prop="measureTime">
<el-date-picker <el-date-picker clearable v-model="form.measureTime" type="date" value-format="yyyy-MM-dd"
clearable placeholder="请选择测量时间" style="width: 100%">
v-model="form.measureTime"
type="date"
value-format="yyyy-MM-dd"
placeholder="请选择测量时间"
style="width: 100%"
>
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
<el-form-item label="测量附件" prop="measureFiles"> <el-form-item label="测量附件" prop="measureFiles">
<file-upload v-model="form.measureFiles" :limit="9" @input="fileInput"/> <file-upload v-model="form.measureFiles" :limit="9" @input="fileInput" />
</el-form-item> </el-form-item>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
@ -342,12 +180,7 @@
</div> </div>
</el-dialog> </el-dialog>
</el-drawer> </el-drawer>
<el-image-viewer <el-image-viewer v-if="showViewer" :on-close="closeViewer" :url-list="previewList" style="z-index: 2050" />
v-if="showViewer"
:on-close="closeViewer"
:url-list="previewList"
style="z-index: 2050"
/>
<indexDrawer ref="indexDrawer"></indexDrawer> <indexDrawer ref="indexDrawer"></indexDrawer>
</div> </div>
</template> </template>
@ -370,9 +203,10 @@ export default {
indexDrawer, indexDrawer,
ElImageViewer, ElImageViewer,
}, },
dicts: ["project_check_status","project_measure_type", "project_checking_result", "project_measure_info_type"], dicts: ["project_check_status", "project_measure_type", "project_checking_result", "project_measure_info_type"],
data() { data() {
return { return {
canCreated:true,
showViewer: false, showViewer: false,
open: false, open: false,
isOpen: false, isOpen: false,
@ -380,7 +214,7 @@ export default {
title: "", title: "",
isUnit: true, isUnit: true,
nodes: [], nodes: [],
form: {measureType:"",measureInfo:""}, form: { measureType: "", measureInfo: "" },
rules: { rules: {
imageUrls: [{ required: true, message: "请上传测量图片", trigger: "blur" }], imageUrls: [{ required: true, message: "请上传测量图片", trigger: "blur" }],
measureType: [{ required: true, message: "请选择测量类型", trigger: "blur" }], measureType: [{ required: true, message: "请选择测量类型", trigger: "blur" }],
@ -427,12 +261,12 @@ export default {
ywc: "已完成0", ywc: "已完成0",
}, },
deptUserData: [], deptUserData: [],
deptUserData2:[], deptUserData2: [],
previewList: [], previewList: [],
}; };
}, },
computed: {}, computed: {},
mounted() {}, mounted() { },
methods: { methods: {
fileInput(files) { fileInput(files) {
let fileUrls = null; let fileUrls = null;
@ -445,17 +279,17 @@ export default {
} }
this.form.measureFiles = fileUrls; this.form.measureFiles = fileUrls;
}, },
selectMeasureType(val){ selectMeasureType(val) {
this.form.measureInfo=""; this.form.measureInfo = "";
}, },
showInfoType(dict){ showInfoType(dict) {
if(this.form.measureType){ if (this.form.measureType) {
if(this.form.measureType=='6'){ if (this.form.measureType == '6') {
return dict.raw.remark == 'gjgc'; return dict.raw.remark == 'gjgc';
}else{ } else {
return dict.raw.remark == null; return dict.raw.remark == null;
} }
}else{ } else {
return false; return false;
} }
}, },
@ -476,14 +310,14 @@ export default {
this.project = project; this.project = project;
this.title = project.projectName; this.title = project.projectName;
this.isOpen = true; this.isOpen = true;
this.tabs.all="全部数据0"; this.tabs.all = "全部数据0";
this.tabs.jxz="进行中0"; this.tabs.jxz = "进行中0";
this.tabs.ywc="已完成0"; this.tabs.ywc = "已完成0";
this.queryParams.projectId = project.id; this.queryParams.projectId = project.id;
this.$api.publics this.$api.publics
.queryUnitList({ .queryUnitList({
projectId: project.id, projectId: project.id,
unitType: 2 unitTypes: [2,4]
}) })
.then((d) => { .then((d) => {
this.nodes = d.rows; this.nodes = d.rows;
@ -516,6 +350,8 @@ export default {
}, },
// //
getList() { getList() {
let tmps=this.nodes.filter(d=>d.unitId==this.unitActiveName);
this.canCreated=tmps.length>0 && tmps[0].unitType==4?false:true;
this.queryParams.deptId = this.unitActiveName; this.queryParams.deptId = this.unitActiveName;
this.queryCount(); this.queryCount();
this.loading = true; this.loading = true;
@ -616,7 +452,7 @@ export default {
submitForm() { submitForm() {
this.$refs["form"].validate((valid) => { this.$refs["form"].validate((valid) => {
if (valid) { if (valid) {
this.form.approveStatus="1"; this.form.approveStatus = "1";
if (this.form.id) { if (this.form.id) {
updateProjectMeasure(this.form).then((response) => { updateProjectMeasure(this.form).then((response) => {
this.$modal.msgSuccess("修改成功"); this.$modal.msgSuccess("修改成功");
@ -647,7 +483,7 @@ export default {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}) })
.catch(() => {}); .catch(() => { });
}, },
/** 导出按钮操作 */ /** 导出按钮操作 */
handleExport() { handleExport() {
@ -688,8 +524,8 @@ export default {
}, },
/** 审批日志 */ /** 审批日志 */
handleAuditinfo(row) { handleAuditinfo(row) {
row.title="实测实量"; row.title = "实测实量";
row.logType="2"; row.logType = "2";
this.$refs.indexDrawer.show(row); this.$refs.indexDrawer.show(row);
} }
}, },

View File

@ -1,196 +1,85 @@
<template> <template>
<div class="app-container"> <div class="app-container">
<el-form <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
:model="queryParams"
ref="queryForm"
size="small"
:inline="true"
v-show="showSearch"
label-width="68px"
>
<el-form-item label="项目名称" prop="projectName"> <el-form-item label="项目名称" prop="projectName">
<el-input <el-input v-model="queryParams.projectName" placeholder="请输入项目名称" clearable @keyup.enter.native="handleQuery" />
v-model="queryParams.projectName"
placeholder="请输入项目名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item> </el-form-item>
<el-form-item label="项目地址" prop="projectAddress"> <el-form-item label="项目地址" prop="projectAddress">
<el-input <el-input v-model="queryParams.projectAddress" placeholder="请输入项目地址" clearable
v-model="queryParams.projectAddress" @keyup.enter.native="handleQuery" />
placeholder="请输入项目地址"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item> </el-form-item>
<el-form-item label="项目分类" prop="projectType"> <el-form-item label="项目分类" prop="projectType">
<el-select <el-select v-model="queryParams.projectType" placeholder="请选择项目分类" clearable>
v-model="queryParams.projectType" <el-option v-for="dict in dict.type.project_category" :key="dict.value" :label="dict.label"
placeholder="请选择项目分类" :value="dict.value" />
clearable
>
<el-option
v-for="dict in dict.type.project_category"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="项目等级" prop="projiectLevel"> <el-form-item label="项目等级" prop="projiectLevel">
<el-select <el-select v-model="queryParams.projiectLevel" placeholder="请选择项目等级" clearable>
v-model="queryParams.projiectLevel" <el-option v-for="dict in dict.type.project_level" :key="dict.value" :label="dict.label"
placeholder="请选择项目等级" :value="dict.value" />
clearable
>
<el-option
v-for="dict in dict.type.project_level"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="建设类型" prop="projectNature"> <el-form-item label="建设类型" prop="projectNature">
<el-select <el-select v-model="queryParams.projectNature" placeholder="请选择项目建设类型" clearable>
v-model="queryParams.projectNature" <el-option v-for="dict in dict.type.project_build_type" :key="dict.value" :label="dict.label"
placeholder="请选择项目建设类型" :value="dict.value" />
clearable
>
<el-option
v-for="dict in dict.type.project_build_type"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="重要等级" prop="weightType"> <el-form-item label="重要等级" prop="weightType">
<el-select <el-select v-model="queryParams.weightType" placeholder="请选择重要等级" clearable>
v-model="queryParams.weightType" <el-option v-for="dict in dict.type.sur_project_weight" :key="dict.value" :label="dict.label"
placeholder="请选择重要等级" :value="dict.value" />
clearable
>
<el-option
v-for="dict in dict.type.sur_project_weight"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="责任主体" prop="deptId" v-hasPermi="['project:project:zgs']"> <el-form-item label="责任主体" prop="deptId" v-hasPermi="['project:project:zgs']">
<el-select v-model="queryParams.deptId" placeholder="请选择责任主体" clearable> <el-select v-model="queryParams.deptId" placeholder="请选择责任主体" clearable>
<el-option <el-option v-for="dict in depts" :key="dict.deptId" :label="dict.deptName" :value="dict.deptId"></el-option>
v-for="dict in depts"
:key="dict.deptId"
:label="dict.deptName"
:value="dict.deptId"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery" <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery"></el-button>
>搜索</el-button
>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"></el-button> <el-button icon="el-icon-refresh" size="mini" @click="resetQuery"></el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<el-row :gutter="10" class="mb8"> <el-row :gutter="10" class="mb8">
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
type="primary" v-hasPermi="['project:surProject:add']">新增</el-button>
plain
icon="el-icon-plus"
size="mini"
@click="handleAdd"
v-hasPermi="['project:surProject:add']"
>新增</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button type="success" plain icon="el-icon-edit" size="mini" :disabled="single" @click="handleUpdate"
type="success" v-hasPermi="['project:surProject:edit']">修改</el-button>
plain
icon="el-icon-edit"
size="mini"
:disabled="single"
@click="handleUpdate"
v-hasPermi="['project:surProject:edit']"
>修改</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button type="danger" plain icon="el-icon-delete" size="mini" :disabled="multiple" @click="handleDelete"
type="danger" v-hasPermi="['project:surProject:remove']">删除</el-button>
plain
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
v-hasPermi="['project:surProject:remove']"
>删除</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport"
type="warning" v-hasPermi="['project:surProject:export']">导出</el-button>
plain
icon="el-icon-download"
size="mini"
@click="handleExport"
v-hasPermi="['project:surProject:export']"
>导出</el-button
>
</el-col> </el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
</el-row> </el-row>
<el-table <el-table v-loading="loading" :data="surProjectList" @selection-change="handleSelectionChange" stripe>
v-loading="loading"
:data="surProjectList"
@selection-change="handleSelectionChange" stripe
>
<el-table-column type="selection" width="55" align="center" /> <el-table-column type="selection" width="55" align="center" />
<el-table-column <el-table-column label="项目名称" align="left" prop="projectName" width="200" class-name="small-padding fixed-width"
label="项目名称" fixed="left" show-overflow-tooltip />
align="left"
prop="projectName"
width="200"
class-name="small-padding fixed-width"
fixed="left"
show-overflow-tooltip
/>
<el-table-column label="责任主体" align="center" prop="deptName" /> <el-table-column label="责任主体" align="center" prop="deptName" />
<el-table-column <el-table-column label="父级项目" align="left" prop="paretProjectName" width="200" show-overflow-tooltip />
label="父级项目" <el-table-column label="项目简称" align="left" prop="simpleName" width="200" show-overflow-tooltip />
align="left"
prop="paretProjectName"
width="200"
show-overflow-tooltip
/>
<el-table-column
label="项目简称"
align="left"
prop="simpleName"
width="200"
show-overflow-tooltip
/>
<el-table-column label="项目分类" align="center" prop="projectType"> <el-table-column label="项目分类" align="center" prop="projectType">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag :options="dict.type.project_category" :value="scope.row.projectType" />
:options="dict.type.project_category"
:value="scope.row.projectType"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="项目等级" align="center" prop="projiectLevel"> <el-table-column label="项目等级" align="center" prop="projiectLevel">
@ -199,353 +88,150 @@
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="项目区域" align="center" prop="projectRegionalName" /> <el-table-column label="项目区域" align="center" prop="projectRegionalName" />
<el-table-column <el-table-column label="进度展示" align="center" v-if="checkPermi(['project:surProject:progressVisible'])">
label="进度展示"
align="center"
v-if="checkPermi(['project:surProject:progressVisible'])"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-switch <el-switch v-model="scope.row.progressVisible" active-value="0" inactive-value="1"
v-model="scope.row.progressVisible" @change="setVisibleStatus(scope.row, $event)"></el-switch>
active-value="0"
inactive-value="1"
@change="setVisibleStatus(scope.row, $event)"
></el-switch>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="项目排序" align="center" width="150" v-if="checkPermi(['project:surProject:projectSort'])">
label="项目排序"
align="center"
width="150"
v-if="checkPermi(['project:surProject:projectSort'])"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-input-number <el-input-number size="mini" v-model="scope.row.projectSort" :min="1" :max="999"
size="mini" @change="setProjectSort(scope.row, $event)"></el-input-number>
v-model="scope.row.projectSort"
:min="1"
:max="999"
@change="setProjectSort(scope.row, $event)"
></el-input-number>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="建设类型" align="left" prop="projectNature" width="120" show-overflow-tooltip>
label="建设类型"
align="left"
prop="projectNature"
width="120"
show-overflow-tooltip
>
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag :options="dict.type.project_build_type" :value="scope.row.projectNature" />
:options="dict.type.project_build_type"
:value="scope.row.projectNature"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="重要等级" align="left" prop="weightType" width="120" show-overflow-tooltip>
label="重要等级"
align="left"
prop="weightType"
width="120"
show-overflow-tooltip
>
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag <dict-tag :options="dict.type.sur_project_weight" :value="scope.row.weightType" />
:options="dict.type.sur_project_weight"
:value="scope.row.weightType"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="项目地址" align="left" prop="projectAddress" width="200" show-overflow-tooltip />
label="项目地址" <el-table-column label="项目负责人" align="center" prop="projectPerson" width="100" />
align="left" <el-table-column label="负责人电话" align="center" prop="projectPhone" width="110" />
prop="projectAddress"
width="200"
show-overflow-tooltip
/>
<el-table-column
label="项目负责人"
align="center"
prop="projectPerson"
width="100"
/>
<el-table-column
label="负责人电话"
align="center"
prop="projectPhone"
width="110"
/>
<el-table-column label="工程期限" align="center" prop="projectTimeLimit" /> <el-table-column label="工程期限" align="center" prop="projectTimeLimit" />
<el-table-column label="总投资" align="center" prop="totalInvestment" /> <el-table-column label="总投资" align="center" prop="totalInvestment" />
<el-table-column label="开累产值" align="center" prop="totalOutputValue" /> <el-table-column label="开累产值" align="center" prop="totalOutputValue" />
<el-table-column <el-table-column label="计划完成时间" align="center" prop="plannedCompletionTime" width="120" show-overflow-tooltip>
label="计划完成时间"
align="center"
prop="plannedCompletionTime"
width="120"
show-overflow-tooltip
>
<template slot-scope="{ row }">{{ row.plannedCompletionTime }}</template> <template slot-scope="{ row }">{{ row.plannedCompletionTime }}</template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="计划开工时间" align="center" prop="scheduledStartTime" width="120" show-overflow-tooltip>
label="计划开工时间"
align="center"
prop="scheduledStartTime"
width="120"
show-overflow-tooltip
>
<template slot-scope="{ row }">{{ row.scheduledStartTime }}</template> <template slot-scope="{ row }">{{ row.scheduledStartTime }}</template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="实际开工时间" align="center" prop="actualOperatingTime" width="120" show-overflow-tooltip>
label="实际开工时间"
align="center"
prop="actualOperatingTime"
width="120"
show-overflow-tooltip
>
<template slot-scope="{ row }">{{ row.actualOperatingTime }}</template> <template slot-scope="{ row }">{{ row.actualOperatingTime }}</template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column label="实际完工时间" align="center" prop="actualCompletionTime" width="120" show-overflow-tooltip>
label="实际完工时间"
align="center"
prop="actualCompletionTime"
width="120"
show-overflow-tooltip
>
<template slot-scope="{ row }">{{ row.actualCompletionTime }}</template> <template slot-scope="{ row }">{{ row.actualCompletionTime }}</template>
</el-table-column> </el-table-column>
<el-table-column label="合同总额" align="center" prop="contractAmount" width="80" /> <el-table-column label="合同总额" align="center" prop="contractAmount" width="80" />
<el-table-column label="付款金额" align="center" prop="paidAmount" width="80" /> <el-table-column label="付款金额" align="center" prop="paidAmount" width="80" />
<el-table-column <el-table-column label="挂账金额" align="center" prop="onAccountAmount" width="80" />
label="挂账金额"
align="center"
prop="onAccountAmount"
width="80"
/>
<el-table-column label="劳务人员" align="center" prop="servicePersonnel" /> <el-table-column label="劳务人员" align="center" prop="servicePersonnel" />
<el-table-column label="监理人员" align="center" prop="supervisorPersonnel" /> <el-table-column label="监理人员" align="center" prop="supervisorPersonnel" />
<el-table-column label="总包人员" align="center" prop="generalContractor" /> <el-table-column label="总包人员" align="center" prop="generalContractor" />
<el-table-column <el-table-column label="操作" align="center" class-name="small-padding fixed-width" fixed="right" width="240">
label="操作"
align="center"
class-name="small-padding fixed-width"
fixed="right"
width="240"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button size="mini" type="text" icon="el-icon-time" @click="prjProcessMgr(scope.row)"
size="mini" v-hasPermi="['project:surProject:edit']">进度管理</el-button>
type="text" <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
icon="el-icon-time" v-hasPermi="['project:surProject:edit']">修改项目</el-button>
@click="prjProcessMgr(scope.row)" <el-button size="mini" type="text" icon="el-icon-user-solid" @click="handleProjectUserinfo(scope.row)"
v-hasPermi="['project:surProject:edit']" v-hasPermi="['project:surProjectUserInfo:list']">项目人员</el-button>
>进度管理</el-button <el-dropdown size="mini" @command="(command) => handleCommand(command, scope.row)" v-hasPermi="[
> 'project:assess:list',
<el-button 'project:build_node_data:list',
size="mini" 'project:projectChecking:list',
type="text" 'work:workTrain:list',
icon="el-icon-edit" 'work:emergencyDrill:list',
@click="handleUpdate(scope.row)" 'project:surProjectInsurance:list',
v-hasPermi="['project:surProject:edit']" 'project:surProjectSpecial:list',
>修改项目</el-button 'project:projectMeasure:list',
> 'project:materialSeal:list',
<el-button 'project:projectDeptWroks:list',
size="mini" 'project:surProjectAttendance:add',
type="text" 'video:videoConfig:list',
icon="el-icon-user-solid" 'video:aiBoxProjectConfig:list',
@click="handleProjectUserinfo(scope.row)" 'project:checkDetection:list',
v-hasPermi="['project:surProjectUserInfo:list']" 'project:costOutput:edit',
>项目人员</el-button 'project:projectStandard:edit',
> 'project:attendanceWorker:list',
<el-dropdown 'project:attendance:list',
size="mini" 'project:surProject:remove',
@command="(command) => handleCommand(command, scope.row)" 'project:projectCommittee:list',
v-hasPermi="[ ]">
'project:assess:list', <el-button size="mini" type="text" icon="el-icon-d-arrow-right">更多操作</el-button>
'project:build_node_data:list',
'project:projectChecking:list',
'work:workTrain:list',
'work:emergencyDrill:list',
'project:surProjectInsurance:list',
'project:surProjectSpecial:list',
'project:projectMeasure:list',
'project:materialSeal:list',
'project:projectDeptWroks:list',
'project:surProjectAttendance:add',
'video:videoConfig:list',
'video:aiBoxProjectConfig:list',
'project:checkDetection:list',
'project:costOutput:edit',
'project:projectStandard:edit',
'project:attendanceWorker:list',
'project:attendance:list',
'project:surProject:remove',
]"
>
<el-button size="mini" type="text" icon="el-icon-d-arrow-right"
>更多操作</el-button
>
<el-dropdown-menu slot="dropdown"> <el-dropdown-menu slot="dropdown">
<el-dropdown-item <el-dropdown-item command="handleAssess" icon="el-icon-coordinate"
command="handleAssess" v-hasPermi="['project:assess:list']">季度考核管理</el-dropdown-item>
icon="el-icon-coordinate" <el-dropdown-item command="handleBuildNode" icon="el-icon-data-analysis"
v-hasPermi="['project:assess:list']" v-hasPermi="['project:build_node_data:list']">计划节点管理</el-dropdown-item>
>季度考核管理</el-dropdown-item <el-dropdown-item command="handleCommittee" icon="el-icon-s-order" v-if="1==2"
> v-hasPermi="['project:projectCommittee:list']">工委会管理</el-dropdown-item>
<el-dropdown-item <el-dropdown-item v-if="1 == 2" command="handleDesign" icon="el-icon-orange"
command="handleBuildNode" v-hasPermi="['project:projectDesign:list']">设计管理</el-dropdown-item>
icon="el-icon-data-analysis" <el-dropdown-item command="handleProjectChecking" icon="el-icon-s-help"
v-hasPermi="['project:build_node_data:list']" v-hasPermi="['project:projectChecking:list']">举牌验收管理</el-dropdown-item>
>计划节点管理</el-dropdown-item <el-dropdown-item command="handleWorkTrain" icon="el-icon-notebook-2"
> v-hasPermi="['work:workTrain:list']">项目教育培训</el-dropdown-item>
<el-dropdown-item v-if="1==2" <el-dropdown-item command="handleEmergencyDrill" icon="el-icon-first-aid-kit"
command="handleDesign" v-hasPermi="['work:emergencyDrill:list']">项目应急演练</el-dropdown-item>
icon="el-icon-orange" <el-dropdown-item command="handleProjectInsurance" icon="el-icon-star-on"
v-hasPermi="['project:projectDesign:list']" v-hasPermi="['project:surProjectInsurance:list']">项目保险管理</el-dropdown-item>
>设计管理</el-dropdown-item <el-dropdown-item command="handleProjectSpecial" icon="el-icon-user"
> v-hasPermi="['project:surProjectSpecial:list']">项目特种人员</el-dropdown-item>
<el-dropdown-item <el-dropdown-item command="handleProjectMeasure" icon="el-icon-s-operation"
command="handleProjectChecking" v-hasPermi="['project:projectMeasure:list']">实测实量管理</el-dropdown-item>
icon="el-icon-s-help" <el-dropdown-item command="handleProjectMaterialSeal" icon="el-icon-s-ticket"
v-hasPermi="['project:projectChecking:list']" v-hasPermi="['project:materialSeal:list']">材料封样管理</el-dropdown-item>
>举牌验收管理</el-dropdown-item <el-dropdown-item command="handleProjectDeptWroks" icon="el-icon-s-custom"
> v-hasPermi="['project:projectDeptWroks:list']">在岗人员管理</el-dropdown-item>
<el-dropdown-item <el-dropdown-item command="handleAttendanceData" icon="el-icon-s-grid"
command="handleWorkTrain" v-hasPermi="['project:attendance:list']">劳务实名管理</el-dropdown-item>
icon="el-icon-notebook-2"
v-hasPermi="['work:workTrain:list']"
>项目教育培训</el-dropdown-item
>
<el-dropdown-item
command="handleEmergencyDrill"
icon="el-icon-first-aid-kit"
v-hasPermi="['work:emergencyDrill:list']"
>项目应急演练</el-dropdown-item
>
<el-dropdown-item
command="handleProjectInsurance"
icon="el-icon-star-on"
v-hasPermi="['project:surProjectInsurance:list']"
>项目保险管理</el-dropdown-item
>
<el-dropdown-item
command="handleProjectSpecial"
icon="el-icon-user"
v-hasPermi="['project:surProjectSpecial:list']"
>项目特种人员</el-dropdown-item
>
<el-dropdown-item
command="handleProjectMeasure"
icon="el-icon-s-operation"
v-hasPermi="['project:projectMeasure:list']"
>实测实量管理</el-dropdown-item
>
<el-dropdown-item
command="handleProjectMaterialSeal"
icon="el-icon-s-ticket"
v-hasPermi="['project:materialSeal:list']"
>材料封样管理</el-dropdown-item
>
<el-dropdown-item
command="handleProjectDeptWroks"
icon="el-icon-s-custom"
v-hasPermi="['project:projectDeptWroks:list']"
>在岗人员管理</el-dropdown-item
>
<el-dropdown-item
command="handleAttendanceData"
icon="el-icon-s-grid"
v-hasPermi="['project:attendance:list']"
>劳务实名管理</el-dropdown-item>
<!-- <el-dropdown-item <!-- <el-dropdown-item
command="handleProjectAttendance" command="handleProjectAttendance"
icon="el-icon-trophy" icon="el-icon-trophy"
v-hasPermi="['project:surProjectAttendance:add']" v-hasPermi="['project:surProjectAttendance:add']"
>今日出勤</el-dropdown-item >今日出勤</el-dropdown-item
> --> > -->
<el-dropdown-item <el-dropdown-item command="handleVideoConfig" icon="el-icon-video-camera-solid"
command="handleVideoConfig" v-hasPermi="['video:videoConfig:list']">视频配置</el-dropdown-item>
icon="el-icon-video-camera-solid" <el-dropdown-item command="handleAiBoxVideoConfig" icon="el-icon-camera"
v-hasPermi="['video:videoConfig:list']" v-hasPermi="['video:aiBoxProjectConfig:list']">AI视频配置</el-dropdown-item>
>视频配置</el-dropdown-item <el-dropdown-item command="handlePrjPhotography" icon="el-icon-camera"
> v-hasPermi="['video:prjphotography:list']">项目全景</el-dropdown-item>
<el-dropdown-item <el-dropdown-item command="handleCheckDetection" icon="el-icon-c-scale-to-original"
command="handleAiBoxVideoConfig" v-hasPermi="['project:checkDetection:list']">材料取样复试</el-dropdown-item>
icon="el-icon-camera" <el-dropdown-item command="handleCostOutput" icon="el-icon-money"
v-hasPermi="['video:aiBoxProjectConfig:list']" v-hasPermi="['project:costOutput:edit']">项目成本产值管理</el-dropdown-item>
>AI视频配置</el-dropdown-item <el-dropdown-item command="handleStandard" icon="el-icon-s-grid"
> v-hasPermi="['project:projectStandard:list']">标准化管理</el-dropdown-item>
<el-dropdown-item <el-dropdown-item command="handleDelete" icon="el-icon-delete"
command="handlePrjPhotography" v-hasPermi="['project:surProject:remove']">删除项目</el-dropdown-item>
icon="el-icon-camera"
v-hasPermi="['video:prjphotography:list']"
>项目全景</el-dropdown-item
>
<el-dropdown-item
command="handleCheckDetection"
icon="el-icon-c-scale-to-original"
v-hasPermi="['project:checkDetection:list']"
>材料取样复试</el-dropdown-item
>
<el-dropdown-item
command="handleCostOutput"
icon="el-icon-money"
v-hasPermi="['project:costOutput:edit']"
>项目成本产值管理</el-dropdown-item
>
<el-dropdown-item
command="handleStandard"
icon="el-icon-s-grid"
v-hasPermi="['project:projectStandard:list']"
>标准化管理</el-dropdown-item>
<el-dropdown-item
command="handleDelete"
icon="el-icon-delete"
v-hasPermi="['project:surProject:remove']"
>删除项目</el-dropdown-item
>
</el-dropdown-menu> </el-dropdown-menu>
</el-dropdown> </el-dropdown>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<pagination <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
v-show="total > 0" @pagination="getList" />
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<!-- 添加或修改项目管理对话框 --> <!-- 添加或修改项目管理对话框 -->
<el-dialog <el-dialog :title="title" v-if="open" :visible.sync="open" width="1200px" append-to-body
:title="title" custom-class="prj-suprj-edit-dialog" :close-on-click-modal="false" :close-on-press-escape="false">
v-if="open"
:visible.sync="open"
width="1200px"
append-to-body
custom-class="prj-suprj-edit-dialog"
:close-on-click-modal="false"
:close-on-press-escape="false"
>
<el-form ref="form" :model="form" :rules="rules" label-width="120px"> <el-form ref="form" :model="form" :rules="rules" label-width="120px">
<el-row> <el-row>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="责任主体" prop="deptId"> <el-form-item label="责任主体" prop="deptId">
<el-select <el-select v-model="form.deptId" placeholder="请选择责任主体" style="width: 100%"
v-model="form.deptId" :disabled="getDeptIdDisabled()">
placeholder="请选择责任主体" <el-option v-for="dict in depts" :key="dict.deptId" :label="dict.deptName"
style="width: 100%" :value="dict.deptId"></el-option>
:disabled="getDeptIdDisabled()"
>
<el-option
v-for="dict in depts"
:key="dict.deptId"
:label="dict.deptName"
:value="dict.deptId"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -556,10 +242,7 @@
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="父级项目" prop="paretProjectName"> <el-form-item label="父级项目" prop="paretProjectName">
<el-input <el-input v-model="form.paretProjectName" placeholder="请输入父级项目名称" />
v-model="form.paretProjectName"
placeholder="请输入父级项目名称"
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
@ -567,17 +250,9 @@
<el-row> <el-row>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="项目建设类型" prop="projectNature"> <el-form-item label="项目建设类型" prop="projectNature">
<el-select <el-select v-model="form.projectNature" placeholder="请选择项目建设类型" style="width: 100%">
v-model="form.projectNature" <el-option v-for="dict in dict.type.project_build_type" :key="dict.value" :label="dict.label"
placeholder="请选择项目建设类型" :value="dict.value"></el-option>
style="width: 100%"
>
<el-option
v-for="dict in dict.type.project_build_type"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -588,19 +263,10 @@
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="项目分类" prop="projectType"> <el-form-item label="项目分类" prop="projectType">
<el-select <el-select v-model="form.projectType" placeholder="请选择项目分类" style="width: 100%">
v-model="form.projectType" <el-option v-for="dict in dict.type.project_category" :key="dict.value" :label="dict.label"
placeholder="请选择项目分类" :value="dict.value"></el-option>
style="width: 100%" </el-select> </el-form-item></el-col>
>
<el-option
v-for="dict in dict.type.project_category"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-form-item
></el-col>
</el-row> </el-row>
<el-row> <el-row>
@ -611,29 +277,16 @@
<el-button @click="getMapInfo"></el-button> <el-button @click="getMapInfo"></el-button>
</div> </div>
<div style="margin-left: 12px; flex-grow: 1"> <div style="margin-left: 12px; flex-grow: 1">
<el-input <el-input type="textarea" :rows="3" placeholder="请输入地址" v-model="form.projectAddress">
type="textarea"
:rows="3"
placeholder="请输入地址"
v-model="form.projectAddress"
>
</el-input> </el-input>
</div> </div>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="项目等级" prop="projiectLevel"> <el-form-item label="项目等级" prop="projiectLevel">
<el-select <el-select v-model="form.projiectLevel" placeholder="请选择项目等级" style="width: 100%">
v-model="form.projiectLevel" <el-option v-for="dict in dict.type.project_level" :key="dict.value" :label="dict.label"
placeholder="请选择项目等级" :value="dict.value"></el-option>
style="width: 100%"
>
<el-option
v-for="dict in dict.type.project_level"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -655,71 +308,41 @@
</el-row> </el-row>
<el-row> <el-row>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="计划完成时间" prop="plannedCompletionTime"> <el-form-item label="计划完成时间" prop="plannedCompletionTime">
<el-date-picker <el-date-picker v-model="form.plannedCompletionTime" type="month" placeholder="选择计划完成时间"
v-model="form.plannedCompletionTime" style="width: 100%">
type="month"
placeholder="选择计划完成时间"
style="width: 100%"
>
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="计划开工时间" prop="scheduledStartTime"> <el-form-item label="计划开工时间" prop="scheduledStartTime">
<el-date-picker <el-date-picker v-model="form.scheduledStartTime" type="month" placeholder="选择计划开工时间" style="width: 100%">
v-model="form.scheduledStartTime" </el-date-picker> </el-form-item></el-col>
type="month"
placeholder="选择计划开工时间"
style="width: 100%"
>
</el-date-picker> </el-form-item
></el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="实际开工时间" prop="actualOperatingTime"> <el-form-item label="实际开工时间" prop="actualOperatingTime">
<el-date-picker <el-date-picker v-model="form.actualOperatingTime" type="month" placeholder="选择实际开工时间"
v-model="form.actualOperatingTime" style="width: 100%">
type="month" </el-date-picker> </el-form-item></el-col>
placeholder="选择实际开工时间"
style="width: 100%"
>
</el-date-picker> </el-form-item
></el-col>
</el-row> </el-row>
<el-row> <el-row>
<el-col :span="8" <el-col :span="8"><el-form-item label="实际完工时间" prop="actualCompletionTime">
><el-form-item label="实际完工时间" prop="actualCompletionTime"> <el-date-picker v-model="form.actualCompletionTime" type="month" placeholder="选择实际完工时间"
<el-date-picker style="width: 100%">
v-model="form.actualCompletionTime" </el-date-picker> </el-form-item></el-col>
type="month" <el-col :span="8"><el-form-item label="形象进度" prop="projectSchedule">
placeholder="选择实际完工时间" <el-select v-model="form.projectSchedule" placeholder="请选择形象进度" style="width: 100%">
style="width: 100%" <el-option v-for="dict in dict.type.sur_project_xmjd" :key="dict.value" :label="dict.label"
> :value="dict.value"></el-option>
</el-date-picker> </el-form-item
></el-col>
<el-col :span="8"
><el-form-item label="形象进度" prop="projectSchedule">
<el-select
v-model="form.projectSchedule"
placeholder="请选择形象进度"
style="width: 100%"
>
<el-option
v-for="dict in dict.type.sur_project_xmjd"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<!-- <el-row> <!-- <el-row>
<el-col :span="8" <el-col :span="8"
><el-form-item label="劳务人员数" prop="servicePersonnel"> ><el-form-item label="劳务人员数" prop="servicePersonnel">
@ -744,12 +367,7 @@
> >
</el-row> --> </el-row> -->
<el-form-item label="项目概述" prop="projectSummarize"> <el-form-item label="项目概述" prop="projectSummarize">
<el-input <el-input v-model="form.projectSummarize" type="textarea" :rows="5" placeholder="请输入内容" />
v-model="form.projectSummarize"
type="textarea"
:rows="5"
placeholder="请输入内容"
/>
</el-form-item> </el-form-item>
<el-form-item label="备注" prop="remark"> <el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" placeholder="请输入备注" /> <el-input v-model="form.remark" placeholder="请输入备注" />
@ -761,11 +379,7 @@
</div> </div>
</el-dialog> </el-dialog>
<ProjectScheduleDlg ref="prjSchDlg"></ProjectScheduleDlg> <ProjectScheduleDlg ref="prjSchDlg"></ProjectScheduleDlg>
<projectUserInfoDrawer <projectUserInfoDrawer size="50%" :visible.sync="projectUserInfoDrawerVisible" :form-data="formData" />
size="50%"
:visible.sync="projectUserInfoDrawerVisible"
:form-data="formData"
/>
<assess-drawer ref="assessDrawer"></assess-drawer> <assess-drawer ref="assessDrawer"></assess-drawer>
<baidu-map ref="map" @success="mapSuccess"></baidu-map> <baidu-map ref="map" @success="mapSuccess"></baidu-map>
<build-node-drawer ref="nodeDrawer"></build-node-drawer> <build-node-drawer ref="nodeDrawer"></build-node-drawer>
@ -783,9 +397,10 @@
<checkDetectionDrawer ref="checkDetection"></checkDetectionDrawer> <checkDetectionDrawer ref="checkDetection"></checkDetectionDrawer>
<standardDrawer ref="standard"></standardDrawer> <standardDrawer ref="standard"></standardDrawer>
<attendanceDataDrawer ref="attendanceData"></attendanceDataDrawer> <attendanceDataDrawer ref="attendanceData"></attendanceDataDrawer>
<aiBoxVideoConfigDrawer ref="aiBoxVideoConfigDrawer"></aiBoxVideoConfigDrawer> <aiBoxVideoConfigDrawer ref="aiBoxVideoConfigDrawer"></aiBoxVideoConfigDrawer>
<prjPhotographyDrawer ref="prjPhotographyDrawer"></prjPhotographyDrawer> <prjPhotographyDrawer ref="prjPhotographyDrawer"></prjPhotographyDrawer>
<projectDesignDrawer ref="designDrawer"></projectDesignDrawer> <projectDesignDrawer ref="designDrawer"></projectDesignDrawer>
<CommitteeDrawer ref="committeeDrawer"></CommitteeDrawer>
</div> </div>
</template> </template>
@ -821,6 +436,7 @@ import attendanceDataDrawer from '@/views/project/attendance/attendanceDrawer.vu
import aiBoxVideoConfigDrawer from '@/views/video/aiBoxProjectConfig/aiBoxVideoConfigDrawer'; import aiBoxVideoConfigDrawer from '@/views/video/aiBoxProjectConfig/aiBoxVideoConfigDrawer';
import prjPhotographyDrawer from '@/views/video/prjphotography/prjPhotographyDrawer.vue' import prjPhotographyDrawer from '@/views/video/prjphotography/prjPhotographyDrawer.vue'
import projectDesignDrawer from '@/views/project/projectDesign/projectDesignDrawer.vue'; import projectDesignDrawer from '@/views/project/projectDesign/projectDesignDrawer.vue';
import CommitteeDrawer from '@/views/project/projectCommittee/projectCommitteeDrawer.vue'
import { checkPermi, checkRole } from "@/utils/permission"; // import { checkPermi, checkRole } from "@/utils/permission"; //
export default { export default {
@ -845,9 +461,10 @@ export default {
checkDetectionDrawer, checkDetectionDrawer,
standardDrawer, standardDrawer,
attendanceDataDrawer, attendanceDataDrawer,
aiBoxVideoConfigDrawer, aiBoxVideoConfigDrawer,
prjPhotographyDrawer, prjPhotographyDrawer,
projectDesignDrawer projectDesignDrawer,
CommitteeDrawer
}, },
dicts: [ dicts: [
"sur_project_xmjd", "sur_project_xmjd",
@ -1059,7 +676,7 @@ export default {
this.handleDelete(row); this.handleDelete(row);
break; break;
case "handleDesign": case "handleDesign":
this.$refs.designDrawer.show(row); this.$refs.designDrawer.show(row);
break; break;
case "handleAssess": case "handleAssess":
this.$refs.assessDrawer.show(row); this.$refs.assessDrawer.show(row);
@ -1105,7 +722,7 @@ export default {
break; break;
case "handleStandard": case "handleStandard":
this.$refs.standard.show(row); this.$refs.standard.show(row);
break; break;
case "handleAttendanceData": case "handleAttendanceData":
this.$refs.attendanceData.show(row); this.$refs.attendanceData.show(row);
break; break;
@ -1115,6 +732,9 @@ export default {
case "handlePrjPhotography": case "handlePrjPhotography":
this.$refs.prjPhotographyDrawer.show(row); this.$refs.prjPhotographyDrawer.show(row);
break; break;
case "handleCommittee":
this.$refs.committeeDrawer.show(row);
break;
default: default:
break; break;
} }
@ -1164,7 +784,7 @@ export default {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}) })
.catch(() => {}); .catch(() => { });
}, },
/** 导出按钮操作 */ /** 导出按钮操作 */
handleExport() { handleExport() {
@ -1225,6 +845,7 @@ export default {
.prj-suprj-edit-dialog { .prj-suprj-edit-dialog {
.el-dialog__body { .el-dialog__body {
padding-bottom: 0px; padding-bottom: 0px;
.fi-longitude { .fi-longitude {
.el-form-item__content { .el-form-item__content {
display: flex; display: flex;

View File

@ -15,8 +15,6 @@ CREATE VIEW vw_smz_ssp_problemmodify_audit AS (
a.*, a.updateTime AS audittime, a.*, a.updateTime AS audittime,
b.deptId, b.deptId,
b.projectName as prjName, b.projectName as prjName,
b.projectType as proType,
b.progressVisible as progressVisible,
u.nick_name AS createBy u.nick_name AS createBy
FROM FROM
smz_ssp_problemmodify a smz_ssp_problemmodify a
@ -54,9 +52,7 @@ CREATE VIEW vw_flow_all AS (
DEF.KEY_ AS procDefKey, DEF.KEY_ AS procDefKey,
sp.id AS businessKey, sp.id AS businessKey,
sp.deptId as businessDeptId, sp.deptId as businessDeptId,
sp.projectType as businessType,
sp.projectName AS businessKeyName, sp.projectName AS businessKeyName,
sp.progressVisible AS businessVisible,
ru.user_id AS startUserId, ru.user_id AS startUserId,
ru.nick_name AS startUserName, ru.nick_name AS startUserName,
rd.dept_name AS startDeptName, rd.dept_name AS startDeptName,
@ -111,9 +107,7 @@ CREATE VIEW vw_flow_await AS (SELECT
DEF.KEY_ AS procDefKey, DEF.KEY_ AS procDefKey,
sp.id AS businessKey, sp.id AS businessKey,
sp.deptId AS businessDeptId, sp.deptId AS businessDeptId,
sp.projectType AS businessType,
sp.projectName AS businessKeyName, sp.projectName AS businessKeyName,
sp.progressVisible AS businessVisible,
ru.user_id AS startUserId, ru.user_id AS startUserId,
ru.nick_name AS startUserName, ru.nick_name AS startUserName,
rd.dept_name AS startDeptName, rd.dept_name AS startDeptName,
@ -155,10 +149,52 @@ WHERE
-- ) -- )
-- ) -- )
##审批意见 ##审批意见
DROP view vw_flow_comment; DROP view vw_flow_comment;
CREATE VIEW vw_flow_comment AS ( CREATE VIEW vw_flow_comment AS (
SELECT
hc.ID_ AS commentId,
hc.TYPE_ AS commentType,
ht.ID_ AS taskId,
ht.NAME_ AS taskName,
ht.REV_ AS rev,
CASE
WHEN hc.TYPE_ = 1
AND ht.REV_ != 2 THEN
'通过'
WHEN hc.TYPE_ != 1 THEN
'驳回'
END AS commentResult,
ht.PROC_INST_ID_ AS procInstId,
ht.TASK_DEF_KEY_ AS taskDefKey,
ht.EXECUTION_ID_ AS executionId,
ht.DELETE_REASON_ AS deleteReason,
DATE_FORMAT(
ht.START_TIME_,
'%Y-%m-%d %H:%i:%S'
) AS startTime,
DATE_FORMAT(
ht.END_TIME_,
'%Y-%m-%d %H:%i:%S'
) AS endTime,
ht.DURATION_ AS duration,
hc.MESSAGE_ AS message,
ru.nick_name AS assigneeName,
rd.dept_name AS deptName,
r.role_name as candidate
FROM
act_hi_taskinst ht
LEFT JOIN act_hi_comment hc ON hc.TASK_ID_ = ht.ID_
LEFT JOIN act_hi_identitylink hi on hi.TASK_ID_ = ht.ID_ and hi.TYPE_ = 'candidate'
left JOIN sys_role r on r.role_id = hi.group_Id_
LEFT JOIN sys_user ru ON ru.user_id = ht.ASSIGNEE_
LEFT JOIN sys_dept rd ON rd.dept_id = ru.dept_id
where hc.TYPE_ is null or hc.TYPE_!='event'
)
##审批意见V2
DROP view vw_flow_comment;
CREATE VIEW vw_flow_comment AS (
SELECT SELECT
hc.ID_ AS commentId, hc.ID_ AS commentId,
hc.TYPE_ AS commentType, hc.TYPE_ AS commentType,
@ -228,9 +264,7 @@ DEF.END_TIME_ as finishTime,
pd.KEY_ AS procDefKey, pd.KEY_ AS procDefKey,
sp.id AS businessKey, sp.id AS businessKey,
sp.deptId AS businessDeptId, sp.deptId AS businessDeptId,
sp.projectType AS businessType,
sp.projectName AS businessKeyName, sp.projectName AS businessKeyName,
sp.progressVisible AS businessVisible,
ru.user_id AS startUserId, ru.user_id AS startUserId,
ru.nick_name AS startUserName, ru.nick_name AS startUserName,
rd.dept_name AS startDeptName, rd.dept_name AS startDeptName,
@ -245,7 +279,6 @@ LEFT JOIN sys_dept rd ON rd.dept_id = ru.dept_id
WHERE WHERE
RES.ASSIGNEE_ is not null and RES.END_TIME_ is not null) RES.ASSIGNEE_ is not null and RES.END_TIME_ is not null)
##君哥其它sql ##君哥其它sql
CREATE VIEW vw_smz_ssp_problemmodify_audit CREATE VIEW vw_smz_ssp_problemmodify_audit
AS AS
@ -260,6 +293,8 @@ SELECT * FROM smz_ssp_auditinfo WHERE id IN(SELECT MAX(id) FROM smz_ssp_auditinf
GROUP BY mainid) GROUP BY mainid)
) a ON p.id=a.mainid ) a ON p.id=a.mainid
130735741
559939996
CREATE VIEW vw_sur_project_build_node_data_all CREATE VIEW vw_sur_project_build_node_data_all
AS AS

View File

@ -0,0 +1,218 @@
/*
SQLyog Ultimate v13.1.1 (64 bit)
MySQL - 8.0.22-cynos : Database - yanzhu_jh
*********************************************************************
*/
/*!40101 SET NAMES utf8 */;
/*!40101 SET SQL_MODE=''*/;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
/*Table structure for table `base_mag` */
DROP TABLE IF EXISTS `base_mag`;
CREATE TABLE `base_mag` (
`id` int NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT NULL COMMENT '期刊名称',
`imgs` varchar(512) DEFAULT NULL COMMENT '图片',
`ord` int DEFAULT NULL COMMENT '排序',
`remark` varchar(255) DEFAULT NULL COMMENT '备注',
`is_del` int DEFAULT '0',
`create_by` varchar(255) DEFAULT NULL,
`create_time` datetime DEFAULT NULL,
`update_by` varchar(255) DEFAULT NULL,
`update_time` datetime DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='期刊';
/*Data for the table `base_mag` */
LOCK TABLES `base_mag` WRITE;
UNLOCK TABLES;
/*Table structure for table `base_mag_detail` */
DROP TABLE IF EXISTS `base_mag_detail`;
CREATE TABLE `base_mag_detail` (
`id` int NOT NULL AUTO_INCREMENT,
`magid` int DEFAULT NULL COMMENT '期刊id',
`topic` int DEFAULT NULL COMMENT '栏目字典mag_topic',
`title` varchar(512) DEFAULT NULL COMMENT '标题',
`deptid` int DEFAULT NULL COMMENT '总包编号',
`authorName` varchar(255) DEFAULT NULL COMMENT '作者',
`authorPhone` varchar(50) DEFAULT NULL COMMENT '作者电话',
`ord` int DEFAULT NULL COMMENT '排序号',
`images` varchar(1024) DEFAULT NULL COMMENT '图片',
`content` text COMMENT '正文',
`remark` varchar(255) DEFAULT NULL COMMENT '备注',
`is_del` int DEFAULT '0',
`create_by` varchar(255) DEFAULT NULL,
`create_time` datetime DEFAULT NULL,
`update_by` varchar(255) DEFAULT NULL,
`update_time` datetime DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='期刊详情';
/*Data for the table `base_mag_detail` */
LOCK TABLES `base_mag_detail` WRITE;
UNLOCK TABLES;
/*Table structure for table `base_working_committee` */
DROP TABLE IF EXISTS `base_working_committee`;
CREATE TABLE `base_working_committee` (
`id` int NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT NULL COMMENT '名称',
`files` varchar(1024) DEFAULT NULL COMMENT '文件',
`ord` int DEFAULT NULL COMMENT '顺序',
`remark` varchar(255) DEFAULT NULL,
`create_by` varchar(255) DEFAULT NULL,
`create_time` datetime DEFAULT NULL,
`update_by` varchar(255) DEFAULT NULL,
`update_time` datetime DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='工委会';
/*Data for the table `base_working_committee` */
LOCK TABLES `base_working_committee` WRITE;
UNLOCK TABLES;
/*Table structure for table `sur_project_working_committee` */
DROP TABLE IF EXISTS `sur_project_working_committee`;
CREATE TABLE `sur_project_working_committee` (
`id` int NOT NULL AUTO_INCREMENT,
`projectId` int DEFAULT NULL COMMENT '项目ID',
`workingType` int DEFAULT NULL COMMENT '分类字典project_working_type',
`costName` varchar(255) DEFAULT NULL COMMENT '成本名称',
`money` double DEFAULT NULL COMMENT '金额(万元)',
`remark` varchar(255) DEFAULT NULL,
`create_by` varchar(255) DEFAULT NULL,
`create_time` datetime DEFAULT NULL,
`update_by` varchar(255) DEFAULT NULL,
`update_time` datetime DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='项目工委会信息';
/*Data for the table `sur_project_working_committee` */
LOCK TABLES `sur_project_working_committee` WRITE;
UNLOCK TABLES;
/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
-- 菜单 SQL
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊列表', '2108', '1', 'mag', 'base/mag/index', 1, 0, 'C', '0', '0', 'base:mag:list', '#', 'admin', sysdate(), '', null, '期刊列表菜单');
-- 按钮父菜单ID
SELECT @parentId := LAST_INSERT_ID();
-- 按钮 SQL
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊列表查询', @parentId, '1', '#', '', 1, 0, 'F', '0', '0', 'base:mag:query', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊列表新增', @parentId, '2', '#', '', 1, 0, 'F', '0', '0', 'base:mag:add', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊列表修改', @parentId, '3', '#', '', 1, 0, 'F', '0', '0', 'base:mag:edit', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊列表删除', @parentId, '4', '#', '', 1, 0, 'F', '0', '0', 'base:mag:remove', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊列表导出', @parentId, '5', '#', '', 1, 0, 'F', '0', '0', 'base:mag:export', '#', 'admin', sysdate(), '', null, '');
-- 菜单 SQL
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊详情', '2108', '1', 'magDetail', 'base/magDetail/index', 1, 0, 'C', '0', '0', 'base:magDetail:list', '#', 'admin', sysdate(), '', null, '期刊详情菜单');
-- 按钮父菜单ID
SELECT @parentId := LAST_INSERT_ID();
-- 按钮 SQL
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊详情查询', @parentId, '1', '#', '', 1, 0, 'F', '0', '0', 'base:magDetail:query', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊详情新增', @parentId, '2', '#', '', 1, 0, 'F', '0', '0', 'base:magDetail:add', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊详情修改', @parentId, '3', '#', '', 1, 0, 'F', '0', '0', 'base:magDetail:edit', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊详情删除', @parentId, '4', '#', '', 1, 0, 'F', '0', '0', 'base:magDetail:remove', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('期刊详情导出', @parentId, '5', '#', '', 1, 0, 'F', '0', '0', 'base:magDetail:export', '#', 'admin', sysdate(), '', null, '');
-- 菜单 SQL
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会列表', '2108', '1', 'committee', 'base/committee/index', 1, 0, 'C', '0', '0', 'base:committee:list', '#', 'admin', sysdate(), '', null, '工委会列表菜单');
-- 按钮父菜单ID
SELECT @parentId := LAST_INSERT_ID();
-- 按钮 SQL
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会列表查询', @parentId, '1', '#', '', 1, 0, 'F', '0', '0', 'base:committee:query', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会列表新增', @parentId, '2', '#', '', 1, 0, 'F', '0', '0', 'base:committee:add', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会列表修改', @parentId, '3', '#', '', 1, 0, 'F', '0', '0', 'base:committee:edit', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会列表删除', @parentId, '4', '#', '', 1, 0, 'F', '0', '0', 'base:committee:remove', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会列表导出', @parentId, '5', '#', '', 1, 0, 'F', '0', '0', 'base:committee:export', '#', 'admin', sysdate(), '', null, '');
-- 菜单 SQL
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会管理', '2108', '1', 'projectCommittee', 'project/projectCommittee/index', 1, 0, 'C', '0', '0', 'project:projectCommittee:list', '#', 'admin', sysdate(), '', null, '工委会管理菜单');
-- 按钮父菜单ID
SELECT @parentId := LAST_INSERT_ID();
-- 按钮 SQL
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会管理查询', @parentId, '1', '#', '', 1, 0, 'F', '0', '0', 'project:projectCommittee:query', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会管理新增', @parentId, '2', '#', '', 1, 0, 'F', '0', '0', 'project:projectCommittee:add', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会管理修改', @parentId, '3', '#', '', 1, 0, 'F', '0', '0', 'project:projectCommittee:edit', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会管理删除', @parentId, '4', '#', '', 1, 0, 'F', '0', '0', 'project:projectCommittee:remove', '#', 'admin', sysdate(), '', null, '');
insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark)
values('工委会管理导出', @parentId, '5', '#', '', 1, 0, 'F', '0', '0', 'project:projectCommittee:export', '#', 'admin', sysdate(), '', null, '');

View File

@ -45,7 +45,7 @@ public class ProjectBuildNodeController extends BaseController {
} }
List<SurProjectBuildNodeData> list = surProjectBuildNodeDataService.selectScheduledAlerts(where); List<SurProjectBuildNodeData> list = surProjectBuildNodeDataService.selectScheduledAlerts(where);
redisCache.setCacheObject(key, list, Constants.BIGSCREEN_QUERY_CACHE, TimeUnit.MINUTES);
return AjaxResult.success(); return AjaxResult.success();
} }
@ -69,7 +69,7 @@ public class ProjectBuildNodeController extends BaseController {
} }
List<SurProjectBuildNodeData> list = surProjectBuildNodeDataService.countCompletionRate(where); List<SurProjectBuildNodeData> list = surProjectBuildNodeDataService.countCompletionRate(where);
redisCache.setCacheObject(key, list, Constants.BIGSCREEN_QUERY_CACHE, TimeUnit.MINUTES);
return AjaxResult.success(list); return AjaxResult.success(list);
} }
@ -86,7 +86,7 @@ public class ProjectBuildNodeController extends BaseController {
return AjaxResult.success(obj); return AjaxResult.success(obj);
} }
List<SurProjectBuildNodeData> list = surProjectBuildNodeDataService.selectCurrent(where); List<SurProjectBuildNodeData> list = surProjectBuildNodeDataService.selectCurrent(where);
redisCache.setCacheObject(key, list, Constants.BIGSCREEN_QUERY_CACHE, TimeUnit.MINUTES);
return AjaxResult.success(); return AjaxResult.success();
} }
@ -110,7 +110,7 @@ public class ProjectBuildNodeController extends BaseController {
} }
surProjectBuildNodeDataService.addProjectNodes(projectId); surProjectBuildNodeDataService.addProjectNodes(projectId);
list=surProjectBuildNodeDataService.selectSurProjectBuildNodeDataList(surProjectBuildNodeData); list=surProjectBuildNodeDataService.selectSurProjectBuildNodeDataList(surProjectBuildNodeData);
redisCache.setCacheObject(key, list, Constants.BIGSCREEN_QUERY_CACHE, TimeUnit.MINUTES);
return AjaxResult.success(list); return AjaxResult.success(list);
} }
@ -127,7 +127,7 @@ public class ProjectBuildNodeController extends BaseController {
return AjaxResult.success(obj); return AjaxResult.success(obj);
} }
List list=surProjectBuildNodeDataService.queryByProjectType(type); List list=surProjectBuildNodeDataService.queryByProjectType(type);
redisCache.setCacheObject(key, list, Constants.BIGSCREEN_QUERY_CACHE, TimeUnit.MINUTES);
return AjaxResult.success(list); return AjaxResult.success(list);
} }
@ -140,7 +140,7 @@ public class ProjectBuildNodeController extends BaseController {
return AjaxResult.success(obj); return AjaxResult.success(obj);
} }
List list=surProjectBuildNodeDataService.queryFinishProject(projectId); List list=surProjectBuildNodeDataService.queryFinishProject(projectId);
redisCache.setCacheObject(key, list, Constants.BIGSCREEN_QUERY_CACHE, TimeUnit.MINUTES);
return AjaxResult.success(list); return AjaxResult.success(list);
} }

View File

@ -1,5 +1,8 @@
package com.yanzhu.jh.bigscreen.web.controller; package com.yanzhu.jh.bigscreen.web.controller;
import cn.hutool.core.date.DateTime;
import cn.hutool.core.date.DateUnit;
import cn.hutool.core.date.DateUtil;
import com.ruoyi.common.constant.Constants; import com.ruoyi.common.constant.Constants;
import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.AjaxResult;
@ -17,6 +20,7 @@ import org.aspectj.weaver.loadtime.Aj;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import java.util.Date;
import java.util.List; import java.util.List;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@ -52,7 +56,14 @@ public class ProjectController extends BaseController {
if(deptId!=null && deptId.longValue()>0){ if(deptId!=null && deptId.longValue()>0){
surProject.setDeptId(deptId); surProject.setDeptId(deptId);
} }
return success(isurProjectService.selectSurProjectList(surProject)); List<SurProject> list=isurProjectService.selectSurProjectList(surProject);
for (SurProject p :list){
//DateTime dt1= DateUtil.parse(p.getScheduledStartTime());
//DateTime dt2=DateUtil.parse(p.getPlannedCompletionTime());
//long days= DateUtil.between(dt1,dt2, DateUnit.DAY);
//p.setProjectTimeLimit(days);
}
return success(list);
} }
@GetMapping("/getProjectBuildNode") @GetMapping("/getProjectBuildNode")

View File

@ -214,7 +214,7 @@ public class SurProjectAttendanceDataServiceImpl implements ISurProjectAttendanc
sdata.setCompanyTypeId(group.getCompanyTypeId()); sdata.setCompanyTypeId(group.getCompanyTypeId());
//查询华筑的分组信息 //查询华筑的分组信息
if("huazhu".equals(sdata.getVendorsCode())){ if("huazhu".equals(sdata.getVendorsCode())){
sdata.setWorkerGender(sdata.getWorkerGender()==1?0l:1l); sdata.setWorkerGender(sdata.getWorkerGender());
sdata.setCompanyTypeId(getHuazhuCompanyTypeId(group.getCompanyName()));//获取华筑的分包商类型 sdata.setCompanyTypeId(getHuazhuCompanyTypeId(group.getCompanyName()));//获取华筑的分包商类型
} }
if("jgw".equals(sdata.getVendorsCode())){ if("jgw".equals(sdata.getVendorsCode())){

View File

@ -114,7 +114,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
SELECT 10 cost_type , SUM(spco.money) money FROM sur_project_cost_output spco SELECT 10 cost_type , SUM(spco.money) money FROM sur_project_cost_output spco
left join sur_project sp on sp.id = spco.project_id left join sur_project sp on sp.id = spco.project_id
WHERE (spco.cost_type=2 AND spco.YEAR &lt;=#{year} ) and sp.isDel=0 and sp.progressVisible=0 WHERE spco.cost_type=9 AND (spco.YEAR &lt;#{year} or ( spco.Year =#{year} and spco.MONTH &lt;= #{month})) and sp.isDel=0 and sp.progressVisible=0
<if test="id!=null and id>0"> and sp.deptId = #{id}</if> <if test="id!=null and id>0"> and sp.deptId = #{id}</if>
<if test="proType != null and proType != ''"> and sp.projectType = #{proType}</if> <if test="proType != null and proType != ''"> and sp.projectType = #{proType}</if>
<if test="projectId!=null and projectId>0"> <if test="projectId!=null and projectId>0">

View File

@ -126,13 +126,12 @@
left join ( left join (
select a.standard_type,count(1) cnt select a.standard_type,count(1) cnt
from sur_project_standard a ,sur_project sp from sur_project_standard a ,sur_project sp
where a.is_del =0 and a.project_id=sp.id where a.is_del =0 and a.project_id=sp.id and sp.progressVisible=0
<if test="projectId!=null and projectId>0"> and a.project_id=#{projectId}</if> <if test="projectId!=null and projectId>0"> and a.project_id=#{projectId}</if>
<if test="deptId!=null and deptId>0"> <if test="deptId!=null and deptId>0">
and a.dept_Id= #{deptId} and sp.deptid= #{deptId}
</if> </if>
<if test="proType != null and proType != '' "> and sp.projectType = #{proType}</if> <if test="proType != null and proType != '' "> and sp.projectType = #{proType}</if>
<if test="activeName != null and activeName != ''"> and sp.progressVisible = 0</if>
<if test="prjIds !=null and prjIds.size()>0"> <if test="prjIds !=null and prjIds.size()>0">
and a.project_id in and a.project_id in
<foreach collection="prjIds" item="item" index="index" open="(" close=")" separator=","> <foreach collection="prjIds" item="item" index="index" open="(" close=")" separator=",">

View File

@ -464,7 +464,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
select projectId,prjName,count(1) proble from vw_smz_ssp_problemmodify_audit select projectId,prjName,count(1) proble from vw_smz_ssp_problemmodify_audit
where infoType=#{infoType} AND isDel=0 where infoType=#{infoType} AND isDel=0
<if test="projectId>0">and projectId=#{projectId}</if> <if test="projectId>0">and projectId=#{projectId}</if>
<if test='proType != null and proType != "" and proType != "0"'> and projectType = #{proType}</if> <if test='proType != null and proType != "" and proType != "0"'> and proType = #{proType}</if>
<if test="deptId >0 ">AND deptid = #{deptId}</if> <if test="deptId >0 ">AND deptid = #{deptId}</if>
<if test="prjIds !=null and prjIds.size()>0"> <if test="prjIds !=null and prjIds.size()>0">
and projectId in and projectId in
@ -698,7 +698,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<select id="countTimeout" parameterType="SmzSspProblemmodifyWhere" resultType="Integer"> <select id="countTimeout" parameterType="SmzSspProblemmodifyWhere" resultType="Integer">
select count(1) cnt select count(1) cnt
FROM smz_ssp_problemmodify ssp FROM smz_ssp_problemmodify ssp
left join sur_project sp on p.projectId=sp.id left join sur_project sp on ssp.projectId=sp.id
WHERE ssp.isDel=0 and sp.progressVisible=0 and sp.isDel=0 WHERE ssp.isDel=0 and sp.progressVisible=0 and sp.isDel=0
<if test="infoType !=null">and ssp.infoType=#{infoType}</if> <if test="infoType !=null">and ssp.infoType=#{infoType}</if>
<if test="roleType !=null and roleType>0">and ssp.roleType=#{roleType}</if> <if test="roleType !=null and roleType>0">and ssp.roleType=#{roleType}</if>