From a90cf43e7a1f41dcde401ed1fd118b0f90d7c3f5 Mon Sep 17 00:00:00 2001
From: cqf
Date: 星期四, 26 五月 2022 11:41:49 +0800
Subject: [PATCH] 举一反三隐患-存在

---
 src/views/doublePreventAction/hiddenDanger/inspectionTask/index.vue |  292 ++++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 214 insertions(+), 78 deletions(-)

diff --git a/src/views/doublePreventAction/hiddenDanger/inspectionTask/index.vue b/src/views/doublePreventAction/hiddenDanger/inspectionTask/index.vue
index a212344..0881220 100644
--- a/src/views/doublePreventAction/hiddenDanger/inspectionTask/index.vue
+++ b/src/views/doublePreventAction/hiddenDanger/inspectionTask/index.vue
@@ -78,27 +78,31 @@
                 highlight-current-row
                 style="width: 100%;"
             >
-                <el-table-column label="任务名称" prop="hazardCode" align="center">
+                <el-table-column label="任务名称" prop="title" align="center">
                 </el-table-column>
-                <el-table-column label="检查类型" prop="hazardDep" align="center">
+                <el-table-column label="检查类型" prop="type" align="center">
+                    <template slot-scope="scope">
+                        <div v-for="item in typeList">
+                            <div v-show="item.id === scope.row.type">
+                                {{ item.name }}
+                            </div>
+                        </div>
+                    </template>
                 </el-table-column>
-                <el-table-column label="检查频次" prop="hazardLiablePerson" align="center">
+                <el-table-column label="检查频次(小时)" prop="intervalSeconds" align="center">
+                    <template slot-scope="scope">
+                        {{ scope.row.intervalSeconds | parseHours}}
+                    </template>
                 </el-table-column>
-                <el-table-column label="任务开始时间" prop="riskUnitName" align="center">
+                <el-table-column label="任务开始时间" prop="startTime" align="center">
                 </el-table-column>
-                <el-table-column label="任务结束时间" prop="createBy" align="center">
+                <el-table-column label="异常通知人" prop="noticeUname" align="center">
                 </el-table-column>
-                <el-table-column label="异常通知人" prop="createTime" align="center">
+                <el-table-column label="巡检人" prop="execUname" align="center">
                 </el-table-column>
-                <el-table-column label="巡检人" prop="updateBy" align="center">
-                </el-table-column>
-                <el-table-column label="创建人" prop="createBy" align="center">
+                <el-table-column label="创建人" prop="createUname" align="center">
                 </el-table-column>
                 <el-table-column label="创建时间" prop="createTime" align="center">
-                </el-table-column>
-                <el-table-column label="最后修改人" prop="updateBy" align="center">
-                </el-table-column>
-                <el-table-column label="最后修改时间" prop="updateTime" align="center">
                 </el-table-column>
                 <el-table-column label="操作" align="center" width="280" class-name="small-padding fixed-width">
                     <template slot-scope="scope">
@@ -123,7 +127,7 @@
             <br>
         </div>
 
-        <el-dialog :title="title" :visible.sync="inspectionTaskVisible" :modal-append-to-body="false" :close-on-click-modal="false" width="55%">
+        <el-dialog :title="title" :visible.sync="inspectionTaskVisible" append-to-body :close-on-click-modal="false" width="55%">
 
 
             <el-divider></el-divider>
@@ -132,8 +136,76 @@
                 <el-form ref="inspectionTaskForm" :rules="inspectionTaskFormRules" :model="inspectionTaskForm" label-position="right" label-width="120px">
                     <el-row>
                         <el-col :span="12">
