From c95cd68de2a10c9a1c8f5a2945cb52b90d8ba83d Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期三, 10 十二月 2025 11:37:35 +0800
Subject: [PATCH] 1.海川开心-来票登记可以多选开票(多选时金额要加起来) 2.海川开心-采购台账添加一个附件操作

---
 src/views/procurementManagement/procurementLedger/index.vue       |   20 
 src/views/procurementManagement/procurementLedger/fileList.vue    |   67 +++
 src/views/procurementManagement/invoiceEntry/index.vue            |   10 
 src/views/procurementManagement/invoiceEntry/components/Modal.vue |  874 +++++++++++++++++++++++++++++++-------------------
 4 files changed, 623 insertions(+), 348 deletions(-)

diff --git a/src/views/procurementManagement/invoiceEntry/components/Modal.vue b/src/views/procurementManagement/invoiceEntry/components/Modal.vue
index 7a752f8..6e9346c 100644
--- a/src/views/procurementManagement/invoiceEntry/components/Modal.vue
+++ b/src/views/procurementManagement/invoiceEntry/components/Modal.vue
@@ -1,91 +1,100 @@
 <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-row :gutter="30">
-        <el-col :span="12">
-          <el-form-item label="閲囪喘鍚堝悓鍙凤細" prop="purchaseLedgerNo">
-            <el-input v-model="form.purchaseLedgerNo" disabled />
-          </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>
-        </el-col>
-        <el-col :span="12">
-          <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="invoiceNumber">
-            <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-number :step="0.01" :min="0" style="width: 100%"
-              v-model="form.invoiceAmount"
-              placeholder="鑷姩濉厖"
-              clearable
-              :disabled="true"
-            />
-          </el-form-item>
-        </el-col>
-        <el-col :span="12">
-          <el-form-item label="褰曞叆浜猴細" prop="issUer">
-            <el-input
-              v-model="form.issUer"
-              placeholder="璇疯緭鍏�"
-              clearable
-            />
-          </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"
-              value-format="YYYY-MM-DD"
-              format="YYYY-MM-DD"
-              clearable
-            />
-          </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"
-              value-format="YYYY-MM-DD"
-              format="YYYY-MM-DD"
-              clearable
-            />
-          </el-form-item>
-        </el-col>
+	<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 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>
+				</el-col>
+				<el-col :span="12">
+					<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="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="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"
+							value-format="YYYY-MM-DD"
+							format="YYYY-MM-DD"
+							clearable
+						/>
+					</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"
+							value-format="YYYY-MM-DD"
+							format="YYYY-MM-DD"
+							clearable
+						/>
+					</el-form-item>
+				</el-col>
 				<el-col :span="12">
 					<el-form-item label="涓婁紶闄勪欢">
 						<FileUpload
@@ -102,49 +111,92 @@
 						/>
 					</el-form-item>
 				</el-col>
-      </el-row>
-      <el-form-item label="浜у搧淇℃伅锛�"> </el-form-item>
-      <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"
-						:precision="2"
-            clearable
-            style="width: 100%"
-            @change="invoiceNumBlur(row)"
-          />
-        </template>
-        <template #ticketsAmountRef="{ row }">
-          <el-input-number
-            v-model="row.ticketsAmount"
-            placeholder="璇疯緭鍏�"
-            :min="0"
-						:precision="2"
-            :step="0.1"
-            clearable
-            style="width: 100%"
-            @change="invoiceAmountBlur(row)"
-          />
-        </template>
-      </PIMTable>
-    </el-form>
-    <template #footer>
+			
+			</el-row>
+			<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 type="primary" :loading="modalLoading" @click="submitForm">
-				{{ modalOptions.confirmText }}
+				纭
 			</el-button>
-      <el-button @click="closeModal">{{ modalOptions.cancelText }}</el-button>
-    </template>
-  </el-dialog>
+			<el-button @click="closeModal">鍙栨秷</el-button>
+		</template>
+	</el-dialog>
 </template>
 
 <script setup>
