From 6b759ea4e8e06809ca2d50cfb0b6d26f4f5a7880 Mon Sep 17 00:00:00 2001
From: zhangherong <571457620@qq.com>
Date: 星期二, 15 四月 2025 16:35:31 +0800
Subject: [PATCH] art: 设备管理-周保-保养流程调试修改

---
 src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue |  172 ++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 145 insertions(+), 27 deletions(-)

diff --git a/src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue b/src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue
index 503be9c..ef11321 100644
--- a/src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue
+++ b/src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue
@@ -63,7 +63,8 @@
             <lx-upload :returnUrl="false"
                        :isMultiple="true"
                        file-type="image"
-                       v-model="model.fileList" />
+                       :disabled="confirmDisable"
+                       v-model="model.imageFilesResult" />
           </a-form-model-item>
         </a-row>
         <a-divider orientation="center" style="font-size: large;font-style: italic;color: #66aeed;"> 淇濆吇椤逛俊鎭�
@@ -88,39 +89,97 @@
                 <template v-slot:maintenanceResult="props">
                   <j-dict-select-tag v-model="props.row.maintenanceResult" dictCode="eam_inspection_result"
                                      placeholder="璇烽�夋嫨淇濆吇缁撴灉"
+                                     :disabled="confirmDisable"
                                      @change="handleInspectionResultSelectChange($event,props.row)"
                                      style="width: 100%" />
                 </template>
 
                 <template v-slot:exceptionDescription="props">
                   <a-textarea style="height: 32px" v-model="props.row.exceptionDescription"
-                              :disabled="!props.row.maintenanceResult||props.row.maintenanceResult==='1'" />
+                              :disabled="confirmDisable || !props.row.maintenanceResult || props.row.maintenanceResult === '1'" />
                 </template>
 
                 <template v-slot:reportFlag="props">
                   <j-dict-select-tag v-model="props.row.reportFlag"
-                                     :disabled="!props.row.maintenanceResult||props.row.maintenanceResult==='1'"
+                                     :disabled="confirmDisable || !props.row.maintenanceResult || props.row.maintenanceResult === '1'"
                                      dictCode="yn"
                                      style="width: 100%" />
                 </template>
               </j-vxe-table>
             </a-tab-pane>
+            <a-tab-pane key='2' tab='娴佺▼鑺傜偣'>
+              <a-card :bordered="false">
+                <a-timeline>
+                  <a-timeline-item v-for="(item,index) in taskData" :key="index">
+                    <div>
+                      <h3 style="font-weight: bold;">{{item.taskName}}</h3>
+                      <div>澶勭悊浜猴細{{item.assignee_dictText}}</div>
+                      <div v-if="index !==0">澶勭悊鏃堕暱锛歿{item.duration}}</div>
+                      <div v-if="item.name !== '鎻愪氦鐢宠'">澶勭悊绫诲瀷锛歿{item.sequenceFlowName}}</div>
+                      <div v-if="item.description">澶勭悊鎰忚锛歿{item.description}}</div>
+                    </div>
+                  </a-timeline-item>
+                </a-timeline>
+              </a-card>
+            </a-tab-pane>
             <a-button v-if="selectedRowKeys.length>0" slot="tabBarExtraContent" type="primary"
-                      @click="handleSelectAllInspectionResult">鎵归噺淇濆吇姝e父
+                      @click="handleSelectAllInspectionResult">淇濆吇姝e父
             </a-button>
           </a-tabs>
         </a-row>
-        <div v-if="['WAIT_CONFIRM', 'WAIT_INITIAL_ACCEPTANCE', 'WAIT_FINAL_ACCEPTANCE', 'COMPLETE'].includes(model.maintenanceStatus)">
+        <div v-if="confirmDisable">
           <a-divider orientation="center" style="font-size: large;font-style: italic;color: #66aeed;"> 鐝粍闀跨‘璁や俊鎭�
           </a-divider>
+          <a-row :gutter="24">
+            <a-col :span="12">
+              <a-form-model-item :labelCol="labelCol" :wrapperCol="wrapperCol" prop="confirmDealType" label="纭绫诲瀷">
+                <j-dict-select-tag  type='radio' v-model='model.confirmDealType' dictCode='approved_rejected' placeholder="璇烽�夋嫨澶勭悊绫诲瀷" :disabled="initialAcceptanceDisable" />
+              </a-form-model-item>
+            </a-col>
+            <a-col :span="12">
+              <a-form-model-item :labelCol="labelCol" :wrapperCol="wrapperCol" prop="confirmComment" label="纭鎰忚">
+                <a-textarea placeholder="璇疯緭鍏ユ剰瑙�" v-model="model.confirmComment" :disabled="initialAcceptanceDisable" />
+              </a-form-model-item>
+            </a-col>
+          </a-row>
         </div>
