From 1bfec53e4e3a196a3ca53e06e9bec88139cbb689 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期三, 24 一月 2024 18:06:40 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- server/service/src/main/java/com/doumee/service/business/impl/TaxesServiceImpl.java | 239 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 238 insertions(+), 1 deletions(-) diff --git a/server/service/src/main/java/com/doumee/service/business/impl/TaxesServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/TaxesServiceImpl.java index 27ae00a..e560f5e 100644 --- a/server/service/src/main/java/com/doumee/service/business/impl/TaxesServiceImpl.java +++ b/server/service/src/main/java/com/doumee/service/business/impl/TaxesServiceImpl.java @@ -9,27 +9,33 @@ import com.doumee.core.utils.Constants; import com.doumee.core.utils.Utils; import com.doumee.dao.business.CompanyMapper; +import com.doumee.dao.business.SolutionsMapper; import com.doumee.dao.business.TaxDetialMapper; import com.doumee.dao.business.TaxesMapper; +import com.doumee.dao.business.dto.DirectInvoicingDTO; +import com.doumee.dao.business.dto.DirectInvoicingDetailDTO; import com.doumee.dao.business.dto.EntrustInvoicingDTO; +import com.doumee.dao.business.join.ApplyChangeJoinMapper; import com.doumee.dao.business.join.InsuranceApplyJoinMapper; import com.doumee.dao.business.join.TaxDetailJoinMapper; import com.doumee.dao.business.join.TaxesJoinMapper; import com.doumee.dao.business.model.*; +import com.doumee.dao.business.vo.TaxesInvoicingVO; import com.doumee.dao.system.model.SystemUser; import com.doumee.service.business.TaxesService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; 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.github.xiaoymin.knife4j.core.util.CollectionUtils; import com.github.yulichang.wrapper.MPJLambdaWrapper; import org.apache.commons.lang3.StringUtils; import org.apache.shiro.SecurityUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; -import org.springframework.util.CollectionUtils; +import java.math.BigDecimal; import java.util.ArrayList; import java.util.Date; import java.util.List; @@ -57,6 +63,10 @@ private CompanyMapper companyMapper; @Autowired private InsuranceApplyJoinMapper insuranceApplyJoinMapper; + @Autowired + private ApplyChangeJoinMapper applyChangeJoinMapper; + @Autowired + private SolutionsMapper solutionsMapper; @Override public Integer create(Taxes taxes) { @@ -420,4 +430,231 @@ + + @Override + public List<TaxesInvoicingVO> getDirectTaxes(Integer id){ + InsuranceApply queryInsuranceApply = insuranceApplyJoinMapper.selectById(id); + if(Objects.isNull(queryInsuranceApply)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + Solutions solutions = solutionsMapper.selectById(queryInsuranceApply.getSolutionId()); + if(Objects.isNull(solutions)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鏂规淇℃伅"); + } + if(!solutions.getType().equals(Constants.ZERO)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炵洿淇濇柟妗堜繚鍗曪紝鏃犳硶杩涜璇ユ搷浣�"); + } + List<TaxesInvoicingVO> taxesInvoicingVOList = new ArrayList<>(); + this.dealTaxesData(id,taxesInvoicingVOList); + List<Taxes> taxesList = taxesJoinMapper.selectJoinList(Taxes.class,new MPJLambdaWrapper<Taxes>() + .selectAll(Taxes.class) + .selectAs(Solutions::getName,Taxes::getSolutionName) + .selectAs(InsuranceApply::getCode,Taxes::getInsuranceCode) + .leftJoin(Solutions.class,Solutions::getId,Taxes::getSolutionId) + .leftJoin(InsuranceApply.class,InsuranceApply::getId,Taxes::getInsuranceApplyId) + .eq(Taxes::getStatus,Constants.ONE) + .eq(Taxes::getInsuranceApplyId,id) + ); + if(CollectionUtils.isNotEmpty(taxesList)){ + for (Taxes taxes:taxesList) { + TaxesInvoicingVO taxesInvoicingVO = taxes.getTaxesInvoicingVO(); + taxesInvoicingVOList.add(taxesInvoicingVO); + } + } + return taxesInvoicingVOList; + + } + + + public void dealTaxesData(Integer id,List<TaxesInvoicingVO> taxesInvoicingVOList){ + InsuranceApply insuranceApply = insuranceApplyJoinMapper.selectJoinOne(InsuranceApply.class, + new MPJLambdaWrapper<InsuranceApply>() + .selectAll(InsuranceApply.class) + .selectAs(Solutions::getName,InsuranceApply::getSolutionsName) + .select(" ( select count(1) from apply_detail ad where ad.apply_id = t.id ) as insureNum") + .notExists(" select 1 from taxes t1 inner join tax_detial t2 on t1.id = t2.tax_id where t2.type = 0 and t1.status != 2 and t.id = t2.INSURANCE_APPLY_ID ") + .eq(InsuranceApply::getStatus,Constants.InsuranceApplyStatus.UPLOAD_INSURANCE.getKey()) + .eq(InsuranceApply::getId,id) + ); + + + List<ApplyChange> applyChangeList = applyChangeJoinMapper.selectJoinList(ApplyChange.class,new MPJLambdaWrapper<ApplyChange>() + .selectAll(ApplyChange.class) + .selectAs(InsuranceApply::getCode,ApplyChange::getApplyCode) + .select("( select count(1) from apply_chagne_detail ad where t.id = ad.APPLY_CHANGE_ID and ad.TYPE = 0 ) as addNum ") + .select("( select count(1) from apply_chagne_detail ad where t.id = ad.APPLY_CHANGE_ID and ad.TYPE = 1 ) as delNum ") + .select("( select ifnull(sum(ad.FEE),0) from apply_chagne_detail ad where t.id = ad.APPLY_CHANGE_ID ) as changeMoney" ) + .notExists(" select 1 from taxes t1 inner join tax_detial t2 on t1.id = t2.tax_id where t2.type = 1 and t1.status != 2 and t.id = t2.APPLY_CHANGE_ID ") + .leftJoin(InsuranceApply.class,InsuranceApply::getId,ApplyChange::getApplyId) + .leftJoin(Solutions.class,Solutions::getId,InsuranceApply::getSolutionId) + .eq(ApplyChange::getStatus,Constants.ApplyChangeStatus.APPROVE.getKey()) + .eq(ApplyChange::getType,Constants.ZERO) + .eq(InsuranceApply::getId,id) + ); + + if(CollectionUtils.isNotEmpty(applyChangeList)){ + for (ApplyChange applyChange:applyChangeList) { + insuranceApply.setFee(insuranceApply.getFee().subtract(applyChange.getFee())); + TaxesInvoicingVO taxesInvoicingVO = applyChange.getTaxesInvoicingVO(); + if(!Objects.isNull(insuranceApply)){ + taxesInvoicingVO.setAmount(BigDecimal.ZERO); + } + taxesInvoicingVOList.add(taxesInvoicingVO); + } + } + if(!Objects.isNull(insuranceApply)){ + TaxesInvoicingVO taxesInvoicingVO = insuranceApply.getTaxesInvoicingVO(); + taxesInvoicingVOList.add(taxesInvoicingVO); + } + } + + + /** + * 鐩翠繚鏁版嵁鎻愪氦 + * @param directInvoicingDTO + */ + @Override + @Transactional(rollbackFor = {BusinessException.class,Exception.class}) + public void directInvoicing(DirectInvoicingDTO directInvoicingDTO){ + LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); + if(Objects.isNull(directInvoicingDTO) + || Objects.isNull(directInvoicingDTO.getInvoicingMoney()) + || Objects.isNull(directInvoicingDTO.getType()) + || Objects.isNull(directInvoicingDTO.getInvoicingDetailDTOList()) + || StringUtils.isNotBlank(directInvoicingDTO.getAddress()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + if(!user.getType().equals(Constants.ONE)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炰紒涓氱敤鎴锋棤娉曡繘琛岃涓氬姟鏌ヨ"); + } + Company company = companyMapper.selectById(user.getCompanyId()); + if(Objects.isNull(company)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌浼佷笟淇℃伅"); + } + InsuranceApply queryInsuranceApply = insuranceApplyJoinMapper.selectById(directInvoicingDTO.getId()); + if(Objects.isNull(queryInsuranceApply)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + Solutions solutions = solutionsMapper.selectById(queryInsuranceApply.getSolutionId()); + if(Objects.isNull(solutions)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鏂规淇℃伅"); + } + if(!solutions.getType().equals(Constants.ZERO)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炵洿淇濇柟妗堜繚鍗曪紝鏃犳硶杩涜璇ユ搷浣�"); + } + + Taxes taxes = new Taxes(); + taxes.setCreator(user.getId()); + taxes.setCreateDate(new Date()); + taxes.setIsdeleted(Constants.ZERO); + taxes.setStatus(Constants.ZERO); + taxes.setCompanyId(company.getId()); + taxes.setPrice(directInvoicingDTO.getInvoicingMoney()); + taxes.setType(directInvoicingDTO.getType()); + taxes.setTaxCode(company.getTaxCode()); + taxes.setTaxAccount(company.getTaxAccount()); + taxes.setTaxAddr(company.getTaxAddr()); + taxes.setAddr(directInvoicingDTO.getAddress()); + taxes.setCompanyName(company.getName()); + taxes.setApplyType(Constants.ONE); + taxes.setSolutionId(solutions.getId()); + taxes.setInsuranceApplyId(queryInsuranceApply.getId()); + taxesMapper.insert(taxes); + + List<TaxesInvoicingVO> taxesInvoicingVOList = new ArrayList<>(); + this.dealTaxesData(queryInsuranceApply.getId(),taxesInvoicingVOList); + List<TaxDetial> taxDetailList = new ArrayList<>(); + for (TaxesInvoicingVO taxesInvoicingVO:taxesInvoicingVOList) { + if(Objects.isNull(taxesInvoicingVO) + || Objects.isNull(taxesInvoicingVO.getAmount()) + || Objects.isNull(taxesInvoicingVO.getId()) + || Objects.isNull(taxesInvoicingVO.getType()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + TaxDetial taxDetial = new TaxDetial(); + taxDetial.setCreator(user.getId()); + taxDetial.setCreateDate(new Date()); + taxDetial.setIsdeleted(Constants.ZERO); + taxDetial.setTaxId(taxes.getId()); + taxDetial.setTotalFee(taxesInvoicingVO.getAmount()); + taxDetial.setFee(taxesInvoicingVO.getAmount()); + if(taxesInvoicingVO.getType().equals(Constants.ZERO)){ + taxDetial.setInsuranceApplyId(taxesInvoicingVO.getId()); + taxDetial.setType(taxesInvoicingVO.getType()); + }else if(taxesInvoicingVO.getType().equals(Constants.ONE)){ + taxDetial.setApplyChangeId(taxesInvoicingVO.getId()); + taxDetial.setType(taxesInvoicingVO.getType()); + } + taxDetailList.add(taxDetial); + } + List<Integer> chIdList = directInvoicingDTO.getInvoicingDetailDTOList(); + if(CollectionUtils.isNotEmpty(chIdList)){ + for (Integer id:chIdList) { + Taxes chTaxes = taxesMapper.selectById(id); + if(Objects.isNull(chTaxes)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌閫夋嫨鍐茬孩鏁版嵁"); + } + if(!(chTaxes.getStatus().equals(Constants.ZERO)||chTaxes.getStatus().equals(Constants.ONE))){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鍐茬孩鏁版嵁鐘舵�侀敊璇�"); + } + TaxDetial taxDetial = new TaxDetial(); + taxDetial.setCreator(user.getId()); + taxDetial.setCreateDate(new Date()); + taxDetial.setIsdeleted(Constants.ZERO); + taxDetial.setTaxId(taxes.getId()); + taxDetial.setTotalFee(chTaxes.getPrice()); + taxDetial.setFee(chTaxes.getPrice()); + taxDetial.setDelTaxId(chTaxes.getId()); + taxDetial.setType(Constants.TWO); + taxDetailList.add(taxDetial); + } + } + if(CollectionUtils.isNotEmpty(taxDetailList)){ + taxDetailJoinMapper.insertBatchSomeColumn(taxDetailList); + }else{ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏃犲彲寮�绁ㄦ暟鎹紝鎿嶄綔澶辫触"); + } + + +// List<DirectInvoicingDetailDTO> directInvoicingDetailDTOList = directInvoicingDTO.getDirectInvoicingDetailDTOList(); +// for (DirectInvoicingDetailDTO directInvoicingDetailDTO:directInvoicingDetailDTOList) { +// if(Objects.isNull(directInvoicingDetailDTO) +// || Objects.isNull(directInvoicingDetailDTO.getId()) +// || Objects.isNull(directInvoicingDetailDTO.getType()) +// || Objects.isNull(directInvoicingDetailDTO.getFee()) +// ){ +// throw new BusinessException(ResponseStatus.BAD_REQUEST); +// } +// +// if(directInvoicingDetailDTO.getType().equals(Constants.ZERO)){ +// //淇濆崟 +// InsuranceApply insuranceApply = insuranceApplyJoinMapper.selectJoinOne(InsuranceApply.class, +// new MPJLambdaWrapper<InsuranceApply>() +// .selectAll(InsuranceApply.class) +// .selectAs(Solutions::getName,InsuranceApply::getSolutionsName) +// .select(" ( select count(1) from apply_detail ad where ad.apply_id = t.id ) as insureNum") +// .notExists(" select 1 from taxes t1 inner join tax_detial t2 on t1.id = t2.tax_id where t2.type = 0 and t1.status != 2 and t.id = t2.INSURANCE_APPLY_ID ") +// .eq(InsuranceApply::getStatus,Constants.InsuranceApplyStatus.UPLOAD_INSURANCE.getKey()) +// .eq(InsuranceApply::getId,directInvoicingDetailDTO.getId()) +// ); +// if(Objects.isNull(insuranceApply)){ +// throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"淇濆崟鍙枫��"+insuranceApply.getCode()+"銆戞湭鏌ヨ鍒颁繚鍗曚俊鎭�"); +// } +// +// +// +// }else if(directInvoicingDetailDTO.getType().equals(Constants.ZERO)){ +// //鍔犲噺淇� +// }else{ +// //鍐茬孩鍗� +// } +// +// +// } +// taxDetailJoinMapper.insertBatchSomeColumn(taxDetialList); + } + + } -- Gitblit v1.9.3