From c05b81c7f50df80ab247a05f9f92af2d799e77cd Mon Sep 17 00:00:00 2001
From: liding <756868258@qq.com>
Date: 星期五, 10 四月 2026 15:59:04 +0800
Subject: [PATCH] feat:1.销售添加是否生产 2.生产订单添加备注

---
 src/views/inventoryManagement/stockManagement/Subtract.vue |   48 ++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 38 insertions(+), 10 deletions(-)

diff --git a/src/views/inventoryManagement/stockManagement/Subtract.vue b/src/views/inventoryManagement/stockManagement/Subtract.vue
index bc6c516..62988d1 100644
--- a/src/views/inventoryManagement/stockManagement/Subtract.vue
+++ b/src/views/inventoryManagement/stockManagement/Subtract.vue
@@ -31,6 +31,13 @@
         </el-form-item>
 
         <el-form-item
+            label="鏂欏彿"
+            prop="materialCode"
+        >
+          <el-input v-model="formState.materialCode"  disabled />
+        </el-form-item>
+
+        <el-form-item
             label="鍗曚綅"
             prop="unit"
         >
@@ -41,7 +48,7 @@
             label="鏁伴噺"
             prop="qualitity"
         >
-          <el-input-number v-model="formState.qualitity" :step="1" :min="0" style="width: 100%" />
+          <el-input-number v-model="formState.qualitity" :step="1" :min="1" :max="maxQuality" style="width: 100%" />
         </el-form-item>
 
         <el-form-item label="澶囨敞" prop="remark">
@@ -69,6 +76,7 @@
 import {ref, computed, getCurrentInstance} from "vue";
 import ProductSelectDialog from "@/views/basicData/product/ProductSelectDialog.vue";
 import {subtractStockInventory} from "@/api/inventoryManagement/stockInventory.js";
+import {subtractStockUnInventory} from "@/api/inventoryManagement/stockUninventory.js";
 
 const props = defineProps({
   visible: {
@@ -78,7 +86,12 @@
   record: {
     type: Object,
     default: () => {},
-  }
+  },
+  type: {
+    type: String,
+    required: true,
+    default: 'qualified',
+  },
 });
 
 const emit = defineEmits(['update:visible', 'completed']);
@@ -87,10 +100,13 @@
   initFormData()
 })
 
+const maxQuality = computed(() => {
+  return props.record.unLockedQuantity ? props.record.unLockedQuantity :  0;
+})
+
 const initFormData = () => {
   if (props.record) {
     formState.value = {
-      ...formState.value,
       ...props.record,
     }
   }
@@ -102,6 +118,7 @@
   productModelId: undefined,
   productName: "",
   model: "",
+  materialCode: "",
   unit: "",
   qualitity: 0,
   remark: '',
@@ -142,6 +159,7 @@
     formState.value.productModelName = product.model;
     formState.value.productModelId = product.id;
     formState.value.unit = product.unit;
+    formState.value.materialCode = product.materialCode;
     showProductSelectDialog.value = false;
     // 瑙﹀彂琛ㄥ崟楠岃瘉鏇存柊
     proxy.$refs["formRef"]?.validateField('productModelId');
@@ -160,13 +178,23 @@
         proxy.$modal.msgError("璇烽�夋嫨瑙勬牸");
         return;
       }
-      subtractStockInventory(formState.value).then(res => {
-        // 鍏抽棴妯℃�佹
-        isShow.value = false;
-        // 鍛婄煡鐖剁粍浠跺凡瀹屾垚
-        emit('completed');
-        proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
-      })
+      if (props.type === 'qualified') {
+        subtractStockInventory(formState.value).then(res => {
+          // 鍏抽棴妯℃�佹
+          isShow.value = false;
+          // 鍛婄煡鐖剁粍浠跺凡瀹屾垚
+          emit('completed');
+          proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
+        })
+      } else {
+        subtractStockUnInventory(formState.value).then(res => {
+          // 鍏抽棴妯℃�佹
+          isShow.value = false;
+          // 鍛婄煡鐖剁粍浠跺凡瀹屾垚
+          emit('completed');
+          proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
+        })
+      }
     }
   })
 };

--
Gitblit v1.9.3