From 9ca79ccb9eb2fcfd199b9e171f6066c13fe159d9 Mon Sep 17 00:00:00 2001
From: zhangwencui <1064582902@qq.com>
Date: 星期四, 15 一月 2026 11:47:50 +0800
Subject: [PATCH] 付款登记超过,供应商往来详细信息页码

---
 src/views/procurementManagement/paymentLedger/index.vue |  440 +++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 282 insertions(+), 158 deletions(-)

diff --git a/src/views/procurementManagement/paymentLedger/index.vue b/src/views/procurementManagement/paymentLedger/index.vue
index 7ee2a3f..ded6392 100644
--- a/src/views/procurementManagement/paymentLedger/index.vue
+++ b/src/views/procurementManagement/paymentLedger/index.vue
@@ -3,51 +3,93 @@
     <div class="search_form">
       <div>
         <span class="search_title">渚涘簲鍟嗗悕绉�:</span>
-        <el-input
-          v-model="searchForm.supplierNameOrContractNo"
-          style="width: 240px"
-          placeholder="杈撳叆渚涘簲鍟嗗悕绉�"
-          @change="handleQuery"
-          clearable
-          :prefix-icon="Search"
-        />
-        <el-button type="primary" @click="handleQuery" style="margin-left: 10px"
-          >鎼滅储</el-button
-        >
+        <el-input v-model="searchForm.supplierName"
+                  style="width: 240px"
+                  placeholder="杈撳叆渚涘簲鍟嗗悕绉�"
+                  @change="handleQuery"
+                  clearable
+                  :prefix-icon="Search" />
+        <el-button type="primary"
+                   @click="handleQuery"
+                   style="margin-left: 10px">鎼滅储</el-button>
       </div>
-      <div>
-      </div>
+      <div></div>
     </div>
-    <el-row>
+    <el-row :gutter="20">
       <el-col :span="14">
         <div class="table_list">
-          <PIMTable
-            :column="tableColumn"
-            :tableData="tableData"
-            :page="page"
-            :isSelection="false"
-            :handleSelectionChange="handleSelectionChange"
-            :tableLoading="tableLoading"
-            @pagination="pagination"
-            :total="total"
-            :rowClick="rowClick"
-            :isShowSummary="isShowSummary"
-            :highlight-current-row="true"
-          ></PIMTable>
+          <el-table ref="multipleTable"
+                    border
+                    v-loading="tableLoading"
+                    :data="tableData"
+                    :header-cell-style="{ background: '#F0F1F5', color: '#333333' }"
+                    height="calc(100vh - 18.5em)"
+                    :highlight-current-row="true"
+                    style="width: 100%"
+                    tooltip-effect="dark"
+                    @row-click="rowClick"
+                    :show-summary="isShowSummary"
+                    :summary-method="summarizeMainTable"
+                    class="lims-table">
+            <el-table-column align="center"
+                             label="搴忓彿"
+                             type="index"
+                             width="60" />
+            <el-table-column label="渚涘簲鍟嗗悕绉�"
+                             prop="supplierName" />
+            <el-table-column label="鍙戠エ閲戦(鍏�)"
+                             prop="invoiceAmount"
+                             show-overflow-tooltip
+                             :formatter="formattedNumber" />
+            <el-table-column label="浠樻閲戦(鍏�)"
+                             prop="paymentAmount"
+                             show-overflow-tooltip
+                             :formatter="formattedNumber" />
+            <el-table-column label="搴斾粯閲戦(鍏�)"
+                             prop="payableAmount"
+                             show-overflow-tooltip>
+              <template #default="{ row, column }">
+                <el-text type="danger">
+                  {{ formattedNumber(row, column, row.payableAmount) }}
+                </el-text>
+              </template>
+            </el-table-column>
+          </el-table>
+          <pagination v-show="total > 0"
+                      @pagination="paginationSearch"
+                      :total="total"
+                      :layout="page.layout"
+                      :page="page.current"
+                      :limit="page.size" />
         </div>
       </el-col>
       <el-col :span="10">
         <div class="table_list">
