From 26e2592813b9263124d518d238262910e817d323 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期一, 14 八月 2023 10:13:10 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java |   84 +++++++++++++++++++++++++++++++++++++----
 1 files changed, 75 insertions(+), 9 deletions(-)

diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java b/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java
index ad22b06..1d2982e 100644
--- a/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java
+++ b/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java
@@ -4,19 +4,24 @@
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.dsh.activity.entity.Coupon;
 import com.dsh.activity.entity.CouponCity;
 import com.dsh.activity.entity.CouponStore;
 import com.dsh.activity.entity.UserCoupon;
+import com.dsh.activity.feignclient.account.AppUserClient;
 import com.dsh.activity.feignclient.account.CityClient;
 import com.dsh.activity.feignclient.account.StoreStaffClient;
 import com.dsh.activity.feignclient.account.model.TCityManager;
 import com.dsh.activity.feignclient.account.model.TStoreStaff;
 import com.dsh.activity.feignclient.model.CouponExamineListSearch;
 import com.dsh.activity.feignclient.model.CouponListOfSearch;
+import com.dsh.activity.feignclient.other.RegionClient;
 import com.dsh.activity.feignclient.other.StoreClient;
+import com.dsh.activity.feignclient.other.model.CityDataAndProvinceDataVo;
 import com.dsh.activity.feignclient.other.model.Store;
 import com.dsh.activity.model.CouponListVo;
+import com.dsh.activity.model.CouponRecordQuery;
 import com.dsh.activity.model.request.CommodityRequest;
 import com.dsh.activity.model.request.CouponDataVo;
 import com.dsh.activity.model.request.CouponPackageReq;
@@ -71,11 +76,18 @@
     @Resource
     private StoreClient stoClient;
 
+
+    @Resource
+    private RegionClient regionClient;
+
     @Resource
     private CouponStoreService couStoreService;
 
     @Resource
     private CouponCityService cityService;
+
+    @Autowired
+    private AppUserClient appUserClient;
 
 
 
@@ -201,6 +213,7 @@
 
     @PostMapping("/base/coupon/insertToAppuserCoupon")
     public void insertToAppuserCoupon(@RequestBody UserCoupon coupon){
+        coupon.setInsertTime(new Date());
         ucService.save(coupon);
     }
 
@@ -266,14 +279,15 @@
             JSONObject jsonObject = JSON.parseObject(coupon.getContent());
             switch (coupon.getType()){
                 case 1:
-                    couponInfo.put("num1",jsonObject.getDouble("num1"));
-                    couponInfo.put("num2",jsonObject.getDouble("num2"));
+//                {"conditionalAmount":50,"deductionAmount":10,"experienceName":""}
+                    couponInfo.put("num1",jsonObject.getDouble("conditionalAmount"));
+                    couponInfo.put("num2",jsonObject.getDouble("deductionAmount"));
                     break;
                 case 2:
-                    couponInfo.put("num1",jsonObject.getDouble("num1"));
+                    couponInfo.put("num1",jsonObject.getDouble("conditionalAmount"));
                     break;
                 case 3:
-                    couponInfo.put("num1",jsonObject.getString("num1"));
+                    couponInfo.put("num1",jsonObject.getString("experienceName"));
                     break;
                 default:
                     break;
@@ -378,17 +392,18 @@
             coupon.setType(dataVo.getPrescription());
             HashMap<String, Object> stringObjectHashMap = new HashMap<>();
             switch (dataVo.getPrescription()){
+//                {"conditionalAmount":50,"deductionAmount":10,"experienceName":""}
                 case 1:
-                    stringObjectHashMap.put("num1",dataVo.getCondition());
-                    stringObjectHashMap.put("num2",dataVo.getSubtraction());
+                    stringObjectHashMap.put("conditionalAmount",dataVo.getCondition());
+                    stringObjectHashMap.put("deductionAmount",dataVo.getSubtraction());
                     coupon.setContent(stringObjectHashMap.toString());
                     break;
                 case 2:
-                    stringObjectHashMap.put("num1",dataVo.getDiscount());
+                    stringObjectHashMap.put("conditionalAmount",dataVo.getDiscount());
                     coupon.setContent(stringObjectHashMap.toString());
                     break;
                 case 3:
-                    stringObjectHashMap.put("num1",dataVo.getExperience());
+                    stringObjectHashMap.put("experienceName",dataVo.getExperience());
                     coupon.setContent(stringObjectHashMap.toString());
                     break;
                 default:
@@ -423,10 +438,61 @@
             if (dataVo.getUserType() == 1){
                 coupon.setCityManagerId(dataVo.getCityManagerId());
             }
-            return couponService.save(coupon);
+            boolean save = couponService.save(coupon);
+            if (save){
+                if (dataVo.getCompany() == 2){
+                    for (Integer storeId : dataVo.getStoreIds()) {
+                        CouponStore couponStore = new CouponStore();
+                        couponStore.setCouponId(coupon.getId());
+                        couponStore.setStoreId(storeId);
+                        couStoreService.save(couponStore);
+                    }
+                }
+                List<Integer> cityIds = dataVo.getCityIds();
+                if (dataVo.getCompany() == 3 && cityIds.size() > 0 ){
+                    List<CityDataAndProvinceDataVo> cityAndProvince = regionClient.getCityAndProvince(cityIds);
+                    for (CityDataAndProvinceDataVo cityId : cityAndProvince) {
+                        CouponCity couponCity = new CouponCity();
+                        couponCity.setCouponId(coupon.getId());
+                        couponCity.setCityCode(cityId.getCityCode());
+                        couponCity.setCity(cityId.getCityName());
+                        couponCity.setProvinceCode(cityId.getProvinceCode());
+                        couponCity.setProvince(cityId.getProvinceName());
+                        cityService.save(couponCity);
+                    }
+                }
+            }
+            return true;
         }catch (Exception e){
             return false;
         }
     }
 
+    @ResponseBody
+    @PostMapping("/base/coupon/queryCity")
+    public List<CouponCity> queryCity(@RequestBody Integer id){
+        List<CouponCity> list = cityService.list(new LambdaQueryWrapper<CouponCity>().eq(CouponCity::getCouponId, id));
+        return list;
+    }
+
+    @ResponseBody
+    @PostMapping("/base/coupon/queryStore")
+    public List<Integer> queryStore(@RequestBody Integer id){
+       return couStoreService.list(new LambdaQueryWrapper<CouponStore>().eq(CouponStore::getCouponId,id)).stream().map(CouponStore::getStoreId).collect(Collectors.toList());
+    }
+
+
+    @PostMapping("/base/coupon/listRecord")
+    @ResponseBody
+    public List<Map<String,Object>> listRecord(@RequestBody CouponRecordQuery ofSearch){
+        Page<Object> objectPage = new Page<>(ofSearch.getOffset(), ofSearch.getLimit());
+        return couponService.listRecord(objectPage,ofSearch.getId(),ofSearch.getIds(),ofSearch.getType());
+    }
+
+
+
+    @PostMapping("/base/coupon/updateType")
+    public void updateType(@RequestBody Long id){
+        couponService.updateType(id);
+    }
 }

--
Gitblit v1.7.1