From b679205246bbe94e1e83db6f8e26d04668afd402 Mon Sep 17 00:00:00 2001
From: 44323 <443237572@qq.com>
Date: 星期四, 06 六月 2024 11:29:01 +0800
Subject: [PATCH] 短信 obs 支付宝支付

---
 ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/TGoodsController.java |  432 +++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 399 insertions(+), 33 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 12d46fe..4f7024a 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
@@ -1,14 +1,17 @@
 package com.ruoyi.goods.controller;
 
 
+import com.alibaba.fastjson2.util.UUIDUtils;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.ruoyi.common.core.domain.R;
-import com.ruoyi.common.core.web.domain.AjaxResult;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.goods.domain.*;
 import com.ruoyi.goods.dto.*;
 import com.ruoyi.goods.service.*;
+import com.ruoyi.goods.utils.MyQrCodeUtil;
+import com.ruoyi.goods.utils.QRCodeUtil;
 import com.ruoyi.goods.vo.GoodDetailVO;
 import com.ruoyi.goods.vo.TGoodsVO;
 import com.ruoyi.goods.vo.TOrderVO;
@@ -17,18 +20,20 @@
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
+import org.apache.logging.log4j.core.util.UuidUtil;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.util.StringUtils;
 import org.springframework.web.bind.annotation.*;
+import org.springframework.web.multipart.MultipartFile;
 
 import javax.annotation.Resource;
+import java.awt.image.BufferedImage;
 import java.text.ParseException;
 import java.text.SimpleDateFormat;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Date;
-import java.util.List;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.*;
 
 /**
  * <p>
@@ -70,15 +75,46 @@
     }
 
     @PostMapping("/goodList")
-    @ApiOperation(value = "商品列表查询", tags = {"学习端-商品列表"})
+    @ApiOperation(value = "商品列表查询", tags = {"家长端-商品列表"})
     public R<PageInfo<TGoods>> listType(@RequestBody GoodQueryDTO goodQuery) {
+        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;
+
         // 类型匹配 todo
-        wrapper = type.isEmpty() ? wrapper : wrapper.in("");
+        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 函数
+            }
+        }
+        wrapper.eq("isDelete", 0);
+        return R.ok(goodsService.page(new PageInfo<>(goodQuery.getPageNumber(), goodQuery.getPageSize()), wrapper));
+    }
+    @PostMapping("/goodListStudy")
+    @ApiOperation(value = "商品列表查询", tags = {"学习端"})
+    public R<PageInfo<TGoods>> goodListStudy(@RequestBody GoodQueryDTO goodQuery) {
+        if (tokenService.getLoginUserStudy() == 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;
+
+        // 类型匹配 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 函数
+            }
+        }
         wrapper.eq("isDelete", 0);
         return R.ok(goodsService.page(new PageInfo<>(goodQuery.getPageNumber(), goodQuery.getPageSize()), wrapper));
     }
@@ -127,6 +163,7 @@
     @PostMapping("/addGoods")
     @ApiOperation(value = "添加", tags = {"后台-商品管理"})
     public R addGoods(@RequestBody TGoods dto) {
+        dto.setSurplus(dto.getTotal());
         goodsService.save(dto);
         return R.ok("添加成功");
     }
@@ -169,21 +206,68 @@
      * 兑换记录
      */
     @GetMapping("/exchangeRecord")
-    @ApiOperation(value = "兑换记录", tags = {"兑换记录"})
+    @ApiOperation(value = "学习端-兑换记录", tags = {"学习端-兑换记录"})
     public R<List<TOrder>> exchangeRecord() {
         return R.ok(orderService.lambdaQuery().eq(TOrder::getUserId, tokenService.getLoginUserStudy().getUserid())
                 .orderByDesc(TOrder::getCreateTime).list());
+    }
+    @GetMapping("/exchangeRecordParent")
+    @ApiOperation(value = "家长端-兑换记录", tags = {"家长端-兑换记录"})
+    public R<Page<TOrder>> exchangeRecordParent(Integer pageNumber,Integer pageSize) {
+        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);
+                    stringBuilder.append(byId1.getName()).append("|");
+                }
+                // 去除最后一个字符
+                stringBuilder.deleteCharAt(stringBuilder.length() - 1);
+                tOrder.setType(stringBuilder.toString());
+            }
+        }
+
+        return R.ok(page);
     }
 
     /**
      * 兑换记录
      */
     @GetMapping("/confirm")
