| | |
| | | |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; |
| | | import com.baomidou.mybatisplus.core.metadata.IPage; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.ruoyi.common.utils.SecurityUtils; |
| | | import com.ruoyi.common.utils.poi.ExcelUtil; |
| | | import com.ruoyi.sales.dto.InvoiceRegistrationDto; |
| | | import com.ruoyi.sales.dto.InvoiceRegistrationProductDto; |
| | |
| | | @Override |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public void invoiceRegistrationSave(SalesLedgerDto salesLedgerDto) { |
| | | // 新增开票登记主表 |
| | | InvoiceRegistration invoiceRegistration = new InvoiceRegistration(); |
| | | BeanUtils.copyProperties(salesLedgerDto, invoiceRegistration); |
| | | invoiceRegistration.setId(null); |
| | | invoiceRegistration.setCustomerId(salesLedgerDto.getCustomerId().intValue()); |
| | | invoiceRegistration.setSalesLedgerId(salesLedgerDto.getId().intValue()); |
| | | invoiceRegistrationMapper.insert(invoiceRegistration); |
| | | |
| | | List<SalesLedgerProduct> productData = salesLedgerDto.getProductData(); |
| | | BigDecimal invoiceAmountTotal = BigDecimal.ZERO; |
| | | if(CollectionUtils.isNotEmpty(productData)){ |
| | | for (SalesLedgerProduct productDatum : productData) { |
| | | // 如果开票数为0 跳过 |
| | | BigDecimal currentInvoiceNum = productDatum.getCurrentInvoiceNum(); |
| | | if(null != currentInvoiceNum && BigDecimal.ZERO.compareTo(currentInvoiceNum) == 0){ |
| | | continue; |
| | | } |
| | | invoiceAmountTotal = invoiceAmountTotal.add(currentInvoiceNum); |
| | | InvoiceRegistrationProduct invoiceRegistrationProduct = new InvoiceRegistrationProduct(); |
| | | BeanUtils.copyProperties(productDatum, invoiceRegistrationProduct); |
| | | invoiceRegistrationProduct.setId(null); |
| | | invoiceRegistrationProduct.setSalesLedgerId(salesLedgerDto.getId().intValue()); |
| | | invoiceRegistrationProduct.setInvoiceRegistrationId(invoiceRegistration.getId()); |
| | | invoiceRegistrationProduct.setInvoiceAmount(productDatum.getCurrentInvoiceAmount()); |
| | | invoiceRegistrationProduct.setInvoiceNum(productDatum.getCurrentInvoiceNum()); |
| | | invoiceRegistrationProduct.setSalesLedgerProductId(productDatum.getId().intValue()); |
| | | invoiceRegistrationProductMapper.insert(invoiceRegistrationProduct); |
| | | salesLedgerProductMapper.updateById(productDatum); |
| | | // 新增一条开票台账数据 |
| | | InvoiceLedger invoiceLedger = new InvoiceLedger(); |
| | | invoiceLedger.setInvoiceRegistrationProductId(invoiceRegistrationProduct.getId()); |
| | | invoiceLedger.setInvoiceTotal(invoiceRegistrationProduct.getInvoiceAmount()); |
| | | invoiceLedgerMapper.insert(invoiceLedger); |
| | | if (CollectionUtils.isEmpty(productData)) { |
| | | return; |
| | | } |
| | | |
| | | for (SalesLedgerProduct productDatum : productData) { |
| | | // 本次开票数 / 金额 |
| | | BigDecimal currentInvoiceNum = productDatum.getCurrentInvoiceNum(); |
| | | BigDecimal currentInvoiceAmount = productDatum.getCurrentInvoiceAmount(); |
| | | |
| | | if (currentInvoiceNum == null || BigDecimal.ZERO.compareTo(currentInvoiceNum) == 0) { |
| | | continue; |
| | | } |
| | | |
| | | LambdaQueryWrapper<SalesLedgerProduct> salesLedgerProductLambdaQueryWrapper = new LambdaQueryWrapper<SalesLedgerProduct>() |
| | | .eq(SalesLedgerProduct::getId, productDatum.getId()) |
| | | .eq(SalesLedgerProduct::getSalesLedgerId, productDatum.getSalesLedgerId()); |
| | | SalesLedgerProduct dbProduct = salesLedgerProductMapper.selectOne(salesLedgerProductLambdaQueryWrapper); |
| | | |
| | | if (dbProduct == null) { |
| | | throw new RuntimeException("销售台账产品不存在,ID:" + productDatum.getId()); |
| | | } |
| | | |
| | | // 计算累计开票 |
| | | BigDecimal newInvoiceNum = dbProduct.getInvoiceNum().add(currentInvoiceNum); |
| | | |
| | | BigDecimal newInvoiceAmount = dbProduct.getInvoiceAmount().add(currentInvoiceAmount); |
| | | |
| | | // 计算未开票 |
| | | BigDecimal newNoInvoiceNum = dbProduct.getQuantity().subtract(newInvoiceNum); |
| | | |
| | | BigDecimal newNoInvoiceAmount = dbProduct.getTaxInclusiveTotalPrice().subtract(newInvoiceAmount); |
| | | |
| | | if (newNoInvoiceNum.compareTo(BigDecimal.ZERO) < 0 |
| | | || newNoInvoiceAmount.compareTo(BigDecimal.ZERO) < 0) { |
| | | throw new RuntimeException("开票数量或金额超过合同总量"); |
| | | } |
| | | |
| | | // 更新 sales_ledger_product |
| | | salesLedgerProductMapper.update( |
| | | null, |
| | | new LambdaUpdateWrapper<SalesLedgerProduct>() |
| | | .eq(SalesLedgerProduct::getId, dbProduct.getId()) |
| | | .set(SalesLedgerProduct::getInvoiceNum, newInvoiceNum) |
| | | .set(SalesLedgerProduct::getInvoiceAmount, newInvoiceAmount) |
| | | .set(SalesLedgerProduct::getNoInvoiceNum, newNoInvoiceNum) |
| | | .set(SalesLedgerProduct::getNoInvoiceAmount, newNoInvoiceAmount) |
| | | ); |
| | | |
| | | InvoiceRegistrationProduct invoiceRegistrationProduct = new InvoiceRegistrationProduct(); |
| | | BeanUtils.copyProperties(dbProduct, invoiceRegistrationProduct); |
| | | |
| | | invoiceRegistrationProduct.setId(null); |
| | | invoiceRegistrationProduct.setSalesLedgerId(salesLedgerDto.getId().intValue()); |
| | | invoiceRegistrationProduct.setInvoiceRegistrationId(invoiceRegistration.getId()); |
| | | invoiceRegistrationProduct.setSalesLedgerProductId(dbProduct.getId().intValue()); |
| | | invoiceRegistrationProduct.setInvoiceNum(currentInvoiceNum); |
| | | invoiceRegistrationProduct.setInvoiceAmount(currentInvoiceAmount); |
| | | invoiceRegistrationProduct.setNoInvoiceAmount(newNoInvoiceAmount); |
| | | |
| | | invoiceRegistrationProductMapper.insert(invoiceRegistrationProduct); |
| | | |
| | | InvoiceLedger invoiceLedger = new InvoiceLedger(); |
| | | invoiceLedger.setInvoiceDate(salesLedgerDto.getIssueDate()); |
| | | invoiceLedger.setInvoiceRegistrationProductId(invoiceRegistrationProduct.getId()); |
| | | invoiceLedger.setInvoiceTotal(currentInvoiceAmount); |
| | | invoiceLedger.setInvoiceNo(salesLedgerDto.getInvoiceNo()); |
| | | invoiceLedger.setCreateUser(SecurityUtils.getUserId().intValue()); |
| | | invoiceLedger.setInvoicePerson(dbProduct.getRegister()); |
| | | |
| | | invoiceLedgerMapper.insert(invoiceLedger); |
| | | } |
| | | } |
| | | |