From 721d99ec58e38a1f586e2bed93cb8f385d1e9bc6 Mon Sep 17 00:00:00 2001 From: phpcjl <phpcjl@gmail.com> Date: 星期一, 16 十二月 2024 16:21:50 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java | 322 ++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 312 insertions(+), 10 deletions(-) diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java index 433629f..ac220ed 100644 --- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java @@ -1,12 +1,14 @@ package com.ruoyi.order.service.impl; import cn.hutool.core.collection.CollectionUtil; +import com.alibaba.fastjson2.JSON; import com.alibaba.fastjson2.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.account.api.feignClient.AppUserClient; -import com.ruoyi.account.api.model.AppUserShop; -import com.ruoyi.account.api.model.UserAddress; +import com.ruoyi.account.api.feignClient.BalanceChangeRecordClient; +import com.ruoyi.account.api.feignClient.UserPointClient; +import com.ruoyi.account.api.model.*; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.exception.ServiceException; import com.ruoyi.common.core.utils.StringUtils; @@ -15,24 +17,28 @@ import com.ruoyi.order.mapper.OrderGoodMapper; import com.ruoyi.order.mapper.OrderMapper; import com.ruoyi.order.model.Order; +import com.ruoyi.order.model.OrderBalancePayment; import com.ruoyi.order.model.OrderGood; import com.ruoyi.order.service.CommissionService; +import com.ruoyi.order.service.OrderBalancePaymentService; import com.ruoyi.order.service.OrderService; -import com.ruoyi.order.vo.OrderDetailVO; -import com.ruoyi.order.vo.OrderGoodsVO; -import com.ruoyi.order.vo.OrderVO; +import com.ruoyi.order.util.ExpressDeliveryUtil; +import com.ruoyi.order.util.vo.QueryKD100Vo; +import com.ruoyi.order.vo.*; import com.ruoyi.other.api.domain.*; -import com.ruoyi.other.api.feignClient.BaseSettingClient; -import com.ruoyi.other.api.feignClient.ShopClient; -import com.ruoyi.other.api.feignClient.TechnicianClient; +import com.ruoyi.other.api.feignClient.*; +import com.ruoyi.system.api.domain.SysUser; +import com.ruoyi.system.api.feignClient.SysUserClient; import com.ruoyi.system.api.model.LoginUser; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import javax.annotation.Resource; +import java.math.BigDecimal; +import java.math.RoundingMode; import java.time.LocalDateTime; -import java.util.ArrayList; -import java.util.List; +import java.time.format.DateTimeFormatter; +import java.util.*; import java.util.stream.Collectors; /** @@ -61,6 +67,29 @@ private CommissionService commissionService; @Resource private BaseSettingClient baseSettingClient; + + @Resource + private SysUserClient sysUserClient; + + @Resource + private BalanceChangeRecordClient balanceChangeRecordClient; + + @Resource + private UserPointClient userPointClient; + + @Resource + private PointSettingClient pointSettingClient; + + @Resource + private OrderBalancePaymentService orderBalancePaymentService; + + @Resource + private VipSettingClient vipSettingClient; + + @Resource + private GoodsClient goodsClient; + + @Override @@ -223,4 +252,277 @@ Long days = jsonObject.getLong("days"); commissionService.addToCommissionDelayQueue(order.getId(), LocalDateTime.now().plusDays(days)); } + + + /** + * 管理后台获取订单列表数据 + * @param orderPageList + * @return + */ + @Override + public List<OrderPageListVo> getOrderPageList(OrderPageList orderPageList) { + Long userid = tokenService.getLoginUser().getUserid(); + SysUser sysUser = sysUserClient.getSysUser(userid).getData(); + if(2 == sysUser.getRoleType()){ + orderPageList.setShopId(sysUser.getObjectId()); + } + //搜索条件,用户姓名 + if(StringUtils.isNotEmpty(orderPageList.getUserName())){ + List<AppUser> data = appUserClient.getAppUserByName(orderPageList.getUserName()).getData(); + List<Long> collect = data.stream().map(AppUser::getId).collect(Collectors.toList()); + if(null != orderPageList.getAppUserIds()){ + List<Long> appUserIds = orderPageList.getAppUserIds(); + appUserIds.addAll(collect); + orderPageList.setAppUserIds(appUserIds); + }else{ + orderPageList.setAppUserIds(collect); + } + } + //搜索条件,用户电话 + if(StringUtils.isNotEmpty(orderPageList.getPhone())){ + List<AppUser> data = appUserClient.getAppUserByPhone(orderPageList.getPhone()).getData(); + List<Long> collect = data.stream().map(AppUser::getId).collect(Collectors.toList()); + if(null != orderPageList.getAppUserIds()){ + List<Long> appUserIds = orderPageList.getAppUserIds(); + appUserIds.addAll(collect); + orderPageList.setAppUserIds(appUserIds); + }else{ + orderPageList.setAppUserIds(collect); + } + } + + List<OrderPageListVo> list = this.baseMapper.getOrderPageList(orderPageList); + for (OrderPageListVo orderPageListVo : list) { + Long appUserId = orderPageListVo.getAppUserId(); + AppUser appUser = appUserClient.getAppUserById(appUserId); + orderPageListVo.setUserName(appUser.getName()); + orderPageListVo.setPhone(appUser.getPhone()); + } + return list; + } + + + /** + * 确认发货操作 + * @param orderId + * @param code + * @return + */ + @Override + public R confirmDelivery(String orderId, String code) { + Order order = this.getById(orderId); + if(1 == order.getPayStatus()){ + return R.fail("订单还未完成支付"); + } + if(1 == order.getOrderType() || null == order.getAddressJson()){ + return R.fail("该订单不支付快递配送"); + } + if(1 != order.getOrderStatus()){ + return R.fail("无效的操作"); + } + //添加快递号和修改订单状态 + order.setExpressJson(code); + order.setOrderStatus(2); + this.updateById(order); + return R.ok(); + } + + + /** + * 取消订单操作 + * @param orderId + * @return + */ + @Override + public R cancelOrder(Long orderId) { + Order order = this.getById(orderId); + if(Arrays.asList(4, 5, 6, 7, 8).contains(order.getOrderStatus())){ + return R.fail("无效的操作"); + } + order.setOrderStatus(5); + this.updateById(order); + //开始退款 + Integer payMethod = order.getPayMethod(); + BigDecimal paymentAmount = order.getPaymentAmount(); + AppUser appUser = appUserClient.getAppUserById(order.getAppUserId()); + if(1 == payMethod){ + //微信退款 + } + if(2 == payMethod){ + //余额退款 + OrderBalancePayment orderBalancePayment = orderBalancePaymentService.getOne(new LambdaQueryWrapper<OrderBalancePayment>().eq(OrderBalancePayment::getOrderId, orderId)); + BigDecimal balance = appUser.getBalance(); + appUser.setTotalRedPacketAmount(appUser.getTotalRedPacketAmount().add(orderBalancePayment.getRedPacketAmount()).setScale(2, RoundingMode.HALF_EVEN)); + appUser.setTotalDistributionAmount(appUser.getTotalDistributionAmount().add(orderBalancePayment.getDistributionAmount()).setScale(2, RoundingMode.HALF_EVEN)); + appUser.setBalance(balance.add(paymentAmount).setScale(2, RoundingMode.HALF_EVEN)); + appUser.setShopAmount(appUser.getShopAmount().subtract(paymentAmount).setScale(2, RoundingMode.HALF_EVEN)); + + //构建账户余额流水明细 + BalanceChangeRecord balanceChangeRecord = new BalanceChangeRecord(); + balanceChangeRecord.setOrderId(orderId); + balanceChangeRecord.setAppUserId(order.getAppUserId()); + balanceChangeRecord.setChangeType(6); + balanceChangeRecord.setBeforeAmount(balance); + balanceChangeRecord.setChangeAmount(paymentAmount); + balanceChangeRecord.setAfterAmount(appUser.getBalance()); + balanceChangeRecord.setDelFlag(0); + balanceChangeRecord.setCreateTime(LocalDateTime.now()); + balanceChangeRecordClient.saveBalanceChangeRecord(balanceChangeRecord); + } + Integer lavePoint = appUser.getLavePoint(); + if(3 == payMethod){ + //积分退款 + appUser.setLavePoint(appUser.getLavePoint() + order.getPoint()); + + //开始运费退款,积分支付,运费是单独进行支付的,所以需要单独退款 + if(null != order.getExpressAmount() && BigDecimal.ZERO.compareTo(order.getExpressAmount()) < 0){ + BigDecimal expressAmount = order.getExpressAmount(); + if(1 == order.getExpressPayMethod()){ + //微信退款 + } + if(2 == order.getExpressPayMethod()){ + //余额退款 + OrderBalancePayment orderBalancePayment = orderBalancePaymentService.getOne(new LambdaQueryWrapper<OrderBalancePayment>().eq(OrderBalancePayment::getOrderId, orderId)); + BigDecimal balance = appUser.getBalance(); + appUser.setTotalRedPacketAmount(appUser.getTotalRedPacketAmount().add(orderBalancePayment.getRedPacketAmount()).setScale(2, RoundingMode.HALF_EVEN)); + appUser.setTotalDistributionAmount(appUser.getTotalDistributionAmount().add(orderBalancePayment.getDistributionAmount()).setScale(2, RoundingMode.HALF_EVEN)); + appUser.setBalance(balance.add(expressAmount).setScale(2, RoundingMode.HALF_EVEN)); + //构建账户余额流水明细 + BalanceChangeRecord balanceChangeRecord = new BalanceChangeRecord(); + balanceChangeRecord.setOrderId(orderId); + balanceChangeRecord.setAppUserId(order.getAppUserId()); + balanceChangeRecord.setChangeType(6); + balanceChangeRecord.setBeforeAmount(balance); + balanceChangeRecord.setChangeAmount(expressAmount); + balanceChangeRecord.setAfterAmount(appUser.getBalance()); + balanceChangeRecord.setDelFlag(0); + balanceChangeRecord.setCreateTime(LocalDateTime.now()); + balanceChangeRecordClient.saveBalanceChangeRecord(balanceChangeRecord); + } + } + } + //退回获得的消费积分 + //需要先检查会员等级时候回回退,使用回退后的会员等级查询配置 + Integer getPoint = order.getGetPoint(); + boolean vipDemotion = vipDemotion(appUser.getShopPoint() - getPoint, appUser.getVipId()); + PointSetting pointSetting = pointSettingClient.getPointSetting(vipDemotion ? appUser.getVipId() - 1 : appUser.getVipId()).getData(); + int earnPoint1 = getPoint; + if(null != pointSetting && 1 == pointSetting.getBuyPointOpen()){ + earnPoint1 = getPoint / (100 - pointSetting.getBuyPoint()); + } + appUser.setLavePoint(lavePoint - getPoint); + appUser.setShopPoint(appUser.getShopPoint() - earnPoint1); + appUser.setTotalPoint(appUser.getTotalPoint() - earnPoint1); + if(vipDemotion){ + appUser.setVipId(appUser.getVipId() - 1); + } + //构建积分流水明细 + UserPoint userPoint = new UserPoint(); + userPoint.setType(11); + userPoint.setHistoricalPoint(lavePoint); + Integer point = appUser.getLavePoint() - lavePoint; + userPoint.setVariablePoint(point >= 0 ? point : point * -1); + userPoint.setBalance(appUser.getLavePoint()); + userPoint.setCreateTime(LocalDateTime.now()); + userPoint.setAppUserId(order.getAppUserId()); + userPoint.setObjectId(orderId); + userPointClient.saveUserPoint(userPoint); + appUserClient.editAppUserById(appUser); + return R.ok(); + } + + + + /** + * 会员降级检测 + */ + public boolean vipDemotion(Integer shopPoint, Integer vipId){ + if(vipId == 1 || vipId > 3){ + return false; + } + VipSetting vipSetting = vipSettingClient.getVipSetting(vipId).getData(); + Integer vipLevelUpShopRole = vipSetting.getVipLevelUpShopRole(); + Integer vipLevelUpShop = vipSetting.getVipLevelUpShop(); + if(1 == vipLevelUpShopRole && shopPoint < vipLevelUpShop){ + return true; + } + return false; + } + + + /** + * 收货操作 + * @param orderId + * @return + */ + @Override + public R receivingOperation(Long orderId) { + Order order = this.getById(orderId); + if(order.getOrderStatus() != 2){ + return R.fail("无效的操作"); + } + order.setOrderStatus(4); + this.updateById(order); + return R.ok(); + } + + + /** + * 获取订单详情 + * @param orderId + * @return + */ + @Override + public OrderInfoVo getOrderInfo(Long orderId) { + Order order = this.getById(orderId); + OrderInfoVo orderInfo = new OrderInfoVo(); + orderInfo.setId(orderId.toString()); + orderInfo.setOrderNumber(order.getOrderNumber()); + orderInfo.setOrderStatus(order.getOrderStatus()); + orderInfo.setCreateTime(order.getCreateTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"))); + AppUser appUser = appUserClient.getAppUserById(order.getAppUserId()); + orderInfo.setUserName(appUser.getName()); + orderInfo.setPhone(appUser.getPhone()); + orderInfo.setOrderType(order.getOrderType() == 1 ? "服务" : (StringUtils.isNotEmpty(order.getExpressJson()) ? "单品-快递配送" : "单品-自提")); + Shop shop = shopClient.getShopById(order.getShopId()).getData(); + if(null != shop){ + orderInfo.setShopName(shop.getName()); + } + orderInfo.setPaymentMethod(order.getPayMethod()); + orderInfo.setTotalAmount(order.getTotalAmount()); + if(StringUtils.isNotEmpty(order.getCouponJson())){ + CouponInfo couponInfo = JSON.parseObject(order.getCouponJson(), CouponInfo.class); + orderInfo.setCouponName(couponInfo.getCouponName()); + } + orderInfo.setDiscountAmount(order.getDiscountTotalAmount()); + orderInfo.setExpressAmount(order.getExpressAmount()); + orderInfo.setPaymentAmount(order.getPaymentAmount()); + orderInfo.setPoint(order.getGetPoint()); + if(StringUtils.isNotEmpty(order.getAddressJson())){ + UserAddress userAddress = JSON.parseObject(order.getAddressJson(), UserAddress.class); + orderInfo.setRecipient(userAddress.getRecieveName() + "-" + userAddress.getRecievePhone()); + orderInfo.setAddress(userAddress.getRecieveAddress()); + } + if(StringUtils.isNotEmpty(order.getExpressJson())){ + JSONObject jsonObject = JSON.parseObject(order.getExpressJson()); + String com = jsonObject.getString("com"); + String num = jsonObject.getString("num"); + QueryKD100Vo queryKD100Vo = ExpressDeliveryUtil.kd100QueryTrack(com, num); + orderInfo.setExpress(queryKD100Vo); + } + List<OrderGood> orderGoods = orderGoodMapper.selectList(new LambdaQueryWrapper<OrderGood>().eq(OrderGood::getOrderId, orderId).eq(OrderGood::getDelFlag, 0)); + int sum = orderGoods.stream().mapToInt(OrderGood::getNum).sum(); + orderInfo.setGoodsNum(sum); + List<Object> goodsJson = new ArrayList<>(); + for (OrderGood orderGood : orderGoods) { + Goods goods = JSON.parseObject(orderGood.getGoodJson(), Goods.class); + Map<String, Object> map = new HashMap<>(); + map.put("name", goods.getName()); + map.put("imgUrl", goods.getHomePagePicture()); + map.put("number", orderGood.getNum()); + goodsJson.add(map); + } + orderInfo.setGoodsJson(JSON.toJSONString(goodsJson)); + return orderInfo; + } } -- Gitblit v1.7.1