From 12b411cd617a1f8d4ef7d03b2d0677f23515ce2f Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期二, 30 十二月 2025 13:30:45 +0800
Subject: [PATCH] 1.双奇点-bug修改

---
 src/views/index.vue                                                        |    5 
 src/views/procurementManagement/procurementInvoiceLedger/Form/EditForm.vue |  230 ++++++++++++++++++++++++-------------
 src/views/inventoryManagement/receiptManagement/index.vue                  |   55 ---------
 src/views/inventoryManagement/issueManagement/index.vue                    |    2 
 src/views/inventoryManagement/stockManagement/index.vue                    |    2 
 src/components/PIMTable/PIMTable.vue                                       |    5 
 src/views/collaborativeApproval/noticeManagement/index.vue                 |    9 +
 src/views/inventoryManagement/dispatchLog/index.vue                        |    8 
 src/views/procurementManagement/paymentLedger/index.vue                    |   21 +-
 9 files changed, 184 insertions(+), 153 deletions(-)

diff --git a/src/components/PIMTable/PIMTable.vue b/src/components/PIMTable/PIMTable.vue
index 1fa1695..12d73ad 100644
--- a/src/components/PIMTable/PIMTable.vue
+++ b/src/components/PIMTable/PIMTable.vue
@@ -204,6 +204,7 @@
     </el-table-column>
   </el-table>
   <pagination
+		v-if="isShowPage"
     :total="page.total"
     :layout="page.layout"
     :page="page.current"
@@ -267,6 +268,10 @@
     type: Boolean,
     default: false,
   },
+	isShowPage: {
+    type: Boolean,
+    default: true,
+  },
   isShowSummary: {
     type: Boolean,
     default: false,
diff --git a/src/views/collaborativeApproval/noticeManagement/index.vue b/src/views/collaborativeApproval/noticeManagement/index.vue
index 799feda..5fbc927 100644
--- a/src/views/collaborativeApproval/noticeManagement/index.vue
+++ b/src/views/collaborativeApproval/noticeManagement/index.vue
@@ -705,6 +705,15 @@
   border-left: 3px solid #409eff;
 }
 
+.card-remark span {
+  flex: 1;
+  min-width: 0;
+  word-wrap: break-word;
+  word-break: break-all;
+  white-space: normal;
+  line-height: 1.5;
+}
+
 .empty-state {
   text-align: center;
   padding: 60px 20px;
diff --git a/src/views/index.vue b/src/views/index.vue
index 748fb14..b71caa1 100644
--- a/src/views/index.vue
+++ b/src/views/index.vue
@@ -287,7 +287,7 @@
 	formatter: function (params) {
 		// 鍔ㄦ�佺敓鎴愭彁绀轰俊鎭紝鍩轰簬鏁版嵁椤圭殑 name 灞炴��
 		const description = params.name === '鏈湀鍥炴閲戦' ? '鏈湀鍥炴閲戦' : '搴旀敹娆鹃噾棰�';
-		return `${description} ${formatNumber(params.value)}鍏� ${params.percent}%`;
+		return `${description} ${formattedNumber(params.value)}鍏� ${params.percent}%`;
 	},
 	position: 'right'
 })
@@ -365,6 +365,9 @@
 		businessInfo.value = {...res.data}
 	})
 }
