From 6361501810a76b6809162cac99b0d9c1faba3715 Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期四, 16 四月 2026 15:10:02 +0800
Subject: [PATCH] fix: 对退料请求做限制

---
 src/views/productionManagement/productionOrder/index.vue |   50 +++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 47 insertions(+), 3 deletions(-)

diff --git a/src/views/productionManagement/productionOrder/index.vue b/src/views/productionManagement/productionOrder/index.vue
index 260b2c3..cc0de4e 100644
--- a/src/views/productionManagement/productionOrder/index.vue
+++ b/src/views/productionManagement/productionOrder/index.vue
@@ -91,6 +91,17 @@
       </template>
     </el-dialog>
 
+    <MaterialLedgerDialog
+      v-model="materialDialogVisible"
+      :order-row="currentMaterialOrder"
+      @saved="getList"
+    />
+    <MaterialDetailDialog
+      v-model="materialDetailDialogVisible"
+      :order-row="currentMaterialDetailOrder"
+      @confirmed="getList"
+    />
+
     <new-product-order v-if="isShowNewModal"
                          v-model:visible="isShowNewModal"
                          @completed="handleQuery" />
@@ -98,7 +109,7 @@
 </template>
 
 <script setup>
-  import { onMounted, ref } from "vue";
+  import { computed, defineAsyncComponent, getCurrentInstance, onMounted, reactive, ref, toRefs } from "vue";
   import { ElMessageBox } from "element-plus";
   import dayjs from "dayjs";
   import { useRouter } from "vue-router";
@@ -109,7 +120,8 @@
     listProcessBom, delProductOrder,
   } from "@/api/productionManagement/productionOrder.js";
   import { listMain as getOrderProcessRouteMain } from "@/api/productionManagement/productProcessRoute.js";
-  import {fileDel} from "@/api/financialManagement/revenueManagement.js";
+  import MaterialLedgerDialog from "@/views/productionManagement/productionOrder/components/MaterialLedgerDialog.vue";
+  import MaterialDetailDialog from "@/views/productionManagement/productionOrder/components/MaterialDetailDialog.vue";
   import PIMTable from "@/components/PIMTable/PIMTable.vue";
   const NewProductOrder = defineAsyncComponent(() => import("@/views/productionManagement/productionOrder/New.vue"));
 
@@ -187,7 +199,7 @@
       label: "鎿嶄綔",
       align: "center",
       fixed: "right",
-      width: 200,
+      width: 340,
       operation: [
         {
           name: "宸ヨ壓璺嚎",
@@ -209,6 +221,20 @@
           type: "text",
           clickFun: row => {
             showProductStructure(row);
+          },
+        },
+        {
+          name: "棰嗘枡",
+          type: "text",
+          clickFun: row => {
+            openMaterialDialog(row);
+          },
+        },
+        {
+          name: "棰嗘枡璇︽儏",
+          type: "text",
+          clickFun: row => {
+            openMaterialDetailDialog(row);
           },
         },
       ],
@@ -277,6 +303,10 @@
     orderId: null,
     routeId: null,
   });
+  const materialDialogVisible = ref(false);
+  const currentMaterialOrder = ref(null);
+  const materialDetailDialogVisible = ref(false);
+  const currentMaterialDetailOrder = ref(null);
 
   const openBindRouteDialog = async row => {
     bindForm.orderId = row.id;
@@ -320,6 +350,16 @@
     } finally {
       bindRouteSaving.value = false;
     }
+  };
+
+  const openMaterialDialog = row => {
+    currentMaterialOrder.value = row;
+    materialDialogVisible.value = true;
+  };
+
+  const openMaterialDetailDialog = async row => {
+    currentMaterialDetailOrder.value = row;
+    materialDetailDialogVisible.value = true;
   };
 
   // 鏌ヨ鍒楄〃
@@ -470,4 +510,8 @@
 :deep(.purple){
   background-color: #F4DEFA;
 }
+.table_list {
+	margin-top: unset;
+}
+
 </style>

--
Gitblit v1.9.3