From f5c900c58513bad824381e69750ac7667ef35de0 Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期四, 26 二月 2026 22:29:46 +0800
Subject: [PATCH] feat: 修改增另任务单查询,使用单号查询

---
 ruoyi-ui/src/views/task/general/detail.vue |   41 +++++++++++++++++++++++++++++++++++++++--
 1 files changed, 39 insertions(+), 2 deletions(-)

diff --git a/ruoyi-ui/src/views/task/general/detail.vue b/ruoyi-ui/src/views/task/general/detail.vue
index e0b0bd8..2c0ab51 100644
--- a/ruoyi-ui/src/views/task/general/detail.vue
+++ b/ruoyi-ui/src/views/task/general/detail.vue
@@ -129,6 +129,16 @@
             @click="syncDispatchOrder"
             style="margin-left: 10px;"
           >鍚屾璋冨害鍗�</el-button>
+          <!-- 浠庢棫绯荤粺鍚屾鏁版嵁鍒版柊绯荤粺鎸夐挳 -->
+          <el-button
+            v-if="taskDetail.emergencyInfo.legacyServiceOrdId && taskDetail.emergencyInfo.legacyDispatchOrdId"
+            type="success"
+            size="mini"
+            icon="el-icon-download"
+            :loading="syncingFromLegacy"
+            @click="syncFromLegacySystem"
+            style="margin-left: 10px;"
+          >浠庢棫绯荤粺鍚屾</el-button>
         </el-descriptions-item>
         <el-descriptions-item label="璋冨害鍗曞彿">
           <span v-if="taskDetail.emergencyInfo.legacyDispatchOrdId">
@@ -788,7 +798,7 @@
 </template>
 
 <script>
-import { getTask, updateTask, assignTask, changeTaskStatus, uploadAttachment, deleteAttachment, getTaskVehicles, getAvailableVehicles, assignVehiclesToTask, unassignVehicleFromTask, getPaymentInfo, syncServiceOrder, syncDispatchOrder, syncTaskStatus } from "@/api/task";
+import { getTask, updateTask, assignTask, changeTaskStatus, uploadAttachment, deleteAttachment, getTaskVehicles, getAvailableVehicles, assignVehiclesToTask, unassignVehicleFromTask, getPaymentInfo, syncServiceOrder, syncDispatchOrder, syncTaskStatus, syncFromLegacySystem, checkTaskInvoice } from "@/api/task";
 import { listUser } from "@/api/system/user";
 import { getToken } from "@/utils/auth";
 
@@ -881,6 +891,7 @@
       // 鍚屾鍔犺浇鐘舵��
       syncingServiceOrder: false,
       syncingDispatchOrder: false,
+      syncingFromLegacy: false,
       syncingTaskStatus: false,
       // 鍙戠エ鐢宠鐘舵��
       hasInvoiceApplied: false,
@@ -1226,6 +1237,32 @@
         this.syncingDispatchOrder = false;
       });
     },
+    /** 浠庢棫绯荤粺鍚屾鏁版嵁鍒版柊绯荤粺 */
+    syncFromLegacySystem() {
+      // 妫�鏌ユ槸鍚﹀悓鏃舵湁serviceOrdID鍜宒ispatchOrdID
+      if (!this.taskDetail.emergencyInfo.legacyServiceOrdId || !this.taskDetail.emergencyInfo.legacyDispatchOrdId) {
+        this.$modal.msgError("缂哄皯蹇呰鐨勬棫绯荤粺ID淇℃伅");
+        return;
+      }
+      
+      this.$modal.confirm('鏄惁纭浠庢棫绯荤粺鍚屾鏁版嵁鍒版柊绯荤粺锛�').then(() => {
+        this.syncingFromLegacy = true;
+        return syncFromLegacySystem(
+          this.taskDetail.emergencyInfo.legacyServiceOrdId,
+          this.taskDetail.emergencyInfo.legacyDispatchOrdId
+        );
+      }).then(() => {
+        this.$modal.msgSuccess("浠庢棫绯荤粺鍚屾鎴愬姛");
+        // 閲嶆柊鍔犺浇浠诲姟璇︽儏
+        this.getTaskDetail();
+      }).catch((error) => {
+        if (error !== 'cancel') {
+          this.$modal.msgError("鍚屾澶辫触: " + (error.message || "鏈煡閿欒"));
+        }
+      }).finally(() => {
+        this.syncingFromLegacy = false;
+      });
+    },
     /** 鎵嬪姩鍚屾浠诲姟鐘舵�� */
     syncTaskStatus() {
       this.$modal.confirm('鏄惁纭鍚屾浠诲姟鐘舵�佸埌鏃х郴缁燂紵').then(() => {
@@ -1245,7 +1282,7 @@
     /** 妫�鏌ュ彂绁ㄧ敵璇风姸鎬� */
     checkInvoiceStatus() {
       // 璋冪敤鍚庣鎺ュ彛妫�鏌ヨ浠诲姟鏄惁宸茬敵璇峰彂绁�
-      this.$axios.get(`/system/invoice/checkTaskInvoice/${this.$route.params.taskId}`)
+      checkTaskInvoice(this.$route.params.taskId)
         .then(response => {
           if (response.code === 200 && response.data) {
             this.hasInvoiceApplied = true;

--
Gitblit v1.9.1