-                            <el-form-item label="任务名称" prop="hazardDep">
-                                <el-select v-model="inspectionTaskForm.hazardDep" class="analyseUnit_input">
+                            <el-form-item label="任务名称" prop="title">
+                                <el-input v-model="inspectionTaskForm.title" class="analyseUnit_input">
+                                </el-input>
+                            </el-form-item>
+                        </el-col>
+                        <el-col :span="12">
+                            <el-form-item label="巡检任务类型" prop="type">
+                                <el-select v-model="inspectionTaskForm.type" class="analyseUnit_input">
+                                    <el-option
+                                        v-for="item in typeList"
+                                        :key="item.id"
+                                        :value="item.id"
+                                        :label="item.name"
+                                    ></el-option>
+                                </el-select>
+                            </el-form-item>
+                        </el-col>
+                    </el-row>
+                    <el-row>
+                        <el-col :span="12">
+                            <el-form-item label="周期开始时间" prop="startTime">
+                                <el-date-picker v-model="inspectionTaskForm.startTime" value-format="yyyy-MM-dd HH:mm:ss" type="datetime" placeholder="周期开始时间" class="analyseUnit_input"></el-date-picker>
+                            </el-form-item>
+                        </el-col>
+                        <el-col :span="12">
+                            <el-form-item label="检查频次" prop="intervalSeconds">
+                                <el-select v-model="inspectionTaskForm.intervalSeconds" class="analyseUnit_input">
+                                    <el-option
+                                    v-for="item in intervalSecondsList"
+                                    :key="item.id"
+                                    :label="item.name"
+                                    :value="item.id"
+                                    >
+                                    </el-option>
+                                </el-select>
+                            </el-form-item>
+                        </el-col>
+                    </el-row>
+                    <el-row>
+                        <el-col :span="12">
+                            <el-form-item label="提前通知时间" prop="noticeSeconds">
+                                <el-select v-model="inspectionTaskForm.noticeSeconds" class="analyseUnit_input">
+                                    <el-option
+                                        v-for="item in noticeSecondsList"
+                                        :key="item.id"
+                                        :label="item.name"
+                                        :value="item.id"
+                                    >
+                                    </el-option>
+                                </el-select>
+                            </el-form-item>
+                        </el-col>
+                        <el-col :span="12">
+                            <el-form-item label="任务有效时间" prop="effectSeconds">
+                                <el-select v-model="inspectionTaskForm.effectSeconds" class="analyseUnit_input">
+                                    <el-option
+                                        v-for="item in effectSecondsList"
+                                        :key="item.id"
+                                        :label="item.name"
+                                        :value="item.id"
+                                    >
+                                    </el-option>
+                                </el-select>
+                            </el-form-item>
+                        </el-col>
+                    </el-row>
+                    <el-row>
+                        <el-col :span="12">
+                            <el-form-item label="异常通知部门" prop="noticeDepartment">
+                                <el-select v-model="noticeDepartment" class="analyseUnit_input" filterable clearable @change="changeNotice">
                                     <el-option
                                         v-for="item in departmentList"
                                         :key="item.id"
@@ -144,39 +216,41 @@
                             </el-form-item>
                         </el-col>
                         <el-col :span="12">
-                            <el-form-item label="检查频次" prop="hazardLiablePerson">
-                                <el-input v-model="inspectionTaskForm.hazardLiablePerson" class="analyseUnit_input"></el-input>
-                            </el-form-item>
-                        </el-col>
+                        <el-form-item label="异常通知人员" prop="noticeUid">
+                            <el-select v-model="inspectionTaskForm.noticeUid" filterable clearable class="analyseUnit_input">
+                                <el-option
+                                    v-for="item in noticeUidList"
+                                    :key="item.id"
+                                    :value="item.id"
+                                    :label="item.realname"
+                                ></el-option>
+                            </el-select>
+                        </el-form-item>
+                    </el-col>
                     </el-row>
                     <el-row>
                         <el-col :span="12">
-                            <el-form-item label="周期开始时间" prop="hazardLiablePerson">
-                                <el-date-picker v-model="inspectionTaskForm.hazardLiablePerson" value-format="yyyy-MM-dd HH:mm:ss" type="datetime" placeholder="周期开始时间" class="analyseUnit_input"></el-date-picker>
+                            <el-form-item label="执行巡检部门" prop="execDepartment">
+                                <el-select v-model="execDepartment" filterable clearable class="analyseUnit_input" @change="changeExec">
+                                    <el-option
+                                        v-for="item in departmentList"
+                                        :key="item.id"
+                                        :value="item.department"
+                                        :label="item.department"
+                                    ></el-option>
+                                </el-select>
                             </el-form-item>
                         </el-col>
                         <el-col :span="12">
-                            <el-form-item label="周期结束时间" prop="hazardLiablePerson">
-                                <el-date-picker v-model="inspectionTaskForm.hazardLiablePerson" value-format="yyyy-MM-dd HH:mm:ss" type="datetime" placeholder="周期结束时间" class="analyseUnit_input"></el-date-picker>
-                            </el-form-item>
-                        </el-col>
-                    </el-row>
-                    <el-row>
-                        <el-col :span="12">
-                            <el-form-item label="异常通知人" prop="hazardLiablePerson">
-                                <el-input v-model="inspectionTaskForm.hazardLiablePerson" class="analyseUnit_input"></el-input>
-                            </el-form-item>
-                        </el-col>
-                        <el-col :span="12">
-                            <el-form-item label="巡检人" prop="hazardLiablePerson">
-                                <el-input v-model="inspectionTaskForm.hazardLiablePerson" class="analyseUnit_input"></el-input>
-                            </el-form-item>
-                        </el-col>
-                    </el-row>
-                    <el-row>
-                        <el-col :span="12">
-                            <el-form-item label="点位类型" prop="type">
-                                <el-input v-model="inspectionTaskForm.type" class="analyseUnit_input"></el-input>
+                            <el-form-item label="执行巡检人员" prop="execUid">
+                                <el-select v-model="inspectionTaskForm.execUid" filterable clearable class="analyseUnit_input">
+                                    <el-option
+                                        v-for="item in execUidList"
+                                        :key="item.id"
+                                        :value="item.id"
+                                        :label="item.realname"
+                                    ></el-option>
+                                </el-select>
                             </el-form-item>
                         </el-col>
                     </el-row>
