From 20158b070098e322336a8bac8f04d59cc9fc09da Mon Sep 17 00:00:00 2001
From: Your Name <123456>
Date: 星期五, 25 三月 2022 10:00:27 +0800
Subject: [PATCH] Merge branch 'master' of https://sinanoaq.cn:8888/r/ztqt

---
 src/api/departmentManage.js                            |   13 
 /dev/null                                              |  411 ----------
 src/views/hiddenDanger/rectify.vue                     |  212 +++++
 src/views/hiddenDanger/acceptDialog/acceptDialog.vue   |  227 +++++
 src/views/hiddenDanger/rectifyDialog/rectifyDialog.vue |  261 ++++++
 src/views/hiddenDanger/personSelect/personSelect.vue   |  166 ++++
 src/api/hiddenDanger.js                                |   50 +
 src/views/hiddenDanger/report.vue                      |  374 ++------
 src/views/hiddenDanger/reportView/reportView.vue       |   52 
 src/views/hiddenDanger/reportDialog/reportDialog.vue   |  221 +++++
 src/views/hiddenDanger/statistics.vue                  |  145 ++-
 src/views/hiddenDanger/accept.vue                      |  215 +++++
 12 files changed, 1,593 insertions(+), 754 deletions(-)

diff --git a/src/api/departmentManage.js b/src/api/departmentManage.js
index 2525b1d..b5d87bf 100644
--- a/src/api/departmentManage.js
+++ b/src/api/departmentManage.js
@@ -56,3 +56,16 @@
         method: 'get',
     })
 }
+
+
+
+export function geDepartmentUserPage(data) {
+    return request({
+        headers: {
+            'Authorization': getToken()
+        },
+        url: process.env.BASE_API + '/department-userList',
+        method: 'post',
+        data
+    })
+}
diff --git a/src/api/hiddenDanger.js b/src/api/hiddenDanger.js
index 521534d..c7fcbee 100644
--- a/src/api/hiddenDanger.js
+++ b/src/api/hiddenDanger.js
@@ -23,6 +23,18 @@
     });
 }
 
