From b02cd77eb78d973c1eb11ebf03d7d5d71b02aa65 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期二, 09 十二月 2025 10:26:53 +0800
Subject: [PATCH] 1.南洋电缆小数点修改

---
 src/views/procurementManagement/invoiceEntry/components/Modal.vue |   80 +++++++++++++++++++++++++++------------
 1 files changed, 55 insertions(+), 25 deletions(-)

diff --git a/src/views/procurementManagement/invoiceEntry/components/Modal.vue b/src/views/procurementManagement/invoiceEntry/components/Modal.vue
index 4c19cfd..1b8983c 100644
--- a/src/views/procurementManagement/invoiceEntry/components/Modal.vue
+++ b/src/views/procurementManagement/invoiceEntry/components/Modal.vue
@@ -54,13 +54,11 @@
         </el-col>
         <el-col :span="12">
           <el-form-item label="鍙戠エ閲戦(鍏�)锛�" prop="invoiceAmount">
-            <el-input
-              type="number"
-              :step="0.01"
-              :min="0"
+            <el-input-number :step="0.01" :min="0" style="width: 100%"
               v-model="form.invoiceAmount"
               placeholder="鑷姩濉厖"
               clearable
+              :disabled="true"
             />
           </el-form-item>
         </el-col>
@@ -80,6 +78,8 @@
               style="width: 100%"
               v-model="form.entryDate"
               type="date"
+              value-format="YYYY-MM-DD"
+              format="YYYY-MM-DD"
               clearable
             />
           </el-form-item>
@@ -106,6 +106,8 @@
               style="width: 100%"
               v-model="form.enterDate"
               type="date"
+              value-format="YYYY-MM-DD"
+              format="YYYY-MM-DD"
               clearable
             />
           </el-form-item>
@@ -116,12 +118,14 @@
         rowKey="id"
         :column="columns"
         :tableData="form.productData"
+				:summaryMethod="summarizeChildrenTable"
+				:isShowSummary="true"
         height="auto"
       >
         <template #ticketsNumRef="{ row }">
           <el-input-number
             v-model="row.ticketsNum"
-            placeholder="璇烽�夋嫨"
+            placeholder="璇疯緭鍏�"
             :min="0"
             :step="0.1"
             clearable
@@ -132,7 +136,7 @@
         <template #ticketsAmountRef="{ row }">
           <el-input-number
             v-model="row.ticketsAmount"
-            placeholder="璇烽�夋嫨"
+            placeholder="璇疯緭鍏�"
             :min="0"
             :step="0.1"
             clearable
@@ -143,16 +147,17 @@
       </PIMTable>
     </el-form>
     <template #footer>
+			<el-button type="primary" :loading="modalLoading" @click="submitForm">
+				{{ modalOptions.confirmText }}
+			</el-button>
       <el-button @click="closeModal">{{ modalOptions.cancelText }}</el-button>
-      <el-button type="primary" :loading="modalLoading" @click="submitForm">
-        {{ modalOptions.confirmText }}
-      </el-button>
     </template>
   </el-dialog>
 </template>
 
 <script setup>
 import { ref, getCurrentInstance } from "vue";
+import { defineEmits } from 'vue';
 import { useModal } from "@/hooks/useModal";
 import useFormData from "@/hooks/useFormData";
 import FileUpload from "@/components/Upload/FileUpload.vue";
@@ -192,8 +197,7 @@
 
 const rules = ref({
   invoiceNumber: [
-    { required: true, message: "璇疯緭鍏ュ彂绁ㄥ彿", trigger: "blur" },
-    { type: "string" },
+    { required: false, message: "璇疯緭鍏ュ彂绁ㄥ彿", trigger: "blur" },
   ],
   invoiceAmount: [
     { required: true, message: "璇疯緭鍏ュ彂绁ㄩ噾棰�", trigger: "blur" },
@@ -214,14 +218,18 @@
   title: "鏉ョエ鐧昏",
 });
 
+const emit = defineEmits(['refreshList']);
+
 const columns = [
   {
     label: "浜у搧澶х被",
     prop: "productCategory",
+		width: 120,
   },
   {
     label: "瑙勬牸鍨嬪彿",
     prop: "specificationModel",
+		width: 120,
   },
   {
     label: "鍗曚綅",
@@ -248,7 +256,7 @@
     prop: "taxInclusiveUnitPrice",
     width: 150,
     formatData: (val) => {
-      return val ? parseFloat(val).toFixed(2) : 0;
+      return val ? parseFloat(val).toFixed(5) : 0;
     },
   },
   {
@@ -256,7 +264,7 @@
     prop: "taxInclusiveTotalPrice",
     width: 150,
     formatData: (val) => {
-      return parseFloat(val).toFixed(2) ?? 0;
+      return parseFloat(val).toFixed(5) ?? 0;
     },
   },
   {
@@ -264,7 +272,7 @@
     prop: "taxExclusiveTotalPrice",
     width: 150,
     formatData: (val) => {
-      return parseFloat(val).toFixed(2) ?? 0;
+      return parseFloat(val).toFixed(5) ?? 0;
     },
   },
   {
@@ -286,10 +294,12 @@
   {
     label: "鏈潵绁ㄦ暟",
     prop: "futureTickets",
+		width: 100,
   },
   {
     label: "鏈潵绁ㄩ噾棰�(鍏�)",
     prop: "futureTicketsAmount",
+		width: 200,
   },
 ];
 
@@ -319,23 +329,36 @@
     form.productData = data.productData;
   }
 };