@@ -189,7 +263,7 @@
             <div class="inspectionTask_point">
                 <el-tabs class="active" v-model="activeName">
                     <el-tab-pane label="巡检点信息" name="inspectionPoint">
-                        <inspection-point ref="inspectionPoint"></inspection-point>
+                        <inspection-point @giveToForm="receiveToForm" ref="inspectionPoint"></inspection-point>
                     </el-tab-pane>
                 </el-tabs>
             </div>
@@ -203,21 +277,35 @@
 </template>
 
 <script>
+    import Cookies from "js-cookie";
     import { mapGetters } from 'vuex'
     import { computePageCount } from '@/utils'
     import inspectionPoint from './components/inpectionPoint'
-    import { addAnalyseUnit, deleteAnalyseUnit, getAnalyseUnitList, updateAnalyseUnit } from '@/api/riskLevelManage'
-    import { getInspectionTask } from "../../../../api/inspectionTask";
+    import { getInspectionTask , addInspectionTask, updateInspectionTask} from "../../../../api/inspectionTask";
     import {getAllDepartment, getDepartmentList} from "../../../../api/departmentManage";
+    import {safetyInspectionItemName} from "../../../../api/safetySelfInspection";
     export default {
         name: 'index',
         filters: {
-            parseMain(type){
-                if(type === 1){
-                    return "是"
-                }else if(type === 0){
-                    return "否"
+            parseHours(seconds){
+                let arg1 = parseFloat(seconds)
+                let arg2 = parseFloat(3600)
+                let t1 = 0
+                let t2 = 0
+                let r1
+                let r2
+                try {
+                    t1 = arg1.toString().split(".")[1].length;
+                }catch (e){
+
                 }
+                try {
+                    t2 = arg2.toString().split(".")[1].length;
+                }catch (e){
+                }
+                r1 = Number(arg1.toString().replace(".",""))
+                r2 = Number(arg2.toString().replace(".",""))
+                return r1/r2*Math.pow(10,t2-t1)
             },
         },
         computed: {
@@ -234,6 +322,13 @@
                 activeName:'inspectionPoint',
                 inspectionTaskData: [],
                 departmentList:[],
+                userList:[],
+                noticeUidList:[],
+                execUidList:[],
+                intervalSecondsList:[{id:7200,name:'2小时'},{id:21600,name:'6小时'},{id:43200,name:'12小时'},{id:86400,name:'1天'},{id:17280,name:'2天'}],
+                noticeSecondsList:[{id:600,name:'10分'},{id:3600,name:'1小时'},{id:7200,name:'2小时'},{id:21600,name:'6小时'},{id:43200,name:'12小时'},{id:86400,name:'1天'}],
+                effectSecondsList:[{id:1800,name:'30分'},{id:3600,name:'1小时'},{id:7200,name:'2小时'},{id:21600,name:'6小时'},{id:43200,name:'12小时'},{id:86400,name:'1天'}],
+                typeList:[{id:1,name:'日常检查'},{id:2,name:'周期检查'}],
                 listLoading: false,
                 pageSize: 10,
                 recordTotal: 0,
@@ -242,6 +337,8 @@
                 title:'',
                 company:'',
                 code:'',
+                noticeDepartment:'',
+                execDepartment:'',
                 inspectionTaskVisible:false,
                 inspectionTaskFormRules:{
                     hazardDep: [{ required: true, message: '责任部门不能为空', trigger: 'change' }],
@@ -250,17 +347,17 @@
                     riskUnitName: [{ required: true, message: '安全风险分析单元名称不能为空', trigger: 'blur' }],
                 },
                 inspectionTaskForm:{
-                    createUid: 0,
-                    effectSeconds: 0,
-                    execUid: 0,
-                    intervalSeconds: 0,
-                    noticeSeconds: 0,
-                    noticeUid: 0,
+                    type:null,
+                    createUid: null,
+                    effectSeconds: null,
+                    execUid: null,
+                    intervalSeconds: null,
+                    noticeSeconds: null,
+                    noticeUid: null,
+                    title:'',
                     riskControlMeasureIdList: [
-                        0
                     ],
                     startTime: "",
-                    type: 0
                 },
                 listQuery:{
                     createUid: "",
@@ -276,6 +373,7 @@
         created() {
             this.getInspectionTaskData()
             this.getDepartment()
+            this.getUser()
         },
         methods: {
             async getInspectionTaskData(){
@@ -286,7 +384,7 @@
                     this.pageSize = res.data.result.size
                     this.pageTotal = computePageCount(res.data.result.total, res.data.result.size)
                     this.currentPage = res.data.result.current
-                    this.inspectionTaskData = res.data.result.records
+                    this.inspectionTaskData = res.data.result
                 }else if(res.data.code === '300'){
                     this.inspectionTaskData = []
                 }
@@ -309,7 +407,33 @@
                     })
                 }
             },
+            changeNotice(){
+                if(this.noticeDepartment === '') {
+                    this.noticeUidList = []
+                    this.inspectionTaskForm.noticeUid = ''
+                }
+                this.noticeUidList = this.userList.filter( item => item.department === this.noticeDepartment)
+            },
+            changeExec(){
+                if(this.execDepartment === '') {
+                    this.execUidList = []
+                    this.inspectionTaskForm.execUid = ''
+                }
+                this.execUidList = this.userList.filter ( item => item.department === this.execDepartment)
+            },
+            async getUser(){
+                let res = await safetyInspectionItemName()
+                if(res.data.code === '200'){
+                    this.userList = res.data.result
+                }else{
+                    this.$message({
+                        message:res.data.message,
+                        type:'warning'
+                    })
+                }
+            },
             showAnalyseUnitForm(value,type){
+                debugger
                 this.inspectionTaskVisible = true
                 this.$nextTick(() =>{
                     this.$refs["inspectionTaskForm"].clearValidate()
@@ -317,29 +441,34 @@
                 if(type === '新增'){
                     this.title = '新建巡检计划设定'
                     this.inspectionTaskForm = {
-                        id: null,
-                        hazardCode: "",
-                        hazardDep: "",
-                        hazardLiablePerson: "",
-                        riskUnitName: "",
-                        createTime: "",
-                        updateTime: "",
-                        createBy: "",
-                        updateBy: "",
-                        validFlag: null,
-                        hazardLiablePersonId: null,
-                        hazardDepId: 1
+                        type:null,
+                        createUid: parseInt(Cookies.get('userId')),
+                        effectSeconds: null,
+                        execUid: null,
+                        intervalSeconds: null,
+                        noticeSeconds: null,
+                        noticeUid: null,
+                        title:'',
+                        riskControlMeasureIdList: [
+                        ],
+                        startTime: "",
                     }
-                }else{
-                    this.title = '修改'
-                    this.inspectionTaskForm = value
+                    setTimeout(() => {
+                        this.$refs.inspectionPoint.inspectionPointData = []
+                    });
+           }else{
+                    this.title = '编辑巡检计划设定'
+                    this.inspectionTaskForm = JSON.parse(JSON.stringify(value))
+                     setTimeout(() => {
+                        this.$refs.inspectionPoint.inspectionPointData =  this.inspectionTaskForm.checkContents
+                    });
                 }
             },
             submitAnalyseUnit(){
                 this.$refs["inspectionTaskForm"].validate((valid) =>{
                     if(valid){
-                        if(this.title === '新增'){
-                            addAnalyseUnit(this.inspectionTaskForm).then((res)=>{
+                        if(this.title === '新建巡检计划设定'){
+                            addInspectionTask(this.inspectionTaskForm).then((res)=>{
                                 if(res.data.code === '200'){
                                     this.inspectionTaskVisible = false
                                     this.getInspectionTaskData()
@@ -357,7 +486,7 @@
                                 }
                             })
                         }else{
-                            updateAnalyseUnit(this.inspectionTaskForm).then((res)=>{
+                            updateInspectionTask(this.inspectionTaskForm).then((res)=>{
                                 if(res.data.code === '200'){
                                     this.inspectionTaskVisible = false
                                     this.getInspectionTaskData()
@@ -401,6 +530,13 @@
                     })
                 })
             },
+            receiveToForm(value) {
+                debugger
+                this.inspectionTaskForm.riskControlMeasureIdList = []
+                this.inspectionTaskForm.riskControlMeasureIdList = value.map( item => {
+                    return item.id
+                })
+            },
             refreshHandle(){
                 this.getInspectionTaskData()
             },

--
Gitblit v1.9.2