From 13a83a82de868164ba4eb7d109e978d386df8ffa Mon Sep 17 00:00:00 2001 From: Hentua <wangdoubleone@gmail.com> Date: Mon, 24 Apr 2023 22:24:48 +0800 Subject: [PATCH] fix --- src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java | 299 ++++++++++++----------------------------------------------- 1 files changed, 64 insertions(+), 235 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java index 12fa502..37608dc 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java @@ -18,6 +18,7 @@ import cc.mrbird.febs.pay.model.AgreementPayDto; import cc.mrbird.febs.pay.model.AgreementSignDto; import cc.mrbird.febs.pay.model.UnipayDto; +import cc.mrbird.febs.pay.service.IAliPayService; import cc.mrbird.febs.pay.service.IPayService; import cc.mrbird.febs.pay.service.UnipayService; import cc.mrbird.febs.rabbit.producter.AgentProducer; @@ -63,14 +64,14 @@ private final MallOrderRefundMapper mallOrderRefundMapper; private final MallOrderRefundOperationMapper mallOrderRefundOperationMapper; private final MallShoppingCartMapper mallShoppingCartMapper; - private final IApiMallMemberService memberService; private final IMallMoneyFlowService mallMoneyFlowService; private final RedisUtils redisUtils; private final AgentProducer agentProducer; - private final IPayService payService; + private final IAliPayService payService; private final IMallAchieveService mallAchieveService; private final UnipayService unipayService; + private final IPayService wechatPayService; private final MallMemberBankSignMapper mallMemberBankSignMapper; private final MallMemberBankMapper mallMemberBankMapper; @@ -79,6 +80,10 @@ private final MallAchieveRecordMapper mallAchieveRecordMapper; private final MallMemberWalletMapper mallMemberWalletMapper; private final MallMqRecordMapper mallMqRecordMapper; + + private final MallShopMapper mallShopMapper; + + private final ICommonService commonService; @Override @Transactional(rollbackFor = Exception.class) @@ -114,11 +119,8 @@ throw new FebsException("请选择门店"); } Long shopId = addOrderDto.getShopId(); - MallShopApply mallShopApply = mallShopApplyMapper.selectById(shopId); + MallShop mallShopApply = mallShopMapper.selectById(shopId); if(ObjectUtil.isEmpty(mallShopApply)){ - throw new FebsException("请选择门店"); - } - if(MallShopApply.APPLY_AGREE != mallShopApply.getStatus()){ throw new FebsException("请选择门店"); } orderInfo.setShopId(shopId); @@ -190,6 +192,11 @@ orderItem.setSkuImage(sku.getSkuImage()); orderItem.setIsNormal(mallGoods.getIsNormal()); orderItem.setCostPrice(sku.getCostPrice()); + orderItem.setStaticMulti(mallGoods.getStaticMulti()); + orderItem.setGoodsLevel(mallGoods.getGoodsLevel()); + orderItem.setNormalBonus(mallGoods.getNormalBonus()); + orderItem.setNormalPer(mallGoods.getNormalPer()); + total = total.add(amount); carriage = carriage.add(mallGoods.getCarriage()); @@ -277,31 +284,17 @@ String rcResult = ""; switch (payOrderDto.getType()) { case "1": - UnipayDto unipayDtoWx = new UnipayDto(); -// unipayDto.setAmount(new BigDecimal("0.01")); - unipayDtoWx.setAmount(orderInfo.getAmount()); - unipayDtoWx.setFrpCode("WEIXIN_APP3"); - unipayDtoWx.setTradeMerchantNo("777180800385820"); - unipayDtoWx.setOrderNo(orderInfo.getOrderNo()); List<MallOrderItem> itemsWx = orderInfo.getItems(); if(CollUtil.isEmpty(itemsWx)){ - unipayDtoWx.setProductName("商品"); + orderInfo.setName("商品"); }else{ - unipayDtoWx.setProductName(itemsWx.get(0).getGoodsName()); + orderInfo.setName(itemsWx.get(0).getGoodsName()); } - String unipayStrWx = unipayService.unipay(unipayDtoWx); - if("fail" == unipayStrWx){ - throw new FebsException("支付失败"); - }else{ -// JSONUtil.parseObj(unipayStr); - JSONObject jsonObject = JSONUtil.parseObj(unipayStrWx); - payResultStr = (String) jsonObject.get("r7_TrxNo"); - rcResult = (String) jsonObject.get("rc_Result"); - } + + payResultStr = wechatPayService.pay(orderInfo); orderInfo.setPayOrderNo(payResultStr); -// orderInfo.setPayOrderNo(payOrderDto.getPayOrderNo()); -// orderInfo.setPayImage(payOrderDto.getPayImage()); orderInfo.setPayMethod("微信支付"); + orderInfo.setPayResult("2"); break; case "2": // if (StrUtil.isNotBlank(orderInfo.getPayOrderNo())) { @@ -342,21 +335,47 @@ orderInfo.setStatus(OrderStatusEnum.WAIT_SHIPPING.getValue()); orderInfo.setPayTime(new Date()); orderInfo.setPayResult("1"); + this.baseMapper.updateById(orderInfo); - changeWallet(orderInfo.getId()); - /** - * 插入一条待处理记录 - * mq处理之后,更新状态 - */ - MallMqRecord mallMqRecord = new MallMqRecord(); - mallMqRecord.setOrderId(orderInfo.getId()); - mallMqRecord.setState(2); - mallMqRecord.setRetryTimes(2); - mallMqRecordMapper.insert(mallMqRecord); - //发送补贴消息 - agentProducer.sendPerkMoneyMsg(orderInfo.getId()); + // 商品级别 会员/代理/股东 + int goodsLevel = 0; + BigDecimal score = BigDecimal.ZERO; + for (MallOrderItem item : orderInfo.getItems()) { + // 计算静态倍数 + if(item.getIsNormal() == 2) { + score = score.add(item.getPrice().multiply(item.getStaticMulti())); + } + + // 判断会员层级 + if (item.getIsNormal() == 2 && goodsLevel < item.getGoodsLevel()) { + goodsLevel = item.getGoodsLevel(); + } + } + + // 根据用户购买的商品设置其等级 + member.setLevel(GoodsToLevelEnums.getLevelByAccountLevel(goodsLevel)); + member.setAccountLevel(goodsLevel); + this.memberMapper.updateById(member); + + memberWalletService.add(score, member.getId(), "score"); + + if (orderInfo.getScoreCnt().compareTo(BigDecimal.ZERO) > 0) { + int reduce = memberWalletService.reduce(orderInfo.getScoreCnt(), member.getId(), "prizeScore"); + if (reduce == 2) { + throw new FebsException("积分不足"); + } + mallMoneyFlowService.addMoneyFlow(member.getId(), orderInfo.getScoreCnt().negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue()); + } + + mallMoneyFlowService.addMoneyFlow(member.getId(), score, MoneyFlowTypeEnum.BUY_TC.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.SCORE.getValue()); + mallMoneyFlowService.addMoneyFlow(member.getId(), orderInfo.getAmount().negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.BALANCE.getValue()); + //发送代理自动升级消息 agentProducer.sendAutoLevelUpMsg(member.getId()); + //发送直推返利消息 + agentProducer.sendOrderReturn(orderInfo.getId()); + // 发送分红消息 + agentProducer.sendOrderBonus(orderInfo.getId()); break; case "4": if (orderInfo.getOrderType() != 2) { @@ -422,181 +441,7 @@ map.put("orderNo", orderInfo.getOrderNo()); map.put("orderId", orderInfo.getId()); map.put("rcResult", rcResult); - return map; - } - - /** - * 支付金额后的操作 - * 减少积分,增加流水 - * 购买套餐后,升级会员等级 - * 增加支付金额流水 - * 增加补贴额度 - * 增加贡献值,增加流水 - * 产生一条业绩记录 - * @param orderId - */ - @Override - public void changeWallet(Long orderId){ - MallOrderInfo orderInfo = this.baseMapper.selectById(orderId); - Long memberId = orderInfo.getMemberId(); - boolean hasTc = false; - //总贡献值 - BigDecimal starSum = BigDecimal.ZERO; - /** - * 总补贴额度 - * 所有合伙人补贴至消费礼包的三倍额度需要复购一次。 - */ - BigDecimal scoreSum = BigDecimal.ZERO; - List<MallOrderItem> orderItems = this.baseMapper.getMallOrderItemByOrderId(orderInfo.getId()); - if (CollUtil.isNotEmpty(orderItems)) { - for (MallOrderItem orderItem : orderItems) { - MallGoods mallGoods = mallGoodsMapper.selectById(orderItem.getGoodsId()); - /** - * 购买套餐赠送贡献值 - * 补贴3倍额度 - */ - if (mallGoods.getIsNormal() == 2) { - hasTc = true; - BigDecimal star = (mallGoods.getStar()==null ? BigDecimal.ZERO : mallGoods.getStar()) - .multiply(new BigDecimal(orderItem.getCnt())); - starSum = starSum.add(star); -// scoreSum = scoreSum.add( -// new BigDecimal(mallGoods.getPresentPrice()) -// .multiply(new BigDecimal(3)) -// .multiply(new BigDecimal(orderItem.getCnt())) -// .abs() -// .setScale(2,BigDecimal.ROUND_DOWN)); - scoreSum = scoreSum.add( - new BigDecimal(mallGoods.getPresentPrice()) - .multiply(new BigDecimal(orderItem.getCnt())) - .abs() - .setScale(2,BigDecimal.ROUND_DOWN)); - } - } - /** - * 增加贡献值,增加流水 - */ - if (starSum.compareTo(BigDecimal.ZERO) > 0) { - //系统设置的个人贡献点最大值 - DataDictionaryCustom starGetDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( - DataDictionaryEnum.STAR_GET.getType(), - DataDictionaryEnum.STAR_GET.getCode()); - if(ObjectUtil.isNotEmpty(starGetDic)){ - String starGetStr = StrUtil.isEmpty(starGetDic.getValue()) ? "0" : starGetDic.getValue(); - BigDecimal starGet = new BigDecimal(starGetStr); - - MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(memberId); - BigDecimal star = new BigDecimal(mallMemberWallet.getStar()); - if(starGet.compareTo(star.add(starSum)) < 0){ - if(starGet.compareTo(BigDecimal.ZERO) == 0){ - mallMemberWalletMapper.addStarByMemberId(starSum.intValue(), memberId); - mallMoneyFlowService.addMoneyFlow( - memberId, - starSum, - MoneyFlowTypeEnum.STAR.getValue(), - orderInfo.getOrderNo(), - FlowTypeEnum.STAR.getValue(), - 2); - } - if(starGet.compareTo(star) > 0){ - BigDecimal subtract = starGet.subtract(star); - if(subtract.compareTo(starSum) < 0){ - starSum = subtract; - } - mallMemberWalletMapper.addStarByMemberId(starSum.intValue(), memberId); - mallMoneyFlowService.addMoneyFlow( - memberId, - starSum, - MoneyFlowTypeEnum.STAR.getValue(), - orderInfo.getOrderNo(), - FlowTypeEnum.STAR.getValue(), - 2); - } - }else{ - mallMemberWalletMapper.addStarByMemberId(starSum.intValue(), memberId); - mallMoneyFlowService.addMoneyFlow( - memberId, - starSum, - MoneyFlowTypeEnum.STAR.getValue(), - orderInfo.getOrderNo(), - FlowTypeEnum.STAR.getValue(), - 2); - } - } - } - /** - * 增加补贴额度 - */ - if (scoreSum.compareTo(BigDecimal.ZERO) > 0) { - MallMember mallMember = memberMapper.selectById(memberId); - if(MemberLevelEnum.SECOND_LEVEL.getLevelCode(mallMember.getLevel()) >= 5){ - scoreSum = scoreSum.multiply(new BigDecimal(3)); - } - if(MemberLevelEnum.SECOND_LEVEL.getLevelCode(mallMember.getLevel()) >= 3 - &&MemberLevelEnum.SECOND_LEVEL.getLevelCode(mallMember.getLevel()) < 5){ - scoreSum = scoreSum.multiply(new BigDecimal(2.8)); - } - if(MemberLevelEnum.SECOND_LEVEL.getLevelCode(mallMember.getLevel()) < 3){ - scoreSum = scoreSum.multiply(new BigDecimal(2.5)); - } - memberWalletService.add(scoreSum, memberId, "totalScore"); - mallMoneyFlowService.addMoneyFlow( - memberId, - scoreSum, - MoneyFlowTypeEnum.TOTAL_SCORE.getValue(), - orderInfo.getOrderNo(), - "", - scoreSum.toString(), - memberId, - 1, - FlowTypeEnum.TOTAL_SCORE.getValue(), - 2); - } - } - - /** - * 购买套餐后,升级会员等级 - */ - if (hasTc) { - MallMember mallMember = memberMapper.selectById(memberId); - if (AgentLevelEnum.ZERO_LEVEL.name().equals(mallMember.getLevel())) { - mallMember.setLevel(AgentLevelEnum.SECOND_LEVEL.name()); - memberMapper.updateById(mallMember); - } - } - /** - * 增加支付金额流水 - */ - mallMoneyFlowService.addMoneyFlow( - memberId, - orderInfo.getAmount().subtract(orderInfo.getScoreAmount()).negate(), - MoneyFlowTypeEnum.PAY.getValue(), - orderInfo.getOrderNo(), - FlowTypeEnum.BALANCE.getValue()); - /** - * 减少积分,增加流水 - */ - int reduce = memberWalletService.reduce(orderInfo.getScoreCnt(), memberId, "prizeScore"); - if (reduce == 2) { - throw new FebsException("积分不足"); - } - mallMoneyFlowService.addMoneyFlow( - memberId, - orderInfo.getScoreCnt().negate(), - MoneyFlowTypeEnum.PAY.getValue(), - orderInfo.getOrderNo(), - FlowTypeEnum.PRIZE_SCORE.getValue()); - /** - * 产生一条业绩记录 - */ - MallAchieveRecord mallAchieveRecord = new MallAchieveRecord(); - mallAchieveRecord.setMemberId(memberId); - mallAchieveRecord.setAchieveTime(new Date()); - mallAchieveRecord.setAmount(orderInfo.getAmount().subtract(orderInfo.getScoreAmount())); - mallAchieveRecord.setOrderId(orderId); - mallAchieveRecord.setPayTime(orderInfo.getPayTime()); - mallAchieveRecordMapper.insert(mallAchieveRecord); } public static void main(String[] args) { @@ -632,6 +477,8 @@ if (reduce == 2) { throw new FebsException("余额不足"); } + + return orderInfo.getOrderNo(); } @@ -892,17 +739,12 @@ if(ObjectUtil.isEmpty(mallGoods)){ throw new FebsException("商品已更新,请重新下单"); } - /** - * 贡献点判断 + + /* + 获取单个商品的折扣积分数量 + = 现价 * 数量 * 折扣现金比例 */ - if (mallGoods.getIsNormal() == 2) { - hasTc = true; - } - /* - 获取单个商品的折扣积分数量 - = 现价 * 数量 * 折扣现金比例 - */ - BigDecimal scorePercent = new BigDecimal(mallGoods.getScorePercent()).multiply(new BigDecimal(0.01)); + BigDecimal scorePercent = new BigDecimal(mallGoods.getScorePercent()).multiply(BigDecimal.valueOf(0.01)); BigDecimal amount = sku.getPresentPrice().multiply(BigDecimal.valueOf(item.getCnt())).multiply(scorePercent); total = total.add(amount); } @@ -914,20 +756,7 @@ if(prizeScore.compareTo(score) < 0){ throw new FebsException("积分不足"); } - if(hasTc){ - //系统设置的个人贡献点最大值 - DataDictionaryCustom starGetDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( - DataDictionaryEnum.STAR_GET.getType(), - DataDictionaryEnum.STAR_GET.getCode()); - if(ObjectUtil.isNotEmpty(starGetDic)){ - String starGetStr = StrUtil.isEmpty(starGetDic.getValue()) ? "0" : starGetDic.getValue(); - BigDecimal starGet = new BigDecimal(starGetStr); - BigDecimal star = new BigDecimal(mallMemberWallet.getStar()); - if(starGet.compareTo(BigDecimal.ZERO) != 0 && starGet.compareTo(star) <= 0){ - throw new FebsException("无法购买套餐"); - } - } - } + /** * 使用积分折扣现金 */ -- Gitblit v1.9.1