From 9b0aed26bc400fdb1b6d62084346df06993a6ebf Mon Sep 17 00:00:00 2001
From: zhangwencui <1064582902@qq.com>
Date: 星期二, 13 一月 2026 17:53:27 +0800
Subject: [PATCH] 开票登记后,下拉框展示的数据有误

---
 src/views/procurementManagement/invoiceEntry/components/Modal.vue |  979 ++++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 620 insertions(+), 359 deletions(-)

diff --git a/src/views/procurementManagement/invoiceEntry/components/Modal.vue b/src/views/procurementManagement/invoiceEntry/components/Modal.vue
index 1fd32e9..2282f01 100644
--- a/src/views/procurementManagement/invoiceEntry/components/Modal.vue
+++ b/src/views/procurementManagement/invoiceEntry/components/Modal.vue
@@ -1,408 +1,669 @@
 <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-dialog :title="modalOptions.title"
+             v-model="visible"
+             width="70%">
+    <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">
-            <el-input v-model="form.purchaseLedgerNo" disabled />
+          <el-form-item label="閲囪喘鍚堝悓鍙凤細"
+                        prop="purchaseLedgerNo">
+            <el-input v-model="form.purchaseLedgerNo"
+                      disabled
+                      placeholder="澶氬悎鍚屾壒閲忓鐞嗭紙鍏蜂綋鍚堝悓鍙疯浜у搧鍒楄〃锛�" />
           </el-form-item>
         </el-col>
         <el-col :span="12">
-          <el-form-item label="閿�鍞悎鍚屽彿锛�" prop="salesContractNo">
-            <el-input
-              v-model="form.salesContractNo"
-              placeholder="鑷姩濉厖"
-              clearable
-              disabled
-            />
+          <el-form-item label="閿�鍞悎鍚屽彿锛�"
+                        prop="salesContractNo">
+            <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-form-item label="渚涘簲鍟嗗悕绉帮細"
+                        prop="supplierName">
+            <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-form-item>-->
+        <!--				</el-col>-->
+        <el-col :span="12">
+          <el-form-item label="鍙戠エ鍙凤細"
+                        prop="invoiceNumber">
+            <el-input v-model="form.invoiceNumber"
+                      placeholder="璇疯緭鍏�"
+                      clearable />
           </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-form-item label="鍙戠エ閲戦(鍏�)锛�"
+                        prop="invoiceAmount">
+            <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="invoiceNumber">
-            <el-input
-              v-model="form.invoiceNumber"
-              placeholder="璇疯緭鍏�"
-              clearable
-            />
+          <el-form-item label="褰曞叆浜猴細"
+                        prop="issUer">
+            <el-input v-model="form.issUer"
+                      placeholder="璇疯緭鍏�"
+                      clearable
+                      disabled />
           </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
-              :disabled="true"
-            />
+          <el-form-item label="寮�绁ㄦ棩鏈燂細"
+                        prop="entryDate">
+            <el-date-picker style="width: 100%"
+                            v-model="form.entryDate"
+                            type="date"
+                            value-format="YYYY-MM-DD"
+                            format="YYYY-MM-DD"
+                            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-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-form-item label="褰曞叆鏃ユ湡锛�"
+                        prop="enterDate">
+            <el-date-picker style="width: 100%"
+                            v-model="form.enterDate"
+                            type="date"
+                            value-format="YYYY-MM-DD"
+                            format="YYYY-MM-DD"
+                            clearable />
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="涓婁紶闄勪欢">
-            <FileUpload
-              :showTip="false"
-              accept="*"
-              :autoUpload="true"
-              :action="action"
-              :headers="{
+            <FileUpload :showTip="false"
+                        accept="*"
+                        :autoUpload="true"
+                        :action="action"
+                        :headers="{
                 Authorization: 'Bearer ' + getToken(),
               }"
-              :limit="10"
-              @success="uploadSuccess"
-              @remove="removeFile"
-            />
+                        :limit="10"
+                        @success="uploadSuccess"
+                        @remove="removeFile" />
           </el-form-item>
         </el-col>
       </el-row>