-          <PIMTable
-            :column="tableColumnSon"
-            :tableData="tableDataSon"
-            :page="pageSon"
-            :isSelection="false"
-            :tableLoading="tableLoadingSon"
-            @pagination="paginationSon"
-            :total="totalSon"
-            :isShowSummary="isShowSummarySon"
-          ></PIMTable>
+          <PIMTable rowKey="id"
+                    :column="tableColumnSon"
+                    :tableData="originalTableDataSon"
+                    :isSelection="false"
+                    :page="sonPage"
+                    @pagination="pagination1"
+                    @selection-change="sonPaginationSearch"
+                    :tableLoading="tableLoadingSon"
+                    :isShowSummary="isShowSummarySon"
+                    :summaryMethod="summarizeMainTable1"
+                    height="calc(100vh - 18.5em)">
+            <template #payableAmountSlot="{ row }">
+              <el-text type="danger">
+                {{ parseFloat(row.payableAmount).toFixed(2) }}
+              </el-text>
+            </template>
+          </PIMTable>
+          <!-- <pagination
+            v-show="sonTotal > 0"
+            :total="sonTotal"
+            @pagination="sonPaginationSearch"
+            :layout="page.layout"
+            :page="sonPage.current"
+            :limit="sonPage.size"
+          /> -->
         </div>
       </el-col>
     </el-row>
@@ -55,133 +97,215 @@
 </template>
 
 <script setup>
-import { ref, toRefs } from "vue";
-import { Search } from "@element-plus/icons-vue";
-import { paymentLedgerList } from "@/api/procurementManagement/paymentLedger.js";
+  import { ref, toRefs } from "vue";
+  import { Search } from "@element-plus/icons-vue";
+  import {
+    paymentLedgerList,
+    paymentRecordList,
+  } from "@/api/procurementManagement/paymentLedger.js";
+  import Pagination from "../../../components/PIMTable/Pagination.vue";
 
