From 03346ce6776f26f580e9a1156977367265435bc4 Mon Sep 17 00:00:00 2001
From: 云 <2163098428@qq.com>
Date: 星期二, 12 五月 2026 15:23:24 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev_NEW_pro' into dev_NEW_pro

---
 src/views/index.vue                                                        |    2 
 src/views/financialManagement/receivable/salesOut.vue                      |  272 +++-------
 src/views/projectManagement/projectType/index.vue                          |    9 
 src/views/basicData/product/index.vue                                      |   38 +
 src/views/productionManagement/workOrderManagement/components/filesDia.vue |    2 
 src/views/lavorissue/ledger/filesDia.vue                                   |    2 
 src/views/salesManagement/invoiceLedger/index.vue                          |    6 
 src/views/basicData/customerFile/index.vue                                 |   37 +
 src/views/equipmentManagement/measurementEquipment/filesDia.vue            |    2 
 src/views/projectManagement/Management/components/formDia.vue              |    4 
 src/components/Dialog/FileList.vue                                         |   22 
 src/views/salesManagement/salesLedger/fileList.vue                         |    2 
 src/api/financialManagement/accountPurchase.js                             |   19 
 src/views/collaborativeApproval/shipmentReview/fileList.vue                |    3 
 src/views/procurementManagement/procurementLedger/fileList.vue             |    3 
 src/views/basicData/customerFileOpenSea/index.vue                          |    2 
 src/views/qualityManagement/rawMaterialInspection/components/filesDia.vue  |    2 
 src/api/basicData/customer.js                                              |    8 
 src/router/index.js                                                        |    7 
 src/views/basicData/supplierManage/filesDia.vue                            |    2 
 src/views/financialManagement/receivable/salesReturn.vue                   |  308 +++---------
 src/views/qualityManagement/finalInspection/components/filesDia.vue        |    2 
 src/views/productionManagement/workOrder/components/filesDia.vue           |    2 
 src/views/financialManagement/payable/purchaseIn.vue                       |  326 +++----------
 src/views/qualityManagement/processInspection/components/filesDia.vue      |    2 
 src/views/projectManagement/Management/projectDetail.vue                   |   12 
 src/views/collaborativeApproval/approvalProcess/fileList.vue               |    3 
 src/views/personnelManagement/contractManagement/filesDia.vue              |    2 
 src/plugins/download.js                                                    |   10 
 src/views/safeProduction/safeWorkApproval/fileList.vue                     |    2 
 src/api/financialManagement/accountSales.js                                |   19 
 src/components/filePreview/index.vue                                       |   16 
 src/views/financialManagement/payable/purchaseReturn.vue                   |  239 +++++++++
 33 files changed, 670 insertions(+), 717 deletions(-)

diff --git a/src/api/basicData/customer.js b/src/api/basicData/customer.js
index 28f2eab..0934193 100644
--- a/src/api/basicData/customer.js
+++ b/src/api/basicData/customer.js
@@ -26,6 +26,14 @@
     })
 }
 
