From 43f105070cf75a057d1d0ce4ff330c3b19a21ab0 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期六, 12 七月 2025 13:45:52 +0800
Subject: [PATCH] 1.付款登记-优化:删除权限优化

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

diff --git a/src/views/procurementManagement/invoiceEntry/components/Modal.vue b/src/views/procurementManagement/invoiceEntry/components/Modal.vue
index 3296bb3..f4f3045 100644
--- a/src/views/procurementManagement/invoiceEntry/components/Modal.vue
+++ b/src/views/procurementManagement/invoiceEntry/components/Modal.vue
@@ -1,6 +1,12 @@
 <template>
   <el-dialog :title="modalOptions.title" v-model="visible" width="70%">
-    <el-form ref="formRef" :model="form" :rules="rules" label-width="120px" label-position="top">
+    <el-form
+      ref="formRef"
+      :model="form"
+      :rules="rules"
+      label-width="120px"
+      label-position="top"
+    >
       <el-row :gutter="30">
         <el-col :span="12">
           <el-form-item label="閲囪喘鍚堝悓鍙凤細" prop="purchaseLedgerNo">
@@ -9,61 +15,129 @@
         </el-col>
         <el-col :span="12">
           <el-form-item label="閿�鍞悎鍚屽彿锛�" prop="salesContractNo">
-            <el-input v-model="form.salesContractNo" placeholder="鑷姩濉厖" clearable disabled />
+            <el-input
+              v-model="form.salesContractNo"
+              placeholder="鑷姩濉厖"
+              clearable
+              disabled
+            />
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="渚涘簲鍟嗗悕绉帮細" prop="supplierName">
-            <el-input v-model="form.supplierName" placeholder="鑷姩濉厖" clearable disabled />
+            <el-input
+              v-model="form.supplierName"
+              placeholder="鑷姩濉厖"
+              clearable
+              disabled
+            />
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="椤圭洰鍚嶇О锛�" prop="projectName">
-            <el-input v-model="form.projectName" placeholder="鑷姩濉厖" clearable disabled />
+            <el-input
+              v-model="form.projectName"
+              placeholder="鑷姩濉厖"
+              clearable
+              disabled
+            />
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="鍙戠エ鍙凤細" prop="invoiceNumber">
-            <el-input v-model="form.invoiceNumber" placeholder="璇疯緭鍏�" clearable />
+            <el-input
+              v-model="form.invoiceNumber"
+              placeholder="璇疯緭鍏�"
+              clearable
+            />
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="鍙戠エ閲戦(鍏�)锛�" prop="invoiceAmount">
-            <el-input type="number" :step="0.01" :min="0" v-model="form.invoiceAmount" placeholder="鑷姩濉厖" clearable />
+            <el-input-number :step="0.01" :min="0" style="width: 100%"
+              v-model="form.invoiceAmount"
+              placeholder="鑷姩濉厖"
+              clearable
+            />
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="褰曞叆浜猴細" prop="issUer">
-            <el-input v-model="form.issUer" placeholder="璇疯緭鍏�" clearable disabled />
+            <el-input
+              v-model="form.issUer"
+              placeholder="璇疯緭鍏�"
+              clearable
+              disabled
+            />
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="寮�绁ㄦ棩鏈燂細" prop="entryDate">
-            <el-date-picker style="width: 100%" v-model="form.entryDate" type="date" clearable />
+            <el-date-picker
+              style="width: 100%"
+              v-model="form.entryDate"
+              type="date"
+              clearable
+            />
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="涓婁紶闄勪欢">
-            <FileUpload :showTip="false" accept="*" :autoUpload="true" :action="action" :headers="{
-              Authorization: 'Bearer ' + getToken(),
-            }" :limit="10" @success="uploadSuccess" @remove="removeFile" />
+            <FileUpload
+              :showTip="false"
+              accept="*"
+              :autoUpload="true"
+              :action="action"
+              :headers="{
+                Authorization: 'Bearer ' + getToken(),
+              }"
+              :limit="10"
+              @success="uploadSuccess"
+              @remove="removeFile"
+            />
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="褰曞叆鏃ユ湡锛�" prop="enterDate">
-            <el-date-picker style="width: 100%" v-model="form.enterDate" type="date" clearable />
+            <el-date-picker
+              style="width: 100%"
+              v-model="form.enterDate"
+              type="date"
+              clearable
+            />
           </el-form-item>
         </el-col>
       </el-row>
       <el-form-item label="浜у搧淇℃伅锛�"> </el-form-item>
-      <PIMTable rowKey="id" :column="columns" :tableData="form.productData" height="auto">
+      <PIMTable
+        rowKey="id"
+        :column="columns"
+        :tableData="form.productData"
+				:summaryMethod="summarizeChildrenTable"
+				:isShowSummary="true"
+        height="auto"
+      >
         <template #ticketsNumRef="{ row }">
