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