From c7f90a3054ee56c3be7317a67d2b192b6509b3e7 Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期五, 27 三月 2026 13:22:40 +0800
Subject: [PATCH] fix: 采购销售订单需要审核

---
 src/views/collaborativeApproval/approvalProcess/components/approvalDia.vue |  186 +
 src/views/procurementManagement/procurementLedger/index.vue                | 1714 +++++++----------
 src/api/salesManagement/salesLedger.js                                     |    9 
 src/views/collaborativeApproval/approvalProcess/index6.vue                 |   22 
 src/api/procurementManagement/procurementLedger.js                         |   34 
 src/views/procurementManagement/invoiceEntry/index.vue                     |    1 
 src/views/collaborativeApproval/approvalProcess/index.vue                  |  161 
 src/views/salesManagement/salesLedger/index.vue                            | 3575 +++++++++++++++++--------------------
 src/views/salesManagement/invoiceRegistration/index.vue                    |    1 
 9 files changed, 2,679 insertions(+), 3,024 deletions(-)

diff --git a/src/api/procurementManagement/procurementLedger.js b/src/api/procurementManagement/procurementLedger.js
index 69a23f7..573c893 100644
--- a/src/api/procurementManagement/procurementLedger.js
+++ b/src/api/procurementManagement/procurementLedger.js
@@ -57,7 +57,7 @@
     params: query,
   });
 }
-// 鏌ヨ閲囪喘鍙拌处鍒楄〃
+
 export function purchaseListPage(query) {
   return request({
     url: "/purchase/ledger/listPage",
@@ -72,30 +72,12 @@
     method: "get",
   });
 }
-export function updateApprovalStatus(query) {
-    return request({
-        url: "/purchase/ledger/updateApprovalStatus",
-        method: "post",
-        data: query,
-    });
-}
 
-// 淇濆瓨閲囪喘妯℃澘
-// /purchase/ledger/addPurchaseTemplate
-export function addPurchaseTemplate(data) {
-    return request({
-        url: "/purchase/ledger/addPurchaseTemplate",
-        method: "post",
-        data: data,
-    });
-}
-
-// 鏌ヨ閲囪喘妯℃澘
-// /purchase/ledger/getPurchaseTemplateList
-export function getPurchaseTemplateList(query) {
-    return request({
-        url: "/purchase/ledger/getPurchaseTemplateList",
-        method: "get",
-        params: query,
-    });
+// 鏍规嵁閲囪喘鍚堝悓鍙锋煡璇㈣鎯�
+export function getPurchaseByCode(query) {
+  return request({
+    url: "/purchase/ledger/getPurchaseByCode",
+    method: "get",
+    params: query,
+  });
 }
diff --git a/src/api/salesManagement/salesLedger.js b/src/api/salesManagement/salesLedger.js
index 66e706a..4b74259 100644
--- a/src/api/salesManagement/salesLedger.js
+++ b/src/api/salesManagement/salesLedger.js
@@ -118,10 +118,11 @@
     });
 }
 
