From c743f4413a00fc063bbbd9d851b6d0c3fff10581 Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期一, 31 七月 2023 10:04:02 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java | 165 ++++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 126 insertions(+), 39 deletions(-) diff --git a/cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java b/cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java index 5058bd9..0ee10ba 100644 --- a/cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java +++ b/cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java @@ -3,11 +3,8 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.dsh.other.entity.Store; -import com.dsh.other.feignclient.model.GetAllNearbyStoreList; -import com.dsh.other.feignclient.model.StoreDetailOfCourse; -import com.dsh.other.feignclient.model.StoreInfo; -import com.dsh.other.feignclient.model.StoreLonLatList; -import com.dsh.other.model.BaseVo; +import com.dsh.other.feignclient.model.*; +import com.dsh.other.model.*; import com.dsh.other.service.StoreService; import com.dsh.other.util.GDMapGeocodingUtil; import com.dsh.other.util.ResultUtil; @@ -71,6 +68,8 @@ info.setStoreImg(store.getRealPicture()); info.setDistance(Long.parseLong(distanceTOKilometer)); info.setStoreAddr(store.getAddress()); + info.setLatitude(storeLat); + info.setLongitude(storeLon); storeInfos.add(info); } Comparator<StoreInfo> distanceComparator = new Comparator<StoreInfo>() { @@ -84,29 +83,49 @@ return storeInfos; } + /** + * 根据门店坐标与传入坐标,计算距离 + * @param distanceVo + * @return + */ + @PostMapping("/base/protocol/storeDetail/distanceCal") + public long calculateDistance(@RequestBody GetDistanceVo distanceVo){ + String current = distanceVo.getLongitude()+","+distanceVo.getLatitude(); + Store store = storeService.getById(distanceVo.getStoreId()); + String result = store.getLon()+","+store.getLat(); + String distanceTOKilometer = gdMapGeocodingUtil.getDistanceTOKilometer(current, result); + return Long.parseLong(distanceTOKilometer); + } - @PostMapping("/base/protocol/storeDetail/storeOfLonLat") - public List<StoreLonLatList> getAllStoreLonLats(@RequestBody GetAllNearbyStoreList list ){ - List<StoreLonLatList> storeInfos = new ArrayList<>(); - try { - Map<String, String> geocode = gdMapGeocodingUtil.geocode(list.getLongitude(), list.getLatitude()); - String cityCode = geocode.get("cityCode"); - List<Store> storeList = storeService.list(new QueryWrapper<Store>() - .eq("cityCode",cityCode)); - if (storeList.size() > 0){ - for (Store store : storeList) { - StoreLonLatList latList = new StoreLonLatList(); - latList.setStoreId(store.getId()); - latList.setLongitude(store.getLon()); - latList.setLatitude(store.getLat()); - storeInfos.add(latList); + + @PostMapping("/base/protocol/storeDetail/citycodeLoLa") + public List<StoreDetailList> getQueryStoreList(@RequestBody StoreOfCitycodeResp citycodeResp){ + List<StoreDetailList> detailLists = new ArrayList<>(); + List<Store> list = storeService.list(new QueryWrapper<Store>() + .eq("state",1 ) + .eq("cityCode",citycodeResp.getCityCode())); + if (list.size() > 0 ){ + for (Store store : list) { + String current = citycodeResp.getLongitude() +","+citycodeResp.getLatitude(); + String result = store.getLon()+","+store.getLat(); + String distanceTOKilometer = gdMapGeocodingUtil.getDistanceTOKilometer(current, result); + long l = Long.parseLong(distanceTOKilometer); + if (ToolUtil.isNotEmpty(citycodeResp.getSpace()) && l > citycodeResp.getSpace()){ + continue; } + StoreDetailList detailList = new StoreDetailList(); + detailList.setStoreId(store.getId()); + detailList.setStoreImg(store.getCoverDrawing()); + detailList.setStoreName(store.getName()); + detailList.setStoreAddress(store.getAddress()); + detailList.setStorePhone(store.getPhone()); + detailList.setStoreDistance(l); + detailList.setStoreTime(store.getStartTime() + "-" + store.getEndTime()); + detailList.setStoreInfo(store.getIntroduce()); + detailLists.add(detailList); } - }catch (Exception e){ - e.printStackTrace(); } - - return storeInfos; + return detailLists; } @@ -116,15 +135,13 @@ /** * 获取门店列表 - * @param provinceCode - * @param cityCode * @return */ @ResponseBody @PostMapping("/store/queryStoreList") - public List<Store> queryStoreList(@RequestBody String provinceCode, @RequestBody String cityCode){ + public List<Store> queryStoreList(QueryStoreList queryStoreList){ try { - return storeService.queryStorsList(provinceCode, cityCode); + return storeService.queryStorsList(queryStoreList.getProvinceCode(), queryStoreList.getCityCode()); }catch (Exception e){ e.printStackTrace(); return new ArrayList<>(); @@ -137,18 +154,12 @@ @ResponseBody @PostMapping("/base/store/queryStoreLists") - @ApiOperation(value = "获取门店列表", tags = {"APP-加入玩湃", "APP-课程列表"}) + @ApiOperation(value = "获取门店列表", tags = {"APP-加入玩湃", "APP-课程列表", "用户—预约场地"}) @ApiImplicitParams({ - @ApiImplicitParam(value = "经纬", name = "lon", dataType = "string", required = true), - @ApiImplicitParam(value = "纬度", name = "lat", dataType = "string", required = true), + @ApiImplicitParam(value = "经纬", name = "lon", dataType = "string", required = false), + @ApiImplicitParam(value = "纬度", name = "lat", dataType = "string", required = false), }) - public ResultUtil<List<BaseVo>> queryStoreLists(@RequestBody String lon, @RequestBody String lat){ - if(ToolUtil.isEmpty(lon)){ - return ResultUtil.paranErr("lon"); - } - if(ToolUtil.isEmpty(lat)){ - return ResultUtil.paranErr("lat"); - } + public ResultUtil<List<BaseVo>> queryStoreLists(String lon, String lat){ try { List<BaseVo> baseVos = storeService.queryStoreLists(lon, lat); return ResultUtil.success(baseVos); @@ -166,7 +177,7 @@ */ @ResponseBody @PostMapping("/store/queryStoreListByName") - public List<Store> queryStoreListByName(@RequestBody String name){ + public List<Store> queryStoreListByName(@RequestParam("name") String name){ try { List<Store> stores = storeService.list(new QueryWrapper<Store>().eq("state", 1).like("name", name)); return stores; @@ -193,4 +204,80 @@ } } + + + + @ResponseBody + @PostMapping("/base/store/queryStoreFreeBenefit") + @ApiOperation(value = "获取门店免费福利", tags = {"APP-免费福利"}) + @ApiImplicitParams({ + @ApiImplicitParam(value = "门店id", name = "id", dataType = "int", required = true), + }) + public ResultUtil<StoreFreeBenefitVo> queryStoreFreeBenefit(Integer id){ + try { + Store store = storeService.getById(id); + StoreFreeBenefitVo storeFreeBenefitVo = new StoreFreeBenefitVo(); + storeFreeBenefitVo.setPhone(store.getPhone()); + storeFreeBenefitVo.setImg(store.getWelfarePicture()); + return ResultUtil.success(storeFreeBenefitVo); + }catch (Exception e){ + e.printStackTrace(); + return ResultUtil.runErr(); + } + } + + + + + @ResponseBody + @PostMapping("/base/store/queryProvinceAndCity") + @ApiOperation(value = "获取省市数据", tags = {"APP-加入玩湃"}) + @ApiImplicitParams({ + @ApiImplicitParam(value = "省编号", name = "pcode", dataType = "string", required = false), + }) + public ResultUtil<List<ProvinceAndCityVo>> queryProvinceAndCity(String pcode){ + try { + List<ProvinceAndCityVo> provinceAndCityVos = storeService.queryProvinceAndCity(pcode); + return ResultUtil.success(provinceAndCityVos); + }catch (Exception e){ + e.printStackTrace(); + return ResultUtil.runErr(); + } + } + + + + + @ResponseBody + @PostMapping("/base/store/queryAllCity") + @ApiOperation(value = "获取所有开通城市", tags = {"APP-赛事活动列表", "用户—预约场地"}) + @ApiImplicitParams({ + }) + public ResultUtil<List<ProvinceAndCityVo>> queryAllCity(){ + try { + List<ProvinceAndCityVo> provinceAndCityVos = storeService.queryAllCity(); + return ResultUtil.success(provinceAndCityVos); + }catch (Exception e){ + e.printStackTrace(); + return ResultUtil.runErr(); + } + } + + + + @ResponseBody + @PostMapping("/base/store/queryStoreByCityCode") + @ApiOperation(value = "获取城市code获取门店", tags = {"APP-加入玩湃"}) + @ApiImplicitParams({ + @ApiImplicitParam(value = "城市code", name = "cityCode", dataType = "string", required = true), + }) + public ResultUtil<List<BaseVo>> queryStoreByCityCode(String cityCode){ + try { + List<BaseVo> list = storeService.queryStoreByCityCode(cityCode); + return ResultUtil.success(list); + }catch (Exception e){ + e.printStackTrace(); + return ResultUtil.runErr(); + } + } } -- Gitblit v1.7.1