-    @ApiOperation(value = "确认收货", tags = {"兑换记录"})
+    @ApiOperation(value = "确认收货", tags = {"家长端-兑换记录"})
     @ApiImplicitParams({
             @ApiImplicitParam(value = "订单id", name = "id", dataType = "String", required = true)
     })
     public R<Boolean> confirm(@RequestParam Integer id) {
+        if (tokenService.getLoginUser1() == null){
+            return R.tokenError("登录失效");
+        }
+        TOrder byId = orderService.getById(id);
+        byId.setState(3);
+        return R.ok(orderService.updateById(byId));
+    }
+    /**
+     * 兑换记录
+     */
+    @GetMapping("/confirmStudy")
+    @ApiOperation(value = "确认收货", tags = {"学习端-兑换记录"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "订单id", name = "id", dataType = "String", required = true)
+    })
+    public R<Boolean> confirmStudy(@RequestParam Integer id) {
+        if (tokenService.getLoginUserStudy() == null){
+            return R.tokenError("登录失效");
+        }
         TOrder byId = orderService.getById(id);
         byId.setState(3);
         return R.ok(orderService.updateById(byId));
@@ -192,9 +276,109 @@
     /**
      * 获取用户收货地址
      */
+    @GetMapping("/shopAddressParent")
+    @ApiOperation(value = "获取用户收货地址", tags = {"家长端-获取用户收货地址"})
+    public R<List<Recipient>> shopAddressParent() {
+        if (tokenService.getLoginUser1() == null){
+            return R.tokenError("登录失效");
+        }
+        return R.ok(recipientService.lambdaQuery().eq(Recipient::getUserId,
+                tokenService.getLoginUser1().getUserid()).list());
+    }
+    /**
+     * 设置默认地址
+     */
+    @GetMapping("/setDefault")
+    @ApiOperation(value = "设置默认地址", tags = {"家长端-设置默认地址"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "地址id", name = "id", dataType = "String", required = true)
+    })
+    public R setDefault(@RequestParam Integer id) {
+        if (tokenService.getLoginUser1() == null){
+            return R.tokenError("登录失效");
+        }
+        Recipient byId = recipientService.getById(id);
+        byId.setIsDefault(1);
+        recipientService.updateById(byId);
+        // 如果设置为默认地址 那么要将之前的默认地址取消掉
+        List<Recipient> userId = recipientService.list(new QueryWrapper<Recipient>()
+                .eq("userId", tokenService.getLoginUser1().getUserid())
+                .ne("id",byId.getId()));
+        for (Recipient recipient1 : userId) {
+            recipient1.setIsDefault(0);
+            recipientService.updateById(recipient1);
+        }
+        return R.ok();
+    }
+    /**
+     * 设置默认地址
+     */
+    @GetMapping("/setDefaultStudy")
+    @ApiOperation(value = "设置默认地址", tags = {"学习端-设置默认地址"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "地址id", name = "id", dataType = "String", required = true)
+    })
+    public R setDefaultStudy(@RequestParam Integer id) {
+        if (tokenService.getLoginUserStudy() == null){
+            return R.tokenError("登录失效");
+        }
+        Recipient byId = recipientService.getById(id);
+        byId.setIsDefault(1);
+        recipientService.updateById(byId);
+        // 如果设置为默认地址 那么要将之前的默认地址取消掉
+        List<Recipient> userId = recipientService.list(new QueryWrapper<Recipient>()
+                .eq("userId", tokenService.getLoginUser1().getUserid())
+                .ne("id",byId.getId()));
+        for (Recipient recipient1 : userId) {
+            recipient1.setIsDefault(0);
+            recipientService.updateById(recipient1);
+        }
+        return R.ok();
+    }
+
+    /**
+     * 根据地址id 获取详情
+     * @param id
+     * @return
+     */
+    @GetMapping("/getAddressById")
+    @ApiOperation(value = "获取地址详情", tags = {"家长端-获取地址详情"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "地址id", name = "id", dataType = "String", required = true)
+    })
+    public R<Recipient> getAddressById(@RequestParam Integer id) {
+        if (tokenService.getLoginUser1() == null){
+            return R.tokenError("登录失效");
+        }
+        Recipient byId = recipientService.getById(id);
+        return R.ok(byId);
+    }
+    /**
+     * 根据地址id 获取详情
+     * @param id
+     * @return
+     */
+    @GetMapping("/getAddressByIdStudy")
+    @ApiOperation(value = "获取地址详情", tags = {"学习端-获取地址详情"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "地址id", name = "id", dataType = "String", required = true)
+    })
+    public R<Recipient> getAddressByIdStudy(@RequestParam Integer id) {
+        if (tokenService.getLoginUserStudy() == null){
+            return R.tokenError("登录失效");
+        }
+        Recipient byId = recipientService.getById(id);
+        return R.ok(byId);
+    }
+    /**
+     * 获取用户收货地址
+     */
     @GetMapping("/shopAddress")