+
+export function hiddenDangerRectify(data) {
+    return request({
+        headers:{
+            'Authorization': getToken()
+        },
+        url: process.env.BASE_API+'/hiddenDanger/rectify',
+        method: 'post',
+        data
+    });
+}
+
 export function hiddenDangerConfirm(data) {
     return request({
         headers:{
@@ -34,6 +46,28 @@
     });
 }
 
+export function hiddenDangerAccept(data) {
+    return request({
+        headers:{
+            'Authorization': getToken()
+        },
+        url: process.env.BASE_API+'/hiddenDanger/accept',
+        method: 'post',
+        data
+    });
+}
+
+
+export function hiddenDangerReject(data) {
+    return request({
+        headers:{
+            'Authorization': getToken()
+        },
+        url: process.env.BASE_API+'/hiddenDanger/reject',
+        method: 'post',
+        data
+    });
+}
 
 export function hiddenDangerReportList(data) {
     return request({
@@ -47,12 +81,24 @@
 }
 
 
-export function hiddenDangerConfirmList(data) {
+export function hiddenDangerAcceptList(data) {
     return request({
         headers:{
             'Authorization': getToken()
         },
-        url: process.env.BASE_API+'/hiddenDanger/confirmPage',
+        url: process.env.BASE_API+'/hiddenDanger/acceptPage',
+        method: 'post',
+        data
+    });
+}
+
+
+export function hiddenDangerRectifyList(data) {
+    return request({
+        headers:{
+            'Authorization': getToken()
+        },
+        url: process.env.BASE_API+'/hiddenDanger/rectifyPage',
         method: 'post',
         data
     });
diff --git a/src/views/hiddenDanger/accept.vue b/src/views/hiddenDanger/accept.vue
new file mode 100644
index 0000000..d8e28cf
--- /dev/null
+++ b/src/views/hiddenDanger/accept.vue
@@ -0,0 +1,215 @@
+<template>
+    <div class="app-container">
+        <div style="margin: 15px">
+            <span class="span-filter-label">单号</span>
+            <el-input style="width: 140px" v-model="filter.filter.code" ></el-input>
+            <span class="span-filter-label">隐患等级</span>
+            <el-select v-model="filter.filter.level" clearable  @clear="clearLevel" placeholder="请选择">
+                <el-option
+                    v-for="item in levels"
+                    :key="item.key"
+                    :label="item.value"
+                    :value="item.key">
+                </el-option>
+            </el-select>
+            <span class="span-filter-label">整改人</span>
+            <el-input style="width: 160px" v-model="filter.filter.rectifierName"></el-input>
+            <el-button class="filter-item" style="margin-left: 10px;" type="primary" icon="el-icon-search"
+                       @click="queryHandle"/>
+        </div>
+        <div class="table_content">
+            <el-table
+                v-loading="listLoading"
+                :key="tableKey"
+                :data="tableData"
+                border
+                fit
+                highlight-current-row
+                style="width: 100%;"
+            >
+                <el-table-column type="index" label="序号" align="center" width="80"/>
+                <el-table-column label="单号" prop="code" align="center" />
+                <el-table-column label="状态" prop="status" align="center" >
+                    <template slot-scope="scope">
+                        <span >{{scope.row.status}}</span>
+                        <span v-if="new Date(scope.row.rectifydeadline) < new Date() && scope.row.status  !== '已完成'" class="overdue-img">逾期</span>
+                    </template>
+                </el-table-column>
+                <el-table-column label="隐患等级" prop="level" align="center" >
+                    <template slot-scope="scope">
+                        <el-tag :type="scope.row.level == '紧急'?'danger':'warning'">{{scope.row.level}}</el-tag>
+                    </template>
+                </el-table-column>
+                <el-table-column label="上报人" prop="requestor" align="center" />
+                <el-table-column label="上报时间" prop="createtime" align="center" />
+                <el-table-column label="整改人" prop="rectifier" align="center" />
+                <el-table-column label="整改期限"   prop="rectifydeadline" align="center" >
+                    <template slot-scope="scope">
+                        <span v-bind:class="{'overdue':new Date(scope.row.rectifydeadline) < new Date() && scope.row.status  !== '已完成'}">{{scope.row.rectifydeadline}}
+                        </span>
+                    </template>
+                </el-table-column>
+                <el-table-column label="整改时间" prop="rectifytime" align="center" />
+
+
+                <el-table-column label="操作" align="center" width="240" class-name="small-padding fixed-width">
+                    <template slot-scope="scope">
+                        <el-button  type="text" @click="viewHandle(scope.row)">查看</el-button>
+                        <el-button  type="text" @click="acceptHandle(scope.row)" v-if="scope.row.status === '整改待验收'">验收</el-button>
+                    </template>
+                </el-table-column>
+            </el-table>
+            <br>
+            <el-pagination
+                v-show="recordTotal>0"
+                :current-page="filter.pageIndex"
+                :page-sizes="[10, 20, 30, 50]"
+                :page-size="filter.pageSize"
+                :total="recordTotal"
+                layout="total, sizes, prev, pager, next, jumper"
+                background
+                style="float:right;"
+                @size-change="handleSizeChange"
+                @current-change="handleCurrentChange"
+            />
+        </div>
+
+        <report-view ref="reportView"></report-view>
+        <accept-dialog ref="acceptDialog" @refresh="hiddenDangerList"></accept-dialog>
+
+
+        <div style="clear: both;"></div>
+    </div>
+</template>
+
+<script>
+import { checkBtnPermission} from "@/utils/permission";
+import { hiddenDangerAcceptList} from '@/api/hiddenDanger';
+import reportView from "./reportView/reportView";
+import acceptDialog from "./acceptDialog/acceptDialog";
+
+export default {
+    name: "confirm",
+  components: {
+    reportView,
+    acceptDialog,
+  },
+    data() {
+      return {
+        recordTotal: 0,
+        tableKey: 0,
+        tableData:[],
+        listLoading: true,
+        levels:[
+          {"key":"URGENT","value":"紧急"},
+          {"key":"COMMON","value":"一般"},
+        ],
+        dataForm: {
+          id:'',
+          note: '',
+          level:'',
+          rejectnote:'',
+        },
+        filter:{
+          pageIndex:1,
+          pageSize:10,
+          filter:{
+            code:'',
+            level:null,
+            rectifierName:'',
+          }
+        }
+      }
+    },
+    created() {
+      this.hiddenDangerList();
+    },
+
+    methods: {
+        queryHandle: function () {
+            this.filter.pageIndex = 1
+            this.hiddenDangerList()
+        },
+
+
+        viewHandle: function (row) {
+          this.$refs.reportView.showDialog("查看",row)
+        },
+
+        acceptHandle(row){
+            this.$refs.acceptDialog.showDialog(row)
+        }  ,
+
+        handleSizeChange: function (val) {
+            this.filter.pageSize = val
+            this.filter.pageIndex = 1
+            this.hiddenDangerList()
+        },
+        handleCurrentChange: function (val) {
+            this.filter.pageIndex = val
+            this.hiddenDangerList()
+        },
+        getBtnPermission(btnType) {
+            return checkBtnPermission(this.userType, btnType)
+        },
+
+        downloadHandle(fileurl){
+            window.open(fileurl, '_blank');
+        },
+
+
+      handleChange(file, fileList) {
+        this.fileList = fileList
+      },
+
+      hiddenDangerList(){
+          this.listLoading = true
+          hiddenDangerAcceptList(this.filter)
+              .then(res=>{
+                if (res.data.code === '200') {
+                  this.tableData =  res.data.result.records
+                  this.recordTotal =  res.data.result.total
+                }
+                else{
+                    this.$message({message: res.data.message, type: 'warning'});
+                }
+              })
+              .catch(err=>{
+                  console.log(err)
+                  this.$message({message: '接口错误', type: 'warning'});
+              })
+              .finally(()=>{
+                  this.listLoading = false
+              })
+      },
+      clearLevel(){
+            this.filter.filter.level = null
+      }
+
+
+    }
+}
+</script>
+
+<style scoped>
+    .overdue{
+        color: red;
+    }
+    .overdue-img{
+        position: fixed;
+        background-color: #f56c6c;
+        border-radius: 4px;
+        color: #fff;
+        display: inline-block;
+        font-size: 12px;
+        height: 21px;
+        line-height: 18px;
+        text-align: center;
+        white-space: nowrap;
+        border: 1px solid #fff;
+        transform: scale(0.8);
+        padding: 1px 3px 0 3px;
+
+    }
+
+</style>
diff --git a/src/views/hiddenDanger/acceptDialog/acceptDialog.vue b/src/views/hiddenDanger/acceptDialog/acceptDialog.vue
new file mode 100644
index 0000000..89b65ff
--- /dev/null
+++ b/src/views/hiddenDanger/acceptDialog/acceptDialog.vue
@@ -0,0 +1,227 @@
+<template>
+    <el-dialog title="验收" :visible.sync="dialogFormVisible"
+               :modal-append-to-body="false" :close-on-click-modal="false" width="800px">
+        <el-form ref="dataForm" :rules="dataFormRules" :model="dataForm" label-position="right" label-width="140px"
+                 style="" element-loading-text="保存中...">
+
+
+            <el-form-item label="隐患级别:">
+                <el-select v-model="dataForm.level"   :disabled="isView">
+                    <el-option
+                        v-for="item in levels"
+                        :key="item.key"
+                        :label="item.value"
+                        :value="item.key">
+                    </el-option>
+                </el-select>
+            </el-form-item>
+
+            <el-form-item label="整改措施:" >
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    :disabled="isView"
+                    v-model="dataForm.rectifymeasure">
+                </el-input>
+            </el-form-item>
+
+            <el-form-item label="整改期限:" >
+                <el-date-picker
+                    v-model="dataForm.rectifydeadline"
+                    type="datetime"
+                    :disabled="isView"
+                    format="yyyy-MM-dd HH:mm"
+                    value-format="yyyy-MM-dd HH:mm"
+                >
+                </el-date-picker>
+            </el-form-item>
+
+            <el-form-item label="上报说明:" >
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    :disabled="isView"
+                    v-model="dataForm.createnote">
+                </el-input>
+            </el-form-item>
+
+            <el-form-item label="上报图片:" v-if="!isView">
+                <el-upload
+                    ref="upload"
+                    :action="baseUrl"
+                    :auto-upload="false"
+                    :headers="headers"
+                    :on-change="handleChange"
+                    name="file"
+                    :file-list="fileList"
+                    list-type="picture-card"
+                    multiple
+                >
+                    <i class="el-icon-plus"></i>
+                </el-upload>
+
+            </el-form-item>
+
+            <el-form-item label="上报图片:" v-if="isView && imgUrls.length > 0" >
+                <el-image
+                    class="upload-img"
+                    v-for='item in imgUrls'
+                    :key='item.id'
+                    :src="item.url"
+                    :preview-src-list="imgPreviewUrls"
+                    style="width:100px;height: 100px;margin: 10px;"
+                >
+                </el-image>
+            </el-form-item>
+
+
+            <el-form-item label="整改说明:"  v-if="isView">
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    :disabled="isView"
+                    v-model="dataForm.rectifynote">
+                </el-input>
+            </el-form-item>
+
+            <el-form-item label="整改图片:"  v-if="isView && imgUrls2.length> 0">
+                <el-image
+                    class="upload-img"
+                    v-for='item in imgUrls2'
+                    :key='item.id'
+                    :src="item.url"
+                    :preview-src-list="imgPreviewUrls2"
+                    style="width:100px;height: 100px;margin: 10px;"
+                >
+                </el-image>
+
+            </el-form-item>
+
+            <el-form-item label="选择:"  >
+                <el-radio-group v-model="isReject" >
+                    <el-radio :label="false" border>验收</el-radio>
+                    <el-radio :label="true" border>驳回</el-radio>
+                </el-radio-group>
+            </el-form-item>
+
+
+            <el-form-item label="驳回理由:"  v-if="isReject">
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    v-model="dataForm.rejectnote">
+                </el-input>
+            </el-form-item>
+
+        </el-form>
+
+        <div style="margin-top: 30px;margin-left: 140px;"  class="dialog-footer" >
+            <el-button @click="dialogFormVisible = false">取消</el-button>
+            <el-button type="primary" @click="acceptSubmit()" v-if="!isReject" :disabled="submiting">验收</el-button>
+            <el-button type="primary" class="el-button el-button--danger"  @click="rejectSubmit()" v-if="isReject" :disabled="submiting">驳回</el-button>
+
+        </div>
+
+    </el-dialog>
+</template>
+
+
+<script>
+    import { hiddenDangerAccept,hiddenDangerReject} from '@/api/hiddenDanger';
+    import { getToken} from "@/utils/auth";
+
+    export default {
+        name: "acceptDialog",
+        data(){
+            return {
+                headers: {
+                    'Authorization': getToken()
+                },
+                baseUrl: process.env.BASE_API + 'hiddenDanger/report',
+                imgUrls:[],
+                imgUrls2:[],
+                fileList:[],
+                imgPreviewUrls:[],
+                imgPreviewUrls2:[],
+                isView:false,
+                isReject:false,
+                submiting:false,
+                levels:[
+                    {"key":"URGENT","value":"紧急"},
+                    {"key":"COMMON","value":"一般"},
+                ],
+                dataForm: {
+                    id:'',
+                    note: '',
+                    level:'',
+                    rejectnote:'',
+                },
+                dialogFormVisible: false,
+                dialogStatus:'',
+                dataFormRules: {},
+            }
+        },
+        methods:{
+            showDialog(row){
+                this.isView = true
+                this.dataForm.id = row.id
+                this.dataForm.level = row.level;
+                this.dataForm.createnote = row.createnote;
+                this.dataForm.rectifydeadline = row.rectifydeadline;
+                this.dataForm.rectifymeasure = row.rectifymeasure;
+                this.dataForm.rectifynote = row.rectifynote;
+                this.imgUrls = row.reportResources.map(item=>{return {url:process.env.IMG_API+item.url,name:item.id}})
+                this.imgUrls2 = row.rectifyResources.map(item=>{return {url:process.env.IMG_API+item.url,name:item.id}})
+                this.imgPreviewUrls = row.reportResources.map(item=>{ return process.env.IMG_API + item.url })
+                this.imgPreviewUrls2 = row.rectifyResources.map(item=>{ return process.env.IMG_API + item.url })
+                this.dialogFormVisible = true;
+            },
+            acceptSubmit(){
+                let params = {}
+                params['id'] = this.dataForm.id
+                this.submit(params,hiddenDangerAccept)
+
+            },
+
+            rejectSubmit(){
+                let params = {}
+                params['id'] = this.dataForm.id
+                params['rejectnote'] = this.dataForm.rectifynote
+                this.submit(params,hiddenDangerReject)
+            },
+
+            submit(params,func){
+                this.submiting = true
+                func(params)
+                    .then(res=>{
+                        if (res.data.code === '200') {
+                            this.dialogFormVisible = false
+                            this.$message({message: '操作成功', type: 'success'});
+                            this.$emit("refresh")
+                        }else{
+                            this.$message({message: res.data.message, type: 'success'});
+                        }
+                        this.fileList = []
+                    })
+                    .catch(err=>{
+                        console.log(err);
+                        this.$message({message: '接口错误', type: 'warning'});
+                    })
+                    .finally(()=>{
+                        this.submiting = false
+                    })
+            },
+            handleChange(file, fileList) {
+                this.fileList = fileList
+            },
+        }
+    }
+</script>
+
+<style scoped>
+
+</style>
diff --git a/src/views/hiddenDanger/confirm.vue b/src/views/hiddenDanger/confirm.vue
deleted file mode 100644
index dc176f0..0000000
--- a/src/views/hiddenDanger/confirm.vue
+++ /dev/null
@@ -1,411 +0,0 @@
-<template>
-    <div class="app-container">
-        <div style="margin: 15px">
-            <span class="span-filter-label">作业编号:</span>
-            <el-input style="width: 160px" v-model="filter.filter.taskcode"></el-input>
-            <span class="span-filter-label">隐患等级</span>
-            <el-select v-model="filter.filter.level"  placeholder="请选择">
-                <el-option
-                    v-for="item in levels"
-                    :key="item.key"
-                    :label="item.value"
-                    :value="item.key">
-                </el-option>
-            </el-select>
-            <span class="span-filter-label">负责人</span>
-            <el-input style="width: 160px" v-model="filter.filter.requestor"></el-input>
-            <span class="span-filter-label">整改人</span>
-            <el-input style="width: 160px" v-model="filter.filter.supervisor"></el-input>
-            <el-button class="filter-item" style="margin-left: 10px;" type="primary" icon="el-icon-search"
-                       @click="queryHandle"/>
-        </div>
-        <div class="table_content">
-            <el-table
-                v-loading="listLoading"
-                :key="tableKey"
-                :data="tableData"
-                border
-                fit
-                highlight-current-row
-                style="width: 100%;"
-            >
-                <el-table-column type="index" label="序号" align="center" width="80"/>
-                <el-table-column label="状态" prop="status" align="center" />
-                <el-table-column label="作业编号" prop="taskcode" align="center" />
-                <el-table-column label="隐患等级" prop="level" align="center" >
-                    <template slot-scope="scope">
-                        <el-tag :type="scope.row.level == '紧急'?'danger':'warning'">{{scope.row.level}}</el-tag>
-                    </template>
-                </el-table-column>
-                <el-table-column label="上报人" prop="requestor" align="center" />
-                <el-table-column label="负责人" prop="principal" align="center" />
-                <el-table-column label="整改" prop="supervisor" align="center" />
-
-                <el-table-column label="创建时间" prop="createtime" align="center" />
-                <el-table-column label="操作" align="center" width="240" class-name="small-padding fixed-width">
-                    <template slot-scope="scope">
-                        <el-button  type="text" @click="viewHandle(scope.row)">查看</el-button>
-                        <el-button  type="text" @click="confirmHandle(scope.row)" v-if="scope.row.status === '未确认'">上报确认</el-button>
-                    </template>
-                </el-table-column>
-            </el-table>
-            <br>
-            <el-pagination
-                v-show="recordTotal>0"
-                :current-page="currentPage"
-                :page-sizes="[10, 20, 30, 50]"
-                :page-size="pageSize"
-                :total="recordTotal"
-                layout="total, sizes, prev, pager, next, jumper"
-                background
-                style="float:right;"
-                @size-change="handleSizeChange"
-                @current-change="handleCurrentChange"
-            />
-        </div>
-        <el-dialog :title="dialogStatus==='confirm'?'上报确认':'查看'" :visible.sync="dialogFormVisible"
-                   :modal-append-to-body="false" :close-on-click-modal="false" width="800px">
-            <el-form ref="dataForm" :rules="dataFormRules" :model="dataForm" label-position="right" label-width="140px"
-                     style="" element-loading-text="保存中...">
-
-                <el-form-item label="作业编号:">
-                    <el-select v-model="dataForm.taskid" filterable placeholder="请选择" :disabled="isView">
-                        <el-option
-                            v-for="item in tasksInfo"
-                            :key="item.id"
-                            :label="item.code"
-                            :value="item.id">
-                        </el-option>
-                    </el-select>
-                </el-form-item>
-
-                <el-form-item label="隐患级别:">
-                    <el-select v-model="dataForm.level"  placeholder="请选择" :disabled="isView">
-                        <el-option
-                            v-for="item in levels"
-                            :key="item.key"
-                            :label="item.value"
-                            :value="item.key">
-                        </el-option>
-                    </el-select>
-                </el-form-item>
-
-                <el-form-item label="上报说明:" >
-                    <el-input
-                        style="width: 400px"
-                        type="textarea"
-                        :rows="3"
-                        :disabled="isView"
-                        placeholder="请输入内容"
-                        v-model="dataForm.note">
-                    </el-input>
-                </el-form-item>
-
-                <el-form-item label="上报图片:" v-if="!isView">
-                    <el-upload
-                        ref="upload"
-                        :action="baseUrl"
-                        :auto-upload="false"
-                        :headers="headers"
-                        :on-change="handleChange"
-                        name="file"
-                        :file-list="fileList"
-                        list-type="picture-card"
-                        multiple
-                    >
-                        <i class="el-icon-plus"></i>
-                    </el-upload>
-
-                </el-form-item>
-
-                <el-form-item label="上报图片:" v-if="isView && imgUrls.length > 0" >
-                    <el-image
-                        class="upload-img"
-                        v-for='item in imgUrls'
-                        :key='item.id'
-                        :src="item.url"
-                        :preview-src-list="imgPreviewUrls"
-                        style="width:200px;height: 200px;margin: 10px;"
-                    >
-                    </el-image>
-                </el-form-item>
-
-                <el-form-item label="隐患确认:" >
-                        <el-radio v-model="dataForm.ishiddendanger" label="1" border >是隐患</el-radio>
-                        <el-radio v-model="dataForm.ishiddendanger" label="0" border >非隐患</el-radio>
-                </el-form-item>
-
-                <el-form-item label="确认说明:"  >
-                    <el-input
-                        style="width: 400px"
-                        type="textarea"
-                        :rows="3"
-                        placeholder="请输入内容"
-                        v-model="dataForm.confirmnote">
-                    </el-input>
-                </el-form-item>
-
-
-
-            </el-form>
-
-            <div style="margin-top: 20px;margin-left: 140px;"  class="dialog-footer" >
-                <el-button @click="dialogFormVisible = false">取消</el-button>
-                <el-button type="primary" @click="trigger2Submit(dataForm.id)">隐患确认</el-button>
-            </div>
-
-        </el-dialog>
-        <report-view ref="reportView"></report-view>
-
-
-        <div style="clear: both;"></div>
-    </div>
-</template>
-
-<script>
-import { checkBtnPermission} from "@/utils/permission";
-import { getSelectTask,hiddenDangerConfirm ,hiddenDangerConfirmList} from '@/api/hiddenDanger';
-import { getToken} from "@/utils/auth";
-import reportView from "./reportView/reportView";
-import { param } from '../../utils'
-
-export default {
-    name: "confirm",
-  components: {
-    reportView
-  },
-    data() {
-      return {
-        baseUrl: process.env.BASE_API + 'hiddenDanger/report',
-        headers: {
-          'Authorization': getToken()
-        },
-        tasksInfo: [],
-        imgUrls:[],
-        imgPreviewUrls:[],
-        isView:false,
-        isConfirm:false,
-        confirmShow:false,
-        isRectify:false,
-        fileList: [],
-        pageSize: 10,
-        recordTotal: 0,
-        currentPage: 1,
-        pageTotal: 0,
-        tableKey: 0,
-        tableData:[],
-        helpDocData: null,
-        listLoading: true,
-        levels:[
-          {"key":"URGENT","value":"紧急"},
-          {"key":"COMMON","value":"一般"},
-        ],
-        dataForm: {
-          id:'',
-          taskid: '',
-          note: '',
-          level:'',
-          confirmnote:'',
-          ishiddendanger:''
-        },
-        queryForm: {
-          name: ''
-        },
-        dialogFormVisible: false,
-        dialogStatus: '',
-        dataFormRules: {},
-        fileType: [],
-        productVoList: [],
-        productVoDialogVisible: false,
-
-        productDialogFormVisible: false,
-        productData: [],
-        pageSizeProduct: 10,
-        currentPageProduct: 1,
-        recordTotalProduct: 0,
-        pageTotalProduct: 0,
-        queryProductForm: {
-          name: '',
-          manufacturer: '',
-          directionCode: '',
-          type: ''
-        },
-        isSupervision: '',
-
-        manufacturer: '',
-        enterpriseList: [],
-        enterpriseDialogFormVisible: false,
-        pageSizeEnterpise: 10,
-        currentPageEnterpise: 1,
-        recordTotalEnterpise: 0,
-        pageTotalEnterpise: 0,
-        filter:{
-          pageIndex:1,
-          pageSize:10,
-          filter:{
-            taskcode:'',
-            supervisor:'',
-            requestor:'',
-            level:""
-          }
-        }
-      }
-    },
-    created() {
-      this.hiddenDangerList();
-
-    },
-    computed: {
-
-    },
-    methods: {
-        refreshHandle: function () {
-            this.hiddenDangerList()
-        },
-        queryHandle: function () {
-            this.currentPage = 1
-            this.hiddenDangerList()
-        },
-        resetDataForm() {
-            this.dataForm = {
-              dataForm: {
-                taskid: '',
-                taskcode:'',
-                note: '',
-                level:''
-              }
-            }
-        },
-        showCreateHandle() {
-          this.getSelectTasks()
-            this.resetDataForm()
-            this.dialogStatus = 'create'
-            this.isView = false
-            this.dialogFormVisible = true
-            this.$nextTick(() => {
-                this.$refs['dataForm'].clearValidate()
-            })
-        },
-        viewHandle: function (row) {
-
-          this.$refs.reportView.showDialog("查看",row)
-
-        },
-      confirmHandle:function(row){
-            this.resetDataForm();
-            this.dialogStatus = 'confirm';
-            this.isView = true
-            this.confirmShow = true;
-            this.dataForm.id = row.id
-            this.dataForm.taskid = row.taskcode
-            this.dataForm.level = row.level;
-            this.dataForm.note = row.createnote;
-            this.imgUrls = row.reportResources.map(item=>{return {url:process.env.IMG_API+item.url,name:item.id}})
-            this.imgPreviewUrls = row.reportResources.map(item=>{ return process.env.IMG_API + item.url })
-            this.dialogFormVisible = true;
-      },
-        handleSizeChange: function (val) {
-            this.pageSize = val
-            this.currentPage = 1
-            this.hiddenDangerList()
-        },
-        handleCurrentChange: function (val) {
-            this.currentPage = val
-            this.hiddenDangerList()
-        },
-        getBtnPermission(btnType) {
-            return checkBtnPermission(this.userType, btnType)
-        },
-
-        showProductHandle(){
-            this.productDialogFormVisible = true;
-        },
-        showEnterprise(){
-            this.enterpriseDialogFormVisible = true;
-        },
-        downloadHandle(fileurl){
-            window.open(fileurl, '_blank');
-        },
-
-
-
-        getSelectTasks(){
-          getSelectTask()
-            .then(res=>{
-              if (res.status !== 200)
-                this.$message({
-                  message: '接口错误',
-                  type: 'success'
-                });
-              else{
-                this.tasksInfo = res.data.result.map(item=>{return {"id":item.id,"code":item.code}})
-              }
-            })
-
-            .catch(res=>{
-              console.log(res)
-            })
-        },
-
-      handleChange(file, fileList) {
-        this.fileList = fileList
-      },
-
-      trigger2Submit(){
-        let params = {}
-        params['id'] = this.dataForm.id
-        params['note'] = this.dataForm.confirmnote
-        params['ishiddendanger'] = this.dataForm.ishiddendanger
-
-        hiddenDangerConfirm(params).then(res=>{
-          if (res.status === 200) {
-            if (res.data.code === '200') {
-              this.dialogFormVisible = false
-              this.$message({
-                message: '操作成功',
-                type: 'success'
-              });
-              this.hiddenDangerList()
-            }else{
-              this.$message({
-                message: res.data.message,
-                type: 'success'
-              });
-            }
-            this.fileList = []
-
-          }
-          else{
-            this.$message({
-              message: '接口错误',
-              type: 'warning'
-            });
-          }
-          }
-        )
-      },
-
-      hiddenDangerList(){
-        hiddenDangerConfirmList(this.filter).then(res=>{
-          this.listLoading = false
-          if (res.status === 200) {
-            if (res.data.code === '200') {
-              this.tableData =  res.data.result.records
-            }
-          }else{
-            this.$message({
-              message: '接口错误',
-              type: 'warning'
-            });
-
-          }
-        })
-      },
-
-    }
-}
-</script>
-
-<style scoped>
-
-</style>
diff --git a/src/views/hiddenDanger/personSelect/personSelect.vue b/src/views/hiddenDanger/personSelect/personSelect.vue
new file mode 100644
index 0000000..a77f966
--- /dev/null
+++ b/src/views/hiddenDanger/personSelect/personSelect.vue
@@ -0,0 +1,166 @@
+<template>
+    <el-dialog
+        :visible.sync="dialogVisible"
+        append-to-body
+        :close-on-click-modal="false"
+        width="75%"
+    >
+        <div class="app-container">
+            <div class="filter-container">
+                <div style="display: block;padding-top: 10px;padding-bottom: 10px">
+                    <div class="basic_search" >
+                        <el-select v-model="filter.filter.department"
+                                   filterable
+                                   clearable
+                                   @change="getPersonList"
+                                   placeholder="请选择">
+                            <el-option
+                                v-for="item in options"
+                                :key="item.value"
+                                :label="item.label"
+                                :value="item.value">
+                            </el-option>
+                        </el-select>
+                    </div>
+                    <el-button  type="primary" icon="el-icon-search" @click="queryHandle"  style="margin-left: 20px"/>
+                </div>
+            </div>
+            <div class="table_content">
+                <el-table
+                    v-loading="listLoading"
+                    :key="tableKey"
+                    :data="tableData"
+                    border
+                    fit
+                    highlight-current-row
+                    style="width: 100%;"
+                >
+                    <el-table-column label="序号" type="index" align="center" width="60"/>
+                    <el-table-column label="所属部门"  align="center">
+                        <template slot-scope="scope">
+                            <span>{{ scope.row.department}}</span>
+                        </template>
+                    </el-table-column>
+
+                    <el-table-column label="姓名"  align="center">
+                        <template slot-scope="scope">
+                            <span>{{ scope.row.realname }}</span>
+                        </template>
+                    </el-table-column>
+
+                    <el-table-column label="操作" align="center" width="180" class-name="small-padding fixed-width">
+                        <template slot-scope="scope">
+                            <el-button type="text" @click="selectOne(scope.row)">选择</el-button>
+                        </template>
+                    </el-table-column>
+                </el-table>
+                <br>
+                <el-pagination
+                    v-show="recordTotal>0"
+                    :current-page="filter.pageIndex"
+                    :page-sizes="[10, 20, 30, 50]"
+                    :page-size="filter.pageSize"
+                    :total="recordTotal"
+                    layout="total, sizes, prev, pager, next, jumper"
+                    background
+                    style="float:right;"
+                    @size-change="handleSizeChange"
+                    @current-change="handleCurrentChange"
+                />
+            </div>
+        </div>
+    </el-dialog>
+</template>
+
+<script>
+  import { geDepartmentUserPage ,getAllDepartment} from '@/api/departmentManage';
+  export default {
+    name: "taskSelect",
+    data(){
+      return{
+        tableKey:0,
+        listLoading:false,
+        recordTotal: 0,
+        options:[],
+        filter: {
+          pageIndex:1,
+          pageSize:10,
+          filter: {
+              department: ''
+          },
+       },
+        dialogVisible:false,
+        tableData:[],
+      }
+    },
+    created(){
+
+    },
+    methods:{
+      queryHandle(){
+          this.filter.pageIndex = 1
+          this.getPersonList()
+      },
+      handleSizeChange(val) {
+        this.filter.pageSize = val
+          this.filter.pageIndex = 1
+        this.getTaskData()
+      },
+      handleCurrentChange(val) {
+          this.filter.pageIndex = val
+        this.getPersonList()
+      },
+      show(){
+        this.dialogVisible = true
+        this.getDepartmentList()
+      },
+      selectOne(value){
+        this.$emit('setPerson',value)
+        this.dialogVisible = false
+      },
+      async getDepartmentList(){
+        let res = await getAllDepartment()
+        if(res.data.code === '200'){
+            this.options = res.data.result.map(item=>{return {value:item.department,label:item.department}})
+        }else{
+          this.$message({
+            message:res.data.message,
+            type:'warning'
+          })
+        }
+      },
+      async getPersonList(){
+          this.listLoading = true
+          geDepartmentUserPage(this.filter)
+              .then(res => {
+                  if (res.data.code === '200') {
+                      this.tableData = res.data.result.records
+                      this.recordTotal =  res.data.result.total
+                  }else{
+                      this.$message({
+                          message:res.data.message,
+                          type:'warning'
+                      })
+                  }
+              })
+             .catch(err=>{
+                 console.log(err)
+                 this.$message({
+                     message:'接口错误',
+                     type:'warning'
+                 })
+             })
+             .finally(()=>{
+                 this.listLoading = false
+              })
+      }
+
+    }
+  }
+</script>
+
+<style scoped>
+    .basic_search{
+        display:inline-block;
+    }
+</style>
diff --git a/src/views/hiddenDanger/rectify.vue b/src/views/hiddenDanger/rectify.vue
new file mode 100644
index 0000000..d429abe
--- /dev/null
+++ b/src/views/hiddenDanger/rectify.vue
@@ -0,0 +1,212 @@
+<template>
+    <div class="app-container">
+        <div style="margin: 15px">
+
+            <span class="span-filter-label">单号</span>
+            <el-input style="width: 140px" v-model="filter.filter.code" ></el-input>
+
+            <span class="span-filter-label">隐患等级</span>
+            <el-select v-model="filter.filter.level"  clearable @clear="clearLevel" placeholder="请选择">
+                <el-option
+                    v-for="item in levels"
+                    :key="item.key"
+                    :label="item.value"
+                    :value="item.key">
+                </el-option>
+            </el-select>
+
+            <span class="span-filter-label">上报人</span>
+            <el-input style="width: 160px" v-model="filter.filter.requestorName"></el-input>
+            <el-button class="filter-item" style="margin-left: 10px;" type="primary" icon="el-icon-search"
+                       @click="queryHandle"/>
+        </div>
+        <div class="table_content">
+            <el-table
+                v-loading="listLoading"
+                :key="tableKey"
+                :data="tableData"
+                border
+                fit
+                highlight-current-row
+                style="width: 100%;"
+            >
+                <el-table-column type="index" label="序号" align="center" width="80"/>
+                <el-table-column label="单号" prop="code" align="center" />
+                <el-table-column label="状态" prop="status" align="center" >
+                    <template slot-scope="scope">
+                        <span >{{scope.row.status}}</span>
+                        <span v-if="new Date(scope.row.rectifydeadline) < new Date() && scope.row.status  !== '已完成'" class="overdue-img">逾期</span>
+                    </template>
+                </el-table-column>
+                <el-table-column label="隐患等级" prop="level" align="center" >
+                    <template slot-scope="scope">
+                        <el-tag :type="scope.row.level == '紧急'?'danger':'warning'">{{scope.row.level}}</el-tag>
+                    </template>
+                </el-table-column>
+                <el-table-column label="上报人" prop="requestor" align="center" />
+                <el-table-column label="整改人" prop="rectifier" align="center" />
+                <el-table-column label="整改期限" prop="rectifydeadline" align="center" >
+                    <template slot-scope="scope">
+                        <span v-bind:class="{'overdue':new Date(scope.row.rectifydeadline) < new Date() && scope.row.status  !== '已完成'}">{{scope.row.rectifydeadline}}
+                        </span>
+                    </template>
+                </el-table-column>
+                <el-table-column label="创建时间" prop="createtime" align="center" />
+                <el-table-column label="操作" align="center" width="240" class-name="small-padding fixed-width">
+                    <template slot-scope="scope">
+                        <el-button  type="text" @click="viewHandle(scope.row)">查看</el-button>
+                        <el-button  type="text" @click="rectifyHandle(scope.row)" v-if="scope.row.status === '待整改' || scope.row.status === '驳回待整改'">整改</el-button>
+                    </template>
+                </el-table-column>
+            </el-table>
+            <br>
+            <el-pagination
+                v-show="recordTotal>0"
+                :current-page="filter.pageIndex"
+                :page-sizes="[10, 20, 30, 50]"
+                :page-size="filter.pageSize"
+                :total="recordTotal"
+                layout="total, sizes, prev, pager, next, jumper"
+                background
+                style="float:right;"
+                @size-change="handleSizeChange"
+                @current-change="handleCurrentChange"
+            />
+        </div>
+
+        <report-view ref="reportView"></report-view>
+        <rectify-dialog ref="rectifyDialog" @refresh = "hiddenDangerList"></rectify-dialog>
+
+        <div style="clear: both;"></div>
+    </div>
+</template>
+
+<script>
+import { checkBtnPermission} from "@/utils/permission";
+import { hiddenDangerRectifyList } from '@/api/hiddenDanger';
+import reportView from "./reportView/reportView";
+import rectifyDialog from "./rectifyDialog/rectifyDialog";
+
+export default {
+    name: "rectify",
+  components: {
+    reportView,
+    rectifyDialog,
+  },
+    data() {
+      return {
+        recordTotal: 0,
+        tableKey: 0,
+        tableData:[],
+        listLoading: false,
+        levels:[
+          {"key":"URGENT","value":"紧急"},
+          {"key":"COMMON","value":"一般"},
+        ],
+        dataForm: {
+          id:'',
+          note: '',
+          level:'',
+          rectifynote:'',
+          rectifydeadline:'',
+          rectifymeasure:''
+        },
+        filter:{
+          pageIndex:1,
+          pageSize:10,
+          filter:{
+            code:'',
+            requestorName:'',
+            level:null,
+          }
+        }
+      }
+    },
+    created() {
+      this.hiddenDangerList();
+
+    },
+    methods: {
+        queryHandle: function () {
+            this.filter.pageIndex = 1
+            this.hiddenDangerList()
+        },
+        viewHandle (row) {
+          this.$refs.reportView.showDialog("查看",row)
+        },
+        rectifyHandle(row){
+            this.$refs.rectifyDialog.show(row)
+        },
+
+        handleSizeChange: function (val) {
+            this.filter.pageSize = val
+            this.filter.pageIndex = 1
+            this.hiddenDangerList()
+        },
+        handleCurrentChange: function (val) {
+            this.filter.pageIndex = val
+            this.hiddenDangerList()
+        },
+        getBtnPermission(btnType) {
+            return checkBtnPermission(this.userType, btnType)
+        },
+
+
+        downloadHandle(fileurl){
+            window.open(fileurl, '_blank');
+        },
+
+
+
+      hiddenDangerList(){
+          this.listLoading = true
+          hiddenDangerRectifyList(this.filter)
+              .then(res=>{
+                if (res.data.code === '200') {
+                  this.tableData =  res.data.result.records
+                  this.recordTotal =  res.data.result.total
+                }
+                else{
+                  this.$message({message:  res.data.message, type: 'warning'});
+                }
+
+        })
+              .catch(err=>{
+                  console.log(err)
+                  this.$message({message: '接口错误', type: 'warning'});
+
+              })
+              .finally(()=>{
+                  this.listLoading = false
+              })
+      },
+        clearLevel(){
+            this.filter.filter.level = null
+        }
+
+    }
+}
+</script>
+
+<style scoped>
+
+    .overdue{
+        color: red;
+    }
+    .overdue-img{
+        position: fixed;
+        background-color: #f56c6c;
+        border-radius: 4px;
+        color: #fff;
+        display: inline-block;
+        font-size: 12px;
+        height: 21px;
+        line-height: 18px;
+        text-align: center;
+        white-space: nowrap;
+        border: 1px solid #fff;
+        transform: scale(0.8);
+        padding: 1px 3px 0 3px;
+
+    }
+</style>
diff --git a/src/views/hiddenDanger/rectifyDialog/rectifyDialog.vue b/src/views/hiddenDanger/rectifyDialog/rectifyDialog.vue
new file mode 100644
index 0000000..9f38d2d
--- /dev/null
+++ b/src/views/hiddenDanger/rectifyDialog/rectifyDialog.vue
@@ -0,0 +1,261 @@
+<template>
+    <el-dialog title="整改" :visible.sync="dialogFormVisible"
+               :modal-append-to-body="false" :close-on-click-modal="false" width="800px">
+        <el-form ref="dataForm" :rules="dataFormRules" :model="dataForm" label-position="right" label-width="140px"
+                 style="" element-loading-text="保存中...">
+
+
+            <el-form-item label="隐患级别:">
+                <el-select v-model="dataForm.level"  placeholder="请选择" :disabled="isView">
+                    <el-option
+                        v-for="item in levels"
+                        :key="item.key"
+                        :label="item.value"
+                        :value="item.key">
+                    </el-option>
+                </el-select>
+            </el-form-item>
+
+            <el-form-item label="整改措施:" >
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    :disabled="isView"
+                    placeholder="请输入内容"
+                    v-model="dataForm.rectifymeasure">
+                </el-input>
+            </el-form-item>
+
+            <el-form-item label="整改期限:" >
+                <el-date-picker
+                    v-model="dataForm.rectifydeadline"
+                    type="datetime"
+                    :disabled="isView"
+                    format="yyyy-MM-dd HH:mm"
+                    value-format="yyyy-MM-dd HH:mm"
+                    placeholder="选择日期时间">
+                </el-date-picker>
+            </el-form-item>
+
+            <el-form-item label="上报说明:" >
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    :disabled="isView"
+                    placeholder="请输入内容"
+                    v-model="dataForm.createnote">
+                </el-input>
+            </el-form-item>
+
+            <el-form-item label="上报图片:" v-if="!isView">
+                <el-upload
+                    ref="upload"
+                    :action="baseUrl"
+                    :auto-upload="false"
+                    :headers="headers"
+                    :on-change="handleChange"
+                    name="file"
+                    :file-list="fileList"
+                    list-type="picture-card"
+                    multiple
+                >
+                    <i class="el-icon-plus"></i>
+                </el-upload>
+
+            </el-form-item>
+
+            <el-form-item label="上报图片:" v-if="isView && imgUrls.length > 0" >
+                <el-image
+                    class="upload-img"
+                    v-for='item in imgUrls'
+                    :key='item.id'
+                    :src="item.url"
+                    :preview-src-list="imgPreviewUrls"
+                    style="width:100px;height: 100px;margin: 10px 10px 10px 2px;border-radius: 3px"
+                >
+                </el-image>
+            </el-form-item>
+
+            <el-form-item label="驳回整改说明:"  v-if="dataForm.status === '驳回待整改'">
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    placeholder="请输入内容"
+                    :disabled="isView"
+                    v-model="dataForm.rectifynote">
+                </el-input>
+            </el-form-item>
+
+            <el-form-item label="驳回整改图片:"  v-if="dataForm.status === '驳回待整改'">
+                <el-image
+                    class="upload-img"
+                    v-for='item in imgUrls2'
+                    :key='item.id'
+                    :src="item.url"
+                    :disabled="isView"
+                    :preview-src-list="imgPreviewUrls2"
+                    style="width:100px;height: 100px;margin: 10px 15px 10px 2px;border-radius: 3px"
+                >
+                </el-image>
+            </el-form-item>
+
+            <el-form-item label="驳回原因:"  v-if="dataForm.status === '驳回待整改'">
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    placeholder="请输入内容"
+                    :disabled="isView"
+                    v-model="dataForm.rejectnote">
+                </el-input>
+            </el-form-item>
+
+
+
+            <el-form-item label="整改说明:"  >
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    placeholder="请输入内容"
+                    v-model="dataForm.note">
+                </el-input>
+            </el-form-item>
+
+            <el-form-item label="整改图片:" >
+                <el-upload
+                    ref="upload"
+                    :action="baseUrl"
+                    :auto-upload="false"
+                    :headers="headers"
+                    :on-change="handleChange"
+                    name="file"
+                    :file-list="fileList"
+                    list-type="picture-card"
+                    multiple
+                >
+                    <i class="el-icon-plus"></i>
+                </el-upload>
+
+            </el-form-item>
+
+        </el-form>
+
+        <div style="margin-top: 20px;margin-left: 140px;"  class="dialog-footer" >
+            <el-button @click="dialogFormVisible = false">取消</el-button>
+            <el-button type="primary" @click="trigger2Submit()" :disabled="submiting">整改提交</el-button>
+        </div>
+
+    </el-dialog>
+</template>
+
+<script>
+    import { hiddenDangerRectify } from '@/api/hiddenDanger';
+    import { getToken} from "@/utils/auth";
+
+    export default {
+        name: "rectifyDialog",
+        data(){
+            return {
+                dialogFormVisible:false,
+                baseUrl: process.env.BASE_API + 'hiddenDanger/report',
+                headers: {
+                    'Authorization': getToken()
+                },
+                imgUrls:[],
+                imgUrls2:[],
+                imgPreviewUrls:[],
+                imgPreviewUrls2:[],
+                fileList:[],
+                isView:false,
+                submiting:false,
+                dataFormRules:{},
+                levels:[
+                    {"key":"URGENT","value":"紧急"},
+                    {"key":"COMMON","value":"一般"},
+                ],
+                dataForm: {
+                    id:'',
+                    note: '',
+                    level:'',
+                    rectifynote:'',
+                    rectifydeadline:'',
+                    rectifymeasure:'',
+                    createnote: '',
+                    rejectnote:'',
+                },
+            }
+        },
+        methods:{
+            resetDataForm(){
+               this.dataForm= {
+                   id:'',
+                   createnote: '',
+                   note:'',
+                   level:'',
+                   rectifynote:'',
+                   rectifydeadline:'',
+                   rectifymeasure:'',
+                   rejectnote:'',
+                },
+                 this.imgUrls =[]
+                 this.imgPreviewUrls = []
+            },
+            show(row){
+                this.resetDataForm();
+                this.isView = true
+                this.dataForm.id = row.id
+                this.dataForm.level = row.level
+                this.dataForm.status = row.status
+                this.dataForm.createnote = row.createnote
+                this.dataForm.rectifydeadline = row.rectifydeadline
+                this.dataForm.rectifymeasure = row.rectifymeasure
+                this.dataForm.rectifynote = row.rectifynote
+                this.dataForm. rejectnote = row.rejectnote
+                this.imgUrls = row.reportResources.map(item=>{return {url:process.env.IMG_API+item.url,name:item.id}})
+                this.imgUrls2 = row.rectifyResources.map(item=>{return {url:process.env.IMG_API+item.url,name:item.id}})
+                this.imgPreviewUrls = row.reportResources.map(item=>{ return process.env.IMG_API + item.url })
+                this.imgPreviewUrls2 = row.rectifyResources.map(item=>{ return process.env.IMG_API + item.url })
+                this.dialogFormVisible = true
+            },
+            trigger2Submit(){
+                let formData = new FormData();
+                formData.append('id',this.dataForm.id)
+                formData.append('note',this.dataForm.note)
+                this.fileList.forEach(file=>{
+                    formData.append("files",file.raw)
+                })
+                this.submiting = true
+                hiddenDangerRectify(formData)
+                    .then(res=>{
+                            if (res.data.code === '200') {
+                                this.dialogFormVisible = false
+                                this.$message({message: '操作成功', type: 'success'});
+                                this.$emit("refresh")
+                            }else{
+                                this.$message({message: res.data.message, type: 'success'});
+                            }
+                            this.fileList = []
+                    }
+                )
+                    .catch(err=>{
+                        console.log(err)
+                        this.$message({message: '接口错误', type: 'warning'});
+                    })
+                    .finally(()=>{
+                        this.submiting = false
+                    })
+            },
+            handleChange(file, fileList) {
+                this.fileList = fileList
+            },
+        }
+    }
+</script>
+
+<style scoped>
+
+</style>
diff --git a/src/views/hiddenDanger/report.vue b/src/views/hiddenDanger/report.vue
index 189085b..5211bbb 100644
--- a/src/views/hiddenDanger/report.vue
+++ b/src/views/hiddenDanger/report.vue
@@ -1,12 +1,14 @@
 <template>
     <div class="app-container">
         <div style="margin: 10px">
-            <span class="span-filter-label" style="margin-left: unset">作业编号</span>
-            <el-input style="width: 160px" v-model="filter.filter.taskcode"></el-input>
+            <span class="span-filter-label">单号</span>
+            <el-input style="width: 140px" v-model="filter.filter.code" ></el-input>
             <span class="span-filter-label">状态</span>
             <el-select
                 v-model="filter.filter.status"
                 class="filter-item"
+                clearable
+                @clear="clearStatus"
                 style="width:150px;margin-bottom: 10px">
                 <el-option
                     v-for="item in reportStatus"
@@ -16,7 +18,10 @@
                 </el-option>
             </el-select>
             <span class="span-filter-label">隐患等级</span>
-            <el-select v-model="filter.filter.level"  placeholder="请选择">
+            <el-select v-model="filter.filter.level"
+                       clearable
+                       @clear="clearLevel"
+                       placeholder="请选择">
                 <el-option
                     v-for="item in levels"
                     :key="item.key"
@@ -25,10 +30,9 @@
                 </el-option>
             </el-select>
 
-            <span class="span-filter-label">负责人</span>
-            <el-input style="width: 160px" v-model="filter.filter.principal"></el-input>
             <span class="span-filter-label">整改人</span>
-            <el-input style="width: 160px" v-model="filter.filter.supervisor"></el-input>
+            <el-input style="width: 160px" v-model="filter.filter.rectifierName"></el-input>
+
 
             <el-button class="filter-item" style="margin-left: 10px;" type="primary"
                        icon="el-icon-plus" @click="showCreateHandle">新增
@@ -47,18 +51,32 @@
                 style="width: 100%;"
             >
                 <el-table-column type="index" label="序号" align="center" width="80"/>
-                <el-table-column label="状态" prop="status" align="center" />
-                <el-table-column label="作业编号" prop="taskcode" align="center" />
+                <el-table-column label="单号" prop="code" align="center" />
+                <el-table-column label="状态" prop="status" align="center" >
+                    <template slot-scope="scope">
+                        <span >{{scope.row.status}}</span>
+                         <span v-if="new Date(scope.row.rectifydeadline) < new Date() && scope.row.status  !== '已完成'" class="overdue-img">逾期</span>
+                    </template>
+                </el-table-column>
                 <el-table-column label="隐患等级" prop="level" align="center" >
                     <template slot-scope="scope">
                         <el-tag :type="scope.row.level == '紧急'?'danger':'warning'">{{scope.row.level}}</el-tag>
                     </template>
                 </el-table-column>
                 <el-table-column label="上报人" prop="requestor" align="center" />
-                <el-table-column label="负责人" prop="principal" align="center" />
-                <el-table-column label="整改人" prop="supervisor" align="center" />
+                <el-table-column label="上报时间" prop="createtime" align="center" />
+                <el-table-column label="整改人" prop="rectifier" align="center" />
 
-                <el-table-column label="创建时间" prop="createtime" align="center" />
+                <el-table-column label="整改期限"   prop="rectifydeadline" align="center" >
+                    <template slot-scope="scope">
+                        <span v-bind:class="{'overdue':new Date(scope.row.rectifydeadline) < new Date() && scope.row.status  !== '已完成'}">{{scope.row.rectifydeadline}}
+                        </span>
+                    </template>
+                </el-table-column>
+                <el-table-column label="整改时间"   prop="rectifytime" align="center" >
+                </el-table-column>
+                <el-table-column label="验收时间"   prop="accepttime" align="center" >
+                </el-table-column>
                 <el-table-column label="操作" align="center" width="240" class-name="small-padding fixed-width">
                     <template slot-scope="scope">
                         <el-button  type="text" @click="viewHandle(scope.row)">查看</el-button>
@@ -68,9 +86,9 @@
             <br>
             <el-pagination
                 v-show="recordTotal>0"
-                :current-page="currentPage"
+                :current-page="filter.pageIndex"
                 :page-sizes="[10, 20, 30, 50]"
-                :page-size="pageSize"
+                :page-size="filter.pageSize"
                 :total="recordTotal"
                 layout="total, sizes, prev, pager, next, jumper"
                 background
@@ -79,340 +97,136 @@
                 @current-change="handleCurrentChange"
             />
         </div>
-        <el-dialog :title="dialogStatus==='create'?'新增':'查看'" :visible.sync="dialogFormVisible"
-                   :modal-append-to-body="false" :close-on-click-modal="false" width="800px">
-            <el-form ref="dataForm" :rules="dataFormRules" :model="dataForm" label-position="right" label-width="140px"
-                     style="" element-loading-text="保存中...">
-
-                <el-form-item label="作业编号:">
-                    <el-input v-model="dataForm.taskCode" readonly style="width: 205px"  placeholder="请选择" >
-
-                    </el-input>
-                    <el-button style="margin-left: 10px;" type="primary"
-                                @click="showTask">选择
-                    </el-button>
-                </el-form-item>
-
-                <el-form-item label="隐患级别:">
-                    <el-select v-model="dataForm.level"  placeholder="请选择" :disabled="isView">
-                        <el-option
-                            v-for="item in levels"
-                            :key="item.key"
-                            :label="item.value"
-                            :value="item.key">
-                        </el-option>
-                    </el-select>
-                </el-form-item>
-
-                <el-form-item label="上报说明:" >
-                    <el-input
-                        style="width: 400px"
-                        type="textarea"
-                        :rows="3"
-                        :disabled="isView"
-                        placeholder="请输入内容"
-                        v-model="dataForm.note">
-                    </el-input>
-                </el-form-item>
-
-                <el-form-item label="上报图片:" v-if="!isView">
-                    <el-upload
-                        ref="upload"
-                        :action="baseUrl"
-                        :auto-upload="false"
-                        :headers="headers"
-                        :on-change="handleChange"
-                        name="file"
-                        :file-list="fileList"
-                        list-type="picture-card"
-                        multiple
-                    >
-                        <i class="el-icon-plus"></i>
-                    </el-upload>
-
-                </el-form-item>
-
-                <el-form-item label="上报图片:" v-if="isView" >
-                    <el-image
-                        class="upload-img"
-                        v-for='item in imgUrls'
-                        :key='item.id'
-                        :src="item.url"
-                        :preview-src-list="imgPreviewUrls"
-                        style="width:200px;height: 200px;margin: 10px;"
-                    >
-                    </el-image>
-                </el-form-item>
-
-                <el-form-item label="确认说明:" :disabled="!isView" v-if="isConfirm">
-                    <el-input
-                        style="width: 400px"
-                        type="textarea"
-                        :rows="3"
-                        placeholder="请输入内容"
-                        v-model="dataForm.note">
-                    </el-input>
-                </el-form-item>
-
-            </el-form>
-
-            <div style="margin-top: 20px;margin-left: 140px;"  class="dialog-footer" v-if="!isView">
-                <el-button @click="dialogFormVisible = false">取消</el-button>
-                <el-button type="primary" @click="trigger2Submit" :disabled="submiting">上报</el-button>
-            </div>
-        </el-dialog>
         <div style="clear: both;"></div>
-        <task-select ref="selectTask" @getInfo="selectSetValue" ></task-select>
         <report-view ref="reportView" ></report-view>
+        <report-dialog ref="reportDialog" @refresh="hiddenDangerList"></report-dialog>
 
     </div>
 </template>
 
 <script>
-import Cookies from 'js-cookie'
 import { checkBtnPermission} from "@/utils/permission";
-import { parseError} from "@/utils/messageDialog";
-import { computePageCount} from "@/utils";
-import { mapGetters} from "vuex";
-import { dictionaryAllItems } from '@/api/dictionary';
-import { getSelectTask,hiddenDangerReport ,hiddenDangerReportList} from '@/api/hiddenDanger';
-import  taskSelect from './taskSelect/taskSelect';
+import {hiddenDangerReportList} from '@/api/hiddenDanger';
 import reportView from './reportView/reportView'
-import { Message, MessageBox } from 'element-ui'
-import {addHelpDoc, delHelpDoc, editHelpDoc, helpDocList} from "@/api/helpDoc";
-import {getToken} from "@/utils/auth";
+import reportDialog from './reportDialog/reportDialog'
 
 export default {
-    name: "helpDoc",
+    name: "report",
     components: {
-        taskSelect,
-        reportView
+        reportView,
+        reportDialog,
      },
     data() {
       return {
-        baseUrl: process.env.BASE_API + 'hiddenDanger/report',
-        headers: {
-          'Authorization': getToken()
-        },
-        tasksInfo: [],
-        imgUrls:[],
-        imgPreviewUrls:[],
-        isView:false,
-        isConfirm:false,
-        isRectify:false,
-        fileList: [],
-        pageSize: 10,
         recordTotal: 0,
-        currentPage: 1,
-        pageTotal: 0,
         tableKey: 0,
         tableData:[],
-        helpDocData: null,
         listLoading: true,
-        submiting:false,
         levels:[
           {"key":"URGENT","value":"紧急"},
           {"key":"COMMON","value":"一般"},
         ],
         reportStatus:[
-          {"key":"UNCONFIRMED","value":"未确认"},
-          {"key":"CONFIRMED","value":"确认未整改"},
-          {"key":"REJECT","value":"已驳回"},
-          {"key":"RECTIFIED","value":"已整改"},
+          {"key":"TORECTIFY","value":"待整改"},
+          {"key":"TOACCEPT","value":"整改待验收"},
+          {"key":"REJECTED","value":"驳回待整改"},
+          {"key":"COMPLETED","value":"已完成"},
         ],
         dataForm: {
-          taskCode:'',
-          taskid: '',
+          rectifydeadline:'',
+          rectifymeasure:'',
+          rectifier:'',
+          rectifierid:'',
           note: '',
           level:''
         },
-        queryForm: {
-          name: ''
-        },
-        dialogFormVisible: false,
-        dialogStatus: '',
-        dataFormRules: {},
-        fileType: [],
-        productVoList: [],
-        productVoDialogVisible: false,
-        productDialogFormVisible: false,
-        productData: [],
-        pageSizeProduct: 10,
-        currentPageProduct: 1,
-        recordTotalProduct: 0,
-        pageTotalProduct: 0,
-        queryProductForm: {
-          name: '',
-          manufacturer: '',
-          directionCode: '',
-          type: ''
-        },
         isSupervision: '',
-
-        manufacturer: '',
-        enterpriseList: [],
-        enterpriseDialogFormVisible: false,
-        pageSizeEnterpise: 10,
-        currentPageEnterpise: 1,
-        recordTotalEnterpise: 0,
-        pageTotalEnterpise: 0,
         filter:{
           pageIndex:1,
           pageSize:10,
           filter:{
-            taskcode:'',
-            status:"UNCONFIRMED",
-            requestor:"",
-            principal:"",
-            supervisor:"",
-            level:""
+            code:'',
+            status:null,
+            level:null,
+            rectifierName:'',
           }
-        }
+        },
+
       }
     },
     created() {
       this.hiddenDangerList();
     },
     methods: {
-
-        refreshHandle: function () {
-            this.hiddenDangerList()
-        },
         queryHandle: function () {
-            this.currentPage = 1
+            this.filter.pageIndex = 1
             this.hiddenDangerList()
         },
         resetDataForm() {
-            this.dataForm = {
-                taskid: '',
-                taskCode:'',
+           this.dataForm= {
+                rectifydeadline:'',
+                rectifymeasure:'',
+                rectifier:'',
+                rectifierid:'',
                 note: '',
                 level:''
             }
         },
         showCreateHandle() {
-            this.getSelectTasks()
-            this.dialogFormVisible = true
-            this.dialogStatus = 'create'
-            this.isView = false
-            this.resetDataForm()
+            this.$refs.reportDialog.show()
         },
         viewHandle: function (row) {
-
            this.$refs.reportView.showDialog("查看",row)
 
         },
         handleSizeChange: function (val) {
-            this.pageSize = val
-            this.currentPage = 1
+            this.filter.pageIndex = 1
+            this.filter.pageSize = val
             this.hiddenDangerList()
         },
         handleCurrentChange: function (val) {
-            this.currentPage = val
+            this.filter.pageIndex = val
             this.hiddenDangerList()
         },
         getBtnPermission(btnType) {
             return checkBtnPermission(this.userType, btnType)
         },
 
-        showProductHandle(){
-            this.productDialogFormVisible = true;
-        },
-        showEnterprise(){
-            this.enterpriseDialogFormVisible = true;
-        },
+
         downloadHandle(fileurl){
             window.open(fileurl, '_blank')
-            ;
-        },
-      selectSetValue(row){
-          this.dataForm.taskCode = row.code
-          this.dataForm.taskid = row.id
-
-      },
-
-
-        getSelectTasks(){
-          getSelectTask()
-            .then(res=>{
-              if (res.status !== 200)
-                this.$message({
-                  message: '接口错误',
-                  type: 'success'
-                });
-              else{
-                this.tasksInfo = res.data.result.map(item=>{return {"id":item.id,"code":item.code}})
-              }
-            })
-
-            .catch(res=>{
-              console.log(res)
-            })
         },
 
-      handleChange(file, fileList) {
-        this.fileList = fileList
-      },
-
-      trigger2Submit(){
-        this.submiting = true
-        let formData = new FormData()
-        formData.append('taskid', this.dataForm.taskid)
-        formData.append("note",this.dataForm.note)
-        formData.append("level",this.dataForm.level)
-        this.fileList.forEach(file=>{
-          formData.append("files",file.raw)
-        })
-
-        hiddenDangerReport(formData).then(res=>{
-          this.submiting = false
-          if (res.status === 200) {
-            if (res.data.code === '200') {
-              this.dialogFormVisible = false
-              this.$message({
-                message: '创建成功',
-                type: 'success'
-              });
-              this.hiddenDangerList()
-            }else{
-              this.$message({
-                message: res.data.message,
-                type: 'success'
-              });
-            }
-            this.fileList = []
-
-          }
-          else{
-            this.$message({
-              message: '接口错误',
-              type: 'warning'
-            });
-          }
-          }
-        )
-
-      },
 
       hiddenDangerList(){
-        hiddenDangerReportList(this.filter).then(res=>{
-          this.listLoading = false
-          if (res.status === 200) {
+        this.listLoading = true
+        hiddenDangerReportList(this.filter)
+            .then(res=>{
             if (res.data.code === '200') {
               this.tableData =  res.data.result.records
+              this.recordTotal =  res.data.result.total
             }
-          }else{
-            this.$message({
-              message: '接口错误',
-              type: 'warning'
-            });
-
-          }
+            else{
+              this.$message({message:  res.data.message, type: 'warning'});
+            }
         })
+            .catch(err=>{
+                console.log(err)
+                this.$message({message: '接口错误', type: 'warning'});
+            })
+            .finally(()=>{
+                this.listLoading = false
+            })
+
       },
-      showTask(){
-        this.$refs.selectTask.showTask()
-      }
+
+
+        clearStatus(){
+            this.filter.filter.status = null
+        },
+        clearLevel(){
+            this.filter.filter.level = null
+        }
 
     }
 }
@@ -425,5 +239,23 @@
         margin-right: 4px;
         margin-left: 7px;
     }
+    .overdue{
+        color: red;
+    }
+    .overdue-img{
+        position: fixed;
+        background-color: #f56c6c;
+        border-radius: 4px;
+        color: #fff;
+        display: inline-block;
+        font-size: 12px;
+        height: 21px;
+        line-height: 18px;
+        text-align: center;
+        white-space: nowrap;
+        border: 1px solid #fff;
+        transform: scale(0.8);
+        padding: 1px 3px 0 3px;
 
+    }
 </style>
diff --git a/src/views/hiddenDanger/reportDialog/reportDialog.vue b/src/views/hiddenDanger/reportDialog/reportDialog.vue
new file mode 100644
index 0000000..f241e67
--- /dev/null
+++ b/src/views/hiddenDanger/reportDialog/reportDialog.vue
@@ -0,0 +1,221 @@
+<template>
+    <el-dialog title="新增" :visible.sync="dialogFormVisible"
+               :modal-append-to-body="false" :close-on-click-modal="false" width="800px">
+        <el-form ref="dataForm" :rules="dataFormRules" :model="dataForm" label-position="right" label-width="140px"
+                 style="" element-loading-text="保存中...">
+
+
+            <el-form-item label="隐患级别:">
+                <el-select v-model="dataForm.level"  placeholder="请选择" :disabled="isView">
+                    <el-option
+                        v-for="item in levels"
+                        :key="item.key"
+                        :label="item.value"
+                        :value="item.key">
+                    </el-option>
+                </el-select>
+            </el-form-item>
+
+            <el-form-item label="选择整改人:">
+                <el-input v-model="dataForm.rectifier" readonly style="width: 205px"  placeholder="请选择" >
+
+                </el-input>
+                <el-button style="margin-left: 10px;" type="primary"
+                           @click="showPersonSelect">选择
+                </el-button>
+            </el-form-item>
+
+            <el-form-item label="整改措施:" >
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    :disabled="isView"
+                    placeholder="请输入内容"
+                    v-model="dataForm.rectifymeasure">
+                </el-input>
+            </el-form-item>
+            <el-form-item label="整改期限   :" >
+                <el-date-picker
+                    v-model="dataForm.rectifydeadline"
+                    type="datetime"
+                    format="yyyy-MM-dd HH:mm"
+                    :picker-options="pickerOptions"
+                    value-format="yyyy-MM-dd HH:mm"
+                    placeholder="选择日期时间">
+                </el-date-picker>
+            </el-form-item>
+            <el-form-item label="上报说明:" >
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    :disabled="isView"
+                    placeholder="请输入内容"
+                    v-model="dataForm.note">
+                </el-input>
+            </el-form-item>
+
+            <el-form-item label="上报图片:" v-if="!isView">
+                <el-upload
+                    ref="upload"
+                    :action="baseUrl"
+                    :auto-upload="false"
+                    :headers="headers"
+                    :on-change="handleChange"
+                    name="file"
+                    :file-list="fileList"
+                    list-type="picture-card"
+                    multiple
+                >
+                    <i class="el-icon-plus"></i>
+                </el-upload>
+
+            </el-form-item>
+
+            <el-form-item label="上报图片:" v-if="isView" >
+                <el-image
+                    class="upload-img"
+                    v-for='item in imgUrls'
+                    :key='item.id'
+                    :src="item.url"
+                    :preview-src-list="imgPreviewUrls"
+                    style="width:100px;height: 100px;margin: 10px;"
+                >
+                </el-image>
+            </el-form-item>
+
+
+
+        </el-form>
+
+        <div style="margin-top: 20px;margin-left: 140px;"  class="dialog-footer" v-if="!isView">
+            <el-button @click="dialogFormVisible = false">取消</el-button>
+            <el-button type="primary" @click="trigger2Submit" :disabled="submiting">上报</el-button>
+        </div>
+        <person-select ref="selectPerson" @setPerson="selectSetValue" ></person-select>
+    </el-dialog>
+</template>
+
+<script>
+    import personSelect from '../personSelect/personSelect'
+    import { hiddenDangerReport } from '@/api/hiddenDanger';
+    import {getToken} from "@/utils/auth";
+    export default {
+        name: "reportDialog",
+        data(){
+            return {
+                baseUrl: process.env.BASE_API + 'hiddenDanger/report',
+                headers: {
+                    'Authorization': getToken()
+                },
+                submiting:false,
+                levels:[
+                    {"key":"URGENT","value":"紧急"},
+                    {"key":"COMMON","value":"一般"},
+                ],
+                pickerOptions:{
+                    disabledDate(now){
+                        return now.getTime() < new Date(new Date().toLocaleDateString()).getTime()
+                    }
+                },
+                fileList: [],
+                dataForm: {
+                    rectifydeadline:'',
+                    rectifymeasure:'',
+                    rectifier:'',
+                    rectifierid:'',
+                    note: '',
+                    level:''
+                },
+                dialogFormVisible: false,
+                dataFormRules: {},
+                isView:false,
+            }
+        },
+        components:{
+            personSelect,
+        },
+        methods:{
+            resetDataForm(){
+                this.dataForm = {
+                    rectifydeadline:'',
+                    rectifymeasure:'',
+                    rectifier:'',
+                    rectifierid:'',
+                    note: '',
+                    level:''
+                }
+            },
+            show(){
+                this.dialogFormVisible = true
+                this.isView = false
+                this.resetDataForm()
+            },
+            trigger2Submit(){
+                this.submiting = true
+                let formData = new FormData()
+                formData.append('rectifier', this.dataForm.rectifier)
+                formData.append("rectifierid",this.dataForm.rectifierid)
+                formData.append("level",this.dataForm.level)
+                formData.append("rectifymeasure",this.dataForm.rectifymeasure)
+                formData.append("rectifydeadline",this.dataForm.rectifydeadline)
+                formData.append("note",this.dataForm.note)
+                this.fileList.forEach(file=>{
+                    formData.append("files",file.raw)
+                })
+
+                hiddenDangerReport(formData)
+                    .then(res=>{
+                            if (res.data.code === '200') {
+                                this.dialogFormVisible = false
+                                this.$message({
+                                    message: '创建成功',
+                                    type: 'success'
+                                });
+                                this.$emit("refresh")
+                            }else{
+                                this.$message({
+                                    message: res.data.message,
+                                    type: 'warning'
+                                });
+                            }
+                            this.fileList = []
+                    }
+                )
+                    .catch(err=>{
+                        console.log(err)
+                        this.$message({
+                            message: "接口错误,请联系管理员",
+                            type: 'warning'
+                        });
+                    })
+                    .finally(()=>{
+                        this.submiting = false
+                    })
+
+            },
+            showPersonSelect(){
+                this.$refs.selectPerson.show();
+            },
+            selectSetValue(row){
+                this.dataForm.rectifier = row.realname
+                this.dataForm.rectifierid = row.id
+            },
+
+
+            handleChange(file, fileList) {
+                this.fileList = fileList
+            },
+
+
+       }
+    }
+</script>
+
+<style scoped>
+
+    .el-picker-panel__footer .el-button--text.el-picker-panel__link-btn {
+        display: none;
+    }
+</style>
diff --git a/src/views/hiddenDanger/reportView/reportView.vue b/src/views/hiddenDanger/reportView/reportView.vue
index f318c4e..66274e5 100644
--- a/src/views/hiddenDanger/reportView/reportView.vue
+++ b/src/views/hiddenDanger/reportView/reportView.vue
@@ -5,12 +5,33 @@
         <el-form ref="dataForm"  :model="dataForm" label-position="right" label-width="140px"
                 element-loading-text="保存中...">
 
-            <el-form-item label="作业编号:">
-                <el-input v-model="dataForm.taskCode"  style="width: 205px"  :readonly="true" />
-            </el-form-item>
-
             <el-form-item label="隐患级别:">
                 <el-input v-model="dataForm.level" style="width: 205px" placeholder="请选择" :readonly="true"/>
+            </el-form-item>
+
+            <el-form-item label="整改人:">
+                <el-input v-model="dataForm.rectifier" style="width: 205px" placeholder="请选择" :readonly="true"/>
+            </el-form-item>
+
+            <el-form-item label="整改期限:">
+                <el-date-picker
+                    v-model="dataForm.rectifydeadline"
+                    type="datetime"
+                    :readonly="true"
+                    format="yyyy-MM-dd HH:mm"
+                    value-format="yyyy-MM-dd HH:mm"
+                    >
+                </el-date-picker>
+            </el-form-item>
+
+            <el-form-item label="整改措施:" >
+                <el-input
+                    style="width: 400px"
+                    type="textarea"
+                    :rows="3"
+                    :readonly="true"
+                    v-model="dataForm.rectifymeasure">
+                </el-input>
             </el-form-item>
 
             <el-form-item label="上报说明:" >
@@ -35,22 +56,19 @@
                 </el-image>
             </el-form-item>
 
-            <el-form-item label="隐患确认:" v-if="this.dataForm.status !== '未确认'">
-                <el-radio v-model="dataForm.ishiddendanger" v-if="dataForm.ishiddendanger" :label="true" border >是隐患</el-radio>
-                <el-radio v-model="dataForm.ishiddendanger" v-if="!dataForm.ishiddendanger" :label="false" border >非隐患</el-radio>
-            </el-form-item>
 
-            <el-form-item :label="this.dataForm.status === '已驳回'?'驳回说明:':'确认说明:'"  v-if="this.dataForm.status !== '未确认'">
+            <el-form-item label="整改说明:" v-if="this.dataForm.status !== '待整改'">
                 <el-input
                     style="width: 400px"
                     type="textarea"
                     :rows="3"
                     :readonly="true"
-                    v-model="dataForm.confirmnote">
+                    v-model="dataForm.rectifynote">
                 </el-input>
             </el-form-item>
 
-            <el-form-item label="整改图片:"  v-if="this.dataForm.status === '已整改' && imgUrls2.length > 0">
+
+            <el-form-item label="整改图片:"  v-if="this.dataForm.status !== '待整改'  && imgUrls2.length > 0">
                 <el-image
                     class="upload-img img-wrapper"
                     v-for='item in imgUrls2'
@@ -62,13 +80,14 @@
 
             </el-form-item>
 
-            <el-form-item label="整改说明:" v-if="this.dataForm.status === '已整改'">
+
+            <el-form-item label="驳回原因:"  v-if="this.dataForm.status === '驳回待整改'">
                 <el-input
                     style="width: 400px"
                     type="textarea"
                     :rows="3"
                     :readonly="true"
-                    v-model="dataForm.rectifynote">
+                    v-model="dataForm.rejectnote">
                 </el-input>
             </el-form-item>
 
@@ -104,16 +123,17 @@
       showDialog(title,row){
         this.title = title;
         this.dataForm.status = row.status
-        this.dataForm.taskCode = row.taskcode
         this.dataForm.level = row.level
         this.imgUrls = row.reportResources.map(item=>{return {url:process.env.IMG_API+item.url,name:item.id}})
         this.imgPreviewUrls = row.reportResources.map(item=>{ return process.env.IMG_API + item.url })
         this.imgUrls2 = row.rectifyResources.map(item=>{return {url:process.env.IMG_API+item.url,name:item.id}})
         this.imgPreviewUrls2 = row.rectifyResources.map(item=>{ return process.env.IMG_API + item.url })
-        this.dataForm.ishiddendanger = row.ishiddendanger
         this.dataForm.rectifynote = row.rectifynote
-        this.dataForm.confirmnote = row.confirmnote
         this.dataForm.createnote = row.createnote;
+        this.dataForm.rectifymeasure = row.rectifymeasure;
+        this.dataForm.rectifydeadline = row.rectifydeadline;
+        this.dataForm.rejectnote = row.rejectnote;
+        this.dataForm.rectifier= row.rectifier;
         this.dialogFormVisible = true;
       },
 
diff --git a/src/views/hiddenDanger/statistics.vue b/src/views/hiddenDanger/statistics.vue
index 802cf9b..8effa42 100644
--- a/src/views/hiddenDanger/statistics.vue
+++ b/src/views/hiddenDanger/statistics.vue
@@ -1,11 +1,13 @@
 <template>
         <div class="app-container">
             <div style="margin: 10px">
-                <span class="span-filter-label">作业编号</span>
-                <el-input style="width: 160px" v-model="filter.filter.taskcode"></el-input>
-                <span class="span-filter-label">状态</span>
+
+                <span class="span-filter-label">单号</span>
+                <el-input style="width: 140px" v-model="filter.filter.code" ></el-input>
+                <span class="span-filter-label" >状态</span>
                 <el-select
                     v-model="filter.filter.status"
+                    clearable @clear="clearStatus"
                     class="filter-item"
                     style="width:120px;margin-bottom: 10px">
                     <el-option
@@ -17,8 +19,9 @@
                 </el-select>
                 <span class="span-filter-label">隐患等级</span>
                 <el-select v-model="filter.filter.level"
+                           clearable @clear="clearLevel"
                            style="width: 100px"
-                           placeholder="请选择">
+                           >
                     <el-option
                         v-for="item in levels"
                         :key="item.key"
@@ -28,12 +31,9 @@
                 </el-select>
 
                 <span class="span-filter-label">上报人</span>
-                <el-input style="width: 140px" v-model="filter.filter.requestor" ></el-input>
-                <span class="span-filter-label">负责人</span>
-                <el-input style="width: 140px" v-model="filter.filter.principal"></el-input>
+                <el-input style="width: 140px" v-model="filter.filter.requestorName" ></el-input>
                 <span class="span-filter-label">整改人</span>
-                <el-input style="width: 140px" v-model="filter.filter.supervisor"></el-input>
-
+                <el-input style="width: 140px" v-model="filter.filter.rectifierName"></el-input>
                 <el-button class="filter-item" style="margin-left: 10px;" type="primary" icon="el-icon-search"
                            @click="queryHandle"/>
             </div>
@@ -46,9 +46,10 @@
                     style="width: 100%;position: relative;top: -7px"
                 >
                     <el-table-column label="待整改数" prop="2rectifynum" align="center" />
-                    <el-table-column label="整改数量" prop="rectifynum" align="center"/>
+                    <el-table-column label="完成数量" prop="completednum" align="center"/>
                     <el-table-column label="驳回总数" prop="rejectnum" align="center" />
                     <el-table-column label="上报总数" prop="reportnum" align="center" />
+                    <el-table-column label="待验收数" prop="2acceptnum" align="center" />
                 </el-table>
                 <el-table
                     :key="tableKey"
@@ -59,18 +60,31 @@
                     style="width: 100%;"
                 >
                     <el-table-column type="index" label="序号" align="center" width="80"/>
-                    <el-table-column label="状态" prop="status" align="center" />
-                    <el-table-column label="作业编号" prop="taskcode" align="center" />
+                    <el-table-column label="单号" prop="code" align="center" />
+                    <el-table-column label="状态" prop="status" align="center" >
+                        <template slot-scope="scope">
+                            <span >{{scope.row.status}}</span>
+                            <span v-if="new Date(scope.row.rectifydeadline) < new Date() && scope.row.status  !== '已完成'" class="overdue-img">逾期</span>
+                        </template>
+                    </el-table-column>
                     <el-table-column label="隐患等级" prop="level" align="center" >
                         <template slot-scope="scope">
                             <el-tag :type="scope.row.level == '紧急'?'danger':'warning'">{{scope.row.level}}</el-tag>
                         </template>
                     </el-table-column>
                     <el-table-column label="上报人" prop="requestor" align="center" />
-                    <el-table-column label="负责人" prop="principal" align="center" />
-                    <el-table-column label="整改人" prop="supervisor" align="center" />
+                    <el-table-column label="上报时间" prop="createtime" align="center" />
+                    <el-table-column label="整改人" prop="rectifier" align="center" />
+                    <el-table-column label="整改期限"   prop="rectifydeadline" align="center" >
+                        <template slot-scope="scope">
+                        <span v-bind:class="{'overdue':new Date(scope.row.rectifydeadline) < new Date() && scope.row.status  !== '已完成'}">{{scope.row.rectifydeadline}}
+                        </span>
+                        </template>
+                    </el-table-column>
+                    <el-table-column label="整改时间" prop="rectifytime" align="center" />
+                    <el-table-column label="验收时间" prop="accepttime" align="center" />
 
-                    <el-table-column label="创建时间" prop="createtime" align="center" />
+
                     <el-table-column label="操作" align="center" width="240" class-name="small-padding fixed-width">
                         <template slot-scope="scope">
                             <el-button  type="text" @click="viewHandle(scope.row)">查看</el-button>
@@ -81,9 +95,9 @@
 
                 <el-pagination
                     v-show="recordTotal>0"
-                    :current-page="currentPage"
+                    :current-page="filter.pageIndex"
                     :page-sizes="[10, 20, 30, 50]"
-                    :page-size="pageSize"
+                    :page-size="filter.pageSize"
                     :total="recordTotal"
                     layout="total, sizes, prev, pager, next, jumper"
                     background
@@ -119,26 +133,22 @@
           {"key":"URGENT","value":"紧急"},
           {"key":"COMMON","value":"一般"},
         ],
-        reportStatus:[
-          {"key":"","value":"全部"},
-          {"key":"UNCONFIRMED","value":"未确认"},
-          {"key":"CONFIRMED","value":"确认未整改"},
-          {"key":"REJECT","value":"已驳回"},
-          {"key":"RECTIFIED","value":"已整改"},
-        ],
-        pageSize:6,
-        currentPage:1,
+          reportStatus:[
+              {"key":"TORECTIFY","value":"待整改"},
+              {"key":"TOACCEPT","value":"整改待验收"},
+              {"key":"REJECTED","value":"驳回待整改"},
+              {"key":"COMPLETED","value":"已完成"},
+          ],
         recordTotal:0,
         filter:{
           pageIndex:1,
-          pageSize:6,
+          pageSize:10,
           filter:{
-            taskcode:'',
-            status:"",
-            requestor:"",
-            principal:"",
-            supervisor:"",
-            level:""
+              code:'',
+              status:null,
+              level:null,
+              requestorName:'',
+              rectifierName:'',
           }
         }
 
@@ -148,17 +158,17 @@
     },
     methods:{
       handleSizeChange: function (val) {
-        this.pageSize = val
         this.filter.pageSize = val
+        this.filter.pageIndex = 1
         this.hiddenDangerStatisticsList()
       },
       handleCurrentChange: function (val) {
-        this.currentPage = val
         this.filter.pageIndex = val
         this.hiddenDangerStatisticsList()
       },
       queryHandle(){
-        this.hiddenDangerStatisticsList()
+          this.filter.pageIndex = 1
+          this.hiddenDangerStatisticsList()
       },
       viewHandle(row){
         this.$refs.reportView.showDialog('查看',row)
@@ -166,26 +176,33 @@
 
       hiddenDangerStatisticsList() {
         this.listLoading = true
-        hiddenDangerStatisticsList(this.filter).then(res=>{
-          this.listLoading = false
-          if (res.status === 200) {
-            if (res.data.code === '200') {
-              this.tableData =  res.data.result.records
-              this.pageSize = res.data.result.size
-              this.currentPage = res.data.result.current
-              this.recordTotal = res.data.result.total
-               this.showData = [(res.data.result.extension)]
+        hiddenDangerStatisticsList(this.filter)
+            .then(res=>{
+                if (res.data.code === '200') {
+                    this.tableData = res.data.result.records
+                    this.recordTotal = res.data.result.total
+                    this.showData = [(res.data.result.extension)]
+                }
+                else{
+                    this.$message({ message: res.data.message, type: 'warning'});
+                }
 
-            }
-          }else{
-            this.$message({
-              message: '接口错误',
-              type: 'warning'
-            });
-
-          }
         })
-      }
+            .catch(err=>{
+                console.log(err)
+                this.$message({ message: '接口错误', type: 'warning'});
+            })
+            .finally(()=>{
+                this.listLoading = false
+            })
+      },
+        clearLevel(){
+          this.filter.filter.level = null
+        },
+        clearStatus(){
+            this.filter.filter.status = null
+        }
+
 
     }
   }
@@ -194,4 +211,24 @@
 
 <style scoped>
 
+    .overdue{
+        color: red;
+    }
+    .overdue-img{
+        position: fixed;
+        background-color: #f56c6c;
+        border-radius: 4px;
+        color: #fff;
+        display: inline-block;
+        font-size: 12px;
+        height: 21px;
+        line-height: 18px;
+        text-align: center;
+        white-space: nowrap;
+        border: 1px solid #fff;
+        transform: scale(0.8);
+        padding: 1px 3px 0 3px;
+
+    }
+
 </style>

--
Gitblit v1.9.2