-        <div v-if="['WAIT_INITIAL_ACCEPTANCE', 'WAIT_FINAL_ACCEPTANCE', 'COMPLETE'].includes(model.maintenanceStatus)">
+        <div v-if="initialAcceptanceDisable">
           <a-divider orientation="center" style="font-size: large;font-style: italic;color: #66aeed;"> 鍒濋獙鏀朵俊鎭�
           </a-divider>
+          <a-row :gutter="24">
+            <a-col :span="12">
+              <a-form-model-item :labelCol="labelCol" :wrapperCol="wrapperCol" prop="initialAcceptanceComment" label="鍒濋獙鏀舵剰瑙�">
+                <a-textarea placeholder="璇疯緭鍏ユ剰瑙�" v-model="model.initialAcceptanceComment" :disabled="finalAcceptanceDisable" />
+              </a-form-model-item>
+            </a-col>
+            <a-col :span="12">
+              <a-form-model-item :labelCol="labelCol" :wrapperCol="wrapperCol" prop="initialAcceptanceFilesResult" label="鍒濋獙鏀堕檮浠�">
+                <lx-upload :returnUrl="false"
+                           :isMultiple="true"
+                           :disabled="finalAcceptanceDisable"
+                           v-model="model.initialAcceptanceFilesResult" />
+              </a-form-model-item>
+            </a-col>
+          </a-row>
         </div>
-        <div v-if="['WAIT_FINAL_ACCEPTANCE', 'COMPLETE'].includes(model.maintenanceStatus)">
+        <div v-if="finalAcceptanceDisable">
           <a-divider orientation="center" style="font-size: large;font-style: italic;color: #66aeed;"> 缁堥獙鏀朵俊鎭�
           </a-divider>
+          <a-row :gutter="24">
+            <a-col :span="12">
+              <a-form-model-item :labelCol="labelCol" :wrapperCol="wrapperCol" prop="finalAcceptanceComment" label="缁堥獙鏀舵剰瑙�">
+                <a-textarea placeholder="璇疯緭鍏ユ剰瑙�" v-model="model.finalAcceptanceComment" :disabled="completionDisable" />
+              </a-form-model-item>
+            </a-col>
+            <a-col :span="12">
+              <a-form-model-item :labelCol="labelCol" :wrapperCol="wrapperCol" prop="finalAcceptanceFilesResult" label="缁堥獙鏀堕檮浠�">
+                <lx-upload :returnUrl="false"
+                           :isMultiple="true"
+                           :disabled="completionDisable"
+                           v-model="model.finalAcceptanceFilesResult" />
+              </a-form-model-item>
+            </a-col>
+          </a-row>
         </div>
       </a-form-model>
     </a-spin>
@@ -145,10 +204,9 @@
       visible: false,
       //鐘舵�佹帶鍒�
       //淇濆吇涓� 涓嶅彲缂栬緫
-      underMaintenanceDisable: false,
-      confirmDisable: false,
-      initialAcceptanceDisable: false,
-      finalAcceptanceDisable: false,
+      // confirmDisable: false,
+      // initialAcceptanceDisable: false,
+      // finalAcceptanceDisable: false,
       editable: false,
       model: {},
       maintenanceCategory: 'WEEK_MAINTENANCE',
@@ -170,13 +228,31 @@
         sm: { span: 21 }
       },
       confirmLoading: false,
-      validatorRules: {},
+      validatorRules: {
+        confirmDealType: [
+          { required: true, message: '璇烽�夋嫨閫氳繃鎴栭┏鍥�!' }
+        ],
+        confirmComment: [
+          { required: true, message: '璇疯緭鍏ョ‘璁ゆ剰瑙�!' }
+        ],
+        initialAcceptanceComment: [
+          { required: true, message: '璇疯緭鍏ュ垵楠屾敹鎰忚!' }
+        ],
+        finalAcceptanceComment: [
+          { required: true, message: '璇疯緭鍏ョ粓楠屾敹鎰忚!' }
+        ],
+      },
       url: {
         queryById: '/eam/weekMaintenanceOrder/queryById',
         detail: '/eam/weekMaintenanceOrderDetail/queryList',
         approval: '/eam/weekMaintenanceOrder/approval',
-        userSelect: '/eam/user_select/list'
+        userSelect: '/eam/user_select/list',
+        queryHisTaskList: '/assign/flow/queryHisTaskList',
       },