-    @ApiOperation(value = "获取用户收货地址", tags = {"获取用户收货地址"})
+    @ApiOperation(value = "获取用户收货地址", tags = {"学习端-获取用户收货地址"})
     public R<List<Recipient>> shopAddress() {
+        if (tokenService.getLoginUserStudy() == null){
+            return R.tokenError("登录失效");
+        }
         return R.ok(recipientService.lambdaQuery().eq(Recipient::getUserId,
                 tokenService.getLoginUserStudy().getUserid()).list());
     }
@@ -203,46 +387,141 @@
      * 新增收货地址/修改收货地址
      */
     @PostMapping("/addressSaveOrUpdate")
-    @ApiOperation(value = "新增收货地址/修改收货地址", tags = {"新增收货地址/修改收货地址"})
+    @ApiOperation(value = "学习端-新增收货地址/修改收货地址", tags = {"学习端-新增收货地址/修改收货地址"})
     public R<String> addressSave(@RequestBody Recipient recipient) {
         recipient.setUserId(tokenService.getLoginUserStudy().getUserid());
-        return R.ok(recipientService.addressSaveOrUpdate(recipient));
+        if (recipient.getIsDefault() == 1){
+            // 如果设置为默认地址 那么要将之前的默认地址取消掉
+            List<Recipient> userId = recipientService.list(new QueryWrapper<Recipient>()
+                    .eq("userId", tokenService.getLoginUser1().getUserid()));
+            for (Recipient recipient1 : userId) {
+                recipient1.setIsDefault(0);
+                recipientService.updateById(recipient1);
+            }
+        }
+        recipientService.addressSaveOrUpdate(recipient);
+        return R.ok();
+    }
+    /**
+     * 新增收货地址/修改收货地址
+     */
+    @PostMapping("/addressSaveOrUpdateParent")
+    @ApiOperation(value = "家长端-新增收货地址/修改收货地址", tags = {"家长端-新增收货地址/修改收货地址"})
+    public R<String> addressSaveOrUpdateParent(@RequestBody Recipient recipient) {
+        if (tokenService.getLoginUser1() == null){
+            return R.tokenError("登录失效!");
+        }
+        recipient.setUserId(tokenService.getLoginUser1().getUserid());
+        if (recipient.getId() != null){
+            if (recipient.getIsDefault() == 1){
+                // 如果设置为默认地址 那么要将之前的默认地址取消掉
+                List<Recipient> userId = recipientService.list(new QueryWrapper<Recipient>()
+                        .eq("userId", tokenService.getLoginUser1().getUserid()));
+                for (Recipient recipient1 : userId) {
+                    recipient1.setIsDefault(0);
+                    recipientService.updateById(recipient1);
+                }
+            }
+            recipientService.updateById(recipient);
+        }else{
+            if (recipient.getIsDefault() == 1){
+                // 如果设置为默认地址 那么要将之前的默认地址取消掉
+                List<Recipient> userId = recipientService.list(new QueryWrapper<Recipient>()
+                        .eq("userId", tokenService.getLoginUser1().getUserid()));
+                for (Recipient recipient1 : userId) {
+                    recipient1.setIsDefault(0);
+                    recipientService.updateById(recipient1);
+                }
+            }
+            recipientService.save(recipient);
+
+        }
+        return R.ok();
     }
 
     /**
      * 删除收货地址
      */
     @GetMapping("/addressDelete")