-const tableColumn = ref([
-  {
-    label: "渚涘簲鍟嗗悕绉�",
-    prop: "supplierName",
-  },
-  {
-    label: "鍙戠エ閲戦(鍏�)",
-    prop: "invoiceAmount",
-  },
-  {
-    label: "浠樻閲戦(鍏�)",
-    prop: "paymentAmount",
-  },
-  {
-    label: "搴斾粯閲戦(鍏�)",
-    prop: "payableAmount",
-  },
-]);
-const tableLoading = ref(false);
-const data = reactive({
-  searchForm: {
-    supplierNameOrContractNo: "",
-  },
-});
-const page = reactive({
-  current: 1,
-  size: 10,
-});
-const total = ref(0);
-const isShowSummary = ref(true);
-const tableData = ref([]);
-const { searchForm } = toRefs(data);
-
-
-import {getInfo} from "@/api/login.js";
-const rowClick = (row) => {
-  tableDataSon.value = Array.isArray(row.details) ? row.details : [];
-};
-
-
-// 瀛愭ā鍧�
-const tableColumnSon = ref([
-  {
-    label: "浠樻鏃ユ湡",
-    prop: "paymentDate",
-  },
-  {
-    label: "寮�绁ㄦ暟",
-    prop: "voteCount",
-  },
-  {
-    label: "浠樻閲戦(鍏�)",
-    prop: "paymentAmount",
-  },
-  {
-    label: "搴斾粯閲戦(鍏�)",
-    prop: "payableAmount",
-  },
-]);
-const tableDataSon = ref([]);
-const tableLoadingSon = ref(false);
-const pageSon = reactive({
-  current: 1,
-  size: 10,
-});
-const totalSon = ref(0);
-const isShowSummarySon = ref(true);
-const detailPageNum = ref(1);
-const detailPageSize = ref(10);
-
-/** 鎼滅储鎸夐挳鎿嶄綔 */
-const handleQuery = () => {
-  page.current = 1;
-  getList();
-};
-const pagination = ({ current, limit }) => {
-  page.current = current;
-  page.size = limit;
-  getList();
-};
-const paginationSon = ({ current, limit }) => {
-  pageSon.current = current;
-  pageSon.size = limit;
-  getList();
-};
-const getList = () => {
-  tableLoading.value = false;
-  paymentLedgerList({
-    ...searchForm.value,
-    ...page,
-    detailPageNum: detailPageNum.value, // 鏂板
-    detailPageSize: detailPageSize.value // 鏂板
-  }).then((res) => {
-    let result = res.data;
-    tableLoading.value = false;
-    tableData.value = result.records || [];
-    total.value = result.total || 0;
+  const tableColumn = ref([
+    {
+      label: "渚涘簲鍟嗗悕绉�",
+      prop: "supplierName",
+      width: 240,
+    },
+    {
+      label: "鍙戠エ閲戦(鍏�)",
+      prop: "invoiceAmount",
+    },
+    {
+      label: "浠樻閲戦(鍏�)",
+      prop: "paymentAmount",
+    },
+    {
+      label: "搴斾粯閲戦(鍏�)",
+      prop: "payableAmount",
+    },
+  ]);
+  const tableData = ref([]);
+  const tableLoading = ref(false);
+  const data = reactive({
+    searchForm: {
+      supplierNameOrContractNo: "",
+    },
   });
-};
-// 琛ㄦ牸閫夋嫨鏁版嵁
-const handleSelectionChange = (selection) => {
-  selectedRows.value = selection;
-};
+  const page = reactive({
+    current: 1,
+    size: 100,
+  });
+  const sonPage = reactive({
+    current: 1,
+    size: 100,
+    total: 0,
+  });
+  const total = ref(0);
+  const sonTotal = ref(0);
+  const isShowSummary = ref(true);
+  const { searchForm } = toRefs(data);
+  const currentSupplierId = ref("");
+  const rowClick = row => {
+    currentSupplierId.value = row.supplierId;
+    getPaymenRecordtList(row.supplierId);
+  };
+  // 瀛愭ā鍧�
+  const tableColumnSon = ref([
+    {
+      label: "鍙戠敓鏃ユ湡",
+      prop: "happenTime",
+      width: 110,
+    },
+    {
+      label: "鍙戠エ閲戦(鍏�)",
+      prop: "invoiceAmount",
+      width: 200,
+      formatData: params => {
+        return params ? parseFloat(params).toFixed(2) : 0;
+      },
+    },
+    {
+      label: "浠樻閲戦(鍏�)",
+      prop: "currentPaymentAmount",
+      width: 200,
+      formatData: params => {
+        return params ? parseFloat(params).toFixed(2) : 0;
+      },
+    },
+    {
+      label: "搴斾粯閲戦(鍏�)",
+      dataType: "slot",
+      width: 200,
+      prop: "payableAmount",
+      slot: "payableAmountSlot",
+    },
+  ]);
+  const tableDataSon = ref([]);
+  const originalTableDataSon = ref([]);
+  const tableLoadingSon = ref(false);
+  const isShowSummarySon = ref(true);
+  const detailPageNum = ref(1);
+  const detailPageSize = ref(10);
+  const { proxy } = getCurrentInstance();
+  const currentId = ref(0);
 
-getList();
+  // 涓昏〃鍚堣鏂规硶
+  const summarizeMainTable = param => {
+    return proxy.summarizeTable(
+      param,
+      ["invoiceAmount", "paymentAmount", "payableAmount"],
+      {
+        ticketsNum: { noDecimal: true }, // 涓嶄繚鐣欏皬鏁�
+        futureTickets: { noDecimal: true }, // 涓嶄繚鐣欏皬鏁�
+      }
+    );
+  };
+  // 瀛愯〃鍚堣鏂规硶
+  const summarizeMainTable1 = param => {
+    let summarizeTable = proxy.summarizeTable(
+      param,
+      ["invoiceAmount", "currentPaymentAmount"],
+      {
+        ticketsNum: { noDecimal: true }, // 涓嶄繚鐣欏皬鏁�
+        futureTickets: { noDecimal: true }, // 涓嶄繚鐣欏皬鏁�
+      }
+    );
+    if (originalTableDataSon.value.length > 0) {
+      summarizeTable[summarizeTable.length - 1] =
+        originalTableDataSon.value[
+          originalTableDataSon.value.length - 1
+        ].payableAmount.toFixed(2);
+    } else {
+      summarizeTable[summarizeTable.length - 1] = 0.0;
+    }
+    return summarizeTable;
+  };
+  /** 鎼滅储鎸夐挳鎿嶄綔 */
+  const handleQuery = () => {
+    page.current = 1;
+    getList();
+  };
+  const paginationSearch = obj => {
+    page.current = obj.page;
+    page.size = obj.limit;
+    getList();
+  };
+  const pagination1 = obj => {
+    sonPage.current = obj.page;
+    sonPage.size = obj.limit;
+    getPaymenRecordtList(currentSupplierId.value);
+    // getList();
+  };
+  const getList = () => {
+    tableLoading.value = true;
+    paymentLedgerList({
+      ...searchForm.value,
+      ...page,
+      detailPageNum: detailPageNum.value, // 鏂板
+      detailPageSize: detailPageSize.value, // 鏂板
+    }).then(res => {
+      let result = res.data;
+      tableLoading.value = false;
+      tableData.value = result.records || [];
+      total.value = result.total || 0;
+      if (tableData.value.length > 0) {
+        getPaymenRecordtList(tableData.value[0].supplierId);
+        currentSupplierId.value = tableData.value[0].supplierId;
+      }
+    });
+  };
+
+  const getPaymenRecordtList = supplierId => {
+    tableLoadingSon.value = true;
+    paymentRecordList(supplierId)
+      .then(res => {
+        tableLoadingSon.value = false;
+        tableDataSon.value = res.data;
+        handlePagination({ page: 1, limit: sonPage.size });
+        sonPage.total = res.data.length;
+      })
+      .catch(e => {
+        tableLoadingSon.value = false;
+      });
+  };
+  const handlePagination = ({ page, limit }) => {
+    sonPage.current = page;
+    sonPage.size = limit;
+
+    const start = (page - 1) * limit;
+    const end = start + limit;
+
+    originalTableDataSon.value = tableDataSon.value.slice(start, end);
+  };
+
+  const sonPaginationSearch = pagination => {
+    // 鎺ユ敹鍒嗛〉鍣ㄥ弬鏁� { page, limit }
+    handlePagination(pagination);
+  };
+  const formattedNumber = (row, column, cellValue) => {
+    if (column.property !== "supplierName") {
+      return parseFloat(cellValue).toFixed(2);
+    } else {
+      return cellValue;
+    }
+  };
+  getList();
 </script>
 
 <style scoped lang="scss">
-/* 閫変腑鏌愯鏃剁殑鑳屾櫙鑹�*/
-/* .el-table__body tr.current-row > td {
-  color: #c0c0c0;
-  background: #F6F7FB !important;
-} */
-.el-row {
-  .el-col-14 {
-    .table_list {
-      padding-right: 0px;
-    }
+  .el-pagination {
+    width: 100%;
+    height: 55px;
+    display: flex;
+    justify-content: flex-end;
+    float: right;
+    flex-direction: row;
+    align-items: center;
+    background: #fff;
+    margin: -20px 0 0 0;
+    padding: 0 20px;
   }
-  .el-col-10 {
-    .table_list {
-      padding-left: 0px;
-    }
+  .pagination-container {
+    margin-top: 0;
   }
-}
 </style>

--
Gitblit v1.9.3