From 072b7c1fa983cbfa9dc5b311fd815c8d9142ee33 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期五, 15 五月 2026 13:25:57 +0800
Subject: [PATCH] 进销存pro 1.计量器具台账不要检定周期了,不要安装位置,加一个快到期提醒

---
 src/views/productionManagement/productionProcess/index.vue |   81 +++++++++++++++++++++++++++++++---------
 1 files changed, 62 insertions(+), 19 deletions(-)

diff --git a/src/views/productionManagement/productionProcess/index.vue b/src/views/productionManagement/productionProcess/index.vue
index ae1732f..747b8de 100644
--- a/src/views/productionManagement/productionProcess/index.vue
+++ b/src/views/productionManagement/productionProcess/index.vue
@@ -52,6 +52,11 @@
                         :type="process.isQuality ? 'warning' : 'info'">
                   {{ process.isQuality ? '璐ㄦ' : '闈炶川妫�' }}
                 </el-tag>
+                <el-tag size="small"
+                        style="margin-left: 8px"
+                        :type="process.isProduction ? 'warning' : 'info'">
+                  {{ process.isProduction ? '鐢熶骇' : '涓嶇敓浜�' }}
+                </el-tag>
                 <el-tag v-if="process.type !== null && process.type !== undefined"
                         size="small"
                         :type="process.type == 1 ? 'primary' : 'success'"
@@ -123,6 +128,10 @@
                       prop="isQuality">
           <el-switch v-model="processForm.isQuality" />
         </el-form-item>
+        <el-form-item label="鏄惁鐢熶骇"
+                      prop="isProduction">
+          <el-switch v-model="processForm.isProduction" />
+        </el-form-item>
         <el-form-item label="璁¤垂绫诲瀷"
                       prop="type">
           <el-radio-group v-model="processForm.type">
@@ -153,9 +162,9 @@
       </el-form>
       <template #footer>
         <span class="dialog-footer">
-          <el-button @click="processDialogVisible = false">鍙栨秷</el-button>
           <el-button type="primary"
                      @click="handleProcessSubmit">纭畾</el-button>
+          <el-button @click="processDialogVisible = false">鍙栨秷</el-button>
         </span>
       </template>
     </el-dialog>
@@ -234,6 +243,7 @@
             </el-form-item>
             <el-form-item label="鏍囧噯鍊�">
               <el-input v-model="selectedParam.standardValue"
+                        @input="val => onStandardValueInput(val, selectedParam)"
                         placeholder="璇疯緭鍏ラ粯璁ゅ��" />
             </el-form-item>
           </el-form>
@@ -243,10 +253,10 @@
       </div>
       <template #footer>
         <span class="dialog-footer">
-          <el-button @click="paramDialogVisible = false">鍙栨秷</el-button>
           <el-button type="primary"
                      :disabled="!selectedParam"
                      @click="handleParamSubmit">纭畾</el-button>
+          <el-button @click="paramDialogVisible = false">鍙栨秷</el-button>
         </span>
       </template>
     </el-dialog>
@@ -264,14 +274,15 @@
         <el-form-item label="鏍囧噯鍊�"
                       prop="standardValue">
           <el-input v-model="editParamForm.standardValue"
+                    @input="val => onStandardValueInput(val, editParamForm)"
                     placeholder="璇疯緭鍏ユ爣鍑嗗��" />
         </el-form-item>
       </el-form>
       <template #footer>
         <span class="dialog-footer">
-          <el-button @click="editParamDialogVisible = false">鍙栨秷</el-button>
           <el-button type="primary"
                      @click="handleEditParamSubmit">纭畾</el-button>
+          <el-button @click="editParamDialogVisible = false">鍙栨秷</el-button>
         </span>
       </template>
     </el-dialog>
@@ -279,7 +290,7 @@
 </template>
 
 <script setup>
-  import { ref, reactive, onMounted } from "vue";
+  import { ref, reactive, computed, onMounted } from "vue";
   import { ElMessage, ElMessageBox } from "element-plus";
   import { Plus, Edit, Delete, Search } from "@element-plus/icons-vue";
   import PIMTable from "@/components/PIMTable/PIMTable.vue";
@@ -304,8 +315,19 @@
   const processLoading = ref(false);
   const deviceOptions = ref([]);
 