+// 娴佸叆鍏捣
+export function backCustomer(id) {
+    return request({
+        url: '/basic/customer/back/' + id,
+        method: 'post'
+    })
+}
+
 export function shareCustomer(data) {
     return request({
         url: '/basic/customer/together',
diff --git a/src/api/financialManagement/accountPurchase.js b/src/api/financialManagement/accountPurchase.js
new file mode 100644
index 0000000..9e2d508
--- /dev/null
+++ b/src/api/financialManagement/accountPurchase.js
@@ -0,0 +1,19 @@
+import request from "@/utils/request";
+
+/** 閲囪喘鍏ュ簱鍒嗛〉鍒楄〃 */
+export const listPageAccountPurchase = (params) => {
+  return request({
+    url: "/accountPurchase/listPageAccountPurchase",
+    method: "get",
+    params,
+  });
+};
+
+/** 閲囪喘閫�璐у垎椤靛垪琛� */
+export const listPageAccountPurchaseReturn = (params) => {
+  return request({
+    url: "/accountPurchase/listPageAccountPurchaseReturn",
+    method: "get",
+    params,
+  });
+};
diff --git a/src/api/financialManagement/accountSales.js b/src/api/financialManagement/accountSales.js
new file mode 100644
index 0000000..e56d50f
--- /dev/null
+++ b/src/api/financialManagement/accountSales.js
@@ -0,0 +1,19 @@
+import request from "@/utils/request";
+
+/** 閿�鍞嚭搴撳垎椤靛垪琛� */
+export const listPageAccountSales = (params) => {
+  return request({
+    url: "/accountSales/listPageAccountSales",
+    method: "get",
+    params,
+  });
+};
+
+/** 閿�鍞��璐у垎椤靛垪琛� */
+export const listPageAccountSalesReturn = (params) => {
+  return request({
+    url: "/accountSales/listPageAccountSalesReturn",
+    method: "get",
+    params,
+  });
+};
diff --git a/src/components/Dialog/FileList.vue b/src/components/Dialog/FileList.vue
index 139dbfb..b0e78cf 100644
--- a/src/components/Dialog/FileList.vue
+++ b/src/components/Dialog/FileList.vue
@@ -36,9 +36,16 @@
         <el-table-column v-if="showActions"
                          fixed="right"
                          label="鎿嶄綔"
-                         :width="120"
+                         :width="150"
                          align="center">
           <template #default="scope">
+            <el-button link
+                       type="primary"
+                       size="small"
+                       class="download-link"
+                       @click="previewFile(scope.row.previewURL)">
+              棰勮
+            </el-button>
             <el-button link
                        type="primary"
                        size="small"
@@ -58,9 +65,11 @@
       </el-table>
     </div>
   </el-dialog>
+  <filePreview ref="filePreviewRef" />
 </template>
 
 <script setup>
+import { ElMessage } from 'element-plus'
   import { ref, computed, getCurrentInstance, onMounted, watch } from "vue";
   import AttachmentUpload from "@/components/AttachmentUpload/file/index.vue";
   import {
@@ -68,6 +77,8 @@
     deleteAttachment,
     createAttachment,
   } from "@/api/basicData/storageAttachment.js";
+  import filePreview from '@/components/filePreview/index.vue'
+  const filePreviewRef = ref()
 
   const props = defineProps({
     visible: {
@@ -122,6 +133,15 @@
     isShow.value = false;
   };
 
+  // 棰勮鏂囦欢
+  const previewFile = (url) => {
+    if (url) {
+      filePreviewRef.value.open(url)
+    } else {
+      ElMessage.warning('鏂囦欢鍦板潃鏃犳晥锛屾棤娉曢瑙�')
+    }
+  }
+
   const handleUpload = () => {
     uploadDialogVisible.value = true;
   };
diff --git a/src/components/filePreview/index.vue b/src/components/filePreview/index.vue
index cda5b56..d8720c3 100644
--- a/src/components/filePreview/index.vue
+++ b/src/components/filePreview/index.vue
@@ -78,9 +78,9 @@
   transformData: (workbookData) => workbookData,
 });
 
-// 璁$畻灞炴�� - 鍒ゆ柇鏂囦欢绫诲瀷
+// 璁$畻灞炴�� - 鍒ゆ柇鏂囦欢绫诲瀷锛堟敮鎸乁RL甯︽煡璇㈠弬鏁帮級
 const isImage = computed(() => {
-  const state = /\.(jpg|jpeg|png|gif)$/i.test(fileUrl.value);
+  const state = /\.(jpg|jpeg|png|gif)(\?.*)?$/i.test(fileUrl.value);
   if (state) {
     imgUrl.value = fileUrl.value.replaceAll('word', 'img');
   }
@@ -89,23 +89,23 @@
 
 const isPdf = computed(() => {
   console.log(fileUrl.value)
-  return /\.pdf$/i.test(fileUrl.value);
+  return /\.pdf(\?.*)?$/i.test(fileUrl.value);
 });
 
 const isDoc = computed(() => {
-  return /\.(doc|docx)$/i.test(fileUrl.value);
+  return /\.(doc|docx)(\?.*)?$/i.test(fileUrl.value);
 });
 
 const isXls = computed(() => {
-  const state = /\.(xls|xlsx)$/i.test(fileUrl.value);
+  const state = /\.(xls|xlsx)(\?.*)?$/i.test(fileUrl.value);
   if (state) {
-    options.value.xls = /\.(xls)$/i.test(fileUrl.value);
+    options.value.xls = /\.(xls)(\?.*)?$/i.test(fileUrl.value);
   }
   return state;
 });
 
 const isZipOrRar = computed(() => {
-  return /\.(zip|rar)$/i.test(fileUrl.value);
+  return /\.(zip|rar)(\?.*)?$/i.test(fileUrl.value);
 });
 
 const isSupported = computed(() => {
@@ -164,7 +164,7 @@
 };
 
 const open = (url) => {
-  fileUrl.value = window.location.protocol+'//'+window.location.host+ url;
+  fileUrl.value = url;
   dialogVisible.value = true;
 };
 const handleClose = () => {
diff --git a/src/plugins/download.js b/src/plugins/download.js
index 2705310..35ac92f 100644
--- a/src/plugins/download.js
+++ b/src/plugins/download.js
@@ -82,6 +82,16 @@
   saveAs(text, name, opts) {
     saveAs(text, name, opts);
   },
+  byUrl(url, filename) {
+    // 灏哢RL涓殑preview鏇挎崲鎴恉ownload
+    const downloadUrl = url.replace(/preview/g, 'download')
+    const link = document.createElement('a')
+    link.href = downloadUrl
+    link.download = filename || ''
+    document.body.appendChild(link)
+    link.click()
+    document.body.removeChild(link)
+  },
   async printErrMsg(data) {
     const resText = await data.text();
     const rspObj = JSON.parse(resText);
diff --git a/src/router/index.js b/src/router/index.js
index aea22ca..d809a63 100644
--- a/src/router/index.js
+++ b/src/router/index.js
@@ -183,7 +183,12 @@
         name: "PurchaseIn",
         meta: { title: "閲囪喘鍏ュ簱" },
       },
-      
+      {
+        path: "purchase-return",
+        component: () => import("@/views/financialManagement/payable/purchaseReturn.vue"),
+        name: "PurchaseReturn",
+        meta: { title: "閲囪喘閫�璐�" },
+      },
       {
         path: "input-invoice",
         component: () => import("@/views/financialManagement/payable/input-invoice.vue"),
diff --git a/src/views/basicData/customerFile/index.vue b/src/views/basicData/customerFile/index.vue
index a080bd9..7091a02 100644
--- a/src/views/basicData/customerFile/index.vue
+++ b/src/views/basicData/customerFile/index.vue
@@ -27,6 +27,9 @@
       <div>
         <el-button type="primary"
                    @click="openForm('add')">鏂板瀹㈡埛</el-button>
+        <el-button type="primary"
+                   plain
+                   @click="back">娴佸叆鍏捣</el-button>
         <el-button @click="handleOut">瀵煎嚭</el-button>
         <el-button type="info"
                    plain
@@ -619,7 +622,7 @@
     addReturnVisit,
     getReturnVisit,
   } from "@/api/basicData/customerFile.js";
-  import {listCustomer, getCustomer, addCustomer, updateCustomer, delCustomer} from "@/api/basicData/customer.js";
+  import {listCustomer, getCustomer, addCustomer, updateCustomer, delCustomer, backCustomer} from "@/api/basicData/customer.js";
   import { ElMessageBox } from "element-plus";
   import { userListNoPage } from "@/api/system/user.js";
   import useUserStore from "@/store/modules/user";
@@ -1126,6 +1129,36 @@
       });
   };
 
+  const back = () => {
+    if (selectedRows.value.length === 0) {
+      proxy.$modal.msgWarning("璇烽�夋嫨鏁版嵁");
+      return;
+    }
+    const ids = selectedRows.value.map(item => item.id);
+    ElMessageBox.confirm("閫変腑鐨勫鎴峰皢娴佸叆鍏捣锛屾槸鍚︾‘璁わ紵", "娴佸叆鍏捣鎻愮ず", {
+      confirmButtonText: "纭",
+      cancelButtonText: "鍙栨秷",
+      type: "warning",
+    })
+      .then(() => {
+        tableLoading.value = true;
+        return Promise.all(ids.map(id => backCustomer(id)))
+          .then(() => {
+            proxy.$modal.msgSuccess("娴佸叆鍏捣鎴愬姛");
+            selectedRows.value = [];
+            getList();
+          })
+          .finally(() => {
+            tableLoading.value = false;
+          });
+      })
+      .catch(error => {
+        if (error === "cancel" || error === "close") {
+          proxy.$modal.msg("宸插彇娑�");
+        }
+      });
+  };
+
   // 鎵撳紑鍥炶鎻愰啋寮圭獥
   const openReminderDialog = row => {
     currentCustomerId.value = row.id;
@@ -1413,7 +1446,7 @@
   const downloadAttachment = row => {
     if (row.url) {
       // proxy.download(row.url, {}, row.name);
-      proxy.$download.name(row.url);
+			proxy.$download.byUrl(row.url, row.originalFilename);
     } else {
       proxy.$modal.msgError("涓嬭浇閾炬帴涓嶅瓨鍦�");
     }
diff --git a/src/views/basicData/customerFileOpenSea/index.vue b/src/views/basicData/customerFileOpenSea/index.vue
index 2598f48..bad28e1 100644
--- a/src/views/basicData/customerFileOpenSea/index.vue
+++ b/src/views/basicData/customerFileOpenSea/index.vue
@@ -1651,7 +1651,7 @@
   const downloadAttachment = row => {
     if (row.url) {
       // proxy.download(row.url, {}, row.name);
-      proxy.$download.name(row.url);
+			proxy.$download.byUrl(row.url, row.originalFilename);
     } else {
       proxy.$modal.msgError("涓嬭浇閾炬帴涓嶅瓨鍦�");
     }
diff --git a/src/views/basicData/product/index.vue b/src/views/basicData/product/index.vue
index 99ab028..07da49b 100644
--- a/src/views/basicData/product/index.vue
+++ b/src/views/basicData/product/index.vue
@@ -43,12 +43,12 @@
                 <el-button type="primary"
                            link
                            :disabled="isTopLevelNode(data, node)"
-                           @click="openProDia('edit', data)">
+                           @click="openProDia('edit', data, node)">
                   缂栬緫
                 </el-button>
                 <el-button type="primary"
                            link
-                           @click="openProDia('add', data)">
+                           @click="openProDia('add', data, node)">
                   娣诲姞浜у搧
                 </el-button>
                 <el-button v-if="!node.childNodes.length"
@@ -285,6 +285,8 @@
   const search = ref("");
   const currentId = ref("");
   const currentParentId = ref("");
+  /** 浜у搧寮圭獥锛歛dd 瀛樼埗鑺傜偣 id锛沞dit 瀛樺綋鍓嶈妭鐐� id 涓� parentId锛堜笉渚濊禆鏍戦�変腑椤癸級 */
+  const productDialogTarget = ref(null);
   const operationType = ref("");
   const treeLoad = ref(false);
   const list = ref([]);
@@ -388,17 +390,28 @@
     return [null, undefined, "", 0, "0"].includes(data?.parentId);
   };
   // 鎵撳紑浜у搧寮规
-  const openProDia = (type, data) => {
-    if (data && type === "edit" && isTopLevelNode(data)) {
+  const openProDia = (type, data, node) => {
+    if (data && type === "edit" && isTopLevelNode(data, node)) {
       proxy.$modal.msgWarning("涓�绾ц妭鐐逛笉鑳界紪杈戞垨鍒犻櫎");
       return;
     }
     operationType.value = type;
-    productDia.value = true;
-    form.value.productName = "";
-    if (type === "edit") {
-      form.value.productName = data.productName;
+    productDialogTarget.value = null;
+    if (type === "add" && data) {
+      productDialogTarget.value = { parentId: data.id };
+    } else if (type === "edit" && data) {
+      let parentId = data.parentId;
+      if (
+        [null, undefined, ""].includes(parentId) &&
+        node?.parent?.data?.id != null
+      ) {
+        parentId = node.parent.data.id;
+      }
+      productDialogTarget.value = { id: data.id, parentId };
     }
+    productDia.value = true;
+    form.value.productName =
+      type === "edit" && data ? data.productName : "";
   };
   // 鎵撳紑瑙勬牸鍨嬪彿寮规
   const openModelDia = (type, data) => {
@@ -417,14 +430,16 @@
     proxy.$refs.formRef.validate(valid => {
       if (valid) {
         if (operationType.value === "add") {
-          form.value.parentId = currentId.value;
+          form.value.parentId =
+            productDialogTarget.value?.parentId ?? currentId.value;
           form.value.id = "";
         } else if (operationType.value === "addOne") {
           form.value.id = "";
           form.value.parentId = "";
         } else {
-          form.value.id = currentId.value;
-          form.value.parentId = "";
+          form.value.id =
+            productDialogTarget.value?.id ?? currentId.value;
+          form.value.parentId = productDialogTarget.value?.parentId ?? "";
         }
         addOrEditProduct(form.value).then(res => {
           proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
@@ -437,6 +452,7 @@
   // 鍏抽棴浜у搧寮规
   const closeProDia = () => {
     proxy.$refs.formRef.resetFields();
+    productDialogTarget.value = null;
     productDia.value = false;
   };
 
diff --git a/src/views/basicData/supplierManage/filesDia.vue b/src/views/basicData/supplierManage/filesDia.vue
index 7943185..ef41985 100644
--- a/src/views/basicData/supplierManage/filesDia.vue
+++ b/src/views/basicData/supplierManage/filesDia.vue
@@ -164,7 +164,7 @@
 }
 // 涓嬭浇闄勪欢
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 // 鍒犻櫎
 const handleDelete = () => {
diff --git a/src/views/collaborativeApproval/approvalProcess/fileList.vue b/src/views/collaborativeApproval/approvalProcess/fileList.vue
index 498f474..1f1b671 100644
--- a/src/views/collaborativeApproval/approvalProcess/fileList.vue
+++ b/src/views/collaborativeApproval/approvalProcess/fileList.vue
@@ -32,8 +32,7 @@
   tableData.value = list
 }
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
-
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 const lookFile = (row) => {
   filePreviewRef.value.open(row.url)
diff --git a/src/views/collaborativeApproval/shipmentReview/fileList.vue b/src/views/collaborativeApproval/shipmentReview/fileList.vue
index da37db2..555312a 100644
--- a/src/views/collaborativeApproval/shipmentReview/fileList.vue
+++ b/src/views/collaborativeApproval/shipmentReview/fileList.vue
@@ -29,8 +29,7 @@
   tableData.value = list
 }
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
-
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 const lookFile = (row) => {
   filePreviewRef.value.open(row.url)
diff --git a/src/views/equipmentManagement/measurementEquipment/filesDia.vue b/src/views/equipmentManagement/measurementEquipment/filesDia.vue
index ee9dc3a..16c026e 100644
--- a/src/views/equipmentManagement/measurementEquipment/filesDia.vue
+++ b/src/views/equipmentManagement/measurementEquipment/filesDia.vue
@@ -157,7 +157,7 @@
 }
 // 涓嬭浇闄勪欢
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 // 鍒犻櫎
 const handleDelete = () => {
diff --git a/src/views/financialManagement/payable/purchaseIn.vue b/src/views/financialManagement/payable/purchaseIn.vue
index 4813159..4fadcbb 100644
--- a/src/views/financialManagement/payable/purchaseIn.vue
+++ b/src/views/financialManagement/payable/purchaseIn.vue
@@ -1,19 +1,27 @@
 <template>
+  <!-- 閲囪喘鍏ュ簱 -->
   <div class="app-container">
     <el-form :model="filters" :inline="true">
       <el-form-item label="鍏ュ簱鍗曞彿:">
-        <el-input v-model="filters.inCode" placeholder="璇疯緭鍏ュ叆搴撳崟鍙�" clearable style="width: 200px;" />
+        <el-input v-model="filters.inboundBatches" placeholder="璇疯緭鍏ュ叆搴撳崟鍙�" clearable style="width: 200px;" />
       </el-form-item>
       <el-form-item label="渚涘簲鍟�:">
-        <el-select v-model="filters.supplierId" placeholder="璇烽�夋嫨渚涘簲鍟�" clearable style="width: 200px;">
-          <el-option v-for="item in supplierList" :key="item.id" :label="item.name" :value="item.id" />
-        </el-select>
+        <el-input v-model="filters.supplierName" placeholder="璇疯緭鍏ヤ緵搴斿晢" clearable style="width: 200px;" />
       </el-form-item>
       <el-form-item label="鍏ュ簱鏃ユ湡:">
-        <el-date-picker v-model="filters.dateRange" value-format="YYYY-MM-DD" format="YYYY-MM-DD" type="daterange" range-separator="鑷�" start-placeholder="寮�濮嬫棩鏈�" end-placeholder="缁撴潫鏃ユ湡" clearable />
+        <el-date-picker
+          v-model="filters.dateRange"
+          value-format="YYYY-MM-DD"
+          format="YYYY-MM-DD"
+          type="daterange"
+          range-separator="鑷�"
+          start-placeholder="寮�濮嬫棩鏈�"
+          end-placeholder="缁撴潫鏃ユ湡"
+          clearable
+        />
       </el-form-item>
       <el-form-item>
-        <el-button type="primary" @click="getTableData">鎼滅储</el-button>
+        <el-button type="primary" @click="onSearch">鎼滅储</el-button>
         <el-button @click="resetFilters">閲嶇疆</el-button>
       </el-form-item>
     </el-form>
@@ -28,6 +36,7 @@
         rowKey="id"
         :column="columns"
         :tableData="dataList"
+        :tableLoading="tableLoading"
         :page="{
           current: pagination.currentPage,
           size: pagination.pageSize,
@@ -35,107 +44,28 @@
         }"
         @pagination="changePage"
       >
-        <template #amount="{ row }">
-          <span class="text-primary">楼{{ formatMoney(row.amount) }}</span>
-        </template>
-        <template #status="{ row }">
-          <el-tag :type="getStatusType(row.status)">{{ getStatusLabel(row.status) }}</el-tag>
-        </template>
-        <template #operation="{ row }">
-          <el-button type="primary" link @click="view(row)">鏌ョ湅</el-button>
-          <el-button type="primary" link @click="edit(row)" v-if="row.status === 'pending'">缂栬緫</el-button>
-          <el-button type="danger" link @click="handleDelete(row)" v-if="row.status === 'pending'">鍒犻櫎</el-button>
+        <template #inboundDate="{ row }">
+          {{ row.InboundDate || row.inboundDate || "" }}
         </template>
       </PIMTable>
     </div>
-
-    <FormDialog :title="dialogTitle" v-model="dialogVisible" width="800px" @confirm="submitForm" @cancel="dialogVisible = false">
-      <el-form :model="form" :rules="rules" ref="formRef" label-width="100px">
-        <el-row :gutter="20">
-          <el-col :span="12">
-            <el-form-item label="鍏ュ簱鍗曞彿" prop="inCode">
-              <el-input v-model="form.inCode" placeholder="璇疯緭鍏ュ叆搴撳崟鍙�" :disabled="isEdit" />
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="渚涘簲鍟�" prop="supplierId">
-              <el-select v-model="form.supplierId" placeholder="璇烽�夋嫨渚涘簲鍟�" style="width: 100%;" :disabled="isEdit">
-                <el-option v-for="item in supplierList" :key="item.id" :label="item.name" :value="item.id" />
-              </el-select>
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-row :gutter="20">
-          <el-col :span="12">
-            <el-form-item label="鍏ュ簱鏃ユ湡" prop="inDate">
-              <el-date-picker v-model="form.inDate" type="date" placeholder="閫夋嫨鏃ユ湡" value-format="YYYY-MM-DD" style="width: 100%;" />
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="鍏ュ簱閲戦" prop="amount">
-              <el-input-number v-model="form.amount" :min="0" :precision="2" style="width: 100%;" />
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-form-item label="鍏ュ簱鏄庣粏" prop="details">
-          <el-table :data="form.details" border style="width: 100%">
-            <el-table-column prop="materialName" label="鐗╂枡鍚嶇О" width="150">
-              <template #default="{ $index }">
-                <el-input v-model="form.details[$index].materialName" placeholder="鐗╂枡鍚嶇О" />
-              </template>
-            </el-table-column>
-            <el-table-column prop="spec" label="瑙勬牸" width="120">
-              <template #default="{ $index }">
-                <el-input v-model="form.details[$index].spec" placeholder="瑙勬牸" />
-              </template>
-            </el-table-column>
-            <el-table-column prop="quantity" label="鏁伴噺" width="100">
-              <template #default="{ $index }">
-                <el-input-number v-model="form.details[$index].quantity" :min="0" style="width: 100%;" />
-              </template>
-            </el-table-column>
-            <el-table-column prop="unitPrice" label="鍗曚环" width="120">
-              <template #default="{ $index }">
-                <el-input-number v-model="form.details[$index].unitPrice" :min="0" :precision="2" style="width: 100%;" />
-              </template>
-            </el-table-column>
-            <el-table-column prop="total" label="閲戦" width="120">
-              <template #default="{ row }">
-                <span>楼{{ formatMoney(row.quantity * row.unitPrice) }}</span>
-              </template>
-            </el-table-column>
-            <el-table-column label="鎿嶄綔" width="80">
-              <template #default="{ $index }">
-                <el-button type="danger" link @click="removeDetail($index)">鍒犻櫎</el-button>
-              </template>
-            </el-table-column>
-          </el-table>
-          <el-button type="primary" link @click="addDetail" style="margin-top: 10px;">+ 娣诲姞鏄庣粏</el-button>
-        </el-form-item>
-        <el-form-item label="澶囨敞" prop="remark">
-          <el-input v-model="form.remark" type="textarea" :rows="3" placeholder="璇疯緭鍏ュ娉�" />
-        </el-form-item>
-      </el-form>
-      <template #footer>
-        <el-button type="primary" @click="submitForm">纭畾</el-button>
-        <el-button @click="dialogVisible = false">鍙栨秷</el-button>
-      </template>
-    </FormDialog>
   </div>
 </template>
 
 <script setup>
-import { ref, reactive, onMounted } from "vue";
-import { ElMessage, ElMessageBox } from "element-plus";
-import FormDialog from "@/components/Dialog/FormDialog.vue";
+import { ref, reactive, onMounted, getCurrentInstance } from "vue";
+import { ElMessage } from "element-plus";
+import { listPageAccountPurchase } from "@/api/financialManagement/accountPurchase";
 
 defineOptions({
   name: "閲囪喘鍏ュ簱",
 });
 
+const { proxy } = getCurrentInstance();
+
 const filters = reactive({
-  inCode: "",
-  supplierId: "",
+  inboundBatches: "",
+  supplierName: "",
   dateRange: [],
 });
 
@@ -146,170 +76,85 @@
 });
 
 const columns = [
-  { label: "鍏ュ簱鍗曞彿", prop: "inCode", width: "150" },
-  { label: "渚涘簲鍟�", prop: "supplierName", width: "180" },
-  { label: "鍏ュ簱鏃ユ湡", prop: "inDate", width: "120" },
-  { label: "鍏ュ簱閲戦", prop: "amount", slot: "amount" },
-  { label: "鐘舵��", prop: "status", slot: "status" },
-  { label: "澶囨敞", prop: "remark", showOverflowTooltip: true },
-  { label: "鎿嶄綔", prop: "operation", slot: "operation", width: "200", fixed: "right" },
+  { label: "鍏ュ簱鍗曞彿", prop: "inboundBatches", minWidth: "150" },
+  { label: "渚涘簲鍟�", prop: "supplierName", minWidth: "180" },
+  {
+    label: "鍏ュ簱鏃ユ湡",
+    prop: "InboundDate",
+    minWidth: "170",
+    dataType: "slot",
+    slot: "inboundDate",
+  },
+  { label: "浜у搧鍚嶇О", prop: "productName", minWidth: "140" },
+  { label: "浜у搧瑙勬牸", prop: "specificationModel", minWidth: "140" },
+  { label: "閲囪喘璁㈠崟鍙�", prop: "purchaseContractNumber", minWidth: "150" },
 ];
 
 const dataList = ref([]);
-const dialogVisible = ref(false);
-const dialogTitle = ref("");
-const formRef = ref(null);
-const isEdit = ref(false);
-const currentId = ref(null);
+const tableLoading = ref(false);
 
-const supplierList = [
-  { id: 1, name: "鍖椾含鍘熸潗鏂欎緵搴斿晢" },
-  { id: 2, name: "涓婃捣鐢靛瓙鍏冨櫒浠跺叕鍙�" },
-  { id: 3, name: "骞垮窞鍖呰鏉愭枡鍘�" },
-  { id: 4, name: "娣卞湷浜旈噾閰嶄欢鍏徃" },
-];
+function buildFilterParams() {
+  const params = {
+    inboundBatches: filters.inboundBatches || undefined,
+    supplierName: filters.supplierName || undefined,
+  };
+  if (filters.dateRange && filters.dateRange.length === 2) {
+    params.startDate = filters.dateRange[0];
+    params.endDate = filters.dateRange[1];
+  }
+  return params;
+}
 
-const form = reactive({
-  inCode: "",
-  supplierId: "",
-  inDate: "",
-  amount: 0,
-  details: [],
-  remark: "",
-});
-
-const rules = {
-  inCode: [{ required: true, message: "璇疯緭鍏ュ叆搴撳崟鍙�", trigger: "blur" }],
-  supplierId: [{ required: true, message: "璇烽�夋嫨渚涘簲鍟�", trigger: "change" }],
-  inDate: [{ required: true, message: "璇烽�夋嫨鍏ュ簱鏃ユ湡", trigger: "change" }],
-  amount: [{ required: true, message: "璇疯緭鍏ュ叆搴撻噾棰�", trigger: "blur" }],
-};
-
-const mockData = [
-  { id: 1, inCode: "RK2024001", supplierId: 1, supplierName: "鍖椾含鍘熸潗鏂欎緵搴斿晢", inDate: "2024-01-10", amount: 8000, status: "approved", details: [{ materialName: "閽㈡潗", spec: "Q235", quantity: 10, unitPrice: 500 }], remark: "" },
-  { id: 2, inCode: "RK2024002", supplierId: 2, supplierName: "涓婃捣鐢靛瓙鍏冨櫒浠跺叕鍙�", inDate: "2024-01-12", amount: 12000, status: "pending", details: [{ materialName: "鑺墖", spec: "STM32", quantity: 100, unitPrice: 80 }], remark: "" },
-  { id: 3, inCode: "RK2024003", supplierId: 3, supplierName: "骞垮窞鍖呰鏉愭枡鍘�", inDate: "2024-01-15", amount: 3500, status: "approved", details: [{ materialName: "绾哥", spec: "50*40*30", quantity: 500, unitPrice: 5 }], remark: "" },
-];
-
-const formatMoney = (value) => {
-  if (value === undefined || value === null) return "0.00";
-  return Number(value).toFixed(2).replace(/\B(?=(\d{3})+(?!\d))/g, ",");
-};
-
-const getStatusLabel = (status) => {
-  const map = { pending: "寰呭鏍�", approved: "宸插鏍�", rejected: "宸查┏鍥�" };
-  return map[status] || status;
-};
-
-const getStatusType = (status) => {
-  const map = { pending: "warning", approved: "success", rejected: "danger" };
-  return map[status] || "";
+const onSearch = () => {
+  pagination.currentPage = 1;
+  getTableData();
 };
 
 const getTableData = () => {
-  let result = [...mockData];
-  if (filters.inCode) {
-    result = result.filter(item => item.inCode.includes(filters.inCode));
-  }
-  if (filters.supplierId) {
-    result = result.filter(item => item.supplierId === filters.supplierId);
-  }
-  if (filters.dateRange && filters.dateRange.length === 2) {
-    result = result.filter(item => item.inDate >= filters.dateRange[0] && item.inDate <= filters.dateRange[1]);
-  }
-  pagination.total = result.length;
-  dataList.value = result.slice((pagination.currentPage - 1) * pagination.pageSize, pagination.currentPage * pagination.pageSize);
+  tableLoading.value = true;
+  listPageAccountPurchase({
+    ...buildFilterParams(),
+    current: pagination.currentPage,
+    size: pagination.pageSize,
+  })
+    .then((res) => {
+      const ok = res.code === 200 || res.code === 0;
+      if (ok && res.data) {
+        pagination.total = res.data.total ?? 0;
+        dataList.value = res.data.records ?? [];
+      } else {
+        ElMessage.error(res.msg || "鏌ヨ澶辫触");
+        dataList.value = [];
+      }
+    })
+    .catch(() => {
+      dataList.value = [];
+    })
+    .finally(() => {
+      tableLoading.value = false;
+    });
 };
 
 const resetFilters = () => {
-  filters.inCode = "";
-  filters.supplierId = "";
+  filters.inboundBatches = "";
+  filters.supplierName = "";
   filters.dateRange = [];
   pagination.currentPage = 1;
   getTableData();
 };
 
-const changePage = ({ current, size }) => {
-  pagination.currentPage = current;
-  pagination.pageSize = size;
+const changePage = ({ page, limit }) => {
+  pagination.currentPage = page;
+  pagination.pageSize = limit;
   getTableData();
 };
 
-const addDetail = () => {
-  form.details.push({ materialName: "", spec: "", quantity: 0, unitPrice: 0 });
-};
-
-const removeDetail = (index) => {
-  form.details.splice(index, 1);
-};
-
-const add = () => {
-  isEdit.value = false;
-  dialogTitle.value = "鏂板鍏ュ簱";
-  Object.assign(form, {
-    inCode: "RK" + Date.now().toString().slice(-8),
-    supplierId: "",
-    inDate: new Date().toISOString().split('T')[0],
-    amount: 0,
-    details: [{ materialName: "", spec: "", quantity: 0, unitPrice: 0 }],
-    remark: "",
-  });
-  dialogVisible.value = true;
-};
-
-const edit = (row) => {
-  isEdit.value = true;
-  currentId.value = row.id;
-  dialogTitle.value = "缂栬緫鍏ュ簱";
-  Object.assign(form, row);
-  if (!form.details || form.details.length === 0) {
-    form.details = [{ materialName: "", spec: "", quantity: 0, unitPrice: 0 }];
-  }
-  dialogVisible.value = true;
-};
-
-const view = (row) => {
-  ElMessage.info(`鏌ョ湅鍏ュ簱鍗�: ${row.inCode}`);
-};
-
-const handleDelete = (row) => {
-  ElMessageBox.confirm("纭鍒犻櫎璇ュ叆搴撳崟鍚楋紵", "鎻愮ず", {
-    confirmButtonText: "纭畾",
-    cancelButtonText: "鍙栨秷",
-    type: "warning",
-  }).then(() => {
-    const index = mockData.findIndex(item => item.id === row.id);
-    if (index !== -1) {
-      mockData.splice(index, 1);
-    }
-    ElMessage.success("鍒犻櫎鎴愬姛");
-    getTableData();
-  });
-};
-
 const handleOut = () => {
-  ElMessage.success("瀵煎嚭鎴愬姛");
-};
-
-const submitForm = () => {
-  formRef.value.validate((valid) => {
-    if (valid) {
-      const supplier = supplierList.find(item => item.id === form.supplierId);
-      if (isEdit.value) {
-        const index = mockData.findIndex(item => item.id === currentId.value);
-        if (index !== -1) {
-          mockData[index] = { ...mockData[index], ...form, supplierName: supplier?.name };
-        }
-        ElMessage.success("缂栬緫鎴愬姛");
-      } else {
-        const newId = mockData.length > 0 ? Math.max(...mockData.map(item => item.id)) + 1 : 1;
-        mockData.push({ id: newId, ...form, supplierName: supplier?.name, status: "pending" });
-        ElMessage.success("鏂板鎴愬姛");
-      }
-      dialogVisible.value = false;
-      getTableData();
-    }
-  });
+  proxy.download(
+    "/accountPurchase/exportAccountPurchaseInbound",
+    buildFilterParams(),
+    `閲囪喘鍏ュ簱_${new Date().getTime()}.xlsx`
+  );
 };
 
 onMounted(() => {
@@ -322,10 +167,5 @@
   display: flex;
   justify-content: space-between;
   margin-bottom: 15px;
-}
-
-.text-primary {
-  color: #409eff;
-  font-weight: bold;
 }
 </style>
diff --git a/src/views/financialManagement/payable/purchaseReturn.vue b/src/views/financialManagement/payable/purchaseReturn.vue
new file mode 100644
index 0000000..e7ca665
--- /dev/null
+++ b/src/views/financialManagement/payable/purchaseReturn.vue
@@ -0,0 +1,239 @@
+<template>
+  <!-- 閲囪喘閫�璐� -->
+
+  <div class="app-container">
+    <el-form :model="filters" :inline="true">
+      <el-form-item label="閫�璐у崟鍙�:">
+        <el-input
+          v-model="filters.returnNo"
+          placeholder="璇疯緭鍏ラ��璐у崟鍙�"
+          clearable
+          style="width: 200px"
+        />
+      </el-form-item>
+
+      <el-form-item label="渚涘簲鍟�:">
+        <el-input
+          v-model="filters.supplierName"
+          placeholder="璇疯緭鍏ヤ緵搴斿晢"
+          clearable
+          style="width: 200px"
+        />
+      </el-form-item>
+
+      <el-form-item label="閫�璐ф棩鏈�:">
+        <el-date-picker
+          v-model="filters.dateRange"
+          value-format="YYYY-MM-DD"
+          format="YYYY-MM-DD"
+          type="daterange"
+          range-separator="鑷�"
+          start-placeholder="寮�濮嬫棩鏈�"
+          end-placeholder="缁撴潫鏃ユ湡"
+          clearable
+        />
+      </el-form-item>
+
+      <el-form-item>
+        <el-button type="primary" @click="onSearch">鎼滅储</el-button>
+
+        <el-button @click="resetFilters">閲嶇疆</el-button>
+      </el-form-item>
+    </el-form>
+
+    <div class="table_list">
+      <div class="actions">
+        <div></div>
+
+        <div>
+          <el-button @click="handleOut" icon="Download">瀵煎嚭</el-button>
+        </div>
+      </div>
+
+      <PIMTable
+        rowKey="id"
+        :column="columns"
+        :tableData="dataList"
+        :tableLoading="tableLoading"
+        :page="{
+          current: pagination.currentPage,
+
+          size: pagination.pageSize,
+
+          total: pagination.total,
+        }"
+        @pagination="changePage"
+      />
+    </div>
+  </div>
+</template>
+
+
+
+<script setup>
+import { ref, reactive, onMounted, getCurrentInstance } from "vue";
+
+import { ElMessage } from "element-plus";
+
+import { listPageAccountPurchaseReturn } from "@/api/financialManagement/accountPurchase";
+
+defineOptions({
+  name: "閲囪喘閫�璐�",
+});
+
+const { proxy } = getCurrentInstance();
+
+const filters = reactive({
+  returnNo: "",
+
+  supplierName: "",
+
+  dateRange: [],
+});
+
+const pagination = reactive({
+  currentPage: 1,
+
+  pageSize: 10,
+
+  total: 0,
+});
+
+const columns = [
+  { label: "閫�璐у崟鍙�", prop: "returnNo", minWidth: "150" },
+
+  { label: "渚涘簲鍟�", prop: "supplierName", minWidth: "180" },
+
+  { label: "鍏宠仈鍏ュ簱鍗曞彿", prop: "inboundBatches", minWidth: "150" },
+
+  { label: "閫�璐ф棩鏈�", prop: "preparedAt", minWidth: "170" },
+
+  {
+    label: "閫�娆炬�婚",
+
+    prop: "totalAmount",
+
+    minWidth: "150",
+
+    align: "right",
+
+    formatData: (val) =>
+      val === null || val === undefined || val === ""
+        ? ""
+        : Number(val).toLocaleString("zh-CN", {
+            minimumFractionDigits: 2,
+            maximumFractionDigits: 2,
+          }),
+  },
+
+  { label: "閫�璐ф柟寮�", prop: "returnType", minWidth: "150" },
+
+  { label: "閲囪喘璁㈠崟鍙�", prop: "purchaseContractNumber", minWidth: "150" },
+];
+
+const dataList = ref([]);
+
+const tableLoading = ref(false);
+
+function buildFilterParams() {
+  const params = {
+    returnNo: filters.returnNo || undefined,
+
+    supplierName: filters.supplierName || undefined,
+  };
+
+  if (filters.dateRange && filters.dateRange.length === 2) {
+    params.startDate = filters.dateRange[0];
+
+    params.endDate = filters.dateRange[1];
+  }
+
+  return params;
+}
+
+const onSearch = () => {
+  pagination.currentPage = 1;
+
+  getTableData();
+};
+
+const getTableData = () => {
+  tableLoading.value = true;
+
+  listPageAccountPurchaseReturn({
+    ...buildFilterParams(),
+
+    current: pagination.currentPage,
+
+    size: pagination.pageSize,
+  })
+    .then((res) => {
+      const ok = res.code === 200 || res.code === 0;
+
+      if (ok && res.data) {
+        pagination.total = res.data.total ?? 0;
+
+        dataList.value = res.data.records ?? [];
+      } else {
+        ElMessage.error(res.msg || "鏌ヨ澶辫触");
+
+        dataList.value = [];
+      }
+    })
+
+    .catch(() => {
+      dataList.value = [];
+    })
+
+    .finally(() => {
+      tableLoading.value = false;
+    });
+};
+
+const resetFilters = () => {
+  filters.returnNo = "";
+
+  filters.supplierName = "";
+
+  filters.dateRange = [];
+
+  pagination.currentPage = 1;
+
+  getTableData();
+};
+
+const changePage = ({ page, limit }) => {
+  pagination.currentPage = page;
+
+  pagination.pageSize = limit;
+
+  getTableData();
+};
+
+const handleOut = () => {
+  proxy.download(
+    "/accountPurchase/exportAccountPurchaseReturn",
+
+    buildFilterParams(),
+
+    `閲囪喘閫�璐${new Date().getTime()}.xlsx`
+  );
+};
+
+onMounted(() => {
+  getTableData();
+});
+</script>
+
+
+
+<style lang="scss" scoped>
+.actions {
+  display: flex;
+
+  justify-content: space-between;
+
+  margin-bottom: 15px;
+}
+</style>
+
diff --git a/src/views/financialManagement/receivable/salesOut.vue b/src/views/financialManagement/receivable/salesOut.vue
index fce0c20..297a82c 100644
--- a/src/views/financialManagement/receivable/salesOut.vue
+++ b/src/views/financialManagement/receivable/salesOut.vue
@@ -1,19 +1,27 @@
 <template>
+<!-- 閿�鍞嚭搴� -->
   <div class="app-container">
     <el-form :model="filters" :inline="true">
       <el-form-item label="鍑哄簱鍗曞彿:">
-        <el-input v-model="filters.outCode" placeholder="璇疯緭鍏ュ嚭搴撳崟鍙�" clearable style="width: 200px;" />
+        <el-input v-model="filters.outboundBatches" placeholder="璇疯緭鍏ュ嚭搴撳崟鍙�" clearable style="width: 200px;" />
       </el-form-item>
-      <el-form-item label="瀹㈡埛:">
-        <el-select v-model="filters.customerId" placeholder="璇烽�夋嫨瀹㈡埛" clearable style="width: 200px;">
-          <el-option v-for="item in customerList" :key="item.id" :label="item.name" :value="item.id" />
-        </el-select>
+      <el-form-item label="瀹㈡埛鍚嶇О:">
+        <el-input v-model="filters.customerName" placeholder="璇疯緭鍏ュ鎴峰悕绉�" clearable style="width: 200px;" />
       </el-form-item>
       <el-form-item label="鍑哄簱鏃ユ湡:">
-        <el-date-picker v-model="filters.dateRange" value-format="YYYY-MM-DD" format="YYYY-MM-DD" type="daterange" range-separator="鑷�" start-placeholder="寮�濮嬫棩鏈�" end-placeholder="缁撴潫鏃ユ湡" clearable />
+        <el-date-picker
+          v-model="filters.dateRange"
+          value-format="YYYY-MM-DD"
+          format="YYYY-MM-DD"
+          type="daterange"
+          range-separator="鑷�"
+          start-placeholder="寮�濮嬫棩鏈�"
+          end-placeholder="缁撴潫鏃ユ湡"
+          clearable
+        />
       </el-form-item>
       <el-form-item>
-        <el-button type="primary" @click="getTableData">鎼滅储</el-button>
+        <el-button type="primary" @click="onSearch">鎼滅储</el-button>
         <el-button @click="resetFilters">閲嶇疆</el-button>
       </el-form-item>
     </el-form>
@@ -28,76 +36,32 @@
         rowKey="id"
         :column="columns"
         :tableData="dataList"
+        :tableLoading="tableLoading"
         :page="{
           current: pagination.currentPage,
           size: pagination.pageSize,
           total: pagination.total,
         }"
         @pagination="changePage"
-      >
-        <template #status="{ row }">
-          <el-tag :type="getStatusType(row.status)">{{ getStatusLabel(row.status) }}</el-tag>
-        </template>
-        <template #operation="{ row }">
-          <el-button type="primary" link @click="view(row)">鏌ョ湅</el-button>
-          <el-button type="primary" link @click="edit(row)" v-if="row.status === 'pending'">缂栬緫</el-button>
-          <el-button type="danger" link @click="handleDelete(row)" v-if="row.status === 'pending'">鍒犻櫎</el-button>
-        </template>
-      </PIMTable>
+      />
     </div>
-
-    <FormDialog :title="dialogTitle" v-model="dialogVisible" width="800px" @confirm="submitForm" @cancel="dialogVisible = false">
-      <el-form :model="form" :rules="rules" ref="formRef" label-width="100px">
-        <el-row :gutter="20">
-          <el-col :span="12">
-            <el-form-item label="鍑哄簱鍗曞彿" prop="outCode">
-              <el-input v-model="form.outCode" placeholder="璇疯緭鍏ュ嚭搴撳崟鍙�" :disabled="isEdit" />
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="瀹㈡埛" prop="customerId">
-              <el-select v-model="form.customerId" placeholder="璇烽�夋嫨瀹㈡埛" style="width: 100%;" :disabled="isEdit">
-                <el-option v-for="item in customerList" :key="item.id" :label="item.name" :value="item.id" />
-              </el-select>
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-row :gutter="20">
-          <el-col :span="12">
-            <el-form-item label="鍑哄簱鏃ユ湡" prop="outDate">
-              <el-date-picker v-model="form.outDate" type="date" placeholder="閫夋嫨鏃ユ湡" value-format="YYYY-MM-DD" style="width: 100%;" />
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="閲戦" prop="amount">
-              <el-input-number v-model="form.amount" :min="0" :precision="2" style="width: 100%;" />
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-form-item label="澶囨敞" prop="remark">
-          <el-input v-model="form.remark" type="textarea" :rows="3" placeholder="璇疯緭鍏ュ娉�" />
-        </el-form-item>
-      </el-form>
-      <template #footer>
-        <el-button type="primary" @click="submitForm">纭畾</el-button>
-        <el-button @click="dialogVisible = false">鍙栨秷</el-button>
-      </template>
-    </FormDialog>
   </div>
 </template>
 
 <script setup>
-import { ref, reactive, onMounted } from "vue";
-import { ElMessage, ElMessageBox } from "element-plus";
-import FormDialog from "@/components/Dialog/FormDialog.vue";
+import { ref, reactive, onMounted, getCurrentInstance } from "vue";
+import { ElMessage } from "element-plus";
+import { listPageAccountSales } from "@/api/financialManagement/accountSales";
 
 defineOptions({
   name: "閿�鍞嚭搴�",
 });
 
+const { proxy } = getCurrentInstance();
+
 const filters = reactive({
-  outCode: "",
-  customerId: "",
+  outboundBatches: "",
+  customerName: "",
   dateRange: [],
 });
 
@@ -108,153 +72,87 @@
 });
 
 const columns = [
-  { label: "鍑哄簱鍗曞彿", prop: "outCode", width: "150" },
-  { label: "瀹㈡埛鍚嶇О", prop: "customerName", width: "180" },
-  { label: "鍑哄簱鏃ユ湡", prop: "outDate", width: "120" },
-  { label: "閲戦", prop: "amount", width: "120" },
-  { label: "鐘舵��", prop: "status", slot: "status" },
-  { label: "澶囨敞", prop: "remark", showOverflowTooltip: true },
-  { label: "鎿嶄綔", prop: "operation", slot: "operation", width: "200", fixed: "right" },
+  { label: "鍑哄簱鍗曞彿", prop: "outboundBatches", minWidth: "150" },
+  { label: "瀹㈡埛鍚嶇О", prop: "customerName", minWidth: "180" },
+  { label: "鍑哄簱鏃ユ湡", prop: "shippingDate", width: "170" },
+  { label: "浜у搧鍚嶇О", prop: "productName", minWidth: "140" },
+  { label: "浜у搧瑙勬牸", prop: "specificationModel", minWidth: "140" },
+  {
+    label: "閲戦",
+    prop: "outboundAmount",
+    minWidth: "120",
+    align: "right",
+    formatData: (val) => (val === null || val === undefined || val === "" ? "" : Number(val).toLocaleString("zh-CN", { minimumFractionDigits: 2, maximumFractionDigits: 2 })),
+  },
+  { label: "鍙戣揣缂栧彿", prop: "shippingNo", minWidth: "140" },
+  { label: "閿�鍞鍗曞彿", prop: "salesContractNo", minWidth: "150" },
 ];
 
 const dataList = ref([]);
-const dialogVisible = ref(false);
-const dialogTitle = ref("");
-const formRef = ref(null);
-const isEdit = ref(false);
-const currentId = ref(null);
+const tableLoading = ref(false);
 
-const customerList = [
-  { id: 1, name: "鍖椾含绉戞妧鏈夐檺鍏徃" },
-  { id: 2, name: "涓婃捣璐告槗鍏徃" },
-  { id: 3, name: "骞垮窞瀹炰笟鏈夐檺鍏徃" },
-  { id: 4, name: "娣卞湷鐢靛瓙鍏徃" },
-];
+function buildFilterParams() {
+  const params = {
+    outboundBatches: filters.outboundBatches || undefined,
+    customerName: filters.customerName || undefined,
+  };
+  if (filters.dateRange && filters.dateRange.length === 2) {
+    params.startDate = filters.dateRange[0];
+    params.endDate = filters.dateRange[1];
+  }
+  return params;
+}
 
-const form = reactive({
-  outCode: "",
-  customerId: "",
-  outDate: "",
-  amount: 0,
-  remark: "",
-});
-
-const rules = {
-  outCode: [{ required: true, message: "璇疯緭鍏ュ嚭搴撳崟鍙�", trigger: "blur" }],
-  customerId: [{ required: true, message: "璇烽�夋嫨瀹㈡埛", trigger: "change" }],
-  outDate: [{ required: true, message: "璇烽�夋嫨鍑哄簱鏃ユ湡", trigger: "change" }],
-  amount: [{ required: true, message: "璇疯緭鍏ラ噾棰�", trigger: "blur" }],
-};
-
-const mockData = [
-  { id: 1, outCode: "CK2024001", customerId: 1, customerName: "鍖椾含绉戞妧鏈夐檺鍏徃", outDate: "2024-01-15", amount: 5000, status: "approved", remark: "" },
-  { id: 2, outCode: "CK2024002", customerId: 2, customerName: "涓婃捣璐告槗鍏徃", outDate: "2024-01-16", amount: 8000, status: "pending", remark: "" },
-  { id: 3, outCode: "CK2024003", customerId: 3, customerName: "骞垮窞瀹炰笟鏈夐檺鍏徃", outDate: "2024-01-18", amount: 12000, status: "approved", remark: "" },
-  { id: 4, outCode: "CK2024004", customerId: 4, customerName: "娣卞湷鐢靛瓙鍏徃", outDate: "2024-01-20", amount: 3500, status: "pending", remark: "" },
-];
-
-const getStatusLabel = (status) => {
-  const map = { pending: "寰呭鏍�", approved: "宸插鏍�", rejected: "宸查┏鍥�" };
-  return map[status] || status;
-};
-
-const getStatusType = (status) => {
-  const map = { pending: "warning", approved: "success", rejected: "danger" };
-  return map[status] || "";
+const onSearch = () => {
+  pagination.currentPage = 1;
+  getTableData();
 };
 
 const getTableData = () => {
-  let result = [...mockData];
-  if (filters.outCode) {
-    result = result.filter(item => item.outCode.includes(filters.outCode));
-  }
-  if (filters.customerId) {
-    result = result.filter(item => item.customerId === filters.customerId);
-  }
-  if (filters.dateRange && filters.dateRange.length === 2) {
-    result = result.filter(item => item.outDate >= filters.dateRange[0] && item.outDate <= filters.dateRange[1]);
-  }
-  pagination.total = result.length;
-  dataList.value = result.slice((pagination.currentPage - 1) * pagination.pageSize, pagination.currentPage * pagination.pageSize);
+  tableLoading.value = true;
+  listPageAccountSales({
+    ...buildFilterParams(),
+    current: pagination.currentPage,
+    size: pagination.pageSize,
+  })
+    .then((res) => {
+      const ok = res.code === 200 || res.code === 0;
+      if (ok && res.data) {
+        pagination.total = res.data.total ?? 0;
+        dataList.value = res.data.records ?? [];
+      } else {
+        ElMessage.error(res.msg || "鏌ヨ澶辫触");
+        dataList.value = [];
+      }
+    })
+    .catch(() => {
+      dataList.value = [];
+    })
+    .finally(() => {
+      tableLoading.value = false;
+    });
 };
 
 const resetFilters = () => {
-  filters.outCode = "";
-  filters.customerId = "";
+  filters.outboundBatches = "";
+  filters.customerName = "";
   filters.dateRange = [];
   pagination.currentPage = 1;
   getTableData();
 };
 
-const changePage = ({ current, size }) => {
-  pagination.currentPage = current;
-  pagination.pageSize = size;
+const changePage = ({ page, limit }) => {
+  pagination.currentPage = page;
+  pagination.pageSize = limit;
   getTableData();
 };
 
-const add = () => {
-  isEdit.value = false;
-  dialogTitle.value = "鏂板鍑哄簱";
-  Object.assign(form, {
-    outCode: "CK" + Date.now(),
-    customerId: "",
-    outDate: "",
-    amount: 0,
-    remark: "",
-  });
-  dialogVisible.value = true;
-};
-
-const edit = (row) => {
-  isEdit.value = true;
-  currentId.value = row.id;
-  dialogTitle.value = "缂栬緫鍑哄簱";
-  Object.assign(form, row);
-  dialogVisible.value = true;
-};
-
-const view = (row) => {
-  ElMessage.info(`鏌ョ湅鍑哄簱鍗�: ${row.outCode}`);
-};
-
-const submitForm = () => {
-  formRef.value.validate((valid) => {
-    if (valid) {
-      const customer = customerList.find(item => item.id === form.customerId);
-      if (isEdit.value) {
-        const index = mockData.findIndex(item => item.id === currentId.value);
-        if (index !== -1) {
-          mockData[index] = { ...mockData[index], ...form, customerName: customer?.name };
-        }
-        ElMessage.success("缂栬緫鎴愬姛");
-      } else {
-        const newId = mockData.length > 0 ? Math.max(...mockData.map(item => item.id)) + 1 : 1;
-        mockData.push({ id: newId, ...form, customerName: customer?.name, status: "pending" });
-        ElMessage.success("鏂板鎴愬姛");
-      }
-      dialogVisible.value = false;
-      getTableData();
-    }
-  });
-};
-
-const handleDelete = (row) => {
-  ElMessageBox.confirm("纭鍒犻櫎璇ュ嚭搴撳崟鍚楋紵", "鎻愮ず", {
-    confirmButtonText: "纭畾",
-    cancelButtonText: "鍙栨秷",
-    type: "warning",
-  }).then(() => {
-    const index = mockData.findIndex(item => item.id === row.id);
-    if (index !== -1) {
-      mockData.splice(index, 1);
-    }
-    ElMessage.success("鍒犻櫎鎴愬姛");
-    getTableData();
-  });
-};
-
 const handleOut = () => {
-  ElMessage.success("瀵煎嚭鎴愬姛");
+  proxy.download(
+    "/accountSales/exportAccountSalesOutbound",
+    buildFilterParams(),
+    `閿�鍞嚭搴揰${new Date().getTime()}.xlsx`
+  );
 };
 
 onMounted(() => {
diff --git a/src/views/financialManagement/receivable/salesReturn.vue b/src/views/financialManagement/receivable/salesReturn.vue
index 4cf54d6..c58d330 100644
--- a/src/views/financialManagement/receivable/salesReturn.vue
+++ b/src/views/financialManagement/receivable/salesReturn.vue
@@ -1,19 +1,27 @@
 <template>
+  <!-- 閿�鍞��璐� -->
   <div class="app-container">
     <el-form :model="filters" :inline="true">
       <el-form-item label="閫�璐у崟鍙�:">
-        <el-input v-model="filters.returnCode" placeholder="璇疯緭鍏ラ��璐у崟鍙�" clearable style="width: 200px;" />
+        <el-input v-model="filters.returnNo" placeholder="璇疯緭鍏ラ��璐у崟鍙�" clearable style="width: 200px;" />
       </el-form-item>
-      <el-form-item label="瀹㈡埛:">
-        <el-select v-model="filters.customerId" placeholder="璇烽�夋嫨瀹㈡埛" clearable style="width: 200px;">
-          <el-option v-for="item in customerList" :key="item.id" :label="item.name" :value="item.id" />
-        </el-select>
+      <el-form-item label="瀹㈡埛鍚嶇О:">
+        <el-input v-model="filters.customerName" placeholder="璇疯緭鍏ュ鎴峰悕绉�" clearable style="width: 200px;" />
       </el-form-item>
       <el-form-item label="閫�璐ф棩鏈�:">
-        <el-date-picker v-model="filters.dateRange" value-format="YYYY-MM-DD" format="YYYY-MM-DD" type="daterange" range-separator="鑷�" start-placeholder="寮�濮嬫棩鏈�" end-placeholder="缁撴潫鏃ユ湡" clearable />
+        <el-date-picker
+          v-model="filters.dateRange"
+          value-format="YYYY-MM-DD"
+          format="YYYY-MM-DD"
+          type="daterange"
+          range-separator="鑷�"
+          start-placeholder="寮�濮嬫棩鏈�"
+          end-placeholder="缁撴潫鏃ユ湡"
+          clearable
+        />
       </el-form-item>
       <el-form-item>
-        <el-button type="primary" @click="getTableData">鎼滅储</el-button>
+        <el-button type="primary" @click="onSearch">鎼滅储</el-button>
         <el-button @click="resetFilters">閲嶇疆</el-button>
       </el-form-item>
     </el-form>
@@ -28,90 +36,32 @@
         rowKey="id"
         :column="columns"
         :tableData="dataList"
+        :tableLoading="tableLoading"
         :page="{
           current: pagination.currentPage,
           size: pagination.pageSize,
           total: pagination.total,
         }"
         @pagination="changePage"
-      >
-        <template #status="{ row }">
-          <el-tag :type="getStatusType(row.status)">{{ getStatusLabel(row.status) }}</el-tag>
-        </template>
-        <template #operation="{ row }">
-          <el-button type="primary" link @click="view(row)">鏌ョ湅</el-button>
-          <el-button type="primary" link @click="edit(row)" v-if="row.status === 'pending'">缂栬緫</el-button>
-          <el-button type="success" link @click="handleAudit(row)" v-if="row.status === 'pending'">瀹℃牳</el-button>
-        </template>
-      </PIMTable>
+      />
     </div>
-
-    <FormDialog :title="dialogTitle" v-model="dialogVisible" width="800px" @confirm="submitForm" @cancel="dialogVisible = false">
-      <el-form :model="form" :rules="rules" ref="formRef" label-width="120px">
-        <el-row :gutter="20">
-          <el-col :span="12">
-            <el-form-item label="閫�璐у崟鍙�" prop="returnCode">
-              <el-input v-model="form.returnCode" placeholder="璇疯緭鍏ラ��璐у崟鍙�" :disabled="isEdit" />
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="鍏宠仈鍑哄簱鍗�" prop="outCode">
-              <el-select v-model="form.outCode" placeholder="璇烽�夋嫨鍑哄簱鍗�" style="width: 100%;" :disabled="isEdit">
-                <el-option v-for="item in outList" :key="item.outCode" :label="item.outCode" :value="item.outCode" />
-              </el-select>
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-row :gutter="20">
-          <el-col :span="12">
-            <el-form-item label="瀹㈡埛" prop="customerId">
-              <el-select v-model="form.customerId" placeholder="璇烽�夋嫨瀹㈡埛" style="width: 100%;" :disabled="isEdit">
-                <el-option v-for="item in customerList" :key="item.id" :label="item.name" :value="item.id" />
-              </el-select>
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="閫�璐ф棩鏈�" prop="returnDate">
-              <el-date-picker v-model="form.returnDate" type="date" placeholder="閫夋嫨鏃ユ湡" value-format="YYYY-MM-DD" style="width: 100%;" />
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-row :gutter="20">
-          <el-col :span="12">
-            <el-form-item label="閫�璐ч噾棰�" prop="amount">
-              <el-input-number v-model="form.amount" :min="0" :precision="2" style="width: 100%;" />
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="閫�璐у師鍥�" prop="reason">
-              <el-input v-model="form.reason" placeholder="璇疯緭鍏ラ��璐у師鍥�" />
-            </el-form-item>
-          </el-col>
-        </el-row>
-        <el-form-item label="澶囨敞" prop="remark">
-          <el-input v-model="form.remark" type="textarea" :rows="3" placeholder="璇疯緭鍏ュ娉�" />
-        </el-form-item>
-      </el-form>
-      <template #footer>
-        <el-button type="primary" @click="submitForm">纭畾</el-button>
-        <el-button @click="dialogVisible = false">鍙栨秷</el-button>
-      </template>
-    </FormDialog>
   </div>
 </template>
 
 <script setup>
-import { ref, reactive, onMounted } from "vue";
-import { ElMessage, ElMessageBox } from "element-plus";
-import FormDialog from "@/components/Dialog/FormDialog.vue";
+import { ref, reactive, onMounted, getCurrentInstance } from "vue";
+import { ElMessage } from "element-plus";
+import { listPageAccountSalesReturn } from "@/api/financialManagement/accountSales";
 
 defineOptions({
   name: "閿�鍞��璐�",
 });
 
+const { proxy } = getCurrentInstance();
+
 const filters = reactive({
-  returnCode: "",
-  customerId: "",
+  returnNo: "",
+  customerName: "",
   dateRange: [],
 });
 
@@ -122,173 +72,89 @@
 });
 
 const columns = [
-  { label: "閫�璐у崟鍙�", prop: "returnCode", width: "150" },
-  { label: "瀹㈡埛鍚嶇О", prop: "customerName", width: "180" },
-  { label: "鍏宠仈鍑哄簱鍗�", prop: "outCode", width: "150" },
-  { label: "閫�璐ф棩鏈�", prop: "returnDate", width: "120" },
-  { label: "閫�璐ч噾棰�", prop: "amount", width: "120" },
-  { label: "閫�璐у師鍥�", prop: "reason", width: "150", showOverflowTooltip: true },
-  { label: "鐘舵��", prop: "status", slot: "status" },
-  { label: "鎿嶄綔", prop: "operation", slot: "operation", width: "200", fixed: "right" },
+  { label: "閫�璐у崟鍙�", prop: "returnNo", minWidth: "150" },
+  { label: "瀹㈡埛鍚嶇О", prop: "customerName", minWidth: "180" },
+  { label: "鍏宠仈鍙戣揣鍗曞彿", prop: "shippingNo", minWidth: "150" },
+  { label: "閫�璐ф棩鏈�", prop: "makeTime", minWidth: "170" },
+  {
+    label: "閫�娆炬�婚",
+    prop: "refundAmount",
+    minWidth: "120",
+    align: "right",
+    formatData: (val) =>
+      val === null || val === undefined || val === ""
+        ? ""
+        : Number(val).toLocaleString("zh-CN", { minimumFractionDigits: 2, maximumFractionDigits: 2 }),
+  },
+  { label: "閫�璐у師鍥�", prop: "returnReason", minWidth: "150", showOverflowTooltip: true },
+  { label: "閿�鍞鍗曞彿", prop: "salesContractNo", minWidth: "150" },
 ];
 
 const dataList = ref([]);
-const dialogVisible = ref(false);
-const dialogTitle = ref("");
-const formRef = ref(null);
-const isEdit = ref(false);
-const currentId = ref(null);
+const tableLoading = ref(false);
 
-const customerList = [
-  { id: 1, name: "鍖椾含绉戞妧鏈夐檺鍏徃" },
-  { id: 2, name: "涓婃捣璐告槗鍏徃" },
-  { id: 3, name: "骞垮窞瀹炰笟鏈夐檺鍏徃" },
-  { id: 4, name: "娣卞湷鐢靛瓙鍏徃" },
-];
+function buildFilterParams() {
+  const params = {
+    returnNo: filters.returnNo || undefined,
+    customerName: filters.customerName || undefined,
+  };
+  if (filters.dateRange && filters.dateRange.length === 2) {
+    params.startDate = filters.dateRange[0];
+    params.endDate = filters.dateRange[1];
+  }
+  return params;
+}
 
-const outList = [
-  { outCode: "CK2024001", customerId: 1 },
-  { outCode: "CK2024002", customerId: 2 },
-  { outCode: "CK2024003", customerId: 3 },
-];
-
-const form = reactive({
-  returnCode: "",
-  outCode: "",
-  customerId: "",
-  returnDate: "",
-  amount: 0,
-  reason: "",
-  remark: "",
-});
-
-const rules = {
-  returnCode: [{ required: true, message: "璇疯緭鍏ラ��璐у崟鍙�", trigger: "blur" }],
-  outCode: [{ required: true, message: "璇烽�夋嫨鍏宠仈鍑哄簱鍗�", trigger: "change" }],
-  customerId: [{ required: true, message: "璇烽�夋嫨瀹㈡埛", trigger: "change" }],
-  returnDate: [{ required: true, message: "璇烽�夋嫨閫�璐ф棩鏈�", trigger: "change" }],
-  amount: [{ required: true, message: "璇疯緭鍏ラ��璐ч噾棰�", trigger: "blur" }],
-};
-
-const mockData = [
-  { id: 1, returnCode: "TH2024001", outCode: "CK2024001", customerId: 1, customerName: "鍖椾含绉戞妧鏈夐檺鍏徃", returnDate: "2024-01-20", amount: 1000, reason: "璐ㄩ噺闂", status: "approved", remark: "" },
-  { id: 2, returnCode: "TH2024002", outCode: "CK2024002", customerId: 2, customerName: "涓婃捣璐告槗鍏徃", returnDate: "2024-01-22", amount: 500, reason: "瑙勬牸涓嶇", status: "pending", remark: "" },
-];
-
-const getStatusLabel = (status) => {
-  const map = { pending: "寰呭鏍�", approved: "宸插鏍�", rejected: "宸查┏鍥�" };
-  return map[status] || status;
-};
-
-const getStatusType = (status) => {
-  const map = { pending: "warning", approved: "success", rejected: "danger" };
-  return map[status] || "";
+const onSearch = () => {
+  pagination.currentPage = 1;
+  getTableData();
 };
 
 const getTableData = () => {
-  let result = [...mockData];
-  if (filters.returnCode) {
-    result = result.filter(item => item.returnCode.includes(filters.returnCode));
-  }
-  if (filters.customerId) {
-    result = result.filter(item => item.customerId === filters.customerId);
-  }
-  if (filters.dateRange && filters.dateRange.length === 2) {
-    result = result.filter(item => item.returnDate >= filters.dateRange[0] && item.returnDate <= filters.dateRange[1]);
-  }
-  pagination.total = result.length;
-  dataList.value = result.slice((pagination.currentPage - 1) * pagination.pageSize, pagination.currentPage * pagination.pageSize);
+  tableLoading.value = true;
+  listPageAccountSalesReturn({
+    ...buildFilterParams(),
+    current: pagination.currentPage,
+    size: pagination.pageSize,
+  })
+    .then((res) => {
+      const ok = res.code === 200 || res.code === 0;
+      if (ok && res.data) {
+        pagination.total = res.data.total ?? 0;
+        dataList.value = res.data.records ?? [];
+      } else {
+        ElMessage.error(res.msg || "鏌ヨ澶辫触");
+        dataList.value = [];
+      }
+    })
+    .catch(() => {
+      dataList.value = [];
+    })
+    .finally(() => {
+      tableLoading.value = false;
+    });
 };
 
 const resetFilters = () => {
-  filters.returnCode = "";
-  filters.customerId = "";
+  filters.returnNo = "";
+  filters.customerName = "";
   filters.dateRange = [];
   pagination.currentPage = 1;
   getTableData();
 };
 
-const changePage = ({ current, size }) => {
-  pagination.currentPage = current;
-  pagination.pageSize = size;
+const changePage = ({ page, limit }) => {
+  pagination.currentPage = page;
+  pagination.pageSize = limit;
   getTableData();
 };
 
-const add = () => {
-  isEdit.value = false;
-  dialogTitle.value = "鏂板閫�璐�";
-  Object.assign(form, {
-    returnCode: "TH" + Date.now(),
-    outCode: "",
-    customerId: "",
-    returnDate: "",
-    amount: 0,
-    reason: "",
-    remark: "",
-  });
-  dialogVisible.value = true;
-};
-
-const edit = (row) => {
-  isEdit.value = true;
-  currentId.value = row.id;
-  dialogTitle.value = "缂栬緫閫�璐�";
-  Object.assign(form, row);
-  dialogVisible.value = true;
-};
-
-const view = (row) => {
-  ElMessage.info(`鏌ョ湅閫�璐у崟: ${row.returnCode}`);
-};
-
-const handleAudit = (row) => {
-  ElMessageBox.confirm("纭瀹℃牳閫氳繃璇ラ��璐у崟鍚楋紵", "鎻愮ず", {
-    confirmButtonText: "閫氳繃",
-    cancelButtonText: "椹冲洖",
-    distinguishCancelAndClose: true,
-    type: "warning",
-  }).then(() => {
-    const index = mockData.findIndex(item => item.id === row.id);
-    if (index !== -1) {
-      mockData[index].status = "approved";
-    }
-    ElMessage.success("瀹℃牳閫氳繃");
-    getTableData();
-  }).catch((action) => {
-    if (action === "cancel") {
-      const index = mockData.findIndex(item => item.id === row.id);
-      if (index !== -1) {
-        mockData[index].status = "rejected";
-      }
-      ElMessage.warning("宸查┏鍥�");
-      getTableData();
-    }
-  });
-};
-
-const submitForm = () => {
-  formRef.value.validate((valid) => {
-    if (valid) {
-      const customer = customerList.find(item => item.id === form.customerId);
-      if (isEdit.value) {
-        const index = mockData.findIndex(item => item.id === currentId.value);
-        if (index !== -1) {
-          mockData[index] = { ...mockData[index], ...form, customerName: customer?.name };
-        }
-        ElMessage.success("缂栬緫鎴愬姛");
-      } else {
-        const newId = mockData.length > 0 ? Math.max(...mockData.map(item => item.id)) + 1 : 1;
-        mockData.push({ id: newId, ...form, customerName: customer?.name, status: "pending" });
-        ElMessage.success("鏂板鎴愬姛");
-      }
-      dialogVisible.value = false;
-      getTableData();
-    }
-  });
-};
-
 const handleOut = () => {
-  ElMessage.success("瀵煎嚭鎴愬姛");
+  proxy.download(
+    "/accountSales/exportAccountSalesReturn",
+    buildFilterParams(),
+    `閿�鍞��璐${new Date().getTime()}.xlsx`
+  );
 };
 
 onMounted(() => {
diff --git a/src/views/index.vue b/src/views/index.vue
index 00d4312..6c0b729 100644
--- a/src/views/index.vue
+++ b/src/views/index.vue
@@ -479,7 +479,7 @@
 // 鑾峰彇宸ュ簭鍒楄〃
 const getProcessList = () => {
   list().then(res => {
-    processOptions.value = res.data
+    processOptions.value = res.data.records
   })
 }
 
diff --git a/src/views/lavorissue/ledger/filesDia.vue b/src/views/lavorissue/ledger/filesDia.vue
index f752496..46da350 100644
--- a/src/views/lavorissue/ledger/filesDia.vue
+++ b/src/views/lavorissue/ledger/filesDia.vue
@@ -163,7 +163,7 @@
 }
 // 涓嬭浇闄勪欢
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 // 鍒犻櫎
 const handleDelete = () => {
diff --git a/src/views/personnelManagement/contractManagement/filesDia.vue b/src/views/personnelManagement/contractManagement/filesDia.vue
index 4bcd812..02f9cef 100644
--- a/src/views/personnelManagement/contractManagement/filesDia.vue
+++ b/src/views/personnelManagement/contractManagement/filesDia.vue
@@ -158,7 +158,7 @@
 }
 // 涓嬭浇闄勪欢
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 // 鍒犻櫎
 const handleDelete = () => {
diff --git a/src/views/procurementManagement/procurementLedger/fileList.vue b/src/views/procurementManagement/procurementLedger/fileList.vue
index fb392c5..945d6a1 100644
--- a/src/views/procurementManagement/procurementLedger/fileList.vue
+++ b/src/views/procurementManagement/procurementLedger/fileList.vue
@@ -32,8 +32,7 @@
   tableData.value = list
 }
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
-
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 const lookFile = (row) => {
   filePreviewRef.value.open(row.url)
diff --git a/src/views/productionManagement/workOrder/components/filesDia.vue b/src/views/productionManagement/workOrder/components/filesDia.vue
index ca6d7a9..1336861 100644
--- a/src/views/productionManagement/workOrder/components/filesDia.vue
+++ b/src/views/productionManagement/workOrder/components/filesDia.vue
@@ -78,7 +78,7 @@
         name: "涓嬭浇",
         type: "text",
         clickFun: row => {
-          proxy.$download.name(row.url);
+					proxy.$download.byUrl(row.url, row.originalFilename);
         },
       },
       {
diff --git a/src/views/productionManagement/workOrderManagement/components/filesDia.vue b/src/views/productionManagement/workOrderManagement/components/filesDia.vue
index 7f038f7..84d8bd4 100644
--- a/src/views/productionManagement/workOrderManagement/components/filesDia.vue
+++ b/src/views/productionManagement/workOrderManagement/components/filesDia.vue
@@ -78,7 +78,7 @@
         name: "涓嬭浇",
         type: "text",
         clickFun: row => {
-          proxy.$download.name(row.url);
+					proxy.$download.byUrl(row.url, row.originalFilename);
         },
       },
       {
diff --git a/src/views/projectManagement/Management/components/formDia.vue b/src/views/projectManagement/Management/components/formDia.vue
index c2ee9c2..0db3efe 100644
--- a/src/views/projectManagement/Management/components/formDia.vue
+++ b/src/views/projectManagement/Management/components/formDia.vue
@@ -1342,9 +1342,9 @@
 }
 
 function downloadAttachment(att) {
-  if (att?.name) {
+  if (att) {
     try {
-      proxy.$download.name(att.url);
+			proxy.$download.byUrl(att.url, att.originalFilename);
       return
     } catch (e) {}
   }
diff --git a/src/views/projectManagement/Management/projectDetail.vue b/src/views/projectManagement/Management/projectDetail.vue
index b526fc6..be670cb 100644
--- a/src/views/projectManagement/Management/projectDetail.vue
+++ b/src/views/projectManagement/Management/projectDetail.vue
@@ -364,16 +364,10 @@
   }
 }
 
-function downloadAttachment(att) {
-  if (att?.url) {
+function downloadAttachment(row) {
+  if (row?.url) {
     try {
-      proxy.$download.resource(att.url)
-      return
-    } catch (e) {}
-  }
-  if (att?.name) {
-    try {
-      proxy.$download.name(att.name, false)
+			proxy.$download.byUrl(row.url, row.originalFilename);
       return
     } catch (e) {}
   }
diff --git a/src/views/projectManagement/projectType/index.vue b/src/views/projectManagement/projectType/index.vue
index 16a17e0..65cc916 100644
--- a/src/views/projectManagement/projectType/index.vue
+++ b/src/views/projectManagement/projectType/index.vue
@@ -250,13 +250,8 @@
 }
 
 /** 涓嬭浇闄勪欢 */
-function handleDownload(attachment) {
-  const url = attachment?.url || attachment?.fileUrl || attachment?.tempPath || attachment?.fileName;
-  if (!url) {
-    ElMessage.warning("鏈壘鍒板彲涓嬭浇鐨勬枃浠跺湴鍧�");
-    return;
-  }
-  proxy.$download.name(url);
+function handleDownload(row) {
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 
 onMounted(() => {
diff --git a/src/views/qualityManagement/finalInspection/components/filesDia.vue b/src/views/qualityManagement/finalInspection/components/filesDia.vue
index 8cda761..4517844 100644
--- a/src/views/qualityManagement/finalInspection/components/filesDia.vue
+++ b/src/views/qualityManagement/finalInspection/components/filesDia.vue
@@ -120,7 +120,7 @@
 };
 // 涓嬭浇闄勪欢
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 // 鍏抽棴寮规
 const closeDia = () => {
diff --git a/src/views/qualityManagement/processInspection/components/filesDia.vue b/src/views/qualityManagement/processInspection/components/filesDia.vue
index b0cb258..fe63f4b 100644
--- a/src/views/qualityManagement/processInspection/components/filesDia.vue
+++ b/src/views/qualityManagement/processInspection/components/filesDia.vue
@@ -124,7 +124,7 @@
 };
 // 涓嬭浇闄勪欢
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 // 鍏抽棴寮规
 const closeDia = () => {
diff --git a/src/views/qualityManagement/rawMaterialInspection/components/filesDia.vue b/src/views/qualityManagement/rawMaterialInspection/components/filesDia.vue
index 9b89a3b..e4c9700 100644
--- a/src/views/qualityManagement/rawMaterialInspection/components/filesDia.vue
+++ b/src/views/qualityManagement/rawMaterialInspection/components/filesDia.vue
@@ -153,7 +153,7 @@
 }
 // 涓嬭浇闄勪欢
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 // 棰勮闄勪欢
 const lookFile = (row) => {
diff --git a/src/views/safeProduction/safeWorkApproval/fileList.vue b/src/views/safeProduction/safeWorkApproval/fileList.vue
index 5cc65f1..c3b7597 100644
--- a/src/views/safeProduction/safeWorkApproval/fileList.vue
+++ b/src/views/safeProduction/safeWorkApproval/fileList.vue
@@ -32,7 +32,7 @@
   tableData.value = list
 }
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 
 }
 const lookFile = (row) => {
diff --git a/src/views/salesManagement/invoiceLedger/index.vue b/src/views/salesManagement/invoiceLedger/index.vue
index 444560d..e52ea47 100644
--- a/src/views/salesManagement/invoiceLedger/index.vue
+++ b/src/views/salesManagement/invoiceLedger/index.vue
@@ -409,12 +409,6 @@
   }
 };
 
-const handleFile = (commonFiles) => {
-  commonFiles.forEach((e) => {
-    proxy.$download.name(e.url);
-  });
-};
-
 const clearRange = () => {
   searchForm.invoiceDate = [];
   searchForm.invoiceDateStart = undefined;
diff --git a/src/views/salesManagement/salesLedger/fileList.vue b/src/views/salesManagement/salesLedger/fileList.vue
index 57c4332..eb4d401 100644
--- a/src/views/salesManagement/salesLedger/fileList.vue
+++ b/src/views/salesManagement/salesLedger/fileList.vue
@@ -29,7 +29,7 @@
   tableData.value = list
 }
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 
 }
 const lookFile = (row) => {

--
Gitblit v1.9.3