From 402aba359adb4b10cfa98ad7fcb424eb55641129 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期四, 04 七月 2024 15:54:52 +0800
Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/DolphinEnglish

---
 ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/TGoodsController.java |  217 ++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 155 insertions(+), 62 deletions(-)

diff --git a/ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/TGoodsController.java b/ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/TGoodsController.java
index 325b9b5..247be0d 100644
--- a/ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/TGoodsController.java
+++ b/ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/TGoodsController.java
@@ -2,7 +2,6 @@
 
 
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.ruoyi.common.core.constant.Constants;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.exception.GlobalException;
@@ -81,20 +80,26 @@
         if (tokenService.getLoginUser1() == null) {
             return R.tokenError("登录失效");
         }
-        List<String> type = goodQuery.getType();
         String keywords = goodQuery.getKeywords();
         // 初始化条件构造器
         QueryWrapper<TGoods> wrapper = new QueryWrapper<>();
-        wrapper = keywords != null && "".equals(keywords.trim()) ? wrapper.like("name", keywords) : wrapper;
+        wrapper = keywords != null && !"".equals(keywords.trim()) ? wrapper.like("name", keywords) : wrapper;
 
         // 类型匹配 todo
         if (goodQuery.getType() != null && goodQuery.getType().size() > 0) {
-            StringBuilder temp = new StringBuilder("");
-            for (String s : goodQuery.getType()) {
-                wrapper.or().apply("FIND_IN_SET('" + s + "', typeIds)"); // 将每个类型 ID 应用于 FIND_IN_SET 函数
+            for (int i = 0; i < goodQuery.getType().size(); i++) {
+//                if (i == 0){
+//                    wrapper.apply("FIND_IN_SET('" + goodQuery.getType().get(i) + "', typeIds)"); // 将每个类型 ID 应用于 FIND_IN_SET 函数
+//                }else{
+                    wrapper.or().apply("FIND_IN_SET('" + goodQuery.getType().get(i) + "', typeIds)"); // 将每个类型 ID 应用于 FIND_IN_SET 函数
+//                }
             }
         }
         wrapper.eq("isDelete", 0);
+        // sort排序
+        wrapper.orderByAsc("CASE WHEN sort IS NULL THEN 1 ELSE 0 END")
+                .orderByAsc("sort")
+                .orderByDesc("createTime");
         return R.ok(goodsService.page(new PageInfo<>(goodQuery.getPageNumber(), goodQuery.getPageSize()), wrapper));
     }
 
@@ -108,15 +113,21 @@
         // 初始化条件构造器
         QueryWrapper<TGoods> wrapper = new QueryWrapper<>();
         wrapper = keywords != null && !"".equals(keywords.trim()) ? wrapper.like("name", keywords) : wrapper;
-
         // 类型匹配 todo
