From d0bec404f2c22ca04e8592f1a2ba0b39eab0be2f Mon Sep 17 00:00:00 2001
From: 马宇豪 <978517621@qq.com>
Date: 星期一, 22 五月 2023 09:37:03 +0800
Subject: [PATCH] Default Changelist

---
 src/views/intellectInspect/inspectTaskManage/inspectTask/index.vue |  222 +++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 199 insertions(+), 23 deletions(-)

diff --git a/src/views/intellectInspect/inspectTaskManage/inspectTask/index.vue b/src/views/intellectInspect/inspectTaskManage/inspectTask/index.vue
index 2158c0c..5feb9f9 100644
--- a/src/views/intellectInspect/inspectTaskManage/inspectTask/index.vue
+++ b/src/views/intellectInspect/inspectTaskManage/inspectTask/index.vue
@@ -1,12 +1,19 @@
 <template>
     <div class="home-container">
-        <div style="height: 100%">
+      <div style="height: 100%;display: flex;flex-direction: column;align-items: stretch;">
             <el-row class="homeCard">
                 <div class="basic-line">
                     <span>任务类型:</span>
                     <el-select v-model="tableData.params.workType" clearable filterable class="input-box" placeholder="任务类型">
                         <el-option v-for="item in workTypeList" :key="item.id" :label="item.name" :value="item.id"></el-option>
                     </el-select>
+                </div>
+                <div class="basic-line">
+                    <span>部门:</span>
+                    <el-cascader class="input-box" :options="departmentList" :props="{ emitPath: false, checkStrictly: true, value: 'depId', label: 'depName' }"
+                                 placeholder="请选择部门" clearable v-model="tableData.params.execDepId"
+                                 @change="changeGroup"
+                    > </el-cascader>
                 </div>
                 <div class="basic-line">
                     <span>执行班组:</span>
@@ -23,7 +30,7 @@
                 <div class="main-card">
                     <el-row class="cardTop">
                         <el-col :span="12" class="mainCardBtn">
-                            <el-button type="primary" :icon="Plus" size="default" @click="openInspectTaskDialog('新增', {})">新建</el-button>
+                            <el-button type="primary" :icon="Plus" size="default" @click="openInspectTaskDialog('新增', {})">新增</el-button>
                             <!--                            <el-button type="danger" :icon="Delete" size="default" plain>删除</el-button>-->
                         </el-col>
                         <el-button type="primary" :icon="Refresh" size="default" />
@@ -80,13 +87,30 @@
                         <el-table-column prop="gmtCreate" label="创建时间" show-overflow-tooltip></el-table-column>
                         <el-table-column prop="lastEditUserName" label="最后修改人" show-overflow-tooltip></el-table-column>
                         <el-table-column prop="gmtModitify" label="最后修改时间" show-overflow-tooltip></el-table-column>
-                        <el-table-column property="status" label="状态" width="60" />
+                        <el-table-column property="taskUnitStatus" label="状态" width="60">
+                            <template #default="scope">
+                                <div>
+                                    <div v-if="scope.row.taskUnitStatus === 1">
+                                        <el-tag :type="''">
+                                            {{ '开启' }}
+                                        </el-tag>
+                                    </div>
+                                    <div v-if="scope.row.taskUnitStatus === 2">
+                                        <el-tag :type="'danger'">
+                                            {{ '关闭' }}
+                                        </el-tag>
+                                    </div>
+                                </div>
+                            </template>
+                        </el-table-column>
                         <el-table-column fixed="right" label="操作" align="center" width="300">
                             <template #default="scope">
                                 <el-button link type="primary" size="small" :icon="View" @click="openInspectTaskDialog('查看', scope.row)">查看</el-button>
                                 <el-button link type="primary" size="small" :icon="Edit" @click="openInspectTaskDialog('修改', scope.row)">修改</el-button>
-                                <el-switch v-model="scope.row.status" inline-prompt active-text="开" inactive-text="关" active-value="开启" inactive-value="关闭" style="margin: 0 10px" />
-                                <el-button link type="danger" size="small" :icon="Delete" @click="deleteInspectTask(scope.$index)">删除</el-button>
+                                <el-button link type="danger" size="small" :icon="Delete" v-if="scope.row.taskUnitStatus === 2" @click="deleteInspectTask(scope.row)">删除</el-button>
+                                <div @click="changeStatus(scope.row)">
+                                    <el-switch v-model="scope.row.taskUnitStatus" inline-prompt active-text="开" inactive-text="关" :active-value="1" :inactive-value="2" style="margin: 0 10px" />
+                                </div>
                             </template>
                         </el-table-column>
                     </el-table>
@@ -103,12 +127,14 @@
 <script lang="ts">
 import { toRefs, reactive, ref, onMounted } from 'vue';
 import { Edit, View, Plus, Delete, Refresh, Search, Download } from '@element-plus/icons-vue';