-      <el-form-item label="浜у搧淇℃伅锛�" prop="entryDate"> </el-form-item>
-      <PIMTable
-        rowKey="id"
-        :column="columns"
-        :tableData="form.productData"
-        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)"
-          />
-        </template>
-        <template #ticketsAmountRef="{ 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-item label="浜у搧淇℃伅锛�"> </el-form-item>
+      <el-table :data="form.productData"
+                border
+                show-summary
+                :summary-method="summarizeChildrenTable">
+        <el-table-column align="center"
+                         label="搴忓彿"
+                         type="index"
+                         width="60" />
+        <el-table-column label="鎵�灞炲悎鍚�"
+                         prop="purchaseLedgerNo"
+                         width="200">
+          <template #default="{ row }">
+            <el-tag type="primary">{{ row.purchaseLedgerNo }}</el-tag>
+          </template>
+        </el-table-column>
+        <el-table-column label="浜у搧澶х被"
+                         prop="productCategory" />
+        <el-table-column label="瑙勬牸鍨嬪彿"
+                         prop="specificationModel"
+                         width="150" />
+        <el-table-column label="鍗曚綅"
+                         prop="unit"
+                         width="70" />
+        <el-table-column label="鏁伴噺"
+                         prop="quantity"
+                         width="70" />
+        <el-table-column label="绋庣巼(%)"
+                         prop="taxRate"
+                         width="80" />
+        <el-table-column label="鍚◣鍗曚环(鍏�)"
+                         prop="taxInclusiveUnitPrice"
+                         :formatter="formattedNumber" />
+        <el-table-column label="鍚◣鎬讳环(鍏�)"
+                         prop="taxInclusiveTotalPrice"
+                         :formatter="formattedNumber" />
+        <el-table-column label="涓嶅惈绋庢�讳环(鍏�)"
+                         prop="taxExclusiveTotalPrice"
+                         :formatter="formattedNumber" />
+        <el-table-column label="鏈寮�绁ㄦ暟"
+                         prop="ticketsNum"
+                         width="180">
+          <template #default="scope">
+            <el-input-number :step="0.1"
+                             :min="0"
+                             style="width: 100%"
+                             :precision="2"
+                             v-model="scope.row.ticketsNum"
+                             @change="invoiceNumBlur(scope.row)" />
+          </template>
+        </el-table-column>
+        <el-table-column label="鏈寮�绁ㄩ噾棰�(鍏�)"
+                         prop="ticketsAmount"
+                         width="180">
+          <template #default="scope">
+            <el-input-number :step="0.01"
+                             :min="0"
+                             style="width: 100%"
+                             :precision="2"
+                             v-model="scope.row.ticketsAmount"
+                             @change="invoiceAmountBlur(scope.row)" />
+          </template>
+        </el-table-column>
+        <el-table-column label="鏈潵绁ㄦ暟"
+                         prop="futureTickets"
+                         :formatter="formattedNumber" />
+        <el-table-column label="鏈鏉ョエ閲戦(鍏�)"
+                         prop="ticketsAmount"
+                         :formatter="formattedNumber" />
+        <el-table-column label="鏈潵绁ㄦ暟"
+                         prop="futureTickets"
+                         :formatter="formattedNumber" />
+        <el-table-column label="鏈潵绁ㄩ噾棰�(鍏�)"
+                         prop="futureTicketsAmount"
+                         :formatter="formattedNumber" />
+      </el-table>
     </el-form>
     <template #footer>
-      <el-button @click="closeModal">{{ modalOptions.cancelText }}</el-button>
-      <el-button type="primary" :loading="modalLoading" @click="submitForm">
-        {{ modalOptions.confirmText }}
+      <el-button type="primary"
+                 :loading="modalLoading"
+                 @click="submitForm">
+        纭
       </el-button>
+      <el-button @click="closeModal">鍙栨秷</el-button>
     </template>
   </el-dialog>
 </template>
 
 <script setup>
-import { ref, getCurrentInstance } from "vue";
-import { useModal } from "@/hooks/useModal";
-import useFormData from "@/hooks/useFormData";
-import FileUpload from "@/components/Upload/FileUpload.vue";
-import {
-  getPurchaseNoById,
-  getInfo,
-  addOrUpdateRegistration,
-} from "@/api/procurementManagement/invoiceEntry.js";
-import { getPurchaseById } from "@/api/procurementManagement/procurementLedger.js";
-import { getToken } from "@/utils/auth";
-import useUserStore from "@/store/modules/user";
+  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";
+  import {
+    getPurchaseNoById,
+    getInfo,
+    addOrUpdateRegistration,
+  } from "@/api/procurementManagement/invoiceEntry.js";
+  import { getPurchaseById } from "@/api/procurementManagement/procurementLedger.js";
+  import { getToken } from "@/utils/auth";
+  import useUserStore from "@/store/modules/user";
+  import dayjs from "dayjs";
 
