From 78c565e37520fad100693c4e298e30e7c916d1bb Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期二, 28 十月 2025 16:21:40 +0800
Subject: [PATCH] fix: 领用二维码异常提示,原材料自检重构

---
 src/pages/production/twist/receive/plate/form.vue |  167 +++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 161 insertions(+), 6 deletions(-)

diff --git a/src/pages/production/twist/receive/plate/form.vue b/src/pages/production/twist/receive/plate/form.vue
index 4a1cf6d..032e5b0 100644
--- a/src/pages/production/twist/receive/plate/form.vue
+++ b/src/pages/production/twist/receive/plate/form.vue
@@ -1,13 +1,15 @@
 <template>
   <wd-form ref="form" :model="model" class="relative form_box">
     <wd-cell-group :border="true">
-      <wd-input
-        v-model="model.diskMaterial"
+      <wd-picker
+        v-model="diskMaterialValue"
+        :columns="diskMaterialOptions"
         label="鐩樺叿绫诲瀷"
         label-width="100px"
         prop="diskMaterial"
+        placeholder="璇烽�夋嫨鐩樺叿绫诲瀷"
         clearable
-        placeholder="璇疯緭鍏ョ洏鍏风被鍨�"
+        @confirm="handleDiskMaterialChange"
       />
       <wd-input
         v-model="model.model"
@@ -41,9 +43,22 @@
 <script setup lang="ts">
 import useFormData from "@/hooks/useFormData";
 import TwistApi from "@/api/product/twist";
+import ManageApi from "@/api/product/manage";
 import { useToast } from "wot-design-uni";
 
+const props = defineProps({
+  mode: {
+    type: String,
+    default: "add",
+  },
+  editData: {
+    type: Object,
+    default: null,
+  },
+});
+
 const emits = defineEmits(["refresh"]);
+const paramsId = ref();
 const toast = useToast();
 const { form: model } = useFormData({
   diskMaterial: undefined, // 鐩樺叿绫诲瀷
@@ -53,22 +68,162 @@
   type: "鐩樺叿",
 });
 