-import { ElTable, ElMessage } from 'element-plus';
+import { ElTable, ElMessage, ElMessageBox } from 'element-plus';
 import { inspectTaskApi } from '/@/api/intellectInspectSystem/inspectTask';
 import inspectTaskDialog from './components/inspectTaskDialog.vue';
 import { departmentApi } from '/@/api/systemManage/department';
 import { teamManageApi } from '/@/api/systemManage/personShiftManage/teamManage';
 import { inspectPointApi } from '/@/api/intellectInspectSystem/inspectPointManage';
+import { facilityAreaApi } from '/@/api/intellectInspectSystem/facilityAreaManage';
+import { RFIDApi } from '/@/api/intellectInspectSystem/RFID';
 let global: any = {
     homeChartOne: null,
     homeChartTwo: null,
@@ -124,6 +150,7 @@
         params: {
             pageIndex: number | null;
             pageSize: number | null;
+            execDepId: number | null;
             unitName: string | null;
             workType: number | null;
             createUserId: number | null;
@@ -137,6 +164,8 @@
     departmentList: [];
     classGroupList: Array<classGroup>;
     inspectPointAllList: [];
+    regionNameList: [];
+    RFIDList: [];
     timeType: Array<type>;
 }
 interface type {
@@ -161,6 +190,7 @@
                     pageIndex: 1,
                     pageSize: 10,
                     unitName: null,
+                    execDepId: null,
                     workType: null,
                     createUserId: null,
                     execClassgroupId: null,
@@ -169,20 +199,22 @@
                 }
             },
             workTypeList: [
-                { id: 1, name: '日常任务' },
-                { id: 2, name: '周期任务' }
+                { id: 1, name: '周期任务' },
+                { id: 2, name: '单次任务' }
             ],
             quotaList: [],
             departmentList: [],
             classGroupList: [],
             inspectPointAllList: [],
+            regionNameList: [],
+            RFIDList: [],
             timeType: [
                 { id: 1, name: '分' },
                 { id: 2, name: '小时' },
                 { id: 3, name: '日' },
                 { id: 4, name: '月' },
                 { id: 5, name: '年' }
-            ]
+            ],
         });
 
         //获取巡检任务数据
@@ -213,10 +245,35 @@
         };
 
         //获取部门
