From 01a4f6341f6fe4806f45cf7a4c7b3bc450a6a0e0 Mon Sep 17 00:00:00 2001
From: 云 <2163098428@qq.com>
Date: 星期四, 07 五月 2026 16:08:53 +0800
Subject: [PATCH] feat(AIChatSidebar): 添加文件上传预览和消息中文件显示功能

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

diff --git a/src/views/productionManagement/productionProcess/index.vue b/src/views/productionManagement/productionProcess/index.vue
index ae1732f..216e73b 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,8 @@
       </el-form>
       <template #footer>
         <span class="dialog-footer">
+          <el-button type="primary" @click="handleProcessSubmit">纭畾</el-button>
           <el-button @click="processDialogVisible = false">鍙栨秷</el-button>
-          <el-button type="primary"
-                     @click="handleProcessSubmit">纭畾</el-button>
         </span>
       </template>
     </el-dialog>
@@ -243,10 +251,8 @@
       </div>
       <template #footer>
         <span class="dialog-footer">
+          <el-button type="primary" :disabled="!selectedParam" @click="handleParamSubmit">纭畾</el-button>
           <el-button @click="paramDialogVisible = false">鍙栨秷</el-button>
-          <el-button type="primary"
-                     :disabled="!selectedParam"
-                     @click="handleParamSubmit">纭畾</el-button>
         </span>
       </template>
     </el-dialog>
@@ -279,7 +285,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 +310,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 +338,7 @@
     name: "",
     salaryQuota: null,
     isQuality: false,
+    isProduction: false,
     remark: "",
     deviceLedgerId: null,
     type: 0,
@@ -475,21 +493,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 +520,7 @@
   // 閫夋嫨宸ュ簭
   const selectProcess = process => {
     selectedProcess.value = process;
+    paramPage2.value.current = 1;
     getParamList(process.id);
   };
 
@@ -513,6 +532,7 @@
     processForm.name = "";
     processForm.salaryQuota = null;
     processForm.isQuality = false;
+    processForm.isProduction = false;
     processForm.remark = "";
     processForm.deviceLedgerId = null;
     processForm.type = 0;
@@ -526,6 +546,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 +565,8 @@
           getProcessList();
           if (selectedProcess.value?.id === process.id) {
             selectedProcess.value = null;
-            paramList.value = [];
+            paramListRaw.value = [];
+            paramPage2.value.total = 0;
           }
         })
         .catch(() => {
@@ -732,10 +754,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