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/report/index.vue |  191 +++++++++++++++++++++++++++++++++++++----------
 1 files changed, 148 insertions(+), 43 deletions(-)

diff --git a/src/pages/production/twist/report/index.vue b/src/pages/production/twist/report/index.vue
index db4ab66..f100b78 100644
--- a/src/pages/production/twist/report/index.vue
+++ b/src/pages/production/twist/report/index.vue
@@ -1,26 +1,28 @@
 <template>
-  <view class="page pt-2">
-    <z-paging ref="paging" refresher-only class="list">
+  <view class="list">
+    <z-paging ref="pagingRef" v-model="twistReportList" :fixed="false" @query="getTwistReportList">
       <template #top>
         <CardTitle title="鎶ュ伐淇℃伅" :hideAction="true" :full="false" @action="addReport" />
       </template>
-      <wd-card v-for="(item, index) in 6" type="rectangle" custom-class="round">
+      <wd-card v-for="item in twistReportList" :key="item.id" type="rectangle" custom-class="round">
         <template #title>
           <view class="flex justify-between">
             <view>
               <wd-icon name="user" color="#0D867F"></wd-icon>
               <text class="text-[#0D867F] ml-2 font-medium">鐢熶骇浜�</text>
-              <text class="text-[#333333] ml-2">鏂瑰厗鐜�</text>
+              <text class="text-[#333333] ml-2">{{ item.productUser }}</text>
             </view>
             <view class="text-[#A8A8A8]" @click="toEdit">缂栬緫</view>
           </view>
         </template>
-        <ProductionCard :data="cardAttr" />
+        <ProductionCard :data="cardAttr" :value="item" />
         <template #footer>
-          <wd-button size="small" plain @click="toCheck">鑷</wd-button>
+          <wd-button size="small" plain style="margin-right: 10px" @click="toAttachment(item)">
+            闄勪欢
+          </wd-button>
+          <wd-button size="small" plain @click="handleSelfCheck(item.id)">鑷</wd-button>
         </template>
       </wd-card>
-      <wd-loadmore custom-class="loadmore" state="loading" />
     </z-paging>
 
     <wd-popup v-model="dialog.visible" position="bottom" custom-class="yl-popup">
@@ -28,7 +30,16 @@
         <wd-button type="text" @click="cancel">鍙栨秷</wd-button>
         <wd-button type="text" @click="submit">纭畾</wd-button>
       </view>
-      <TwistForm />
+      <TwistForm ref="twistFormRef" />
+    </wd-popup>
+    <wd-popup v-model="drawFormRef.visible" position="bottom" custom-class="yl-popup">
+      <Draw
+        :single-regulation-info-array="drawData.singleRegulationInfoArray"
+        :steel-regulation-info="drawData.steelRegulationInfo"
+        :reel-tooling-info="drawData.reelToolingInfo"
+        :wire-id="drawData.wireId"
+        @close="handleDrawClose"
+      />
     </wd-popup>
     <wd-toast />
   </view>
@@ -38,50 +49,82 @@
 import TwistForm from "./form.vue";
 import { useToast } from "wot-design-uni";
 import ProductionCard from "../../components/ProductionCard.vue";
+import { onLoad } from "@dcloudio/uni-app";
+import { ref, reactive } from "vue";
+import ManageApi from "@/api/product/manage";
+import TwistApi from "@/api/product/twist";
+import Draw from "./draw.vue";
 
+const drawFormRef = reactive({
+  visible: false,
+});
+
+// 澶勭悊draw缁勪欢鍏抽棴浜嬩欢
+const handleDrawClose = () => {
+  // 纭繚寮圭獥琚纭叧闂�
+  drawFormRef.visible = false;
+};
+const pagingRef = ref();
+const paramsId = ref();
+const twistFormRef = ref();
 const toast = useToast();
 const dialog = reactive({
   visible: false,
 });
+const drawData = ref({
+  singleRegulationInfoArray: [],
+  steelRegulationInfo: {
+    model: "",
+    twistedDirection: "",
+    outerDiameter: "",
+    scratch: "",
+    oilStain: "",
+  },
+  reelToolingInfo: {
+    nutFixed: "",
+    sidePlateFlat: "",
+    centerPlateFlat: "",
+    paintQuality: "",
+    burrCrack: "",
+    edgeBlunt: "",
+    woodMold: "",
+    weldQuality: "",
+  },
+  wireId: "",
+});
 
 const cardAttr = ref<any[]>([
   {
-    label: "鍚堝悓鍙�",
-    value: "ht2921246",
+    label: "棰嗙敤鏉嗗彿",
+    prop: "poleNumber",
   },
   {
-    label: "鐘舵��",
-    value: "-----",
+    label: "鏉嗛噸(kg)",
+    prop: "poleWeight",
   },
   {
-    label: "瀹㈡埛鍚嶇О",
-    value: "澶忓織璞�",
+    label: "鍗曚笣鐩樺彿",
+    prop: "monofilamentNumber",
   },
   {
-    label: "鏈哄彴",
-    value: "-----",
-  },
-  {
-    label: "瑙勬牸鍨嬪彿",
-    value: "2921246",
-  },
-  {
-    label: "宸茬敓浜ф暟閲�",
-    value: "0",
+    label: "瀹為檯閲嶉噺(kg)",
+    prop: "actuallyWeight",
   },
   {
     label: "鐩橀暱(m)",
-    value: "292",
+    prop: "oneLength",
   },
   {
-    label: "璁″垝鏁伴噺",
-    value: "100",
+    label: "鐞嗚閲嶉噺(kg)",
+    prop: "theoryWeight",
   },
   {
-    label: "璐ㄩ噺杩芥函鍙�",
-    value: "JX-1838",
+    label: "瑙勬牸鍨嬪彿",
+    prop: "model",
   },
 ]);