-    @ApiOperation(value = "删除收货地址", tags = {"删除收货地址"})
+    @ApiOperation(value = "学习端-删除收货地址", tags = {"学习端-删除收货地址"})
     @ApiImplicitParams({
             @ApiImplicitParam(value = "地址信息id", name = "id", dataType = "String", required = true)
     })
     public R<String> addressDelete(@RequestParam String id) {
         return R.ok(recipientService.removeById(id) ? "删除成功!" : "删除失败!");
     }
-
     /**
-     * 修改订单收货地址
-     *
-     * @param orderId 订单id
+     * 删除收货地址
      */
-    @GetMapping("/updateOrderAddress")
-    @ApiOperation(value = "修改订单收货地址", tags = {"修改订单收货地址"})
+    @GetMapping("/addressDeleteParent")
+    @ApiOperation(value = "家长端-删除收货地址", tags = {"家长端-删除收货地址"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "地址信息id", name = "id", dataType = "String", required = true)
+    })
+    public R<String> addressDeleteParent(@RequestParam Integer id) {
+        return R.ok(recipientService.removeById(id) ? "删除成功!" : "删除失败!");
+    }
+
+
+    @GetMapping("/getOrderAddressParent")
+    @ApiOperation(value = "获取修改订单收货地址", tags = {"家长端-获取修改订单收货地址"})
+    public R<List<Recipient>> getOrderAddressParent() {
+        if (tokenService.getLoginUser1() == null){
+            return R.tokenError("登录失效");
+        }
+        List<Recipient> userId = recipientService.list(new QueryWrapper<Recipient>()
+                .eq("userId", tokenService.getLoginUser1().getUserid()));
+
+        return R.ok(userId);
+    }
+    @GetMapping("/getOrderAddress")
+    @ApiOperation(value = "获取修改订单收货地址", tags = {"学习端-获取修改订单收货地址"})
+    public R<List<Recipient>> getOrderAddress() {
+        if (tokenService.getLoginUserStudy() == null){
+            return R.tokenError("登录失效");
+        }
+        List<Recipient> userId = recipientService.list(new QueryWrapper<Recipient>()
+                .eq("userId", tokenService.getLoginUserStudy().getUserid()));
+        return R.ok(userId);
+    }
+    @GetMapping("/updateOrderAddressParent")
+    @ApiOperation(value = "修改订单收货地址", tags = {"家长端-修改订单收货地址"})
     @ApiImplicitParams({
             @ApiImplicitParam(value = "订单id", name = "orderId", dataType = "String", required = true),
-            @ApiImplicitParam(value = "完整收货地址", name = "address", dataType = "String", required = true)
+            @ApiImplicitParam(value = "地址信息id", name = "recipientId", dataType = "String", required = true)
     })