-export function judgmentInventory(query) {
+// 鏍规嵁閿�鍞悎鍚屽彿鏌ヨ閿�鍞鎯�
+export function getSalesByCode(query) {
   return request({
-    url: "/sales/product/judgmentInventory",
-     method: "get",
-        params: query,
+    url: "/sales/ledger/getSalesByCode",
+    method: "get",
+    params: query,
   });
 }
\ No newline at end of file
diff --git a/src/views/collaborativeApproval/approvalProcess/components/approvalDia.vue b/src/views/collaborativeApproval/approvalProcess/components/approvalDia.vue
index 403cab6..f0c43ae 100644
--- a/src/views/collaborativeApproval/approvalProcess/components/approvalDia.vue
+++ b/src/views/collaborativeApproval/approvalProcess/components/approvalDia.vue
@@ -32,7 +32,24 @@
 						</el-form-item>
 					</el-col>
 				</el-row>
-				<el-row>
+				<!-- 鎶ラ攢閲戦锛堜粎褰� approveType 涓� 4 鏃舵樉绀猴級 -->
+				<el-row v-if="props.approveType == 4">
+					<el-col :span="24">
+						<el-form-item label="鎶ラ攢閲戦锛�" prop="price">
+							<el-input-number
+								v-model="form.price"
+								placeholder="璇疯緭鍏ユ姤閿�閲戦"
+								:min="0"
+								:precision="2"
+								:step="0.01"
+								style="width: 100%"
+								disabled
+								clearable
+							/>
+						</el-form-item>
+					</el-col>
+				</el-row>
+				<el-row v-if="!isPurchaseApproval && !isSalesApproval">
 					<el-col :span="24">
 						<el-form-item label="瀹℃壒浜嬬敱锛�" prop="approveReason">
 							<el-input v-model="form.approveReason" placeholder="璇疯緭鍏�" clearable type="textarea" disabled/>
@@ -73,6 +90,98 @@
 					</el-col>
 				</el-row>
 			</el-form>
+      <div v-if="isPurchaseApproval" style="margin: 10px 0 18px;">
+        <el-divider content-position="left">閲囪喘璇︽儏</el-divider>
+        <el-skeleton :loading="purchaseLoading" animated>
+          <template #template>
+            <el-skeleton-item variant="h3" style="width: 30%" />
+            <el-skeleton-item variant="text" style="width: 100%" />
+            <el-skeleton-item variant="text" style="width: 100%" />
+          </template>
+          <template #default>
+            <el-empty v-if="!purchaseDetail || !purchaseDetail.purchaseContractNumber" description="鏈煡璇㈠埌瀵瑰簲閲囪喘璇︽儏" />
+            <template v-else>
+              <el-descriptions :column="2" border>
+                <el-descriptions-item label="閲囪喘鍚堝悓鍙�">{{ purchaseDetail.purchaseContractNumber }}</el-descriptions-item>
+                <el-descriptions-item label="渚涘簲鍟嗗悕绉�">{{ purchaseDetail.supplierName }}</el-descriptions-item>
+                <el-descriptions-item label="椤圭洰鍚嶇О">{{ purchaseDetail.projectName }}</el-descriptions-item>
+                <el-descriptions-item label="閿�鍞悎鍚屽彿">{{ purchaseDetail.salesContractNo }}</el-descriptions-item>
+                <el-descriptions-item label="绛捐鏃ユ湡">{{ purchaseDetail.executionDate }}</el-descriptions-item>
+                <el-descriptions-item label="褰曞叆鏃ユ湡">{{ purchaseDetail.entryDate }}</el-descriptions-item>
+                <el-descriptions-item label="浠樻鏂瑰紡">{{ purchaseDetail.paymentMethod }}</el-descriptions-item>
+                <el-descriptions-item label="鍚堝悓閲戦" :span="2">
+                  <span style="font-size: 18px; color: #e6a23c; font-weight: bold;">
+                    楼{{ Number(purchaseDetail.contractAmount ?? 0).toFixed(2) }}
+                  </span>
+                </el-descriptions-item>
+              </el-descriptions>
+
+              <div style="margin-top: 20px;">
+                <h4>浜у搧鏄庣粏</h4>
+                <el-table :data="purchaseProducts" border style="width: 100%">
+                  <el-table-column prop="productCategory" label="浜у搧鍚嶇О" />
+                  <el-table-column prop="specificationModel" label="瑙勬牸鍨嬪彿" />
+                  <el-table-column prop="unit" label="鍗曚綅" />
+                  <el-table-column prop="quantity" label="鏁伴噺" />
+                  <el-table-column prop="taxInclusiveUnitPrice" label="鍚◣鍗曚环">
+                    <template #default="scope">楼{{ Number(scope.row.taxInclusiveUnitPrice ?? 0).toFixed(2) }}</template>
+                  </el-table-column>
+                  <el-table-column prop="taxInclusiveTotalPrice" label="鍚◣鎬讳环">
+                    <template #default="scope">楼{{ Number(scope.row.taxInclusiveTotalPrice ?? 0).toFixed(2) }}</template>
+                  </el-table-column>
+                </el-table>
+              </div>
+            </template>
+          </template>
+        </el-skeleton>
+      </div>
+      <div v-if="isSalesApproval" style="margin: 10px 0 18px;">
+        <el-divider content-position="left">閿�鍞鎯�</el-divider>
+        <el-skeleton :loading="salesLoading" animated>
+          <template #template>
+            <el-skeleton-item variant="h3" style="width: 30%" />
+            <el-skeleton-item variant="text" style="width: 100%" />
+            <el-skeleton-item variant="text" style="width: 100%" />
+          </template>
+          <template #default>
+            <el-empty v-if="!salesDetail || !salesDetail.salesContractNo" description="鏈煡璇㈠埌瀵瑰簲閿�鍞鎯�" />
+            <template v-else>
+              <el-descriptions :column="2" border>
+                <el-descriptions-item label="閿�鍞悎鍚屽彿">{{ salesDetail.salesContractNo }}</el-descriptions-item>
+                <el-descriptions-item label="瀹㈡埛鍚堝悓鍙�">{{ salesDetail.customerContractNo }}</el-descriptions-item>
+                <el-descriptions-item label="瀹㈡埛鍚嶇О">{{ salesDetail.customerName }}</el-descriptions-item>
+                <el-descriptions-item label="涓氬姟鍛�">{{ salesDetail.salesman }}</el-descriptions-item>
+                <el-descriptions-item label="椤圭洰鍚嶇О">{{ salesDetail.projectName }}</el-descriptions-item>
+                <el-descriptions-item label="浠樻鏂瑰紡">{{ salesDetail.paymentMethod }}</el-descriptions-item>
+                <el-descriptions-item label="褰曞叆浜�">{{ salesEntryPersonDisplay }}</el-descriptions-item>
+                <el-descriptions-item label="褰曞叆鏃ユ湡">{{ salesDetail.entryDate }}</el-descriptions-item>
+                <el-descriptions-item label="绛捐鏃ユ湡">{{ salesDetail.executionDate }}</el-descriptions-item>
+                <el-descriptions-item label="鍚堝悓閲戦" :span="2">
+                  <span style="font-size: 18px; color: #e6a23c; font-weight: bold;">
+                    楼{{ Number(salesDetail.contractAmount ?? 0).toFixed(2) }}
+                  </span>
+                </el-descriptions-item>
+              </el-descriptions>
+
+              <div style="margin-top: 20px;">
+                <h4>浜у搧鏄庣粏</h4>
+                <el-table :data="salesProducts" border style="width: 100%">
+                  <el-table-column prop="productCategory" label="浜у搧鍚嶇О" />
+                  <el-table-column prop="specificationModel" label="瑙勬牸鍨嬪彿" />
+                  <el-table-column prop="unit" label="鍗曚綅" />
+                  <el-table-column prop="quantity" label="鏁伴噺" />
+                  <el-table-column prop="taxInclusiveUnitPrice" label="鍚◣鍗曚环">
+                    <template #default="scope">楼{{ Number(scope.row.taxInclusiveUnitPrice ?? 0).toFixed(2) }}</template>
+                  </el-table-column>
+                  <el-table-column prop="taxInclusiveTotalPrice" label="鍚◣鎬讳环">
+                    <template #default="scope">楼{{ Number(scope.row.taxInclusiveTotalPrice ?? 0).toFixed(2) }}</template>
+                  </el-table-column>
+                </el-table>
+              </div>
+            </template>
+          </template>
+        </el-skeleton>
+      </div>
       <el-form :model="{ activities }" ref="formRef" label-position="top">
         <el-steps :active="getActiveStep()" finish-status="success" process-status="process" align-center direction="vertical">
           <el-step
@@ -146,13 +255,15 @@
 </template>
 
 <script setup>
-import { getCurrentInstance, reactive, ref, toRefs } from "vue";
+import { computed, getCurrentInstance, reactive, ref, toRefs } from "vue";
 import vueEsign from "vue-esign";
 import {
 	approveProcessDetails,
 	getDept,
 	updateApproveNode
 } from "@/api/collaborativeApproval/approvalProcess.js";
+import { getPurchaseByCode } from "@/api/procurementManagement/procurementLedger.js";
+import { getSalesByCode } from "@/api/salesManagement/salesLedger.js";
 import useUserStore from "@/store/modules/user.js";
 import {userListNoPageByTenantId} from "@/api/system/user.js";
 import { WarningFilled, Edit, Check, MoreFilled } from '@element-plus/icons-vue'
@@ -167,6 +278,38 @@
 const userStore = useUserStore()
 const productOptions = ref([]);
 const userList = ref([])
+const purchaseLoading = ref(false)
+const currentPurchase = ref({})
+const isPurchaseApproval = computed(() => Number(props.approveType) === 5)
+const salesLoading = ref(false)
+const currentSales = ref({})
+const isSalesApproval = computed(() => Number(props.approveType) === 6)
+const purchaseDetail = computed(() => currentPurchase.value?.data || currentPurchase.value || {})
+const purchaseProducts = computed(() => {
+  const detail = purchaseDetail.value || {}
+  return detail.productData || detail.products || detail.children || []
+})
+const salesDetail = computed(() => currentSales.value?.data || currentSales.value || {})
+const salesProducts = computed(() => {
+  const detail = salesDetail.value || {}
+  return detail.productData || detail.products || detail.children || []
+})
+/** 閿�鍞鎯咃細褰曞叆浜猴紙鎺ュ彛鍙兘鍙繑 entryPerson 鐢ㄦ埛ID锛岄渶鐢� userList 鍙嶆煡鏄电О锛� */
+const salesEntryPersonDisplay = computed(() => {
+  const d = salesDetail.value || {}
+  if (d.entryPersonName) return d.entryPersonName
+  if (d.recorderName) return d.recorderName
+  if (d.createByName) return d.createByName
+  if (d.createUserName) return d.createUserName
+  const id = d.entryPerson
+  if (id != null && id !== "" && userList.value?.length) {
+    const u = userList.value.find(
+      (x) => x.userId == id || String(x.userId) === String(id)
+    )
+    if (u) return u.nickName
+  }
+  return id != null && id !== "" ? String(id) : "-"
+})
 const data = reactive({
 	form: {
 		approveTime: "",
@@ -185,6 +328,12 @@
 const esign = ref(null);
 const lineWidth = ref(0);
 const lineColor = ref("#000000");
+const props = defineProps({
+	approveType: {
+		type: [Number, String],
+		default: 0
+	}
+})
 
 // 涓婁紶閰嶇疆
 const upload = reactive({
@@ -219,11 +368,40 @@
 const openDialog = (type, row) => {
   operationType.value = type;
   dialogFormVisible.value = true;
+  currentPurchase.value = {}
+  currentSales.value = {}
 	userListNoPageByTenantId().then((res) => {
 		userList.value = res.data;
 	});
 	form.value = {...row}
 	getProductOptions()
+  if (isPurchaseApproval.value) {
+    const purchaseContractNumber = row?.approveReason
+    if (purchaseContractNumber) {
+      purchaseLoading.value = true
+      getPurchaseByCode({ purchaseContractNumber }).then((res) => {
+        // 鍏煎鍚庣杩斿洖 {code,data} 鎴栫洿鎺ヨ繑鍥炶鎯呭璞′袱绉嶇粨鏋�
+        currentPurchase.value = res || {}
+      }).catch(() => {
+        proxy.$modal.msgError("鏌ヨ閲囪喘璇︽儏澶辫触")
+      }).finally(() => {
+        purchaseLoading.value = false
+      })
+    }
+  }
+  if (isSalesApproval.value) {
+    const salesContractNo = row?.approveReason
+    if (salesContractNo) {
+      salesLoading.value = true
+      getSalesByCode({ salesContractNo }).then((res) => {
+        currentSales.value = res || {}
+      }).catch(() => {
+        proxy.$modal.msgError("鏌ヨ閿�鍞鎯呭け璐�")
+      }).finally(() => {
+        salesLoading.value = false
+      })
+    }
+  }
   approveProcessDetails(row.approveId).then((res) => {
     activities.value = res.data
     // 澧炲姞isApproval瀛楁
@@ -330,6 +508,10 @@
 const closeDia = () => {
   proxy.resetForm("formRef");
   dialogFormVisible.value = false;
+  purchaseLoading.value = false
+  currentPurchase.value = {}
+  salesLoading.value = false
+  currentSales.value = {}
   emit('close')
 };
 defineExpose({
diff --git a/src/views/collaborativeApproval/approvalProcess/index.vue b/src/views/collaborativeApproval/approvalProcess/index.vue
index cc90438..abe5725 100644
--- a/src/views/collaborativeApproval/approvalProcess/index.vue
+++ b/src/views/collaborativeApproval/approvalProcess/index.vue
@@ -43,7 +43,7 @@
       ></PIMTable>
     </div>
     <info-form-dia ref="infoFormDia" @close="handleQuery" :approveType="approveType"></info-form-dia>
-    <approval-dia ref="approvalDia" @close="handleQuery"></approval-dia>
+    <approval-dia ref="approvalDia" @close="handleQuery" :approveType="approveType"></approval-dia>
     <FileList ref="fileListRef" />
   </div>
 </template>
@@ -76,73 +76,95 @@
   },
 });
 const { searchForm } = toRefs(data);
-const tableColumn = ref([
-  {
-    label: "瀹℃壒鐘舵��",
-    prop: "approveStatus",
-    dataType: "tag",
-		width: 100,
-    formatData: (params) => {
-      if (params == 0) {
-        return "寰呭鏍�";
-      } else if (params == 1) {
-        return "瀹℃牳涓�";
-      } else if (params == 2) {
-        return "瀹℃牳瀹屾垚";
-      } else if (params == 4) {
-        return "宸查噸鏂版彁浜�";
-      } else {
-        return '涓嶉�氳繃';
-      }
+const tableColumn = computed(() => {
+  const baseColumns = [
+    {
+      label: "瀹℃壒鐘舵��",
+      prop: "approveStatus",
+      dataType: "tag",
+		  width: 100,
+      formatData: (params) => {
+        if (params == 0) {
+          return "寰呭鏍�";
+        } else if (params == 1) {
+          return "瀹℃牳涓�";
+        } else if (params == 2) {
+          return "瀹℃牳瀹屾垚";
+        } else if (params == 4) {
+          return "宸查噸鏂版彁浜�";
+        } else {
+          return '涓嶉�氳繃';
+        }
+      },
+      formatType: (params) => {
+        if (params == 0) {
+          return "warning";
+        } else if (params == 1) {
+          return "primary";
+        } else if (params == 2) {
+          return "success";
+        } else if (params == 4) {
+          return "";
+        } else {
+          return 'danger';
+        }
+      },
     },
-    formatType: (params) => {
-      if (params === 0) {
-        return "warning";
-      } else if (params === 2) {
-        return "success";
-      } else if (params === 3) {
-        return "danger";
-      } else {
-        return 'danger';
-      }
+    {
+      label: "娴佺▼缂栧彿",
+      prop: "approveId",
+      width: 170
     },
-  },
-  {
-    label: "娴佺▼缂栧彿",
-    prop: "approveId",
-    width: 170
-  },
-  {
-    label: "鐢宠閮ㄩ棬",
-    prop: "approveDeptName",
-		width: 220
-  },
-  {
-    label: "瀹℃壒浜嬬敱",
-    prop: "approveReason",
-		width: 200
-  },
-  {
-    label: "鐢宠浜�",
-    prop: "approveUserName",
-    width: 120
-  },
-  {
-    label: "鐢宠鏃ユ湡",
-    prop: "approveTime",
-		width: 200
-  },
-  {
-    label: "缁撴潫鏃ユ湡",
-    prop: "approveOverTime",
-    width: 120
-  },
-  {
-    label: "褰撳墠瀹℃壒浜�",
-    prop: "approveUserCurrentName",
-    width: 120
-  },
-  {
+    {
+      label: "鐢宠閮ㄩ棬",
+      prop: "approveDeptName",
+		  width: 220
+    },
+    {
+      label: "瀹℃壒浜嬬敱",
+      prop: "approveReason",
+		  width: 200
+    },
+    {
+      label: "鐢宠浜�",
+      prop: "approveUserName",
+      width: 120
+    },
+    {
+      label: "鐢宠鏃ユ湡",
+      prop: "approveTime",
+		  width: 200
+    },
+    {
+      label: "缁撴潫鏃ユ湡",
+      prop: "approveOverTime",
+      width: 120
+    },
+    {
+      label: "褰撳墠瀹℃壒浜�",
+      prop: "approveUserCurrentName",
+      width: 120
+    }
+  ];
+
+  // 濡傛灉鏄姤閿�绠$悊瀹℃壒琛紙approveType=4锛夛紝娣诲姞鎶ラ攢閲戦鍒�
+  if (props.approveType == 4) {
+    baseColumns.push({
+      label: "鎶ラ攢閲戦",
+      prop: "price",
+      width: 120,
+      fixed: "right",
+      formatData: (params) => {
+        if (params) {
+          return `楼${Number(params).toFixed(2)}`;
+        }
+        return '-'
+      }
+    });
+  }
+
+  // 娣诲姞鎿嶄綔鍒�
+  baseColumns.push({
     dataType: "action",
     label: "鎿嶄綔",
     align: "center",
@@ -180,8 +202,10 @@
         },
       },
     ],
-  },
-]);
+  });
+
+  return baseColumns;
+});
 const tableData = ref([]);
 const selectedRows = ref([]);
 const tableLoading = ref(false);
@@ -239,6 +263,7 @@
     3: "鍑哄樊绠$悊瀹℃壒琛�",
     4: "鎶ラ攢绠$悊瀹℃壒琛�",
     5: "閲囪喘鐢宠瀹℃壒琛�",
+    6: "閿�鍞鍗曞鎵硅〃",
   }
   const fileName = nameMap[type] || nameMap[0]
   proxy.download(url, {}, `${fileName}.xlsx`)
diff --git a/src/views/collaborativeApproval/approvalProcess/index6.vue b/src/views/collaborativeApproval/approvalProcess/index6.vue
new file mode 100644
index 0000000..3b40d80
--- /dev/null
+++ b/src/views/collaborativeApproval/approvalProcess/index6.vue
@@ -0,0 +1,22 @@
+<template>
+  <div class="container">
+    <!-- 寮曞叆index.vue缁勪欢骞朵紶閫掑弬鏁� -->
+    <ApprovalProcessIndex :approveType="6" />
+  </div>
+</template>
+
+<script setup>
+  import ApprovalProcessIndex from "./index.vue";
+
+  // 瀹氫箟缁勪欢鍚嶇О
+  defineOptions({
+    name: "ApprovalProcessIndex1",
+  });
+</script>
+
+<style scoped>
+  .container {
+    width: 100%;
+    height: 100%;
+  }
+</style>
diff --git a/src/views/procurementManagement/invoiceEntry/index.vue b/src/views/procurementManagement/invoiceEntry/index.vue
index 87e08e9..82555ff 100644
--- a/src/views/procurementManagement/invoiceEntry/index.vue
+++ b/src/views/procurementManagement/invoiceEntry/index.vue
@@ -120,6 +120,7 @@
   gePurchaseListPage,
   {
     purchaseContractNumber: undefined,
+    approvalStatus: 2
   },
   [
     {
diff --git a/src/views/procurementManagement/procurementLedger/index.vue b/src/views/procurementManagement/procurementLedger/index.vue
index 99a392f..a7935b5 100644
--- a/src/views/procurementManagement/procurementLedger/index.vue
+++ b/src/views/procurementManagement/procurementLedger/index.vue
@@ -44,32 +44,31 @@
         <el-button type="danger" plain @click="handleDelete">鍒犻櫎</el-button>
       </div>
       <el-table
-          :data="tableData"
-          border
-          v-loading="tableLoading"
-          @selection-change="handleSelectionChange"
-          :expand-row-keys="expandedRowKeys"
-          :row-key="(row) => row.id"
-          show-summary
-          :summary-method="summarizeMainTable"
-          @expand-change="expandChange"
-          height="calc(100vh - 18.5em)"
-          :row-class-name="tableRowClassName"
+        :data="tableData"
+        border
+        v-loading="tableLoading"
+        @selection-change="handleSelectionChange"
+        :expand-row-keys="expandedRowKeys"
+        :row-key="(row) => row.id"
+        show-summary
+        :summary-method="summarizeMainTable"
+        @expand-change="expandChange"
+        height="calc(100vh - 18.5em)"
       >
         <el-table-column align="center" type="selection" width="55" />
         <el-table-column type="expand">
           <template #default="props">
             <el-table
-                :data="props.row.children"
-                border
-                show-summary
-                :summary-method="summarizeChildrenTable"
+              :data="props.row.children"
+              border
+              show-summary
+              :summary-method="summarizeChildrenTable"
             >
               <el-table-column
-                  align="center"
-                  label="搴忓彿"
-                  type="index"
-                  width="60"
+                align="center"
+                label="搴忓彿"
+                type="index"
+                width="60"
               />
               <el-table-column label="浜у搧澶х被" prop="productCategory" />
               <el-table-column label="瑙勬牸鍨嬪彿" prop="specificationModel" />
@@ -77,163 +76,168 @@
               <el-table-column label="鏁伴噺" prop="quantity" />
               <el-table-column label="绋庣巼(%)" prop="taxRate" />
               <el-table-column
-                  label="鍚◣鍗曚环(鍏�)"
-                  prop="taxInclusiveUnitPrice"
-                  :formatter="formattedNumber"
+                label="鍚◣鍗曚环(鍏�)"
+                prop="taxInclusiveUnitPrice"
+                :formatter="formattedNumber"
               />
               <el-table-column
-                  label="鍚◣鎬讳环(鍏�)"
-                  prop="taxInclusiveTotalPrice"
-                  :formatter="formattedNumber"
+                label="鍚◣鎬讳环(鍏�)"
+                prop="taxInclusiveTotalPrice"
+                :formatter="formattedNumber"
               />
               <el-table-column
-                  label="涓嶅惈绋庢�讳环(鍏�)"
-                  prop="taxExclusiveTotalPrice"
-                  :formatter="formattedNumber"
+                label="涓嶅惈绋庢�讳环(鍏�)"
+                prop="taxExclusiveTotalPrice"
+                :formatter="formattedNumber"
               />
             </el-table>
           </template>
         </el-table-column>
         <el-table-column align="center" label="搴忓彿" type="index" width="60" />
         <el-table-column
-            label="閲囪喘鍚堝悓鍙�"
-            prop="purchaseContractNumber"
-            width="200"
-            show-overflow-tooltip
+          label="閲囪喘鍚堝悓鍙�"
+          prop="purchaseContractNumber"
+          width="200"
+          show-overflow-tooltip
         />
         <el-table-column
-            label="閿�鍞悎鍚屽彿"
-            prop="salesContractNo"
-            width="200"
-            show-overflow-tooltip
+          label="閿�鍞悎鍚屽彿"
+          prop="salesContractNo"
+          width="200"
+          show-overflow-tooltip
         />
         <el-table-column
-            label="渚涘簲鍟嗗悕绉�"
-            width="240"
-            prop="supplierName"
-            show-overflow-tooltip
-        />
-        <el-table-column label="璁㈠崟鐘舵��" width="100" align="center">
-          <template #default="scope">
-            <el-tag v-if="scope.row.isInvalid" type="danger" size="small">澶辨晥</el-tag>
-            <el-tag v-else type="success" size="small">姝e父</el-tag>
-          </template>
-        </el-table-column>
-        <el-table-column
-            label="椤圭洰鍚嶇О"
-            prop="projectName"
-            width="420"
-            show-overflow-tooltip
+          label="渚涘簲鍟嗗悕绉�"
+          width="240"
+          prop="supplierName"
+          show-overflow-tooltip
         />
         <el-table-column
-            label="瀹℃壒鐘舵��"
-            prop="approvalStatus"
-            width="200"
-            show-overflow-tooltip
-        >
+          label="椤圭洰鍚嶇О"
+          prop="projectName"
+          width="420"
+          show-overflow-tooltip
+        />
+        <el-table-column label="瀹℃壒鐘舵��" width="140">
           <template #default="scope">
             <el-tag
-                size="small"
-            >
-              {{ approvalStatusText[scope.row.approvalStatus] || '鏈煡鐘舵��' }}
-            </el-tag>
+              v-if="(scope.row.approveStatus ?? scope.row.approvalStatus ?? scope.row.auditStatus) == 0"
+              type="warning"
+            >寰呭鏍�</el-tag>
+            <el-tag
+              v-else-if="(scope.row.approveStatus ?? scope.row.approvalStatus ?? scope.row.auditStatus) == 1"
+              type="primary"
+            >瀹℃牳涓�</el-tag>
+            <el-tag
+              v-else-if="(scope.row.approveStatus ?? scope.row.approvalStatus ?? scope.row.auditStatus) == 2"
+              type="success"
+            >瀹℃牳瀹屾垚</el-tag>
+            <el-tag
+              v-else-if="(scope.row.approveStatus ?? scope.row.approvalStatus ?? scope.row.auditStatus) == 3"
+              type="danger"
+            >瀹℃牳鏈�氳繃</el-tag>
+            <el-tag
+              v-else-if="(scope.row.approveStatus ?? scope.row.approvalStatus ?? scope.row.auditStatus) == 4"
+              type="info"
+            >宸查噸鏂版彁浜�</el-tag>
+            <el-tag v-else type="info">-</el-tag>
           </template>
         </el-table-column>
         <el-table-column
-            label="浠樻鏂瑰紡"
-            width="100"
-            prop="paymentMethod"
-            show-overflow-tooltip
+          label="浠樻鏂瑰紡"
+          width="100"
+          prop="paymentMethod"
+          show-overflow-tooltip
         />
         <el-table-column
-            label="鍚堝悓閲戦(鍏�)"
-            prop="contractAmount"
-            width="200"
-            show-overflow-tooltip
-            :formatter="formattedNumber"
+          label="鍚堝悓閲戦(鍏�)"
+          prop="contractAmount"
+           width="200"
+          show-overflow-tooltip
+          :formatter="formattedNumber"
         />
         <el-table-column
-            label="褰曞叆浜�"
-            prop="recorderName"
-            width="100"
-            show-overflow-tooltip
+          label="褰曞叆浜�"
+          prop="recorderName"
+           width="100"
+          show-overflow-tooltip
         />
         <el-table-column
-            label="褰曞叆鏃ユ湡"
-            prop="entryDate"
-            width="100"
-            show-overflow-tooltip
+          label="褰曞叆鏃ユ湡"
+          prop="entryDate"
+           width="100"
+          show-overflow-tooltip
         />
         <el-table-column
-            fixed="right"
-            label="鎿嶄綔"
-            min-width="150"
-            align="center"
+          fixed="right"
+          label="鎿嶄綔"
+          min-width="150"
+          align="center"
         >
           <template #default="scope">
             <el-button
-                link
-                type="primary"
-                size="small"
-                @click="openForm('edit', scope.row)"
-            >缂栬緫</el-button
+              link
+              type="primary"
+              size="small"
+              @click="openForm('edit', scope.row)"
+              >缂栬緫</el-button
             >
             <el-button
-                link
-                type="success"
-                size="small"
-                @click="showQRCode(scope.row)"
-            >鐢熸垚浜岀淮鐮�</el-button
+              link
+              type="success"
+              size="small"
+              @click="showQRCode(scope.row)"
+              >鐢熸垚浜岀淮鐮�</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"
+        v-show="total > 0"
+        :total="total"
+        layout="total, sizes, prev, pager, next, jumper"
+        :page="page.current"
+        :limit="page.size"
+        @pagination="paginationChange"
       />
     </div>
     <el-dialog
-        v-model="dialogFormVisible"
-        :title="operationType === 'add' ? '鏂板閲囪喘鍙拌处椤甸潰' : '缂栬緫閲囪喘鍙拌处椤甸潰'"
-        width="70%"
-        @close="closeDia"
+      v-model="dialogFormVisible"
+      :title="operationType === 'add' ? '鏂板閲囪喘鍙拌处椤甸潰' : '缂栬緫閲囪喘鍙拌处椤甸潰'"
+      width="70%"
+      @close="closeDia"
     >
       <el-form
-          :model="form"
-          label-width="140px"
-          label-position="top"
-          :rules="rules"
-          ref="formRef"
+        :model="form"
+        label-width="140px"
+        label-position="top"
+        :rules="rules"
+        ref="formRef"
       >
         <el-row :gutter="30">
           <el-col :span="12">
             <el-form-item label="閲囪喘鍚堝悓鍙凤細" prop="purchaseContractNumber">
               <el-input
-                  v-model="form.purchaseContractNumber"
-                  placeholder="璇疯緭鍏�"
-                  clearable
+                v-model="form.purchaseContractNumber"
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
           <el-col :span="12">
             <el-form-item label="閿�鍞悎鍚屽彿锛�" prop="salesLedgerId">
               <el-select
-                  v-model="form.salesLedgerId"
-                  placeholder="璇烽�夋嫨"
-                  clearable
-                  @change="salesLedgerChange"
+                v-model="form.salesLedgerId"
+                placeholder="璇烽�夋嫨"
+                clearable
+                @change="salesLedgerChange"
               >
                 <el-option
-                    v-for="item in salesContractList"
-                    :key="item.id"
-                    :label="item.salesContractNo"
-                    :value="item.id"
+                  v-for="item in salesContractList"
+                  :key="item.id"
+                  :label="item.salesContractNo"
+                  :value="item.id"
                 />
               </el-select>
             </el-form-item>
@@ -243,17 +247,15 @@
           <el-col :span="12">
             <el-form-item label="渚涘簲鍟嗗悕绉帮細" prop="supplierId">
               <el-select
-                  v-model="form.supplierId"
-                  placeholder="璇烽�夋嫨"
-                  clearable
-                  filterable
-                  allow-create
+                v-model="form.supplierId"
+                placeholder="璇烽�夋嫨"
+                clearable
               >
                 <el-option
-                    v-for="item in supplierList"
-                    :key="item.id"
-                    :label="item.supplierName"
-                    :value="item.id"
+                  v-for="item in supplierList"
+                  :key="item.id"
+                  :label="item.supplierName"
+                  :value="item.id"
                 />
               </el-select>
             </el-form-item>
@@ -261,65 +263,51 @@
           <el-col :span="12">
             <el-form-item label="椤圭洰鍚嶇О锛�" prop="projectName">
               <el-input
-                  v-model="form.projectName"
-                  placeholder="璇疯緭鍏�"
-                  clearable
+                v-model="form.projectName"
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
         </el-row>
+				<el-row :gutter="30">
+					<el-col :span="12">
+						<el-form-item label="浠樻鏂瑰紡">
+							<el-input
+								v-model="form.paymentMethod"
+								placeholder="璇疯緭鍏�"
+								clearable
+							/>
+						</el-form-item>
+					</el-col>
+					<el-col :span="12">
+						<el-form-item label="绛捐鏃ユ湡锛�" prop="executionDate">
+							<el-date-picker
+								style="width: 100%"
+								v-model="form.executionDate"
+								value-format="YYYY-MM-DD"
+								format="YYYY-MM-DD"
+								type="date"
+								placeholder="璇烽�夋嫨"
+								clearable
+							/>
+						</el-form-item>
+					</el-col>
+				</el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="浠樻鏂瑰紡">
-              <el-input
-                  v-model="form.paymentMethod"
-                  placeholder="璇疯緭鍏�"
-                  clearable
-              />
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="绛捐鏃ユ湡锛�" prop="executionDate">
-              <el-date-picker
-                  style="width: 100%"
-                  v-model="form.executionDate"
-                  value-format="YYYY-MM-DD"
-                  format="YYYY-MM-DD"
-                  type="date"
-                  placeholder="璇烽�夋嫨"
-                  clearable
-              />
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-row :gutter="30">
-          <el-col :span="12">
-            <el-form-item label="瀹℃壒浜猴細" prop="approverId">
+            <el-form-item label="褰曞叆浜猴細" prop="recorderId">
               <el-select
-                  v-model="form.approverId"
-                  placeholder="璇烽�夋嫨瀹℃壒浜�"
-                  clearable
+                v-model="form.recorderId"
+                placeholder="璇烽�夋嫨"
+                clearable
+                disabled
               >
                 <el-option
-                    v-for="item in userList"
-                    :key="item.userId"
-                    :label="item.nickName"
-                    :value="item.userId"
-                />
-              </el-select>
-            </el-form-item>
-            <el-form-item label="褰曞叆浜猴細" prop="recorderId" v-show="false">
-              <el-select
-                  v-model="form.recorderId"
-                  placeholder="璇烽�夋嫨"
-                  clearable
-                  disabled
-              >
-                <el-option
-                    v-for="item in userList"
-                    :key="item.userId"
-                    :label="item.nickName"
-                    :value="item.userId"
+                  v-for="item in userList"
+                  :key="item.userId"
+                  :label="item.nickName"
+                  :value="item.userId"
                 />
               </el-select>
             </el-form-item>
@@ -327,109 +315,120 @@
           <el-col :span="12">
             <el-form-item label="褰曞叆鏃ユ湡锛�" prop="entryDate">
               <el-date-picker
-                  style="width: 100%"
-                  v-model="form.entryDate"
-                  value-format="YYYY-MM-DD"
-                  format="YYYY-MM-DD"
-                  type="date"
-                  placeholder="璇烽�夋嫨"
-                  clearable
+                style="width: 100%"
+                v-model="form.entryDate"
+                value-format="YYYY-MM-DD"
+                format="YYYY-MM-DD"
+                type="date"
+                placeholder="璇烽�夋嫨"
+                clearable
               />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row>
+          <el-col :span="24">
+            <el-form-item>
+              <template #label>
+                <span>瀹℃壒浜洪�夋嫨锛�</span>
+                <el-button type="primary" @click="addApproverNode" style="margin-left: 8px;">鏂板鑺傜偣</el-button>
+              </template>
+              <div style="display: flex; align-items: flex-end; flex-wrap: wrap;">
+                <div
+                  v-for="(node, index) in approverNodes"
+                  :key="node.id"
+                  style="margin-right: 30px; text-align: center; margin-bottom: 10px;"
+                >
+                  <div>
+                    <span>瀹℃壒浜�</span>
+                    鈫�
+                  </div>
+                  <el-select
+                    v-model="node.userId"
+                    placeholder="閫夋嫨浜哄憳"
+                    style="width: 140px; margin-bottom: 8px;"
+                  >
+                    <el-option
+                      v-for="user in userList"
+                      :key="user.userId"
+                      :label="user.nickName"
+                      :value="user.userId"
+                    />
+                  </el-select>
+                  <div>
+                    <el-button
+                      type="danger"
+                      size="small"
+                      @click="removeApproverNode(index)"
+                      v-if="approverNodes.length > 1"
+                    >鍒犻櫎</el-button>
+                  </div>
+                </div>
+              </div>
             </el-form-item>
           </el-col>
         </el-row>
         <el-row>
           <el-form-item label="浜у搧淇℃伅锛�" prop="entryDate">
             <el-button type="primary" @click="openProductForm('add')"
-            >娣诲姞</el-button
+              >娣诲姞</el-button
             >
             <el-button plain type="danger" @click="deleteProduct"
-            >鍒犻櫎</el-button
+              >鍒犻櫎</el-button
             >
           </el-form-item>
-          <div class="select-button-group" style="width: 220px; margin: 20px 0;" v-if="operationType === 'add'">
-            <el-select
-                filterable
-                allow-create
-                :reserve-keyword="true"
-                :default-first-option="false"
-                v-model="templateName"
-                :input-value="filterInputValue"
-                @filter-change="onTemplateFilterChange"
-                @change="onTemplateChange"
-                style="width: 180px; border-right: none; border-radius: 4px 0 0 4px;"
-                placeholder="璇烽�夋嫨"
-                class="no-arrow-select"
-            >
-              <el-option
-                  v-for="item in templateList"
-                  :key="item.value"
-                  :label="item.templateName"
-                  :value="item.templateName"
-              ></el-option>
-            </el-select>
-            <!-- 鎸夐挳锛氫笌 Select 楂樺害鍖归厤锛屽幓鎺夊乏渚ц竟妗嗭紝鏃犵紳琛旀帴 -->
-            <el-button
-                size="small"
-                style="height: 32px; border-radius: 0 4px 4px 0; margin-left: -1px;"
-                @click="handleButtonClick"
-                :disabled="!templateName || templateName.trim() === '' || isTemplateNameDuplicate"
-            >
-              淇濆瓨
-            </el-button>
-          </div>
         </el-row>
         <el-table
-            :data="productData"
-            border
-            @selection-change="productSelected"
-            show-summary
-            :summary-method="summarizeProTable"
+          :data="productData"
+          border
+          @selection-change="productSelected"
+          show-summary
+          :summary-method="summarizeProTable"
         >
           <el-table-column align="center" type="selection" width="55" />
           <el-table-column
-              align="center"
-              label="搴忓彿"
-              type="index"
-              width="60"
+            align="center"
+            label="搴忓彿"
+            type="index"
+            width="60"
           />
           <el-table-column label="浜у搧澶х被" prop="productCategory" />
           <el-table-column label="瑙勬牸鍨嬪彿" prop="specificationModel" />
           <el-table-column label="鍗曚綅" prop="unit" width="70" />
           <el-table-column label="鏁伴噺" prop="quantity" width="70" />
-          <el-table-column label="搴撳瓨棰勮鏁伴噺" prop="warnNum" width="120" show-overflow-tooltip />
+					<el-table-column label="搴撳瓨棰勮鏁伴噺" prop="warnNum" width="120" show-overflow-tooltip />
           <el-table-column label="绋庣巼(%)" prop="taxRate" width="80" />
           <el-table-column
-              label="鍚◣鍗曚环(鍏�)"
-              prop="taxInclusiveUnitPrice"
-              :formatter="formattedNumber"
-              width="150"
+            label="鍚◣鍗曚环(鍏�)"
+            prop="taxInclusiveUnitPrice"
+            :formatter="formattedNumber"
+            width="150"
           />
           <el-table-column
-              label="鍚◣鎬讳环(鍏�)"
-              prop="taxInclusiveTotalPrice"
-              :formatter="formattedNumber"
-              width="150"
+            label="鍚◣鎬讳环(鍏�)"
+            prop="taxInclusiveTotalPrice"
+            :formatter="formattedNumber"
+            width="150"
           />
           <el-table-column
-              label="涓嶅惈绋庢�讳环(鍏�)"
-              prop="taxExclusiveTotalPrice"
-              :formatter="formattedNumber"
-              width="150"
+            label="涓嶅惈绋庢�讳环(鍏�)"
+            prop="taxExclusiveTotalPrice"
+            :formatter="formattedNumber"
+            width="150"
           />
           <el-table-column
-              fixed="right"
-              label="鎿嶄綔"
-              min-width="60"
-              align="center"
+            fixed="right"
+            label="鎿嶄綔"
+            min-width="60"
+            align="center"
           >
             <template #default="scope">
               <el-button
-                  link
-                  type="primary"
-                  size="small"
-                  @click="openProductForm('edit', scope.row, scope.$index)"
-              >缂栬緫</el-button
+                link
+                type="primary"
+                size="small"
+                @click="openProductForm('edit', scope.row, scope.$index)"
+                >缂栬緫</el-button
               >
             </template>
           </el-table-column>
@@ -438,11 +437,11 @@
           <el-col :span="24">
             <el-form-item label="澶囨敞路锛�" prop="remark">
               <el-input
-                  v-model="form.remark"
-                  placeholder="璇疯緭鍏�"
-                  clearable
-                  type="textarea"
-                  :rows="2"
+                v-model="form.remark"
+                placeholder="璇疯緭鍏�"
+                clearable
+                type="textarea"
+                :rows="2"
               />
             </el-form-item>
           </el-col>
@@ -451,16 +450,16 @@
           <el-col :span="24">
             <el-form-item label="闄勪欢鏉愭枡锛�" prop="remark">
               <el-upload
-                  v-model:file-list="fileList"
-                  :action="upload.url"
-                  multiple
-                  ref="fileUpload"
-                  auto-upload
-                  :headers="upload.headers"
-                  :before-upload="handleBeforeUpload"
-                  :on-error="handleUploadError"
-                  :on-success="handleUploadSuccess"
-                  :on-remove="handleRemove"
+                v-model:file-list="fileList"
+                :action="upload.url"
+                multiple
+                ref="fileUpload"
+                auto-upload
+                :headers="upload.headers"
+                :before-upload="handleBeforeUpload"
+                :on-error="handleUploadError"
+                :on-success="handleUploadSuccess"
+                :on-remove="handleRemove"
               >
                 <el-button type="primary">涓婁紶</el-button>
                 <template #tip>
@@ -482,30 +481,30 @@
       </template>
     </el-dialog>
     <el-dialog
-        v-model="productFormVisible"
-        :title="productOperationType === 'add' ? '鏂板浜у搧' : '缂栬緫浜у搧'"
-        width="40%"
-        @close="closeProductDia"
+      v-model="productFormVisible"
+      :title="productOperationType === 'add' ? '鏂板浜у搧' : '缂栬緫浜у搧'"
+      width="40%"
+      @close="closeProductDia"
     >
       <el-form
-          :model="productForm"
-          label-width="140px"
-          label-position="top"
-          :rules="productRules"
-          ref="productFormRef"
+        :model="productForm"
+        label-width="140px"
+        label-position="top"
+        :rules="productRules"
+        ref="productFormRef"
       >
         <el-row :gutter="30">
           <el-col :span="24">
             <el-form-item label="浜у搧澶х被锛�" prop="productId">
               <el-tree-select
-                  v-model="productForm.productId"
-                  placeholder="璇烽�夋嫨"
-                  clearable
-                  check-strictly
-                  @change="getModels"
-                  :data="productOptions"
-                  :render-after-expand="false"
-                  style="width: 100%"
+                v-model="productForm.productId"
+                placeholder="璇烽�夋嫨"
+                clearable
+                check-strictly
+                @change="getModels"
+                :data="productOptions"
+                :render-after-expand="false"
+                style="width: 100%"
               />
             </el-form-item>
           </el-col>
@@ -514,16 +513,16 @@
           <el-col :span="24">
             <el-form-item label="瑙勬牸鍨嬪彿锛�" prop="productModelId">
               <el-select
-                  v-model="productForm.productModelId"
-                  placeholder="璇烽�夋嫨"
-                  clearable
-                  @change="getProductModel"
+                v-model="productForm.productModelId"
+                placeholder="璇烽�夋嫨"
+                clearable
+                @change="getProductModel"
               >
                 <el-option
-                    v-for="item in modelOptions"
-                    :key="item.id"
-                    :label="item.model"
-                    :value="item.id"
+                  v-for="item in modelOptions"
+                  :key="item.id"
+                  :label="item.model"
+                  :value="item.id"
                 />
               </el-select>
             </el-form-item>
@@ -533,75 +532,75 @@
           <el-col :span="12">
             <el-form-item label="鍗曚綅锛�" prop="unit">
               <el-input
-                  v-model="productForm.unit"
-                  placeholder="璇疯緭鍏�"
-                  clearable
+                v-model="productForm.unit"
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
-          <el-col :span="12">
-            <el-form-item label="绋庣巼(%)锛�" prop="taxRate">
-              <el-select
-                  v-model="productForm.taxRate"
-                  placeholder="璇烽�夋嫨"
-                  clearable
-                  @change="mathNum"
-              >
-                <el-option label="1" value="1" />
-                <el-option label="6" value="6" />
-                <el-option label="13" value="13" />
-              </el-select>
-            </el-form-item>
-          </el-col>
+					<el-col :span="12">
+						<el-form-item label="绋庣巼(%)锛�" prop="taxRate">
+							<el-select
+								v-model="productForm.taxRate"
+								placeholder="璇烽�夋嫨"
+								clearable
+								@change="mathNum"
+							>
+								<el-option label="1" value="1" />
+								<el-option label="6" value="6" />
+								<el-option label="13" value="13" />
+							</el-select>
+						</el-form-item>
+					</el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
             <el-form-item label="鍚◣鍗曚环(鍏�)锛�" prop="taxInclusiveUnitPrice">
               <el-input-number
-                  v-model="productForm.taxInclusiveUnitPrice"
-                  :precision="2"
-                  :step="0.1"
-                  clearable
-                  style="width: 100%"
-                  @change="mathNum"
+                v-model="productForm.taxInclusiveUnitPrice"
+                :precision="2"
+                :step="0.1"
+                clearable
+                style="width: 100%"
+                @change="mathNum"
               />
             </el-form-item>
           </el-col>
-          <el-col :span="12">
-            <el-form-item label="鏁伴噺锛�" prop="quantity">
-              <el-input-number
-                  :step="0.1"
-                  clearable
-                  :precision="2"
-                  style="width: 100%"
-                  v-model="productForm.quantity"
-                  placeholder="璇疯緭鍏�"
-                  @change="mathNum"
-              />
-            </el-form-item>
-          </el-col>
+					<el-col :span="12">
+						<el-form-item label="鏁伴噺锛�" prop="quantity">
+							<el-input-number
+								:step="0.1"
+								clearable
+								:precision="2"
+								style="width: 100%"
+								v-model="productForm.quantity"
+								placeholder="璇疯緭鍏�"
+								@change="mathNum"
+							/>
+						</el-form-item>
+					</el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
             <el-form-item label="鍚◣鎬讳环(鍏�)锛�" prop="taxInclusiveTotalPrice">
               <el-input-number
-                  v-model="productForm.taxInclusiveTotalPrice"
-                  :precision="2"
-                  :step="0.1"
-                  clearable
-                  style="width: 100%"
-                  @change="reverseMathNum('taxInclusiveTotalPrice')"
+                v-model="productForm.taxInclusiveTotalPrice"
+                :precision="2"
+                :step="0.1"
+                clearable
+                style="width: 100%"
+                @change="reverseMathNum('taxInclusiveTotalPrice')"
               />
             </el-form-item>
           </el-col>
           <el-col :span="12">
             <el-form-item
-                label="涓嶅惈绋庢�讳环(鍏�)锛�"
-                prop="taxExclusiveTotalPrice"
+              label="涓嶅惈绋庢�讳环(鍏�)锛�"
+              prop="taxExclusiveTotalPrice"
             >
               <el-input
-                  v-model="productForm.taxExclusiveTotalPrice"
-                  @change="reverseMathNum('taxExclusiveTotalPrice')"
+                v-model="productForm.taxExclusiveTotalPrice"
+                @change="reverseMathNum('taxExclusiveTotalPrice')"
               />
             </el-form-item>
           </el-col>
@@ -610,26 +609,26 @@
           <el-col :span="12">
             <el-form-item label="鍙戠エ绫诲瀷锛�" prop="invoiceType">
               <el-select
-                  v-model="productForm.invoiceType"
-                  placeholder="璇烽�夋嫨"
-                  clearable
+                v-model="productForm.invoiceType"
+                placeholder="璇烽�夋嫨"
+                clearable
               >
                 <el-option label="澧炴櫘绁�" value="澧炴櫘绁�" />
                 <el-option label="澧炰笓绁�" value="澧炰笓绁�" />
               </el-select>
             </el-form-item>
           </el-col>
-          <el-col :span="12">
-            <el-form-item label="搴撳瓨棰勮鏁伴噺锛�" prop="warnNum">
-              <el-input-number
-                  v-model="productForm.warnNum"
-                  :precision="2"
-                  :step="0.1"
-                  clearable
-                  style="width: 100%"
-              />
-            </el-form-item>
-          </el-col>
+					<el-col :span="12">
+						<el-form-item label="搴撳瓨棰勮鏁伴噺锛�" prop="warnNum">
+							<el-input-number
+								v-model="productForm.warnNum"
+								:precision="2"
+								:step="0.1"
+								clearable
+								style="width: 100%"
+							/>
+						</el-form-item>
+					</el-col>
         </el-row>
       </el-form>
       <template #footer>
@@ -642,10 +641,10 @@
 
     <!-- 浜岀淮鐮佹樉绀哄璇濇 -->
     <el-dialog
-        v-model="qrCodeDialogVisible"
-        title="閲囪喘鍚堝悓鍙蜂簩缁寸爜"
-        width="400px"
-        center
+      v-model="qrCodeDialogVisible"
+      title="閲囪喘鍚堝悓鍙蜂簩缁寸爜"
+      width="400px"
+      center
     >
       <div style="text-align: center;">
         <img :src="qrCodeUrl" alt="浜岀淮鐮�" style="width:200px;height:200px;" />
@@ -657,27 +656,27 @@
 
     <!-- 鎵爜鏂板瀵硅瘽妗� -->
     <el-dialog
-        v-model="scanAddDialogVisible"
-        title="鎵爜鏂板閲囪喘鍙拌处"
-        width="70%"
-        @close="closeScanAddDialog"
+      v-model="scanAddDialogVisible"
+      title="鎵爜鏂板閲囪喘鍙拌处"
+      width="70%"
+      @close="closeScanAddDialog"
     >
       <el-form
-          :model="scanAddForm"
-          label-width="140px"
-          label-position="top"
-          :rules="scanAddRules"
-          ref="scanAddFormRef"
+        :model="scanAddForm"
+        label-width="140px"
+        label-position="top"
+        :rules="scanAddRules"
+        ref="scanAddFormRef"
       >
         <el-row :gutter="20">
           <el-col :span="24">
             <el-form-item label="鎵爜鍐呭锛�">
               <el-input
-                  v-model="scanAddForm.scanContent"
-                  type="textarea"
-                  :rows="3"
-                  placeholder="璇锋壂鎻忎簩缁寸爜鎴栨墜鍔ㄨ緭鍏ラ噰璐悎鍚屼俊鎭�"
-                  @input="parseScanContent"
+                v-model="scanAddForm.scanContent"
+                type="textarea"
+                :rows="3"
+                placeholder="璇锋壂鎻忎簩缁寸爜鎴栨墜鍔ㄨ緭鍏ラ噰璐悎鍚屼俊鎭�"
+                @input="parseScanContent"
               />
             </el-form-item>
           </el-col>
@@ -686,18 +685,18 @@
           <el-col :span="12">
             <el-form-item label="閲囪喘鍚堝悓鍙凤細" prop="purchaseContractNumber">
               <el-input
-                  v-model="scanAddForm.purchaseContractNumber"
-                  placeholder="璇疯緭鍏�"
-                  clearable
+                v-model="scanAddForm.purchaseContractNumber"
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
           <el-col :span="12">
             <el-form-item label="渚涘簲鍟嗗悕绉帮細" prop="supplierName">
               <el-input
-                  v-model="scanAddForm.supplierName"
-                  placeholder="璇疯緭鍏�"
-                  clearable
+                v-model="scanAddForm.supplierName"
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
@@ -706,21 +705,21 @@
           <el-col :span="12">
             <el-form-item label="椤圭洰鍚嶇О锛�" prop="projectName">
               <el-input
-                  v-model="scanAddForm.projectName"
-                  placeholder="璇疯緭鍏�"
-                  clearable
+                v-model="scanAddForm.projectName"
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
           <el-col :span="12">
             <el-form-item label="鍚堝悓閲戦(鍏�)锛�" prop="contractAmount">
               <el-input-number
-                  v-model="scanAddForm.contractAmount"
-                  :precision="2"
-                  :step="0.1"
-                  clearable
-                  style="width: 100%"
-                  placeholder="璇疯緭鍏�"
+                v-model="scanAddForm.contractAmount"
+                :precision="2"
+                :step="0.1"
+                clearable
+                style="width: 100%"
+                placeholder="璇疯緭鍏�"
               />
             </el-form-item>
           </el-col>
@@ -729,9 +728,9 @@
           <el-col :span="12">
             <el-form-item label="浠樻鏂瑰紡锛�">
               <el-input
-                  v-model="scanAddForm.paymentMethod"
-                  placeholder="璇疯緭鍏�"
-                  clearable
+                v-model="scanAddForm.paymentMethod"
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
@@ -745,11 +744,11 @@
           <el-col :span="24">
             <el-form-item label="澶囨敞锛�">
               <el-input
-                  v-model="scanAddForm.remark"
-                  type="textarea"
-                  :rows="2"
-                  placeholder="璇疯緭鍏ュ娉ㄤ俊鎭�"
-                  clearable
+                v-model="scanAddForm.remark"
+                type="textarea"
+                :rows="2"
+                placeholder="璇疯緭鍏ュ娉ㄤ俊鎭�"
+                clearable
               />
             </el-form-item>
           </el-col>
@@ -765,17 +764,17 @@
 
     <!-- 鎵爜鐧昏瀵硅瘽妗� -->
     <el-dialog
-        v-model="scanDialogVisible"
-        title="鎵爜鐧昏"
-        width="60%"
-        @close="closeScanDialog"
+      v-model="scanDialogVisible"
+      title="鎵爜鐧昏"
+      width="60%"
+      @close="closeScanDialog"
     >
       <el-form
-          :model="scanForm"
-          label-width="120px"
-          label-position="left"
-          :rules="scanRules"
-          ref="scanFormRef"
+        :model="scanForm"
+        label-width="120px"
+        label-position="left"
+        :rules="scanRules"
+        ref="scanFormRef"
       >
         <el-row :gutter="20">
           <el-col :span="12">
@@ -819,10 +818,10 @@
           <el-col :span="24">
             <el-form-item label="鎵爜澶囨敞锛�">
               <el-input
-                  v-model="scanForm.scanRemark"
-                  type="textarea"
-                  :rows="3"
-                  placeholder="璇疯緭鍏ユ壂鐮佸娉ㄤ俊鎭�"
+                v-model="scanForm.scanRemark"
+                type="textarea"
+                :rows="3"
+                placeholder="璇疯緭鍏ユ壂鐮佸娉ㄤ俊鎭�"
               />
             </el-form-item>
           </el-col>
@@ -854,42 +853,35 @@
         </div>
       </template>
     </el-dialog>
-
   </div>
 </template>
 
 <script setup>
-import {getToken} from "@/utils/auth";
+import { getToken } from "@/utils/auth";
 import pagination from "@/components/PIMTable/Pagination.vue";
-import {getCurrentInstance, nextTick, onMounted, reactive, ref, toRefs} from "vue";
-import {Search} from "@element-plus/icons-vue";
-import {ElMessage, ElMessageBox} from "element-plus";
-import {userListNoPage} from "@/api/system/user.js";
+import { ref, onMounted, reactive, toRefs, getCurrentInstance, nextTick } from "vue";
+import { Search } from "@element-plus/icons-vue";
+import { ElMessageBox } from "element-plus";
+import { userListNoPage } from "@/api/system/user.js";
 import {
-  addOrUpdateSalesLedgerProduct,
-  delLedgerFile,
-  delProduct,
-  getProductInfoByContractNo,
   getSalesLedgerWithProducts,
+  addOrUpdateSalesLedgerProduct,
+  delProduct,
+  delLedgerFile,
+  getProductInfoByContractNo,
 } from "@/api/salesManagement/salesLedger.js";
 import {
   addOrEditPurchase,
-  addPurchaseTemplate,
-  createPurchaseNo,
   delPurchase,
-  getOptions,
-  getPurchaseById,
-  getPurchaseTemplateList,
   getSalesNo,
+  purchaseListPage,
   productList,
-  purchaseListPage
+  getPurchaseById,
+  getOptions,
+  createPurchaseNo,
 } from "@/api/procurementManagement/procurementLedger.js";
 import useFormData from "@/hooks/useFormData.js";
 import QRCode from "qrcode";
-import useUserStore from "@/store/modules/user";
-import {modelList, productTreeList} from "@/api/basicData/product.js";
-import dayjs from "dayjs";
-
 const { proxy } = getCurrentInstance();
 const tableData = ref([]);
 const productData = ref([]);
@@ -907,109 +899,17 @@
 });
 const total = ref(0);
 const fileList = ref([]);
+const approverNodes = ref([{ id: 1, userId: null }]);
+let nextApproverId = 2;
+import useUserStore from "@/store/modules/user";
+import { modelList, productTreeList } from "@/api/basicData/product.js";
+import dayjs from "dayjs";
 
 const userStore = useUserStore();
 
 // 浜岀淮鐮佺浉鍏冲彉閲�
 const qrCodeDialogVisible = ref(false);
 const qrCodeUrl = ref("");
-
-// 璁㈠崟瀹℃壒鐘舵�佹樉绀烘枃鏈�
-const approvalStatusText = {
-  0: '瀹℃壒涓�',
-  1: '瀹℃壒閫氳繃',
-  2: '瀹℃壒澶辫触'
-};
-
-
-const templateName = ref('');
-const filterInputValue = ref('');
-const templateList = ref([]);
-const isTemplateNameDuplicate = ref(false); // 鏍囪妯℃澘鍚嶇О鏄惁閲嶅
-
-// 妫�鏌ユā鏉垮悕绉版槸鍚﹂噸澶�
-const checkTemplateNameDuplicate = (name) => {
-  if (!name || name.trim() === '') {
-    isTemplateNameDuplicate.value = false;
-    return false;
-  }
-  const isDuplicate = templateList.value.some(item => item.templateName === name.trim());
-  isTemplateNameDuplicate.value = isDuplicate;
-  return isDuplicate;
-};
-
-// 闃叉姈瀹氭椂鍣�
-let duplicateCheckTimer = null;
-const onTemplateFilterChange = (val) => {
-  filterInputValue.value = val ?? '';
-  // 娓呴櫎涔嬪墠鐨勫畾鏃跺櫒
-  if (duplicateCheckTimer) {
-    clearTimeout(duplicateCheckTimer);
-  }
-  // 瀹炴椂妫�鏌ユā鏉垮悕绉版槸鍚﹂噸澶嶏紙闃叉姈澶勭悊锛岄伩鍏嶉绻佹彁绀猴級
-  if (val && val.trim()) {
-    duplicateCheckTimer = setTimeout(() => {
-      const isDuplicate = checkTemplateNameDuplicate(val);
-      if (isDuplicate) {
-        ElMessage({
-          message: '妯℃澘鍚嶇О宸插瓨鍦紝璇锋洿鎹㈡ā鏉垮悕绉�',
-          type: 'warning',
-          duration: 2000
-        });
-      }
-    }, 300); // 300ms 闃叉姈
-  } else {
-    isTemplateNameDuplicate.value = false;
-  }
-};
-
-// allow-create 鏃讹紝杈撳叆涓嶅瓨鍦ㄧ殑鍐呭浼氫綔涓� string 鍊艰繑鍥烇紱杩欓噷鍚屾鍥炶緭鍏ユ浠ョ‘淇濇枃瀛椾笉涓�
-const onTemplateChange = async (val) => {
-  if (typeof val === 'string') {
-    filterInputValue.value = val;
-    // 閫夋嫨鎴栬緭鍏ユ椂妫�鏌ラ噸澶�
-    checkTemplateNameDuplicate(val);
-  }
-  
-  // 杩囨护鏁版嵁锛屾煡鎵惧尮閰嶇殑妯℃澘
-  const matchedTemplate = templateList.value.find(item => item.templateName === val);
-  
-  if (matchedTemplate?.id) {
-    // 濡傛灉鎵惧埌妯℃澘锛屽姞杞芥ā鏉挎暟鎹�
-    form.value = {
-      ...form.value,
-      ...matchedTemplate,
-    };
-    productData.value = matchedTemplate.productData || [];
-    // 鐢熸垚鏂扮殑閲囪喘鍚堝悓鍙�
-    try {
-      const res = await createPurchaseNo();
-      if (res?.data) {
-        form.value.purchaseContractNumber = res.data;
-      }
-    } catch (error) {
-      console.error('鐢熸垚閲囪喘鍚堝悓鍙峰け璐�:', error);
-    }
-  } else {
-    // 濡傛灉娌℃湁鎵惧埌妯℃澘锛岄噸缃〃鍗曪紙淇濇寔褰撳墠琛ㄥ崟鐘舵�侊級
-    const currentFormData = { ...form.value };
-    const currentProductData = [...productData.value];
-    
-    // 濡傛灉瀵硅瘽妗嗘湭鎵撳紑锛屽厛鎵撳紑
-    if (!dialogFormVisible.value) {
-      operationType.value = 'add';
-      dialogFormVisible.value = true;
-    }
-    
-    // 绛夊緟涓嬩竴涓� tick 鍚庢仮澶嶆暟鎹�
-    await nextTick();
-    form.value = {
-      ...form.value,
-      ...currentFormData,
-    };
-    productData.value = currentProductData;
-  }
-};
 
 // 鐢ㄦ埛淇℃伅琛ㄥ崟寮规鏁版嵁
 const operationType = ref("");
@@ -1034,7 +934,7 @@
     supplierName: "",
     supplierId: "",
     paymentMethod: "",
-    executionDate: "",
+		executionDate: "",
   },
   rules: {
     purchaseContractNumber: [
@@ -1042,13 +942,19 @@
     ],
     projectName: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
     supplierId: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    entryDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-    approverId:[{ required: true, message: "璇烽�夋嫨瀹℃壒浜�", trigger: "change" }],
-    executionDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+		entryDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+		executionDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
   },
 });
 const {  form, rules } = toRefs(data);
 const { form: searchForm } = useFormData(data.searchForm);
+
+const addApproverNode = () => {
+  approverNodes.value.push({ id: nextApproverId++, userId: null });
+};
+const removeApproverNode = (index) => {
+  approverNodes.value.splice(index, 1);
+};
 
 // 浜у搧琛ㄥ崟寮规鏁版嵁
 const productFormVisible = ref(false);
@@ -1068,7 +974,7 @@
     taxInclusiveTotalPrice: "",
     taxExclusiveTotalPrice: "",
     invoiceType: "",
-    warnNum: "",
+		warnNum: "",
   },
   productRules: {
     productId: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
@@ -1079,7 +985,7 @@
       { required: true, message: "璇疯緭鍏�", trigger: "blur" },
     ],
     taxRate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-    warnNum: [{ required: false, message: "璇烽�夋嫨", trigger: "change" }],
+		warnNum: [{ required: false, message: "璇烽�夋嫨", trigger: "change" }],
     taxInclusiveTotalPrice: [
       { required: true, message: "璇疯緭鍏�", trigger: "blur" },
     ],
@@ -1109,14 +1015,7 @@
 };
 
 const formattedNumber = (row, column, cellValue) => {
-  if (cellValue === null || cellValue === undefined || cellValue === '') {
-    return '0.00';
-  }
-  const num = parseFloat(cellValue);
-  if (isNaN(num)) {
-    return '0.00';
-  }
-  return num.toFixed(2);
+  return parseFloat(cellValue).toFixed(2);
 };
 // 鏌ヨ鍒楄〃
 /** 鎼滅储鎸夐挳鎿嶄綔 */
@@ -1124,100 +1023,23 @@
   page.current = 1;
   getList();
 };