-        const getQuotaList = async () => {
-            let res = await inspectTaskApi().getQuotaList();
+        // const getQuotaList = async () => {
+        //     let res = await inspectTaskApi().getQuotaList();
+        //     if (res.data.code === '200') {
+        //         state.quotaList = res.data.data;
+        //     } else {
+        //         ElMessage({
+        //             type: 'warning',
+        //             message: res.data.msg
+        //         });
+        //     }
+        // };
+      //获取部门
+      const getQuotaList = async () => {
+        let res = await inspectTaskApi().getAllQuotaList();
+        if (res.data.code === '200') {
+          state.quotaList = res.data.data;
+        } else {
+          ElMessage({
+            type: 'warning',
+            message: res.data.msg
+          });
+        }
+      };
+
+        //获取巡检点
+        const getInspectTaskPoint = async () => {
+            let res = await inspectPointApi().getInspectPointAll();
             if (res.data.code === '200') {
-                state.quotaList = res.data.data;
+                state.inspectPointAllList = res.data.data;
             } else {
                 ElMessage({
                     type: 'warning',
@@ -225,11 +282,24 @@
             }
         };
 
-        //获取巡检点
-        const getInspectTaskPoint = async () => {
-            let res = await inspectPointApi().getInspectPointAll();
+        //获取所有设施区域名称
+        const initFacilityAreaType = async () => {
+            let res = await facilityAreaApi().getAllFacilityAreaList();
             if (res.data.code === '200') {
-                state.inspectPointAllList = res.data.data;
+                state.regionNameList = JSON.parse(JSON.stringify(res.data.data));
+            } else {
+                ElMessage({
+                    type: 'warning',
+                    message: res.data.msg
+                });
+            }
+        };
+
+        //获取所有RFID名称
+        const initRFIDList = async () => {
+            let res = await RFIDApi().getAllRFIDList();
+            if (res.data.code === '200') {
+                state.RFIDList = JSON.parse(JSON.stringify(res.data.data));
             } else {
                 ElMessage({
                     type: 'warning',
@@ -251,8 +321,98 @@
             }
         };
 
+        const changeGroup = async () => {
+            if(state.tableData.params.execDepId === null) {
+                state.classGroupList = []
+            }else{
+                let res = await departmentApi().getByDepId({depId:state.tableData.params.execDepId})
+                if(res.data.code === '200'){
+                    state.classGroupList = res.data.data
+                }else{
+
+                }
+            }
+        };
+
+        const changeStatus = async (value: { taskUnitStatus: number; id: number }) => {
+            if (value.taskUnitStatus === 2) {
+                ElMessageBox.confirm(`此操作将关闭该巡检任务”,是否继续?`, '提示', {
+                    confirmButtonText: '确认',
+                    cancelButtonText: '取消',
+                    type: 'warning'
+                })
+                    .then(async () => {
+                        let res = await inspectTaskApi().openOrCloseInspectTask({ id: value.id, taskUnitStatus: 2 });
+                        if (res.data.code === '200') {
+                            await getInspectionTask();
+                            ElMessage({
+                                type: 'success',
+                                duration: 2000,
+                                message: '关闭成功'
+                            });
+                        } else {
+                            ElMessage({
+                                type: 'warning',
+                                message: res.data.msg
+                            });
+                        }
+                    })
+                    .catch((error) => {});
+            } else {
+                ElMessageBox.confirm(`此操作将开启该巡检任务”,是否继续?`, '提示', {
+                    confirmButtonText: '确认',
+                    cancelButtonText: '取消',
+                    type: 'warning'
+                })
+                    .then(async () => {
+                        let res = await inspectTaskApi().openOrCloseInspectTask({ id: value.id, taskUnitStatus: 1 });
+                        if (res.data.code === '200') {
+                            await getInspectionTask();
+                            ElMessage({
+                                type: 'success',
+                                duration: 2000,
+                                message: '开启成功'
+                            });
+                        } else {
+                            ElMessage({
+                                type: 'warning',
+                                message: res.data.msg
+                            });
+                        }
+                    })
+                    .catch((error) => {});
+            }
+            await getInspectionTask();
+        };
+
+        // 删除
+        const deleteInspectTask = (row: any) => {
+            ElMessageBox.confirm(`此操作将永久删除该任务:“${row.unitName}”,是否继续?`, '提示', {
+                confirmButtonText: '确认',
+                cancelButtonText: '取消',
+                type: 'warning'
+            })
+                .then(async () => {
+                    let res = await inspectTaskApi().deleteInspectTask({ id: row.id });
+                    if (res.data.code === '200') {
+                        ElMessage({
+                            type: 'success',
+                            duration: 2000,
+                            message: '删除成功'
+                        });
+                        await getInspectionTask();
+                    } else {
+                        ElMessage({
+                            type: 'warning',
+                            message: res.data.msg
+                        });
+                    }
+                })
+                .catch(() => {});
+        };
+
         const openInspectTaskDialog = (type: string, value: {}) => {
-            inspectTaskDialogRef.value.showInspectTaskDialog(type, value, state.workTypeList, state.departmentList, state.timeType, state.classGroupList, state.quotaList, state.inspectPointAllList);
+            inspectTaskDialogRef.value.showInspectTaskDialog(type, value, state.workTypeList, state.departmentList, state.timeType, state.classGroupList, state.quotaList, state.inspectPointAllList, state.regionNameList, state.RFIDList);
         };
 
         const parseNumber = (value: number, type: string) => {
@@ -281,6 +441,7 @@
                 pageIndex: 1,
                 pageSize: 10,
                 unitName: null,
+                execDepId: null,
                 workType: null,
                 createUserId: null,
                 execClassgroupId: null,
@@ -296,6 +457,8 @@
             getDepartmentData();
             getClassGroupData();
             getInspectTaskPoint();
+            initFacilityAreaType();
+            initRFIDList();
         });
 
         return {
@@ -305,7 +468,10 @@
             Refresh,
             Plus,
             reset,
+            changeStatus,
+            changeGroup,
             parseNumber,
+            deleteInspectTask,
             getInspectionTask,
             onHandleSizeChange,
             onHandleCurrentChange,
@@ -320,15 +486,17 @@
 <style scoped lang="scss">
 $homeNavLengh: 8;
 .home-container {
-    height: calc(100vh - 114px);
+    height: calc(100vh - 144px);
     box-sizing: border-box;
     overflow: hidden;
+    position: relative;
     .homeCard {
         width: 100%;
         padding: 20px;
         box-sizing: border-box;
         background: #fff;
         border-radius: 4px;
+        flex: 0 auto;
 
         .main-card {
             width: 100%;
@@ -343,10 +511,18 @@
                 }
             }
             .pageBtn {
-                height: 60px;
-                display: flex;
-                align-items: center;
-                justify-content: right;
+              position: absolute;
+              width: 100%;
+              z-index: 99;
+              bottom: 0;
+              right: 0;
+              height: 60px;
+              border-radius: 0 0 4px 4px;
+              padding-right: 20px;
+              background: #fff;
+              display: flex;
+              align-items: center;
+              justify-content: right;
 
                 .demo-pagination-block + .demo-pagination-block {
                     margin-top: 10px;
@@ -357,7 +533,7 @@
             }
         }
         &:last-of-type {
-            height: calc(100% - 100px);
+          flex: 1;
         }
     }
     .el-row {

--
Gitblit v1.9.2