+// 鐢ㄤ簬缂栬緫鏃跺瓨鍌ㄥ畬鏁村垪琛ㄦ暟鎹拰褰撳墠缂栬緫ID
+const allListData = ref<any[]>([]);
+const editId = ref<number>();
+
+// 鐩樺叿绫诲瀷瀛楀吀鏁版嵁
+const diskMaterialOptions = ref<Array<{ label: string; value: string }>>([]);
+const diskMaterialValue = ref("");
+
+// 鍔犺浇鐩樺叿绫诲瀷瀛楀吀鏁版嵁
+const loadDiskMaterialDict = async () => {
+  try {
+    const res = await ManageApi.dictAPI("disk_material");
+    if (res.data && Array.isArray(res.data)) {
+      diskMaterialOptions.value = res.data.map((item: any) => ({
+        label: item.dictLabel || "",
+        value: item.dictValue || "",
+      }));
+    }
+  } catch (error) {
+    console.error("鍔犺浇鐩樺叿绫诲瀷瀛楀吀澶辫触:", error);
+  }
+};
+
+// 澶勭悊鐩樺叿绫诲瀷閫夋嫨
+const handleDiskMaterialChange = (val: any) => {
+  model.diskMaterial = val.value;
+};
+
+// 鐩戝惉 model.diskMaterial 鍙樺寲锛屽悓姝ラ�夋嫨鍣ㄦ樉绀�
+watch(
+  () => model.diskMaterial,
+  (newValue) => {
+    diskMaterialValue.value = newValue || "";
+  },
+  { immediate: true }
+);
+
 const submit = async () => {
-  const { code } = await TwistApi.addStrandedWireDish([model]);
+  const { code } = await TwistApi.addStrandedWireDish([
+    {
+      wireId: paramsId.value,
+      ...model,
+    },
+  ]);
   if (code == 200) {
     toast.success("鏂板鎴愬姛");
     emits("refresh");
     return true;
   }
+  return false;
+};
+
+// 缂栬緫鎻愪氦锛堜篃璧版柊澧炴帴鍙o紝鎻愪氦鏁翠釜鍒楄〃锛�
+const submitEdit = async (list?: any[], id?: number) => {
+  const currentList = list || allListData.value;
+  const currentId = id || editId.value;
+
+  if (!currentId) {
+    toast.error("缂哄皯璁板綍ID");
+    return false;
+  }
+
+  // 鏇存柊鍒楄〃涓搴旂殑鏁版嵁椤�
+  const updatedList = currentList.map((item) => {
+    if (item.id === currentId) {
+      // 淇濈暀鍘熸湁鏁版嵁锛岀劧鍚庢洿鏂颁慨鏀圭殑瀛楁
+      const updatedItem = {
+        ...item, // 鍏堜繚鐣欏師鏈夌殑鎵�鏈夋暟鎹�
+        diskMaterial: model.diskMaterial,
+        model: model.model,
+        amount: model.amount,
+        supplier: model.supplier,
+        type: model.type,
+      };
+      return updatedItem;
+    }
+    return item;
+  });
+
+  // 鎻愪氦鏁翠釜鍒楄〃
+  const { code } = await TwistApi.addStrandedWireDish(updatedList);
+
+  if (code == 200) {
+    toast.success("鏇存柊鎴愬姛");
+    return true;
+  }
+  return false;
+};
+
+// 璁剧疆琛ㄥ崟鏁版嵁锛堢敤浜庣紪杈戞椂鍥炴樉锛�
+const setFormData = (list: any[], currentEditId: number) => {
+  // 瀹夊叏妫�鏌ワ細纭繚list鏄暟缁�
+  if (!Array.isArray(list)) {
+    console.error("setFormData: list 鍙傛暟涓嶆槸鏁扮粍", list);
+    return;
+  }
+
+  // 瀛樺偍瀹屾暣鍒楄〃鏁版嵁
+  allListData.value = list;
+  editId.value = currentEditId;
+
+  // 鎵惧埌褰撳墠缂栬緫椤瑰苟鍥炴樉鍒拌〃鍗�
+  const currentItem = list.find((item) => item.id === currentEditId);
+  if (currentItem) {
+    model.diskMaterial = currentItem.diskMaterial;
+    model.model = currentItem.model;
+    model.amount = currentItem.amount;
+    model.supplier = currentItem.supplier;
+    model.type = currentItem.type || "鐩樺叿";
+    // 璁剧疆鐩樺叿绫诲瀷鐨勫洖鏄惧��
+    diskMaterialValue.value = currentItem.diskMaterial || "";
+  }
+};
+
+onLoad((options: any) => {
+  paramsId.value = options.id;
+});
+
+onMounted(async () => {
+  await loadDiskMaterialDict();
+});
+
+// 鐩戝惉缂栬緫鏁版嵁鍙樺寲锛岃嚜鍔ㄥ洖鏄�
+watch(
+  () => props.editData,
+  (newData) => {
+    if (newData && props.mode === "edit") {
+      model.diskMaterial = newData.diskMaterial || "";
+      model.model = newData.model || "";
+      model.amount = newData.amount || "";
+      model.supplier = newData.supplier || "";
+      model.type = newData.type || "鐩樺叿";
+      diskMaterialValue.value = newData.diskMaterial || "";
+    }
+  },
+  { immediate: true, deep: true }
+);
+
+// 閲嶇疆琛ㄥ崟鏁版嵁
+const resetFormData = () => {
+  model.diskMaterial = undefined;
+  model.model = undefined;
+  model.amount = undefined;
+  model.supplier = undefined;
+  model.type = "鐩樺叿";
+  diskMaterialValue.value = "";
 };
 
 defineExpose({
   submit,
+  submitEdit,
+  setFormData,
+  resetFormData,
 });
 </script>
 <style lang="scss" scoped>
-.form_box {
-}
 .submit_btn {
   position: absolute;
   bottom: 0;

--
Gitblit v1.9.3