-
+// 瀛愯〃鍚堣鏂规硶
+const summarizeChildrenTable = (param) => {
+	return proxy.summarizeTable(param, [
+		"taxInclusiveUnitPrice",
+		"taxInclusiveTotalPrice",
+		"taxExclusiveTotalPrice",
+		"ticketsNum",
+		"ticketsAmount",
+		"ticketsAmountRef",
+		"futureTickets",
+		"futureTicketsAmount",
+	]);
+};
 //鏈鏉ョエ鏁板け鐒︽搷浣�
 const invoiceNumBlur = (row) => {
   if (!row.ticketsNum || row.ticketsNum === "") {
     row.ticketsNum = 0;
   }
+	row.ticketsNum = row.ticketsNum.toFixed(5);
   if (Number(row.ticketsNum) > Number(row.tempFutureTickets)) {
     proxy.$modal.msgWarning("鏈寮�绁ㄦ暟涓嶅緱澶т簬鏈紑绁ㄦ暟");
     row.ticketsNum = 0;
     return;
   }
   // 璁$畻鏈鏉ョエ閲戦
-  row.ticketsAmount = row.ticketsNum * row.taxInclusiveUnitPrice;
+  row.ticketsAmount = (row.ticketsNum * row.taxInclusiveUnitPrice).toFixed(5)
   // 璁$畻鏈潵绁ㄦ暟
-  row.futureTickets = row.tempFutureTickets - row.ticketsNum;
+  row.futureTickets = (row.tempFutureTickets - row.ticketsNum).toFixed(5)
   // 璁$畻鏈潵绁ㄩ噾棰�
-  row.futureTicketsAmount = row.tempFutureTicketsAmount - row.ticketsAmount;
+  row.futureTicketsAmount = (row.tempFutureTicketsAmount - row.ticketsAmount).toFixed(5)
   calculateinvoiceAmount();
 };
 
@@ -344,6 +367,7 @@
   if (!row.ticketsAmount) {
     row.ticketsAmount = 0;
   }
+	row.ticketsAmount = row.ticketsAmount.toFixed(5);
   // 璁$畻鏄惁瓒呰繃鏉ョエ鎬婚噾棰�
   if (row.ticketsAmount > row.tempFutureTicketsAmount) {
     proxy.$modal.msgWarning("鏈鏉ョエ閲戦涓嶅緱澶т簬鏈潵绁ㄩ噾棰�");
@@ -351,12 +375,12 @@
   }
   // 璁$畻鏈鏉ョエ鏁�
   row.ticketsNum = Number(
-    (row.ticketsAmount / row.taxInclusiveUnitPrice).toFixed(2)
+    (row.ticketsAmount / row.taxInclusiveUnitPrice).toFixed(5)
   );
   // 璁$畻鏈潵绁ㄦ暟
-  row.futureTickets = row.tempFutureTickets - row.ticketsNum;
+  row.futureTickets = (row.tempFutureTickets - row.ticketsNum).toFixed(5)
   // 璁$畻鏈潵绁ㄩ噾棰�
-  row.futureTicketsAmount = row.tempFutureTicketsAmount - row.ticketsAmount;
+  row.futureTicketsAmount = (row.tempFutureTicketsAmount - row.ticketsAmount).toFixed(5)
   calculateinvoiceAmount();
 };
 
@@ -364,10 +388,10 @@
   let invoiceAmountTotal = 0;
   form.productData.forEach((item) => {
     if (item.ticketsAmount) {
-      invoiceAmountTotal += item.ticketsAmount;
+      invoiceAmountTotal += Number(item.ticketsAmount);
     }
   });
-  form.invoiceAmount = invoiceAmountTotal.toFixed(2);
+  form.invoiceAmount = invoiceAmountTotal.toFixed(5);
 };
 
 const open = (type, eid) => {
@@ -386,10 +410,15 @@
   form.tempFileIds = form.tempFileIds.filter((item) => item !== tempId);
 };
 
+const closeAndRefresh = () => {
+  closeModal();
+  emit('refreshList');
+};
+
 const submitForm = () => {
   formRef.value.validate(async (valid, fields) => {
     if (valid) {
-      modalLoading.value = true;
+      // modalLoading.value = true;
       const { code } = await addOrUpdateRegistration({
         purchaseLedgerId: id.value,
         purchaseContractNumber: form.purchaseLedgerNo,
@@ -409,7 +438,7 @@
       });
       modalLoading.value = false;
       if (code == 200) {
-        closeModal();
+        closeAndRefresh();
       }
     } else {
       modalLoading.value = false;
@@ -419,6 +448,7 @@
 
 defineExpose({
   open,
+  closeAndRefresh,
 });
 </script>
 

--
Gitblit v1.9.3