@@ -154,9 +206,9 @@
 import useFormData from "@/hooks/useFormData";
 import FileUpload from "@/components/Upload/FileUpload.vue";
 import {
-  getPurchaseNoById,
-  getInfo,
-  addOrUpdateRegistration,
+	getPurchaseNoById,
+	getInfo,
+	addOrUpdateRegistration,
 } from "@/api/procurementManagement/invoiceEntry.js";
 import { getPurchaseById } from "@/api/procurementManagement/procurementLedger.js";
 import { getToken } from "@/utils/auth";
@@ -164,7 +216,7 @@
 import dayjs from "dayjs";
 
 defineOptions({
-  name: "鏉ョエ鐧昏妯℃�佹",
+	name: "鏉ョエ鐧昏妯℃�佹",
 });
 
 const userStore = useUserStore();
@@ -172,152 +224,218 @@
 const formRef = ref();
 const { proxy } = getCurrentInstance();
 const { form } = useFormData({
-  purchaseLedgerNo: undefined, // 閲囪喘鍚堝悓鍙�
-  salesContractNo: undefined, // 閿�鍞悎鍚屽彿
-  supplierName: undefined, // 渚涘簲鍟嗗悕绉�
-  invoiceNumber: undefined, // 鍙戠エ鍙�
-  invoiceAmount: undefined, // 鍙戠エ閲戦(鍏�)
-  issUerId: userStore.id, // 褰曞叆浜�
-  issUer: userStore.nickName, // 褰曞叆浜�
-  entryDate: undefined, // 寮�绁ㄦ棩鏈�
-  salesContractNoId: undefined, // 寮�绁ㄦ棩鏈�
-  enterDate: dayjs().format("YYYY-MM-DD"),
-  productData: [], // 琛ㄦ牸
-  tempFileIds: [], // 鏂囦欢
+	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 selectedContracts = ref([]); // 瀛樺偍閫変腑鐨勫悎鍚屾暟鎹�
+
 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" }],
+	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 {
-  id,
-  visible,
-  loading: modalLoading,
-  openModal,
-  modalOptions,
-  handleConfirm,
-  closeModal,
+	id,
+	visible,
+	loading: modalLoading,
+	openModal,
+	modalOptions,
+	handleConfirm,
+	closeModal,
 } = useModal({
-  title: "鏉ョエ鐧昏",
+	title: "鏉ョエ鐧昏",
 });
 
 const emit = defineEmits(['refreshList']);
 
 const columns = [
-  {
-    label: "浜у搧澶х被",
-    prop: "productCategory",
+	{
+		label: "浜у搧澶х被",
+		prop: "productCategory",
 		width: 120,
-  },
-  {
-    label: "瑙勬牸鍨嬪彿",
-    prop: "specificationModel",
+	},
+	{
+		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",
+	},
+	{
+		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",
+	},
+	{
+		label: "鏈潵绁ㄩ噾棰�(鍏�)",
+		prop: "futureTicketsAmount",
 		width: 200,
-  },
+	},
 ];
-
-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.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.supplierName = data.supplierName;
-    form.entryDate = data.entryDate;
-    form.productData = data.productData;
-  }
+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;
+		}
+		
+		// 鍏佽涓嶅悓鐨勯噰璐悎鍚屽彿鎵归噺澶勭悊锛屾棤闇�妫�鏌ラ噸澶�
+		
+		// 娓呯┖琛ㄥ崟鏁版嵁
+		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) => {
@@ -334,108 +452,186 @@
 };
 //鏈鏉ョエ鏁板け鐒︽搷浣�
 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();
+	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();
+	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);
+	let invoiceAmountTotal = 0;
+	form.productData.forEach((item) => {
+		if (item.ticketsAmount) {
+			invoiceAmountTotal += Number(item.ticketsAmount);
+		}
+	});
+	form.invoiceAmount = invoiceAmountTotal.toFixed(2);
 };
 
-const open = (type, eid) => {
-  openModal();
-  getTableData(type, eid);
-  id.value = eid;
+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);
+	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 { tempId } = file.response.data;
+	form.tempFileIds = form.tempFileIds.filter((item) => item !== tempId);
 };
 
 const closeAndRefresh = () => {
-  closeModal();
-  emit('refreshList');
+	closeModal();
+	emit('refreshList');
 };
 
 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,
