From 25cc86fd8a2fb3b2bb6b385cba0adaf89ff3dcdc Mon Sep 17 00:00:00 2001
From: chenlu <1320612696@qq.com>
Date: 星期四, 18 十二月 2025 16:39:32 +0800
Subject: [PATCH] 流程卡进度打印部分代码

---
 north-glass-erp/northglass-erp/src/views/pp/processCard/PrintCustomLabelSemi2.vue |  171 +++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 124 insertions(+), 47 deletions(-)

diff --git a/north-glass-erp/northglass-erp/src/views/pp/processCard/PrintCustomLabelSemi2.vue b/north-glass-erp/northglass-erp/src/views/pp/processCard/PrintCustomLabelSemi2.vue
index 04e8503..a6e3674 100644
--- a/north-glass-erp/northglass-erp/src/views/pp/processCard/PrintCustomLabelSemi2.vue
+++ b/north-glass-erp/northglass-erp/src/views/pp/processCard/PrintCustomLabelSemi2.vue
@@ -19,6 +19,8 @@
 let dataList = ref([])
 let list = ref([])
 let lastList=ref([])
+let projectNo = ref([])
+let type = ref([])
 
 let filterData = ref({})
 
@@ -27,35 +29,80 @@
 })
 
 
+
 const {currentRoute} = useRouter()
 const route = currentRoute.value
-data.value.printList = JSON.parse(route.query.printList)
-const type = route.query.type
 const faceOrientation = route.query.faceOrientation
 const lableType = route.query.lableType
+const printType=route.query.printType
+projectNo.value = route.query.projectNo
+type.value = route.query.type
 
 onMounted(() => {
-  request.post(`/processCard/getSelectPrintLabel1`,data.value).then((res) => {
-    if (res.code == 200) {
-      produceList.value = deepClone(res.data.data)
-      for (let i = 0; i < produceList.value.length; i++) {
-        let count= produceList.value[i].data.length
-        for (let j = 0; j < count; j++) {
-          for (let k = 0; k < produceList.value[i].data[j].quantity; k++){
-            labelList.value.push(produceList.value[i].data[j])
-          }
-
-        }
+  if (localStorage.getItem('hasRefreshed')=="false") {
+    localStorage.setItem('hasRefreshed', 'true');
+    location.reload();
+  }else{
+    localStorage.setItem('hasRefreshed', 'false');
+  }
+  //宸ョ▼鎵撳嵃鎴愬搧鏍囩
+  if(projectNo.value!=null){
+    request.post(`/processCard/getSelectPrintLabel/${projectNo.value}/${type.value}`).then((res) => {
+      if (res.code == 200) {
+        labelList.value = deepClone(res.data.data)
+      } else {
+        ElMessage.warning(res.msg)
+        router.push("/login")
       }
-    } else {
-      ElMessage.warning(res.msg)
-      router.push("/login")
-    }
-  })
+    })
+
+  }else{
+    data.value.printList = JSON.parse(route.query.printList)
+    //娴佺▼鍗$紪杈戞墦鍗版爣绛� 甯稿窞
+    if (printType == 1) {
+      request.post(`/processCard/getSelectPrintLabel1`, data.value).then((res) => {
+        if (res.code == 200) {
+          produceList.value = deepClone(res.data.data)
+          for (let i = 0; i < produceList.value.length; i++) {
+            let count = produceList.value[i].data.length
+            for (let j = 0; j < count; j++) {
+              for (let k = 0; k < produceList.value[i].data[j].quantity; k++) {
+                labelList.value.push(produceList.value[i].data[j])
+              }
+
+            }
+          }
+        } else {
+          ElMessage.warning(res.msg)
+          router.push("/login")
+        }
+      })
 
     }
+    //鏄庣粏鍒嗘灦鎵撳嵃鏍囩 甯稿窞
+    else if(printType==2){
+      request.post(`/processCard/getSelectPrintLabelDetails`, data.value).then((res) => {
+        if (res.code == 200) {
+          produceList.value = deepClone(res.data.data)
+          for (let i = 0; i < produceList.value.length; i++) {
+            let count = produceList.value[i].data.length
+            for (let j = 0; j < count; j++) {
+              for (let k = 0; k < produceList.value[i].data[j].quantity; k++) {
+                labelList.value.push(produceList.value[i].data[j])
+              }
 
-)
+            }
+          }
+        } else {
+          ElMessage.warning(res.msg)
+          router.push("/login")
+        }
+      })
+    }
+  }
+
+
+})
 
 
 // 鎵撳嵃鏂规硶
@@ -105,27 +152,49 @@
   <div id="printFlowCard" >
     <template v-for="(item,id) in labelList">
     <div id="entirety" >