-
-// 淇濆瓨妯℃澘
-const handleButtonClick = async () => {
-  // 妫�鏌ユā鏉垮悕绉版槸鍚︿负绌�
-  if (!templateName.value || templateName.value.trim() === '') {
-    ElMessage({
-      message: '璇疯緭鍏ユā鏉垮悕绉�',
-      type: 'warning',
-    });
-    return;
-  }
-
-  // 妫�鏌ユā鏉垮悕绉版槸鍚﹂噸澶�
-  const isDuplicate = checkTemplateNameDuplicate(templateName.value);
-  if (isDuplicate) {
-    ElMessage({
-      message: '妯℃澘鍚嶇О宸插瓨鍦紝璇锋洿鎹㈡ā鏉垮悕绉�',
-      type: 'warning',
-    });
-    return;
-  }
-
-  // 妫�鏌ヤ緵搴斿晢鏄惁閫夋嫨
-  if (!form.value.supplierId) {
-    ElMessage({
-      message: '璇峰厛閫夋嫨渚涘簲鍟�',
-      type: 'warning',
-    });
-    return;
-  }
-
-  // 妫�鏌ユ槸鍚︽湁浜у搧鏁版嵁
-  // if (!productData.value || productData.value.length === 0) {
-  //   ElMessage({
-  //     message: '璇峰厛娣诲姞浜у搧淇℃伅',
-  //     type: 'warning',
-  //   });
-  //   return;
-  // }
-
-  try {
-    let params = {
-      productData: proxy.HaveJson(productData.value),
-      supplierId: form.value.supplierId,
-      paymentMethod: form.value.paymentMethod,
-      recorderId: form.value.recorderId,
-      approverId: form.value.approverId,
-      templateName: templateName.value.trim()
-    };
-    console.log(params);
-    let res = await addPurchaseTemplate(params);
-
-    if (res && res.code === 200) {
-      ElMessage({
-        message: '妯℃澘淇濆瓨鎴愬姛',
-        type: 'success',
-      });
-      // 淇濆瓨鎴愬姛鍚庨噸鏂拌幏鍙栨ā鏉垮垪琛�
-      await getTemplateList();
-      // 娓呯┖妯℃澘鍚嶇О杈撳叆
-      templateName.value = '';
-      filterInputValue.value = '';
-      isTemplateNameDuplicate.value = false;
-    } else {
-      ElMessage({
-        message: res?.msg || '妯℃澘淇濆瓨澶辫触',
-        type: 'error',
-      });
-    }
-  } catch (error) {
-    console.error('淇濆瓨妯℃澘澶辫触:', error);
-    ElMessage({
-      message: '妯℃澘淇濆瓨澶辫触锛岃绋嶅悗閲嶈瘯',
-      type: 'error',
-    });
-  }
-};
 // 瀛愯〃鍚堣鏂规硶
 const summarizeChildrenTable = (param) => {
   return proxy.summarizeTable(
-      param,
-      [
-        "taxInclusiveUnitPrice",
-        "taxInclusiveTotalPrice",
-        "taxExclusiveTotalPrice",
-        "ticketsNum",
-        "ticketsAmount",
-        "futureTickets",
-        "futureTicketsAmount",
-      ],
-      {
-        ticketsNum: { noDecimal: true }, // 涓嶄繚鐣欏皬鏁�
-        futureTickets: { noDecimal: true }, // 涓嶄繚鐣欏皬鏁�
-      }
+    param,
+    [
+      "taxInclusiveUnitPrice",
+      "taxInclusiveTotalPrice",
+      "taxExclusiveTotalPrice",
+      "ticketsNum",
+      "ticketsAmount",
+      "futureTickets",
+      "futureTicketsAmount",
+    ],
+    {
+      ticketsNum: { noDecimal: true }, // 涓嶄繚鐣欏皬鏁�
+      futureTickets: { noDecimal: true }, // 涓嶄繚鐣欏皬鏁�
+    }
   );
 };
 const paginationChange = (obj) => {
@@ -1229,24 +1051,18 @@
   tableLoading.value = true;
   const { entryDate, ...rest } = searchForm;
   purchaseListPage({ ...rest, ...page })
-      .then((res) => {
-        tableLoading.value = false;
-        // tableData.value = res.data.records;
-        // 澶勭悊鏁版嵁锛屾坊鍔犲け鏁堢姸鎬佹爣璁�
-        tableData.value = res.data.records.map(record => ({
-          ...record,
-          isInvalid: record.isWhite === 1
-        }));
-        // 鍒濆鍖栧瓙鏁版嵁鏁扮粍
-        tableData.value.forEach((item) => {
-          item.children = [];
-        });
-        total.value = res.data.total;
-        expandedRowKeys.value = [];
-      })
-      .catch(() => {
-        tableLoading.value = false;
+    .then((res) => {
+      tableLoading.value = false;
+      tableData.value = res.data.records;
+      tableData.value.map((item) => {
+        item.children = [];
       });
+      total.value = res.data.total;
+      expandedRowKeys.value = [];
+    })
+    .catch(() => {
+      tableLoading.value = false;
+    });
 };
 // 琛ㄦ牸閫夋嫨鏁版嵁
 const handleSelectionChange = (selection) => {
@@ -1257,24 +1073,19 @@
 };
 const expandedRowKeys = ref([]);
 // 灞曞紑琛�
-const expandChange = async (row, expandedRows) => {
+const expandChange = (row, expandedRows) => {
   if (expandedRows.length > 0) {
     expandedRowKeys.value = [];
     try {
-      const res = await productList({ salesLedgerId: row.id, type: 2 });
-      const index = tableData.value.findIndex((item) => item.id === row.id);
-      if (index > -1) {
-        tableData.value[index].children = res.data || [];
+      productList({ salesLedgerId: row.id, type: 2 }).then((res) => {
+        const index = tableData.value.findIndex((item) => item.id === row.id);
+        if (index > -1) {
+          tableData.value[index].children = res.data;
+        }
         expandedRowKeys.value.push(row.id);
-      }
+      });
     } catch (error) {
-      console.error('鍔犺浇浜у搧鍒楄〃澶辫触:', error);
-      proxy.$modal.msgError('鍔犺浇浜у搧鍒楄〃澶辫触');
-      // 灞曞紑澶辫触鏃讹紝绉婚櫎灞曞紑鐘舵��
-      const index = expandedRows.findIndex(item => item.id === row.id);
-      if (index > -1) {
-        expandedRows.splice(index, 1);
-      }
+      console.log(error);
     }
   } else {
     expandedRowKeys.value = [];
@@ -1293,63 +1104,53 @@
   ]);
 };
 // 鎵撳紑寮规
-const openForm = async (type, row) => {
-  await getTemplateList()
+const openForm = (type, row) => {
   operationType.value = type;
   form.value = {};
   productData.value = [];
   fileList.value = [];
-  templateName.value = '';
-  filterInputValue.value = '';
-  isTemplateNameDuplicate.value = false;
-  try {
-    // 骞惰鍔犺浇鍩虹鏁版嵁
-    const [userRes, salesRes, supplierRes] = await Promise.all([
-      userListNoPage(),
-      getSalesNo(),
-      getOptions()
-    ]);
-    
-    userList.value = userRes.data || [];
-    salesContractList.value = salesRes || [];
-    // 渚涘簲鍟嗚繃婊ゅ嚭isWhite=0 鐨勬暟鎹�
-    supplierList.value = (supplierRes.data || []).filter((item) => item.isWhite === 0);
-    
-    // 璁剧疆榛樿鍊�
-    form.value.recorderId = userStore.id;
-    form.value.entryDate = getCurrentDate();
-    
-    if (type === "add") {
-      // 鏂板鏃剁敓鎴愰噰璐悎鍚屽彿
-      try {
-        const purchaseNoRes = await createPurchaseNo();
-        if (purchaseNoRes?.data) {
-          form.value.purchaseContractNumber = purchaseNoRes.data;
-        }
-      } catch (error) {
-        console.error('鐢熸垚閲囪喘鍚堝悓鍙峰け璐�:', error);
-        proxy.$modal.msgWarning('鐢熸垚閲囪喘鍚堝悓鍙峰け璐�');
-      }
-    } else if (type === "edit" && row?.id) {
-      // 缂栬緫鏃跺姞杞芥暟鎹�
-      currentId.value = row.id;
-      try {
-        const purchaseRes = await getPurchaseById({ id: row.id, type: 2 });
-        form.value = { ...purchaseRes };
-        productData.value = purchaseRes.productData || [];
-        fileList.value = purchaseRes.salesLedgerFiles || [];
-      } catch (error) {
-        console.error('鍔犺浇閲囪喘鍙拌处鏁版嵁澶辫触:', error);
-        proxy.$modal.msgError('鍔犺浇鏁版嵁澶辫触');
-        return;
-      }
-    }
-    
-    dialogFormVisible.value = true;
-  } catch (error) {
-    console.error('鎵撳紑琛ㄥ崟澶辫触:', error);
-    proxy.$modal.msgError('鍔犺浇鍩虹鏁版嵁澶辫触');
+  approverNodes.value = [{ id: 1, userId: null }];
+  nextApproverId = 2;
+  if (operationType.value == "add") {
+    createPurchaseNo().then((res) => {
+      form.value.purchaseContractNumber = res.data;
+    });
   }
+  userListNoPage().then((res) => {
+    userList.value = res.data;
+  });
+  getSalesNo().then((res) => {
+    salesContractList.value = res;
+  });
+  getOptions().then((res) => {
+    supplierList.value = res.data;
+  });
+  form.value.recorderId = userStore.id;
+  form.value.entryDate = getCurrentDate();
+  if (type === "edit") {
+    currentId.value = row.id;
+    getPurchaseById({ id: row.id, type: 2 }).then((res) => {
+      form.value = { ...res };
+      productData.value = form.value.productData;
+      const approveUserIds = form.value.approveUserIds || form.value.approverIds;
+      if (approveUserIds) {
+        const ids = String(approveUserIds)
+          .split(",")
+          .map((id) => Number(id.trim()))
+          .filter((id) => !Number.isNaN(id));
+        if (ids.length > 0) {
+          approverNodes.value = ids.map((id, idx) => ({ id: idx + 1, userId: id }));
+          nextApproverId = ids.length + 1;
+        }
+      }
+      if (form.value.salesLedgerFiles) {
+        fileList.value = form.value.salesLedgerFiles;
+      } else {
+        fileList.value = [];
+      }
+    });
+  }
+  dialogFormVisible.value = true;
 };
 // 涓婁紶鍓嶆牎妫�
 function handleBeforeUpload(file) {
@@ -1378,57 +1179,49 @@
   }
 }
 // 绉婚櫎鏂囦欢
-async function handleRemove(file) {
-  if (!file?.id) {
-    return;
-  }
-  
+function handleRemove(file) {
+  console.log("handleRemove", file.id);
   if (file.size > 1024 * 1024 * 10) {
     // 浠呭墠绔竻鐞嗭紝涓嶈皟鐢ㄥ垹闄ゆ帴鍙e拰鎻愮ず
     return;
   }
-  
-  if (operationType.value === "edit" && file.id) {
-    try {
-      await delLedgerFile([file.id]);
+  if (operationType.value === "edit") {
+    let ids = [];
+    ids.push(file.id);
+    delLedgerFile(ids).then((res) => {
       proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
-    } catch (error) {
-      console.error('鍒犻櫎鏂囦欢澶辫触:', error);
-      proxy.$modal.msgError("鍒犻櫎鏂囦欢澶辫触");
-    }
+    });
   }
 }
 // 鎻愪氦琛ㄥ崟
-const submitForm = async () => {
-  try {
-    const valid = await proxy.$refs["formRef"].validate().catch(() => false);
-    if (!valid) {
-      return;
+const submitForm = () => {
+  proxy.$refs["formRef"].validate((valid) => {
+    if (valid) {
+      const hasEmptyApprover = approverNodes.value.some((node) => !node.userId);
+      if (hasEmptyApprover) {
+        proxy.$modal.msgWarning("璇蜂负鎵�鏈夊鎵硅妭鐐归�夋嫨瀹℃壒浜�");
+        return;
+      }
+      form.value.approveUserIds = approverNodes.value.map((node) => node.userId).join(",");
+      if (productData.value.length > 0) {
+        form.value.productData = proxy.HaveJson(productData.value);
+      } else {
+        proxy.$modal.msgWarning("璇锋坊鍔犱骇鍝佷俊鎭�");
+        return;
+      }
+      let tempFileIds = [];
+      if (fileList.value.length > 0) {
+        tempFileIds = fileList.value.map((item) => item.tempId);
+      }
+      form.value.tempFileIds = tempFileIds;
+      form.value.type = 2;
+      addOrEditPurchase(form.value).then((res) => {
+        proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
+        closeDia();
+        getList();
+      });
     }
-    
-    if (!productData.value || productData.value.length === 0) {
-      proxy.$modal.msgWarning("璇锋坊鍔犱骇鍝佷俊鎭�");
-      return;
-    }
-    
-    form.value.productData = proxy.HaveJson(productData.value);
-    form.value.tempFileIds = fileList.value
-      .filter(item => item.tempId)
-      .map((item) => item.tempId);
-    form.value.type = 2;
-    
-    try {
-      await addOrEditPurchase(form.value);
-      proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
-      closeDia();
-      getList();
-    } catch (error) {
-      console.error('鎻愪氦琛ㄥ崟澶辫触:', error);
-      proxy.$modal.msgError("鎻愪氦澶辫触锛岃绋嶅悗閲嶈瘯");
-    }
-  } catch (error) {
-    console.error('琛ㄥ崟楠岃瘉澶辫触:', error);
-  }
+  });
 };
 // 鍏抽棴寮规
 const closeDia = () => {
@@ -1447,26 +1240,17 @@
   productFormVisible.value = true;
   getProductOptions();
 };
-const getProductOptions = async () => {
-  try {
-    const res = await productTreeList();
+const getProductOptions = () => {
+  productTreeList().then((res) => {
     productOptions.value = convertIdToValue(res);
-  } catch (error) {
-    console.error('鍔犺浇浜у搧閫夐」澶辫触:', error);
-    proxy.$modal.msgError('鍔犺浇浜у搧閫夐」澶辫触');
-  }
+  });
 };
-const getModels = async (value) => {
+const getModels = (value) => {
   if (value) {
     productForm.value.productCategory = findNodeById(productOptions.value, value) || "";
-    try {
-      const res = await modelList({ id: value });
-      modelOptions.value = res || [];
-    } catch (error) {
-      console.error('鍔犺浇瑙勬牸鍨嬪彿澶辫触:', error);
-      proxy.$modal.msgError('鍔犺浇瑙勬牸鍨嬪彿澶辫触');
-      modelOptions.value = [];
-    }
+    modelList({ id: value }).then((res) => {
+      modelOptions.value = res;
+    });
   } else {
     productForm.value.productCategory = "";
     modelOptions.value = [];
@@ -1511,103 +1295,75 @@
   });
 }
 // 鎻愪氦浜у搧琛ㄥ崟
-const submitProduct = async () => {
-  try {
-    const valid = await proxy.$refs["productFormRef"].validate().catch(() => false);
-    if (!valid) {
-      return;
-    }
-    
-    if (operationType.value === "edit") {
-      await submitProductEdit();
-    } else {
-      if (productOperationType.value === "add") {
-        productData.value.push({ ...productForm.value });
+const submitProduct = () => {
+  proxy.$refs["productFormRef"].validate((valid) => {
+    if (valid) {
+      if (operationType.value === "edit") {
+        submitProductEdit();
       } else {
-        productData.value[productOperationIndex.value] = {
-          ...productForm.value,
-        };
+        if (productOperationType.value === "add") {
+          productData.value.push({ ...productForm.value });
+          console.log("productData.value---", productData.value);
+        } else {
+          productData.value[productOperationIndex.value] = {
+            ...productForm.value,
+          };
+        }
+        closeProductDia();
       }
-      closeProductDia();
     }
-  } catch (error) {
-    console.error('鎻愪氦浜у搧琛ㄥ崟澶辫触:', error);
-  }
+  });
 };
-
-const submitProductEdit = async () => {
-  try {
-    productForm.value.salesLedgerId = currentId.value;
-    productForm.value.type = 2;
-    await addOrUpdateSalesLedgerProduct(productForm.value);
+const submitProductEdit = () => {
+  productForm.value.salesLedgerId = currentId.value;
+  productForm.value.type = 2;
+  addOrUpdateSalesLedgerProduct(productForm.value).then((res) => {
     proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
     closeProductDia();
-    
-    // 閲嶆柊鍔犺浇浜у搧鏁版嵁
-    try {
-      const res = await getPurchaseById({ id: currentId.value, type: 2 });
-      productData.value = res.productData || [];
-    } catch (error) {
-      console.error('閲嶆柊鍔犺浇浜у搧鏁版嵁澶辫触:', error);
-    }
-  } catch (error) {
-    console.error('鎻愪氦浜у搧缂栬緫澶辫触:', error);
-    proxy.$modal.msgError("鎻愪氦澶辫触锛岃绋嶅悗閲嶈瘯");
-  }
+    getPurchaseById({ id: currentId.value, type: 2 }).then((res) => {
+      productData.value = res.productData;
+    });
+  });
 };
 // 鍒犻櫎浜у搧
-const deleteProduct = async () => {
+const deleteProduct = () => {
   if (productSelectedRows.value.length === 0) {
     proxy.$modal.msgWarning("璇烽�夋嫨鏁版嵁");
     return;
   }
-  
   if (operationType.value === "add") {
-    // 鏂板妯″紡涓嬶紝鐩存帴浠庡墠绔暟鎹腑鍒犻櫎
     productSelectedRows.value.forEach((selectedRow) => {
       const index = productData.value.findIndex(
-          (product) => product.id === selectedRow.id
+        (product) => product.id === selectedRow.id
       );
       if (index !== -1) {
         productData.value.splice(index, 1);
       }
     });
-    proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
   } else {
-    // 缂栬緫妯″紡涓嬶紝闇�瑕佽皟鐢ㄦ帴鍙e垹闄�
-    const ids = productSelectedRows.value
-      .filter(item => item.id)
-      .map((item) => item.id);
-    
-    if (ids.length === 0) {
-      proxy.$modal.msgWarning("璇烽�夋嫨鏈夋晥鐨勬暟鎹�");
-      return;
+    let ids = [];
+    if (productSelectedRows.value.length > 0) {
+      ids = productSelectedRows.value.map((item) => item.id);
     }
-    
-    try {
-      await ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚垹闄わ紝鏄惁纭鍒犻櫎锛�", "鍒犻櫎纭", {
-        confirmButtonText: "纭",
-        cancelButtonText: "鍙栨秷",
-        type: "warning",
+    ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚垹闄わ紝鏄惁纭鍒犻櫎锛�", "瀵煎嚭", {
+      confirmButtonText: "纭",
+      cancelButtonText: "鍙栨秷",
+      type: "warning",
+    })
+      .then(() => {
+        delProduct(ids).then((res) => {
+          proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
+          closeProductDia();
+          getSalesLedgerWithProducts({ id: currentId.value, type: 2 }).then(
+            (res) => {
+              productData.value = res.productData;
+            }
+          );
+        });
+      })
+      .catch(() => {
+        proxy.$modal.msg("宸插彇娑�");
       });
-      
-      await delProduct(ids);
-      proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
-      closeProductDia();
-      
-      // 閲嶆柊鍔犺浇浜у搧鏁版嵁
-      try {
-        const res = await getSalesLedgerWithProducts({ id: currentId.value, type: 2 });
-        productData.value = res.productData || [];
-      } catch (error) {
-        console.error('閲嶆柊鍔犺浇浜у搧鏁版嵁澶辫触:', error);
-      }
-    } catch (error) {
-      if (error !== 'cancel') {
-        console.error('鍒犻櫎浜у搧澶辫触:', error);
-        proxy.$modal.msgError("鍒犻櫎澶辫触锛岃绋嶅悗閲嶈瘯");
-      }
-    }
   }
 };
 // 鍏抽棴浜у搧寮规
@@ -1616,71 +1372,62 @@
   productFormVisible.value = false;
 };
 // 瀵煎嚭
-const handleOut = async () => {
-  try {
-    await ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚鍑猴紝鏄惁纭瀵煎嚭锛�", "瀵煎嚭纭", {
-      confirmButtonText: "纭",
-      cancelButtonText: "鍙栨秷",
-      type: "warning",
+const handleOut = () => {
+  ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚鍑猴紝鏄惁纭瀵煎嚭锛�", "瀵煎嚭", {
+    confirmButtonText: "纭",
+    cancelButtonText: "鍙栨秷",
+    type: "warning",
+  })
+    .then(() => {
+      proxy.download("/purchase/ledger/export", {}, "閲囪喘鍙拌处.xlsx");
+    })
+    .catch(() => {
+      proxy.$modal.msg("宸插彇娑�");
     });
-    proxy.download("/purchase/ledger/export", {}, "閲囪喘鍙拌处.xlsx");
-  } catch (error) {
-    if (error !== 'cancel') {
-      console.error('瀵煎嚭澶辫触:', error);
-      proxy.$modal.msgError("瀵煎嚭澶辫触锛岃绋嶅悗閲嶈瘯");
-    }
-  }
 };
-
 // 鍒犻櫎
-const handleDelete = async () => {
-  if (selectedRows.value.length === 0) {
+const handleDelete = () => {
+  let ids = [];
+  if (selectedRows.value.length > 0) {
+		// 妫�鏌ユ槸鍚︽湁浠栦汉缁存姢鐨勬暟鎹�
+		const unauthorizedData = selectedRows.value.filter(item => item.recorderName !== userStore.nickName);
+		if (unauthorizedData.length > 0) {
+			proxy.$modal.msgWarning("涓嶅彲鍒犻櫎浠栦汉缁存姢鐨勬暟鎹�");
+			return;
+		}
+    ids = selectedRows.value.map((item) => item.id);
+  } else {
     proxy.$modal.msgWarning("璇烽�夋嫨鏁版嵁");
     return;
   }
-  
-  // 妫�鏌ユ槸鍚︽湁浠栦汉缁存姢鐨勬暟鎹�
-  const unauthorizedData = selectedRows.value.filter(item => item.recorderName !== userStore.nickName);
-  if (unauthorizedData.length > 0) {
-    proxy.$modal.msgWarning("涓嶅彲鍒犻櫎浠栦汉缁存姢鐨勬暟鎹�");
-    return;
-  }
-  
-  const ids = selectedRows.value
-    .filter(item => item.id)
-    .map((item) => item.id);
-  
-  if (ids.length === 0) {
-    proxy.$modal.msgWarning("璇烽�夋嫨鏈夋晥鐨勬暟鎹�");
-    return;
-  }
-  
-  try {
-    await ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚垹闄わ紝鏄惁纭鍒犻櫎锛�", "鍒犻櫎纭", {
-      confirmButtonText: "纭",
-      cancelButtonText: "鍙栨秷",
-      type: "warning",
+  ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚垹闄わ紝鏄惁纭鍒犻櫎锛�", "瀵煎嚭", {
+    confirmButtonText: "纭",
+    cancelButtonText: "鍙栨秷",
+    type: "warning",
+  })
+    .then(() => {
+      delPurchase(ids).then((res) => {
+        proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
+        getList();
+      });
+    })
+    .catch(() => {
+      proxy.$modal.msg("宸插彇娑�");
     });
-    
-    await delPurchase(ids);
-    proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
-    getList();
-  } catch (error) {
-    if (error !== 'cancel') {
-      console.error('鍒犻櫎澶辫触:', error);
-      proxy.$modal.msgError("鍒犻櫎澶辫触锛岃绋嶅悗閲嶈瘯");
-    }
-  }
 };
 // 鑾峰彇褰撳墠鏃ユ湡骞舵牸寮忓寲涓� YYYY-MM-DD
 function getCurrentDate() {
-  return dayjs().format("YYYY-MM-DD");
+  const today = new Date();
+  const year = today.getFullYear();
+  const month = String(today.getMonth() + 1).padStart(2, "0"); // 鏈堜唤浠�0寮�濮�
+  const day = String(today.getDate()).padStart(2, "0");
+  return `${year}-${month}-${day}`;
 }
 const mathNum = () => {
-  if (!productForm.value.taxRate) {
-    proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
-    return;
-  }
+	if (!productForm.value.taxRate) {
+		proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
+		return;
+	}
   if (!productForm.value.taxInclusiveUnitPrice) {
     return;
   }
@@ -1689,59 +1436,61 @@
   }
   // 鍚◣鎬讳环璁$畻
   productForm.value.taxInclusiveTotalPrice =
-      proxy.calculateTaxIncludeTotalPrice(
-          productForm.value.taxInclusiveUnitPrice,
-          productForm.value.quantity
-      );
+    proxy.calculateTaxIncludeTotalPrice(
+      productForm.value.taxInclusiveUnitPrice,
+      productForm.value.quantity
+    );
   if (productForm.value.taxRate) {
     // 涓嶅惈绋庢�讳环璁$畻
     productForm.value.taxExclusiveTotalPrice =
-        proxy.calculateTaxExclusiveTotalPrice(
-            productForm.value.taxInclusiveTotalPrice,
-            productForm.value.taxRate
-        );
+      proxy.calculateTaxExclusiveTotalPrice(
+        productForm.value.taxInclusiveTotalPrice,
+        productForm.value.taxRate
+      );
   }
 };
 const reverseMathNum = (field) => {
-  if (!productForm.value.taxRate) {
-    proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
-    return;
-  }
+	if (!productForm.value.taxRate) {
+		proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
+		return;
+	}
   const taxRate = Number(productForm.value.taxRate);
   if (!taxRate) return;
   if (field === 'taxInclusiveTotalPrice') {
     // 宸茬煡鍚◣鎬讳环鍜屾暟閲忥紝鍙嶇畻鍚◣鍗曚环
     if (productForm.value.quantity) {
       productForm.value.taxInclusiveUnitPrice =
-          (Number(productForm.value.taxInclusiveTotalPrice) / Number(productForm.value.quantity)).toFixed(2);
+        (Number(productForm.value.taxInclusiveTotalPrice) / Number(productForm.value.quantity)).toFixed(2);
     }
     // 宸茬煡鍚◣鎬讳环鍜屽惈绋庡崟浠凤紝鍙嶇畻鏁伴噺
     else if (productForm.value.taxInclusiveUnitPrice) {
       productForm.value.quantity =
-          (Number(productForm.value.taxInclusiveTotalPrice) / Number(productForm.value.taxInclusiveUnitPrice)).toFixed(2);
+        (Number(productForm.value.taxInclusiveTotalPrice) / Number(productForm.value.taxInclusiveUnitPrice)).toFixed(2);
     }
     // 鍙嶇畻涓嶅惈绋庢�讳环
     productForm.value.taxExclusiveTotalPrice =
-        (Number(productForm.value.taxInclusiveTotalPrice) / (1 + taxRate / 100)).toFixed(2);
+      (Number(productForm.value.taxInclusiveTotalPrice) / (1 + taxRate / 100)).toFixed(2);
   } else if (field === 'taxExclusiveTotalPrice') {
     // 鍙嶇畻鍚◣鎬讳环
     productForm.value.taxInclusiveTotalPrice =
-        (Number(productForm.value.taxExclusiveTotalPrice) * (1 + taxRate / 100)).toFixed(2);
+      (Number(productForm.value.taxExclusiveTotalPrice) * (1 + taxRate / 100)).toFixed(2);
     // 宸茬煡鏁伴噺锛屽弽绠楀惈绋庡崟浠�
     if (productForm.value.quantity) {
       productForm.value.taxInclusiveUnitPrice =
-          (Number(productForm.value.taxInclusiveTotalPrice) / Number(productForm.value.quantity)).toFixed(2);
+        (Number(productForm.value.taxInclusiveTotalPrice) / Number(productForm.value.quantity)).toFixed(2);
     }
     // 宸茬煡鍚◣鍗曚环锛屽弽绠楁暟閲�
     else if (productForm.value.taxInclusiveUnitPrice) {
       productForm.value.quantity =
-          (Number(productForm.value.taxInclusiveTotalPrice) / Number(productForm.value.taxInclusiveUnitPrice)).toFixed(2);
+        (Number(productForm.value.taxInclusiveTotalPrice) / Number(productForm.value.taxInclusiveUnitPrice)).toFixed(2);
     }
   }
 };
 // 閿�鍞悎鍚岄�夋嫨鏀瑰彉鏂规硶
 const salesLedgerChange = async (row) => {
-  const index = salesContractList.value.findIndex((item) => item.id === row);
+  console.log("row", row);
+  var index = salesContractList.value.findIndex((item) => item.id == row);
+  console.log("index", index);
   if (index > -1) {
     form.value.projectName = salesContractList.value[index].projectName;
     await querygProductInfoByContractNo();
@@ -1789,18 +1538,13 @@
     return;
   }
 
-  try {
-    const a = document.createElement('a');
-    a.href = qrCodeUrl.value;
-    a.download = `閲囪喘鍚堝悓鍙蜂簩缁寸爜_${dayjs().format('YYYYMMDDHHmmss')}.png`;
-    document.body.appendChild(a);
-    a.click();
-    document.body.removeChild(a);
-    proxy.$modal.msgSuccess("涓嬭浇鎴愬姛");
-  } catch (error) {
-    console.error('涓嬭浇浜岀淮鐮佸け璐�:', error);
-    proxy.$modal.msgError("涓嬭浇澶辫触锛岃绋嶅悗閲嶈瘯");
-  }
+  const a = document.createElement('a');
+  a.href = qrCodeUrl.value;
+  a.download = `閲囪喘鍚堝悓鍙蜂簩缁寸爜_${new Date().getTime()}.png`;
+  document.body.appendChild(a);
+  a.click();
+  document.body.removeChild(a);
+  proxy.$modal.msgSuccess("涓嬭浇鎴愬姛");
 };
 
 // 鎵爜鏂板瀵硅瘽妗嗙浉鍏冲彉閲�
@@ -1873,35 +1617,30 @@
 };
 
 // 鎻愪氦鎵爜鏂板
-const submitScanAdd = async () => {
-  try {
-    const valid = await proxy.$refs["scanAddFormRef"].validate().catch(() => false);
-    if (!valid) {
-      return;
-    }
-    
-    // 鏋勫缓鏂板鏁版嵁
-    const newData = {
-      purchaseContractNumber: scanAddForm.purchaseContractNumber,
-      supplierName: scanAddForm.supplierName,
-      projectName: scanAddForm.projectName,
-      contractAmount: scanAddForm.contractAmount,
-      paymentMethod: scanAddForm.paymentMethod,
-      recorderName: scanAddForm.recorderName,
-      entryDate: getCurrentDate(),
-      remark: scanAddForm.scanRemark,
-      type: 2
-    };
+const submitScanAdd = () => {
+  proxy.$refs["scanAddFormRef"].validate((valid) => {
+    if (valid) {
+      // 鏋勫缓鏂板鏁版嵁
+      const newData = {
+        purchaseContractNumber: scanAddForm.purchaseContractNumber,
+        supplierName: scanAddForm.supplierName,
+        projectName: scanAddForm.projectName,
+        contractAmount: scanAddForm.contractAmount,
+        paymentMethod: scanAddForm.paymentMethod,
+        recorderName: scanAddForm.recorderName,
+        entryDate: getCurrentDate(),
+        remark: scanAddForm.scanRemark,
+        type: 2
+      };
 
-    // await addOrEditPurchase(newData);
-    
-    proxy.$modal.msgSuccess("鎵爜鏂板鎴愬姛锛�");
-    closeScanAddDialog();
-    getList(); // 鍒锋柊鍒楄〃
-  } catch (error) {
-    console.error('鎻愪氦鎵爜鏂板澶辫触:', error);
-    proxy.$modal.msgError("鎻愪氦澶辫触锛岃绋嶅悗閲嶈瘯");
-  }
+      // 妯℃嫙鏂板鎴愬姛
+      proxy.$modal.msgSuccess("鎵爜鏂板鎴愬姛锛�");
+      closeScanAddDialog();
+
+      // 鍙互閫夋嫨鏄惁鍒锋柊鍒楄〃
+      // getList();
+    }
+  });
 };
 
 // 鎵撳紑鎵爜鐧昏瀵硅瘽妗�
@@ -1924,69 +1663,40 @@
 };
 
 // 鎻愪氦鎵爜鐧昏
-const submitScan = async () => {
-  try {
-    const valid = await proxy.$refs["scanFormRef"].validate().catch(() => false);
-    if (!valid) {
-      return;
+const submitScan = () => {
+  proxy.$refs["scanFormRef"].validate((valid) => {
+    if (valid) {
+      // 娣诲姞鎵爜璁板綍
+      scanRecords.value.push({
+        ...scanForm,
+        id: Date.now(), // 妯℃嫙ID
+        scanTime: getCurrentDateTime(),
+      });
+      scanForm.scanStatus = "宸叉壂鐮�";
+      scanForm.scanRemark = scanForm.scanRemark || "鏃�";
+      proxy.$modal.msgSuccess("鎵爜鐧昏鎴愬姛锛�");
+      closeScanDialog();
     }
-    
-    // 娣诲姞鎵爜璁板綍
-    scanRecords.value.push({
-      ...scanForm,
-      id: Date.now(), // 妯℃嫙ID
-      scanTime: getCurrentDateTime(),
-    });
-    scanForm.scanStatus = "宸叉壂鐮�";
-    scanForm.scanRemark = scanForm.scanRemark || "鏃�";
-    proxy.$modal.msgSuccess("鎵爜鐧昏鎴愬姛锛�");
-    closeScanDialog();
-  } catch (error) {
-    console.error('鎻愪氦鎵爜鐧昏澶辫触:', error);
-    proxy.$modal.msgError("鎻愪氦澶辫触锛岃绋嶅悗閲嶈瘯");
-  }
+  });
 };
 
 // 鑾峰彇褰撳墠鏃ユ湡鏃堕棿
 function getCurrentDateTime() {
-  return dayjs().format("YYYY-MM-DD HH:mm:ss");
+  const now = new Date();
+  const year = now.getFullYear();
+  const month = String(now.getMonth() + 1).padStart(2, "0");
+  const day = String(now.getDate()).padStart(2, "0");
+  const hours = String(now.getHours()).padStart(2, "0");
+  const minutes = String(now.getMinutes()).padStart(2, "0");
+  const seconds = String(now.getSeconds()).padStart(2, "0");
+  return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
 }
 
-// 娣诲姞琛岀被鍚嶆柟娉�
-const tableRowClassName = ({ row }) => {
-  return row.isInvalid ? 'invalid-row' : '';
-};
 
-// 鑾峰彇妯℃澘淇℃伅
-const getTemplateList =async ()=>{
-  let res = await getPurchaseTemplateList()
-  if(res && res.code===200 && Array.isArray(res.data)){
-    templateList.value = res.data
-  }
-}
 
 onMounted(() => {
   getList();
-  getTemplateList();
-
 });
 </script>
 
-<style scoped lang="scss">
-.invalid-row {
-  opacity: 0.6;
-  background-color: #f5f7fa;
-}
-.el-row{
-  justify-content: space-between;
-  align-items: center
-}
-.no-arrow-select {
-  --el-select-suffix-icon-color: transparent; /* 闅愯棌榛樿涓嬫媺绠ご */
-}
-.select-button-group {
-  display: flex;
-  align-items: center;
-}
-
-</style>
+<style scoped lang="scss"></style>
diff --git a/src/views/salesManagement/invoiceRegistration/index.vue b/src/views/salesManagement/invoiceRegistration/index.vue
index 8bf1236..7823098 100644
--- a/src/views/salesManagement/invoiceRegistration/index.vue
+++ b/src/views/salesManagement/invoiceRegistration/index.vue
@@ -437,6 +437,7 @@
   searchForm: {
     customerName: "",
     status: false,
+    approvalStatus: 2,
     customerContractNo: undefined, // 瀹㈡埛鍚堝悓鍙�
     projectName: undefined, // 椤圭洰鍚嶇О
     createUer: undefined, // 鐧昏浜�
diff --git a/src/views/salesManagement/salesLedger/index.vue b/src/views/salesManagement/salesLedger/index.vue
index ab7b9d6..7b45b73 100644
--- a/src/views/salesManagement/salesLedger/index.vue
+++ b/src/views/salesManagement/salesLedger/index.vue
@@ -1,48 +1,29 @@
 <template>
   <div class="app-container">
     <div class="search_form">
-      <el-form :model="searchForm"
-               :inline="true">
+      <el-form :model="searchForm" :inline="true">
         <el-form-item label="瀹㈡埛鍚嶇О锛�">
-          <el-input v-model="searchForm.customerName"
-                    placeholder="璇疯緭鍏�"
-                    clearable
-                    prefix-icon="Search"
-                    @change="handleQuery" />
+          <el-input v-model="searchForm.customerName" placeholder="璇疯緭鍏�" clearable prefix-icon="Search"
+            @change="handleQuery" />
         </el-form-item>
         <el-form-item label="瀹㈡埛鍚堝悓鍙凤細">
-          <el-input v-model="searchForm.customerContractNo"
-                    placeholder="璇疯緭鍏�"
-                    clearable
-                    prefix-icon="Search"
-                    @change="handleQuery" />
+          <el-input v-model="searchForm.customerContractNo" placeholder="璇疯緭鍏�" clearable prefix-icon="Search"
+            @change="handleQuery" />
         </el-form-item>
         <el-form-item label="閿�鍞悎鍚屽彿锛�">
-          <el-input v-model="searchForm.salesContractNo"
-                    placeholder="璇疯緭鍏�"
-                    clearable
-                    prefix-icon="Search"
-                    @change="handleQuery" />
+          <el-input v-model="searchForm.salesContractNo" placeholder="璇疯緭鍏�" clearable prefix-icon="Search"
+            @change="handleQuery" />
         </el-form-item>
         <el-form-item label="椤圭洰鍚嶇О锛�">
-          <el-input v-model="searchForm.projectName"
-                    placeholder="璇疯緭鍏�"
-                    clearable
-                    prefix-icon="Search"
-                    @change="handleQuery" />
+          <el-input v-model="searchForm.projectName" placeholder="璇疯緭鍏�" clearable prefix-icon="Search"
+            @change="handleQuery" />
         </el-form-item>
         <el-form-item label="褰曞叆鏃ユ湡锛�">
-          <el-date-picker v-model="searchForm.entryDate"
-                          value-format="YYYY-MM-DD"
-                          format="YYYY-MM-DD"
-                          type="daterange"
-                          placeholder="璇烽�夋嫨"
-                          clearable
-                          @change="changeDaterange" />
+          <el-date-picker v-model="searchForm.entryDate" value-format="YYYY-MM-DD" format="YYYY-MM-DD" type="daterange"
+            placeholder="璇烽�夋嫨" clearable @change="changeDaterange" />
         </el-form-item>
         <el-form-item>
-          <el-button type="primary"
-                     @click="handleQuery"> 鎼滅储 </el-button>
+          <el-button type="primary" @click="handleQuery"> 鎼滅储 </el-button>
         </el-form-item>
       </el-form>
     </div>
@@ -50,254 +31,125 @@
       <div class="actions">
         <div></div>
         <div>
-          <el-button type="primary"
-                     @click="openForm('add')">
+          <el-button type="primary" @click="openForm('add')">
             鏂板鍙拌处
           </el-button>
           <el-button @click="handleOut">瀵煎嚭</el-button>
-          <el-button type="danger"
-                     plain
-                     @click="handleDelete">鍒犻櫎</el-button>
-          <el-button type="primary"
-                     plain
-                     @click="handlePrint">鎵撳嵃</el-button>
+          <el-button type="danger" plain @click="handleDelete">鍒犻櫎</el-button>
+          <el-button type="primary" plain @click="handlePrint">鎵撳嵃</el-button>
         </div>
       </div>
-      <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"
-                @expand-change="expandChange"
-                height="calc(100vh - 18.5em)">
-        <el-table-column align="center"
-                         type="selection"
-                         width="55" />
+      <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" @expand-change="expandChange" height="calc(100vh - 18.5em)">
+        <el-table-column align="center" type="selection" width="55" />
         <el-table-column type="expand">
           <template #default="props">
-            <el-table :data="props.row.children"
-                      border
-                      show-summary
-                      :summary-method="summarizeChildrenTable">
-              <el-table-column align="center"
-                               label="搴忓彿"
-                               type="index"
-                               width="60" />
-              <el-table-column label="浜у搧澶х被"
-                               prop="productCategory" />
-              <el-table-column label="瑙勬牸鍨嬪彿"
-                               prop="specificationModel" />
-              <el-table-column label="鍗曚綅"
-                               prop="unit" />
-              <el-table-column label="鐢熶骇鐘舵��"
-                               width="100px"
-                               align="center">
-                <template #default="scope">
-                  <el-tag v-if="scope.row.productionStatus === '宸插畬鎴�'"
-                          type="success">宸插畬鎴�</el-tag>
-                  <el-tag v-if="scope.row.productionStatus === '鐢熶骇涓�'"
-                          type="warning">鐢熶骇涓�</el-tag>
-                  <el-tag v-if="scope.row.productionStatus === '鏈紑濮�'"
-                          type="danger">鏈紑濮�</el-tag>
-                  <el-tag v-if="!scope.row.productionStatus"
-                          type="info">鏆傛棤鐘舵��</el-tag>
-                </template>
-              </el-table-column>
-              <el-table-column label="浜у搧鐘舵��"
-                               width="100px"
-                               align="center">
-                <template #default="scope">
-                  <el-tag v-if="scope.row.approveStatus === 0"
-                          type="info">鏈嚭搴�</el-tag>
-                  <el-tag v-if="scope.row.approveStatus === 1"
-                          type="success">宸插嚭搴�</el-tag>
-                  <el-tag v-if="scope.row.approveStatus === 2"
-                          type="warning">瀹℃牳涓�</el-tag>
-                  <el-tag v-if="scope.row.approveStatus === 3"
-                          type="success">瀹℃牳鎴愬姛</el-tag>
-                  <el-tag v-if="scope.row.approveStatus === 4"
-                          type="danger">瀹℃牳澶辫触</el-tag>
-                </template>
-              </el-table-column>
-              <el-table-column label="鍙戣揣杞︾墝"
-                               minWidth="100px"
-                               align="center">
-                <template #default="scope">
-                  <div>
-                    <el-tag type="success"
-                            v-if="scope.row.shippingCarNumber">{{ scope.row.shippingCarNumber }}</el-tag>
-                    <el-tag v-else
-                            type="info">鏈彂璐�</el-tag>
-                  </div>
-                </template>
-              </el-table-column>
-              <el-table-column label="鍙戣揣鏃ユ湡"
-                               minWidth="100px"
-                               align="center">
-                <template #default="scope">
-                  <div>
-                    <div v-if="scope.row.shippingDate">{{ scope.row.shippingDate }}</div>
-                    <el-tag v-else
-                            type="info">鏈彂璐�</el-tag>
-                  </div>
-                </template>
-              </el-table-column>
-              <el-table-column label="鏁伴噺"
-                               prop="quantity" />
-              <el-table-column label="绋庣巼(%)"
-                               prop="taxRate" />
-              <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 Width="60px"
-                               label="鎿嶄綔"
-                               align="center">
-                <template #default="scope">
-                  <el-button :disabled="scope.row.approveStatus===2 || scope.row.approveStatus===5"
-                             link
-                             type="primary"
-                             size="small"
-                             @click="openDeliveryForm(scope.row)">鍙戣揣</el-button>
-                </template>
-              </el-table-column>
+            <el-table :data="props.row.children" border show-summary :summary-method="summarizeChildrenTable" style="min-width: 1200px;"
+                      scrollbar-always-on>
+              <el-table-column align="center" label="搴忓彿" type="index" width="70" />
+              <el-table-column label="浜у搧澶х被" prop="productCategory" width="160" />
+              <el-table-column label="瑙勬牸鍨嬪彿" prop="specificationModel" width="220" />
+              <el-table-column label="鍗曚綅" prop="unit" width="100" />
+              <el-table-column label="鏁伴噺" prop="quantity" width="120" />
+              <el-table-column label="绋庣巼(%)" prop="taxRate" width="120" />
+              <el-table-column label="鍚◣鍗曚环(鍏�)" prop="taxInclusiveUnitPrice" :formatter="formattedNumber" width="160" />
+              <el-table-column label="鍚◣鎬讳环(鍏�)" prop="taxInclusiveTotalPrice" :formatter="formattedNumber" width="180" />
+              <el-table-column label="涓嶅惈绋庢�讳环(鍏�)" prop="taxExclusiveTotalPrice" :formatter="formattedNumber" width="180" />
+<!--              <el-table-column fixed="right" label="鎿嶄綔" width="150" align="center">-->
+<!--                <template #default="scope">-->
+<!--                  <el-button link type="primary" size="small" @click="openDeliveryForm(props.row, scope.row)">鍙戣揣</el-button>-->
+<!--                </template>-->
+<!--              </el-table-column>-->
             </el-table>
           </template>
         </el-table-column>
-        <el-table-column align="center"
-                         label="搴忓彿"
-                         type="index"
-                         width="60" />
-        <el-table-column label="閿�鍞悎鍚屽彿"
-                         prop="salesContractNo"
-                         width="180"
-                         show-overflow-tooltip />
-        <el-table-column label="瀹㈡埛鍚堝悓鍙�"
-                         prop="customerContractNo"
-                         width="180"
-                         show-overflow-tooltip />
-        <el-table-column label="瀹㈡埛鍚嶇О"
-                         prop="customerName"
-                         width="300"
-                         show-overflow-tooltip />
-        <el-table-column label="涓氬姟鍛�"
-                         prop="salesman"
-                         width="100"
-                         show-overflow-tooltip />
-        <el-table-column label="椤圭洰鍚嶇О"
-                         prop="projectName"
-                         width="180"
-                         show-overflow-tooltip />
-        <el-table-column label="浠樻鏂瑰紡"
-                         prop="paymentMethod"
-                         show-overflow-tooltip />
-        <el-table-column label="鍚堝悓閲戦(鍏�)"
-                         prop="contractAmount"
-                         width="220"
-                         show-overflow-tooltip
-                         :formatter="formattedNumber" />
-        <el-table-column label="褰曞叆浜�"
-                         prop="entryPersonName"
-                         width="100"
-                         show-overflow-tooltip />
-        <el-table-column label="褰曞叆鏃ユ湡"
-                         prop="entryDate"
-                         width="120"
-                         show-overflow-tooltip />
-        <el-table-column label="绛捐鏃ユ湡"
-                         prop="executionDate"
-                         width="120"
-                         show-overflow-tooltip />
-        <el-table-column fixed="right"
-                         label="鎿嶄綔"
-                         min-width="100"
-                         align="center">
+        <el-table-column align="center" label="搴忓彿" type="index" width="60" />
+        <el-table-column label="閿�鍞悎鍚屽彿" prop="salesContractNo" width="180" show-overflow-tooltip />
+        <el-table-column label="瀹㈡埛鍚堝悓鍙�" prop="customerContractNo" width="180" show-overflow-tooltip />
+        <el-table-column label="瀹㈡埛鍚嶇О" prop="customerName" width="300" show-overflow-tooltip />
+        <el-table-column label="涓氬姟鍛�" prop="salesman" width="100" show-overflow-tooltip />
+        <el-table-column label="椤圭洰鍚嶇О" prop="projectName" width="180" show-overflow-tooltip />
+        <el-table-column label="瀹℃牳鐘舵��" width="140">
           <template #default="scope">
-            <el-button link
-                       type="primary"
-                       size="small"
-                       @click="openForm('edit', scope.row)">缂栬緫</el-button>
-            <!--            <el-button link type="primary" size="small" @click="openForm('view', scope.row)">璇︽儏</el-button>-->
-            <el-button link
-                       type="primary"
-                       size="small"
-                       @click="downLoadFile(scope.row)">闄勪欢</el-button>
-            <!--            <el-button link type="primary" size="small" @click="openDeliveryForm(scope.row)">鍙戣揣</el-button>-->
+
+              <el-tag
+                v-if="(scope.row.approveStatus ?? scope.row.approvalStatus) == 0"
+                type="warning"
+              >寰呭鏍�</el-tag>
+              <el-tag
+                v-else-if="(scope.row.approveStatus ?? scope.row.approvalStatus) == 1"
+                type="primary"
+              >瀹℃牳涓�</el-tag>
+              <el-tag
+                v-else-if="(scope.row.approveStatus ?? scope.row.approvalStatus) == 2"
+                type="success"
+              >瀹℃牳瀹屾垚</el-tag>
+              <el-tag
+                v-else-if="(scope.row.approveStatus ?? scope.row.approvalStatus) == 3"
+                type="danger"
+              >瀹℃牳鏈�氳繃</el-tag>
+              <el-tag
+                v-else-if="(scope.row.approveStatus ?? scope.row.approvalStatus) == 4"
+                type="info"
+              >宸查噸鏂版彁浜�</el-tag>
+              <el-tag v-else type="info">-</el-tag>
+
+          </template>
+        </el-table-column>
+        <el-table-column label="閿�鍞被鍨�" width="120">
+          <template #default="scope">
+            <el-tag
+              :type="scope.row.salesType === '绱ф��' ? 'danger' : 'info'"
+            >{{ scope.row.salesType || '-' }}</el-tag>
+          </template>
+        </el-table-column>
+        <el-table-column label="浠樻鏂瑰紡" prop="paymentMethod" show-overflow-tooltip />
+        <el-table-column label="鍚堝悓閲戦(鍏�)" prop="contractAmount" width="220" show-overflow-tooltip
+          :formatter="formattedNumber" />
+        <el-table-column label="褰曞叆浜�" prop="entryPersonName" width="100" show-overflow-tooltip />
+        <el-table-column label="褰曞叆鏃ユ湡" prop="entryDate" width="120" show-overflow-tooltip />
+        <el-table-column label="绛捐鏃ユ湡" prop="executionDate" width="120" show-overflow-tooltip />
+        <el-table-column fixed="right" label="鎿嶄綔" min-width="150" align="center">
+          <template #default="scope">
+            <el-button link type="primary" size="small" @click="openForm('edit', scope.row)">缂栬緫</el-button>
+<!--            <el-button link type="primary" size="small" @click="openForm('view', scope.row)">璇︽儏</el-button>-->
+            <el-button link type="primary" size="small" @click="downLoadFile(scope.row)">闄勪欢</el-button>
+            <el-button link type="primary" size="small" @click="openDeliveryForm(scope.row)">鍙戣揣</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" />
+      <pagination v-show="total > 0" :total="total" layout="total, sizes, prev, pager, next, jumper"
+        :page="page.current" :limit="page.size" @pagination="paginationChange" />
     </div>
-    <el-dialog v-model="dialogFormVisible"
-               :title="operationType === 'add' ? '鏂板閿�鍞彴璐﹂〉闈�' : '缂栬緫閿�鍞彴璐﹂〉闈�'"
-               width="70%"
-               @close="closeDia">
-      <el-form :model="form"
-               label-width="140px"
-               label-position="top"
-               :rules="rules"
-               ref="formRef">
+    <el-dialog v-model="dialogFormVisible" :title="operationType === 'add' ? '鏂板閿�鍞彴璐﹂〉闈�' : '缂栬緫閿�鍞彴璐﹂〉闈�'" width="70%"
+      @close="closeDia">
+      <el-form :model="form" label-width="140px" label-position="top" :rules="rules" ref="formRef">
         <el-row :gutter="30">
           <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="salesman">
-              <el-select v-model="form.salesman"
-                         placeholder="璇烽�夋嫨"
-                         clearable
-                         :disabled="operationType === 'view'">
-                <el-option v-for="item in userList"
-                           :key="item.nickName"
-                           :label="item.nickName"
-                           :value="item.nickName" />
+            <el-form-item label="涓氬姟鍛橈細" prop="salesman">
+              <el-select v-model="form.salesman" placeholder="璇烽�夋嫨" clearable :disabled="operationType === 'view'">
+                <el-option v-for="item in userList" :key="item.nickName" :label="item.nickName"
+                  :value="item.nickName" />
               </el-select>
             </el-form-item>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="瀹㈡埛鍚堝悓鍙凤細"
-                          prop="customerContractNo">
-              <el-input v-model="form.customerContractNo"
-                        placeholder="璇疯緭鍏�"
-                        clearable
-                        :disabled="operationType === 'view'" />
+            <el-form-item label="瀹㈡埛鍚堝悓鍙凤細" prop="customerContractNo">
+              <el-input v-model="form.customerContractNo" placeholder="璇疯緭鍏�" clearable :disabled="operationType === 'view'"/>
             </el-form-item>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="瀹㈡埛鍚嶇О锛�"
-                          prop="customerId">
-              <el-select v-model="form.customerId"
-                         placeholder="璇烽�夋嫨"
-                         clearable
-                         :disabled="operationType === 'view'">
-                <el-option v-for="item in customerOption"
-                           :key="item.id"
-                           :label="item.customerName"
-                           :value="item.id">
+            <el-form-item label="瀹㈡埛鍚嶇О锛�" prop="customerId">
+              <el-select v-model="form.customerId" placeholder="璇烽�夋嫨" clearable :disabled="operationType === 'view'">
+                <el-option v-for="item in customerOption" :key="item.id" :label="item.customerName" :value="item.id">
                   {{
                     item.customerName + "鈥斺��" + item.taxpayerIdentificationNumber
                   }}
@@ -308,155 +160,134 @@
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="椤圭洰鍚嶇О锛�"
-                          prop="projectName">
-              <el-input v-model="form.projectName"
-                        placeholder="璇疯緭鍏�"
-                        clearable
-                        :disabled="operationType === 'view'" />
+            <el-form-item label="椤圭洰鍚嶇О锛�" prop="projectName">
+              <el-input v-model="form.projectName" placeholder="璇疯緭鍏�" clearable :disabled="operationType === 'view'" />
             </el-form-item>
           </el-col>
-          <el-col :span="12">
-            <el-form-item label="绛捐鏃ユ湡锛�"
-                          prop="executionDate">
-              <el-date-picker style="width: 100%"
-                              v-model="form.executionDate"
-                              value-format="YYYY-MM-DD"
-                              format="YYYY-MM-DD"
-                              type="date"
-                              placeholder="璇烽�夋嫨"
-                              clearable
-                              :disabled="operationType === 'view'" />
-            </el-form-item>
-          </el-col>
+					<el-col :span="12">
+						<el-form-item label="绛捐鏃ユ湡锛�" prop="executionDate">
+							<el-date-picker style="width: 100%" v-model="form.executionDate" value-format="YYYY-MM-DD"
+															format="YYYY-MM-DD" type="date" placeholder="璇烽�夋嫨" clearable :disabled="operationType === 'view'" />
+						</el-form-item>
+					</el-col>
         </el-row>
         <el-row :gutter="30">
+					<el-col :span="12">
+						<el-form-item label="褰曞叆浜猴細" prop="entryPerson">
+							<el-select v-model="form.entryPerson" placeholder="璇烽�夋嫨" clearable @change="changs" disabled>
+								<el-option v-for="item in userList" :key="item.userId" :label="item.nickName" :value="item.userId" />
+							</el-select>
+						</el-form-item>
+					</el-col>
           <el-col :span="12">
-            <el-form-item label="褰曞叆浜猴細"
-                          prop="entryPerson">
-              <el-select v-model="form.entryPerson"
-                         placeholder="璇烽�夋嫨"
-                         clearable
-                         @change="changs"
-                         disabled>
-                <el-option v-for="item in userList"
-                           :key="item.userId"
-                           :label="item.nickName"
-                           :value="item.userId" />
-              </el-select>
-            </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"
-                              value-format="YYYY-MM-DD"
-                              format="YYYY-MM-DD"
-                              type="date"
-                              placeholder="璇烽�夋嫨"
-                              clearable />
+            <el-form-item label="褰曞叆鏃ユ湡锛�" prop="entryDate">
+              <el-date-picker style="width: 100%" v-model="form.entryDate" value-format="YYYY-MM-DD" format="YYYY-MM-DD"
+                type="date" placeholder="璇烽�夋嫨" clearable />
             </el-form-item>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
             <el-form-item label="浠樻鏂瑰紡">
-              <el-input v-model="form.paymentMethod"
-                        placeholder="璇疯緭鍏�"
-                        clearable
-                        :disabled="operationType === 'view'" />
+              <el-input v-model="form.paymentMethod" placeholder="璇疯緭鍏�" clearable :disabled="operationType === 'view'" />
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="閿�鍞被鍨嬶細" prop="salesType">
+              <el-select
+                v-model="form.salesType"
+                placeholder="璇烽�夋嫨"
+                clearable
+                :disabled="operationType === 'view'"
+                style="width: 100%"
+              >
+                <el-option label="鏅��" value="鏅��" />
+                <el-option label="绱ф��" value="绱ф��" />
+              </el-select>
             </el-form-item>
           </el-col>
         </el-row>
         <el-row>
-          <el-form-item label="浜у搧淇℃伅锛�"
-                        prop="entryDate">
-            <el-button v-if="operationType !== 'view'"
-                       type="primary"
-                       @click="openProductForm('add')">娣诲姞</el-button>
-            <el-button v-if="operationType !== 'view'"
-                       plain
-                       type="danger"
-                       @click="deleteProduct">鍒犻櫎</el-button>
+          <el-col :span="24">
+            <el-form-item v-if="operationType !== 'view'">
+              <template #label>
+                <span>瀹℃壒浜洪�夋嫨锛�</span>
+                <el-button type="primary" @click="addApproverNode" style="margin-left: 8px;">鏂板鑺傜偣</el-button>
+              </template>
+              <div style="display: flex; align-items: flex-end; flex-wrap: wrap;">
+                <div
+                  v-for="(node, index) in approverNodes"
+                  :key="node.id"
+                  style="margin-right: 30px; text-align: center; margin-bottom: 10px;"
+                >
+                  <div>
+                    <span>瀹℃壒浜�</span>
+                    鈫�
+                  </div>
+                  <el-select
+                    v-model="node.userId"
+                    placeholder="閫夋嫨浜哄憳"
+                    style="width: 140px; margin-bottom: 8px;"
+                  >
+                    <el-option
+                      v-for="user in userList"
+                      :key="user.userId"
+                      :label="user.nickName"
+                      :value="user.userId"
+                    />
+                  </el-select>
+                  <div>
+                    <el-button
+                      type="danger"
+                      size="small"
+                      @click="removeApproverNode(index)"
+                      v-if="approverNodes.length > 1"
+                    >鍒犻櫎</el-button>
+                  </div>
+                </div>
+              </div>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row>
+          <el-form-item label="浜у搧淇℃伅锛�" prop="entryDate">
+            <el-button v-if="operationType !== 'view'" type="primary" @click="openProductForm('add')">娣诲姞</el-button>
+            <el-button v-if="operationType !== 'view'" plain type="danger" @click="deleteProduct" >鍒犻櫎</el-button>
           </el-form-item>
         </el-row>
-        <el-table :data="productData"
-                  border
-                  @selection-change="productSelected"
-                  show-summary
-                  :summary-method="summarizeMainTable">
-          <el-table-column align="center"
-                           type="selection"
-                           width="55"
-                           v-if="operationType !== 'view'" />
-          <el-table-column align="center"
-                           label="搴忓彿"
-                           type="index"
-                           width="60" />
-          <el-table-column label="浜у搧澶х被"
-                           prop="productCategory" />
-          <el-table-column label="瑙勬牸鍨嬪彿"
-                           prop="specificationModel" />
-          <el-table-column label="鍗曚綅"
-                           prop="unit" />
-          <el-table-column label="鏁伴噺"
-                           prop="quantity" />
-          <el-table-column label="绋庣巼(%)"
-                           prop="taxRate" />
-          <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 fixed="right"
-                           label="鎿嶄綔"
-                           min-width="60"
-                           align="center"
-                           v-if="operationType !== 'view'">
+        <el-table :data="productData" border @selection-change="productSelected" show-summary
+          :summary-method="summarizeMainTable">
+          <el-table-column align="center" type="selection" width="55" v-if="operationType !== 'view'" />
+          <el-table-column align="center" label="搴忓彿" type="index" width="60" />
+          <el-table-column label="浜у搧澶х被" prop="productCategory" />
+          <el-table-column label="瑙勬牸鍨嬪彿" prop="specificationModel" />
+          <el-table-column label="鍗曚綅" prop="unit" />
+          <el-table-column label="鏁伴噺" prop="quantity" />
+          <el-table-column label="绋庣巼(%)" prop="taxRate" />
+          <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 fixed="right" label="鎿嶄綔" min-width="60" align="center" v-if="operationType !== 'view'">
             <template #default="scope">
-              <el-button link
-                         type="primary"
-                         size="small"
-                         @click="openProductForm('edit', scope.row,scope.$index)">缂栬緫</el-button>
+              <el-button link type="primary" size="small" @click="openProductForm('edit', scope.row,scope.$index)">缂栬緫</el-button>
             </template>
           </el-table-column>
         </el-table>
         <el-row :gutter="30">
           <el-col :span="24">
-            <el-form-item label="澶囨敞路锛�"
-                          prop="remark">
-              <el-input v-model="form.remark"
-                        placeholder="璇疯緭鍏�"
-                        clearable
-                        type="textarea"
-                        :rows="2"
-                        :disabled="operationType === 'view'" />
+            <el-form-item label="澶囨敞路锛�" prop="remark">
+              <el-input v-model="form.remark" placeholder="璇疯緭鍏�" clearable type="textarea" :rows="2" :disabled="operationType === 'view'" />
             </el-form-item>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="24">
-            <el-form-item label="闄勪欢鏉愭枡锛�"
-                          prop="remark">
-              <el-upload v-model:file-list="fileList"
-                         :action="upload.url"
-                         multiple
-                         ref="fileUpload"
-                         auto-upload
-                         :headers="upload.headers"
-                         :before-upload="handleBeforeUpload"
-                         :on-error="handleUploadError"
-                         :on-success="handleUploadSuccess"
-                         :on-remove="handleRemove">
-                <el-button type="primary"
-                           v-if="operationType !== 'view'">涓婁紶</el-button>
-                <template #tip
-                          v-if="operationType !== 'view'">
+            <el-form-item label="闄勪欢鏉愭枡锛�" prop="remark">
+              <el-upload v-model:file-list="fileList" :action="upload.url" multiple ref="fileUpload" auto-upload
+                :headers="upload.headers" :before-upload="handleBeforeUpload" :on-error="handleUploadError"
+                :on-success="handleUploadSuccess" :on-remove="handleRemove">
+                <el-button type="primary" v-if="operationType !== 'view'">涓婁紶</el-button>
+                <template #tip v-if="operationType !== 'view'">
                   <div class="el-upload__tip">
                     鏂囦欢鏍煎紡鏀寔
                     doc锛宒ocx锛寈ls锛寈lsx锛宲pt锛宲ptx锛宲df锛宼xt锛寈ml锛宩pg锛宩peg锛宲ng锛実if锛宐mp锛宺ar锛寊ip锛�7z
@@ -469,140 +300,84 @@
       </el-form>
       <template #footer>
         <div class="dialog-footer">
-          <el-button type="primary"
-                     @click="submitForm">纭</el-button>
+          <el-button type="primary" @click="submitForm">纭</el-button>
           <el-button @click="closeDia">鍙栨秷</el-button>
         </div>
       </template>
     </el-dialog>
-    <el-dialog v-model="productFormVisible"
-               :title="productOperationType === 'add' ? '鏂板浜у搧' : '缂栬緫浜у搧'"
-               width="40%"
-               @close="closeProductDia">
-      <el-form :model="productForm"
-               label-width="140px"
-               label-position="top"
-               :rules="productRules"
-               ref="productFormRef">
+    <el-dialog v-model="productFormVisible" :title="productOperationType === 'add' ? '鏂板浜у搧' : '缂栬緫浜у搧'" width="40%"
+      @close="closeProductDia">
+      <el-form :model="productForm" label-width="140px" label-position="top" :rules="productRules" ref="productFormRef">
         <el-row :gutter="30">
           <el-col :span="24">
-            <el-form-item label="浜у搧澶х被锛�"
-                          prop="productCategory">
+            <el-form-item label="浜у搧澶х被锛�" prop="productCategory">
               <!-- <el-select v-model="productForm.productCategory" placeholder="璇烽�夋嫨" clearable>
                 <el-option v-for="item in userList" :key="item.nickName" :label="item.nickName" :value="item.nickName"/>
               </el-select> -->
-              <el-tree-select v-model="productForm.productCategory"
-                              placeholder="璇烽�夋嫨"
-                              clearable
-                              check-strictly
-                              @change="getModels"
-                              :data="productOptions"
-                              :render-after-expand="false"
-                              style="width: 100%" />
+              <el-tree-select v-model="productForm.productCategory" placeholder="璇烽�夋嫨" clearable check-strictly
+                @change="getModels" :data="productOptions" :render-after-expand="false" style="width: 100%" />
             </el-form-item>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="24">
-            <el-form-item label="瑙勬牸鍨嬪彿锛�"
-                          prop="productModelId">
-              <el-select v-model="productForm.productModelId"
-                         placeholder="璇烽�夋嫨"
-                         clearable
-                         @change="getProductModel">
-                <el-option v-for="item in modelOptions"
-                           :key="item.id"
-                           :label="item.model"
-                           :value="item.id" />
+            <el-form-item label="瑙勬牸鍨嬪彿锛�" prop="productModelId">
+              <el-select v-model="productForm.productModelId" placeholder="璇烽�夋嫨" clearable @change="getProductModel">
+                <el-option v-for="item in modelOptions" :key="item.id" :label="item.model" :value="item.id" />
               </el-select>
             </el-form-item>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="鍗曚綅锛�"
-                          prop="unit">
-              <el-input v-model="productForm.unit"
-                        placeholder="璇疯緭鍏�"
-                        clearable />
+            <el-form-item label="鍗曚綅锛�" prop="unit">
+              <el-input v-model="productForm.unit" placeholder="璇疯緭鍏�" clearable />
+            </el-form-item>
+          </el-col>
+					<el-col :span="12">
+						<el-form-item label="绋庣巼(%)锛�" prop="taxRate">
+							<el-select v-model="productForm.taxRate" placeholder="璇烽�夋嫨" clearable @change="calculateFromTaxRate">
+								<el-option label="1" value="1" />
+								<el-option label="6" value="6" />
+								<el-option label="13" value="13" />
+							</el-select>
+						</el-form-item>
+					</el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="鍚◣鍗曚环(鍏�)锛�" prop="taxInclusiveUnitPrice">
+              <el-input-number :step="0.01" :min="0" v-model="productForm.taxInclusiveUnitPrice" style="width: 100%"
+															 :precision="2"
+															 placeholder="璇疯緭鍏�" clearable @change="calculateFromUnitPrice" />
+            </el-form-item>
+          </el-col>
+					<el-col :span="12">
+						<el-form-item label="鏁伴噺锛�" prop="quantity">
+							<el-input-number  :step="0.1" :min="0" v-model="productForm.quantity" placeholder="璇疯緭鍏�" clearable
+																:precision="2"
+																@change="calculateFromQuantity" style="width: 100%" />
+						</el-form-item>
+					</el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="鍚◣鎬讳环(鍏�)锛�" prop="taxInclusiveTotalPrice">
+              <el-input v-model="productForm.taxInclusiveTotalPrice" placeholder="璇疯緭鍏�" clearable @change="calculateFromTotalPrice" />
             </el-form-item>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="绋庣巼(%)锛�"
-                          prop="taxRate">
-              <el-select v-model="productForm.taxRate"
-                         placeholder="璇烽�夋嫨"
-                         clearable
-                         @change="calculateFromTaxRate">
-                <el-option label="1"
-                           value="1" />
-                <el-option label="6"
-                           value="6" />
-                <el-option label="13"
-                           value="13" />
-              </el-select>
+            <el-form-item label="涓嶅惈绋庢�讳环(鍏�)锛�" prop="taxExclusiveTotalPrice">
+              <el-input v-model="productForm.taxExclusiveTotalPrice" placeholder="璇疯緭鍏�" clearable @change="calculateFromExclusiveTotalPrice" />
             </el-form-item>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="鍚◣鍗曚环(鍏�)锛�"
-                          prop="taxInclusiveUnitPrice">
-              <el-input-number :step="0.01"
-                               :min="0"
-                               v-model="productForm.taxInclusiveUnitPrice"
-                               style="width: 100%"
-                               :precision="2"
-                               placeholder="璇疯緭鍏�"
-                               clearable
-                               @change="calculateFromUnitPrice" />
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="鏁伴噺锛�"
-                          prop="quantity">
-              <el-input-number :step="0.1"
-                               :min="0"
-                               v-model="productForm.quantity"
-                               placeholder="璇疯緭鍏�"
-                               clearable
-                               :precision="2"
-                               @change="calculateFromQuantity"
-                               style="width: 100%" />
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-row :gutter="30">
-          <el-col :span="12">
-            <el-form-item label="鍚◣鎬讳环(鍏�)锛�"
-                          prop="taxInclusiveTotalPrice">
-              <el-input v-model="productForm.taxInclusiveTotalPrice"
-                        placeholder="璇疯緭鍏�"
-                        clearable
-                        @change="calculateFromTotalPrice" />
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="涓嶅惈绋庢�讳环(鍏�)锛�"
-                          prop="taxExclusiveTotalPrice">
-              <el-input v-model="productForm.taxExclusiveTotalPrice"
-                        placeholder="璇疯緭鍏�"
-                        clearable
-                        @change="calculateFromExclusiveTotalPrice" />
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-row :gutter="30">
-          <el-col :span="12">
-            <el-form-item label="鍙戠エ绫诲瀷锛�"
-                          prop="invoiceType">
-              <el-select v-model="productForm.invoiceType"
-                         placeholder="璇烽�夋嫨"
-                         clearable>
-                <el-option label="澧炴櫘绁�"
-                           value="澧炴櫘绁�" />
-                <el-option label="澧炰笓绁�"
-                           value="澧炰笓绁�" />
+            <el-form-item label="鍙戠エ绫诲瀷锛�" prop="invoiceType">
+              <el-select v-model="productForm.invoiceType" placeholder="璇烽�夋嫨" clearable>
+                <el-option label="澧炴櫘绁�" value="澧炴櫘绁�" />
+                <el-option label="澧炰笓绁�" value="澧炰笓绁�" />
               </el-select>
             </el-form-item>
           </el-col>
@@ -610,704 +385,661 @@
       </el-form>
       <template #footer>
         <div class="dialog-footer">
-          <el-button type="primary"
-                     @click="submitProduct">纭</el-button>
+          <el-button type="primary" @click="submitProduct">纭</el-button>
           <el-button @click="closeProductDia">鍙栨秷</el-button>
         </div>
       </template>
     </el-dialog>
-    <!-- 鎵撳嵃棰勮寮圭獥 -->
-    <el-dialog v-model="printPreviewVisible"
-               title="鎵撳嵃棰勮"
-               width="90%"
-               :close-on-click-modal="false"
-               class="print-preview-dialog">
-      <div class="print-preview-container">
-        <div class="print-preview-header">
-          <el-button type="primary"
-                     @click="executePrint">鎵ц鎵撳嵃</el-button>
-          <el-button @click="printPreviewVisible = false">鍏抽棴棰勮</el-button>
-        </div>
-        <div class="print-preview-content">
-          <div v-if="printData.length === 0"
-               style="text-align: center; padding: 50px; color: #999;">
-            鏆傛棤鎵撳嵃鏁版嵁
-          </div>
-          <div v-else
-               style="text-align: center; padding: 10px; color: #666; font-size: 14px; background: #e8f4fd; margin-bottom: 10px;">
-            鍏� {{ printData.length }} 鏉℃暟鎹緟鎵撳嵃
-          </div>
-          <div v-for="(item, index) in printData"
-               :key="index"
-               class="print-page">
-            <div class="delivery-note">
-              <div class="header">
-                <div class="company-name">榧庤瘹鐟炲疄涓氭湁闄愯矗浠诲叕鍙�</div>
-                <div class="document-title">闆跺敭鍙戣揣鍗�</div>
-              </div>
-              <div class="info-section">
-                <div class="info-row">
-                  <div>
-                    <span class="label">鍙戣揣鏃ユ湡锛�</span>
-                    <span class="value">{{ formatDate(item.createTime) }}</span>
-                  </div>
-                  <div>
-                    <span class="label">瀹㈡埛鍚嶇О锛�</span>
-                    <span class="value">{{ item.customerName || '寮犵埍鏈�' }}</span>
-                  </div>
-                </div>
-                <div class="info-row">
-                  <span class="label">鍗曞彿锛�</span>
-                  <span class="value">{{ item.salesContractNo }}</span>
-                </div>
-              </div>
-              <div class="table-section">
-                <table class="product-table">
-                  <thead>
-                    <tr>
-                      <th>浜у搧鍚嶇О</th>
-                      <th>瑙勬牸鍨嬪彿</th>
-                      <th>鍗曚綅</th>
-                      <th>鍗曚环</th>
-                      <th>闆跺敭鏁伴噺</th>
-                      <th>闆跺敭閲戦</th>
-                    </tr>
-                  </thead>
-                  <tbody>
-                    <tr v-for="product in item.products"
-                        :key="product.id">
-                      <td>{{ product.productCategory || '' }}</td>
-                      <td>{{ product.specificationModel || '' }}</td>
-                      <td>{{ product.unit || '' }}</td>
-                      <td>{{ product.taxInclusiveUnitPrice || '0' }}</td>
-                      <td>{{ product.quantity || '0' }}</td>
-                      <td>{{ product.taxInclusiveTotalPrice || '0' }}</td>
-                    </tr>
-                    <tr v-if="!item.products || item.products.length === 0">
-                      <td colspan="6"
-                          style="text-align: center; color: #999;">鏆傛棤浜у搧鏁版嵁</td>
-                    </tr>
-                  </tbody>
-                  <tfoot>
-                    <tr>
-                      <td class="label">鍚堣</td>
-                      <td class="total-value"></td>
-                      <td class="total-value"></td>
-                      <td class="total-value"></td>
-                      <td class="total-value">{{ getTotalQuantity(item.products) }}</td>
-                      <td class="total-value">{{ getTotalAmount(item.products) }}</td>
-                    </tr>
-                  </tfoot>
-                </table>
-              </div>
-              <div class="footer-section">
-                <div class="footer-row">
-                  <div class="footer-item">
-                    <span class="label">鏀惰揣鐢佃瘽锛�</span>
-                    <span class="value"></span>
-                  </div>
-                  <div class="footer-item">
-                    <span class="label">鏀惰揣浜猴細</span>
-                    <span class="value"></span>
-                  </div>
-                  <div class="footer-item address-item">
-                    <span class="label">鏀惰揣鍦板潃锛�</span>
-                    <span class="value address-value"></span>
-                  </div>
-                </div>
-                <div class="footer-row">
-                  <div class="footer-item">
-                    <span class="label">鎿嶄綔鍛橈細</span>
-                    <span class="value">{{ userStore.nickName || '鎾曞紑鍓�' }}</span>
-                  </div>
-                  <div class="footer-item">
-                    <span class="label">鎵撳嵃鏃ユ湡锛�</span>
-                    <span class="value">{{ formatDateTime(new Date()) }}</span>
-                  </div>
-                </div>
-              </div>
-            </div>
-          </div>
-        </div>
-      </div>
-    </el-dialog>
-    <!-- 鍙戣揣寮规 -->
-    <el-dialog v-model="deliveryFormVisible"
-               title="鍙戣揣淇℃伅"
-               width="40%"
-               @close="closeDeliveryDia">
-      <el-form :model="deliveryForm"
-               label-width="120px"
-               label-position="top"
-               :rules="deliveryRules"
-               ref="deliveryFormRef">
-        <el-row :gutter="30">
-          <el-col :span="24">
-            <el-form-item label="鍙戣揣鏃ユ湡锛�"
-                          prop="shippingDate">
-              <el-date-picker style="width: 100%"
-                              v-model="deliveryForm.shippingDate"
-                              value-format="YYYY-MM-DD"
-                              format="YYYY-MM-DD"
-                              type="date"
-                              placeholder="璇烽�夋嫨鍙戣揣鏃ユ湡"
-                              clearable />
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-row :gutter="30">
-          <el-col :span="24">
-            <el-form-item label="鍙戣揣杞︾墝鍙凤細"
-                          prop="shippingCarNumber">
-              <el-input v-model="deliveryForm.shippingCarNumber"
-                        placeholder="璇疯緭鍏ュ彂璐ц溅鐗屽彿"
-                        clearable />
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-row :gutter="30">
-          <el-col :span="24">
-            <el-form-item label="瀹℃壒浜猴細"
-                          prop="approverId">
-              <el-select v-model="deliveryForm.approverId"
-                         placeholder="璇烽�夋嫨瀹℃壒浜�"
-                         clearable
-                         :disabled="operationType === 'view'">
-                <el-option v-for="item in userList"
-                           :key="item.userId"
-                           :label="item.nickName"
-                           :value="item.userId" />
-              </el-select>
-            </el-form-item>
-          </el-col>
-        </el-row>
-      </el-form>
-      <template #footer>
-        <div class="dialog-footer">
-          <el-button type="primary"
-                     @click="submitDelivery">纭鍙戣揣</el-button>
-          <el-button @click="closeDeliveryDia">鍙栨秷</el-button>
-        </div>
-      </template>
-    </el-dialog>
+		<!-- 鎵撳嵃棰勮寮圭獥 -->
+		<el-dialog
+			v-model="printPreviewVisible"
+			title="鎵撳嵃棰勮"
+			width="90%"
+			:close-on-click-modal="false"
+			class="print-preview-dialog"
+		>
+			<div class="print-preview-container">
+				<div class="print-preview-header">
+					<el-button type="primary" @click="executePrint">鎵ц鎵撳嵃</el-button>
+					<el-button @click="printPreviewVisible = false">鍏抽棴棰勮</el-button>
+				</div>
+				<div class="print-preview-content">
+					<div v-if="printData.length === 0" style="text-align: center; padding: 50px; color: #999;">
+						鏆傛棤鎵撳嵃鏁版嵁
+					</div>
+					<div v-else style="text-align: center; padding: 10px; color: #666; font-size: 14px; background: #e8f4fd; margin-bottom: 10px;">
+						鍏� {{ printData.length }} 鏉℃暟鎹緟鎵撳嵃
+					</div>
+					<div v-for="(item, index) in printData" :key="index" class="print-page">
+						<div class="delivery-note">
+							<div class="header">
+								<div class="company-name">榧庤瘹鐟炲疄涓氭湁闄愯矗浠诲叕鍙�</div>
+								<div class="document-title">闆跺敭鍙戣揣鍗�</div>
+							</div>
+
+							<div class="info-section">
+								<div class="info-row">
+									<div>
+										<span class="label">鍙戣揣鏃ユ湡锛�</span>
+										<span class="value">{{ formatDate(item.createTime) }}</span>
+									</div>
+									<div>
+
+										<span class="label">瀹㈡埛鍚嶇О锛�</span>
+										<span class="value">{{ item.customerName || '寮犵埍鏈�' }}</span>
+									</div>
+								</div>
+								<div class="info-row">
+									<span class="label">鍗曞彿锛�</span>
+									<span class="value">{{ item.salesContractNo }}</span>
+								</div>
+							</div>
+
+							<div class="table-section">
+								<table class="product-table">
+									<thead>
+									<tr>
+										<th>浜у搧鍚嶇О</th>
+										<th>瑙勬牸鍨嬪彿</th>
+										<th>鍗曚綅</th>
+										<th>鍗曚环</th>
+										<th>闆跺敭鏁伴噺</th>
+										<th>闆跺敭閲戦</th>
+									</tr>
+									</thead>
+									<tbody>
+									<tr v-for="product in item.products" :key="product.id">
+										<td>{{ product.productCategory || '' }}</td>
+										<td>{{ product.specificationModel || '' }}</td>
+										<td>{{ product.unit || '' }}</td>
+										<td>{{ product.taxInclusiveUnitPrice || '0' }}</td>
+										<td>{{ product.quantity || '0' }}</td>
+										<td>{{ product.taxInclusiveTotalPrice || '0' }}</td>
+									</tr>
+									<tr v-if="!item.products || item.products.length === 0">
+										<td colspan="6" style="text-align: center; color: #999;">鏆傛棤浜у搧鏁版嵁</td>
+									</tr>
+									</tbody>
+									<tfoot>
+									<tr>
+										<td class="label">鍚堣</td>
+										<td class="total-value"></td>
+										<td class="total-value"></td>
+										<td class="total-value"></td>
+										<td class="total-value">{{ getTotalQuantity(item.products) }}</td>
+										<td class="total-value">{{ getTotalAmount(item.products) }}</td>
+									</tr>
+									</tfoot>
+								</table>
+							</div>
+
+							<div class="footer-section">
+								<div class="footer-row">
+									<div class="footer-item">
+										<span class="label">鏀惰揣鐢佃瘽锛�</span>
+										<span class="value"></span>
+									</div>
+									<div class="footer-item">
+										<span class="label">鏀惰揣浜猴細</span>
+										<span class="value"></span>
+									</div>
+									<div class="footer-item address-item">
+										<span class="label">鏀惰揣鍦板潃锛�</span>
+										<span class="value address-value"></span>
+									</div>
+								</div>
+								<div class="footer-row">
+									<div class="footer-item">
+										<span class="label">鎿嶄綔鍛橈細</span>
+										<span class="value">{{ userStore.nickName || '鎾曞紑鍓�' }}</span>
+									</div>
+									<div class="footer-item">
+										<span class="label">鎵撳嵃鏃ユ湡锛�</span>
+										<span class="value">{{ formatDateTime(new Date()) }}</span>
+									</div>
+								</div>
+							</div>
+						</div>
+					</div>
+				</div>
+			</div>
+		</el-dialog>
+		<!-- 鍙戣揣寮规 -->
+		<el-dialog
+			v-model="deliveryFormVisible"
+			title="鍙戣揣淇℃伅"
+			width="40%"
+			@close="closeDeliveryDia"
+		>
+			<el-form :model="deliveryForm" label-width="120px" label-position="top" :rules="deliveryRules" ref="deliveryFormRef">
+				<el-row :gutter="30">
+					<el-col :span="24">
+						<el-form-item label="鍙戣揣鏃ユ湡锛�" prop="shippingDate">
+							<el-date-picker
+								style="width: 100%"
+								v-model="deliveryForm.shippingDate"
+								value-format="YYYY-MM-DD"
+								format="YYYY-MM-DD"
+								type="date"
+								placeholder="璇烽�夋嫨鍙戣揣鏃ユ湡"
+								clearable
+							/>
+						</el-form-item>
+					</el-col>
+				</el-row>
+				<el-row :gutter="30">
+					<el-col :span="24">
+						<el-form-item label="鍙戣揣杞︾墝鍙凤細" prop="shippingCarNumber">
+							<el-input
+								v-model="deliveryForm.shippingCarNumber"
+								placeholder="璇疯緭鍏ュ彂璐ц溅鐗屽彿"
+								clearable
+							/>
+						</el-form-item>
+					</el-col>
+				</el-row>
+			</el-form>
+			<template #footer>
+				<div class="dialog-footer">
+					<el-button type="primary" @click="submitDelivery">纭鍙戣揣</el-button>
+					<el-button @click="closeDeliveryDia">鍙栨秷</el-button>
+				</div>
+			</template>
+		</el-dialog>
     <FileList ref="fileListRef" />
   </div>
 </template>
 
 <script setup>
-  import { getToken } from "@/utils/auth";
-  import pagination from "@/components/PIMTable/Pagination.vue";
-  import { onMounted, ref } from "vue";
-  import { addShippingInfo } from "@/api/salesManagement/deliveryLedger.js";
-  import { ElMessage, ElMessageBox } from "element-plus";
-  import useUserStore from "@/store/modules/user";
-  import { userListNoPage } from "@/api/system/user.js";
-  import FileList from "./fileList.vue";
-  import {
-    ledgerListPage,
-    productList,
-    customerList,
-    addOrUpdateSalesLedger,
-    getSalesLedgerWithProducts,
-    delLedger,
-    addOrUpdateSalesLedgerProduct,
-    delProduct,
-    delLedgerFile,
-    getProductInventory,
-    judgmentInventory,
-  } from "@/api/salesManagement/salesLedger.js";
-  import { modelList, productTreeList } from "@/api/basicData/product.js";
-  import useFormData from "@/hooks/useFormData.js";
-  import dayjs from "dayjs";
+import { getToken } from "@/utils/auth";
+import pagination from "@/components/PIMTable/Pagination.vue";
+import {onMounted, ref} from "vue";
+import { addShippingInfo } from "@/api/salesManagement/deliveryLedger.js";
+import {ElMessage, ElMessageBox} from "element-plus";
+import useUserStore from "@/store/modules/user";
+import { userListNoPage } from "@/api/system/user.js";
+import FileList from "./fileList.vue";
+import {
+  ledgerListPage,
+  productList,
+  customerList,
+  addOrUpdateSalesLedger,
+  getSalesLedgerWithProducts,
+  delLedger,
+  addOrUpdateSalesLedgerProduct,
+  delProduct,
+  delLedgerFile, getProductInventory,
+} from "@/api/salesManagement/salesLedger.js";
+import { modelList, productTreeList } from "@/api/basicData/product.js";
+import useFormData from "@/hooks/useFormData.js";
+import dayjs from "dayjs";
+import {
+  getStockInPage
+} from "@/api/inventoryManagement/stockIn.js";
 
-  const userStore = useUserStore();
-  const { proxy } = getCurrentInstance();
-  const tableData = ref([]);
-  const productData = ref([]);
-  const selectedRows = ref([]);
-  const productSelectedRows = ref([]);
-  const userList = ref([]);
-  const customerOption = ref([]);
-  const productOptions = ref([]);
-  const modelOptions = ref([]);
-  const tableLoading = ref(false);
-  const page = reactive({
-    current: 1,
-    size: 100,
-  });
-  const total = ref(0);
-  const fileList = ref([]);
 
-  // 鐢ㄦ埛淇℃伅琛ㄥ崟寮规鏁版嵁
-  const operationType = ref("");
-  const dialogFormVisible = ref(false);
-  const data = reactive({
-    searchForm: {
-      customerName: "", // 瀹㈡埛鍚嶇О
-      customerContractNo: "", // 瀹㈡埛鍚堝悓缂栧彿
-      salesContractNo: "", // 閿�鍞悎鍚岀紪鍙�
-      projectName: "", // 椤圭洰鍚嶇О
-      entryDate: null, // 褰曞叆鏃ユ湡
-      entryDateStart: undefined,
-      entryDateEnd: undefined,
-    },
-    form: {
-      salesContractNo: "",
-      salesman: "",
-      customerContractNo: "",
-      customerId: "",
-      projectName: "",
-      entryPerson: "",
-      entryDate: "",
-      maintenanceTime: "",
-      productData: [],
-      executionDate: "",
-      paymentMethod: "",
-    },
-    rules: {
-      salesman: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-      customerContractNo: [
-        { required: true, message: "璇疯緭鍏�", trigger: "blur" },
-      ],
-      customerId: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-      projectName: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-      entryPerson: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-      entryDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-      executionDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-    },
-  });
-  const { form, rules } = toRefs(data);
-  const { form: searchForm } = useFormData(data.searchForm);
-  // 浜у搧琛ㄥ崟寮规鏁版嵁
-  const productFormVisible = ref(false);
-  const productOperationType = ref("");
-  const currentId = ref("");
-  const productFormData = reactive({
-    productForm: {
-      productCategory: "",
-      specificationModel: "",
-      unit: "",
-      quantity: "",
-      taxInclusiveUnitPrice: "",
-      taxRate: "",
-      taxInclusiveTotalPrice: "",
-      taxExclusiveTotalPrice: "",
-      invoiceType: "",
-    },
-    productRules: {
-      productCategory: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-      productModelId: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-      specificationModel: [
-        { required: true, message: "璇烽�夋嫨", trigger: "change" },
-      ],
-      unit: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-      quantity: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-      taxInclusiveUnitPrice: [
-        { required: true, message: "璇疯緭鍏�", trigger: "blur" },
-      ],
-      taxRate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-      taxInclusiveTotalPrice: [
-        { required: true, message: "璇疯緭鍏�", trigger: "blur" },
-      ],
-      taxExclusiveTotalPrice: [
-        { required: true, message: "璇疯緭鍏�", trigger: "blur" },
-      ],
-      invoiceType: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
-    },
-  });
-  const { productForm, productRules } = toRefs(productFormData);
-  // 闃叉寰幆璁$畻鐨勬爣蹇�
-  const isCalculating = ref(false);
-  const upload = reactive({
-    // 涓婁紶鐨勫湴鍧�
-    url: import.meta.env.VITE_APP_BASE_API + "/file/upload",
-    // 璁剧疆涓婁紶鐨勮姹傚ご閮�
-    headers: { Authorization: "Bearer " + getToken() },
-  });
-  // 鎵撳嵃鐩稿叧
-  const printPreviewVisible = ref(false);
-  const printData = ref([]);
+const userStore = useUserStore();
+const { proxy } = getCurrentInstance();
+const tableData = ref([]);
+const productData = ref([]);
+const selectedRows = ref([]);
+const productSelectedRows = ref([]);
+const userList = ref([]);
+const customerOption = ref([]);
+const productOptions = ref([]);
+const modelOptions = ref([]);
+const tableLoading = ref(false);
+const page = reactive({
+  current: 1,
+  size: 100,
+});
+const total = ref(0);
+const fileList = ref([]);
+const approverNodes = ref([{ id: 1, userId: null }]);
+let nextApproverId = 2;
 
-  // 鍙戣揣鐩稿叧
-  const deliveryFormVisible = ref(false);
-  const currentDeliveryRow = ref(null);
-  const deliveryFormData = reactive({
-    deliveryForm: {
-      shippingDate: "",
-      shippingCarNumber: "",
-    },
-    deliveryRules: {
-      shippingDate: [
-        { required: true, message: "璇烽�夋嫨鍙戣揣鏃ユ湡", trigger: "change" },
-      ],
-      shippingCarNumber: [
-        { required: true, message: "璇疯緭鍏ュ彂璐ц溅鐗屽彿", trigger: "blur" },
-      ],
-      approverId: [
-        {
-          required: true,
-          message: "",
-        },
-      ],
-    },
-  });
-  const { deliveryForm, deliveryRules } = toRefs(deliveryFormData);
+// 鐢ㄦ埛淇℃伅琛ㄥ崟寮规鏁版嵁
+const operationType = ref("");
+const dialogFormVisible = ref(false);
+const data = reactive({
+  searchForm: {
+    customerName: "", // 瀹㈡埛鍚嶇О
+    customerContractNo: "", // 瀹㈡埛鍚堝悓缂栧彿
+    salesContractNo: "", // 閿�鍞悎鍚岀紪鍙�
+    projectName: "", // 椤圭洰鍚嶇О
+    entryDate: null, // 褰曞叆鏃ユ湡
+    entryDateStart: undefined,
+    entryDateEnd: undefined,
+  },
+  form: {
+    salesContractNo: "",
+    salesman: "",
+    customerContractNo: "",
+    customerId: "",
+    projectName: "",
+    entryPerson: "",
+    entryDate: "",
+    maintenanceTime: "",
+    productData: [],
+    executionDate: "",
+    paymentMethod: "",
+    salesType: "鏅��",
+  },
+  rules: {
+    salesType: [{ required: true, message: "璇烽�夋嫨閿�鍞被鍨�", trigger: "change" }],
+    salesman: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+    customerContractNo: [
+      { required: true, message: "璇疯緭鍏�", trigger: "blur" },
+    ],
+    customerId: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+    projectName: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    entryPerson: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+    entryDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+    executionDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+  },
+});
+const { form, rules } = toRefs(data);
+const { form: searchForm } = useFormData(data.searchForm);
+const addApproverNode = () => {
+  approverNodes.value.push({ id: nextApproverId++, userId: null });
+};
+const removeApproverNode = (index) => {
+  approverNodes.value.splice(index, 1);
+};
+// 浜у搧琛ㄥ崟寮规鏁版嵁
+const productFormVisible = ref(false);
+const productOperationType = ref("");
+const currentId = ref("");
+const productFormData = reactive({
+  productForm: {
+    productCategory: "",
+    specificationModel: "",
+    unit: "",
+    quantity: "",
+    taxInclusiveUnitPrice: "",
+    taxRate: "",
+    taxInclusiveTotalPrice: "",
+    taxExclusiveTotalPrice: "",
+    invoiceType: "",
+  },
+  productRules: {
+    productCategory: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+		productModelId: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+    specificationModel: [
+      { required: true, message: "璇烽�夋嫨", trigger: "change" },
+    ],
+    unit: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    quantity: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    taxInclusiveUnitPrice: [
+      { required: true, message: "璇疯緭鍏�", trigger: "blur" },
+    ],
+    taxRate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+    taxInclusiveTotalPrice: [
+      { required: true, message: "璇疯緭鍏�", trigger: "blur" },
+    ],
+    taxExclusiveTotalPrice: [
+      { required: true, message: "璇疯緭鍏�", trigger: "blur" },
+    ],
+    invoiceType: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+  },
+});
+const { productForm, productRules } = toRefs(productFormData);
+// 闃叉寰幆璁$畻鐨勬爣蹇�
+const isCalculating = ref(false);
+const upload = reactive({
+  // 涓婁紶鐨勫湴鍧�
+  url: import.meta.env.VITE_APP_BASE_API + "/file/upload",
+  // 璁剧疆涓婁紶鐨勮姹傚ご閮�
+  headers: { Authorization: "Bearer " + getToken() },
+});
+// 鎵撳嵃鐩稿叧
+const printPreviewVisible = ref(false);
+const printData = ref([]);
 
-  const changeDaterange = value => {
-    if (value) {
-      searchForm.entryDateStart = dayjs(value[0]).format("YYYY-MM-DD");
-      searchForm.entryDateEnd = dayjs(value[1]).format("YYYY-MM-DD");
-    } else {
-      searchForm.entryDateStart = undefined;
-      searchForm.entryDateEnd = undefined;
-    }
-    handleQuery();
-  };
+// 鍙戣揣鐩稿叧
+const deliveryFormVisible = ref(false);
+const currentDeliveryContext = ref(null);
+const deliveryFormData = reactive({
+  deliveryForm: {
+    shippingDate: "",
+    shippingCarNumber: "",
+  },
+  deliveryRules: {
+    shippingDate: [
+      { required: true, message: "璇烽�夋嫨鍙戣揣鏃ユ湡", trigger: "change" }
+    ],
+    shippingCarNumber: [
+      { required: true, message: "璇疯緭鍏ュ彂璐ц溅鐗屽彿", trigger: "blur" }
+    ],
+  },
+});
+const { deliveryForm, deliveryRules } = toRefs(deliveryFormData);
 
-  // 鏌ヨ鍒楄〃
-  /** 鎼滅储鎸夐挳鎿嶄綔 */
-  const handleQuery = () => {
-    page.current = 1;
-    expandedRowKeys.value = [];
-    getList();
-  };
-  const paginationChange = obj => {
-    page.current = obj.page;
-    page.size = obj.limit;
-    getList();
-  };
-  const getList = async () => {
-    let userLists = await userListNoPage();
-    userList.value = userLists.data;
-    tableLoading.value = true;
-    const { entryDate, ...rest } = searchForm;
-    ledgerListPage({ ...rest, ...page })
-      .then(res => {
-        tableLoading.value = false;
-        tableData.value = res.records;
-        tableData.value.map(item => {
-          item.children = [];
-        });
-        total.value = res.total;
-      })
-      .catch(() => {
-        tableLoading.value = false;
-      });
-  };
-  // 鑾峰彇浜у搧澶х被tree鏁版嵁
-  const getProductOptions = () => {
-    productTreeList().then(res => {
-      productOptions.value = convertIdToValue(res);
-    });
-  };
-  const formattedNumber = (row, column, cellValue) => {
-    return parseFloat(cellValue).toFixed(2);
-  };
-  // 鑾峰彇tree瀛愭暟鎹�
-  const getModels = value => {
-    productForm.value.productCategory = findNodeById(productOptions.value, value);
-    modelList({ id: value }).then(res => {
-      modelOptions.value = res;
-    });
-  };
-  const getProductModel = value => {
-    console.log("value", value);
-    const index = modelOptions.value.findIndex(item => item.id === value);
-    if (index !== -1) {
-      productForm.value.specificationModel = modelOptions.value[index].model;
-      productForm.value.unit = modelOptions.value[index].unit;
-    } else {
-      productForm.value.specificationModel = null;
-      productForm.value.unit = null;
-    }
-  };
-  const findNodeById = (nodes, productId) => {
-    for (let i = 0; i < nodes.length; i++) {
-      if (nodes[i].value === productId) {
-        return nodes[i].label; // 鎵惧埌鑺傜偣锛岃繑鍥炶鑺傜偣
-      }
-      if (nodes[i].children && nodes[i].children.length > 0) {
-        const foundNode = findNodeById(nodes[i].children, productId);
-        if (foundNode) {
-          return foundNode; // 鍦ㄥ瓙鑺傜偣涓壘鍒帮紝杩斿洖璇ヨ妭鐐�
-        }
-      }
-    }
-    return null; // 娌℃湁鎵惧埌鑺傜偣锛岃繑鍥瀗ull
-  };
-  function convertIdToValue(data) {
-    return data.map(item => {
-      const { id, children, ...rest } = item;
-      const newItem = {
-        ...rest,
-        value: id, // 灏� id 鏀逛负 value
-      };
-      if (children && children.length > 0) {
-        newItem.children = convertIdToValue(children);
-      }
-
-      return newItem;
-    });
+const changeDaterange = (value) => {
+  if (value) {
+    searchForm.entryDateStart = dayjs(value[0]).format("YYYY-MM-DD");
+    searchForm.entryDateEnd = dayjs(value[1]).format("YYYY-MM-DD");
+  } else {
+    searchForm.entryDateStart = undefined;
+    searchForm.entryDateEnd = undefined;
   }
-  // 琛ㄦ牸閫夋嫨鏁版嵁
-  const handleSelectionChange = selection => {
-    // 杩囨护鎺夊瓙鏁版嵁
-    selectedRows.value = selection.filter(item => item.children !== undefined);
-    console.log("selection", selectedRows.value);
-  };
-  const productSelected = selectedRows => {
-    productSelectedRows.value = selectedRows;
-  };
-  const expandedRowKeys = ref([]);
-  // 灞曞紑琛岋紙濮嬬粓鍙睍寮�涓�琛岋級
-  const expandChange = row => {
-    const rowKey = row.id;
-    const isExpanded = expandedRowKeys.value.includes(rowKey);
+  handleQuery();
+};
 
-    if (isExpanded) {
-      // 褰撳墠琛屽凡灞曞紑 -> 鏀惰捣
-      expandedRowKeys.value = [];
-      return;
+// 鏌ヨ鍒楄〃
+/** 鎼滅储鎸夐挳鎿嶄綔 */
+const handleQuery = () => {
+  page.current = 1;
+	expandedRowKeys.value = [];
+  getList();
+};
+const paginationChange = (obj) => {
+  page.current = obj.page;
+  page.size = obj.limit;
+  getList();
+};
+const getList = () => {
+  tableLoading.value = true;
+  const { entryDate, ...rest } = searchForm;
+  ledgerListPage({ ...rest, ...page })
+    .then((res) => {
+      tableLoading.value = false;
+      tableData.value = res.records;
+      tableData.value.map((item) => {
+        item.children = [];
+      });
+      total.value = res.total;
+    })
+    .catch(() => {
+      tableLoading.value = false;
+    });
+};
+// 鑾峰彇浜у搧澶х被tree鏁版嵁
+const getProductOptions = () => {
+  productTreeList().then((res) => {
+    productOptions.value = convertIdToValue(res);
+  });
+};
+const formattedNumber = (row, column, cellValue) => {
+  return parseFloat(cellValue).toFixed(2);
+};
+// 鑾峰彇tree瀛愭暟鎹�
+const getModels = (value) => {
+  productForm.value.productCategory = findNodeById(productOptions.value, value);
+  modelList({ id: value }).then((res) => {
+    modelOptions.value = res;
+  });
+};
+const getProductModel = (value) => {
+  console.log("value", value);
+  const index = modelOptions.value.findIndex((item) => item.id === value);
+  if (index !== -1) {
+    productForm.value.specificationModel = modelOptions.value[index].model;
+    productForm.value.unit = modelOptions.value[index].unit;
+  } else {
+    productForm.value.specificationModel = null;
+    productForm.value.unit = null;
+  }
+};
+const findNodeById = (nodes, productId) => {
+  for (let i = 0; i < nodes.length; i++) {
+    if (nodes[i].value === productId) {
+      return nodes[i].label; // 鎵惧埌鑺傜偣锛岃繑鍥炶鑺傜偣
+    }
+    if (nodes[i].children && nodes[i].children.length > 0) {
+      const foundNode = findNodeById(nodes[i].children, productId);
+      if (foundNode) {
+        return foundNode; // 鍦ㄥ瓙鑺傜偣涓壘鍒帮紝杩斿洖璇ヨ妭鐐�
+      }
+    }
+  }
+  return null; // 娌℃湁鎵惧埌鑺傜偣锛岃繑鍥瀗ull
+};
+function convertIdToValue(data) {
+  return data.map((item) => {
+    const { id, children, ...rest } = item;
+    const newItem = {
+      ...rest,
+      value: id, // 灏� id 鏀逛负 value
+    };
+    if (children && children.length > 0) {
+      newItem.children = convertIdToValue(children);
     }
 
-    // 灞曞紑褰撳墠琛屽墠锛屽厛鏀惰捣鍏跺畠琛�
+    return newItem;
+  });
+}
+// 琛ㄦ牸閫夋嫨鏁版嵁
+const handleSelectionChange = (selection) => {
+  // 杩囨护鎺夊瓙鏁版嵁
+  selectedRows.value = selection.filter((item) => item.children !== undefined);
+  console.log("selection", selectedRows.value);
+};
+const productSelected = (selectedRows) => {
+  productSelectedRows.value = selectedRows;
+};
+const expandedRowKeys = ref([]);
+// 灞曞紑琛�
+const expandChange = (row, expandedRows) => {
+  if (expandedRows.length > 0) {
     expandedRowKeys.value = [];
-
     try {
-      productList({ salesLedgerId: row.id, type: 1 }).then(res => {
-        const index = tableData.value.findIndex(item => item.id === row.id);
+      productList({ salesLedgerId: row.id, type: 1 }).then((res) => {
+        const index = tableData.value.findIndex((item) => item.id === row.id);
         if (index > -1) {
           tableData.value[index].children = res.data;
         }
-        // 鍙繚鐣欏綋鍓嶈繖涓�琛屽浜庡睍寮�鐘舵��
-        expandedRowKeys.value = [rowKey];
+        expandedRowKeys.value.push(row.id);
       });
     } catch (error) {
       console.log(error);
     }
-  };
-  // 涓昏〃鍚堣鏂规硶
-  const summarizeMainTable = param => {
-    return proxy.summarizeTable(param, [
-      "contractAmount",
-      "taxInclusiveTotalPrice",
-      "taxExclusiveTotalPrice",
-    ]);
-  };
-  // 瀛愯〃鍚堣鏂规硶
-  const summarizeChildrenTable = param => {
-    return proxy.summarizeTable(param, [
-      "taxInclusiveUnitPrice",
-      "taxInclusiveTotalPrice",
-      "taxExclusiveTotalPrice",
-    ]);
-  };
-  // 鎵撳紑寮规
-  const openForm = async (type, row) => {
-    operationType.value = type;
-    form.value = {};
-    productData.value = [];
-    customerList().then(res => {
-      customerOption.value = res;
+  } else {
+    expandedRowKeys.value = [];
+  }
+};
+// 涓昏〃鍚堣鏂规硶
+const summarizeMainTable = (param) => {
+  return proxy.summarizeTable(param, [
+    "contractAmount",
+    "taxInclusiveTotalPrice",
+    "taxExclusiveTotalPrice",
+  ]);
+};
+// 瀛愯〃鍚堣鏂规硶
+const summarizeChildrenTable = (param) => {
+  return proxy.summarizeTable(param, [
+    "taxInclusiveUnitPrice",
+    "taxInclusiveTotalPrice",
+    "taxExclusiveTotalPrice",
+  ]);
+};
+// 鎵撳紑寮规
+const openForm = async (type, row) => {
+  operationType.value = type;
+  form.value = {};
+  productData.value = [];
+  approverNodes.value = [{ id: 1, userId: null }];
+  nextApproverId = 2;
+  let userLists = await userListNoPage();
+  userList.value = userLists.data;
+  customerList().then((res) => {
+    customerOption.value = res;
+  });
+  form.value.entryPerson = userStore.id;
+  if (type !== "add") {
+    currentId.value = row.id;
+    getSalesLedgerWithProducts({ id: row.id, type: 1 }).then((res) => {
+      form.value = { ...res };
+      form.value.entryPerson = Number(res.entryPerson);
+      if (!form.value.salesType) {
+        form.value.salesType = "鏅��";
+      }
+      productData.value = form.value.productData;
+      fileList.value = form.value.salesLedgerFiles;
+      const approveUserIds = form.value.approveUserIds || form.value.approverIds;
+      if (approveUserIds) {
+        const ids = String(approveUserIds)
+          .split(",")
+          .map((id) => Number(id.trim()))
+          .filter((id) => !Number.isNaN(id));
+        if (ids.length > 0) {
+          approverNodes.value = ids.map((id, idx) => ({ id: idx + 1, userId: id }));
+          nextApproverId = ids.length + 1;
+        }
+      }
     });
-    form.value.entryPerson = userStore.id;
-    if (type !== "add") {
-      currentId.value = row.id;
-      getSalesLedgerWithProducts({ id: row.id, type: 1 }).then(res => {
-        form.value = { ...res };
-        form.value.entryPerson = Number(res.entryPerson);
-        productData.value = form.value.productData;
-        fileList.value = form.value.salesLedgerFiles;
-      });
-    }
-    // let userAll = await userStore.getInfo()
-    // userList.value.forEach(element => {
-    //   if(userAll.user.nickName === element.nickName && userAll.user.userName === element.userName) {
-    //     form.value.entryPerson = userAll.user.userId // 璁剧疆榛樿涓氬姟鍛樹负褰撳墠鐢ㄦ埛
-    //   }
-    // });
-    form.value.entryDate = getCurrentDate(); // 璁剧疆榛樿褰曞叆鏃ユ湡涓哄綋鍓嶆棩鏈�
-    dialogFormVisible.value = true;
-  };
-  function changs(val) {
-    console.log(val);
   }
-  // 涓婁紶鍓嶆牎妫�
-  function handleBeforeUpload(file) {
-    // 鏍℃鏂囦欢澶у皬
-    // if (file.size > 1024 * 1024 * 10) {
-    //   proxy.$modal.msgError("涓婁紶鏂囦欢澶у皬涓嶈兘瓒呰繃10MB!");
-    //   return false;
-    // }
-    proxy.$modal.loading("姝e湪涓婁紶鏂囦欢锛岃绋嶅��...");
-    return true;
+  // let userAll = await userStore.getInfo()
+  // userList.value.forEach(element => {
+  //   if(userAll.user.nickName === element.nickName && userAll.user.userName === element.userName) {
+  //     form.value.entryPerson = userAll.user.userId // 璁剧疆榛樿涓氬姟鍛樹负褰撳墠鐢ㄦ埛
+  //   }
+  // });
+  form.value.entryDate = getCurrentDate(); // 璁剧疆榛樿褰曞叆鏃ユ湡涓哄綋鍓嶆棩鏈�
+  if (type === "add") {
+    form.value.salesType = "鏅��";
   }
-  // 涓婁紶澶辫触
-  function handleUploadError(err) {
-    proxy.$modal.msgError("涓婁紶鏂囦欢澶辫触");
-    proxy.$modal.closeLoading();
+  dialogFormVisible.value = true;
+};
+function changs(val) {
+  console.log(val);
+}
+// 涓婁紶鍓嶆牎妫�
+function handleBeforeUpload(file) {
+  // 鏍℃鏂囦欢澶у皬
+  // if (file.size > 1024 * 1024 * 10) {
+  //   proxy.$modal.msgError("涓婁紶鏂囦欢澶у皬涓嶈兘瓒呰繃10MB!");
+  //   return false;
+  // }
+  proxy.$modal.loading("姝e湪涓婁紶鏂囦欢锛岃绋嶅��...");
+  return true;
+}
+// 涓婁紶澶辫触
+function handleUploadError(err) {
+  proxy.$modal.msgError("涓婁紶鏂囦欢澶辫触");
+  proxy.$modal.closeLoading();
+}
+// 涓婁紶鎴愬姛鍥炶皟
+function handleUploadSuccess(res, file, uploadFiles) {
+  proxy.$modal.closeLoading();
+  if (res.code === 200) {
+    file.tempId = res.data.tempId;
+    proxy.$modal.msgSuccess("涓婁紶鎴愬姛");
+  } else {
+    proxy.$modal.msgError(res.msg);
+    proxy.$refs.fileUpload.handleRemove(file);
   }
-  // 涓婁紶鎴愬姛鍥炶皟
-  function handleUploadSuccess(res, file, uploadFiles) {
-    proxy.$modal.closeLoading();
-    if (res.code === 200) {
-      file.tempId = res.data.tempId;
-      proxy.$modal.msgSuccess("涓婁紶鎴愬姛");
-    } else {
-      proxy.$modal.msgError(res.msg);
-      proxy.$refs.fileUpload.handleRemove(file);
-    }
+}
+// 绉婚櫎鏂囦欢
+function handleRemove(file) {
+  if (operationType.value === "edit") {
+    let ids = [];
+    ids.push(file.id);
+    delLedgerFile(ids).then((res) => {
+      proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
+    });
   }
-  // 绉婚櫎鏂囦欢
-  function handleRemove(file) {
-    if (operationType.value === "edit") {
-      let ids = [];
-      ids.push(file.id);
-      delLedgerFile(ids).then(res => {
-        proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
-      });
-    }
-  }
-  // 鎻愪氦琛ㄥ崟
-  const submitForm = () => {
-    proxy.$refs["formRef"].validate(valid => {
-      if (valid) {
-        console.log("productData.value--", productData.value);
-        if (productData.value !== null && productData.value.length > 0) {
-          form.value.productData = proxy.HaveJson(productData.value);
-        } else {
-          proxy.$modal.msgWarning("璇锋坊鍔犱骇鍝佷俊鎭�");
+}
+// 鎻愪氦琛ㄥ崟
+const submitForm = () => {
+  proxy.$refs["formRef"].validate((valid) => {
+    if (valid) {
+      if (operationType.value !== "view") {
+        const hasEmptyApprover = approverNodes.value.some((node) => !node.userId);
+        if (hasEmptyApprover) {
+          proxy.$modal.msgWarning("璇蜂负鎵�鏈夊鎵硅妭鐐归�夋嫨瀹℃壒浜�");
           return;
         }
-        let tempFileIds = [];
-        if (fileList.value !== null && fileList.value.length > 0) {
-          tempFileIds = fileList.value.map(item => item.tempId);
-        }
-        form.value.tempFileIds = tempFileIds;
-        form.value.type = 1;
-        addOrUpdateSalesLedger(form.value).then(res => {
-          proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
-          closeDia();
-          getList();
-        });
+        form.value.approveUserIds = approverNodes.value.map((node) => node.userId).join(",");
       }
-    });
-  };
-  // 鍏抽棴寮规
-  const closeDia = () => {
-    proxy.resetForm("formRef");
-    dialogFormVisible.value = false;
-  };
+			console.log('productData.value--', productData.value)
+      if (productData.value !== null && productData.value.length > 0) {
+        form.value.productData = proxy.HaveJson(productData.value);
+      } else {
+        proxy.$modal.msgWarning("璇锋坊鍔犱骇鍝佷俊鎭�");
+        return;
+      }
+      let tempFileIds = [];
+      if (fileList.value !== null && fileList.value.length > 0) {
+        tempFileIds = fileList.value.map((item) => item.tempId);
+      }
+      form.value.tempFileIds = tempFileIds;
+      form.value.type = 1;
+      addOrUpdateSalesLedger(form.value).then((res) => {
+        proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
+        closeDia();
+        getList();
+      });
+    }
+  });
+};
+// 鍏抽棴寮规
+const closeDia = () => {
+  proxy.resetForm("formRef");
+  dialogFormVisible.value = false;
+};
 
-  const productIndex = ref(0);
-  // 鎵撳紑浜у搧寮规
-  const openProductForm = (type, row, index) => {
-    productOperationType.value = type;
-    productForm.value = {};
-    proxy.resetForm("productFormRef");
-    if (type === "edit") {
-      productForm.value = { ...row };
-      productIndex.value = index;
-    }
-    productFormVisible.value = true;
-    getProductOptions();
-  };
-  // 鎻愪氦浜у搧琛ㄥ崟
-  const submitProduct = () => {
-    proxy.$refs["productFormRef"].validate(valid => {
-      if (valid) {
-        if (operationType.value === "edit") {
-          submitProductEdit();
-        } else {
-          if (productOperationType.value === "add") {
-            productData.value.push({ ...productForm.value });
-          } else {
-            productData.value[productIndex.value] = { ...productForm.value };
-          }
-          closeProductDia();
+const productIndex = ref(0);
+// 鎵撳紑浜у搧寮规
+const openProductForm = (type, row,index) => {
+  productOperationType.value = type;
+  productForm.value = {};
+  proxy.resetForm("productFormRef");
+  if (type === "edit") {
+    productForm.value = { ...row };
+    productIndex.value = index;
+  }
+  productFormVisible.value = true;
+  getProductOptions();
+};
+// 鎻愪氦浜у搧琛ㄥ崟
+const submitProduct = () => {
+  proxy.$refs["productFormRef"].validate((valid) => {
+    if (valid) {
+      if (operationType.value === "edit") {
+        submitProductEdit();
+      } else {
+        if(productOperationType.value === "add"){
+          productData.value.push({ ...productForm.value });
+        }else{
+          productData.value[productIndex.value] = { ...productForm.value }
         }
+        closeProductDia();
+      }
+    }
+  });
+};
+const submitProductEdit = () => {
+  productForm.value.salesLedgerId = currentId.value;
+  productForm.value.type = 1
+  addOrUpdateSalesLedgerProduct(productForm.value).then((res) => {
+    proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
+    closeProductDia();
+    getSalesLedgerWithProducts({ id: currentId.value, type: 1 }).then((res) => {
+      productData.value = res.productData;
+    });
+  });
+};
+// 鍒犻櫎浜у搧
+const deleteProduct = () => {
+  if (productSelectedRows.value.length === 0) {
+    proxy.$modal.msgWarning("璇烽�夋嫨鏁版嵁");
+    return;
+  }
+  if (operationType.value === "add") {
+    productSelectedRows.value.forEach((selectedRow) => {
+      const index = productData.value.findIndex(
+        (product) => product.id === selectedRow.id
+      );
+      if (index !== -1) {
+        productData.value.splice(index, 1);
       }
     });
-  };
-  const submitProductEdit = () => {
-    productForm.value.salesLedgerId = currentId.value;
-    productForm.value.type = 1;
-    addOrUpdateSalesLedgerProduct(productForm.value).then(res => {
-      proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
-      closeProductDia();
-      getSalesLedgerWithProducts({ id: currentId.value, type: 1 }).then(res => {
-        productData.value = res.productData;
-      });
-    });
-  };
-  // 鍒犻櫎浜у搧
-  const deleteProduct = () => {
-    if (productSelectedRows.value.length === 0) {
-      proxy.$modal.msgWarning("璇烽�夋嫨鏁版嵁");
-      return;
-    }
-    if (operationType.value === "add") {
-      productSelectedRows.value.forEach(selectedRow => {
-        const index = productData.value.findIndex(
-          product => product.id === selectedRow.id
-        );
-        if (index !== -1) {
-          productData.value.splice(index, 1);
-        }
-      });
-    } else {
-      let ids = [];
-      if (productSelectedRows.value.length > 0) {
-        ids = productSelectedRows.value.map(item => item.id);
-      }
-      ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚垹闄わ紝鏄惁纭鍒犻櫎锛�", "瀵煎嚭", {
-        confirmButtonText: "纭",
-        cancelButtonText: "鍙栨秷",
-        type: "warning",
-      })
-        .then(() => {
-          delProduct(ids).then(res => {
-            proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
-            closeProductDia();
-            getSalesLedgerWithProducts({ id: currentId.value, type: 1 }).then(
-              res => {
-                productData.value = res.productData;
-              }
-            );
-          });
-        })
-        .catch(() => {
-          proxy.$modal.msg("宸插彇娑�");
-        });
-    }
-  };
-  // 鍏抽棴浜у搧寮规
-  const closeProductDia = () => {
-    proxy.resetForm("productFormRef");
-    productFormVisible.value = false;
-  };
-  // 瀵煎嚭
-  const handleOut = () => {
-    ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚鍑猴紝鏄惁纭瀵煎嚭锛�", "瀵煎嚭", {
-      confirmButtonText: "纭",
-      cancelButtonText: "鍙栨秷",
-      type: "warning",
-    })
-      .then(() => {
-        proxy.download("/sales/ledger/export", {}, "閿�鍞彴璐�.xlsx");
-      })
-      .catch(() => {
-        proxy.$modal.msg("宸插彇娑�");
-      });
-  };
-  // 鍒犻櫎
-  const handleDelete = () => {
+  } else {
     let ids = [];
-    if (selectedRows.value.length > 0) {
-      ids = selectedRows.value.map(item => item.id);
-    } else {
-      proxy.$modal.msgWarning("璇烽�夋嫨鏁版嵁");
-      return;
+    if (productSelectedRows.value.length > 0) {
+      ids = productSelectedRows.value.map((item) => item.id);
     }
     ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚垹闄わ紝鏄惁纭鍒犻櫎锛�", "瀵煎嚭", {
       confirmButtonText: "纭",
@@ -1315,844 +1047,843 @@
       type: "warning",
     })
       .then(() => {
-        delLedger(ids).then(res => {
+        delProduct(ids).then((res) => {
           proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
-          getList();
+          closeProductDia();
+          getSalesLedgerWithProducts({ id: currentId.value, type: 1 }).then(
+            (res) => {
+              productData.value = res.productData;
+            }
+          );
         });
       })
       .catch(() => {
         proxy.$modal.msg("宸插彇娑�");
       });
-  };
-
-  // 鎵撳嵃鍔熻兘
-  const handlePrint = async () => {
-    if (selectedRows.value.length === 0) {
-      proxy.$modal.msgWarning("璇烽�夋嫨瑕佹墦鍗扮殑鏁版嵁");
-      return;
-    }
-
-    // 鏄剧ず鍔犺浇鐘舵��
-    proxy.$modal.loading("姝e湪鑾峰彇浜у搧鏁版嵁锛岃绋嶅��...");
-
-    try {
-      // 涓烘瘡涓�変腑鐨勯攢鍞彴璐﹁褰曟煡璇㈠搴旂殑浜у搧鏁版嵁
-      const printDataWithProducts = [];
-
-      for (const row of selectedRows.value) {
-        try {
-          // 璋冪敤productList鎺ュ彛鏌ヨ浜у搧鏁版嵁
-          const productRes = await productList({
-            salesLedgerId: row.id,
-            type: 1,
-          });
-
-          // 灏嗕骇鍝佹暟鎹暣鍚堝埌閿�鍞彴璐﹁褰曚腑
-          const rowWithProducts = {
-            ...row,
-            products: productRes.data || [],
-          };
-
-          printDataWithProducts.push(rowWithProducts);
-        } catch (error) {
-          console.error(`鑾峰彇閿�鍞彴璐� ${row.id} 鐨勪骇鍝佹暟鎹け璐�:`, error);
-          // 鍗充娇鏌愪釜璁板綍鐨勪骇鍝佹暟鎹幏鍙栧け璐ワ紝涔熻鍖呭惈璇ヨ褰�
-          printDataWithProducts.push({
-            ...row,
-            products: [],
-          });
-        }
-      }
-
-      printData.value = printDataWithProducts;
-      console.log("鎵撳嵃鏁版嵁锛堝寘鍚骇鍝侊級:", printData.value);
-      printPreviewVisible.value = true;
-    } catch (error) {
-      console.error("鑾峰彇浜у搧鏁版嵁澶辫触:", error);
-      proxy.$modal.msgError("鑾峰彇浜у搧鏁版嵁澶辫触锛岃閲嶈瘯");
-    } finally {
-      proxy.$modal.closeLoading();
-    }
-  };
-  // 鎵ц鎵撳嵃
-  const executePrint = () => {
-    console.log("寮�濮嬫墽琛屾墦鍗帮紝鏁版嵁鏉℃暟:", printData.value.length);
-    console.log("鎵撳嵃鏁版嵁:", printData.value);
-
-    // 鍒涘缓涓�涓柊鐨勬墦鍗扮獥鍙�
-    const printWindow = window.open("", "_blank", "width=800,height=600");
-
-    // 鏋勫缓鎵撳嵃鍐呭
-    let printContent = `
-                            <!DOCTYPE html>
-                            <html>
-                            <head>
-                              <meta charset="UTF-8">
-                              <title>鎵撳嵃棰勮</title>
-                              <style>
-                                body {
-                                  margin: 0;
-                                  padding: 0;
-                                  font-family: "SimSun", serif;
-                                  background: white;
-                                }
-                                                                             .print-page {
-                                    width: 200mm;
-                                    height: 75mm;
-                                    padding: 10mm;
-                                    padding-left: 20mm;
-                                    background: white;
-                                    box-sizing: border-box;
-                                    page-break-after: always;
-                                    page-break-inside: avoid;
-                                  }
-                                 .print-page:last-child {
-                                   page-break-after: avoid;
-                                 }
-                                .delivery-note {
-                                  width: 100%;
-                                  height: 100%;
-                                  font-size: 12px;
-                                  line-height: 1.2;
-                                  display: flex;
-                                  flex-direction: column;
-                                  color: #000;
-                                }
-                                .header {
-                                  text-align: center;
-                                  margin-bottom: 8px;
-                                }
-                                .company-name {
-                                  font-size: 18px;
-                                  font-weight: bold;
-                                  margin-bottom: 4px;
-                                }
-                                .document-title {
-                                  font-size: 16px;
-                                  font-weight: bold;
-                                }
-                                .info-section {
-                                  margin-bottom: 8px;
-                                  display: flex;
-                                  justify-content: space-between;
-                                  align-items: center;
-                                }
-                                .info-row {
-                                  line-height: 20px;
-                                }
-                                .label {
-                                  font-weight: bold;
-                                  width: 60px;
-                                  font-size: 12px;
-                                }
-                                .value {
-                                  margin-right: 20px;
-                                  min-width: 80px;
-                                  font-size: 12px;
-                                }
-                                         .table-section {
-                                         margin-bottom: 40px;
-                                  //  flex: 0.6;
-                                 }
-                                .product-table {
-                                  width: 100%;
-                                  border-collapse: collapse;
-                                  border: 1px solid #000;
-                                }
-                                         .product-table th, .product-table td {
-                                   border: 1px solid #000;
-                                   padding: 6px;
-                                   text-align: center;
-                                   font-size: 12px;
-                                   line-height: 1.4;
-                                 }
-                                .product-table th {
-                                  font-weight: bold;
-                                }
-                                .total-value {
-                                  font-weight: bold;
-                                }
-                                .footer-section {
-                                  margin-top: auto;
-                                }
-                                .footer-row {
-                                  display: flex;
-                                  margin-bottom: 3px;
-                                  line-height: 22px;
-                                  justify-content: space-between;
-                                }
-                                .footer-item {
-                                  display: flex;
-                                  margin-right: 20px;
-                                }
-                                .footer-item .label {
-                                  font-weight: bold;
-                                  width: 80px;
-                                  font-size: 12px;
-                                }
-                                .footer-item .value {
-                                  min-width: 80px;
-                                  font-size: 12px;
-                                }
-                                .address-item .address-value {
-                                  min-width: 200px;
-                                }
-                                @media print {
-                                  body {
-                                    margin: 0;
-                                    padding: 0;
-                                  }
-                                             .print-page {
-                                     margin: 0;
-                                     padding: 10mm;
-                                     /* padding-left: 20mm; */
-                                     page-break-inside: avoid;
-                                     page-break-after: always;
-                                   }
-                                   .print-page:last-child {
-                                     page-break-after: avoid;
-                                   }
-                                }
-                              </style>
-                            </head>
-                            <body>
-                          `;
-
-    // 涓烘瘡鏉℃暟鎹敓鎴愭墦鍗伴〉闈�
-    printData.value.forEach((item, index) => {
-      printContent += `
-                              <div class="print-page">
-                                <div class="delivery-note">
-                                  <div class="header">
-                                    <div class="company-name">榧庤瘹鐟炲疄涓氭湁闄愯矗浠诲叕鍙�</div>
-                                    <div class="document-title">闆跺敭鍙戣揣鍗�</div>
-                                  </div>
-                                  
-                                  <div class="info-section">
-                                    <div class="info-row">
-                                      <div>
-                                        <span class="label">鍙戣揣鏃ユ湡锛�</span>
-                                        <span class="value">${formatDate(
-                                          item.createTime
-                                        )}</span>
-                                      </div>
-                                      <div>
-                                        <span class="label">瀹㈡埛鍚嶇О锛�</span>
-                                        <span class="value">${
-                                          item.customerName || "寮犵埍鏈�"
-                                        }</span>
-                                      </div>
-                                    </div>
-                                    <div class="info-row">
-                                      <span class="label">鍗曞彿锛�</span>
-                                      <span class="value">${
-                                        item.salesContractNo || ""
-                                      }</span>
-                                    </div>
-                                  </div>
-
-                                  <div class="table-section">
-                                    <table class="product-table">
-                                      <thead>
-                                        <tr>
-                                          <th>浜у搧鍚嶇О</th>
-                                          <th>瑙勬牸鍨嬪彿</th>
-                                          <th>鍗曚綅</th>
-                                          <th>鍗曚环</th>
-                                          <th>闆跺敭鏁伴噺</th>
-                                          <th>闆跺敭閲戦</th>
-                                        </tr>
-                                      </thead>
-                                      <tbody>
-                                        ${
-                                          item.products &&
-                                          item.products.length > 0
-                                            ? item.products
-                                                .map(
-                                                  product => `
-                                            <tr>
-                                              <td>${
-                                                product.productCategory || ""
-                                              }</td>
-                                              <td>${
-                                                product.specificationModel || ""
-                                              }</td>
-                                              <td>${product.unit || ""}</td>
-                                              <td>${
-                                                product.taxInclusiveUnitPrice ||
-                                                "0"
-                                              }</td>
-                                              <td>${product.quantity || "0"}</td>
-                                              <td>${
-                                                product.taxInclusiveTotalPrice ||
-                                                "0"
-                                              }</td>
-                                            </tr>
-                                          `
-                                                )
-                                                .join("")
-                                            : '<tr><td colspan="6" style="text-align: center; color: #999;">鏆傛棤浜у搧鏁版嵁</td></tr>'
-                                        }
-                                      </tbody>
-                                      <tfoot>
-                                        <tr>
-                                          <td class="label">鍚堣</td>
-                                          <td class="total-value"></td>
-                                          <td class="total-value"></td>
-                                          <td class="total-value"></td>
-                                          <td class="total-value">${getTotalQuantityForPrint(
-                                            item.products
-                                          )}</td>
-                                          <td class="total-value">${getTotalAmountForPrint(
-                                            item.products
-                                          )}</td>
-                                        </tr>
-                                      </tfoot>
-                                    </table>
-                                  </div>
-
-                                  <div class="footer-section">
-                                    <div class="footer-row">
-                                      <div class="footer-item">
-                                        <span class="label">鏀惰揣鐢佃瘽锛�</span>
-                                        <span class="value"></span>
-                                      </div>
-                                      <div class="footer-item">
-                                        <span class="label">鏀惰揣浜猴細</span>
-                                        <span class="value"></span>
-                                      </div>
-                                      <div class="footer-item address-item">
-                                        <span class="label">鏀惰揣鍦板潃锛�</span>
-                                        <span class="value address-value"></span>
-                                      </div>
-                                    </div>
-                                    <div class="footer-row">
-                                      <div class="footer-item">
-                                        <span class="label">鎿嶄綔鍛橈細</span>
-                                        <span class="value">${
-                                          userStore.nickName || "鎾曞紑鍓�"
-                                        }</span>
-                                      </div>
-                                      <div class="footer-item">
-                                        <span class="label">鎵撳嵃鏃ユ湡锛�</span>
-                                        <span class="value">${formatDateTime(
-                                          new Date()
-                                        )}</span>
-                                      </div>
-                                    </div>
-                                  </div>
-                                </div>
-                              </div>
-                            `;
+  }
+};
+// 鍏抽棴浜у搧寮规
+const closeProductDia = () => {
+  proxy.resetForm("productFormRef");
+  productFormVisible.value = false;
+};
+// 瀵煎嚭
+const handleOut = () => {
+  ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚鍑猴紝鏄惁纭瀵煎嚭锛�", "瀵煎嚭", {
+    confirmButtonText: "纭",
+    cancelButtonText: "鍙栨秷",
+    type: "warning",
+  })
+    .then(() => {
+      proxy.download("/sales/ledger/export", {}, "閿�鍞彴璐�.xlsx");
+    })
+    .catch(() => {
+      proxy.$modal.msg("宸插彇娑�");
     });
+};
+// 鍒犻櫎
+const handleDelete = () => {
+  let ids = [];
+  if (selectedRows.value.length > 0) {
+    ids = selectedRows.value.map((item) => item.id);
+  } else {
+    proxy.$modal.msgWarning("璇烽�夋嫨鏁版嵁");
+    return;
+  }
+  ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚垹闄わ紝鏄惁纭鍒犻櫎锛�", "瀵煎嚭", {
+    confirmButtonText: "纭",
+    cancelButtonText: "鍙栨秷",
+    type: "warning",
+  })
+    .then(() => {
+      delLedger(ids).then((res) => {
+        proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
+        getList();
+      });
+    })
+    .catch(() => {
+      proxy.$modal.msg("宸插彇娑�");
+    });
+};
 
-    printContent += `
-                            </body>
-                            </html>
-                          `;
+// 鎵撳嵃鍔熻兘
+const handlePrint = async () => {
+	if (selectedRows.value.length === 0) {
+		proxy.$modal.msgWarning("璇烽�夋嫨瑕佹墦鍗扮殑鏁版嵁");
+		return;
+	}
 
-    // 鍐欏叆鍐呭鍒版柊绐楀彛
-    printWindow.document.write(printContent);
-    printWindow.document.close();
+	// 鏄剧ず鍔犺浇鐘舵��
+	proxy.$modal.loading("姝e湪鑾峰彇浜у搧鏁版嵁锛岃绋嶅��...");
 
-    // 绛夊緟鍐呭鍔犺浇瀹屾垚鍚庢墦鍗�
-    printWindow.onload = () => {
-      setTimeout(() => {
-        printWindow.print();
-        printWindow.close();
-        printPreviewVisible.value = false;
-      }, 500);
-    };
-  };
-  // 鏍煎紡鍖栨棩鏈�
-  const formatDate = dateString => {
-    if (!dateString) return getCurrentDate();
-    const date = new Date(dateString);
-    const year = date.getFullYear();
-    const month = String(date.getMonth() + 1).padStart(2, "0");
-    const day = String(date.getDate()).padStart(2, "0");
-    return `${year}/${month}/${day}`;
-  };
-  // 鏍煎紡鍖栨棩鏈熸椂闂�
-  const formatDateTime = date => {
-    const year = date.getFullYear();
-    const month = String(date.getMonth() + 1).padStart(2, "0");
-    const day = String(date.getDate()).padStart(2, "0");
-    const hours = String(date.getHours()).padStart(2, "0");
-    const minutes = String(date.getMinutes()).padStart(2, "0");
-    const seconds = String(date.getSeconds()).padStart(2, "0");
-    return `${year}/${month}/${day} ${hours}:${minutes}:${seconds}`;
-  };
-  // 鑾峰彇褰撳墠鏃ユ湡骞舵牸寮忓寲涓� YYYY-MM-DD
-  function getCurrentDate() {
-    const today = new Date();
-    const year = today.getFullYear();
-    const month = String(today.getMonth() + 1).padStart(2, "0"); // 鏈堜唤浠�0寮�濮�
-    const day = String(today.getDate()).padStart(2, "0");
-    return `${year}-${month}-${day}`;
+	try {
+		// 涓烘瘡涓�変腑鐨勯攢鍞彴璐﹁褰曟煡璇㈠搴旂殑浜у搧鏁版嵁
+		const printDataWithProducts = [];
+
+		for (const row of selectedRows.value) {
+			try {
+				// 璋冪敤productList鎺ュ彛鏌ヨ浜у搧鏁版嵁
+				const productRes = await productList({ salesLedgerId: row.id, type: 1 });
+
+				// 灏嗕骇鍝佹暟鎹暣鍚堝埌閿�鍞彴璐﹁褰曚腑
+				const rowWithProducts = {
+					...row,
+					products: productRes.data || []
+				};
+
+				printDataWithProducts.push(rowWithProducts);
+			} catch (error) {
+				console.error(`鑾峰彇閿�鍞彴璐� ${row.id} 鐨勪骇鍝佹暟鎹け璐�:`, error);
+				// 鍗充娇鏌愪釜璁板綍鐨勪骇鍝佹暟鎹幏鍙栧け璐ワ紝涔熻鍖呭惈璇ヨ褰�
+				printDataWithProducts.push({
+					...row,
+					products: []
+				});
+			}
+		}
+
+		printData.value = printDataWithProducts;
+		console.log('鎵撳嵃鏁版嵁锛堝寘鍚骇鍝侊級:', printData.value);
+		printPreviewVisible.value = true;
+
+	} catch (error) {
+		console.error('鑾峰彇浜у搧鏁版嵁澶辫触:', error);
+		proxy.$modal.msgError("鑾峰彇浜у搧鏁版嵁澶辫触锛岃閲嶈瘯");
+	} finally {
+		proxy.$modal.closeLoading();
+	}
+};
+// 鎵ц鎵撳嵃
+const executePrint = () => {
+	console.log('寮�濮嬫墽琛屾墦鍗帮紝鏁版嵁鏉℃暟:', printData.value.length);
+	console.log('鎵撳嵃鏁版嵁:', printData.value);
+
+	// 鍒涘缓涓�涓柊鐨勬墦鍗扮獥鍙�
+	const printWindow = window.open('', '_blank', 'width=800,height=600');
+
+	// 鏋勫缓鎵撳嵃鍐呭
+	let printContent = `
+    <!DOCTYPE html>
+    <html>
+    <head>
+      <meta charset="UTF-8">
+      <title>鎵撳嵃棰勮</title>
+      <style>
+        body {
+          margin: 0;
+          padding: 0;
+          font-family: "SimSun", serif;
+          background: white;
+        }
+                                                     .print-page {
+            width: 200mm;
+            height: 75mm;
+            padding: 10mm;
+            padding-left: 20mm;
+            background: white;
+            box-sizing: border-box;
+            page-break-after: always;
+            page-break-inside: avoid;
+          }
+         .print-page:last-child {
+           page-break-after: avoid;
+         }
+        .delivery-note {
+          width: 100%;
+          height: 100%;
+          font-size: 12px;
+          line-height: 1.2;
+          display: flex;
+          flex-direction: column;
+          color: #000;
+        }
+        .header {
+          text-align: center;
+          margin-bottom: 8px;
+        }
+        .company-name {
+          font-size: 18px;
+          font-weight: bold;
+          margin-bottom: 4px;
+        }
+        .document-title {
+          font-size: 16px;
+          font-weight: bold;
+        }
+        .info-section {
+          margin-bottom: 8px;
+          display: flex;
+          justify-content: space-between;
+          align-items: center;
+        }
+        .info-row {
+          line-height: 20px;
+        }
+        .label {
+          font-weight: bold;
+          width: 60px;
+          font-size: 12px;
+        }
+        .value {
+          margin-right: 20px;
+          min-width: 80px;
+          font-size: 12px;
+        }
+                 .table-section {
+                 margin-bottom: 40px;
+          //  flex: 0.6;
+         }
+        .product-table {
+          width: 100%;
+          border-collapse: collapse;
+          border: 1px solid #000;
+        }
+                 .product-table th, .product-table td {
+           border: 1px solid #000;
+           padding: 6px;
+           text-align: center;
+           font-size: 12px;
+           line-height: 1.4;
+         }
+        .product-table th {
+          font-weight: bold;
+        }
+        .total-value {
+          font-weight: bold;
+        }
+        .footer-section {
+          margin-top: auto;
+        }
+        .footer-row {
+          display: flex;
+          margin-bottom: 3px;
+          line-height: 22px;
+          justify-content: space-between;
+        }
+        .footer-item {
+          display: flex;
+          margin-right: 20px;
+        }
+        .footer-item .label {
+          font-weight: bold;
+          width: 80px;
+          font-size: 12px;
+        }
+        .footer-item .value {
+          min-width: 80px;
+          font-size: 12px;
+        }
+        .address-item .address-value {
+          min-width: 200px;
+        }
+        @media print {
+          body {
+            margin: 0;
+            padding: 0;
+          }
+                     .print-page {
+             margin: 0;
+             padding: 10mm;
+             /* padding-left: 20mm; */
+             page-break-inside: avoid;
+             page-break-after: always;
+           }
+           .print-page:last-child {
+             page-break-after: avoid;
+           }
+        }
+      </style>
+    </head>
+    <body>
+  `;
+
+	// 涓烘瘡鏉℃暟鎹敓鎴愭墦鍗伴〉闈�
+	printData.value.forEach((item, index) => {
+		printContent += `
+      <div class="print-page">
+        <div class="delivery-note">
+          <div class="header">
+            <div class="company-name">榧庤瘹鐟炲疄涓氭湁闄愯矗浠诲叕鍙�</div>
+            <div class="document-title">闆跺敭鍙戣揣鍗�</div>
+          </div>
+
+          <div class="info-section">
+            <div class="info-row">
+              <div>
+                <span class="label">鍙戣揣鏃ユ湡锛�</span>
+                <span class="value">${formatDate(item.createTime)}</span>
+              </div>
+              <div>
+                <span class="label">瀹㈡埛鍚嶇О锛�</span>
+                <span class="value">${item.customerName || '寮犵埍鏈�'}</span>
+              </div>
+            </div>
+            <div class="info-row">
+              <span class="label">鍗曞彿锛�</span>
+              <span class="value">${item.salesContractNo || ''}</span>
+            </div>
+          </div>
+
+          <div class="table-section">
+            <table class="product-table">
+              <thead>
+                <tr>
+                  <th>浜у搧鍚嶇О</th>
+                  <th>瑙勬牸鍨嬪彿</th>
+                  <th>鍗曚綅</th>
+                  <th>鍗曚环</th>
+                  <th>闆跺敭鏁伴噺</th>
+                  <th>闆跺敭閲戦</th>
+                </tr>
+              </thead>
+              <tbody>
+                ${item.products && item.products.length > 0 ?
+                  item.products.map(product => `
+                    <tr>
+                      <td>${product.productCategory || ''}</td>
+                      <td>${product.specificationModel || ''}</td>
+                      <td>${product.unit || ''}</td>
+                      <td>${product.taxInclusiveUnitPrice || '0'}</td>
+                      <td>${product.quantity || '0'}</td>
+                      <td>${product.taxInclusiveTotalPrice || '0'}</td>
+                    </tr>
+                  `).join('') :
+                  '<tr><td colspan="6" style="text-align: center; color: #999;">鏆傛棤浜у搧鏁版嵁</td></tr>'
+                }
+              </tbody>
+              <tfoot>
+                <tr>
+                  <td class="label">鍚堣</td>
+                  <td class="total-value"></td>
+                  <td class="total-value"></td>
+                  <td class="total-value"></td>
+                  <td class="total-value">${getTotalQuantityForPrint(item.products)}</td>
+                  <td class="total-value">${getTotalAmountForPrint(item.products)}</td>
+                </tr>
+              </tfoot>
+            </table>
+          </div>
+
+          <div class="footer-section">
+            <div class="footer-row">
+              <div class="footer-item">
+                <span class="label">鏀惰揣鐢佃瘽锛�</span>
+                <span class="value"></span>
+              </div>
+              <div class="footer-item">
+                <span class="label">鏀惰揣浜猴細</span>
+                <span class="value"></span>
+              </div>
+              <div class="footer-item address-item">
+                <span class="label">鏀惰揣鍦板潃锛�</span>
+                <span class="value address-value"></span>
+              </div>
+            </div>
+            <div class="footer-row">
+              <div class="footer-item">
+                <span class="label">鎿嶄綔鍛橈細</span>
+                <span class="value">${userStore.nickName || '鎾曞紑鍓�'}</span>
+              </div>
+              <div class="footer-item">
+                <span class="label">鎵撳嵃鏃ユ湡锛�</span>
+                <span class="value">${formatDateTime(new Date())}</span>
+              </div>
+            </div>
+          </div>
+        </div>
+      </div>
+    `;
+	});
+
+	printContent += `
+    </body>
+    </html>
+  `;
+
+	// 鍐欏叆鍐呭鍒版柊绐楀彛
+	printWindow.document.write(printContent);
+	printWindow.document.close();
+
+	// 绛夊緟鍐呭鍔犺浇瀹屾垚鍚庢墦鍗�
+	printWindow.onload = () => {
+		setTimeout(() => {
+			printWindow.print();
+			printWindow.close();
+			printPreviewVisible.value = false;
+		}, 500);
+	};
+};
+// 鏍煎紡鍖栨棩鏈�
+const formatDate = (dateString) => {
+	if (!dateString) return getCurrentDate();
+	const date = new Date(dateString);
+	const year = date.getFullYear();
+	const month = String(date.getMonth() + 1).padStart(2, "0");
+	const day = String(date.getDate()).padStart(2, "0");
+	return `${year}/${month}/${day}`;
+};
+// 鏍煎紡鍖栨棩鏈熸椂闂�
+const formatDateTime = (date) => {
+	const year = date.getFullYear();
+	const month = String(date.getMonth() + 1).padStart(2, "0");
+	const day = String(date.getDate()).padStart(2, "0");
+	const hours = String(date.getHours()).padStart(2, "0");
+	const minutes = String(date.getMinutes()).padStart(2, "0");
+	const seconds = String(date.getSeconds()).padStart(2, "0");
+	return `${year}/${month}/${day} ${hours}:${minutes}:${seconds}`;
+};
+// 鑾峰彇褰撳墠鏃ユ湡骞舵牸寮忓寲涓� YYYY-MM-DD
+function getCurrentDate() {
+  const today = new Date();
+  const year = today.getFullYear();
+  const month = String(today.getMonth() + 1).padStart(2, "0"); // 鏈堜唤浠�0寮�濮�
+  const day = String(today.getDate()).padStart(2, "0");
+  return `${year}-${month}-${day}`;
+}
+
+// 璁$畻浜у搧鎬绘暟閲�
+const getTotalQuantity = (products) => {
+  if (!products || products.length === 0) return '0';
+  const total = products.reduce((sum, product) => {
+    return sum + (parseFloat(product.quantity) || 0);
+  }, 0);
+  return total.toFixed(2);
+};
+
+// 璁$畻浜у搧鎬婚噾棰�
+const getTotalAmount = (products) => {
+  if (!products || products.length === 0) return '0';
+  const total = products.reduce((sum, product) => {
+    return sum + (parseFloat(product.taxInclusiveTotalPrice) || 0);
+  }, 0);
+  return total.toFixed(2);
+};
+
+// 鐢ㄤ簬鎵撳嵃鐨勮绠楀嚱鏁�
+const getTotalQuantityForPrint = (products) => {
+  if (!products || products.length === 0) return '0';
+  const total = products.reduce((sum, product) => {
+    return sum + (parseFloat(product.quantity) || 0);
+  }, 0);
+  return total.toFixed(2);
+};
+
+const getTotalAmountForPrint = (products) => {
+  if (!products || products.length === 0) return '0';
+  const total = products.reduce((sum, product) => {
+    return sum + (parseFloat(product.taxInclusiveTotalPrice) || 0);
+  }, 0);
+  return total.toFixed(2);
+};
+
+const mathNum = () => {
+  console.log("productForm.value", productForm.value);
+  if (!productForm.value.taxInclusiveUnitPrice) {
+    return;
+  }
+  if (!productForm.value.quantity) {
+    return;
+  }
+  // 鍚◣鎬讳环璁$畻
+  productForm.value.taxInclusiveTotalPrice =
+    proxy.calculateTaxIncludeTotalPrice(
+      productForm.value.taxInclusiveUnitPrice,
+      productForm.value.quantity
+    );
+  if (productForm.value.taxRate) {
+    // 涓嶅惈绋庢�讳环璁$畻
+    productForm.value.taxExclusiveTotalPrice =
+      proxy.calculateTaxExclusiveTotalPrice(
+        productForm.value.taxInclusiveTotalPrice,
+        productForm.value.taxRate
+      );
+  }
+};
+
+// 鏍规嵁鍚◣鎬讳环璁$畻鍚◣鍗曚环鍜屾暟閲�
+const calculateFromTotalPrice = () => {
+  if (isCalculating.value) return;
+
+  const totalPrice = parseFloat(productForm.value.taxInclusiveTotalPrice);
+  const quantity = parseFloat(productForm.value.quantity);
+
+  if (!totalPrice || !quantity || quantity <= 0) {
+    return;
   }
 
-  // 璁$畻浜у搧鎬绘暟閲�
-  const getTotalQuantity = products => {
-    if (!products || products.length === 0) return "0";
-    const total = products.reduce((sum, product) => {
-      return sum + (parseFloat(product.quantity) || 0);
-    }, 0);
-    return total.toFixed(2);
-  };
+  isCalculating.value = true;
 
-  // 璁$畻浜у搧鎬婚噾棰�
-  const getTotalAmount = products => {
-    if (!products || products.length === 0) return "0";
-    const total = products.reduce((sum, product) => {
-      return sum + (parseFloat(product.taxInclusiveTotalPrice) || 0);
-    }, 0);
-    return total.toFixed(2);
-  };
+  // 璁$畻鍚◣鍗曚环 = 鍚◣鎬讳环 / 鏁伴噺
+  productForm.value.taxInclusiveUnitPrice = (totalPrice / quantity).toFixed(2);
 
-  // 鐢ㄤ簬鎵撳嵃鐨勮绠楀嚱鏁�
-  const getTotalQuantityForPrint = products => {
-    if (!products || products.length === 0) return "0";
-    const total = products.reduce((sum, product) => {
-      return sum + (parseFloat(product.quantity) || 0);
-    }, 0);
-    return total.toFixed(2);
-  };
-
-  const getTotalAmountForPrint = products => {
-    if (!products || products.length === 0) return "0";
-    const total = products.reduce((sum, product) => {
-      return sum + (parseFloat(product.taxInclusiveTotalPrice) || 0);
-    }, 0);
-    return total.toFixed(2);
-  };
-
-  const mathNum = () => {
-    console.log("productForm.value", productForm.value);
-    if (!productForm.value.taxInclusiveUnitPrice) {
-      return;
-    }
-    if (!productForm.value.quantity) {
-      return;
-    }
-    // 鍚◣鎬讳环璁$畻
-    productForm.value.taxInclusiveTotalPrice =
-      proxy.calculateTaxIncludeTotalPrice(
-        productForm.value.taxInclusiveUnitPrice,
-        productForm.value.quantity
-      );
-    if (productForm.value.taxRate) {
-      // 涓嶅惈绋庢�讳环璁$畻
-      productForm.value.taxExclusiveTotalPrice =
-        proxy.calculateTaxExclusiveTotalPrice(
-          productForm.value.taxInclusiveTotalPrice,
-          productForm.value.taxRate
-        );
-    }
-  };
-
-  // 鏍规嵁鍚◣鎬讳环璁$畻鍚◣鍗曚环鍜屾暟閲�
-  const calculateFromTotalPrice = () => {
-    if (isCalculating.value) return;
-
-    const totalPrice = parseFloat(productForm.value.taxInclusiveTotalPrice);
-    const quantity = parseFloat(productForm.value.quantity);
-
-    if (!totalPrice || !quantity || quantity <= 0) {
-      return;
-    }
-
-    isCalculating.value = true;
-
-    // 璁$畻鍚◣鍗曚环 = 鍚◣鎬讳环 / 鏁伴噺
-    productForm.value.taxInclusiveUnitPrice = (totalPrice / quantity).toFixed(2);
-
-    // 濡傛灉鏈夌◣鐜囷紝璁$畻涓嶅惈绋庢�讳环
-    if (productForm.value.taxRate) {
-      productForm.value.taxExclusiveTotalPrice =
-        proxy.calculateTaxExclusiveTotalPrice(
-          totalPrice,
-          productForm.value.taxRate
-        );
-    }
-
-    isCalculating.value = false;
-  };
-
-  // 鏍规嵁涓嶅惈绋庢�讳环璁$畻鍚◣鍗曚环鍜屾暟閲�
-  const calculateFromExclusiveTotalPrice = () => {
-    if (!productForm.value.taxRate) {
-      proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
-      return;
-    }
-    if (isCalculating.value) return;
-
-    const exclusiveTotalPrice = parseFloat(
-      productForm.value.taxExclusiveTotalPrice
-    );
-    const quantity = parseFloat(productForm.value.quantity);
-    const taxRate = parseFloat(productForm.value.taxRate);
-
-    if (!exclusiveTotalPrice || !quantity || quantity <= 0 || !taxRate) {
-      return;
-    }
-
-    isCalculating.value = true;
-
-    // 鍏堣绠楀惈绋庢�讳环 = 涓嶅惈绋庢�讳环 / (1 - 绋庣巼/100)
-    const taxRateDecimal = taxRate / 100;
-    const inclusiveTotalPrice = exclusiveTotalPrice / (1 - taxRateDecimal);
-    productForm.value.taxInclusiveTotalPrice = inclusiveTotalPrice.toFixed(2);
-
-    // 璁$畻鍚◣鍗曚环 = 鍚◣鎬讳环 / 鏁伴噺
-    productForm.value.taxInclusiveUnitPrice = (
-      inclusiveTotalPrice / quantity
-    ).toFixed(2);
-
-    isCalculating.value = false;
-  };
-
-  // 鏍规嵁鏁伴噺鍙樺寲璁$畻鎬讳环
-  const calculateFromQuantity = () => {
-    // 杩欓噷
-    if (!productForm.value.taxRate) {
-      proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
-      return;
-    }
-    if (isCalculating.value) return;
-    newfunction();
-    const quantity = parseFloat(productForm.value.quantity);
-    const unitPrice = parseFloat(productForm.value.taxInclusiveUnitPrice);
-
-    if (!quantity || quantity <= 0 || !unitPrice) {
-      return;
-    }
-
-    isCalculating.value = true;
-
-    // 璁$畻鍚◣鎬讳环
-    productForm.value.taxInclusiveTotalPrice = (unitPrice * quantity).toFixed(2);
-
-    // 濡傛灉鏈夌◣鐜囷紝璁$畻涓嶅惈绋庢�讳环
-    if (productForm.value.taxRate) {
-      productForm.value.taxExclusiveTotalPrice =
-        proxy.calculateTaxExclusiveTotalPrice(
-          productForm.value.taxInclusiveTotalPrice,
-          productForm.value.taxRate
-        );
-    }
-
-    isCalculating.value = false;
-  };
-  const newfunction = () => {
-    // productForm.value.productModelId;
-    // productForm.quantity
-    judgmentInventory({
-      productModelId: productForm.value.productModelId,
-      quantity: productForm.value.quantity,
-    }).then(res => {
-      console.log("res", res);
-      // if (res.code === 200) {
-      //   proxy.$modal.msgSuccess("搴撳瓨鍏呰冻");
-      // } else {
-      //   proxy.$modal.msgError(res.msg);
-      // }
-    });
-  };
-  // 鏍规嵁鍚◣鍗曚环鍙樺寲璁$畻鎬讳环
-  const calculateFromUnitPrice = () => {
-    if (!productForm.value.taxRate) {
-      proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
-      return;
-    }
-    if (isCalculating.value) return;
-
-    const quantity = parseFloat(productForm.value.quantity);
-    const unitPrice = parseFloat(productForm.value.taxInclusiveUnitPrice);
-
-    if (!quantity || quantity <= 0 || !unitPrice) {
-      return;
-    }
-
-    isCalculating.value = true;
-
-    // 璁$畻鍚◣鎬讳环
-    productForm.value.taxInclusiveTotalPrice = (unitPrice * quantity).toFixed(2);
-
-    // 濡傛灉鏈夌◣鐜囷紝璁$畻涓嶅惈绋庢�讳环
-    if (productForm.value.taxRate) {
-      productForm.value.taxExclusiveTotalPrice =
-        proxy.calculateTaxExclusiveTotalPrice(
-          productForm.value.taxInclusiveTotalPrice,
-          productForm.value.taxRate
-        );
-    }
-
-    isCalculating.value = false;
-  };
-
-  // 鏍规嵁绋庣巼鍙樺寲璁$畻涓嶅惈绋庢�讳环
-  const calculateFromTaxRate = () => {
-    if (!productForm.value.taxRate) {
-      proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
-      return;
-    }
-    if (isCalculating.value) return;
-
-    const inclusiveTotalPrice = parseFloat(
-      productForm.value.taxInclusiveTotalPrice
-    );
-    const taxRate = parseFloat(productForm.value.taxRate);
-
-    if (!inclusiveTotalPrice || !taxRate) {
-      return;
-    }
-
-    isCalculating.value = true;
-
-    // 璁$畻涓嶅惈绋庢�讳环
+  // 濡傛灉鏈夌◣鐜囷紝璁$畻涓嶅惈绋庢�讳环
+  if (productForm.value.taxRate) {
     productForm.value.taxExclusiveTotalPrice =
-      proxy.calculateTaxExclusiveTotalPrice(inclusiveTotalPrice, taxRate);
+      proxy.calculateTaxExclusiveTotalPrice(
+        totalPrice,
+        productForm.value.taxRate
+      );
+  }
 
-    isCalculating.value = false;
-  };
-  /**
-   * 涓嬭浇鏂囦欢
-   *
-   * @param row 涓嬭浇鏂囦欢鐨勭浉鍏充俊鎭璞�
-   */
-  const fileListRef = ref(null);
-  const downLoadFile = row => {
-    getSalesLedgerWithProducts({ id: row.id, type: 1 }).then(res => {
-      fileListRef.value.open(res.salesLedgerFiles);
-    });
-  };
+  isCalculating.value = false;
+};
 
-  // 鎵撳紑鍙戣揣寮规
-  const openDeliveryForm = row => {
+// 鏍规嵁涓嶅惈绋庢�讳环璁$畻鍚◣鍗曚环鍜屾暟閲�
+const calculateFromExclusiveTotalPrice = () => {
+	if (!productForm.value.taxRate) {
+		proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
+		return;
+	}
+  if (isCalculating.value) return;
+
+  const exclusiveTotalPrice = parseFloat(productForm.value.taxExclusiveTotalPrice);
+  const quantity = parseFloat(productForm.value.quantity);
+  const taxRate = parseFloat(productForm.value.taxRate);
+
+  if (!exclusiveTotalPrice || !quantity || quantity <= 0 || !taxRate) {
+    return;
+  }
+
+  isCalculating.value = true;
+
+  // 鍏堣绠楀惈绋庢�讳环 = 涓嶅惈绋庢�讳环 / (1 - 绋庣巼/100)
+  const taxRateDecimal = taxRate / 100;
+  const inclusiveTotalPrice = exclusiveTotalPrice / (1 - taxRateDecimal);
+  productForm.value.taxInclusiveTotalPrice = inclusiveTotalPrice.toFixed(2);
+
+  // 璁$畻鍚◣鍗曚环 = 鍚◣鎬讳环 / 鏁伴噺
+  productForm.value.taxInclusiveUnitPrice = (inclusiveTotalPrice / quantity).toFixed(2);
+
+  isCalculating.value = false;
+};
+
+// 鏍规嵁鏁伴噺鍙樺寲璁$畻鎬讳环
+const calculateFromQuantity = () => {
+	if (!productForm.value.taxRate) {
+		proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
+		return;
+	}
+  if (isCalculating.value) return;
+
+  const quantity = parseFloat(productForm.value.quantity);
+  const unitPrice = parseFloat(productForm.value.taxInclusiveUnitPrice);
+
+  if (!quantity || quantity <= 0 || !unitPrice) {
+    return;
+  }
+
+  isCalculating.value = true;
+
+  // 璁$畻鍚◣鎬讳环
+  productForm.value.taxInclusiveTotalPrice = (unitPrice * quantity).toFixed(2);
+
+  // 濡傛灉鏈夌◣鐜囷紝璁$畻涓嶅惈绋庢�讳环
+  if (productForm.value.taxRate) {
+    productForm.value.taxExclusiveTotalPrice =
+      proxy.calculateTaxExclusiveTotalPrice(
+        productForm.value.taxInclusiveTotalPrice,
+        productForm.value.taxRate
+      );
+  }
+
+  isCalculating.value = false;
+};
+
+// 鏍规嵁鍚◣鍗曚环鍙樺寲璁$畻鎬讳环
+const calculateFromUnitPrice = () => {
+	if (!productForm.value.taxRate) {
+		proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
+		return;
+	}
+  if (isCalculating.value) return;
+
+  const quantity = parseFloat(productForm.value.quantity);
+  const unitPrice = parseFloat(productForm.value.taxInclusiveUnitPrice);
+
+  if (!quantity || quantity <= 0 || !unitPrice) {
+    return;
+  }
+
+  isCalculating.value = true;
+
+  // 璁$畻鍚◣鎬讳环
+  productForm.value.taxInclusiveTotalPrice = (unitPrice * quantity).toFixed(2);
+
+  // 濡傛灉鏈夌◣鐜囷紝璁$畻涓嶅惈绋庢�讳环
+  if (productForm.value.taxRate) {
+    productForm.value.taxExclusiveTotalPrice =
+      proxy.calculateTaxExclusiveTotalPrice(
+        productForm.value.taxInclusiveTotalPrice,
+        productForm.value.taxRate
+      );
+  }
+
+  isCalculating.value = false;
+};
+
+// 鏍规嵁绋庣巼鍙樺寲璁$畻涓嶅惈绋庢�讳环
+const calculateFromTaxRate = () => {
+	if (!productForm.value.taxRate) {
+		proxy.$modal.msgWarning("璇峰厛閫夋嫨绋庣巼");
+		return;
+	}
+  if (isCalculating.value) return;
+
+  const inclusiveTotalPrice = parseFloat(productForm.value.taxInclusiveTotalPrice);
+  const taxRate = parseFloat(productForm.value.taxRate);
+
+  if (!inclusiveTotalPrice || !taxRate) {
+    return;
+  }
+
+  isCalculating.value = true;
+
+  // 璁$畻涓嶅惈绋庢�讳环
+  productForm.value.taxExclusiveTotalPrice =
+    proxy.calculateTaxExclusiveTotalPrice(
+      inclusiveTotalPrice,
+      taxRate
+    );
+
+  isCalculating.value = false;
+};
+/**
+ * 涓嬭浇鏂囦欢
+ *
+ * @param row 涓嬭浇鏂囦欢鐨勭浉鍏充俊鎭璞�
+ */
+const fileListRef = ref(null)
+const downLoadFile = (row) => {
+  getSalesLedgerWithProducts({ id: row.id, type: 1 }).then((res) => {
+    fileListRef.value.open(res.salesLedgerFiles)
+  });
+}
+
+// 鎵撳紑鍙戣揣寮规
+const openDeliveryForm = (row) => {
+  getProductInventory({ salesLedgerId: row.id, type:1 }).then((res) => {
     currentDeliveryRow.value = row;
     deliveryForm.value = {
-      shippingDate: "", // 绉婚櫎榛樿鍊艰缃�
+      shippingDate: getCurrentDate(),
       shippingCarNumber: "",
     };
     deliveryFormVisible.value = true;
-  };
-
-  // 鎻愪氦鍙戣揣琛ㄥ崟
-  const submitDelivery = () => {
-    proxy.$refs["deliveryFormRef"].validate(valid => {
-      if (valid) {
-        addShippingInfo({
-          approverId: deliveryForm.value.approverId,
-          salesLedgerId: currentDeliveryRow.value.salesLedgerId,
-          salesLedgerProductId: currentDeliveryRow.value.id,
-          shippingDate: deliveryForm.value.shippingDate,
-          shippingCarNumber: deliveryForm.value.shippingCarNumber,
-        })
-          .then(() => {
-            proxy.$modal.msgSuccess("鍙戣揣鎴愬姛");
-            closeDeliveryDia();
-            getList();
-            expandedRowKeys.value = [];
-          })
-          .catch(() => {
-            proxy.$modal.msgError("鍙戣揣澶辫触锛岃閲嶈瘯");
-          });
-      }
-    });
-  };
-
-  // 鍏抽棴鍙戣揣寮规
-  const closeDeliveryDia = () => {
-    proxy.resetForm("deliveryFormRef");
-    deliveryFormVisible.value = false;
-    currentDeliveryRow.value = null;
-  };
-
-  onMounted(() => {
-    getList();
+  }).catch(err => {
+    ElMessage.error(err.msg);
   });
+};
+
+// 鎻愪氦鍙戣揣琛ㄥ崟
+const submitDelivery = () => {
+  proxy.$refs["deliveryFormRef"].validate((valid) => {
+    if (valid) {
+      addShippingInfo({
+        salesLedgerId: currentDeliveryContext.value.parentRow.id,
+        salesLedgerProductId: currentDeliveryContext.value.productRow.id,
+        shippingDate: deliveryForm.value.shippingDate,
+        shippingCarNumber: deliveryForm.value.shippingCarNumber,
+      })
+        .then(() => {
+          proxy.$modal.msgSuccess("鍙戣揣鎴愬姛");
+          closeDeliveryDia();
+        })
+        .catch(() => {
+          proxy.$modal.msgError("鍙戣揣澶辫触锛岃閲嶈瘯");
+        });
+    }
+  });
+};
+
+// 鍏抽棴鍙戣揣寮规
+const closeDeliveryDia = () => {
+  proxy.resetForm("deliveryFormRef");
+  deliveryFormVisible.value = false;
+  currentDeliveryContext.value = null;
+};
+
+onMounted(() => {
+	getList();
+});
 </script>
 
 <style scoped lang="scss">
-  .ml-10 {
-    margin-left: 10px;
-  }
+.ml-10 {
+  margin-left: 10px;
+}
 
-  .table_list {
-    margin-top: unset;
-  }
+.table_list {
+  margin-top: unset;
+}
 
-  .actions {
-    display: flex;
-    justify-content: space-between;
-    margin-bottom: 10px;
-  }
-  .print-preview-dialog {
-    .el-dialog__body {
-      padding: 0;
-      max-height: 80vh;
-      overflow-y: auto;
-    }
-  }
+.actions {
+  display: flex;
+  justify-content: space-between;
+  margin-bottom: 10px;
+}
+.print-preview-dialog {
+	.el-dialog__body {
+		padding: 0;
+		max-height: 80vh;
+		overflow-y: auto;
+	}
+}
 
-  .print-preview-container {
-    .print-preview-header {
-      padding: 15px;
-      border-bottom: 1px solid #e4e7ed;
-      text-align: center;
+.print-preview-container {
+	.print-preview-header {
+		padding: 15px;
+		border-bottom: 1px solid #e4e7ed;
+		text-align: center;
 
-      .el-button {
-        margin: 0 10px;
-      }
-    }
+		.el-button {
+			margin: 0 10px;
+		}
+	}
 
-    .print-preview-content {
-      padding: 20px;
-      background-color: #f5f5f5;
-      min-height: 400px;
-    }
-  }
+	.print-preview-content {
+		padding: 20px;
+		background-color: #f5f5f5;
+		min-height: 400px;
+	}
+}
 
-  .print-page {
-    width: 220mm;
-    height: 90mm;
-    padding: 10mm;
-    margin: 0 auto;
-    background: white;
-    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
-    margin-bottom: 10px;
-    box-sizing: border-box;
-  }
+.print-page {
+	width: 220mm;
+	height: 90mm;
+	padding: 10mm;
+	margin: 0 auto;
+	background: white;
+	box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
+	margin-bottom: 10px;
+	box-sizing: border-box;
+}
 
-  .delivery-note {
-    width: 100%;
-    height: 100%;
-    font-family: "SimSun", serif;
-    font-size: 10px;
-    line-height: 1.2;
-    display: flex;
-    flex-direction: column;
-  }
+.delivery-note {
+	width: 100%;
+	height: 100%;
+	font-family: "SimSun", serif;
+	font-size: 10px;
+	line-height: 1.2;
+	display: flex;
+	flex-direction: column;
+}
 
-  .header {
-    text-align: center;
-    margin-bottom: 8px;
+.header {
+	text-align: center;
+	margin-bottom: 8px;
 
-    .company-name {
-      font-size: 18px;
-      font-weight: bold;
-      margin-bottom: 4px;
-    }
+	.company-name {
+		font-size: 18px;
+		font-weight: bold;
+		margin-bottom: 4px;
+	}
 
-    .document-title {
-      font-size: 16px;
-      font-weight: bold;
-    }
-  }
+	.document-title {
+		font-size: 16px;
+		font-weight: bold;
+	}
+}
 
-  .info-section {
-    margin-bottom: 8px;
-    display: flex;
-    justify-content: space-between;
-    align-items: center;
+.info-section {
+	margin-bottom: 8px;
+	display: flex;
+	justify-content: space-between;
+	align-items: center;
 
-    .info-row {
-      line-height: 20px;
+	.info-row {
+		line-height: 20px;
 
-      .label {
-        font-weight: bold;
-        width: 60px;
-        font-size: 14px;
-      }
+		.label {
+			font-weight: bold;
+			width: 60px;
+			font-size: 14px;
+		}
 
-      .value {
-        margin-right: 20px;
-        min-width: 80px;
-        font-size: 14px;
-      }
-    }
-  }
+		.value {
+			margin-right: 20px;
+			min-width: 80px;
+			font-size: 14px;
+		}
+	}
+}
 
-  .table-section {
-    margin-bottom: 4px;
-    flex: 1;
+.table-section {
+	margin-bottom: 4px;
+	flex: 1;
 
-    .product-table {
-      width: 100%;
-      border-collapse: collapse;
-      border: 1px solid #000;
+	.product-table {
+		width: 100%;
+		border-collapse: collapse;
+		border: 1px solid #000;
 
-      th,
-      td {
-        border: 1px solid #000;
-        padding: 6px;
-        text-align: center;
-        font-size: 14px;
-        line-height: 1.4;
-      }
+		th, td {
+			border: 1px solid #000;
+			padding: 6px;
+			text-align: center;
+			font-size: 14px;
+			line-height: 1.4;
+		}
 
-      th {
-        font-weight: bold;
-      }
+		th {
+			font-weight: bold;
+		}
 
-      .total-label {
-        text-align: right;
-        font-weight: bold;
-      }
+		.total-label {
+			text-align: right;
+			font-weight: bold;
+		}
 
-      .total-value {
-        font-weight: bold;
-      }
-    }
-  }
+		.total-value {
+			font-weight: bold;
+		}
+	}
+}
 
-  .footer-section {
-    .footer-row {
-      display: flex;
-      margin-bottom: 3px;
-      line-height: 20px;
-      justify-content: space-between;
+.footer-section {
+	.footer-row {
+		display: flex;
+		margin-bottom: 3px;
+		line-height: 20px;
+		justify-content: space-between;
 
-      .footer-item {
-        display: flex;
-        margin-right: 20px;
+		.footer-item {
+			display: flex;
+			margin-right: 20px;
 
-        .label {
-          font-weight: bold;
-          width: 80px;
-          font-size: 14px;
-        }
+			.label {
+				font-weight: bold;
+				width: 80px;
+				font-size: 14px;
+			}
 
-        .value {
-          min-width: 80px;
-          font-size: 14px;
-        }
+			.value {
+				min-width: 80px;
+				font-size: 14px;
+			}
 
-        &.address-item {
-          .address-value {
-            min-width: 200px;
-          }
-        }
-      }
-    }
-  }
+			&.address-item {
+				.address-value {
+					min-width: 200px;
+				}
+			}
+		}
+	}
+}
 
-  @media print {
-    .app-container {
-      display: none;
-    }
+@media print {
+	.app-container {
+		display: none;
+	}
 
-    .print-page {
-      box-shadow: none;
-      margin: 0;
-      padding: 10mm;
-      padding-left: 20mm;
-      page-break-inside: avoid;
-      page-break-after: always;
-    }
-    .print-page:last-child {
-      page-break-after: avoid;
-    }
-  }
+	.print-page {
+		box-shadow: none;
+		margin: 0;
+		padding: 10mm;
+		padding-left: 20mm;
+		page-break-inside: avoid;
+		page-break-after: always;
+	}
+	.print-page:last-child {
+		page-break-after: avoid;
+	}
+}
 </style>

--
Gitblit v1.9.3