-    public R<Boolean> updateOrderAddress(@RequestParam String orderId,
-                                                  @RequestParam String address) {
-        return R.ok(orderService.lambdaUpdate().set(TOrder::getConsigneeAddress, address)
-                .eq(TOrder::getId, orderId).eq(TOrder::getState, 1).update());
+    public R updateOrderAddressParent(@RequestParam Integer orderId,@RequestParam Integer recipientId) {
+        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("修改成功");
+    }
+    @GetMapping("/updateOrderAddress")
+    @ApiOperation(value = "修改订单收货地址", tags = {"学习端-修改订单收货地址"})
+    public R updateOrderAddress(@RequestParam Integer orderId,@RequestParam Integer recipientId) {
+        if (tokenService.getLoginUserStudy() == null){
+            return R.tokenError("登录失效");
+        }
+        Recipient userId = recipientService.getById(recipientId);
+        TOrder byId = orderService.getById(orderId);
+        byId.setConsigneeName(userId.getAddress());
+        byId.setConsigneePhone(userId.getRecipientPhone());
+        byId.setConsigneeAddress(userId.getAddress());
+        orderService.updateById(byId);
+        return R.ok();
     }
 
     /**
      * 收货地址省市区三级联动
      */
     @GetMapping("/addressTree")
-    @ApiOperation(value = "收货地址省市区三级联动", tags = {"收货地址省市区三级联动"})
+    @ApiOperation(value = "学习端-收货地址省市区三级联动", tags = {"学习端-收货地址省市区三级联动"})
     public R<List<Region>> addressTree() {
         return R.ok(regionService.addressTree());
     }
@@ -252,7 +531,7 @@
      * 远程调用
      */
     @GetMapping("/goodRecommend")
-    @ApiOperation(value = "可兑换商品推荐", tags = {"可兑换商品推荐"})
+    @ApiOperation(value = "学习端-可兑换商品推荐", tags = {"学习端-可兑换商品推荐"})
     public R<List<TGoodsVO>> goodRecommend() {
         return R.ok(goodsService.goodRecommend(tokenService.getLoginUserStudy().getUserid()));
     }
@@ -263,11 +542,33 @@
      * @param goodId 商品id
      */
     @GetMapping("/goodDetail")
-    @ApiOperation(value = "商品详情", tags = {"商品详情"})
+    @ApiOperation(value = "学习端-商品详情", tags = {"学习端-商城"})
     @ApiImplicitParams({
             @ApiImplicitParam(value = "商品id", name = "goodId", dataType = "String", required = true)
     })
     public R<GoodDetailVO> goodDetail(@RequestParam String goodId) {
+        // 商品详情
+        TGoods goods = goodsService.lambdaQuery().eq(TGoods::getId, goodId).one();
+        // 商品分类详情
+        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));
+    }
+    /**
+     * 商品详情
+     *
+     * @param goodId 商品id
+     */
+    @GetMapping("/goodDetailParent")
+    @ApiOperation(value = "商品详情", tags = {"家长端-商城"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "商品id", name = "goodId", dataType = "String", required = true)
+    })
+    public R<GoodDetailVO> goodDetailParent(@RequestParam String goodId) {
+        if (tokenService.getLoginUser1() == null){
+            return R.tokenError("登录失效");
+        }
         // 商品详情
         TGoods goods = goodsService.lambdaQuery().eq(TGoods::getId, goodId).one();
         // 商品分类详情
@@ -281,15 +582,72 @@
      * 商城-立即兑换
      */
     @GetMapping("/redeemNow")
-    @ApiOperation(value = "商城-立即兑换", tags = {"立即兑换"})
+    @ApiOperation(value = "商城立即兑换", tags = {"学习端-商城"})
     @ApiImplicitParams({
             @ApiImplicitParam(value = "商品id", name = "goodId", dataType = "String", required = true)
     })
     public R<GoodDetailVO> redeemNow(@RequestParam String goodId) {
+        if (tokenService.getLoginUserStudy() == null){
+            return R.tokenError("登录失效");
+        }
         Recipient recipient = recipientService.lambdaQuery()
                 .eq(Recipient::getUserId, tokenService.getLoginUserStudy().getUserid())
                 .eq(Recipient::getIsDefault, 1).one();
-        return R.ok(goodsService.redeemNow(goodId, recipient));
+        GoodDetailVO goodDetailVO = goodsService.redeemNow(goodId, recipient);
+        LocalDateTime currentDateTime = LocalDateTime.now();
+        // 格式化日期和时间信息
+        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyyMMddHHmmss");
+        String formattedDateTime = currentDateTime.format(formatter);
+        // 生成随机数,填充剩余位数
+        Random random = new Random();
+        StringBuilder randomPart = new StringBuilder();
+        for (int i = 0; i < 3; i++) {
+            randomPart.append((char) (random.nextInt(26) + 'A')); // 大写字母
+        }
+        // 组合订单编号
+        String orderNumber = formattedDateTime + randomPart.toString();
+        goodDetailVO.setOrderNumber(orderNumber);
+        return R.ok(goodDetailVO);
+    }
+    /**
+     * 商城-立即兑换
+     */
+    @GetMapping("/redeemNowParent")
+    @ApiOperation(value = "商城立即兑换", tags = {"家长端-商城"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "商品id", name = "goodId", dataType = "String", required = true)
+    })
+    public R<GoodDetailVO> redeemNowParent(@RequestParam String goodId) {
+        if (tokenService.getLoginUser1() == null){
+            return R.tokenError("登录失效");
+        }
+        Recipient recipient = recipientService.lambdaQuery()
+                .eq(Recipient::getUserId, tokenService.getLoginUser1().getUserid())
+                .eq(Recipient::getIsDefault, 1).one();
+        if (recipient == null){
+            // 随便取一条地址数据
+            List<Recipient> list = recipientService.lambdaQuery()
+                    .eq(Recipient::getUserId, tokenService.getLoginUser1().getUserid())
+                    .eq(Recipient::getIsDefault, 1).list();
+            if (!list.isEmpty()){
+                recipient = list.get(0);
+            }
+        }
+        GoodDetailVO goodDetailVO = goodsService.redeemNow(goodId, recipient);
+        LocalDateTime currentDateTime = LocalDateTime.now();
+        // 格式化日期和时间信息
+        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyyMMddHHmmss");
+        String formattedDateTime = currentDateTime.format(formatter);
+        // 生成随机数,填充剩余位数
+        Random random = new Random();
+        StringBuilder randomPart = new StringBuilder();
+        for (int i = 0; i < 3; i++) {
+            randomPart.append((char) (random.nextInt(26) + 'A')); // 大写字母
+        }
+        // 组合订单编号
+        String orderNumber = formattedDateTime + randomPart.toString();
+        goodDetailVO.setOrderNumber(orderNumber);
+        return R.ok(goodDetailVO);
     }
 
 
