From 60f70f7409ec1ece8905e088fb43e0cb0258a70b Mon Sep 17 00:00:00 2001 From: luodangjia <luodangjia> Date: 星期四, 19 十二月 2024 10:10:57 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java | 358 ++++++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 328 insertions(+), 30 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 31860a6..4adce50 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,39 +1,45 @@ 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; +import com.ruoyi.common.core.web.page.PageInfo; import com.ruoyi.common.security.service.TokenService; import com.ruoyi.order.enums.OrderStatus; -import com.ruoyi.order.enums.OrderType; 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; /** @@ -62,6 +68,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 @@ -101,9 +130,6 @@ orderGoodsVO.setOriginalPrice(goods.getOriginalPrice()); goodsList.add(orderGoodsVO); } - - - // 收货地址 String addressJson = order.getAddressJson(); UserAddress userAddress = new UserAddress(); @@ -111,7 +137,6 @@ userAddress = JSONObject.parseObject(addressJson, UserAddress.class); } - // 优惠券 String couponJson = order.getCouponJson(); CouponInfo couponInfo = new CouponInfo(); @@ -125,7 +150,6 @@ if (StringUtils.isNotEmpty(activityJson)){ orderActivityInfo = JSONObject.parseObject(activityJson, OrderActivityInfo.class); } - OrderDetailVO orderDetailVO = new OrderDetailVO(); if (CollectionUtil.isNotEmpty(orderGoods)){ @@ -201,7 +225,7 @@ public void writeOff(String code,Integer shopId) { LoginUser loginUserApplet = tokenService.getLoginUserApplet(); Order order = orderMapper.selectOne(new LambdaQueryWrapper<Order>() - .eq(Order::getOrderNumber, code)); + .eq(Order::getId, code)); boolean check = check(order, shopId, loginUserApplet.getUserid()); if (!check){ throw new ServiceException("订单不存在"); @@ -209,18 +233,6 @@ order.setOrderStatus(OrderStatus.COMPLETED.getCode()); orderMapper.updateById(order); Integer orderType = order.getOrderType(); - if (orderType.equals(OrderType.SERVICE.getCode())){ - R<TechnicianSubscribe> subscribeR = technicianClient.getSubscribeByOrderId(order.getId()); - if (R.isError(subscribeR)){ - throw new ServiceException("获取预约信息失败"); - } - TechnicianSubscribe subscribe = subscribeR.getData(); - subscribe.setStatus(2); - R<Void> r = technicianClient.updateStatus(subscribe.getStatus(), subscribe.getId()); - if (R.isError(r)){ - throw new ServiceException("更新预约状态失败"); - } - } // 售后设置 R<BaseSetting> baseSettingR = baseSettingClient.getBaseSetting(5); @@ -234,6 +246,292 @@ String content = baseSetting.getContent(); JSONObject jsonObject = JSONObject.parseObject(content); Long days = jsonObject.getLong("days"); - commissionService.addToCommissionDelayQueue(order.getId(), LocalDateTime.now().plusDays(days)); + if (days != null && days > 0){ + commissionService.addToCommissionDelayQueue(order.getId(), LocalDateTime.now().plusDays(days)); + } + } + + + /** + * 管理后台获取订单列表数据 + * @param orderPageList + * @return + */ + @Override + public PageInfo<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); + } + } + + PageInfo<OrderPageListVo> pageInfo = new PageInfo(orderPageList.getPageCurr(), orderPageList.getPageSize()); + + List<OrderPageListVo> list = this.baseMapper.getOrderPageList(pageInfo, orderPageList); + for (OrderPageListVo orderPageListVo : list) { + Long appUserId = orderPageListVo.getAppUserId(); + AppUser appUser = appUserClient.getAppUserById(appUserId); + orderPageListVo.setUserName(appUser.getName()); + orderPageListVo.setPhone(appUser.getPhone()); + } + return pageInfo.setRecords(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); + refundPayMoney(order); + return R.ok(); + } + + + /** + * 返回订单支付金额和回退积分和会员等级 + * @param order + */ + public void refundPayMoney(Order 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, order.getId())); + 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(order.getId()); + 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, order.getId())); + 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(order.getId()); + 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(order.getId()); + userPointClient.saveUserPoint(userPoint); + appUserClient.editAppUserById(appUser); + } + + + + /** + * 会员降级检测 + */ + 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