+
+const twistReportList = ref<any[]>([]);
 
 const toEdit = () => {
   uni.navigateTo({
@@ -89,13 +132,19 @@
   });
 };
 
-const addReport = () => {
+const addReport = async () => {
   dialog.visible = true;
+  // 鎵撳紑鏂板寮圭獥鏃惰嚜鍔ㄦ墽琛�
+  // await showDrawPopup();
 };
 
-const submit = () => {
-  toast.show("鎻愪氦");
-  dialog.visible = false;
+const submit = async () => {
+  const isSuccess = await twistFormRef.value.submit();
+  dialog.visible = !isSuccess; // 濡傛灉鎻愪氦鎴愬姛锛屽叧闂脊绐�
+  if (isSuccess) {
+    // 鎻愪氦鎴愬姛鍚庢墽琛�
+    // showDrawPopup();
+  }
 };
 
 const cancel = () => {
@@ -103,24 +152,80 @@
   dialog.visible = false;
 };
 
-const toCheck = () => {
+const toAttachment = (item: any) => {
   uni.navigateTo({
-    url: "/pages/production/twist/selfInspect/index",
+    url: "/pages/production/twist/attachment/index",
+    success: () => {
+      // 椤甸潰璺宠浆鎴愬姛鍚庡彂閫佷簨浠朵紶閫掓暟鎹�
+      uni.$emit("detailData", item);
+    },
   });
 };
+
+const showDrawPopup = async () => {
+  try {
+    const { data } = await TwistApi.querySingleDishInspection({
+      id: paramsId.value,
+    });
+    // 閫傞厤涓嶅悓鐨勬暟鎹粨鏋勮繑鍥炴牸寮�
+    const responseData = data.data || data;
+    if (responseData && responseData.singleWirePrePareInfoVo) {
+      const info = responseData.singleWirePrePareInfoVo;
+      drawData.value = {
+        singleRegulationInfoArray: info.singleRegulationInfoArray || [],
+        steelRegulationInfo: info.steelRegulationInfo || {},
+        reelToolingInfo: info.reelToolingInfo || {},
+        wireId: paramsId.value,
+      };
+      // 鏄剧ずDraw寮圭獥
+      drawFormRef.visible = true;
+      toast.success("璇峰~鍐欓鐢ㄤ俊鎭�!");
+    } else {
+      // toast.error("宸插瓨鍦ㄩ鐢ㄤ俊鎭�,鏃犻渶濉姤!");
+    }
+  } catch (error) {
+    console.error("鑾峰彇棰嗙敤淇℃伅澶辫触:", error);
+    toast.error("鑾峰彇淇℃伅澶辫触锛岃閲嶈瘯");
+  }
+};
+
+const handleSelfCheck = (id: string) => {
+  console.log("鎵ц鑷鎿嶄綔锛孖D:", id);
+  uni.showToast({
+    title: "鑷鍔熻兘寮�鍙戜腑",
+    icon: "none",
+  });
+};
+
+// 淇濈暀鍘熸湁鐨刢onfirm鍑芥暟锛岀敤浜庡叾浠栧湴鏂硅皟鐢�
+// const confirm = async () => {
+//   await showDrawPopup();
+// };
+
+// 鑾峰彇鎷変笣鎶ュ伐鍒楄〃
+const getTwistReportList = async () => {
+  const { data } = await ManageApi.getReportList({
+    wireId: paramsId.value,
+    type: "缁炵嚎",
+  });
+  pagingRef.value.complete(data);
+};
+
+onLoad((options: any) => {
+  paramsId.value = options.id;
+  showDrawPopup();
+});
 </script>
 
 <style lang="scss" scoped>
-.page {
+.list {
+  height: calc(100vh - 80px);
+  padding: 12px;
   background: #f3f9f8;
 
-  .list {
-    margin: 12px;
-
-    :deep() {
-      .round {
-        border-radius: 4px;
-      }
+  :deep() {
+    .round {
+      border-radius: 4px;
     }
   }
 }

--
Gitblit v1.9.3