From b8fd394b8da06c07c077c6f018de9a1f6c62b98c Mon Sep 17 00:00:00 2001
From: zhangherong <571457620@qq.com>
Date: 星期四, 17 四月 2025 14:30:38 +0800
Subject: [PATCH] art: 设备管理-点检工单-查询,列表修改

---
 src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue |  196 ++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 168 insertions(+), 28 deletions(-)

diff --git a/src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue b/src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue
index 503be9c..5303ee7 100644
--- a/src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue
+++ b/src/views/flowable/workflow/weekMaintenance/WeekMaintenanceApprovalModal.vue
@@ -4,6 +4,7 @@
     :width="1200"
     :visible="visible"
     :confirmLoading="confirmLoading"
+    :okButtonProps="{ class:{'jee-hidden': disableSubmit} }"
     switchFullscreen
     @ok="handleOk"
     @cancel="handleCancel"
@@ -63,7 +64,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 +90,97 @@
                 <template v-slot:maintenanceResult="props">
                   <j-dict-select-tag v-model="props.row.maintenanceResult" dictCode="eam_inspection_result"
                                      placeholder="璇烽�夋嫨淇濆吇缁撴灉"
+                                     :disabled="disableSubmit || 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="disableSubmit || 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="disableSubmit || confirmDisable || !props.row.maintenanceResult || props.row.maintenanceResult === '1'"
                                      dictCode="yn"
                                      style="width: 100%" />
                 </template>
               </j-vxe-table>
             </a-tab-pane>
-            <a-button v-if="selectedRowKeys.length>0" slot="tabBarExtraContent" type="primary"
-                      @click="handleSelectAllInspectionResult">鎵归噺淇濆吇姝e父
+            <a-tab-pane v-if="!disableSubmit" 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="!disableSubmit || selectedRowKeys.length > 0" slot="tabBarExtraContent" type="primary"
+                      @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="disableSubmit || 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="disableSubmit || 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="disableSubmit || 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="disableSubmit || 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="disableSubmit || 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="disableSubmit || completionDisable"
+                           v-model="model.finalAcceptanceFilesResult" />
+              </a-form-model-item>
+            </a-col>
+          </a-row>
         </div>
       </a-form-model>
     </a-spin>
@@ -145,10 +205,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 +229,32 @@
         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',
       },
+      disableSubmit: false,
+      taskData: [],
+      isDisplayBmp: false,
+      showBmpButtonLoading: false,
+      selectedRowKeys: [],
       detail: {
         loading: false,
         dataSource: [],
@@ -222,8 +300,7 @@
           {
             title: '淇濆吇缁撴灉',
             key: 'maintenanceResult',
-            type: JVXETypes.selectSearch,
-            dictCode: 'eam_inspection_result',
+            type: JVXETypes.slot,
             width: '10%',
             align: 'center',
             slotName: 'maintenanceResult',
@@ -234,7 +311,7 @@
           {
             title: '寮傚父鎻忚堪',
             key: 'exceptionDescription',
-            type: JVXETypes.textarea,
+            type: JVXETypes.slot,
             width: '20%',
             align: 'center',
             slotName: 'exceptionDescription',
@@ -242,16 +319,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,17 +336,67 @@
   },
   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
+    },
+    recordDetail(record) {
+      this.loading = true
+      this.visible = true
+      this.detail.dataSource = []
+      this.model = Object.assign({}, record)
+      if(this.model.imageFiles) {
+        let obj = JSON.parse(this.model.imageFiles);
+        this.model.imageFilesResult = [...obj];
+      }
+      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.loadDetail(record.id)
       this.loading = false
     },
     close() {
@@ -291,7 +414,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 +441,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