-        productData: form.productData,
-        issueDate: form.entryDate,
-        issUerId: form.issUerId, // 褰曞叆浜篿d
-        issUer: form.issUer, // 褰曞叆浜�
-        salesContractNoId: form.salesContractNoId,
-        supplierName: form.supplierName,
-        tempFileIds: form.tempFileIds,
-        enterDate: form.enterDate,
-        type: 4,
-      });
-      modalLoading.value = false;
-      if (code == 200) {
-        closeAndRefresh();
-      }
-    } else {
-      modalLoading.value = false;
-    }
-  });
+	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
+					);
+					
+					// 涓烘瘡涓噰璐悎鍚屽垱寤虹嫭绔嬬殑瀵硅薄
+					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(contractProductData),
+						
+						// 鎵归噺鏍囪瘑
+						isBatch: true,
+						type: 4
+					};
+				});
+				
+				// 鍙皟鐢ㄤ竴娆℃帴鍙o紝浼犻�掑寘鍚墍鏈夊悎鍚屾暟鎹殑鏁扮粍
+				modalLoading.value = true;
+				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 singleForm = {
+					// 鍩虹琛ㄥ崟鏁版嵁
+					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(form.productData),
+					
+					// 鎵归噺鏍囪瘑
+					isBatch: false,
+					type: 4
+				};
+				
+				modalLoading.value = true;
+				addOrUpdateRegistration(singleForm).then((res) => {
+					modalLoading.value = false;
+					if (res.code === 200) {
+						proxy.$modal.msgSuccess("鐧昏鎴愬姛");
+						closeAndRefresh();
+					}
+				}).catch(() => {
+					modalLoading.value = false;
+					proxy.$modal.msgError("鐧昏澶辫触");
+				});
+			}
+		}
+	});
 };
 
 defineExpose({
-  open,
-  closeAndRefresh,
+	open,
+	closeAndRefresh,
 });
 </script>
 