-      <div class="row1">
+
+      <div class="row1" v-if="item.customer_name!==undefined">
         <span>{{ item.customer_name }}</span>&nbsp;
         <span>{{ item.order_id }}</span>&nbsp;
-        <span v-if="item.process.includes('澶硅兌')">鑳剁墖</span>
+        <span v-if="item.process.includes('澶硅兌')||item.process.includes('澶瑰眰')">鑳剁墖</span>
         <span v-else-if="item.process.includes('涓┖')">涓┖</span>
         <span v-else-if="item.process.includes('鐧惧彾')">鐧惧彾</span>
         <span v-else></span>
       </div>
-      <div class="row2">
+
+
+
+      <div class="row2" v-if="item.customer_name!==undefined">
         <span>{{item.project}}</span>&nbsp;
         <span>{{ item.building_number }}</span>
         <span v-if="item.bend_radius!=null">R={{item.bend_radius}}</span>
       </div>
-      <div class="row3" v-if="item.other_columns!=null&&(JSON.parse(item.other_columns).S02!=null)"> <span>{{JSON.parse(item.other_columns).S02}}={{item.quantity}}</span>&nbsp;</div>
-      <div class="row3" v-else><span>{{Math.round(item.width)}}x{{Math.round(item.height)}}={{item.quantity}}</span></div>
-      <div class="row5">
+      <div class="row3" v-if="item.other_columns!=null&&(JSON.parse(item.other_columns).S02!=null)">
+        <span v-if="item.heat_layout_id!==undefined && company.showDeliveryCreator"  style="font-size: 7pt;">
+          ({{ item.stock_id }}) {{ item.heat_layout_id }}/{{ item.heat_layout_sort }}
+        </span>
+        <span v-if="item.stock_id!==undefined && !company.showDeliveryCreator"  style="font-size: 7pt">
+              {{ item.stock_id }}/{{ item.polys_id }}
+        </span>
+        {{JSON.parse(item.other_columns).S02}}={{item.quantity}}
+
+      </div>
+      <div class="row3" v-else>
+         <span v-if="item.heat_layout_id!==undefined && company.showDeliveryCreator"  style="font-size: 7pt;">
+          ({{ item.stock_id }}) {{ item.heat_layout_id }}/{{ item.heat_layout_sort }}
+        </span>
+        <span v-if="item.stock_id!==undefined && !company.showDeliveryCreator"  style="font-size: 7pt">
+              {{ item.stock_id }}/{{ item.polys_id }}
+        </span>
+        {{Math.round(item.width)}}x{{Math.round(item.height)}}={{item.quantity}}
+      </div>
+      <div class="row5" v-if="item.customer_name!==undefined">
         <span>{{item.glass_child}}</span>&nbsp;
         <span>{{item.processing_note}}</span>
       </div>
     </div>
-      <div style="width: 20px" v-if="id%2===0"></div>
+      <div style="width: 19px" v-if="id%2===0"></div>
+      <div class="element-to-break-after" style="width: 1px" v-if="id%2===1"></div>
     </template>
   </div>
 
@@ -163,7 +232,7 @@
   height: 35px;
 }
 .row1 span {
-  font-size: 15pt;
+  font-size: 14pt;
 }
 .row2 {
   font-size: 12pt;
@@ -171,7 +240,7 @@
   height: 35px;
 }
 .row2 span {
-  font-size: 14pt;
+  font-size: 17pt;
 }
 span {
   font-size: 12pt;
@@ -181,12 +250,12 @@
 .row3 {
   margin-top: -5px;
   height: 35px;
-  font-size: 22pt;
+  font-size: 20pt;
   font-weight: bolder;
   line-height: 35px;
 }
 .row3 span{
-  font-size: 22pt;
+  font-size: 24pt;
 }
 
 .row5 {
@@ -195,29 +264,37 @@
   font-size: 14pt;
 }
 .row5 span {
-  font-size: 14pt;
+  font-size: 16pt;
 }
 
 .row6 {
-  height: 20px;
+  height: 25px;
   font-weight: bold;
   font-size: 10pt;
 }
-
-
-
-
-
-@media print {
-  div {
-    page-break-inside: avoid;
-  }
-  @page {
-    size: auto;  /* auto is the initial value */
-    margin: 13mm 4mm 0mm 4mm;  /* this affects the margin in the printer settings */
-
-  }
-
+.row6 span {
+  font-size: 16pt;
 }
 
+.cell{
+  position: absolute;
+  font-weight: bold;
+  margin-left: 5px;
+  margin-top: 0px;
+}
+
+.cell1{
+  position: absolute;
+  font-weight: bold;
+  margin-left: 225px;
+  margin-top: -30px;
+}
+
+
+.element-to-break-after {
+  page-break-after: always;
+}
+
+
+
 </style>
\ No newline at end of file

--
Gitblit v1.8.0