From 04ecdbfb7be63ca4a3d49d3575847e728e3e9ae7 Mon Sep 17 00:00:00 2001
From: liding <756868258@qq.com>
Date: 星期五, 27 三月 2026 17:44:13 +0800
Subject: [PATCH] fix:1.耗材选择产品优化

---
 src/views/inventoryManagement/stockManagement/Subtract.vue |  175 +++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 161 insertions(+), 14 deletions(-)

diff --git a/src/views/inventoryManagement/stockManagement/Subtract.vue b/src/views/inventoryManagement/stockManagement/Subtract.vue
index a277a00..cc5a12b 100644
--- a/src/views/inventoryManagement/stockManagement/Subtract.vue
+++ b/src/views/inventoryManagement/stockManagement/Subtract.vue
@@ -30,19 +30,115 @@
           <el-input v-model="formState.model"  disabled />
         </el-form-item>
 
+        <!-- 闈炲師鏉愭枡鏄剧ず鏁伴噺瀛楁 -->
         <el-form-item
-            label="鍗曚綅"
-            prop="unit"
-        >
-          <el-input v-model="formState.unit"  disabled />
-        </el-form-item>
-
-        <el-form-item
+            v-if="props.record.productType !== 0"
             label="鏁伴噺"
             prop="qualitity"
+            :rules="[
+              { required: true, message: '璇疯緭鍏ユ暟閲�', trigger: ['blur', 'change'] }
+            ]"
         >
-          <el-input-number v-model="formState.qualitity" :step="1" :min="1" :max="maxQuality" style="width: 100%" />
+          <el-input-number
+              v-model="formState.qualitity"
+              :min="0"
+              :step="1"
+              :precision="0"
+              style="width: 100%"
+              controls-position="right"
+              placeholder="璇疯緭鍏ユ暟閲�"
+          />
         </el-form-item>
+
+        <!-- 鍘熸潗鏂欐樉绀鸿繃纾呯浉鍏冲瓧娈� -->
+        <template v-if="props.record.productType === 0">
+          <el-form-item
+              label="杞︾墝鍙�"
+              prop="licensePlateNo"
+              :rules="[{ required: true, message: '璇疯緭鍏ヨ溅鐗屽彿', trigger: ['blur','change'] }]"
+          >
+            <el-input v-model="formState.licensePlateNo" />
+          </el-form-item>
+          <el-form-item
+              label="鍗曚綅"
+              prop="unit"
+          >
+            <el-select
+                v-model="formState.unit"
+                placeholder="璇烽�夋嫨鍗曚綅"
+                style="width: 100%"
+                clearable
+            >
+              <el-option label="鍚�" value="鍚�" />
+              <el-option label="鍏枻" value="鍏枻" />
+            </el-select>
+          </el-form-item>
+          <el-form-item
+              label="姣涢噸"
+              prop="grossWeight"
+              :rules="[{ required: true, message: '璇疯緭鍏ユ瘺閲�', trigger: ['blur','change'] }]"
+          >
+            <el-input-number
+                v-model="formState.grossWeight"
+                :step="0.01"
+                :min="0"
+                style="width: 100%"
+                @change="computeNetWeight"
+            />
+          </el-form-item>
+
+          <el-form-item
+              label="鐨噸"
+              prop="tareWeight"
+              :rules="[{ required: true, message: '璇疯緭鍏ョ毊閲�', trigger: ['blur','change'] }]"
+          >
+            <el-input-number
+                v-model="formState.tareWeight"
+                :step="0.01"
+                :min="0"
+                style="width: 100%"
+                @change="computeNetWeight"
+            />
+          </el-form-item>
+
+          <el-form-item
+              label="鍑�閲�"
+              prop="netWeight"
+              :rules="[{ required: true, message: '鍑�閲嶇敱姣涢噸鍜岀毊閲嶈嚜鍔ㄨ绠�', trigger: ['blur','change'] }]"
+          >
+            <el-input-number
+                v-model="formState.netWeight"
+                :step="0.01"
+                :min="0"
+                style="width: 100%"
+                disabled
+            />
+          </el-form-item>
+
+          <el-form-item
+              label="杩囩鏃ユ湡"
+              prop="weighingDate"
+              :rules="[{ required: true, message: '璇烽�夋嫨杩囩鏃ユ湡', trigger: 'change' }]"
+          >
+            <el-date-picker
+                style="width: 100%"
+                v-model="formState.weighingDate"
+                value-format="YYYY-MM-DD HH:mm:ss"
+                format="YYYY-MM-DD HH:mm:ss"
+                type="datetime"
+                placeholder="璇烽�夋嫨杩囩鏃ユ湡"
+                clearable
+            />
+          </el-form-item>
+
+          <el-form-item
+              label="杩囩鍛�"
+              prop="weighingOperator"
+              :rules="[{ required: true, message: '璇疯緭鍏ヨ繃纾呭憳', trigger: ['blur','change'] }]"
+          >
+            <el-input v-model="formState.weighingOperator" />
+          </el-form-item>
+        </template>
 
         <el-form-item label="澶囨敞" prop="remark">
           <el-input v-model="formState.remark" type="textarea" />
