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