gaoluyang
2 天以前 02e9c39e8ec8d4a57e874b62907934bc9b605ccf
src/views/salesManagement/invoiceRegistration/index.vue
@@ -208,7 +208,7 @@
        <el-row :gutter="30">
          <el-col :span="12">
            <el-form-item label="销售合同号:" prop="salesContractNo">
              <el-input v-model="form.salesContractNo" disabled></el-input>
              <el-input v-model="form.salesContractNo" disabled placeholder="多合同批量处理(具体合同号见产品列表)"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
@@ -298,6 +298,11 @@
            type="index"
            width="60"
          />
          <el-table-column label="所属合同" prop="salesContractNo" width="200">
            <template #default="{ row }">
              <el-tag type="primary">{{ row.salesContractNo }}</el-tag>
            </template>
          </el-table-column>
          <el-table-column label="产品大类" prop="productCategory" />
          <el-table-column
            label="规格型号"
@@ -576,6 +581,8 @@
    return;
  }
  
  // 允许不同的销售合同号批量处理,无需检查重复
  form.value = {};
  productData.value = [];
  
@@ -585,26 +592,31 @@
  );
  
  Promise.all(promises).then(results => {
    // 合并所有合同的产品数据,并为每个产品添加对应的合同ID
    // 合并所有合同的产品数据,并为每个产品添加对应的合同信息
    const allProductData = [];
    results.forEach((result, index) => {
      const contractId = selectedRows.value[index].id;
      const contract = selectedRows.value[index];
      const contractId = contract.id;
      if (result.productData) {
        result.productData.forEach(item => {
          allProductData.push({
            ...item,
            salesLedgerId: contractId // 明确设置合同ID
            id: contractId, // 明确设置合同ID
            salesContractNo: contract.salesContractNo, // 添加销售合同号
            customerName: contract.customerName, // 添加客户名称
            customerContractNo: contract.customerContractNo // 添加客户合同号
          });
        });
      }
    });
    
    // 设置表单数据(使用第一个合同的基本信息)
    // 设置表单数据(使用第一个合同的基本信息,销售合同号留空)
    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;
    form.value.selectedContractIds = selectedRows.value.map(row => row.id); // 存储所有选中的合同ID
    form.value.salesContractNo = ""; // 销售合同号留空,因为会在产品表格中分别显示
    
    productData.value = allProductData;
    
@@ -616,44 +628,44 @@
const submitForm = () => {
  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);
        });
      // 统一将所有合同的数据放在一个数组里,单个和批量都使用数组格式
      const submitData = selectedRows.value.map(contract => {
        // 筛选出属于当前合同的产品数据
        const contractProductData = productData.value.filter(item =>
          item.salesLedgerId === contract.id
        );
        
        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();
        });
      }
        // 为每个销售合同号创建独立的对象
        return {
          // 基础表单数据
          issueDate: form.value.issueDate,
          createTime: form.value.createTime,
          createUer: form.value.createUer,
          invoiceNo: form.value.invoiceNo,
          // 合同实际信息
          id: contract.id, // 使用id作为字段名,值为salesLedgerId
          salesContractNo: contract.salesContractNo, // 使用实际的销售合同号
          customerName: contract.customerName, // 使用实际的客户名称
          customerId: contract.customerId, // 添加客户ID
          customerContractNo: contract.customerContractNo, // 使用实际的客户合同号
          projectName: contract.projectName, // 使用实际的项目名称
          salesman: contract.salesman, // 使用实际的业务员
          // 产品数据
          productData: proxy.HaveJson(contractProductData),
          // 批量标识
          isBatch: selectedRows.value.length > 1
        };
      });
      // 统一调用接口,传递数组格式的数据
      invoiceRegistrationSave(submitData).then(() => {
        proxy.$modal.msgSuccess(selectedRows.value.length > 1 ? "批量新增成功" : "提交成功");
        closeDia();
        getList();
      });
    }
  });
};