gongchunyi
9 小时以前 1635bfb381b94ce4b6b195537e47775fa6e320ca
src/views/procurementManagement/paymentLedger/index.vue
@@ -191,23 +191,68 @@
};
// 子表合计方法
const summarizeMainTable1 = (param) => {
  let summarizeTable = proxy.summarizeTable(
    param,
    ["invoiceAmount", "paymentAmount"],
    {
      ticketsNum: { noDecimal: true }, // 不保留小数
      futureTickets: { noDecimal: true }, // 不保留小数
  const toNum = (v) => {
    const n = Number(v);
    return Number.isFinite(n) ? n : 0;
  };
  const toTime = (v) => {
    const t = new Date(v).getTime();
    return Number.isFinite(t) ? t : -Infinity;
  };
  const toId = (v) => {
    const n = Number(v);
    return Number.isFinite(n) ? n : -Infinity;
  };
  // 以当前右侧表格展示的数据为准(分页 slice 后的数据)
  const rows = originalTableDataSon.value || [];
  // 合同金额:按采购合同号去重后合计
  const invoiceByContract = new Map();
  for (const r of rows) {
    const contractNo = r?.purchaseContractNumber;
    if (!contractNo) continue;
    if (!invoiceByContract.has(contractNo)) {
      invoiceByContract.set(contractNo, toNum(r?.invoiceAmount));
    }
  );
  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 invoiceTotal = Array.from(invoiceByContract.values()).reduce(
    (sum, v) => sum + v,
    0
  );
  const paymentTotal = rows.reduce((sum, r) => sum + toNum(r?.paymentAmount), 0);
  const latestRowByContract = new Map();
  for (const r of rows) {
    const contractNo = r?.purchaseContractNumber;
    if (!contractNo) continue;
    const existed = latestRowByContract.get(contractNo);
    const currentTime = toTime(r?.paymentDate);
    const existedTime = toTime(existed?.paymentDate);
    const shouldReplace =
      !existed ||
      currentTime > existedTime ||
      (currentTime === existedTime && toId(r?.id) > toId(existed?.id));
    if (shouldReplace) {
      latestRowByContract.set(contractNo, r);
    }
  }
  const payableTotal = Array.from(latestRowByContract.values()).reduce(
    (sum, r) => sum + toNum(r?.payableAmount),
    0
  );
  const columns = param?.columns || [];
  const summary = columns.map((col, idx) => {
    if (idx === 0) return "合计";
    const prop = col?.property ?? col?.prop;
    if (prop === "invoiceAmount") return invoiceTotal.toFixed(2);
    if (prop === "paymentAmount") return paymentTotal.toFixed(2);
    if (prop === "payableAmount") return payableTotal.toFixed(2);
    return "";
  });
  return summary;
};
/** 搜索按钮操作 */
const handleQuery = () => {
@@ -238,7 +283,7 @@
const getPaymenRecordtList = (supplierId) => {
  tableLoadingSon.value = true;
  paymentRecordList(supplierId)
  paymentRecordList({supplierId: supplierId})
    .then((res) => {
      tableLoadingSon.value = false;
      tableDataSon.value = res.data;