-        if (goodQuery.getType() != null && !goodQuery.getType().isEmpty()) {
-            for (String s : goodQuery.getType()) {
-                // 将每个类型 ID 应用于 FIND_IN_SET 函数
-                wrapper.or().apply("FIND_IN_SET('" + s + "', typeIds)");
+        if (goodQuery.getType() != null && goodQuery.getType().size() > 0) {
+            for (int i = 0; i < goodQuery.getType().size(); i++) {
+                if (i == 0){
+                    wrapper.apply("FIND_IN_SET('" + goodQuery.getType().get(i) + "', typeIds)"); // 将每个类型 ID 应用于 FIND_IN_SET 函数
+                }else{
+                    wrapper.or().apply("FIND_IN_SET('" + goodQuery.getType().get(i) + "', typeIds)"); // 将每个类型 ID 应用于 FIND_IN_SET 函数
+                }
             }
         }
         wrapper.eq("isDelete", 0);
+        // sort排序
+        wrapper.orderByAsc("CASE WHEN sort IS NULL THEN 1 ELSE 0 END")
+                .orderByDesc("sort")
+                .orderByDesc("createTime");
         return R.ok(goodsService.page(new PageInfo<>(goodQuery.getPageNumber(), goodQuery.getPageSize()), wrapper));
     }
 
@@ -137,6 +148,15 @@
     @PostMapping("/deleteGoodsType/{id}")
     @ApiOperation(value = "删除", tags = {"后台-商品类型管理"})
     public R deleteGoodsType(@PathVariable("id") Integer id) {
+        // 初始化条件构造器
+        QueryWrapper<TGoods> wrapper = new QueryWrapper<>();
+        // 类型匹配 todo
+        wrapper.or().apply("FIND_IN_SET('" + id + "', typeIds)"); // 将每个类型 ID 应用于 FIND_IN_SET 函数
+        wrapper.eq("isDelete", 0);
+        List<TGoods> list = goodsService.list(wrapper);
+        if (!list.isEmpty()) {
+            return R.fail("当前商品分类被使用,无法删除!");
+        }
         TGoodsType byId = goodsTypeService.getById(id);
         byId.setIsDelete(1);
         goodsTypeService.removeById(byId);
@@ -153,9 +173,27 @@
         wrapper.orderByDesc("id");
         List<TGoods> list = goodsService.list(wrapper);
         for (TGoods tGoods : list) {
-            long goodsId = orderService.count(new QueryWrapper<TOrder>().eq("goodsId", tGoods.getId()));
-            tGoods.setInventory(goodsId);
+            Long temp = 0L;
+            List<TOrder> list1 = orderService.list(new QueryWrapper<TOrder>().eq("goodsId", tGoods.getId()));
+            for (TOrder tOrder : list1) {
+                temp += tOrder.getCount();
+            }
+            tGoods.setInventory(temp);
+            // 剩余兑换数量
+            Integer residueNumber = null;
+            if (null != tGoods.getTotal()) {
+                // 计算剩余兑换数量
+                List<TOrder> orderList = orderService.lambdaQuery().eq(TOrder::getGoodsId, tGoods)
+                        .eq(TOrder::getDisabled, 0).list();
+                Integer item = 0;
+                for (TOrder order : orderList) {
+                    item += order.getCount();
+                }
+                residueNumber = tGoods.getTotal() - item;
+                tGoods.setSurplus(residueNumber);
+            }
         }
+
         PageInfo<TGoods> res = new PageInfo<>(query.getPageNumber(), query.getPageSize());
         res.setRecords(list);
         return R.ok(res);
@@ -164,9 +202,9 @@
     @PostMapping("/addGoods")
     @ApiOperation(value = "添加", tags = {"后台-商品管理"})
     public R addGoods(@RequestBody TGoods dto) {
-        if (dto.getTotal()!=null){
+        if (dto.getTotal() != null) {
             dto.setSurplus(dto.getTotal());
-        }else{
+        } else {
             dto.setSurplus(0);
         }
         goodsService.save(dto);
@@ -184,12 +222,22 @@
     @PostMapping("/updateGoods")
     @ApiOperation(value = "修改", tags = {"后台-商品管理"})
     public R updateGoods(@RequestBody TGoods dto) {
-        if (dto.getTotal()!=null){
-            dto.setSurplus(dto.getTotal());
-        }else{
-            dto.setSurplus(0);
+        TGoods byId = goodsService.getById(dto.getId());
+        if (!Objects.equals(byId.getTotal(), dto.getTotal())){
+            // 如果修改了商品总数 那么需要再判断当前商品已被购买了多少
+            List<TOrder> list = orderService.list(new QueryWrapper<TOrder>()
+                    .eq("goodsId", dto.getId()));
+            Integer temp = 0;
+            for (TOrder tOrder : list) {
+                temp += tOrder.getCount();
+            }
+            if (dto.getTotal()<temp){
+                return R.fail("商品总数不能小于当前商品已兑换数量,"+"当前商品已兑换数量为:"+temp);
+            }
         }
         goodsService.updateById(dto);
+        goodsService.updateOne(dto);
+
         return R.ok("修改成功");
     }
 
@@ -218,6 +266,10 @@
     @GetMapping("/exchangeRecord")
     @ApiOperation(value = "学习端-兑换记录", tags = {"学习端-商城"})
     public R<List<ExchangeRecordVO>> exchangeRecord() {
+        LoginUserParent loginUserStudy = tokenService.getLoginUserStudy();
+        if (null == loginUserStudy) {
+            return R.tokenError("登录失效!");
+        }
         List<ExchangeRecordVO> exchangeRecord = orderService.exchangeRecord(tokenService.getLoginUserStudy().getUserid());
         for (ExchangeRecordVO record : exchangeRecord) {
             TGoods goods = goodsService.getById(record.getGoodsId());
@@ -236,33 +288,24 @@
 
     @GetMapping("/exchangeRecordParent")
     @ApiOperation(value = "家长端-兑换记录", tags = {"家长端-兑换记录"})
-    public R<Page<TOrder>> exchangeRecordParent(Integer pageNumber, Integer pageSize) {
+    public R<List<ExchangeRecordVO>> exchangeRecordParent() {
         if (tokenService.getLoginUser1() == null) {
             return R.tokenError("登录失效");
         }
-        Page<TOrder> page = orderService.page(new Page<>(pageNumber, pageSize), new QueryWrapper<TOrder>().eq("userId", tokenService.getLoginUser1().getUserid())
-                .orderByDesc("createTime"));
-        List<TOrder> records = page.getRecords();
-        for (TOrder tOrder : records) {
-            TGoods byId = goodsService.getById(tOrder.getGoodsId());
-            tOrder.setName(byId.getName());
-            tOrder.setImg(byId.getCoverImg());
-            StringBuilder stringBuilder = new StringBuilder();
-            if (StringUtils.hasLength(byId.getTypeIds())) {
-                String[] split = byId.getTypeIds().split(",");
-                for (String s : split) {
-                    TGoodsType byId1 = goodsTypeService.getById(s);
-                    if (byId1 != null) {
-                        stringBuilder.append(byId1.getName()).append("|");
-                    }
-                }
-                // 去除最后一个字符
-                stringBuilder.deleteCharAt(stringBuilder.length() - 1);
-                tOrder.setType(stringBuilder.toString());
+        List<ExchangeRecordVO> exchangeRecord = orderService.exchangeRecord(tokenService.getLoginUser1().getUserid());
+        for (ExchangeRecordVO record : exchangeRecord) {
+            TGoods goods = goodsService.getById(record.getGoodsId());
+            List<String> typeList;
+            if (null != goods) {
+                List<TGoodsType> goodsTypes = goodsTypeService.lambdaQuery().in(TGoodsType::getId, Arrays.stream(goods.getTypeIds().split(",")).collect(Collectors.toList()))
+                        .eq(TGoodsType::getIsDelete, 0).list();
+                typeList = goodsTypes.stream().map(TGoodsType::getName).collect(Collectors.toList());
+            } else {
+                typeList = new ArrayList<>();
             }
+            record.setGoodsType(typeList);
         }
-
-        return R.ok(page);
+        return R.ok(exchangeRecord);
     }
 
     /**
@@ -280,6 +323,7 @@
         }
         TOrder byId = orderService.getById(id);
         byId.setState(3);
+        byId.setCompleteTime(new Date());
         return R.ok(orderService.updateById(byId));
     }
 
@@ -549,13 +593,19 @@
         if (tokenService.getLoginUser1() == null) {
             return R.tokenError("登录失效");
         }
-        Recipient userId = recipientService.getById(recipientId);
-        TOrder byId = orderService.getById(orderId);
-        byId.setConsigneeName(userId.getRecipient());
-        byId.setConsigneePhone(userId.getRecipientPhone());
-        byId.setConsigneeAddress(userId.getAddress());
-        orderService.updateById(byId);
-        return R.ok("修改成功");
+        Recipient recipient = recipientService.getById(recipientId);
+        TOrder order = orderService.getById(orderId);
+        if (null == order) {
+            throw new GlobalException("订单不存在!");
+        }
+        if (!Constants.ONE.equals(order.getState())) {
+            throw new GlobalException("订单已发货,无法修改收货地址!");
+        }
+        order.setConsigneeName(recipient.getRecipient());
+        order.setConsigneePhone(recipient.getRecipientPhone());
+        order.setConsigneeAddress(recipient.getProvince()+recipient.getCity()+recipient.getAddress());
+        orderService.updateById(order);
+        return R.ok();
     }
 
     @GetMapping("/updateOrderAddress")
@@ -577,9 +627,9 @@
         if (!Constants.ONE.equals(order.getState())) {
             throw new GlobalException("订单已发货,无法修改收货地址!");
         }
-        order.setConsigneeName(recipient.getAddress());
+        order.setConsigneeName(recipient.getRecipient());
         order.setConsigneePhone(recipient.getRecipientPhone());
-        order.setConsigneeAddress(recipient.getAddress());
+        order.setConsigneeAddress(recipient.getProvince()+recipient.getCity()+recipient.getAddress());
         orderService.updateById(order);
         return R.ok();
     }
@@ -602,7 +652,11 @@
     @ApiOperation(value = "可兑换商品推荐", tags = {"学习端-商城"})
     @ApiOperationSupport(order = 38)
     public R<List<TGoodsVO>> goodRecommend() {
-        return R.ok(goodsService.goodRecommend(tokenService.getLoginUserStudy().getUserid()));
+        LoginUserParent loginUserStudy = tokenService.getLoginUserStudy();
+        if (null == loginUserStudy) {
+            return R.tokenError("登录失效!");
+        }
+        return R.ok(goodsService.goodRecommend(loginUserStudy.getUserid()));
     }
 
     /**
@@ -643,7 +697,19 @@
             number += goods.getBasicCount();
         }
         number += orderService.getGoodBuyNumber(goods.getId());
-        return R.ok(new GoodDetailVO(goods, goodsTypes, number));
+        // 剩余兑换数量
+        Integer residueNumber = null;
+        if (null != goods.getTotal()) {
+            // 计算剩余兑换数量
+            List<TOrder> orderList = orderService.lambdaQuery().eq(TOrder::getGoodsId, goodId)
+                    .eq(TOrder::getDisabled, 0).list();
+            Integer item = 0;
+            for (TOrder order : orderList) {
+                item += order.getCount();
+            }
+            residueNumber = goods.getTotal() - item;
+        }
+        return R.ok(new GoodDetailVO(goods, goodsTypes, number, residueNumber));
     }
 
     /**
@@ -653,7 +719,6 @@
      */
     @GetMapping("/goodDetailParent")
     @ApiOperation(value = "商品详情", tags = {"家长端-商城"})
-    @ApiOperationSupport(order = 24)
     @ApiImplicitParams({
             @ApiImplicitParam(value = "商品id", name = "goodId", dataType = "String", required = true)
     })
@@ -669,8 +734,24 @@
         // 商品分类详情
         List<TGoodsType> goodsTypes = goodsTypeService.lambdaQuery().in(TGoodsType::getId, Arrays.asList(goods.getTypeIds().split(","))).list();
         // 已兑换人数
-        int number = goods.getBasicCount() + orderService.getGoodBuyNumber(goods.getId());
-        return R.ok(new GoodDetailVO(goods, goodsTypes, number));
+        int number = 0;
+        if (null != goods.getBasicCount()) {
+            number += goods.getBasicCount();
+        }
+        number += orderService.getGoodBuyNumber(goods.getId());
+        // 剩余兑换数量
+        Integer residueNumber = null;
+        if (null != goods.getTotal()) {
+            // 计算剩余兑换数量
+            List<TOrder> orderList = orderService.lambdaQuery().eq(TOrder::getGoodsId, goodId)
+                    .eq(TOrder::getDisabled, 0).list();
+            Integer item = 0;
+            for (TOrder order : orderList) {
+                item += order.getCount();
+            }
+            residueNumber = goods.getTotal() - item;
+        }
+        return R.ok(new GoodDetailVO(goods, goodsTypes, number, residueNumber));
     }
 
     /**
@@ -690,6 +771,13 @@
                 .eq(Recipient::getUserId, tokenService.getLoginUserStudy().getUserid())
                 .eq(Recipient::getIsDefault, 1)
                 .eq(Recipient::getDisabled, 0).one();
+        if (null == recipient) {
+            recipient = recipientService.lambdaQuery()
+                    .eq(Recipient::getUserId, tokenService.getLoginUserStudy().getUserid())
+                    .eq(Recipient::getDisabled, 0)
+                    .orderByDesc(Recipient::getCreateTime)
+                    .last("limit 1").one();
+        }
         GoodDetailVO goodDetailVO = goodsService.redeemNow(goodId, recipient);
         LocalDateTime currentDateTime = LocalDateTime.now();
         // 格式化日期和时间信息
@@ -726,12 +814,11 @@
                 .eq(Recipient::getIsDefault, 1).one();
         if (recipient == null) {
             // 随便取一条地址数据
-            List<Recipient> list = recipientService.lambdaQuery()
+            recipient = recipientService.lambdaQuery()
                     .eq(Recipient::getUserId, tokenService.getLoginUser1().getUserid())
-                    .eq(Recipient::getIsDefault, 1).list();
-            if (!list.isEmpty()) {
-                recipient = list.get(0);
-            }
+                    .orderByDesc(Recipient::getCreateTime)
+                    .eq(Recipient::getDisabled, 0).last("limit 1")
+                    .one();
         }
         GoodDetailVO goodDetailVO = goodsService.redeemNow(goodId, recipient);
         LocalDateTime currentDateTime = LocalDateTime.now();
@@ -785,11 +872,14 @@
         TOrder byId = orderService.getById(id);
         TGoods byId2 = goodsService.getById(byId.getGoodsId());
         TOrderVO tGoodsVO = new TOrderVO();
-        tGoodsVO.setName(byId2.getName());
         BeanUtils.copyProperties(byId, tGoodsVO);
+        tGoodsVO.setName(byId2.getName());
         TUser byId1 = studyClient.getUserById(byId.getUserId()).getData();
         tGoodsVO.setUserName(byId1.getName());
         tGoodsVO.setPhone(byId1.getPhone());
+        if (byId.getProvince() != null && byId.getCity() != null) {
+            tGoodsVO.setConsigneeAddress(byId.getProvince() + byId.getCity() + tGoodsVO.getConsigneeAddress());
+        }
         return R.ok(tGoodsVO);
     }
 
@@ -810,11 +900,14 @@
     @ApiOperation(value = "列表查询", tags = {"后台-订单管理"})
     @ApiOperationSupport(order = 13)
     public R<PageInfo<TOrderVO>> listAll1(@RequestBody OrderQuery query) throws ParseException {
-        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
 
         if (query.getEndTime() != null) {
             Date parse = format.parse(query.getStartTime());
             Date parse1 = format.parse(query.getEndTime());
+            parse1.setHours(23);
+            parse1.setMinutes(59);
+            parse1.setSeconds(59);
             query.setStartTime1(parse);
             query.setEndTime1(parse1);
         }

--
Gitblit v1.7.1