gaoluyang
2025-11-27 357242b782a2e9a28bfc7f77257e544bacd7f868
src/views/salesManagement/invoiceRegistration/index.vue
@@ -460,9 +460,10 @@
    invoiceNo: "",
    createUer: userStore.nickName,
    issueDate: dayjs().format("YYYY-MM-DD"),
    selectedContractIds: [], // 新增:存储所有选中的合同ID
    isBatch: false // 新增:标识是否为批量操作
  },
  rules: {
    salesLedgerId: [{ required: true, message: "请选择", trigger: "change" }],
    createUer: [{ required: true, message: "请选择", trigger: "blur" }],
    issueDate: [{ required: true, message: "请选择", trigger: "change" }],
    invoiceNo: [{ required: true, message: "请输入", trigger: "change" }],
@@ -558,21 +559,55 @@
};
// 打开弹框
const openForm = () => {
  // 判断是否多选
  if (selectedRows.value.length != 1) {
    proxy.$modal.msgError("请选择一条合同");
  // 判断是否选择了合同
  if (selectedRows.value.length === 0) {
    proxy.$modal.msgError("请至少选择一条合同");
    return;
  }
  // 检查所有选择的合同是否具有相同的客户名称
  const firstRow = selectedRows.value[0];
  const isSameCustomer = selectedRows.value.every(row =>
    row.customerName === firstRow.customerName
  );
  if (!isSameCustomer) {
    proxy.$modal.msgError("请选择相同客户名称的合同");
    return;
  }
  form.value = {};
  productData.value = [];
  getSalesLedgerWithProducts({ id: selectedRows.value[0].id }).then((res) => {
    form.value = { ...res };
  // 加载所有选中合同的产品数据
  const promises = selectedRows.value.map(row =>
    getSalesLedgerWithProducts({ id: row.id })
  );
  Promise.all(promises).then(results => {
    // 合并所有合同的产品数据,并为每个产品添加对应的合同ID
    const allProductData = [];
    results.forEach((result, index) => {
      const contractId = selectedRows.value[index].id;
      if (result.productData) {
        result.productData.forEach(item => {
          allProductData.push({
            ...item,
            salesLedgerId: contractId // 明确设置合同ID
          });
        });
      }
    });
    // 设置表单数据(使用第一个合同的基本信息)
    form.value = { ...results[0] };
    form.value.createTime = dayjs().format("YYYY-MM-DD");
    form.value.issueDate = dayjs().format("YYYY-MM-DD");
    form.value.createUer = userStore.nickName;
    productData.value = form.value.productData.map((item) => {
      return item;
    });
    form.value.selectedContractIds = selectedRows.value.map(row => row.id); // 存储所有选中的合同ID
    productData.value = allProductData;
    dialogFormVisible.value = true;
    console.log("productData.value ", productData.value);
  });
@@ -582,11 +617,43 @@
  proxy.$refs["formRef"].validate((valid) => {
    if (valid) {
      form.value.productData = proxy.HaveJson(productData.value);
      form.value.isBatch = selectedRows.value.length > 1; // 设置批量标识
      // 如果是批量操作,需要为每个合同创建单独的开票登记记录
      if (selectedRows.value.length > 1) {
        // 批量提交逻辑
        const promises = selectedRows.value.map(contract => {
          // 筛选出属于当前合同的产品数据
          const contractProductData = productData.value.filter(item =>
            item.salesLedgerId === contract.id
          );
          const batchForm = {
            ...form.value,
            salesLedgerId: contract.id,
            productData: contractProductData,
            selectedContractIds: undefined, // 不传递批量ID
            isBatch: true
          };
          return invoiceRegistrationSave(batchForm);
        });
        Promise.all(promises).then(results => {
          proxy.$modal.msgSuccess(`成功提交${results.length}条开票登记记录`);
          closeDia();
          getList();
        }).catch(error => {
          proxy.$modal.msgError("部分提交失败,请检查数据");
          console.error("批量提交错误:", error);
        });
      } else {
        // 单个合同提交逻辑
      invoiceRegistrationSave(form.value).then((res) => {
        proxy.$modal.msgSuccess("提交成功");
        closeDia();
        getList();
      });
      }
    }
  });
};
@@ -692,3 +759,8 @@
  font-weight: bold;
}
</style>