From 41b60f3df5f3054aad44307c13a26b14f3b32ac0 Mon Sep 17 00:00:00 2001
From: nickchange <126672920+nickchange@users.noreply.github.com>
Date: 星期二, 21 十一月 2023 09:46:03 +0800
Subject: [PATCH] 11.21

---
 cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java |  150 ++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 144 insertions(+), 6 deletions(-)

diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java b/cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java
index cfb00ef..74ff933 100644
--- a/cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java
+++ b/cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java
@@ -1,10 +1,15 @@
 package com.dsh.activity.controller;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.dsh.activity.entity.Coupon;
+import com.dsh.activity.entity.CouponStore;
 import com.dsh.activity.entity.UserCoupon;
 import com.dsh.activity.feignclient.model.CouponStuAvailableVo;
+import com.dsh.activity.feignclient.model.QueryUserCouponByIdAndUserId;
 import com.dsh.activity.model.CouponListVo;
+import com.dsh.activity.model.SendCouponReq;
+import com.dsh.activity.service.CouponStoreService;
 import com.dsh.activity.service.ICouponService;
 import com.dsh.activity.service.UserCouponService;
 import com.dsh.activity.util.ResultUtil;
@@ -18,6 +23,7 @@
 
 import java.text.SimpleDateFormat;
 import java.util.ArrayList;
+import java.util.Date;
 import java.util.List;
 import java.util.Map;
 import java.util.stream.Collectors;
@@ -29,9 +35,6 @@
 public class UserCouponController {
 
     @Autowired
-    private UserCouponService uconService;
-
-    @Autowired
     private ICouponService cService;
 
     @Autowired
@@ -39,6 +42,10 @@
 
     @Autowired
     private UserCouponService userCouponService;
+
+
+    @Autowired
+    private CouponStoreService csServie;
 
 
 
@@ -50,7 +57,7 @@
 
         List<CouponStuAvailableVo> availableVos = new ArrayList<>();
 
-        List<UserCoupon> list = uconService.list(new QueryWrapper<UserCoupon>()
+        List<UserCoupon> list = userCouponService.list(new QueryWrapper<UserCoupon>()
                 .eq("userId", appUserId)
                 .eq("status",1));
         if (list.size() > 0){
@@ -84,6 +91,21 @@
         return availableVos;
     }
 
+    @PostMapping("/base/userConpon/queryCouponRules")
+    public Map<String,Object> getCouponRules(@RequestBody Integer couponId){
+        return cService.queryConponRuleOfJson(couponId);
+    }
+
+    @ResponseBody
+    @PostMapping("/base/userConpon/getCoupons")
+    public List<Coupon> getCoupons(@RequestBody String couponIds){
+        ArrayList<Integer> integers = new ArrayList<>();
+        for (String s : couponIds.split(",")) {
+            Integer integer = Integer.valueOf(s);
+            integers.add(integer);
+        }
+        return cService.list(new LambdaQueryWrapper<Coupon>().in(Coupon::getId,integers));
+    }
 
 
     @ResponseBody
@@ -111,6 +133,35 @@
     }
 
 
+
+
+    @ResponseBody
+    @PostMapping("/api/coupon/querySiteCouponList")
+    @ApiOperation(value = "获取场地支付页面可用优惠券列表", tags = {"APP-预约场地", ""})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "场地id", name = "siteId", dataType = "int", required = true),
+            @ApiImplicitParam(value = "支付金额", name = "price", dataType = "double", required = true),
+            @ApiImplicitParam(value = "经度", name = "lon", dataType = "string", required = true),
+            @ApiImplicitParam(value = "纬度", name = "lat", dataType = "string", required = true),
+            @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
+    })
+    public ResultUtil<List<CouponListVo>> querySiteCouponList(Integer siteId, Double price, String lon, String lat){
+        try {
+            Integer uid = tokenUtil.getUserIdFormRedis();
+            if(null == uid){
+                return ResultUtil.tokenErr();
+            }
+            List<CouponListVo> listVos = userCouponService.querySiteCouponList(uid, siteId, price, lon, lat);
+            return ResultUtil.success(listVos);
+        }catch (Exception e){
+            e.printStackTrace();
+            return ResultUtil.runErr();
+        }
+    }
+
+
+
+
     /**
      * 根据id获取用户优惠券数据
      * @param id
@@ -118,13 +169,100 @@
      */
     @ResponseBody
     @PostMapping("/userCoupon/queryUserCouponById")