diff --git a/src/views/procurementManagement/invoiceEntry/index.vue b/src/views/procurementManagement/invoiceEntry/index.vue
index ea77ad4..2797edb 100644
--- a/src/views/procurementManagement/invoiceEntry/index.vue
+++ b/src/views/procurementManagement/invoiceEntry/index.vue
@@ -186,11 +186,11 @@
 };
 
 const handleAdd = (type) => {
-  if (selectedRows.value.length !== 1) {
-    proxy.$modal.msgWarning("璇峰厛閫変腑涓�鏉℃暟鎹�");
-    return;
-  }
-  modalRef.value.open(type, selectedRows.value[0].id);
+	if (selectedRows.value.length < 1) {
+		proxy.$modal.msgWarning("璇疯嚦灏戦�変腑涓�鏉℃暟鎹�");
+		return;
+	}
+	modalRef.value.open(type, selectedRows.value);
 };
 
 const handleEdit = (type, id) => {
diff --git a/src/views/procurementManagement/procurementLedger/fileList.vue b/src/views/procurementManagement/procurementLedger/fileList.vue
new file mode 100644
index 0000000..fb392c5
--- /dev/null
+++ b/src/views/procurementManagement/procurementLedger/fileList.vue
@@ -0,0 +1,67 @@
+<template>
+  <el-dialog v-model="dialogVisible" title="闄勪欢" width="40%" :before-close="handleClose">
+    <el-table :data="tableData" border height="40vh">
+      <el-table-column label="闄勪欢鍚嶇О" prop="name" min-width="400" show-overflow-tooltip />
+      <el-table-column fixed="right" label="鎿嶄綔" width="150" align="center">
+        <template #default="scope">
+          <el-button link type="primary" size="small" @click="downLoadFile(scope.row)">涓嬭浇</el-button>
+          <el-button link type="primary" size="small" @click="lookFile(scope.row)">棰勮</el-button>
+          <el-button link type="danger" size="small" @click="handleDelete(scope.row)">鍒犻櫎</el-button>
+        </template>
+      </el-table-column>
+    </el-table>
+  </el-dialog>
+  <filePreview ref="filePreviewRef" />
+</template>
+
+<script setup>
+import { ref } from 'vue'
+import { ElMessageBox, ElMessage } from 'element-plus'
+import filePreview from '@/components/filePreview/index.vue'
+import { delCommonFile } from '@/api/publicApi/commonFile.js'
+
+const dialogVisible = ref(false)
+const tableData = ref([])
+const { proxy } = getCurrentInstance();
+const filePreviewRef = ref()
+const handleClose = () => {
+  dialogVisible.value = false
+}
+const open = (list) => {
+  dialogVisible.value = true
+  tableData.value = list
+}
+const downLoadFile = (row) => {
+  proxy.$download.name(row.url);
+
+}
+const lookFile = (row) => {
+  filePreviewRef.value.open(row.url)
+}
+// 鍒犻櫎闄勪欢
+const handleDelete = (row) => {
+  ElMessageBox.confirm(`纭鍒犻櫎闄勪欢"${row.name}"鍚楋紵`, '鍒犻櫎纭', {
+    confirmButtonText: '纭',
+    cancelButtonText: '鍙栨秷',
+    type: 'warning',
+  }).then(() => {
+    delCommonFile([row.id]).then(() => {
+      ElMessage.success('鍒犻櫎鎴愬姛')
+      // 浠庡垪琛ㄤ腑绉婚櫎宸插垹闄ょ殑闄勪欢
+      const index = tableData.value.findIndex(item => item.id === row.id)
+      if (index !== -1) {
+        tableData.value.splice(index, 1)
+      }
+    }).catch(() => {
+      ElMessage.error('鍒犻櫎澶辫触')
+    })
+  }).catch(() => {
+    proxy.$modal.msg('宸插彇娑堝垹闄�')
+  })
+}
+defineExpose({
+  open
+})
+</script>
+
+<style></style>
\ No newline at end of file
diff --git a/src/views/procurementManagement/procurementLedger/index.vue b/src/views/procurementManagement/procurementLedger/index.vue
index 679418d..32c4a29 100644
--- a/src/views/procurementManagement/procurementLedger/index.vue
+++ b/src/views/procurementManagement/procurementLedger/index.vue
@@ -99,12 +99,10 @@
         <el-table-column
           label="閿�鍞悎鍚屽彿"
           prop="salesContractNo"
-          width="200"
           show-overflow-tooltip
         />
         <el-table-column
           label="渚涘簲鍟嗗悕绉�"
-          width="240"
           prop="supplierName"
           show-overflow-tooltip
         />
@@ -124,7 +122,7 @@
         <el-table-column
           label="褰曞叆浜�"
           prop="recorderName"
-           width="100"
+           width="120"
           show-overflow-tooltip
         />
         <el-table-column
@@ -136,7 +134,7 @@
         <el-table-column
           fixed="right"
           label="鎿嶄綔"
-          min-width="150"
+          width="180"
           align="center"
         >
           <template #default="scope">
@@ -153,6 +151,13 @@
               size="small"
               @click="showQRCode(scope.row)"
               >鐢熸垚浜岀淮鐮�</el-button
+            >
+            <el-button
+              link
+              type="primary"
+              size="small"
+              @click="downLoadFile(scope.row)"
+              >闄勪欢</el-button
             >
 
           </template>
@@ -757,6 +762,7 @@
         </div>
       </template>
     </el-dialog>
+		<FileList ref="fileListRef" />
   </div>
 </template>
 
@@ -767,6 +773,7 @@
 import { Search } from "@element-plus/icons-vue";
 import { ElMessageBox } from "element-plus";
 import { userListNoPage } from "@/api/system/user.js";
+import FileList from "./fileList.vue";
 import {
   getSalesLedgerWithProducts,
   addOrUpdateSalesLedgerProduct,
@@ -1384,6 +1391,11 @@
   }
 };
 
+const fileListRef = ref(null)
+const downLoadFile = (row) => {
+	fileListRef.value.open(row.salesLedgerFiles)
+}
+
 // 鏄剧ず浜岀淮鐮�
 const showQRCode = async (row) => {
   try {

--
Gitblit v1.9.3