| | |
| | | package com.ruoyi.project.service.impl; |
| | | |
| | | import java.math.BigDecimal; |
| | | import java.text.SimpleDateFormat; |
| | | import java.time.LocalDate; |
| | | import java.time.ZoneId; |
| | | import java.time.temporal.TemporalAdjusters; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | import java.util.*; |
| | | |
| | | import com.alibaba.fastjson.JSONArray; |
| | | import com.baomidou.mybatisplus.core.toolkit.ObjectUtils; |
| | | import com.ruoyi.common.exception.base.BaseException; |
| | | import com.ruoyi.common.tax.PerformanceTaxtUtils; |
| | | import com.ruoyi.common.tax.TaxtUtils; |
| | | import com.ruoyi.common.utils.bean.DtoConversionUtils; |
| | | import com.ruoyi.project.domain.*; |
| | | import com.ruoyi.project.domain.vo.TaxMoneyVO; |
| | | import com.ruoyi.project.domain.vo.TaxedMoneyVO; |
| | | import com.ruoyi.project.domain.vo.*; |
| | | import com.ruoyi.project.mapper.ServiceFundMapper; |
| | | import lombok.extern.flogger.Flogger; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.commons.collections4.CollectionUtils; |
| | | import org.slf4j.Logger; |
| | | import org.slf4j.LoggerFactory; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | |
| | | import com.ruoyi.common.utils.StringUtils; |
| | | import com.ruoyi.project.mapper.ServiceFunddetailMapper; |
| | | import com.ruoyi.project.service.IServiceFunddetailService; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | |
| | | /** |
| | | * 费用申请明细Service业务层处理 |
| | |
| | | * @author ruoyi |
| | | * @date 2022-01-25 |
| | | */ |
| | | @Slf4j |
| | | @Service |
| | | public class ServiceFunddetailServiceImpl extends ServiceImpl<ServiceFunddetailMapper, ServiceFunddetail> implements IServiceFunddetailService { |
| | | |
| | | protected final Logger logger = LoggerFactory.getLogger(this.getClass()); |
| | | @Autowired |
| | | ServiceFunddetailMapper serviceFunddetailMapper; |
| | | |
| | |
| | | if (serviceFunddetail.getUploadtime() != null) { |
| | | wrappers.eq(ServiceFunddetail::getUploadtime, serviceFunddetail.getUploadtime()); |
| | | } |
| | | if (serviceFunddetail.getJxrq() != null) { |
| | | wrappers.like(ServiceFunddetail::getJxrq, serviceFunddetail.getJxrq()); |
| | | } |
| | | if (StringUtils.isNotBlank(serviceFunddetail.getIdcardno())) { |
| | | wrappers.eq(ServiceFunddetail::getIdcardno, serviceFunddetail.getIdcardno()); |
| | | } |
| | | if (StringUtils.isNotBlank(serviceFunddetail.getApplytype())) { |
| | | wrappers.eq(ServiceFunddetail::getApplytype, serviceFunddetail.getApplytype()); |
| | | } |
| | | if (serviceFunddetail.getDel_flag() != null) { |
| | | wrappers.eq(ServiceFunddetail::getDel_flag, serviceFunddetail.getDel_flag()); |
| | | } |
| | | if (serviceFunddetail.getDeptId() != null) { |
| | | wrappers.eq(ServiceFunddetail::getDeptId, serviceFunddetail.getDeptId()); |
| | | } |
| | | if (serviceFunddetail.getDeptName() != null) { |
| | | wrappers.eq(ServiceFunddetail::getDeptName, serviceFunddetail.getDeptName()); |
| | | } |
| | | return this.list(wrappers); |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | /** |
| | | * 根据受益人编号获取税费金额 |
| | | * 根据受益人身份证编号获取税费金额 |
| | | * |
| | | * @param taxMoneyVo |
| | | * @return |
| | | */ |
| | | @Override |
| | | public Double getTaxBeforeByBeneFiciaryNo(TaxMoneyVO taxMoneyVo) { |
| | | public Double getTaxByBeneFiciaryNo(TaxMoneyVO taxMoneyVo) { |
| | | Double sum = 0.00; |
| | | Double totalScore = 0.00; |
| | | List<ServiceFunddetail> taxationByBeneFiciaryNo = serviceFunddetailMapper.getTaxBeforeByBeneFiciaryNo(taxMoneyVo); |
| | |
| | | /** |
| | | * 根据税后工资,算出税前工资 |
| | | * |
| | | * @param money |
| | | * @param taxMoneyVo |
| | | * @return |
| | | */ |
| | | @Override |
| | |
| | | totalScore = taxationByBeneFiciaryNo.stream().mapToDouble(ServiceFunddetail::getTaxamount).sum(); |
| | | } |
| | | //计算出总的税后薪酬(包含本次) |
| | | sum = sum + taxMoneyVo.getMoney(); |
| | | sum = sum + Double.valueOf(taxMoneyVo.getMoney()); |
| | | //税前总金额 |
| | | String taxationBefore = TaxtUtils.getTaxationBefore(new BigDecimal(sum)); |
| | | //总个税 |
| | |
| | | ServiceFunddetail serviceFunddetail = serviceFunddetailMapper.selectById(id); |
| | | Long fundid = serviceFunddetail.getFundid(); |
| | | ServiceFund serviceFund = serviceFundMapper.selectById(fundid); |
| | | if (ObjectUtils.isNotEmpty(serviceFund)) { |
| | | Double pretax = serviceFund.getPretaxcost(); |
| | | Double aftertax = serviceFund.getTaxedcost(); |
| | | pretax = pretax - serviceFunddetail.getAmount(); |
| | | aftertax = aftertax - serviceFunddetail.getTaxedamount(); |
| | | Double amount = pretax + aftertax; |
| | | |
| | | Double pretax = serviceFund.getPretaxcost(); |
| | | Double aftertax = serviceFund.getTaxedcost(); |
| | | pretax = pretax - serviceFunddetail.getAmount(); |
| | | aftertax = aftertax - serviceFunddetail.getTaxedamount(); |
| | | Double amount = pretax + aftertax; |
| | | |
| | | serviceFund.setPretaxcost(pretax); |
| | | serviceFund.setTaxedcost(aftertax); |
| | | serviceFund.setAmountrequested(amount); |
| | | int updateAmount = serviceFundMapper.updateById(serviceFund); |
| | | |
| | | serviceFund.setPretaxcost(pretax); |
| | | serviceFund.setTaxedcost(aftertax); |
| | | serviceFund.setAmountrequested(amount); |
| | | int updateAmount = serviceFundMapper.updateById(serviceFund); |
| | | } |
| | | return serviceFunddetailMapper.deleteById(id); |
| | | } |
| | | |
| | | @Override |
| | | public List<ServiceFunddetailVO> getFundDetail(Long id) { |
| | | List<ServiceFunddetail> serviceFunddetails = serviceFunddetailMapper.selectFundDetailListById(id); |
| | | List<ServiceFunddetailVO> serviceFunddetailVOS = DtoConversionUtils.sourceToTarget(serviceFunddetails, ServiceFunddetailVO.class); |
| | | for (ServiceFunddetailVO serviceFunddetailVO : serviceFunddetailVOS) { |
| | | if (!StringUtils.isEmpty(serviceFunddetailVO.getAnnexfiles())) { |
| | | List<RbDetailFile> rbDetailFiles = JSONArray.parseArray(serviceFunddetailVO.getAnnexfiles(), RbDetailFile.class); |
| | | serviceFunddetailVO.setAnnexfilesList(rbDetailFiles); |
| | | } |
| | | if (!StringUtils.isEmpty(serviceFunddetailVO.getInvoicefiles())) { |
| | | List<RbDetailFile> rbDetailFiles = JSONArray.parseArray(serviceFunddetailVO.getInvoicefiles(), RbDetailFile.class); |
| | | serviceFunddetailVO.setInvoicefilesList(rbDetailFiles); |
| | | } |
| | | } |
| | | return serviceFunddetailVOS; |
| | | } |
| | | |
| | | /** |
| | | * 根据条件算税 |
| | | * |
| | | * @param serviceFunddetails |
| | | */ |
| | | @Override |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public Boolean calculateTax(List<ServiceFunddetail> serviceFunddetails) { |
| | | if (CollectionUtils.isEmpty(serviceFunddetails)) { |
| | | throw new BaseException("算税条件为空,请检查后,再进行计算"); |
| | | } |
| | | //这个是为了获取fund_tax_time |
| | | Long fundid = serviceFunddetails.get(0).getFundid(); |
| | | log.info("算税的fundid的值为:{}", fundid); |
| | | ServiceFund serviceFund1 = serviceFundMapper.selectById(fundid); |
| | | log.info("fund表的fundtextime值为:{}", serviceFund1.getFundtaxtime()); |
| | | |
| | | //用于临时保存已经算好的"费用详情数据" |
| | | List<ServiceFunddetail> temporarySave = new ArrayList<>(); |
| | | //保存总税前金额(用于更新fund表里的) |
| | | BigDecimal pretaxcost = BigDecimal.valueOf(0.00); |
| | | for (ServiceFunddetail serviceFunddetail : serviceFunddetails) { |
| | | if (StringUtils.isEmpty(serviceFunddetail.getIdcardno())) { |
| | | logger.info("serviceFunddetail数据入参 : {}", serviceFunddetail); |
| | | //如果身份证号为空,就不用查了,可能是医院的记录 |
| | | if (StringUtils.isEmpty(serviceFunddetail.getServicesscopename()) || !serviceFunddetail.getServicesscopename().contains("税后")) { |
| | | serviceFunddetail.setTaxedamount(serviceFunddetail.getAmount()); |
| | | } else { |
| | | serviceFunddetail.setAmount(serviceFunddetail.getTaxedamount()); |
| | | } |
| | | //公司的申请金额也要加进去 |
| | | pretaxcost = pretaxcost.add(BigDecimal.valueOf(serviceFunddetail.getAmount())); |
| | | |
| | | serviceFunddetail.setTaxamount(0.0); |
| | | logger.info("serviceFunddetail更新后的数据 : {}", serviceFunddetail); |
| | | boolean b = this.updateById(serviceFunddetail); |
| | | logger.info("serviceFunddetail修改结果 : {}", b); |
| | | continue; |
| | | } |
| | | |
| | | //获取当月的第一天 |
| | | Date firstDay = Date.from(LocalDate.now().with(TemporalAdjusters.firstDayOfMonth()).atStartOfDay(ZoneId.systemDefault()).toInstant()); |
| | | // SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); |
| | | // String firstDatStr = dateFormat.format(firstDay); |
| | | TaxMoneyByItemEO taxMoneyVO = new TaxMoneyByItemEO(); |
| | | if (serviceFund1.getFundtaxtime() != null) { |
| | | taxMoneyVO.setTaxTime(serviceFund1.getFundtaxtime()); |
| | | } else { |
| | | taxMoneyVO.setTaxTime(new Date()); |
| | | } |
| | | taxMoneyVO.setFirstDay(firstDay); |
| | | taxMoneyVO.setFundID(serviceFunddetail.getFundid()); |
| | | taxMoneyVO.setIDCard(serviceFunddetail.getIdcardno()); |
| | | //查出税前、税、税后的总额(不包含本次) |
| | | TaxMoneySumEO taxSum = serviceFunddetailMapper.getTaxSum(taxMoneyVO); |
| | | logger.info("查询的taxSum的值 : {}", taxSum); |
| | | if (ObjectUtils.isEmpty(taxSum)) { |
| | | taxSum = new TaxMoneySumEO(); |
| | | } |
| | | |
| | | //判断临时集合temporarySave中,有没有已经算过的数据 |
| | | if (CollectionUtils.isNotEmpty(temporarySave)) { |
| | | for (ServiceFunddetail serviceFunddetail1 : temporarySave) { |
| | | //如果本次的”人员类型“、”身份证号“在临时集合中存在,则将集合数据中的该受益人的,税前、税金、税后,和总的相加,并将老的覆盖 |
| | | // if (serviceFunddetail1.getApplytype().equals(serviceFunddetail.getApplytype()) && serviceFunddetail1.getBeneficiaryno().equals(serviceFunddetail.getBeneficiaryno())) { |
| | | if (serviceFunddetail1.getIdcardno().trim().equals(serviceFunddetail.getIdcardno().trim())) { |
| | | //将集合数据中的该受益人的,税前、税金、税后,和总的相加 |
| | | BigDecimal amounts = BigDecimal.valueOf(taxSum.getAmounts()).add(new BigDecimal(String.valueOf(serviceFunddetail1.getAmount()))); |
| | | BigDecimal taxAmounts = BigDecimal.valueOf(taxSum.getTaxAmounts()).add(new BigDecimal(String.valueOf(serviceFunddetail1.getTaxamount()))); |
| | | BigDecimal TaxedAmounts = BigDecimal.valueOf(taxSum.getTaxedAmounts()).add(new BigDecimal(String.valueOf(serviceFunddetail1.getTaxedamount()))); |
| | | //将老的覆盖 |
| | | taxSum.setAmounts(amounts.doubleValue()); |
| | | taxSum.setTaxAmounts(taxAmounts.doubleValue()); |
| | | taxSum.setTaxedAmounts(TaxedAmounts.doubleValue()); |
| | | } |
| | | continue; |
| | | } |
| | | } |
| | | |
| | | if (StringUtils.isEmpty(serviceFunddetail.getServicesscopename()) || !serviceFunddetail.getServicesscopename().contains("税后")) { |
| | | logger.info("计算税前信息开始:{}", serviceFunddetail); |
| | | logger.info("taxSum入参数据:{}", taxSum); |
| | | // 如何税前金额不为空,用之前的”总税前金额“,加上当前”税前金额“ |
| | | BigDecimal newAmounts = BigDecimal.valueOf(taxSum.getAmounts()).add(BigDecimal.valueOf(serviceFunddetail.getAmount())); |
| | | |
| | | // 计算总税金(包含本次) |
| | | String taxation = TaxtUtils.getTaxation(newAmounts); |
| | | //计算本次税金(总税金(包含本次) - 总税金(不包含本次)) |
| | | BigDecimal taxAmountNow = new BigDecimal(taxation).subtract(new BigDecimal(String.valueOf(taxSum.getTaxAmounts()))); |
| | | |
| | | //计算本次的税后金额(本次的税前金额 - 税金) |
| | | BigDecimal texdAfterNow = BigDecimal.valueOf(serviceFunddetail.getAmount()).subtract(taxAmountNow); |
| | | logger.info("打印newAmounts:{},taxation:{},taxAmountNow:{},texdAfterNow:{}", newAmounts, taxation, taxAmountNow, texdAfterNow); |
| | | |
| | | //将循环的数据重新放到一个新对象中 |
| | | ServiceFunddetail serviceFunddetail3 = DtoConversionUtils.sourceToTarget(serviceFunddetail, ServiceFunddetail.class); |
| | | serviceFunddetail3.setTaxamount(taxAmountNow.doubleValue()); |
| | | serviceFunddetail3.setTaxedamount(texdAfterNow.doubleValue()); |
| | | if (ObjectUtils.isEmpty(serviceFund1.getFundtaxtime())) { |
| | | serviceFunddetail3.setTaxTime(new Date()); |
| | | } else { |
| | | serviceFunddetail3.setTaxTime(serviceFund1.getFundtaxtime()); |
| | | } |
| | | logger.info("打印税前serviceFunddetail3数据 :{}", serviceFunddetail3); |
| | | |
| | | // 将该条数据更新 |
| | | boolean b = this.updateById(serviceFunddetail3); |
| | | pretaxcost = pretaxcost.add(BigDecimal.valueOf(serviceFunddetail.getAmount())); |
| | | // 把该数据,放到临时的集合中 |
| | | temporarySave.add(serviceFunddetail3); |
| | | } else if (serviceFunddetail.getServicesscopename().contains("税后")) { |
| | | logger.info("计算税后信息开始:{}", serviceFunddetail); |
| | | logger.info("taxSum入参数据:{}", taxSum); |
| | | //税后不为空, 用之前的”总税后金额“,加上当前”税后金额“ |
| | | BigDecimal newTaxedAmounts = BigDecimal.valueOf(taxSum.getTaxedAmounts()).add(BigDecimal.valueOf(serviceFunddetail.getTaxedamount())); |
| | | |
| | | //通过总税后(包含本次)算出总税前 |
| | | String taxationBefore = TaxtUtils.getTaxationBefore(newTaxedAmounts); |
| | | //算出本次税前(总税前(包含本次) - 总税前(不包含本次)) |
| | | BigDecimal amountNow = new BigDecimal(taxationBefore).subtract(BigDecimal.valueOf(taxSum.getAmounts())); |
| | | |
| | | //算出本次税金(本次税前 - 本次税后) |
| | | BigDecimal tax = amountNow.subtract(BigDecimal.valueOf(serviceFunddetail.getTaxedamount())); |
| | | logger.info("打印newTaxedAmounts:{},taxationBefore:{},amountNow:{},tax:{}", newTaxedAmounts, taxationBefore, amountNow, tax); |
| | | |
| | | //将循环的数据重新放到一个新对象中 |
| | | ServiceFunddetail serviceFunddetail3 = DtoConversionUtils.sourceToTarget(serviceFunddetail, ServiceFunddetail.class); |
| | | serviceFunddetail3.setAmount(amountNow.doubleValue()); |
| | | serviceFunddetail3.setTaxamount(tax.doubleValue()); |
| | | if (ObjectUtils.isEmpty(serviceFund1.getFundtaxtime())) { |
| | | serviceFunddetail3.setTaxTime(new Date()); |
| | | } else { |
| | | serviceFunddetail3.setTaxTime(serviceFund1.getFundtaxtime()); |
| | | } |
| | | logger.info("打印serviceFunddetail3:{}", serviceFunddetail3); |
| | | // 将该条数据更新 |
| | | updateById(serviceFunddetail3); |
| | | pretaxcost = pretaxcost.add(BigDecimal.valueOf(serviceFunddetail3.getAmount())); |
| | | // 把该数据,放到临时的集合中 |
| | | temporarySave.add(serviceFunddetail3); |
| | | } |
| | | } |
| | | ServiceFund serviceFund = new ServiceFund(); |
| | | serviceFund.setPretaxcost(pretaxcost.doubleValue()); |
| | | serviceFund.setId(serviceFunddetails.get(0).getFundid()); |
| | | if (ObjectUtils.isEmpty(serviceFund1.getFundtaxtime())) { |
| | | serviceFund.setFundtaxtime(new Date()); |
| | | } |
| | | // 1 已算税 |
| | | serviceFund.setIstax(1); |
| | | serviceFundMapper.updateById(serviceFund); |
| | | |
| | | return true; |
| | | } |
| | | |
| | | @Override |
| | | public Map<String, Double> performance(ServiceFunddetail serviceFunddetail) { |
| | | //根据"身份证号"和"绩效日期(年份)"查询个人历史绩效 |
| | | ServiceFunddetail serviceFunddetailEo = new ServiceFunddetail(); |
| | | serviceFunddetailEo.setIdcardno(serviceFunddetail.getIdcardno()); |
| | | serviceFunddetailEo.setApplytype("5"); |
| | | Calendar cal = Calendar.getInstance(); |
| | | //默认本年度 |
| | | serviceFunddetailEo.setJxrq(String.valueOf(cal.get(Calendar.YEAR))); |
| | | List<ServiceFunddetail> serviceFunddetails = queryList(serviceFunddetailEo); |
| | | |
| | | //统计历史的税 |
| | | BigDecimal historyTax = BigDecimal.valueOf(0.00); |
| | | //计算扣去每月5000的历史税前金额 |
| | | BigDecimal historyTaxBefore = BigDecimal.valueOf(0.00); |
| | | //本月是否已经算过绩效(下面扣除5000需要用到这个,如果本月已经扣过5000,就不再扣了) |
| | | Boolean deduct = false; |
| | | //获取当前月份 |
| | | Date date = new Date(); |
| | | SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM"); |
| | | String nowMonth = sdf.format(date); |
| | | |
| | | for (ServiceFunddetail serviceFunddetail1 : serviceFunddetails) { |
| | | historyTaxBefore = historyTaxBefore.add(BigDecimal.valueOf(serviceFunddetail1.getAmount())).subtract(BigDecimal.valueOf(5000)); |
| | | historyTax = historyTax.add(BigDecimal.valueOf(serviceFunddetail1.getTaxamount())); |
| | | if (serviceFunddetail1.getJxrq().equals(nowMonth)) { |
| | | deduct = true; |
| | | } |
| | | } |
| | | BigDecimal allValue = BigDecimal.valueOf(0.00); |
| | | //先查询一下本月是否已经算过绩效(一个月只减一次5000,如果上一次已经减过,这一次就不在减了) |
| | | if (deduct == true) { |
| | | //本月已经减过5000了 |
| | | allValue = historyTaxBefore.add(BigDecimal.valueOf(serviceFunddetail.getAmount())); |
| | | } else { |
| | | BigDecimal subtract = BigDecimal.valueOf(serviceFunddetail.getAmount()).subtract(BigDecimal.valueOf(5000)); |
| | | allValue = historyTaxBefore.add(subtract); |
| | | } |
| | | //计算加上本次的税前金额的总税 |
| | | BigDecimal personTaxation = PerformanceTaxtUtils.getPersonTaxation(allValue); |
| | | //计算本次的税 |
| | | BigDecimal nowSingleTax = personTaxation.subtract(historyTax); |
| | | //计算本次的税后 |
| | | BigDecimal taxAfter = BigDecimal.valueOf(serviceFunddetail.getAmount()).subtract(nowSingleTax); |
| | | |
| | | //将计算出来的数据放到serviceFunddetail中 |
| | | serviceFunddetail.setTaxamount(nowSingleTax.doubleValue()); |
| | | serviceFunddetail.setTaxedamount(taxAfter.doubleValue()); |
| | | serviceFunddetail.setJxrq(nowMonth); |
| | | |
| | | save(serviceFunddetail); |
| | | Map map = new HashMap(); |
| | | map.put("amount", serviceFunddetail.getAmount()); |
| | | map.put("taxedamount", taxAfter.doubleValue()); |
| | | return map; |
| | | } |
| | | |
| | | |
| | | @Override |
| | | public List<SpStatBonus> getListBySpStatBonus(SpStatBonusReq spStatBonusReq) { |
| | | return serviceFunddetailMapper.getListBySpStatBonus(spStatBonusReq.getPabegtime(), spStatBonusReq.getPaendtime(), spStatBonusReq.getPadeptno(), spStatBonusReq.getPauserno(), spStatBonusReq.getPabonustype()); |
| | | } |
| | | } |