@@ -66,7 +162,7 @@
 </template>
 
 <script setup>
-import {ref, computed, getCurrentInstance} from "vue";
+import {ref, computed, getCurrentInstance, onMounted} from "vue";
 import ProductSelectDialog from "@/views/basicData/product/ProductSelectDialog.vue";
 import {subtractStockInventory} from "@/api/inventoryManagement/stockInventory.js";
 import {subtractStockUnInventory} from "@/api/inventoryManagement/stockUninventory.js";
@@ -93,15 +189,22 @@
   initFormData()
 })
 
-const maxQuality = computed(() => {
-  return props.record.unLockedQuantity ? props.record.unLockedQuantity :  0;
+const isRawMaterial = computed(() => {
+  return props.record.parentName === '鍘熸潗鏂�';
 })
+
+const ledgerNetWeight = computed(() => {
+  const n = Number(props.record?.netWeight ?? 0);
+  return Number.isFinite(n) ? n : 0;
+});
 
 const initFormData = () => {
   if (props.record) {
     formState.value = {
       ...props.record,
     }
+    // 鍒濆鍖栨椂涔熻Е鍙戜竴娆″噣閲嶈绠楋紝閬垮厤鎺ュ彛鍥炲~鍚庡噣閲嶄负绌�
+    computeNetWeight()
   }
 }
 
@@ -112,7 +215,13 @@
   productName: "",
   model: "",
   unit: "",
-  qualitity: 0,
+  // 杩囩鐩稿叧瀛楁
+  licensePlateNo: "",
+  grossWeight: undefined,
+  tareWeight: undefined,
+  netWeight: undefined,
+  weighingDate: undefined,
+  weighingOperator: "",
   remark: '',
 });
 
@@ -135,10 +244,42 @@
     productId: undefined,
     productModelId: undefined,
     productName: "",
-    productModelName: "",
-    description: '',
+    model: "",
+    unit: "",
+    licensePlateNo: "",
+    grossWeight: undefined,
+    tareWeight: undefined,
+    netWeight: undefined,
+    weighingDate: undefined,
+    weighingOperator: "",
+    remark: '',
   };
   isShow.value = false;
+};
+
+// 鍑�閲� = 姣涢噸 - 鐨噸
+const computeNetWeight = () => {
+  const { grossWeight, tareWeight } = formState.value;
+  if (grossWeight != null && tareWeight != null) {
+    const net = Number(grossWeight) - Number(tareWeight);
+    const safeNet = Number(net.toFixed(2));
+    const computedNet = safeNet > 0 ? safeNet : 0;
+    const maxNet = ledgerNetWeight.value;
+    if (Number.isFinite(maxNet) && maxNet > 0 && computedNet > maxNet) {
+      const cappedNet = Number(maxNet.toFixed(2));
+      formState.value.netWeight = cappedNet;
+      // 鍚屾姣涢噸锛屼繚鎸侊細鍑�閲� = 姣涢噸 - 鐨噸
+      const tare = Number(tareWeight);
+      if (Number.isFinite(tare)) {
+        formState.value.grossWeight = Number((tare + cappedNet).toFixed(2));
+      }
+      proxy?.$modal?.msgWarning?.(`棰嗙敤鍑�閲嶄笉鑳借秴杩囧彴璐﹀噣閲嶏紙${maxNet.toFixed(2)} 鍚級`);
+      return;
+    }
+    formState.value.netWeight = computedNet;
+  } else {
+    formState.value.netWeight = undefined;
+  }
 };
 
 // 浜у搧閫夋嫨澶勭悊
@@ -169,6 +310,12 @@
         proxy.$modal.msgError("璇烽�夋嫨瑙勬牸");
         return;
       }
+      const maxNet = ledgerNetWeight.value;
+      const usedNet = Number(formState.value.netWeight ?? 0);
+      if (Number.isFinite(maxNet) && maxNet > 0 && Number.isFinite(usedNet) && usedNet > maxNet) {
+        proxy.$modal.msgError(`棰嗙敤鍑�閲嶄笉鑳借秴杩囧彴璐﹀噣閲嶏紙${maxNet.toFixed(2)} 鍚級`);
+        return;
+      }
       if (props.type === 'qualified') {
         subtractStockInventory(formState.value).then(res => {
           // 鍏抽棴妯℃�佹

--
Gitblit v1.9.3