@@ -299,11 +657,19 @@
      * @param goodExchange 商品信息
      */
     @PostMapping("/goodExchange")
-    @ApiOperation(value = "商品兑换-确认", tags = {"商品兑换-确认"})
-    public R<Boolean> goodExchange(@RequestBody GoodExchangeDTO goodExchange) {
-        Recipient recipient = recipientService.getById(goodExchange.getRecipientId());
-        return R.ok(goodsService.goodExchange(goodExchange, recipient));
+    @ApiOperation(value = "家长端-商品兑换确认", tags = {"家长端-商品兑换确认"})
+    public R goodExchange(@RequestBody GoodExchangeDTO goodExchange) {
+        Recipient recipient = recipientService.getById(Integer.valueOf(goodExchange.getRecipientId()));
+        return goodsService.goodExchange1(goodExchange, recipient);
     }
+    @PostMapping("/goodExchangeStudy")
+    @ApiOperation(value = "学习端-商品兑换确认", tags = {"学习端-商品兑换确认"})
+    public R goodExchangeStudy(@RequestBody GoodExchangeDTO goodExchange) {
+        Recipient recipient = recipientService.getById(goodExchange.getRecipientId());
+        return goodsService.goodExchange(goodExchange, recipient);
+    }
+
+
     @Autowired
     private StudyClient studyClient;
     @PostMapping("/getOrderInfo/{id}")

--
Gitblit v1.7.1