-defineOptions({
-  name: "鏉ョエ鐧昏妯℃�佹",
-});
-
-const userStore = useUserStore();
-const action = import.meta.env.VITE_APP_BASE_API + "/file/upload";
-const formRef = ref();
-const { proxy } = getCurrentInstance();
-const { form } = useFormData({
-  purchaseLedgerNo: undefined, // 閲囪喘鍚堝悓鍙�
-  salesContractNo: undefined, // 閿�鍞悎鍚屽彿
-  supplierName: undefined, // 渚涘簲鍟嗗悕绉�
-  projectName: undefined, // 椤圭洰鍚嶇О
-  invoiceNumber: undefined, // 鍙戠エ鍙�
-  invoiceAmount: undefined, // 鍙戠エ閲戦(鍏�)
-  issUerId: userStore.id, // 褰曞叆浜�
-  issUer: userStore.nickName, // 褰曞叆浜�
-  entryDate: undefined, // 寮�绁ㄦ棩鏈�
-  salesContractNoId: undefined, // 寮�绁ㄦ棩鏈�
-  productData: [], // 琛ㄦ牸
-  tempFileIds: [], // 鏂囦欢
-});
-
-const rules = ref({
-  invoiceNumber: [
-    { required: true, message: "璇疯緭鍏ュ彂绁ㄥ彿", trigger: "blur" },
-    { type: "string" },
-  ],
-  invoiceAmount: [
-    { required: true, message: "璇疯緭鍏ュ彂绁ㄩ噾棰�", trigger: "blur" },
-  ],
-});
-
-const {
-  id,
-  visible,
-  loading: modalLoading,
-  openModal,
-  modalOptions,
-  handleConfirm,
-  closeModal,
-} = useModal({
-  title: "鏉ョエ鐧昏",
-});
-
-const columns = [
-  {
-    label: "浜у搧澶х被",
-    prop: "productCategory",
-  },
-  {
-    label: "瑙勬牸鍨嬪彿",
-    prop: "specificationModel",
-  },
-  {
-    label: "鍗曚綅",
-    prop: "unit",
-    width: 80,
-  },
-  {
-    label: "鏁伴噺",
-    prop: "quantity",
-    width: 80,
-  },
-  {
-    label: "绋庣巼(%)",
-    prop: "taxRate",
-    width: 80,
-  },
-  {
-    label: "褰曞叆鏃ユ湡",
-    prop: "registerDate",
-    width: 120,
-  },
-  {
-    label: "鍚◣鍗曚环(鍏�)",
-    prop: "taxInclusiveUnitPrice",
-    width: 150,
-    formatData: (val) => {
-      return parseFloat(val).toFixed(2) ?? 0;
-    },
-  },
-  {
-    label: "鍚◣鎬讳环(鍏�)",
-    prop: "taxInclusiveTotalPrice",
-    width: 150,
-    formatData: (val) => {
-      return parseFloat(val).toFixed(2) ?? 0;
-    },
-  },
-  {
-    label: "涓嶅惈绋庢�讳环(鍏�)",
-    prop: "taxExclusiveTotalPrice",
-    width: 150,
-    formatData: (val) => {
-      return parseFloat(val).toFixed(2) ?? 0;
-    },
-  },
-  {
-    label: "鏈鏉ョエ鏁�",
-    prop: "ticketsNum",
-    dataType: "slot",
-    slot: "ticketsNumRef",
-    width: 180,
-    align: "center",
-  },
-  {
-    label: "鏈鏉ョエ閲戦(鍏�)",
-    prop: "ticketsAmount",
-    dataType: "slot",
-    slot: "ticketsAmountRef",
-    width: 180,
-    align: "center",
-  },
-  {
-    label: "鏈潵绁ㄦ暟",
-    prop: "futureTickets",
-  },
-  {
-    label: "鏈潵绁ㄩ噾棰�(鍏�)",
-    prop: "futureTicketsAmount",
-  },
-];
-
-const getTableData = async (type, id) => {
-  if (type == "add") {
-    const { data } = await getPurchaseNoById({ id });
-    form.purchaseLedgerNo = data.purchaseContractNumber;
-    form.invoiceAmount = data.invoiceAmount;
-    form.invoiceNumber = data.invoiceNumber;
-    form.entryDate = data.entryDate;
-    form.salesContractNoId = data.salesContractNoId;
-
-    const { data: infoData } = await getInfo({ id });
-    form.salesContractNo = infoData.salesContractNo;
-    form.projectName = infoData.projectName;
-    form.supplierName = infoData.supplierName;
-    form.productData = infoData.productData;
-  } else if (type == "edit") {
-    const data = await getPurchaseById({ id, type: 2 });
-    form.purchaseLedgerNo = data.purchaseContractNumber;
-    form.invoiceAmount = data.invoiceAmount;
-    form.invoiceNumber = data.invoiceNumber;
-    form.salesContractNo = data.salesContractNo;
-    form.projectName = data.projectName;
-    form.supplierName = data.supplierName;
-    form.entryDate = data.entryDate;
-    form.productData = data.productData;
-  }
-};
-
-//鏈鏉ョエ鏁板け鐒︽搷浣�
-const invoiceNumBlur = (row) => {
-  if (!row.ticketsNum || row.ticketsNum === "") {
-    row.ticketsNum = 0;
-  }
-  if (Number(row.ticketsNum) > Number(row.tempFutureTickets)) {
-    proxy.$modal.msgWarning("鏈寮�绁ㄦ暟涓嶅緱澶т簬鏈紑绁ㄦ暟");
-    row.ticketsNum = 0;
-    return;
-  }
-  // 璁$畻鏈鏉ョエ閲戦
-  row.ticketsAmount = row.ticketsNum * row.taxInclusiveUnitPrice;
-  // 璁$畻鏈潵绁ㄦ暟
-  row.futureTickets = row.tempFutureTickets - row.ticketsNum;
-  // 璁$畻鏈潵绁ㄩ噾棰�
-  row.futureTicketsAmount = row.tempFutureTicketsAmount - row.ticketsAmount;
-  calculateinvoiceAmount();
-};
-
-// 鏈鏉ョエ閲戦澶辩劍鎿嶄綔
-const invoiceAmountBlur = (row) => {
-  if (!row.ticketsAmount) {
-    row.ticketsAmount = 0;
-  }
-  // 璁$畻鏄惁瓒呰繃鏉ョエ鎬婚噾棰�
-  if (row.ticketsAmount > row.tempFutureTicketsAmount) {
-    proxy.$modal.msgWarning("鏈鏉ョエ閲戦涓嶅緱澶т簬鏈潵绁ㄩ噾棰�");
-    row.ticketsAmount = 0;
-  }
-  // 璁$畻鏈鏉ョエ鏁�
-  row.ticketsNum = Number(
-    (row.ticketsAmount / row.taxInclusiveUnitPrice).toFixed(2)
-  );
-  // 璁$畻鏈潵绁ㄦ暟
-  row.futureTickets = row.tempFutureTickets - row.ticketsNum;
-  // 璁$畻鏈潵绁ㄩ噾棰�
-  row.futureTicketsAmount = row.tempFutureTicketsAmount - row.ticketsAmount;
-  calculateinvoiceAmount();
-};
-
-const calculateinvoiceAmount = () => {
-  let invoiceAmountTotal = 0;
-  form.productData.forEach((item) => {
-    if (item.ticketsAmount) {
-      invoiceAmountTotal += item.ticketsAmount;
-    }
+  defineOptions({
+    name: "鏉ョエ鐧昏妯℃�佹",
   });
-  form.invoiceAmount = invoiceAmountTotal.toFixed(2);
-};
 
-const open = (type, eid) => {
-  openModal();
-  getTableData(type, eid);
-  id.value = eid;
-};
+  const userStore = useUserStore();
+  const action = import.meta.env.VITE_APP_BASE_API + "/file/upload";
+  const formRef = ref();
+  const { proxy } = getCurrentInstance();
+  const { form } = useFormData({
+    purchaseLedgerNo: undefined, // 閲囪喘鍚堝悓鍙�
+    salesContractNo: undefined, // 閿�鍞悎鍚屽彿
+    supplierName: undefined, // 渚涘簲鍟嗗悕绉�
+    projectName: undefined, // 椤圭洰鍚嶇О
+    invoiceNumber: undefined, // 鍙戠エ鍙�
+    invoiceAmount: undefined, // 鍙戠エ閲戦(鍏�)
+    issUerId: userStore.id, // 褰曞叆浜�
+    issUer: userStore.nickName, // 褰曞叆浜�
+    entryDate: undefined, // 寮�绁ㄦ棩鏈�
+    salesContractNoId: undefined, // 寮�绁ㄦ棩鏈�
+    enterDate: dayjs().format("YYYY-MM-DD"),
+    productData: [], // 琛ㄦ牸
+    tempFileIds: [], // 鏂囦欢
+  });
 
-const uploadSuccess = (response) => {
-  form.tempFileIds.push(response.data.tempId);
-  console.log(form);
-};
+  const selectedContracts = ref([]); // 瀛樺偍閫変腑鐨勫悎鍚屾暟鎹�
 
-const removeFile = (file) => {
-  const { tempId } = file.response.data;
-  form.tempFileIds = form.tempFileIds.filter((item) => item !== tempId);
-};
+  const rules = ref({
+    invoiceNumber: [
+      { required: true, message: "璇疯緭鍏ュ彂绁ㄥ彿", trigger: "blur" },
+      { type: "string" },
+    ],
+    invoiceAmount: [
+      { required: true, message: "璇疯緭鍏ュ彂绁ㄩ噾棰�", trigger: "blur" },
+    ],
+    entryDate: [{ required: true, message: "璇烽�夋嫨寮�绁ㄦ棩鏈�", trigger: "change" }],
+    enterDate: [{ required: true, message: "璇烽�夋嫨褰曞叆鏃ユ湡", trigger: "change" }],
+  });
 
-const submitForm = () => {
-  formRef.value.validate(async (valid, fields) => {
-    if (valid) {
-      modalLoading.value = true;
-      const { code } = await addOrUpdateRegistration({
-        purchaseLedgerId: id.value,
-        purchaseContractNumber: form.purchaseLedgerNo,
-        invoiceNumber: form.invoiceNumber,
-        invoiceAmount: form.invoiceAmount,
-        salesContractNo: form.salesContractNo,
-        projectName: form.projectName,
-        productData: form.productData,
-        issUerId: form.issUerId, // 褰曞叆浜�
-        issUer: form.issUer, // 褰曞叆浜�
-        salesContractNoId: form.salesContractNoId,
-        supplierName: form.supplierName,
-        tempFileIds: form.tempFileIds,
-        type: 4,
-      });
-      modalLoading.value = false;
-      if (code == 200) {
-        closeModal();
+  const {
+    id,
+    visible,
+    loading: modalLoading,
+    openModal,
+    modalOptions,
+    handleConfirm,
+    closeModal,
+  } = useModal({
+    title: "鏉ョエ鐧昏",
+  });
+
+  const emit = defineEmits(["refreshList"]);
+
+  const columns = [
+    {
+      label: "浜у搧澶х被",
+      prop: "productCategory",
+      width: 120,
+    },
+    {
+      label: "瑙勬牸鍨嬪彿",
+      prop: "specificationModel",
+      width: 120,
+    },
+    {
+      label: "鍗曚綅",
+      prop: "unit",
+      width: 80,
+    },
+    {
+      label: "鏁伴噺",
+      prop: "quantity",
+      width: 80,
+    },
+    {
+      label: "绋庣巼(%)",
+      prop: "taxRate",
+      width: 80,
+    },
+    {
+      label: "褰曞叆鏃ユ湡",
+      prop: "registerDate",
+      width: 120,
+    },
+    {
+      label: "鍚◣鍗曚环(鍏�)",
+      prop: "taxInclusiveUnitPrice",
+      width: 150,
+      formatData: val => {
+        return val ? parseFloat(val).toFixed(2) : 0;
+      },
+    },
+    {
+      label: "鍚◣鎬讳环(鍏�)",
+      prop: "taxInclusiveTotalPrice",
+      width: 150,
+      formatData: val => {
+        return parseFloat(val).toFixed(2) ?? 0;
+      },
+    },
+    {
+      label: "涓嶅惈绋庢�讳环(鍏�)",
+      prop: "taxExclusiveTotalPrice",
+      width: 150,
+      formatData: val => {
+        return parseFloat(val).toFixed(2) ?? 0;
+      },
+    },
+    {
+      label: "鏈鏉ョエ鏁�",
+      prop: "ticketsNum",
+      dataType: "slot",
+      slot: "ticketsNumRef",
+      width: 180,
+      align: "center",
+    },
+    {
+      label: "鏈鏉ョエ閲戦(鍏�)",
+      prop: "ticketsAmount",
+      dataType: "slot",
+      slot: "ticketsAmountRef",
+      width: 180,
+      align: "center",
+    },
+    {
+      label: "鏈潵绁ㄦ暟",
+      prop: "futureTickets",
+      width: 100,
+    },
+    {
+      label: "鏈潵绁ㄩ噾棰�(鍏�)",
+      prop: "futureTicketsAmount",
+      width: 200,
+    },
+  ];
+  const formattedNumber = (row, column, cellValue) => {
+    if (cellValue == 0) {
+      return parseFloat(cellValue).toFixed(2);
+    }
+    if (cellValue) {
+      return parseFloat(cellValue).toFixed(2);
+    } else {
+      return cellValue;
+    }
+  };
+  const getTableData = async (type, selectedRows) => {
+    if (type == "add") {
+      // 妫�鏌ユ墍鏈夐�夋嫨鐨勫悎鍚屾槸鍚﹀叿鏈夌浉鍚岀殑渚涘簲鍟嗗悕绉�
+      const firstRow = selectedRows[0];
+      const isSameSupplier = selectedRows.every(
+        row => row.supplierName === firstRow.supplierName
+      );
+
+      if (!isSameSupplier) {
+        proxy.$modal.msgError("璇烽�夋嫨鐩稿悓渚涘簲鍟嗗悕绉扮殑鍚堝悓");
+        return;
       }
-    }
-  });
-};
 
-defineExpose({
-  open,
-});
+      // 鍏佽涓嶅悓鐨勯噰璐悎鍚屽彿鎵归噺澶勭悊锛屾棤闇�妫�鏌ラ噸澶�
+
+      // 娓呯┖琛ㄥ崟鏁版嵁
+      Object.keys(form).forEach(key => {
+        if (key !== "productData") {
+          form[key] = undefined;
+        }
+      });
+      form.productData = [];
+
+      // 鍔犺浇鎵�鏈夐�変腑鍚堝悓鐨勪骇鍝佹暟鎹�
+      const promises = selectedRows.map(row => getInfo({ id: row.id }));
+
+      Promise.all(promises).then(results => {
+        // 鍚堝苟鎵�鏈夊悎鍚岀殑浜у搧鏁版嵁锛屽苟涓烘瘡涓骇鍝佹坊鍔犲搴旂殑鍚堝悓淇℃伅
+        const allProductData = [];
+        results.forEach((result, index) => {
+          const contract = selectedRows[index];
+          const contractId = contract.id;
+          if (result.data && result.data.productData) {
+            result.data.productData.forEach(item => {
+              allProductData.push({
+                ...item,
+                // id: contractId, // 鏄庣‘璁剧疆鍚堝悓ID
+                purchaseLedgerNo: contract.purchaseContractNumber, // 娣诲姞閲囪喘鍚堝悓鍙�
+                supplierName: contract.supplierName, // 娣诲姞渚涘簲鍟嗗悕绉�
+                projectName: contract.projectName, // 娣诲姞椤圭洰鍚嶇О
+              });
+            });
+          }
+        });
+
+        // 璁剧疆琛ㄥ崟鏁版嵁锛堜娇鐢ㄧ涓�涓悎鍚岀殑鍩烘湰淇℃伅锛岄噰璐悎鍚屽彿鐣欑┖锛�
+        form.purchaseLedgerNo = ""; // 閲囪喘鍚堝悓鍙风暀绌猴紝鍥犱负浼氬湪浜у搧琛ㄦ牸涓垎鍒樉绀�
+        form.invoiceAmount = 0;
+        form.invoiceNumber = "";
+        form.entryDate = dayjs().format("YYYY-MM-DD");
+        form.enterDate = dayjs().format("YYYY-MM-DD");
+        form.salesContractNo = results[0].data.salesContractNo;
+        form.projectName = results[0].data.projectName;
+        form.supplierName = results[0].data.supplierName;
+        // 淇濈暀褰曞叆浜轰俊鎭�
+        form.issUerId = userStore.id;
+        form.issUer = userStore.nickName;
+
+        form.productData = allProductData;
+
+        // 瀛樺偍閫変腑鐨勫悎鍚屾暟鎹�
+        selectedContracts.value = selectedRows;
+      });
+    } else if (type == "edit") {
+      const id = Array.isArray(selectedRows) ? selectedRows[0].id : selectedRows;
+      const data = await getPurchaseById({ id, type: 2 });
+      form.purchaseLedgerNo = data.purchaseContractNumber;
+      form.invoiceAmount = data.invoiceAmount;
+      form.invoiceNumber = data.invoiceNumber;
+      form.salesContractNo = data.salesContractNo;
+      form.projectName = data.projectName;
+      form.supplierName = data.supplierName;
+      form.entryDate = data.entryDate;
+      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;
+    }
+    if (Number(row.ticketsNum) > Number(row.tempFutureTickets)) {
+      proxy.$modal.msgWarning("鏈寮�绁ㄦ暟涓嶅緱澶т簬鏈紑绁ㄦ暟");
+      row.ticketsNum = 0;
+      return;
+    }
+    // 璁$畻鏈鏉ョエ閲戦
+    row.ticketsAmount = (row.ticketsNum * row.taxInclusiveUnitPrice).toFixed(2);
+    // 璁$畻鏈潵绁ㄦ暟
+    row.futureTickets = (row.tempFutureTickets - row.ticketsNum).toFixed(2);
+    // 璁$畻鏈潵绁ㄩ噾棰�
+    row.futureTicketsAmount = (
+      row.tempFutureTicketsAmount - row.ticketsAmount
+    ).toFixed(2);
+    calculateinvoiceAmount();
+  };
+
+  // 鏈鏉ョエ閲戦澶辩劍鎿嶄綔
+  const invoiceAmountBlur = row => {
+    if (!row.ticketsAmount) {
+      row.ticketsAmount = 0;
+    }
+    // 璁$畻鏄惁瓒呰繃鏉ョエ鎬婚噾棰�
+    if (row.ticketsAmount > row.tempFutureTicketsAmount) {
+      proxy.$modal.msgWarning("鏈鏉ョエ閲戦涓嶅緱澶т簬鏈潵绁ㄩ噾棰�");
+      row.ticketsAmount = 0;
+    }
+    // 璁$畻鏈鏉ョエ鏁�
+    row.ticketsNum = Number(
+      (row.ticketsAmount / row.taxInclusiveUnitPrice).toFixed(2)
+    );
+    // 璁$畻鏈潵绁ㄦ暟
+    row.futureTickets = (row.tempFutureTickets - row.ticketsNum).toFixed(2);
+    // 璁$畻鏈潵绁ㄩ噾棰�
+    row.futureTicketsAmount = (
+      row.tempFutureTicketsAmount - row.ticketsAmount
+    ).toFixed(2);
+    calculateinvoiceAmount();
+  };
+
+  const calculateinvoiceAmount = () => {
+    let invoiceAmountTotal = 0;
+    form.productData.forEach(item => {
+      if (item.ticketsAmount) {
+        invoiceAmountTotal += Number(item.ticketsAmount);
+      }
+    });
+    form.invoiceAmount = invoiceAmountTotal.toFixed(2);
+  };
+
+  const open = async (type, selectedRows) => {
+    visible.value = true;
+
+    // 濡傛灉鏄壒閲忔搷浣滐紝璁剧疆鏍囬
+    if (Array.isArray(selectedRows) && selectedRows.length > 1) {
+      modalOptions.title = `鎵归噺鏂板 (${selectedRows.length}鏉�)`;
+    } else {
+      modalOptions.title = type == "add" ? "鏂板" : "缂栬緫";
+    }
+
+    // 濡傛灉鏄崟涓搷浣滐紝鑾峰彇id
+    if (!Array.isArray(selectedRows) || selectedRows.length === 1) {
+      const idValue = Array.isArray(selectedRows)
+        ? selectedRows[0].id
+        : selectedRows;
+      id.value = idValue;
+    }
+
+    await getTableData(type, selectedRows);
+  };
+
+  const uploadSuccess = response => {
+    form.tempFileIds.push(response.data.tempId);
+    console.log(form);
+  };
+
+  const removeFile = file => {
+    const { tempId } = file.response.data;
+    form.tempFileIds = form.tempFileIds.filter(item => item !== tempId);
+  };
+
+  const closeAndRefresh = () => {
+    closeModal();
+    emit("refreshList");
+  };
+  const processProductData = products => {
+    return products.map(product => {
+      return {
+        ...product,
+        futureTickets: product.futureTickets
+          ? Number(Number(product.futureTickets).toFixed(2))
+          : 0,
+        futureTicketsAmount: product.futureTicketsAmount
+          ? Number(Number(product.futureTicketsAmount).toFixed(2))
+          : 0,
+        ticketsNum: product.ticketsNum
+          ? Number(Number(product.ticketsNum).toFixed(2))
+          : 0,
+        ticketsAmount: product.ticketsAmount
+          ? Number(Number(product.ticketsAmount).toFixed(2))
+          : 0,
+      };
+    });
+  };
+  const submitForm = () => {
+    proxy.$refs["formRef"].validate(valid => {
+      if (valid) {
+        // 濡傛灉鏄壒閲忔搷浣滐紝灏嗘墍鏈夊悎鍚岀殑鏁版嵁鏀惧湪涓�涓暟缁勯噷锛屽彧璋冪敤涓�娆℃帴鍙�
+        if (selectedContracts.value.length > 1) {
+          // 鍒涘缓鍖呭惈鎵�鏈夊悎鍚屾暟鎹殑鏁扮粍
+          const batchData = selectedContracts.value.map(contract => {
+            // 绛涢�夊嚭灞炰簬褰撳墠鍚堝悓鐨勪骇鍝佹暟鎹�
+            const contractProductData = form.productData.filter(
+              item => item.id === contract.id
+            );
+            const processedProductData = processProductData(contractProductData);
+            // 涓烘瘡涓噰璐悎鍚屽垱寤虹嫭绔嬬殑瀵硅薄
+            return {
+              // 鍩虹琛ㄥ崟鏁版嵁
+              invoiceNumber: form.invoiceNumber,
+              invoiceAmount: form.invoiceAmount,
+              entryDate: form.entryDate,
+              enterDate: form.enterDate,
+              issUerId: form.issUerId, // 褰曞叆浜篿d
+              issUer: form.issUer, // 褰曞叆浜�
+              tempFileIds: form.tempFileIds,
+
+              // 鍚堝悓瀹為檯淇℃伅
+              purchaseLedgerId: contract.id, // 浣跨敤id浣滀负瀛楁鍚嶏紝鍊间负purchaseLedgerId
+              purchaseContractNumber: contract.purchaseContractNumber, // 浣跨敤瀹為檯鐨勯噰璐悎鍚屽彿
+              salesContractNo: contract.salesContractNo, // 浣跨敤瀹為檯鐨勯攢鍞悎鍚屽彿
+              supplierName: contract.supplierName, // 浣跨敤瀹為檯鐨勪緵搴斿晢鍚嶇О
+              projectName: contract.projectName, // 浣跨敤瀹為檯鐨勯」鐩悕绉�
+
+              // 浜у搧鏁版嵁
+              productData: proxy.HaveJson(processedProductData),
+
+              // 鎵归噺鏍囪瘑
+              isBatch: true,
+              type: 4,
+            };
+          });
+
+          // 鍙皟鐢ㄤ竴娆℃帴鍙o紝浼犻�掑寘鍚墍鏈夊悎鍚屾暟鎹殑鏁扮粍
+          modalLoading.value = true;
+          console.log(batchData, "batchData");
+
+          addOrUpdateRegistration(batchData)
+            .then(res => {
+              modalLoading.value = false;
+              if (res.code === 200) {
+                proxy.$modal.msgSuccess("鎵归噺鐧昏鎴愬姛");
+                closeAndRefresh();
+              }
+            })
+            .catch(() => {
+              modalLoading.value = false;
+              proxy.$modal.msgError("鎵归噺鐧昏澶辫触");
+            });
+        } else {
+          // 鍗曚釜鍚堝悓鎻愪氦閫昏緫 - 浠ユ暟缁勬牸寮忎紶閫�
+          const singleContract = selectedContracts.value[0];
+          const processedProductData = processProductData(form.productData);
+          const singleFormArray = [
+            {
+              // 鍩虹琛ㄥ崟鏁版嵁
+              invoiceNumber: form.invoiceNumber,
+              invoiceAmount: form.invoiceAmount,
+              entryDate: form.entryDate,
+              enterDate: form.enterDate,
+              issUerId: form.issUerId, // 褰曞叆浜篿d
+              issUer: form.issUer, // 褰曞叆浜�
+              tempFileIds: form.tempFileIds,
+
+              // 鍚堝悓瀹為檯淇℃伅
+              purchaseLedgerId: singleContract.id, // 浣跨敤id浣滀负瀛楁鍚嶏紝鍊间负purchaseLedgerId
+              purchaseContractNumber: singleContract.purchaseContractNumber, // 浣跨敤瀹為檯鐨勯噰璐悎鍚屽彿
+              salesContractNo: singleContract.salesContractNo, // 浣跨敤瀹為檯鐨勯攢鍞悎鍚屽彿
+              supplierName: singleContract.supplierName, // 浣跨敤瀹為檯鐨勪緵搴斿晢鍚嶇О
+              projectName: singleContract.projectName, // 浣跨敤瀹為檯鐨勯」鐩悕绉�
+
+              // 浜у搧鏁版嵁
+              productData: proxy.HaveJson(processedProductData),
+
+              // 鎵归噺鏍囪瘑
+              isBatch: false,
+              type: 4,
+            },
+          ];
+
+          modalLoading.value = true;
+          console.log(singleFormArray, "singleFormArray");
+
+          addOrUpdateRegistration(singleFormArray)
+            .then(res => {
+              modalLoading.value = false;
+              if (res.code === 200) {
+                proxy.$modal.msgSuccess("鐧昏鎴愬姛");
+                closeAndRefresh();
+              }
+            })
+            .catch(() => {
+              modalLoading.value = false;
+              proxy.$modal.msgError("鐧昏澶辫触");
+            });
+        }
+      }
+    });
+  };
+
+  defineExpose({
+    open,
+    closeAndRefresh,
+  });
 </script>
 
 <style lang="scss" scoped></style>

--
Gitblit v1.9.3