-  // 鍙傛暟鍒楄〃鏁版嵁
-  const paramList = ref([]);
+  // 宸ュ簭宸查�夊弬鏁拌〃鏍煎垎椤碉紙鎺ュ彛涓�娆¤繑鍥炲叏閲忥級
+  const paramPage2 = ref({
+    current: 1,
+    size: 10,
+    total: 0,
+  });
+  const paramListRaw = ref([]);
+  const paramList = computed(() => {
+    const all = paramListRaw.value;
+    const { current, size } = paramPage2.value;
+    const start = (current - 1) * size;
+    return all.slice(start, start + size);
+  });
   const paramLoading = ref(false);
 
   // 鏁版嵁瀛楀吀
@@ -321,6 +343,7 @@
     name: "",
     salaryQuota: null,
     isQuality: false,
+    isProduction: false,
     remark: "",
     deviceLedgerId: null,
     type: 0,
@@ -371,7 +394,18 @@
     technologyParamId: null,
     paramName: "",
     standardValue: null,
+    paramType: null,
   });
+
+  const onStandardValueInput = (val, target) => {
+    const data = target.value || target;
+    const type = data.paramType;
+    if (type === 1) {
+      // 鏁板�兼牸寮忥細涓嶈兘杈撳叆涓枃鎴栬嫳鏂囧瓧绗�
+      data.standardValue = val.replace(/[a-zA-Z\u4e00-\u9fa5]/g, "");
+    }
+  };
+
   const editParamRules = {
     standardValue: [
       {
@@ -382,6 +416,12 @@
           if (value === null || value === undefined || value === "") {
             callback(new Error("璇疯緭鍏ユ爣鍑嗗��"));
           } else {
+            const type = editParamForm.paramType;
+            if (type === 1 && value) {
+              if (/[a-zA-Z\u4e00-\u9fa5]/.test(value)) {
+                return callback(new Error("鏁板�兼牸寮忎笉鑳藉寘鍚腑鑻辨枃瀛楃"));
+              }
+            }
             callback();
           }
         },
@@ -475,21 +515,21 @@
     }
   };
 
-  const paramPage2 = ref({
-    current: 1,
-    size: 10,
-    total: 0,
-  });
-
   // 鑾峰彇鍙傛暟鍒楄〃
   const getParamList = processId => {
     paramLoading.value = true;
-    console.log(paramPage2.value, "paramPage2.value");
     getProcessParamList({ technologyOperationId: processId })
       .then(res => {
-        console.log(res, "res");
-        paramList.value = res.data || [];
-        paramPage2.value.total = 0;
+        const list = res.data || [];
+        paramListRaw.value = Array.isArray(list) ? list : [];
+        paramPage2.value.total = paramListRaw.value.length;
+        const maxPage = Math.max(
+          1,
+          Math.ceil(paramPage2.value.total / paramPage2.value.size) || 1
+        );
+        if (paramPage2.value.current > maxPage) {
+          paramPage2.value.current = maxPage;
+        }
       })
       .catch(() => {
         ElMessage.error("鑾峰彇鍙傛暟鍒楄〃澶辫触");
@@ -502,6 +542,7 @@
   // 閫夋嫨宸ュ簭
   const selectProcess = process => {
     selectedProcess.value = process;
+    paramPage2.value.current = 1;
     getParamList(process.id);
   };
 
@@ -513,6 +554,7 @@
     processForm.name = "";
     processForm.salaryQuota = null;
     processForm.isQuality = false;
+    processForm.isProduction = false;
     processForm.remark = "";
     processForm.deviceLedgerId = null;
     processForm.type = 0;
@@ -526,6 +568,7 @@
     processForm.name = process.name;
     processForm.salaryQuota = process.salaryQuota;
     processForm.isQuality = !!process.isQuality;
+    processForm.isProduction = !!process.isProduction;
     processForm.remark = process.remark || "";
     processForm.deviceLedgerId = Number(process.deviceLedgerId);
     processForm.type = process.type;
@@ -544,7 +587,8 @@
           getProcessList();
           if (selectedProcess.value?.id === process.id) {
             selectedProcess.value = null;
-            paramList.value = [];
+            paramListRaw.value = [];
+            paramPage2.value.total = 0;
           }
         })
         .catch(() => {
@@ -692,6 +736,7 @@
     editParamForm.technologyParamId = row.technologyParamId;
     editParamForm.paramName = row.paramName;
     editParamForm.standardValue = row.standardValue;
+    editParamForm.paramType = row.paramType;
     editParamDialogVisible.value = true;
   };
 
@@ -732,10 +777,8 @@
   };
 
   const handleParamPagination = obj => {
-    console.log(obj, "obj");
     paramPage2.value.current = obj.page;
     paramPage2.value.size = obj.limit;
-    getParamList(selectedProcess.value.id);
   };
 
   // 鑾峰彇鏁版嵁瀛楀吀

--
Gitblit v1.9.3