+const formattedNumber = (row, column, cellValue) => {
+	return parseFloat(cellValue).toFixed(2);
+};
 // 鍚堝悓閲戦
 const analysisCustomer = () => {
 	analysisCustomerContractAmounts().then((res) => {
diff --git a/src/views/inventoryManagement/dispatchLog/index.vue b/src/views/inventoryManagement/dispatchLog/index.vue
index faa442d..4788a39 100644
--- a/src/views/inventoryManagement/dispatchLog/index.vue
+++ b/src/views/inventoryManagement/dispatchLog/index.vue
@@ -242,7 +242,7 @@
 									<div>
 										
 										<span class="label">瀹㈡埛鍚嶇О锛�</span>
-										<span class="value">{{ item.supplierName || '寮犵埍鏈�' }}</span>
+										<span class="value">{{ item.supplierName }}</span>
 									</div>
 								</div>
 								<div class="info-row">
@@ -444,7 +444,7 @@
 	page.current = 1
 	searchForm.value.supplierName = ''
 	searchForm.value.customerName = ''
-	searchForm.value.timeStr = ''
+	searchForm.value.timeStr = getCurrentDate() // 閲嶇疆涓哄綋鍓嶆棩鏈�
 	selectedRows.value = []
   	searchForm.value.productCategory = ''
 	getList()
@@ -687,12 +687,12 @@
               </div>
               <div>
                 <span class="label">瀹㈡埛鍚嶇О锛�</span>
-                <span class="value">${item.supplierName || '寮犵埍鏈�'}</span>
+                <span class="value">${item.supplierName}</span>
               </div>
             </div>
             <div class="info-row">
               <span class="label">鍗曞彿锛�</span>
-              <span class="value">${item.code || ''}</span>
+              <span class="value">${item.code}</span>
             </div>
           </div>
 
diff --git a/src/views/inventoryManagement/issueManagement/index.vue b/src/views/inventoryManagement/issueManagement/index.vue
index e62e785..f0597e3 100644
--- a/src/views/inventoryManagement/issueManagement/index.vue
+++ b/src/views/inventoryManagement/issueManagement/index.vue
@@ -298,7 +298,7 @@
   page.current = 1
   searchForm.value.supplierName = ''
   searchForm.value.customerName = ''
-  searchForm.value.timeStr = ''
+  searchForm.value.timeStr = getCurrentDate() // 閲嶇疆涓哄綋鍓嶆棩鏈�
   selectedRows.value = []
   searchForm.value.productCategory = ''
   getList()
diff --git a/src/views/inventoryManagement/receiptManagement/index.vue b/src/views/inventoryManagement/receiptManagement/index.vue
index 75dce3c..24f7174 100644
--- a/src/views/inventoryManagement/receiptManagement/index.vue
+++ b/src/views/inventoryManagement/receiptManagement/index.vue
@@ -1,59 +1,6 @@
 <template>
   <div class="app-container">
     <el-tabs v-model="activeTab" @tab-change="handleTabChange">
-      <!-- <el-tab-pane label="閲囪喘鍏ュ簱" name="production">
-        <div class="search_form">
-          <div>
-            <span class="search_title ml10">鍏ュ簱鏃ユ湡锛�</span>
-            <el-date-picker
-              v-model="searchForm.timeStr"
-              type="date"
-              placeholder="璇烽�夋嫨鏃ユ湡"
-              value-format="YYYY-MM-DD"
-              format="YYYY-MM-DD"
-              clearable
-              @change="handleQuery"
-            />
-            <span class="search_title ml10">浜у搧澶х被锛�</span>
-            <el-input
-              v-model="searchForm.productCategory"
-              style="width: 240px"
-              placeholder="璇疯緭鍏�"
-              clearable
-            />
-            <el-button type="primary" @click="handleQuery" style="margin-left: 10px">鎼滅储</el-button>
-          </div>
-          <div>
-            <el-button @click="handleOut">瀵煎嚭</el-button>
-            <el-button type="danger" plain @click="handleDelete">鍒犻櫎</el-button>
-          </div>
-        </div>
-        <div class="table_list">
-          <el-table :data="tableData" border v-loading="tableLoading" @selection-change="handleSelectionChange"
-            :expand-row-keys="expandedRowKeys" :row-key="row => row.id" show-summary style="width: 100%"
-            :summary-method="summarizeMainTable" height="calc(100vh - 18.5em)">
-            <el-table-column align="center" type="selection" width="55" />
-            <el-table-column align="center" label="搴忓彿" type="index" width="60" />
-            <el-table-column label="鍏ュ簱鏃堕棿" prop="createTime" show-overflow-tooltip />
-            <el-table-column label="浜у搧澶х被" prop="productCategory" show-overflow-tooltip />
-            <el-table-column label="瑙勬牸鍨嬪彿" prop="specificationModel" show-overflow-tooltip />
-            <el-table-column label="鍗曚綅" prop="unit" width="70" show-overflow-tooltip />
-						<el-table-column label="鍏ュ簱鏁伴噺" prop="inboundNum" width="100" show-overflow-tooltip />
-						<el-table-column label="鍗曚环(鍏�)" prop="unitPrice" width="150"></el-table-column>
-						<el-table-column label="鎬讳环(鍏�)" prop="totalPrice" width="150"></el-table-column>
-            <el-table-column fixed="right" label="鎿嶄綔" min-width="60" align="center">
-              <template #default="scope">
-                <el-button link type="primary" size="small" @click="openForm('edit', scope.row, 'production');">缂栬緫</el-button>
-                <el-button link type="success" size="small" @click="showQRCode(scope.row,1)">鐢熸垚鏉″舰鐮�</el-button>
-                <el-button link type="success" size="small" @click="showERCode(scope.row,1)">鐢熸垚浜岀淮鐮�</el-button>
-              </template>
-            </el-table-column>
-          </el-table>
-          <pagination v-show="total > 0" :total="total" layout="total, sizes, prev, pager, next, jumper"
-            :page="page.current" :limit="page.size" @pagination="paginationChange" />
-        </div>
-      </el-tab-pane> -->
-      
      <el-tab-pane label="閲囪喘鍏ュ簱" name="purchase">
        <div class="search_form">
          <div>
@@ -405,7 +352,7 @@
   // 鍒囨崲 tab 鏃舵竻绌烘悳绱㈡潯浠�
   searchForm.value.supplierName = ''
   searchForm.value.customerName = ''
-  searchForm.value.timeStr = ''
+  searchForm.value.timeStr = getCurrentDate() // 閲嶇疆涓哄綋鍓嶆棩鏈�
   searchForm.value.productCategory = ''
   getList()
 }
diff --git a/src/views/inventoryManagement/stockManagement/index.vue b/src/views/inventoryManagement/stockManagement/index.vue
index 0739daa..21a459a 100644
--- a/src/views/inventoryManagement/stockManagement/index.vue
+++ b/src/views/inventoryManagement/stockManagement/index.vue
@@ -384,7 +384,7 @@
   page.current = 1
   // searchForm.value.supplierName = ''
   searchForm.value.customerName = ''
-  searchForm.value.timeStr = ''
+  searchForm.value.timeStr = getCurrentDate() // 閲嶇疆涓哄綋鍓嶆棩鏈�
   selectedRows.value = []
   searchForm.value.productCategory = ''
   getList()
diff --git a/src/views/procurementManagement/paymentLedger/index.vue b/src/views/procurementManagement/paymentLedger/index.vue
index 741e6ac..14bcaf4 100644
--- a/src/views/procurementManagement/paymentLedger/index.vue
+++ b/src/views/procurementManagement/paymentLedger/index.vue
@@ -86,7 +86,8 @@
             :tableLoading="tableLoadingSon"
             :isShowSummary="isShowSummarySon"
             :summaryMethod="summarizeMainTable1"
-						height="calc(100vh - 18.5em)"
+            :isShowPage="false"
+            height="calc(100vh - 18.5em)"
           >
             <template #payableAmountSlot="{ row }">
               <el-text type="danger">
@@ -94,14 +95,14 @@
               </el-text>
             </template>
           </PIMTable>
-          <pagination
-            v-show="sonTotal > 0"
-            :total="sonTotal"
-            @pagination="sonPaginationSearch"
-            :layout="page.layout"
-            :page="sonPage.current"
-            :limit="sonPage.size"
-          />
+<!--          <pagination-->
+<!--            v-show="sonTotal > 0"-->
+<!--            :total="sonTotal"-->
+<!--            @pagination="sonPaginationSearch"-->
+<!--            :layout="page.layout"-->
+<!--            :page="sonPage.current"-->
+<!--            :limit="sonPage.size"-->
+<!--          />-->
         </div>
       </el-col>
     </el-row>
@@ -245,8 +246,6 @@
   paymentLedgerList({
     ...searchForm.value,
     ...page,
-    detailPageNum: detailPageNum.value, // 鏂板
-    detailPageSize: detailPageSize.value, // 鏂板
   }).then((res) => {
     let result = res.data;
     tableLoading.value = false;
diff --git a/src/views/procurementManagement/procurementInvoiceLedger/Form/EditForm.vue b/src/views/procurementManagement/procurementInvoiceLedger/Form/EditForm.vue
index f939be4..6290804 100644
--- a/src/views/procurementManagement/procurementInvoiceLedger/Form/EditForm.vue
+++ b/src/views/procurementManagement/procurementInvoiceLedger/Form/EditForm.vue
@@ -1,48 +1,48 @@
 <template>
-  <el-form :model="form">
-    <el-row :gutter="20">
-      <el-col :span="12">
-        <el-form-item label="閲囪喘鍚堝悓鍙凤細">
-          <el-tag size="large">{{ form.purchaseContractNumber }}</el-tag>
-        </el-form-item>
-      </el-col>
-      <el-col :span="12">
-        <el-form-item label="閿�鍞悎鍚屽彿锛�">
-          <el-text>{{ form.salesContractNo }}</el-text>
-        </el-form-item>
-      </el-col>
-      <el-col :span="12">
-        <el-form-item label="鍚◣鍗曚环(鍏�)锛�">
-          <el-text type="primary">{{ form.taxInclusiveUnitPrice }}</el-text>
-        </el-form-item>
-      </el-col>
-      <el-col :span="12">
-        <el-form-item label="鍒涘缓鏃堕棿锛�">
-          <el-text>{{ form.createdAt }}</el-text>
-        </el-form-item>
-      </el-col>
-      <el-col :span="12">
-        <el-form-item label="鍙戠エ鍙凤細">
-          <el-input disabled v-model="form.invoiceNumber" />
-        </el-form-item>
-      </el-col>
-      <el-col :span="12">
-        <el-form-item label="鏉ョエ鏁帮細">
-          <el-input-number :step="0.1" :min="0" style="width: 100%" v-model="form.ticketsNum" @change="inputTicketsNum" :precision="2"/>
-        </el-form-item>
-      </el-col>
-      <el-col :span="12">
-        <el-form-item label="鏈鏉ョエ閲戦(鍏�)锛�">
+	<el-form :model="form">
+		<el-row :gutter="20">
+			<el-col :span="12">
+				<el-form-item label="閲囪喘鍚堝悓鍙凤細">
+					<el-tag size="large">{{ form.purchaseContractNumber }}</el-tag>
+				</el-form-item>
+			</el-col>
+			<el-col :span="12">
+				<el-form-item label="閿�鍞悎鍚屽彿锛�">
+					<el-text>{{ form.salesContractNo }}</el-text>
+				</el-form-item>
+			</el-col>
+			<el-col :span="12">
+				<el-form-item label="鍚◣鍗曚环(鍏�)锛�">
+					<el-text type="primary">{{ form.taxInclusiveUnitPrice }}</el-text>
+				</el-form-item>
+			</el-col>
+			<el-col :span="12">
+				<el-form-item label="鍒涘缓鏃堕棿锛�">
+					<el-text>{{ form.createdAt }}</el-text>
+				</el-form-item>
+			</el-col>
+			<el-col :span="12">
+				<el-form-item label="鍙戠エ鍙凤細">
+					<el-input v-model="form.invoiceNumber" />
+				</el-form-item>
+			</el-col>
+			<el-col :span="12">
+				<el-form-item label="鏉ョエ鏁帮細">
+					<el-input-number :step="0.1" :min="0" style="width: 100%" v-model="form.ticketsNum" @change="inputTicketsNum" :precision="2"/>
+				</el-form-item>
+			</el-col>
+			<el-col :span="12">
+				<el-form-item label="鏈鏉ョエ閲戦(鍏�)锛�">
 					<el-input-number :step="0.1" :min="0" style="width: 100%" v-model="form.ticketsAmount" @change="inputTicketsAmount" :precision="2"/>
-        </el-form-item>
-      </el-col>
-      <el-col :span="12">
-        <el-form-item label="鏈潵绁ㄦ暟锛�">
-          <el-text type="success">{{ form.futureTickets }}</el-text>
-        </el-form-item>
-      </el-col>
-    </el-row>
-  </el-form>
+				</el-form-item>
+			</el-col>
+			<el-col :span="12">
+				<el-form-item label="鏈潵绁ㄦ暟锛�">
+					<el-text type="success">{{ form.futureTickets }}</el-text>
+				</el-form-item>
+			</el-col>
+		</el-row>
+	</el-form>
 </template>
 
 <script setup>
@@ -51,34 +51,43 @@
 const { proxy } = getCurrentInstance()
 
 defineOptions({
-  name: "鏉ョエ鍙拌处琛ㄥ崟",
+	name: "鏉ョエ鍙拌处琛ㄥ崟",
 });
-const temFutureTickets = ref(0)
+const temFutureTickets = ref(0) // 鍒濆鏈潵绁ㄦ暟
+const initialTicketsNum = ref(0) // 鍒濆鏉ョエ鏁�
+const initialTicketsAmount = ref(0) // 鍒濆鏉ョエ閲戦
+const quantity = ref(0) // 鎬绘暟閲�
 const { form, resetForm } = useFormData({
-  id: undefined,
-  purchaseContractNumber: undefined, // 閲囪喘鍚堝悓鍙�
-  salesContractNo: undefined, // 閿�鍞悎鍚屽彿
-  createdAt: undefined, // 鍒涘缓鏃堕棿
-  invoiceNumber: undefined, // 鍙戠エ鍙�
-  ticketsNum: undefined, // 鏉ョエ鏁�
-  ticketsAmount: undefined, // 鏉ョエ閲戦
+	id: undefined,
+	purchaseContractNumber: undefined, // 閲囪喘鍚堝悓鍙�
+	salesContractNo: undefined, // 閿�鍞悎鍚屽彿
+	createdAt: undefined, // 鍒涘缓鏃堕棿
+	invoiceNumber: undefined, // 鍙戠エ鍙�
+	ticketsNum: undefined, // 鏉ョエ鏁�
+	ticketsAmount: undefined, // 鏉ョエ閲戦
 	taxInclusiveUnitPrice: undefined, // 鍚◣鍗曚环
+	ticketRegistrationId: undefined, // 鍚◣鍗曚环
 });
 
 const load = async (id) => {
-  const { code, data } = await getProductRecordById({ id });
-  if (code === 200) {
-    form.id = data.id;
-    form.purchaseContractNumber = data.purchaseContractNumber;
-    form.salesContractNo = data.salesContractNo;
-    form.createdAt = data.createdAt;
-    form.invoiceNumber = data.invoiceNumber;
-    form.ticketsNum = data.ticketsNum;
-    form.ticketsAmount = data.ticketsAmount.toFixed(2);
-    form.taxInclusiveUnitPrice = data.taxInclusiveUnitPrice;
-    form.futureTickets = data.futureTickets;
-    temFutureTickets.value = data.futureTickets;
-  }
+	const { code, data } = await getProductRecordById({ id });
+	if (code === 200) {
+		form.id = data.id;
+		form.purchaseContractNumber = data.purchaseContractNumber;
+		form.salesContractNo = data.salesContractNo;
+		form.createdAt = data.createdAt;
+		form.invoiceNumber = data.invoiceNumber;
+		form.ticketsNum = data.ticketsNum;
+		form.ticketsAmount = data.ticketsAmount ? Number(data.ticketsAmount).toFixed(2) : 0;
+		form.taxInclusiveUnitPrice = data.taxInclusiveUnitPrice;
+		form.futureTickets = data.futureTickets;
+		temFutureTickets.value = data.futureTickets;
+		initialTicketsNum.value = data.ticketsNum || 0;
+		initialTicketsAmount.value = data.ticketsAmount || 0;
+		form.ticketRegistrationId = data.ticketRegistrationId;
+		// 鑾峰彇鎬绘暟閲忥紝濡傛灉鏁版嵁涓湁 quantity 瀛楁鍒欎娇鐢紝鍚﹀垯浣跨敤鏉ョエ鏁�+鏈潵绁ㄦ暟
+		quantity.value = data.quantity || (Number(data.ticketsNum || 0) + Number(data.futureTickets || 0));
+	}
 };
 
 const inputTicketsNum = (val) => {
@@ -87,15 +96,44 @@
 		proxy.$modal.msgWarning("鍚◣鍗曚环涓嶈兘涓洪浂鎴栨湭瀹氫箟");
 		return;
 	}
-	if (Number(form.ticketsNum) > Number(temFutureTickets.value)) {
-		proxy.$modal.msgWarning("寮�绁ㄦ暟涓嶅緱澶т簬鏈紑绁ㄦ暟");
-		form.ticketsNum = temFutureTickets.value
+	
+	const newTicketsNum = Number(form.ticketsNum) || 0;
+	const currentTicketsNum = Number(initialTicketsNum.value) || 0;
+	
+	// 璁$畻鏂板鐨勬潵绁ㄦ暟
+	const addedTicketsNum = newTicketsNum - currentTicketsNum;
+	
+	// 璁$畻鏂扮殑鏈潵绁ㄦ暟 = 鍒濆鏈潵绁ㄦ暟 - 鏂板鐨勬潵绁ㄦ暟
+	const newFutureTickets = Number(temFutureTickets.value) - addedTicketsNum;
+	
+	// 楠岃瘉锛氭柊鐨勬潵绁ㄦ暟 + 鏂扮殑鏈潵绁ㄦ暟 鈮� quantity
+	if (newTicketsNum + newFutureTickets > Number(quantity.value)) {
+		proxy.$modal.msgWarning(`鏉ョエ鏁�+鏈潵绁ㄦ暟涓嶈兘澶т簬鎬绘暟閲�(${quantity.value})`);
+		// 闄愬埗鏉ョエ鏁帮紝浣垮叾婊¤冻锛氭潵绁ㄦ暟 + 鏈潵绁ㄦ暟 鈮� quantity
+		// 鏈�澶ф潵绁ㄦ暟 = quantity - 鍒濆鏈潵绁ㄦ暟 + 鍒濆鏉ョエ鏁�
+		const maxTicketsNum = Number(quantity.value) - Number(temFutureTickets.value) + Number(initialTicketsNum.value);
+		form.ticketsNum = Math.max(0, Math.min(maxTicketsNum, newTicketsNum));
+		// 閲嶆柊璁$畻
+		const recalculatedAddedTicketsNum = Number(form.ticketsNum) - Number(initialTicketsNum.value);
+		const recalculatedFutureTickets = Number(temFutureTickets.value) - recalculatedAddedTicketsNum;
+		form.futureTickets = Number(recalculatedFutureTickets.toFixed(2));
+		const ticketsAmount = Number(form.ticketsNum) * Number(form.taxInclusiveUnitPrice);
+		form.ticketsAmount = Number(ticketsAmount.toFixed(2));
+		return;
+	}
+	
+	// 妫�鏌ユ柊澧炵殑鏉ョエ鏁版槸鍚﹀ぇ浜庡垵濮嬫湭鏉ョエ鏁�
+	if (addedTicketsNum > Number(temFutureTickets.value)) {
+		proxy.$modal.msgWarning("鏂板寮�绁ㄦ暟涓嶅緱澶т簬鏈紑绁ㄦ暟");
+		form.ticketsNum = Number(initialTicketsNum.value) + Number(temFutureTickets.value);
 	}
 	
 	// 纭繚鎵�鏈夋暟鍊奸兘杞崲涓烘暟瀛楃被鍨嬭繘琛岃绠�
-	const ticketsAmount = Number(form.ticketsNum) * Number(form.taxInclusiveUnitPrice);
-	const futureTickets = Number(temFutureTickets.value) - Number(form.ticketsNum);
-	form.futureTickets = Number(futureTickets.toFixed(2));
+	const finalTicketsNum = Number(form.ticketsNum) || 0;
+	const finalAddedTicketsNum = finalTicketsNum - Number(initialTicketsNum.value);
+	const finalFutureTickets = Number(temFutureTickets.value) - finalAddedTicketsNum;
+	const ticketsAmount = finalTicketsNum * Number(form.taxInclusiveUnitPrice);
+	form.futureTickets = Number(finalFutureTickets.toFixed(2));
 	form.ticketsAmount = Number(ticketsAmount.toFixed(2));
 };
 const inputTicketsAmount = (val) => {
@@ -105,23 +143,53 @@
 		return;
 	}
 	
-	if (Number(val) > Number(form.futureTickets*form.taxInclusiveUnitPrice)) {
-		proxy.$modal.msgWarning("鏈鏉ョエ閲戦涓嶅緱澶т簬鎬婚噾棰�");
-		form.ticketsAmount = (form.futureTickets*form.taxInclusiveUnitPrice).toFixed(2)
-		const ticketsNum = Number(form.ticketsAmount) / Number(form.taxInclusiveUnitPrice);
-		form.ticketsNum = Number(ticketsNum.toFixed(2))
+	const newTicketsAmount = Number(val) || 0;
+	
+	// 璁$畻鏂扮殑鏉ョエ鏁�
+	const newTicketsNum = newTicketsAmount / Number(form.taxInclusiveUnitPrice);
+	const currentTicketsNum = Number(initialTicketsNum.value) || 0;
+	
+	// 璁$畻鏂板鐨勬潵绁ㄦ暟
+	const addedTicketsNum = newTicketsNum - currentTicketsNum;
+	
+	// 璁$畻鏂扮殑鏈潵绁ㄦ暟 = 鍒濆鏈潵绁ㄦ暟 - 鏂板鐨勬潵绁ㄦ暟
+	const newFutureTickets = Number(temFutureTickets.value) - addedTicketsNum;
+	
+	// 楠岃瘉锛氭柊鐨勬潵绁ㄦ暟 + 鏂扮殑鏈潵绁ㄦ暟 鈮� quantity
+	if (newTicketsNum + newFutureTickets > Number(quantity.value)) {
+		proxy.$modal.msgWarning(`鏉ョエ鏁�+鏈潵绁ㄦ暟涓嶈兘澶т簬鎬绘暟閲�(${quantity.value})`);
+		// 闄愬埗鏉ョエ鏁帮紝浣垮叾婊¤冻锛氭潵绁ㄦ暟 + 鏈潵绁ㄦ暟 鈮� quantity
+		const maxTicketsNum = Number(quantity.value) - Number(temFutureTickets.value) + Number(initialTicketsNum.value);
+		form.ticketsNum = Math.max(0, Math.min(maxTicketsNum, newTicketsNum));
+		form.ticketsAmount = Number((form.ticketsNum * Number(form.taxInclusiveUnitPrice)).toFixed(2));
+		const recalculatedAddedTicketsNum = Number(form.ticketsNum) - Number(initialTicketsNum.value);
+		const recalculatedFutureTickets = Number(temFutureTickets.value) - recalculatedAddedTicketsNum;
+		form.futureTickets = Number(recalculatedFutureTickets.toFixed(2));
+		return;
+	}
+	
+	// 妫�鏌ユ柊澧炵殑鏉ョエ閲戦鏄惁澶т簬鍒濆鏈潵绁ㄦ暟瀵瑰簲鐨勯噾棰�
+	const maxAddedAmount = Number(temFutureTickets.value * form.taxInclusiveUnitPrice);
+	if (addedTicketsNum > 0 && addedTicketsNum * Number(form.taxInclusiveUnitPrice) > maxAddedAmount) {
+		proxy.$modal.msgWarning("鏂板鏉ョエ閲戦涓嶅緱澶т簬鏈紑绁ㄩ噾棰�");
+		form.ticketsAmount = Number((initialTicketsAmount.value + maxAddedAmount).toFixed(2));
+		form.ticketsNum = Number((currentTicketsNum + Number(temFutureTickets.value)).toFixed(2));
+		form.futureTickets = 0;
 		return;
 	}
 	
 	// 纭繚鎵�鏈夋暟鍊奸兘杞崲涓烘暟瀛楃被鍨嬭繘琛岃绠�
-	const ticketsNum = Number(val) / Number(form.taxInclusiveUnitPrice);
-	form.ticketsNum = Number(ticketsNum.toFixed(2));
+	const finalTicketsNum = Number(newTicketsNum.toFixed(2));
+	const finalAddedTicketsNum = finalTicketsNum - Number(initialTicketsNum.value);
+	const finalFutureTickets = Number(temFutureTickets.value) - finalAddedTicketsNum;
+	form.ticketsNum = finalTicketsNum;
+	form.futureTickets = Number(finalFutureTickets.toFixed(2));
 };
 
 defineExpose({
-  load,
-  form,
-  resetForm,
+	load,
+	form,
+	resetForm,
 });
 </script>
 

--
Gitblit v1.9.3