From acad524bfb7f376c09ff8e6600fab207780156e1 Mon Sep 17 00:00:00 2001
From: 44323 <443237572@qq.com>
Date: 星期四, 23 十一月 2023 18:46:05 +0800
Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/PlayPai

---
 cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java |  854 +++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 805 insertions(+), 49 deletions(-)

diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java b/cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java
index 20ff43d..3d82719 100644
--- a/cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java
+++ b/cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java
@@ -9,9 +9,12 @@
 import com.dsh.activity.feignclient.course.model.CoursePackage;
 import com.dsh.activity.feignclient.course.model.CoursePackagePaymentConfig;
 import com.dsh.activity.feignclient.model.*;
+import com.dsh.activity.feignclient.other.OperatorClient;
 import com.dsh.activity.feignclient.other.StoreClient;
 import com.dsh.activity.feignclient.other.model.Store;
 import com.dsh.activity.feignclient.other.model.StoreDetailOfCourse;
+import com.dsh.activity.feignclient.other.model.StoreInfoDto;
+import com.dsh.activity.feignclient.other.model.TOperatorCity;
 import com.dsh.activity.model.CoachChangeStateVO;
 import com.dsh.activity.model.PointMerchandiseIncomeVo;
 import com.dsh.activity.model.PointMerchandiseVo;
@@ -25,6 +28,7 @@
 import com.dsh.activity.util.StrUtils;
 import com.dsh.activity.util.TokenUtil;
 import com.dsh.activity.util.ToolUtil;
+import io.swagger.models.auth.In;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
@@ -89,12 +93,31 @@
      * 门票上下架 state=1 上架 state=2 下架
      */
     @RequestMapping("/base/pointMerchars/changeState")
