From bc365ef47ae4e01754aeadbae26170e11c9bb80e Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期一, 22 六月 2026 16:56:12 +0800
Subject: [PATCH] 新疆马铃薯 1.删除按钮添加操作权限

---
 src/views/qualityManagement/rawMaterialInspection/components/formDia.vue |   63 +++++++++++++++++++++++++++++++
 1 files changed, 62 insertions(+), 1 deletions(-)

diff --git a/src/views/qualityManagement/rawMaterialInspection/components/formDia.vue b/src/views/qualityManagement/rawMaterialInspection/components/formDia.vue
index 8c91275..ff30667 100644
--- a/src/views/qualityManagement/rawMaterialInspection/components/formDia.vue
+++ b/src/views/qualityManagement/rawMaterialInspection/components/formDia.vue
@@ -102,6 +102,33 @@
 
         <el-row :gutter="30">
           <el-col :span="12">
+            <el-form-item label="鍏ュ簱姣斾緥(%)锛�" prop="stockInRatio">
+              <el-input-number :step="0.01" :min="0" :max="100" style="width: 100%" v-model="form.stockInRatio" placeholder="璇疯緭鍏ュ叆搴撴瘮渚�" clearable :precision="2" :disabled="isViewMode" />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="妫�楠岃鍒�" prop="inspectRule">
+              <el-radio-group v-model="form.inspectRule">
+                <el-radio :label="0">鍏ㄦ</el-radio>
+                <el-radio :label="1">鎶芥</el-radio>
+              </el-radio-group>
+            </el-form-item>
+          </el-col>
+          <el-col :span="6" v-if="form.inspectRule === 1">
+            <el-form-item label="鎶芥姣斾緥(%)" prop="sampleRatio">
+              <el-input-number v-model="form.sampleRatio" :min="0.01" :max="100" :precision="2" placeholder="璇疯緭鍏ユ娊妫�姣斾緥" style="width: 100%" @change="calcSampleQuantity" :disabled="isViewMode" />
+            </el-form-item>
+          </el-col>
+          <el-col :span="6" v-if="form.inspectRule === 1">
+            <el-form-item label="鎶芥鏁伴噺" prop="sampleQuantity">
+              <el-input-number v-model="form.sampleQuantity" :min="0" :precision="2" style="width: 100%" disabled />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
             <el-form-item label="妫�娴嬪崟浣嶏細" prop="checkCompany">
               <el-input v-model="form.checkCompany" placeholder="璇疯緭鍏�" clearable :disabled="isViewMode"/>
             </el-form-item>
@@ -193,8 +220,12 @@
     testStandardId: "",
     unit: "",
     quantity: "",
+    stockInRatio: 100.00,
     checkCompany: "",
     checkResult: "",
+    inspectRule: 0,
+    sampleRatio: undefined,
+    sampleQuantity: undefined,
   },
   rules: {
     checkTime: [{required: false, message: "璇疯緭鍏�", trigger: "blur"},],
@@ -207,6 +238,22 @@
     quantity: [{required: false, message: "璇疯緭鍏�", trigger: "blur"}],
     qualifiedQuantity: [{required: false, message: "璇疯緭鍏�", trigger: "blur"}],
     unqualifiedQuantity: [{required: false, message: "璇疯緭鍏�", trigger: "blur"}],
+    stockInRatio: [
+      {
+        validator: (rule, value, callback) => {
+          if (value !== null && value !== undefined && value !== '') {
+            if (value < 0 || value > 100) {
+              callback(new Error('鍏ュ簱姣斾緥鑼冨洿0~100'));
+            } else {
+              callback();
+            }
+          } else {
+            callback();
+          }
+        },
+        trigger: 'blur'
+      }
+    ],
     checkCompany: [{required: false, message: "璇疯緭鍏�", trigger: "blur"}],
     checkResult: [{required: false, message: "璇烽�夋嫨妫�娴嬬粨鏋�", trigger: "change"}],
   },
@@ -221,7 +268,7 @@
     prop: "unit",
   },
   {
-    label: "鏍囧噯鍊�",
+    label: "鍘傚鏍囧噯鍊�",
     prop: "standardValue",
   },
   {
@@ -281,8 +328,12 @@
     testStandardId: "",
     unit: "",
     quantity: "",
+    stockInRatio: 100.00,
     checkCompany: "",
     checkResult: "",
+    inspectRule: 0,
+    sampleRatio: undefined,
+    sampleQuantity: undefined,
   }
   testStandardOptions.value = [];
   tableData.value = [];
@@ -378,6 +429,16 @@
   form.value.unit = modelOptions.value.find(item => item.id == value)?.unit || '';
 }
 
+const calcSampleQuantity = () => {
+  const q = parseFloat(form.value.quantity) || 0;
+  const r = parseFloat(form.value.sampleRatio) || 0;
+  if (q > 0 && r > 0) {
+    form.value.sampleQuantity = Number((q * r / 100).toFixed(2));
+  } else {
+    form.value.sampleQuantity = undefined;
+  }
+};
+
 const findNodeById = (nodes, productId) => {
   for (let i = 0; i < nodes.length; i++) {
     if (nodes[i].value === productId) {

--
Gitblit v1.9.3