-    public UserCoupon queryUserCouponById(@RequestBody Long id){
+    public UserCoupon queryUserCouponById(@RequestBody QueryUserCouponByIdAndUserId userCouponByIdAndUserId){
         try {
-            UserCoupon userCoupon = userCouponService.getById(id);
+                UserCoupon userCoupon = userCouponService.getOne(new LambdaQueryWrapper<UserCoupon>().eq(UserCoupon::getId,userCouponByIdAndUserId.getId()).eq(UserCoupon::getUserId,userCouponByIdAndUserId.getUserId()));
             return userCoupon;
         }catch (Exception e){
             e.printStackTrace();
             return null;
         }
     }
+    @Autowired
+    private ICouponService couponService;
+    @PostMapping("/userCoupon/sendUserCoupon")
+    public void sendUserCoupon(@RequestBody SendCouponReq sendCouponReq){
+        try {
+            String couponIds = sendCouponReq.getCouponIds();
+            for (String s : couponIds.split(",")) {
+                Coupon coupon = couponService.getById(s);
+                if (new Date().before(coupon.getStartTime())&&new Date().after(coupon.getEndTime())){
+                    continue;
+                }
+                //查询该优惠卷的数量够不够
+                List<Integer> queryIds = new ArrayList<>();
+                queryIds.add(coupon.getId());
+                int counts = userCouponService.count(new QueryWrapper<UserCoupon>().eq("couponId", s));
+                if (coupon.getQuantityIssued()<=counts){
+                    continue;
+                }
+                
+                UserCoupon userCoupon = new UserCoupon();
+                userCoupon.setCouponId(Integer.valueOf(s));
+                userCoupon.setUserId(sendCouponReq.getUserId());
+                userCoupon.setStatus(1);
+                userCoupon.setInsertTime(new Date());
+                userCouponService.save(userCoupon);
+            }
+        }catch (Exception e){
+            e.printStackTrace();
+        }
+    }
+
+
+    /**
+     * 修改优惠券数据
+     * @param userCoupon
+     */
+    @ResponseBody
+    @PostMapping("/userCoupon/updateUserCoupon")
+    public void updateUserCoupon(@RequestBody UserCoupon userCoupon){
+        try {
+            userCoupon.setUserId(null);
+            userCouponService.updateById(userCoupon);
+        }catch (Exception e){
+            e.printStackTrace();
+        }
+    }
+
+    
+    
+    @ResponseBody
+    @PostMapping("/userCoupon/queryCouponOfStore")
+    public List<Integer> getCouponStoreIds(@RequestBody Integer couponId){
+        try {
+            List<Integer> storeIds = new ArrayList<>();
+            List<CouponStore> list = csServie.list(new QueryWrapper<CouponStore>()
+                    .eq("couponId",couponId));
+            if (list.size() > 0 ){
+                storeIds = list.stream().map(CouponStore::getStoreId).collect(Collectors.toList());
+            }
+            if(storeIds.size()==0){
+                storeIds.add(-1);
+            }
+            return storeIds;
+        }catch (Exception e){
+            e.printStackTrace();
+            return null;
+        }
+    }
+
+
+    @ResponseBody
+    @PostMapping("/userCoupon/queryCounts")
+    public Integer queryCounts(@RequestBody List<Integer> queryIds){
+     return    userCouponService.count(new QueryWrapper<UserCoupon>().eq("couponId",queryIds.get(0)));
+
+
+    }
+
+
+    @ResponseBody
+    @PostMapping("/userCoupon/queryCounts1")
+    public Integer queryCounts1(@RequestBody List<Integer> queryIds){
+        return    userCouponService.count(new QueryWrapper<UserCoupon>().eq("couponId",queryIds.get(0)).eq("userId",queryIds.get(1)));
+
+
+    }
+    
 }

--
Gitblit v1.7.1