+      taskData: [],
+      isDisplayBmp: false,
+      showBmpButtonLoading: false,
+      selectedRowKeys: [],
       detail: {
         loading: false,
         dataSource: [],
@@ -222,8 +298,7 @@
           {
             title: '淇濆吇缁撴灉',
             key: 'maintenanceResult',
-            type: JVXETypes.selectSearch,
-            dictCode: 'eam_inspection_result',
+            type: JVXETypes.slot,
             width: '10%',
             align: 'center',
             slotName: 'maintenanceResult',
@@ -234,7 +309,7 @@
           {
             title: '寮傚父鎻忚堪',
             key: 'exceptionDescription',
-            type: JVXETypes.textarea,
+            type: JVXETypes.slot,
             width: '20%',
             align: 'center',
             slotName: 'exceptionDescription',
@@ -242,16 +317,12 @@
           {
             title: '鏄惁鎶ヤ慨',
             key: 'reportFlag',
-            type: JVXETypes.selectSearch,
-            dictCode: 'yn',
+            type: JVXETypes.slot,
             width: '10%',
             align: 'center',
             slotName: 'reportFlag',
           }
         ],
-        isDisplayBmp: false,
-        showBmpButtonLoading: false,
-        selectedRowKeys: [],
         toolbarConfig: {
           // prefix 鍓嶇紑锛泂uffix 鍚庣紑
           slot: ['prefix', 'suffix'],
@@ -263,16 +334,46 @@
   },
   created() {
   },
+  computed: {
+    confirmDisable: function(){
+      return ['WAIT_CONFIRM', 'WAIT_INITIAL_ACCEPTANCE', 'WAIT_FINAL_ACCEPTANCE', 'COMPLETE'].includes(this.model.maintenanceStatus);
+    },
+    initialAcceptanceDisable: function() {
+      return ['WAIT_INITIAL_ACCEPTANCE', 'WAIT_FINAL_ACCEPTANCE', 'COMPLETE'].includes(this.model.maintenanceStatus);
+    },
+    finalAcceptanceDisable: function() {
+      return ['WAIT_FINAL_ACCEPTANCE', 'COMPLETE'].includes(this.model.maintenanceStatus);
+    },
+    completionDisable: function() {
+      return ['COMPLETE', 'ABOLISH'].includes(this.model.maintenanceStatus);
+    }
+  },
   methods: {
     async handleDetail(item) {
       this.loading = true
       this.visible = true
       this.detail.dataSource = []
-      let param = {
-        id: item.dataId
+      let taskDataList = await  getAction(this.url.queryHisTaskList, { procInstId: item.procInstId });
+      this.taskData = [...taskDataList.result];
+      let res = await getAction(this.url.queryById, {id: item.dataId})
+      this.model = Object.assign({}, res.result)
+      if(this.model.imageFiles) {
+        let obj = JSON.parse(this.model.imageFiles);
+        this.model.imageFilesResult = [...obj];
       }
-      let res = await getAction(this.url.queryById, param)
-      this.model = Object.assign({}, res.result, item)
+      if(this.model.initialAcceptanceFiles) {
+        let obj = JSON.parse(this.model.initialAcceptanceFiles);
+        this.model.initialAcceptanceFilesResult = [...obj];
+      }
+      if(this.model.finalAcceptanceFiles) {
+        let obj = JSON.parse(this.model.finalAcceptanceFiles);
+        this.model.finalAcceptanceFilesResult = [...obj];
+      }
+      this.model.dataId = item.dataId
+      this.model.taskId = item.id
+      this.model.userId = item.assignee
+      this.model.instanceId = item.procInstId
+      this.model.values = item.variables
       await this.loadDetail(item.dataId)
       this.loading = false
     },
@@ -291,7 +392,24 @@
       // 瑙﹀彂琛ㄥ崟楠岃瘉
       this.$refs.form.validate(valid => {
         if (valid) {
-          let tableData = that.$refs.editableDetailTable.getTableData()
+          let tableData = that.$refs.editableDetailTable.getTableData();
+
+          let checkMsg = null;
+          tableData.some(row => {
+            if(!row.maintenanceResult) {
+              checkMsg = '淇濆吇缁撴灉涓嶈兘涓虹┖锛�';
+              return true;
+            }
+            if(row.maintenanceResult === '2' && (!row.exceptionDescription || !row.reportFlag)) {
+              checkMsg = '淇濆吇缁撴灉涓哄紓甯革紝闇�瑕佸~鍐欏紓甯稿師鍥犲強鏄惁鎶ヤ慨锛�';
+              return true;
+            }
+          })
+          if(checkMsg) {
+            that.$message.warning(checkMsg);
+            return;
+          }
+
           that.model.tableDetailList = [...tableData]
 
           that.confirmLoading = true
@@ -301,7 +419,7 @@
           httpAction(httpurl, this.model, method).then((res) => {
             if (res.success) {
               that.$message.success(res.message)
-              that.$emit('ok')
+              that.$emit('searchReset')
               that.close()
             } else {
               that.$message.warning(res.message)

--
Gitblit v1.9.3