From d2d931816da9f6de4da1f3a7f3f6e596128c6f14 Mon Sep 17 00:00:00 2001
From: buhuazhen <hua100783@gmail.com>
Date: 星期五, 13 三月 2026 17:10:51 +0800
Subject: [PATCH] style(views): 统一检测项目对话框输入框宽度并居中表单

---
 src/views/inventoryManagement/stockManagement/Subtract.vue |  137 ++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 121 insertions(+), 16 deletions(-)

diff --git a/src/views/inventoryManagement/stockManagement/Subtract.vue b/src/views/inventoryManagement/stockManagement/Subtract.vue
index bc6c516..d23c974 100644
--- a/src/views/inventoryManagement/stockManagement/Subtract.vue
+++ b/src/views/inventoryManagement/stockManagement/Subtract.vue
@@ -38,10 +38,71 @@
         </el-form-item>
 
         <el-form-item
-            label="鏁伴噺"
-            prop="qualitity"
+            label="杞︾墝鍙�"
+            prop="licensePlateNo"
         >
-          <el-input-number v-model="formState.qualitity" :step="1" :min="0" style="width: 100%" />
+          <el-input v-model="formState.licensePlateNo" />
+        </el-form-item>
+
+        <el-form-item
+            label="姣涢噸(鍚�)"
+            prop="grossWeight"
+        >
+          <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"
+        >
+          <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"
+        >
+          <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"
+        >
+          <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"
+        >
+          <el-input v-model="formState.weighingOperator" />
         </el-form-item>
 
         <el-form-item label="澶囨敞" prop="remark">
@@ -66,9 +127,10 @@
 </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";
 
 const props = defineProps({
   visible: {
@@ -78,7 +140,12 @@
   record: {
     type: Object,
     default: () => {},
-  }
+  },
+  type: {
+    type: String,
+    required: true,
+    default: 'qualified',
+  },
 });
 
 const emit = defineEmits(['update:visible', 'completed']);
@@ -87,10 +154,13 @@
   initFormData()
 })
 
+const isRawMaterial = computed(() => {
+  return props.record.parentName === '鍘熸潗鏂�';
+})
+
 const initFormData = () => {
   if (props.record) {
     formState.value = {
-      ...formState.value,
       ...props.record,
     }
   }
@@ -103,7 +173,13 @@
   productName: "",
   model: "",
   unit: "",
-  qualitity: 0,
+  // 杩囩鐩稿叧瀛楁
+  licensePlateNo: "",
+  grossWeight: undefined,
+  tareWeight: undefined,
+  netWeight: undefined,
+  weighingDate: undefined,
+  weighingOperator: "",
   remark: '',
 });
 
@@ -126,10 +202,29 @@
     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));
+    formState.value.netWeight = safeNet > 0 ? safeNet : 0;
+  } else {
+    formState.value.netWeight = undefined;
+  }
 };
 
 // 浜у搧閫夋嫨澶勭悊
@@ -160,13 +255,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