-          <el-input-number v-model="row.ticketsNum" placeholder="璇烽�夋嫨" :min="0" :step="0.1" clearable style="width: 100%"
-            @change="invoiceNumBlur(row)" />
+          <el-input-number
+            v-model="row.ticketsNum"
+            placeholder="璇疯緭鍏�"
+            :min="0"
+            :step="0.1"
+            clearable
+            style="width: 100%"
+            @change="invoiceNumBlur(row)"
+          />
         </template>
         <template #ticketsAmountRef="{ row }">
-          <el-input-number v-model="row.ticketsAmount" placeholder="璇烽�夋嫨" :min="0" :step="0.1" clearable
-            style="width: 100%" @change="invoiceAmountBlur(row)" />
+          <el-input-number
+            v-model="row.ticketsAmount"
+            placeholder="璇疯緭鍏�"
+            :min="0"
+            :step="0.1"
+            clearable
+            style="width: 100%"
+            @change="invoiceAmountBlur(row)"
+          />
         </template>
       </PIMTable>
     </el-form>
@@ -78,6 +152,7 @@
 
 <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";
@@ -139,14 +214,18 @@
   title: "鏉ョエ鐧昏",
 });
 
+const emit = defineEmits(['refreshList']);
+
 const columns = [
   {
     label: "浜у搧澶х被",
     prop: "productCategory",
+		width: 120,
   },
   {
     label: "瑙勬牸鍨嬪彿",
     prop: "specificationModel",
+		width: 120,
   },
   {
     label: "鍗曚綅",
@@ -211,10 +290,12 @@
   {
     label: "鏈潵绁ㄦ暟",
     prop: "futureTickets",
+		width: 100,
   },
   {
     label: "鏈潵绁ㄩ噾棰�(鍏�)",
     prop: "futureTicketsAmount",
+		width: 200,
   },
 ];
 
@@ -244,7 +325,19 @@
     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 === "") {
@@ -256,11 +349,11 @@
     return;
   }
   // 璁$畻鏈鏉ョエ閲戦
-  row.ticketsAmount = row.ticketsNum * row.taxInclusiveUnitPrice;
+  row.ticketsAmount = (row.ticketsNum * row.taxInclusiveUnitPrice).toFixed(2)
   // 璁$畻鏈潵绁ㄦ暟
-  row.futureTickets = row.tempFutureTickets - row.ticketsNum;
+  row.futureTickets = (row.tempFutureTickets - row.ticketsNum).toFixed(2)
   // 璁$畻鏈潵绁ㄩ噾棰�
-  row.futureTicketsAmount = row.tempFutureTicketsAmount - row.ticketsAmount;
+  row.futureTicketsAmount = (row.tempFutureTicketsAmount - row.ticketsAmount).toFixed(2)
   calculateinvoiceAmount();
 };
 
@@ -279,9 +372,9 @@
     (row.ticketsAmount / row.taxInclusiveUnitPrice).toFixed(2)
   );
   // 璁$畻鏈潵绁ㄦ暟
-  row.futureTickets = row.tempFutureTickets - row.ticketsNum;
+  row.futureTickets = (row.tempFutureTickets - row.ticketsNum).toFixed(2)
   // 璁$畻鏈潵绁ㄩ噾棰�
-  row.futureTicketsAmount = row.tempFutureTicketsAmount - row.ticketsAmount;
+  row.futureTicketsAmount = (row.tempFutureTicketsAmount - row.ticketsAmount).toFixed(2)
   calculateinvoiceAmount();
 };
 
@@ -289,7 +382,7 @@
   let invoiceAmountTotal = 0;
   form.productData.forEach((item) => {
     if (item.ticketsAmount) {
-      invoiceAmountTotal += item.ticketsAmount;
+      invoiceAmountTotal += Number(item.ticketsAmount);
     }
   });
   form.invoiceAmount = invoiceAmountTotal.toFixed(2);
@@ -309,6 +402,11 @@
 const removeFile = (file) => {
   const { tempId } = file.response.data;
   form.tempFileIds = form.tempFileIds.filter((item) => item !== tempId);
+};
+
+const closeAndRefresh = () => {
+  closeModal();
+  emit('refreshList');
 };
 
 const submitForm = () => {
@@ -334,7 +432,7 @@
       });
       modalLoading.value = false;
       if (code == 200) {
-        closeModal();
+        closeAndRefresh();
       }
     } else {
       modalLoading.value = false;
@@ -344,6 +442,7 @@
 
 defineExpose({
   open,
+  closeAndRefresh,
 });
 </script>
 

--
Gitblit v1.9.3