xuhy
2024-09-11 8b5f7469e4470e4b89f1659e1dc361dff5ea1b09
ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TExchangeOrderServiceImpl.java
@@ -3,9 +3,14 @@
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ruoyi.account.api.feignClient.AppUserAddressClient;
import com.ruoyi.account.api.feignClient.AppUserClient;
import com.ruoyi.account.api.model.TAppUser;
import com.ruoyi.account.api.model.TAppUserAddress;
import com.ruoyi.common.core.web.page.PageInfo;
import com.ruoyi.common.security.service.TokenService;
import com.ruoyi.order.api.model.TExchangeOrder;
import com.ruoyi.order.api.model.TShoppingOrder;
import com.ruoyi.order.api.query.ShoppingOrderQuery;
import com.ruoyi.order.dto.ExchangeOrderGoodsInfo;
import com.ruoyi.order.dto.GetMyExchangeOrder;
import com.ruoyi.order.dto.MyExchangeOrderList;
@@ -17,11 +22,14 @@
import com.ruoyi.other.api.feignClient.GoodsClient;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.stereotype.Service;
import org.springframework.util.StringUtils;
import javax.annotation.Resource;
import java.time.format.DateTimeFormatter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
 * <p>
@@ -45,8 +53,9 @@
   
   @Resource
   private AppUserAddressClient appUserAddressClient;
   @Resource
   private AppUserClient appUserClient;
   
   
   
@@ -57,7 +66,7 @@
    * @return
    */
   @Override
   public List<MyExchangeOrderList> getMyExchangeOrder(GetMyExchangeOrder query) {
   public Map<String, Object> getMyExchangeOrder(GetMyExchangeOrder query) {
      Long userid = tokenService.getLoginUserApplet().getUserId();
      LambdaQueryWrapper<TExchangeOrder> wrapper = new LambdaQueryWrapper<TExchangeOrder>().eq(TExchangeOrder::getDelFlag, 0).eq(TExchangeOrder::getAppUserId, userid);
      if(query.getStatus() == 0){
@@ -65,7 +74,9 @@
      }else{
         wrapper.eq(TExchangeOrder::getStatus, query.getStatus());
      }
      List<TExchangeOrder> list = this.list(wrapper.orderByDesc(TExchangeOrder::getCreateTime).last(" limit " + query.getPageCurr() + "," + query.getPageSize()));
      long count = this.count(wrapper);
      Integer pageCurr = (query.getPageCurr() - 1) * query.getPageSize();
      List<TExchangeOrder> list = this.list(wrapper.orderByDesc(TExchangeOrder::getCreateTime).last(" limit " + pageCurr + "," + query.getPageSize()));
      List<MyExchangeOrderList> pageList = new ArrayList<>();
      for (TExchangeOrder tExchangeOrder : list) {
         MyExchangeOrderList exchangeOrderList = new MyExchangeOrderList();
@@ -82,7 +93,7 @@
            name = goods.getName();
            imgUrl = goods.getCoverPicture();
         }else{
            TCoupon coupon = couponClient.getCouponById(tExchangeOrder.getGoodsId()).getData();
            TCoupon coupon = couponClient.getCouponById1(tExchangeOrder.getCouponId()).getData();
            name = coupon.getName();
            imgUrl = coupon.getCoverPicture();
         }
@@ -90,7 +101,10 @@
         exchangeOrderList.setImgUrl(imgUrl);
         pageList.add(exchangeOrderList);
      }
      return pageList;
      Map<String, Object> map = new HashMap<>();
      map.put("list", pageList);
      map.put("total", count);
      return map;
   }
   
   
@@ -105,10 +119,12 @@
      ExchangeOrderGoodsInfo info = new ExchangeOrderGoodsInfo();
      info.setId(id);
      info.setStatus(exchangeOrder.getStatus());
      TAppUserAddress userAddress = appUserAddressClient.getAppUserAddressById(exchangeOrder.getAppUserAddressId()).getData();
      info.setConsignee(userAddress.getName());
      info.setPhone(userAddress.getPhone());
      info.setAddress(userAddress.getAddress());
      if(null != exchangeOrder.getAppUserAddressId()){
         TAppUserAddress userAddress = appUserAddressClient.getAppUserAddressById(exchangeOrder.getAppUserAddressId()).getData();
         info.setConsignee(userAddress.getName());
         info.setPhone(userAddress.getPhone());
         info.setAddress(userAddress.getAddress());
      }
      info.setExpressCompany(exchangeOrder.getExpressCompany());
      info.setExpressNumber(exchangeOrder.getExpressNumber());
      String name = "";
@@ -118,7 +134,7 @@
         name = goods.getName();
         imgUrl = goods.getCoverPicture();
      }else{
         TCoupon coupon = couponClient.getCouponById(exchangeOrder.getGoodsId()).getData();
         TCoupon coupon = couponClient.getCouponById1(exchangeOrder.getCouponId()).getData();
         info.setCouponType(coupon.getType());
         info.setDays(coupon.getDays());
         info.setEndTime(coupon.getEndTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
@@ -133,8 +149,52 @@
      info.setCreateTime(exchangeOrder.getCreateTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
      info.setPoints(exchangeOrder.getPoints());
      info.setRemark(exchangeOrder.getRemark());
      info.setDeliveryTime(exchangeOrder.getConsignerTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
      info.setFinishTime(exchangeOrder.getReceivingTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
      if(null != exchangeOrder.getConsignerTime()){
         info.setDeliveryTime(exchangeOrder.getConsignerTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
      }
      if(null != exchangeOrder.getReceivingTime()){
         info.setFinishTime(exchangeOrder.getReceivingTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
      }
      return info;
   }
    @Override
    public PageInfo<TExchangeOrder> pageList(ShoppingOrderQuery query) {
      String startTime1 = null;
      String startTime2 = null;
      if (StringUtils.hasLength(query.getStartTime())){
         String[] split = query.getStartTime().split(" - ");
         startTime1 = split[0];
         startTime2 = split[1];
      }
      PageInfo<TExchangeOrder> pageInfo = new PageInfo<>(query.getPageCurr(),query.getPageSize());
      List<TExchangeOrder> list = this.baseMapper.pageList(pageInfo,query,startTime1,startTime2);
      for (TExchangeOrder tShoppingOrder : list) {
         tShoppingOrder.setUid(tShoppingOrder.getId().toString());
         switch (tShoppingOrder.getOrderType()){
            case 1:
               TGoods data = goodsClient.getGoodsById(tShoppingOrder.getGoodsId()).getData();
               if (data!=null){
                  tShoppingOrder.setName(data.getName());
               }
               break;
            case 2:
               TCoupon data1 = couponClient.getCouponById1(tShoppingOrder.getCouponId()).getData();
               if (data1!=null){
                  tShoppingOrder.setName(data1.getName());
               }
               break;
         }
         if (tShoppingOrder.getAppUserId() != null){
            TAppUser data = appUserClient.getUserById(tShoppingOrder.getAppUserId()).getData();
            if (data!=null){
               tShoppingOrder.setPhone(data.getPhone());
            }
         }
      }
      pageInfo.setRecords(list);
      return pageInfo;
    }
}