-    public Object changeState(@RequestBody CoachChangeStateVO dto){
-        return pmdsService.changeState(dto);
+    public void changeState(@RequestBody CoachChangeStateVO dto){
+
+
+         pmdsService.changeState(dto);
+    }
+    /**
+     * 根据id查询
+     */
+
+    @RequestMapping("/base/pointMerchars/getById")
+    @ResponseBody
+    public PointsMerchandise getById(@RequestBody Integer id){
+        return pmdsService.getById(id);
     }
     /**
      * 门票核销
      */
+    @RequestMapping("/base/course/changeState")
+    @ResponseBody
+    public Object changeState(@RequestBody CourseChangeStateDTO dto){
+        return userPointsMerchandiseService.changeState(dto);
+    }
+
+
+
     @RequestMapping("/base/pointMerchars/writeOff")
     public Object writeOff(@RequestBody WriteOffDTO dto){
         UserPointsMerchandise byId = userPointsMerchandiseService.getById(dto.getId());
@@ -105,10 +128,96 @@
         byId.setVerificationUserId(dto.getVerificationUserId());
         return userPointsMerchandiseService.updateById(byId);
     }
+    @Autowired
+    private OperatorClient operatorClient;
+    @Resource
+    private CouponCityService cityService;
     @ResponseBody
     @PostMapping("/base/pointMerchars/ticketList")
     public List<Map<String,Object>> ticketList(@RequestBody IntegralGoodsOfSearch ofSearch){
-        List<Map<String, Object>> result = pmdsService.ticketList(ofSearch);
+        List<Map<String, Object>> result1 = pmdsService.ticketList(ofSearch);
+        List<Map<String, Object>> result = new ArrayList<>();
+        if(ofSearch.getObjType()==3){
+            for (Map<String, Object> map : result1) {
+                List<PointsMerchandiseStore> id = pmdstoService.list(new LambdaQueryWrapper<PointsMerchandiseStore>().eq(PointsMerchandiseStore::getPointsMerchandiseId, map.get("id")));
+                List<Integer> collect = id.stream().map(PointsMerchandiseStore::getStoreId).collect(Collectors.toList());
+                if(collect.size()==0){
+                    collect.add(-1);
+                }
+                if(collect.contains(ofSearch.getObjId())){
+                    if(id.size()>1){
+                        map.put("size",1);
+                    }else {
+                        map.put("size",0);
+                    }
+                    result.add(map);
+                }
+            }
+        }else if(ofSearch.getObjType()==2){
+            for (Map<String, Object> map : result1) {
+                // 拿到当前运营商下的门店的门票
+                List<PointsMerchandiseStore> id = pmdstoService.list(new QueryWrapper<PointsMerchandiseStore>().in("storeId",ofSearch.getStoreIds()));
+                // 拿到积分商品id集合
+                List<Integer> collect = id.stream().map(PointsMerchandiseStore::getPointsMerchandiseId).collect(Collectors.toList());
+                if(collect.size()==0){
+                    collect.add(-1);
+                }
+                Integer temp =(Integer)map.get("id");
+                if (collect.contains(temp)){
+                    if(id.size()>1){
+                        map.put("size",1);
+                    }else {
+                        map.put("size",0);
+                    }
+                    result.add(map);
+                }
+                if (Integer.parseInt(String.valueOf(map.get("useScope"))) == 1){
+                    result.add(map);
+                }
+                if (Integer.parseInt(String.valueOf(map.get("useScope"))) == 2){
+                    // 获取到优惠券id 查询这个优惠券指定了哪些城市
+                    Integer id1 = Integer.parseInt(String.valueOf(map.get("id")));
+                    // 获取到运营商管理的省和市
+                    List<TOperatorCity> cityByOperatorId = operatorClient.getCityByOperatorId(ofSearch.getObjId());
+                    // 拿到运营商市的code集合
+                    List<String> collect1 = cityByOperatorId.stream().filter(t -> t.getPid() != 0)
+                            .map(tOperatorCity -> Integer.toString(tOperatorCity.getCode()))
+                            .collect(Collectors.toList());
+                    List<CouponCity> couponId = cityService.list(new QueryWrapper<CouponCity>().eq("couponId", id1));
+                    // 先判断优惠券管理的市  运营商是否有
+                    List<String> collect3 = couponId.stream().map(CouponCity::getCityCode)
+                            .collect(Collectors.toList());
+                    // 优惠券指定的省
+                    List<String> collect4 = couponId.stream().map(CouponCity::getCityCode)
+                            .collect(Collectors.toList());
+                    if (!Collections.disjoint(collect3, collect4)){
+                        result.add(map);
+                    }else{
+                        // 如果没有交集 那么还需要判断运营商是否管理了整个省
+
+
+                    }
+                }
+                if (Integer.parseInt(String.valueOf(map.get("useScope"))) == 3){
+                    // 获取到优惠券id 查询这个优惠券指定了哪些门店
+                    Integer id3 = Integer.parseInt(String.valueOf(map.get("id")));
+                    // 当前运营商管理的门店ids
+                    List<Integer> storeIds = ofSearch.getStoreIds();
+                    // 优惠券指定的门店
+                    List<Integer> collect5 = cstoreService.list(new QueryWrapper<CouponStore>().eq("couponId",id3)
+                            .in("storeId", storeIds)).stream().map(CouponStore::getStoreId)
+                            .collect(Collectors.toList());
+                    // 判断两个集合是否相交
+                    // 比较两个集合中是否有相同的元素;当两个集合中没有相同元素时返回true,
+                    // 当有相同元素时返回false。
+                    if (!Collections.disjoint(collect5, storeIds)){
+                        result.add(map);
+                    }
+                }
+            }
+        } else {
+            result=result1;
+        }
         if (result.size() > 0){
             for (Map<String, Object> stringObjectMap : result) {
                 Integer o = (Integer) stringObjectMap.get("id");
@@ -143,10 +252,11 @@
                 String endTime = (String) stringObjectMap.get("endTime");
                 stringObjectMap.put("timeValue",startTime + "至"+endTime);
                 int count1 = upmseService.count(new LambdaQueryWrapper<UserPointsMerchandise>()
-                        .eq(UserPointsMerchandise::getPointsMerchandiseId, o));
-                int count2 = upmseService.count(new LambdaQueryWrapper<UserPointsMerchandise>()
                         .eq(UserPointsMerchandise::getPointsMerchandiseId, o)
                         .eq(UserPointsMerchandise::getStatus,2));
+                int count2 = upmseService.count(new LambdaQueryWrapper<UserPointsMerchandise>()
+                        .eq(UserPointsMerchandise::getPointsMerchandiseId, o)
+                        );
                 stringObjectMap.put("hasExchangeQty",count1);
                 stringObjectMap.put("hasPickQty",count2);
 
@@ -171,31 +281,66 @@
 
     @ResponseBody
     @PostMapping("/base/pointMerchars/convertGoods")
-    public List<IntegralCommodity> getConvertibleGoods(){
+    public List<IntegralCommodity> getConvertibleGoods(@RequestBody Location location) throws Exception {
         List<IntegralCommodity> commodity = new ArrayList<>();
-        List<PointsMerchandise> merchandises = pmdsService.list(new QueryWrapper<PointsMerchandise>()
-                .eq("state",1)
-                .eq("shelves",1)
-                .gt("endTime",new Date()));
-        if (merchandises.size() > 0){
-            for (PointsMerchandise merchandise : merchandises) {
-                IntegralCommodity integralCommodity = new IntegralCommodity();
-                integralCommodity.setCommodityId(merchandise.getId());
-                integralCommodity.setCommodityImg(merchandise.getCover());
-                integralCommodity.setCommodityName(merchandise.getName());
-                integralCommodity.setCommodityPrice(merchandise.getPrice());
-                integralCommodity.setGoodsType(merchandise.getType());
-                commodity.add(integralCommodity);
-            }
+
+        Map<String, String> geocode = gdMapGeocodingUtil.geocode(location.getLon(), location.getLat());
+        String provinceCode = geocode.get("provinceCode");
+        String cityCode = geocode.get("cityCode");
+
+
+        List<PointsMerchandiseCity> cityCode1 = pmdsCityService.list(new QueryWrapper<PointsMerchandiseCity>().eq("cityCode", cityCode));
+        List<Integer> cIds = new ArrayList<>();
+        for (PointsMerchandiseCity pointsMerchandiseCity : cityCode1) {
+            cIds.add(pointsMerchandiseCity.getPointsMerchandiseId());
         }
+
+//        if (cIds.size()>0) {
+
+            List<PointsMerchandise> merchandises = pmdsService.list(new QueryWrapper<PointsMerchandise>()
+                    .eq("state", 1)
+                    .eq("shelves", 1)
+                    .gt("endTime", new Date()).last("ORDER BY sort desc,insertTime desc"));
+            if (merchandises.size() > 0){
+                for (PointsMerchandise merchandise : merchandises) {
+                    IntegralCommodity integralCommodity = new IntegralCommodity();
+                    integralCommodity.setCommodityId(merchandise.getId());
+                    integralCommodity.setCommodityImg(merchandise.getCover());
+                    integralCommodity.setCommodityName(merchandise.getName());
+                    integralCommodity.setCommodityPrice(merchandise.getPrice());
+                    integralCommodity.setGoodsType(merchandise.getType());
+                    integralCommodity.setSort(merchandise.getSort());
+                    commodity.add(integralCommodity);
+                }
+//            }
+        }
+
         System.out.println(commodity);
         return commodity;
     }
-
+@Resource
+private CoursePackageClient coursePackageClient;
+    @Autowired
+     private PointsMerchandiseService pointsMerchandiseService;
 
     @ResponseBody
     @PostMapping("/base/pointMerchars/getCommoditys")
     public PointMerchandiseVo getVicinityGoods(@RequestBody CommodityRequest request){
+//        if (request.getShopId()!=null){
+//            List<CoursePackage> coursePackages = coursePackageClient.queryByStoreId(request.getShopId());
+//            List<Integer> coursIds = new ArrayList<>();
+//            for (CoursePackage coursePackage : coursePackages) {
+//                coursIds.add(coursePackage.getId());
+//            }
+//            List<PointsMerchandise> points = pointsMerchandiseService.list(new QueryWrapper<PointsMerchandise>().eq("state",1).eq("shelves",1).in("coursePackageId", coursIds));
+//            PointMerchandiseVo pointMerchandiseVo = new PointMerchandiseVo();
+//            pointMerchandiseVo.setMerchandises(points);
+//            return pointMerchandiseVo;
+//
+//        }
+
+
+
         PointMerchandiseVo pointMerchandiseVo = new PointMerchandiseVo();
         List<PointsMerchandise> list =  new ArrayList<>();
         String provinceCode = "";
@@ -233,14 +378,13 @@
                 .eq("pointsMerchandiseId",goodId));
     }
 
-
-    @PostMapping("/base/pointMerchars/getGoodDetails")
-    public ProductDetailsVo getGoodDetailsWithId(@RequestBody ProductDetailRequest detailRequest){
+    @PostMapping("/base/pointMerchars/getGoodDetailsWithIdOne")
+    public ProductDetailsVo getGoodDetailsWithIdOne(@RequestBody Integer id){
         SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
         ProductDetailsVo detailsVo = new ProductDetailsVo();
-        PointsMerchandise merchandise = pmdsService.getById(detailRequest.getGoodId());
+        PointsMerchandise merchandise = pmdsService.getById(id);
         detailsVo.setCardType(merchandise.getCardType());
-        switch (detailRequest.getGoodsType()){
+        switch (merchandise.getType()){
             case 2:
 //                课包
                 CoursePackage coursePackage = cpClient.queryCoursePackageById(merchandise.getCoursePackageId());
@@ -250,6 +394,204 @@
                 list1.add(coursePackage.getCoverDrawing());
                 list1.addAll(Arrays.asList(StrUtils.splitStr2StrArr(coursePackage.getDetailDrawing(), ",")));
                 detailsVo.setPics(list1);
+                Collections.sort(detailsVo.getPics(), (s1, s2) -> {
+                    if (s1.equals(coursePackage.getCoverDrawing())) {
+                        return -1; // s1排在前面
+                    } else if (s2.equals(coursePackage.getCoverDrawing())) {
+                        return 1; // s2排在前面
+                    } else {
+                        return 0; // 保持原顺序
+                    }
+                });
+                detailsVo.setGoodName(coursePackage.getName());
+                detailsVo.setBelongsScope(merchandise.getUserPopulation());
+                int coursePackageNums = upmseService.count(new QueryWrapper<UserPointsMerchandise>()
+                        .eq("pointsMerchandiseId",merchandise.getId() ));
+                detailsVo.setRedeemedNum(coursePackageNums);
+                detailsVo.setResidueNum(Math.max(merchandise.getQuantityIssued() - coursePackageNums, 0));
+                detailsVo.setPerLimit(merchandise.getPickUpQuantity());
+                if (merchandise.getRedemptionMethod() == 1){
+                    detailsVo.setExchangeType(1);
+                    detailsVo.setIntegral(merchandise.getIntegral());
+                }else {
+                    detailsVo.setExchangeType(2);
+                    detailsVo.setIntegral(merchandise.getIntegral());
+                    detailsVo.setCash(merchandise.getCash());
+                }
+                detailsVo.setCost(merchandise.getPrice());
+                if (merchandise.getUseScope() == 1){
+                    detailsVo.setExchangeAddrType(1);
+                    detailsVo.setBelongs("全国通用");
+                }else if (merchandise.getUseScope() == 2){
+                    detailsVo.setExchangeAddrType(2);
+                    detailsVo.setBelongs(merchandise.getProvince()+"|"+merchandise.getCity() + "用户可用");
+                }else {
+                    detailsVo.setExchangeAddrType(3);
+                    List<PointsMerchandiseStore> list = pmdstoService.list(new QueryWrapper<PointsMerchandiseStore>()
+                            .eq("pointsMerchandiseId",merchandise.getId() ));
+                    PointsMerchandiseStore pointsMerchandiseStore = list.get(0);
+                    StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(pointsMerchandiseStore.getStoreId());
+                    detailsVo.setBelongs(courseOfStore.getStoreName()+"可用");
+                }
+                List<CoursePackagePaymentConfig> courseConfigList = cpcfigClient.getCourseConfigList(coursePackage.getId());
+
+                for (CoursePackagePaymentConfig coursePackagePaymentConfig : courseConfigList) {
+                    if (Objects.equals(coursePackagePaymentConfig.getId(), merchandise.getCoursePackageConfigId())){
+                        detailsVo.setCourseHours(coursePackagePaymentConfig.getClassHours());
+                        break;
+                    }
+                }
+                detailsVo.setStartTime(format.format(merchandise.getStartTime()));
+                detailsVo.setEndTime(format.format(merchandise.getEndTime()));
+
+                detailsVo.setContents(merchandise.getRedemptionInstructions());
+                detailsVo.setGoodType(merchandise.getType());
+
+                break;
+            case 1:
+            case 3:
+
+                detailsVo.setGoodId(merchandise.getId());
+                List<String> list2 = new ArrayList<>();
+                String cover = merchandise.getCover();
+                list2.addAll(Arrays.asList(StrUtils.splitStr2StrArr(merchandise.getProductImages(), ",")));
+                detailsVo.setPics(list2);
+                Collections.sort(detailsVo.getPics(), (s1, s2) -> {
+                    if (s1.equals(merchandise.getCover())) {
+                        return -1; // s1排在前面
+                    } else if (s2.equals(merchandise.getCover())) {
+                        return 1; // s2排在前面
+                    } else {
+                        return 0; // 保持原顺序
+                    }
+                });
+                detailsVo.setPics(list2);
+                detailsVo.setGoodName(merchandise.getName());
+                detailsVo.setBelongsScope(merchandise.getUserPopulation());
+                int count = upmseService.count(new QueryWrapper<UserPointsMerchandise>()
+                        .eq("pointsMerchandiseId",merchandise.getId() ));
+                detailsVo.setRedeemedNum(count);
+                detailsVo.setResidueNum(Math.max(merchandise.getQuantityIssued() - count, 0));
+                detailsVo.setPerLimit(merchandise.getPickUpQuantity());
+                detailsVo.setExchangeType(merchandise.getRedemptionMethod());
+                if (merchandise.getRedemptionMethod() == 1){
+                    detailsVo.setIntegral(merchandise.getIntegral());
+                }else {
+                    detailsVo.setIntegral(merchandise.getIntegral());
+                    detailsVo.setCash(merchandise.getCash());
+                }
+                detailsVo.setCost(merchandise.getPrice());
+                if (merchandise.getUseScope() == 1){
+                    detailsVo.setExchangeAddrType(1);
+                    detailsVo.setBelongs("全国通用");
+                }else if (merchandise.getUseScope() == 2){
+                    detailsVo.setExchangeAddrType(2);
+                    detailsVo.setBelongs(merchandise.getProvince()+"|"+merchandise.getCity() + "用户可用");
+                }else {
+                    detailsVo.setExchangeAddrType(3);
+                    List<PointsMerchandiseStore> list = pmdstoService.list(new QueryWrapper<PointsMerchandiseStore>()
+                            .eq("pointsMerchandiseId",merchandise.getId() ));
+                    PointsMerchandiseStore pointsMerchandiseStore = list.get(0);
+                    StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(pointsMerchandiseStore.getStoreId());
+                    detailsVo.setBelongs(courseOfStore.getStoreName()+"可用");
+                }
+
+                detailsVo.setStartTime(format.format(merchandise.getStartTime()));
+                detailsVo.setEndTime(format.format(merchandise.getEndTime()));
+
+                detailsVo.setContents(merchandise.getRedemptionInstructions());
+                detailsVo.setGoodType(merchandise.getType());
+                break;
+            case 4:
+//                优惠券
+                Coupon coupon = iCouponService.getById(id);
+                detailsVo.setGoodId(coupon.getId());
+                List<String> list3 = new ArrayList<>();
+                list3.add(ToolUtil.isEmpty(coupon.getCover()) ? "" : coupon.getCover());
+                if (ToolUtil.isNotEmpty(coupon.getProductImages())){
+                    list3.addAll(Arrays.asList(StrUtils.splitStr2StrArr(coupon.getProductImages(), ",")));
+                }
+                detailsVo.setPics(list3);
+                Collections.sort(detailsVo.getPics(), (s1, s2) -> {
+                    if (s1.equals(coupon.getCover())) {
+                        return -1; // s1排在前面
+                    } else if (s2.equals(coupon.getCover())) {
+                        return 1; // s2排在前面
+                    } else {
+                        return 0; // 保持原顺序
+                    }
+                });
+                detailsVo.setGoodName(coupon.getName());
+                detailsVo.setBelongsScope(coupon.getUserPopulation());
+                int couponNums = upmseService.count(new QueryWrapper<UserPointsMerchandise>()
+                        .eq("pointsMerchandiseId",merchandise.getId() ));
+                detailsVo.setRedeemedNum(couponNums);
+                detailsVo.setResidueNum(Math.max(coupon.getQuantityIssued() - couponNums, 0));
+                detailsVo.setPerLimit(coupon.getPickUpQuantity());
+                detailsVo.setExchangeType(coupon.getRedemptionMethod());
+                if (coupon.getRedemptionMethod() == 1){
+                    detailsVo.setIntegral(coupon.getIntegral().intValue());
+                }else {
+                    detailsVo.setIntegral(coupon.getIntegral().intValue());
+                    detailsVo.setCash(coupon.getCash());
+                }
+                if (coupon.getUseScope() == 1){
+                    detailsVo.setExchangeAddrType(1);
+                    detailsVo.setBelongs("全国通用");
+                }else if (coupon.getUseScope() == 2){
+                    detailsVo.setExchangeAddrType(2);
+                    List<CouponCity> list = ccityService.list(new LambdaQueryWrapper<CouponCity>()
+                            .eq(CouponCity::getCouponId, coupon.getId()));
+                    if (list.size() > 0){
+                        detailsVo.setBelongs(list.get(0).getProvince()+"|"+list.get(0).getCity() + "用户可用");
+                    }
+                }else {
+                    detailsVo.setExchangeAddrType(3);
+                    List<CouponStore> list = cstoreService.list(new QueryWrapper<CouponStore>()
+                            .eq("couponId",coupon.getId() ));
+                    StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(list.get(0).getStoreId());
+                    detailsVo.setBelongs(courseOfStore.getStoreName()+"可用");
+                }
+                detailsVo.setStartTime(format.format(coupon.getStartTime()));
+                detailsVo.setEndTime(format.format(coupon.getEndTime()));
+
+                detailsVo.setContents(coupon.getIllustrate());
+                detailsVo.setGoodType(4);
+                break;
+            default:
+                break;
+        }
+        return detailsVo;
+    }
+
+
+    @Autowired
+    private UserCouponService userCouponService;
+    @PostMapping("/base/pointMerchars/getGoodDetails")
+    public ProductDetailsVo getGoodDetailsWithId(@RequestBody ProductDetailRequest detailRequest){
+        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
+        ProductDetailsVo detailsVo = new ProductDetailsVo();
+        PointsMerchandise merchandise = pmdsService.getById(detailRequest.getGoodId());
+
+
+
+        if (merchandise!=null) {
+            detailsVo.setCardType(merchandise.getCardType());
+        }
+        switch (detailRequest.getGoodsType()){
+            case 2:
+//                课包
+                CoursePackage coursePackage = cpClient.queryCoursePackageById(merchandise.getCoursePackageId());
+
+//                detailsVo.setGoodId(coursePackage.getId());
+                detailsVo.setGoodId(merchandise.getId());
+//                List<String> list1 = new ArrayList<>();
+//                list1.add(coursePackage.getCoverDrawing());
+//                list1.addAll(Arrays.asList(StrUtils.splitStr2StrArr(coursePackage.getDetailDrawing(), ",")));
+
+                String productImages = merchandise.getProductImages();
+                String[] list1 = productImages.split(",");
+                detailsVo.setPics(Arrays.asList(list1));
                 Collections.sort(detailsVo.getPics(), (s1, s2) -> {
                     if (s1.equals(coursePackage.getCoverDrawing())) {
                         return -1; // s1排在前面
@@ -379,10 +721,17 @@
                 });
                 detailsVo.setGoodName(coupon.getName());
                 detailsVo.setBelongsScope(coupon.getUserPopulation());
-                int couponNums = upmseService.count(new QueryWrapper<UserPointsMerchandise>()
-                        .eq("pointsMerchandiseId",merchandise.getId() ));
-                detailsVo.setRedeemedNum(couponNums);
-                detailsVo.setResidueNum(Math.max(coupon.getQuantityIssued() - couponNums, 0));
+//                int couponNums = upmseService.count(new QueryWrapper<UserPointsMerchandise>()
+//                        .eq("pointsMerchandiseId",merchandise.getId() ));
+
+
+
+                int couponCounts = userCouponService.count(new QueryWrapper<UserCoupon>().eq("couponId", coupon.getId()));
+//                detailsVo.setRedeemedNum(coupon.getPickUpQuantity());
+                detailsVo.setRedeemedNum(couponCounts);
+
+                detailsVo.setResidueNum(Math.max(coupon.getQuantityIssued() - couponCounts, 0));
+
                 detailsVo.setPerLimit(coupon.getPickUpQuantity());
                 detailsVo.setExchangeType(coupon.getRedemptionMethod());
                 if (coupon.getRedemptionMethod() == 1){
@@ -421,6 +770,10 @@
     }
 
 
+    @Autowired
+    private ICouponService couponService;
+
+
     @ResponseBody
     @PostMapping("/base/pointMerchars/getDetailsOfExchange")
     public ExchangeDetailsVo getIntegralExchangeDetails(@RequestBody Integer appUserId){
@@ -428,44 +781,225 @@
         List<ExchangeDetailsResponse> responses = new ArrayList<>();
         SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
         List<UserPointsMerchandise> pointsMerchandises = upmseService.list(new QueryWrapper<UserPointsMerchandise>()
-                .eq("userId",appUserId ));
+                .eq("userId",appUserId ).eq("payStatus",2));
+
+
+        List<Coupon> list1 = couponService.list();
+        List<Integer> ids = new ArrayList<>();
+        for (Coupon coupon : list1) {
+            if (coupon.getDistributionMethod()==1) {
+                ids.add(coupon.getId());
+            }
+        }
+        List<UserCoupon> userCoupons = new ArrayList<>();
+        if (ids.size()>0) {
+           userCoupons = userCouponService.list(new QueryWrapper<UserCoupon>().eq("userId", appUserId).in("couponId", ids));
+        }
         if (pointsMerchandises.size() > 0 ){
             for (UserPointsMerchandise pointsMerchandise : pointsMerchandises) {
                 PointsMerchandise merchandise = pmdsService.getById(pointsMerchandise.getPointsMerchandiseId());
+                if (merchandise==null){
+                    continue;
+                }
                 ExchangeDetailsResponse detailsResponse = new ExchangeDetailsResponse();
                 detailsResponse.setDetailsId(pointsMerchandise.getId());
                 detailsResponse.setGoodName(merchandise.getName());
                 if (merchandise.getRedemptionMethod() == 1){
                     detailsResponse.setExchangeType(1);
                     detailsResponse.setIntegral(merchandise.getIntegral());
-                }else {
+                }else if (merchandise.getRedemptionMethod() == 2){
                     detailsResponse.setExchangeType(2);
                     detailsResponse.setIntegral(merchandise.getIntegral());
+                    detailsResponse.setCash(merchandise.getCash());
+                }else if (merchandise.getRedemptionMethod() == 3){
+                    detailsResponse.setExchangeType(3);
                     detailsResponse.setCash(merchandise.getCash());
                 }
                 detailsResponse.setStartTime(simpleDateFormat.format(merchandise.getStartTime()));
                 detailsResponse.setEndTime(simpleDateFormat.format(merchandise.getEndTime()));
                 detailsResponse.setUseStatus(pointsMerchandise.getStatus() == 1 ? 2 : 1);
                 detailsResponse.setGoodType(merchandise.getType());
+                if(merchandise.getType()==3){
+                    detailsResponse.setCardType(merchandise.getCardType());
+                    List<Integer> sids = new ArrayList<>();
+                    detailsResponse.setUserId(appUserId);
+                    if(merchandise.getUseScope()==1){
+                        sids.add(0);
+                        detailsResponse.setSid(sids);
+                        detailsResponse.setRid(new ArrayList<>());
+                    }else if(merchandise.getUseScope()==2){
+                        // 指定城市
+                        List<PointsMerchandiseCity> list = pmdsCityService.list(new LambdaQueryWrapper<PointsMerchandiseCity>().eq(PointsMerchandiseCity::getPointsMerchandiseId, merchandise.getId()));
+                        List<String> collect = list.stream().map(PointsMerchandiseCity::getCityCode).collect(Collectors.toList());
+                        if(collect.size()==0){
+                            collect.add("-1");
+                        }
+                        List<Integer> storeIds = stoClient.queryStoreIdByCityCode(collect);
+                        detailsResponse.setSid(storeIds);
+                        if(storeIds.size()>0){
+                            // 获取rid
+                            List<Integer> rid= stoClient.querySiteIdById(storeIds);
+                            detailsResponse.setRid(rid);
+                        }
+
+
+                    }else if(merchandise.getUseScope()==3){
+                        // 指定门店
+                        List<PointsMerchandiseStore> list = pmdstoService.list(new LambdaQueryWrapper<PointsMerchandiseStore>().eq(PointsMerchandiseStore::getPointsMerchandiseId, merchandise.getId()));
+                        List<Integer> collect = list.stream().map(PointsMerchandiseStore::getStoreId).collect(Collectors.toList());
+                        detailsResponse.setSid(collect);
+                        if(collect.size()>0){
+                            // 获取rid
+                            List<Integer> rid= stoClient.querySiteIdById(collect);
+                            detailsResponse.setRid(rid);
+                        }
+
+                    }
+
+
+                    if (merchandise.getCardType()==1){
+                        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
+                        Calendar calendar = Calendar.getInstance();
+                        calendar.setTime(pointsMerchandise.getInsertTime());
+                        calendar.add(Calendar.DAY_OF_MONTH, 1);
+                        Date end = calendar.getTime();
+                        String startDate = dateFormat.format(pointsMerchandise.getInsertTime());
+                        String endDate = dateFormat.format(end);
+                        detailsResponse.setStartTime(startDate);
+                        detailsResponse.setEndTime(startDate);
+
+                        Date now = new Date();
+                        Calendar cal1 = Calendar.getInstance();
+                        cal1.setTime(pointsMerchandise.getInsertTime());
+
+                        Calendar cal2 = Calendar.getInstance();
+                        cal2.setTime(now);
+
+                        // Compare the year, month, and day of the two Calendar instances
+                        boolean isSameDate = cal1.get(Calendar.YEAR) == cal2.get(Calendar.YEAR) &&
+                                cal1.get(Calendar.MONTH) == cal2.get(Calendar.MONTH) &&
+                                cal1.get(Calendar.DAY_OF_MONTH) == cal2.get(Calendar.DAY_OF_MONTH);
+
+                        // Print the result
+                        if (isSameDate) {
+                        } else {
+                            System.out.println("The two dates do not have the same date.");
+                            detailsResponse.setUseStatus(3);
+
+                        }
+
+
+                    } else if (merchandise.getCardType()==2) {
+                        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
+                        Calendar calendar = Calendar.getInstance();
+                        calendar.setTime(pointsMerchandise.getInsertTime());
+                        calendar.add(Calendar.DAY_OF_MONTH, 31);
+                        Date end = calendar.getTime();
+                        String startDate = dateFormat.format(pointsMerchandise.getInsertTime());
+                        String endDate = dateFormat.format(end);
+                        detailsResponse.setStartTime(startDate);
+                        detailsResponse.setEndTime(endDate);
+
+                        Date now = new Date();
+                        if (now.after(end)){
+                            detailsResponse.setUseStatus(3);
+                        }
+
+                    } else if (merchandise.getCardType()==3){
+                        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
+                        Calendar calendar = Calendar.getInstance();
+                        calendar.setTime(pointsMerchandise.getInsertTime());
+                        calendar.add(Calendar.DAY_OF_MONTH, 93);
+                        Date end = calendar.getTime();
+                        String startDate = dateFormat.format(pointsMerchandise.getInsertTime());
+                        String endDate = dateFormat.format(end);
+                        detailsResponse.setStartTime(startDate);
+                        detailsResponse.setEndTime(endDate);
+
+                        Date now = new Date();
+                        if (now.after(end)){
+                            detailsResponse.setUseStatus(3);
+                        }
+
+                    } else if (merchandise.getCardType()==4) {
+                        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
+                        Calendar calendar = Calendar.getInstance();
+                        calendar.setTime(pointsMerchandise.getInsertTime());
+                        calendar.add(Calendar.DAY_OF_MONTH, 372);
+                        Date end = calendar.getTime();
+                        String startDate = dateFormat.format(pointsMerchandise.getInsertTime());
+                        String endDate = dateFormat.format(end);
+                        detailsResponse.setStartTime(startDate);
+                        detailsResponse.setEndTime(endDate);
+
+                        Date now = new Date();
+                        if (now.after(end)){
+                            detailsResponse.setUseStatus(3);
+                        }
+
+                    }
+
+
+                }
                 responses.add(detailsResponse);
             }
             detailsVo.setDetailsResponses(responses);
+        }
+
+        if (userCoupons.size()>0){
+            for (UserCoupon userCoupon : userCoupons) {
+
+                Coupon c = couponService.getById(userCoupon.getCouponId());
+                if (c==null|| c.getRedemptionMethod()==null){
+                    continue;
+                }
+
+                ExchangeDetailsResponse detailsResponse = new ExchangeDetailsResponse();
+                detailsResponse.setDetailsId(Long.valueOf(c.getId()));
+                detailsResponse.setGoodName(c.getName());
+                if (c.getRedemptionMethod() == 1){
+                    detailsResponse.setExchangeType(1);
+                    detailsResponse.setIntegral(c.getIntegral().intValue());
+                }else {
+                    detailsResponse.setExchangeType(2);
+                    detailsResponse.setIntegral(c.getIntegral().intValue());
+                    detailsResponse.setCash(c.getCash());
+                }
+                detailsResponse.setStartTime(simpleDateFormat.format(c.getStartTime()));
+                detailsResponse.setEndTime(simpleDateFormat.format(c.getEndTime()));
+                detailsResponse.setUseStatus(userCoupon.getStatus() == 1 ? 2 : 1);
+                detailsResponse.setGoodType(4);
+                responses.add(detailsResponse);
+
+
+            }
+            Comparator<ExchangeDetailsResponse> comparator = Comparator.comparing(ExchangeDetailsResponse::getStartTime).reversed();
+            Collections.sort(responses, comparator);
+            detailsVo.setDetailsResponses(responses);
+
         }
         return detailsVo;
     }
 
 
+@Autowired
+private PointsMerchandiseStoreService storeService;
+
     @ResponseBody
     @PostMapping("/base/pointMerchars/getSpecificsOfGoods")
     public PointDetailsVo getSpecificsOfGoods(@RequestBody Long speMercharsId){
-        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
+         SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
         PointDetailsVo detailsVo = new PointDetailsVo();
         UserPointsMerchandise byId = upmseService.getById(speMercharsId);
 
+
         if (ToolUtil.isNotEmpty(byId)){
+            List<PointsMerchandiseStore> stores = storeService.list(new QueryWrapper<PointsMerchandiseStore>().eq("pointsMerchandiseId", byId.getPointsMerchandiseId()));
+
             PointsMerchandise pmdsServiceById = pmdsService.getById(byId.getPointsMerchandiseId());
             // 2.0
             detailsVo.setCardType(pmdsServiceById.getCardType());
+            detailsVo.setExchangeAddrType(pmdsServiceById.getUseScope());
             detailsVo.setExchangeType(pmdsServiceById.getRedemptionMethod());
             detailsVo.setGoodType(pmdsServiceById.getType());
             if (pmdsServiceById.getRedemptionMethod() == 1){
@@ -480,6 +1014,22 @@
                 case 3:
                     List<String> list10 = Arrays.asList(StrUtils.splitStr2StrArr(pmdsServiceById.getProductImages(), ","));
                     ArrayList<String> list2 = new ArrayList<>(list10);
+
+
+                    SimpleDateFormat dateFormat5 = new SimpleDateFormat("yyyy-MM-dd");
+
+
+                    for (PointsMerchandiseStore store : stores) {
+                        StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(store.getStoreId());
+                    detailsVo.setBelongs(courseOfStore.getStoreName());
+                    }
+
+                    String format = dateFormat5.format(byId.getInsertTime());
+                    detailsVo.setOrderTime(format);
+
+
+
+
                     list2.add(pmdsServiceById.getCover());
                     detailsVo.setPics(list2);
                     Collections.sort(detailsVo.getPics(), (s1, s2) -> {
@@ -491,6 +1041,101 @@
                             return 0; // 保持原顺序
                         }
                     });
+
+
+
+
+                    if (pmdsServiceById.getCardType()==1){
+                        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
+                        Calendar calendar = Calendar.getInstance();
+                        calendar.setTime(byId.getInsertTime());
+                        calendar.add(Calendar.DAY_OF_MONTH, 1);
+                        Date end = calendar.getTime();
+                        String startDate = dateFormat.format(byId.getInsertTime());
+                        String endDate = dateFormat.format(end);
+                        detailsVo.setStartTime(startDate);
+                        detailsVo.setEndTime(startDate);
+
+                        Date now = new Date();
+                        Calendar cal1 = Calendar.getInstance();
+                        cal1.setTime(pmdsServiceById.getInsertTime());
+
+                        Calendar cal2 = Calendar.getInstance();
+                        cal2.setTime(now);
+
+                        // Compare the year, month, and day of the two Calendar instances
+                        boolean isSameDate = cal1.get(Calendar.YEAR) == cal2.get(Calendar.YEAR) &&
+                                cal1.get(Calendar.MONTH) == cal2.get(Calendar.MONTH) &&
+                                cal1.get(Calendar.DAY_OF_MONTH) == cal2.get(Calendar.DAY_OF_MONTH);
+
+                        // Print the result
+                        if (isSameDate) {
+                        } else {
+                            System.out.println("The two dates do not have the same date.");
+                            detailsVo.setUseType(3);
+                        }
+
+
+                    } else if (pmdsServiceById.getCardType()==2) {
+                        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
+
+
+
+                        Calendar calendar = Calendar.getInstance();
+                        calendar.setTime(byId.getInsertTime());
+                        calendar.add(Calendar.DAY_OF_MONTH, 31);
+                        Date end = calendar.getTime();
+                        String startDate = dateFormat.format(byId.getInsertTime());
+                        String endDate = dateFormat.format(end);
+                        detailsVo.setStartTime(startDate);
+                        detailsVo.setEndTime(endDate);
+
+                        Date now = new Date();
+                        if (now.after(end)){
+                            detailsVo.setUseType(3);
+                        }
+
+                    } else if (pmdsServiceById.getCardType()==3) {
+                        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
+
+
+
+                        Calendar calendar = Calendar.getInstance();
+                        calendar.setTime(byId.getInsertTime());
+                        calendar.add(Calendar.DAY_OF_MONTH, 93);
+                        Date end = calendar.getTime();
+                        String startDate = dateFormat.format(byId.getInsertTime());
+                        String endDate = dateFormat.format(end);
+                        detailsVo.setStartTime(startDate);
+                        detailsVo.setEndTime(endDate);
+
+                        Date now = new Date();
+                        if (now.after(end)){
+                            detailsVo.setUseType(3);
+                        }
+
+                    } else if (pmdsServiceById.getCardType()==4) {
+                        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
+                        Calendar calendar = Calendar.getInstance();
+                        calendar.setTime(byId.getInsertTime());
+                        calendar.add(Calendar.DAY_OF_MONTH, 372);
+                        Date end = calendar.getTime();
+                        String startDate = dateFormat.format(byId.getInsertTime());
+                        String endDate = dateFormat.format(end);
+                        detailsVo.setStartTime(startDate);
+                        detailsVo.setEndTime(endDate);
+
+                        Date now = new Date();
+                        if (now.after(end)){
+                            detailsVo.setUseType(3);
+                        }
+
+                    }
+
+
+
+
+
                     break;
                 case 2:
                     CoursePackage coursePackage = cpClient.queryCoursePackageById(pmdsServiceById.getCoursePackageId());
@@ -532,16 +1177,23 @@
 
             detailsVo.setGoodName(pmdsServiceById.getName());
             // 2.0
-            detailsVo.setStartTime(simpleDateFormat.format(byId.getInsertTime()));
-            detailsVo.setEndTime(simpleDateFormat.format(pmdsServiceById.getEndTime()));
-            detailsVo.setOrderTime(simpleDateFormat.format(byId.getInsertTime()));
+            if (detailsVo.getStartTime()==null) {
+                detailsVo.setStartTime(simpleDateFormat.format(byId.getInsertTime()));
+                detailsVo.setEndTime(simpleDateFormat.format(pmdsServiceById.getEndTime()));
+                detailsVo.setOrderTime(simpleDateFormat.format(byId.getInsertTime()));
+
+            }
             if (byId.getStatus() == 1){
                 detailsVo.setUseType(2);
             }else {
                 detailsVo.setUseType(1);
-                detailsVo.setWriteOffTime(simpleDateFormat.format(byId.getVerificationTime()));
-                StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(byId.getVerifiStoreId());
-                detailsVo.setWriteOffName(courseOfStore.getStoreName());
+                if (pmdsServiceById.getType()!=2) {
+                    detailsVo.setWriteOffTime(simpleDateFormat.format(byId.getVerificationTime()));
+                }
+                if (byId.getStoreId()!=null) {
+                    StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(byId.getStoreId());
+                    detailsVo.setWriteOffName(courseOfStore.getStoreName());
+                }
             }
             switch (pmdsServiceById.getUseScope()){
                 case 1:
@@ -551,13 +1203,76 @@
                     detailsVo.setBelongs(pmdsServiceById.getProvince()+pmdsServiceById.getCity());
                     break;
                 case 3:
-                    StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(byId.getStoreId());
-                    detailsVo.setBelongs(courseOfStore.getStoreName()+" "+courseOfStore.getStoreAddr());
+//                    StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(byId.getStoreId());
+//                    detailsVo.setBelongs(courseOfStore.getStoreName()+" "+courseOfStore.getStoreAddr());
+//                    detailsVo.setBelongs("---------------");
                     break;
                 default:
                     break;
             }
             detailsVo.setContents(pmdsServiceById.getRedemptionInstructions());
+        }else {
+            Coupon coupon = iCouponService.getById(speMercharsId);
+            detailsVo.setDetailsId(Long.valueOf(coupon.getId()));
+            List<String> list3 = new ArrayList<>();
+            list3.add(ToolUtil.isEmpty(coupon.getCover()) ? "" : coupon.getCover());
+            if (ToolUtil.isNotEmpty(coupon.getProductImages())){
+                list3.addAll(Arrays.asList(StrUtils.splitStr2StrArr(coupon.getProductImages(), ",")));
+            }
+            detailsVo.setPics(list3);
+            Collections.sort(detailsVo.getPics(), (s1, s2) -> {
+                if (s1.equals(coupon.getCover())) {
+                    return -1; // s1排在前面
+                } else if (s2.equals(coupon.getCover())) {
+                    return 1; // s2排在前面
+                } else {
+                    return 0; // 保持原顺序
+                }
+            });
+            detailsVo.setGoodName(coupon.getName());
+//            detailsVo.setBelongsScope(coupon.getUserPopulation());
+//                int couponNums = upmseService.count(new QueryWrapper<UserPointsMerchandise>()
+//                        .eq("pointsMerchandiseId",merchandise.getId() ));
+
+
+
+            int couponCounts = userCouponService.count(new QueryWrapper<UserCoupon>().eq("couponId", coupon.getId()));
+//                detailsVo.setRedeemedNum(coupon.getPickUpQuantity());
+//            detailsVo.setRedeemedNum(couponCounts);
+
+//            detailsVo.setResidueNum(Math.max(coupon.getQuantityIssued() - couponCounts, 0));
+
+//            detailsVo.setPerLimit(coupon.getPickUpQuantity());
+            detailsVo.setExchangeType(coupon.getRedemptionMethod());
+            if (coupon.getRedemptionMethod() == 1){
+                detailsVo.setIntegral(coupon.getIntegral().intValue());
+            }else {
+                detailsVo.setIntegral(coupon.getIntegral().intValue());
+                detailsVo.setCash(coupon.getCash());
+            }
+            if (coupon.getUseScope() == 1){
+                detailsVo.setExchangeAddrType(1);
+                detailsVo.setBelongs("全国通用");
+            }else if (coupon.getUseScope() == 2){
+                detailsVo.setExchangeAddrType(2);
+                List<CouponCity> list = ccityService.list(new LambdaQueryWrapper<CouponCity>()
+                        .eq(CouponCity::getCouponId, coupon.getId()));
+                if (list.size() > 0){
+                    detailsVo.setBelongs(list.get(0).getProvince()+"|"+list.get(0).getCity() + "用户可用");
+                }
+            }else {
+                detailsVo.setExchangeAddrType(3);
+                List<CouponStore> list = cstoreService.list(new QueryWrapper<CouponStore>()
+                        .eq("couponId",coupon.getId() ));
+                StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(list.get(0).getStoreId());
+                detailsVo.setBelongs(courseOfStore.getStoreName()+"可用");
+            }
+            SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
+            detailsVo.setStartTime(format.format(coupon.getStartTime()));
+            detailsVo.setEndTime(format.format(coupon.getEndTime()));
+
+            detailsVo.setContents(coupon.getIllustrate());
+            detailsVo.setGoodType(4);
         }
         return detailsVo;
     }
@@ -570,17 +1285,21 @@
 
 
     @PostMapping("/base/pointMerchars/saveDetailsUserPointMercase")
-    public void saveDetailsUserPointMercase(@RequestBody UserPointsMerchandise merchandise){
+    public Long saveDetailsUserPointMercase(@RequestBody UserPointsMerchandise merchandise){
         merchandise.setInsertTime(new Date());
         upmseService.save(merchandise);
+        return merchandise.getId();
     }
 
 
     @PostMapping("/base/pointMerchars/updateDetailsUserPointMercase")
-    public void updateDetailsUserPointMercase(@RequestBody UserPointsMerchandise merchandise){
+    public void  updateDetailsUserPointMercase(@RequestBody UserPointsMerchandise merchandise){
+        merchandise.setUserId(null);
+        merchandise.setPointsMerchandiseId(null);
         upmseService.updateById(merchandise);
     }
 
+    @ResponseBody
     @PostMapping("/base/pointMerchars/queryUserPointMerchaseByCode")
     public List<UserPointsMerchandise> queryUserPointMerchaseByCode(@RequestBody String code){
         return upmseService.list(new QueryWrapper<UserPointsMerchandise>()
@@ -611,7 +1330,15 @@
     @PostMapping("/base/pointMerchars/queryUserHasGoodsNums")
     public int queryUserHasGoodsNums(@RequestBody AppUserGoodResp goodResp){
         int count = upmseService.count(new LambdaQueryWrapper<UserPointsMerchandise>()
-                .eq(UserPointsMerchandise::getUserId,goodResp.getGoodId())
+                .eq(UserPointsMerchandise::getUserId,goodResp.getAppUserId())
+                .eq(UserPointsMerchandise::getPointsMerchandiseId,goodResp.getGoodId()));
+        System.out.println(count);
+        return count;
+    }
+    @ResponseBody
+    @PostMapping("/base/pointMerchars/queryUserHasGoodsNums1")
+    public int queryUserHasGoodsNums1(@RequestBody AppUserGoodResp goodResp){
+        int count = upmseService.count(new LambdaQueryWrapper<UserPointsMerchandise>()
                 .eq(UserPointsMerchandise::getPointsMerchandiseId,goodResp.getGoodId()));
         System.out.println(count);
         return count;
@@ -637,6 +1364,15 @@
 
     }
 
+    //拿到积分商品现金的消费记录
+    @ResponseBody
+    @PostMapping("/base/pointMerchars/getConsumeDetails")
+    public List<ConsumeDetail> getConsumeDetails(@RequestBody BillingDataRequestVo requestVo){
+       return   upmseService.getConsumeDetails(requestVo);
+
+
+
+    }
 
 
     public int dealTimeStatus(String startTime, String endTime){
@@ -712,6 +1448,8 @@
             vo.setSort(byId.getSort());
             vo.setContent(byId.getRedemptionInstructions());
         }
+        int count = userPointsMerchandiseService.count(new LambdaQueryWrapper<UserPointsMerchandise>().eq(UserPointsMerchandise::getPointsMerchandiseId, pointMercharsId));
+        vo.setNum(count);
         return vo;
     }
 
@@ -760,7 +1498,16 @@
 
     @PostMapping("/base/pointMerchars/queryPointMerchaseById")
     public PointsMerchandise queryPointMerchaseById(@RequestBody Integer id){
-        return pmdsService.getById(id);
+        PointsMerchandise byId = pmdsService.getById(id);
+        int count1 = upmseService.count(new LambdaQueryWrapper<UserPointsMerchandise>()
+                .eq(UserPointsMerchandise::getPointsMerchandiseId, byId.getId())
+                .eq(UserPointsMerchandise::getStatus,2));
+        int count2 = upmseService.count(new LambdaQueryWrapper<UserPointsMerchandise>()
+                .eq(UserPointsMerchandise::getPointsMerchandiseId, byId.getId())
+        );
+        byId.setPickUpQuantity3(count2);
+        byId.setPickUpQuantity4(count1);
+        return byId;
     }
 
     @PostMapping("/base/pointMerchars/getshopName")
@@ -869,7 +1616,14 @@
                 for (Store store : stores) {
                     StoreVos storeVos1 = new StoreVos();
                     storeVos1.setNum1(store.getProvince() +"省"+ store.getCity() +"市");
-                    storeVos1.setNum2(store.getName());
+                    if(store.getOperatorId()==0){
+                        storeVos1.setNum2("平台");
+                    }else {
+
+                        storeVos1.setNum2(store.getOName());
+                    }
+                    storeVos1.setNum3(store.getName());
+                    storeVos1.setNum4(store.getIds());
                     storeVos.add(storeVos1);
                 }
             }
@@ -885,7 +1639,9 @@
         try {
             Integer pointMerchandiseId = (Integer) map.get("pointMerchandiseId");
             PointsMerchandise byId1 = pmdsService.getById(pointMerchandiseId);
-
+            if(Integer.valueOf(map.get("type").toString())!=1){
+                byId1.setStatus(2);
+            }
             Integer quantityIssued = (Integer) map.get("quantityIssued");
             Integer pickUpQuantity = (Integer) map.get("pickUpQuantity");
             String redemptionInstructions = (String) map.get("redemptionInstructions");
@@ -911,11 +1667,10 @@
     }
 
 
-
     @PostMapping("/base/pointMerchars/add")
     public Integer add(@RequestBody PointsMerchandise pointsMerchandise){
         Integer storeId = pointsMerchandise.getShelves();
-        pointsMerchandise.setShelves(2);
+        pointsMerchandise.setShelves(1);
         boolean save = pmdsService.save(pointsMerchandise);
         if(save && ToolUtil.isNotEmpty(storeId) && pointsMerchandise.getType()==2){
             PointsMerchandiseStore pointsMerchandiseStore = new PointsMerchandiseStore();
@@ -934,6 +1689,7 @@
 
 
 
+
     @PostMapping("/base/pointMerchars/addOther")
     public Boolean addOther(@RequestBody String pam){
         Boolean save =false;

--
Gitblit v1.7.1