From 2b4511ca363e74343e1cb678c23a9e7638800a3f Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期四, 06 七月 2023 17:33:25 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java |  102 +++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 95 insertions(+), 7 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 6b51f47..5058bd9 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
@@ -1,9 +1,15 @@
 package com.dsh.other.controller;
 
+
 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.service.StoreService;
+import com.dsh.other.util.GDMapGeocodingUtil;
 import com.dsh.other.util.ResultUtil;
 import com.dsh.other.util.ToolUtil;
 import io.swagger.annotations.ApiImplicitParam;
@@ -12,19 +18,100 @@
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
-import java.util.ArrayList;
-import java.util.List;
+import java.util.*;
 
-/**
- * @author zhibing.pu
- * @date 2023/6/24 15:42
- */
 @RestController
 @RequestMapping("")
 public class StoreController {
 
     @Autowired
     private StoreService storeService;
+
+
+    @Autowired
+    private GDMapGeocodingUtil gdMapGeocodingUtil;
+
+
+
+
+    @PostMapping("/base/protocol/storeDetail/courseOfSto")
+    public StoreDetailOfCourse getCourseOfStore(@RequestBody Integer storeId){
+        StoreDetailOfCourse ofCourse = new StoreDetailOfCourse();
+        Store store = storeService.getById(storeId);
+        if (null != store){
+            ofCourse.setStoreName(store.getName());
+            ofCourse.setStoreAddr(store.getAddress());
+        }
+        return ofCourse;
+    }
+
+    @PostMapping("/base/protocol/storeDetail/nearbyStore")
+    public List<StoreInfo> getAllNearbyStoreList(@RequestBody GetAllNearbyStoreList list ){
+        String current = list.getLongitude()+","+list.getLatitude();
+        List<StoreInfo> storeInfos = new ArrayList<>();
+        String cityCode = "";
+        try {
+            Map<String, String> geocode = gdMapGeocodingUtil.geocode(list.getLongitude(), list.getLatitude());
+            cityCode = geocode.get("cityCode");
+        }catch (Exception e){
+            e.printStackTrace();
+        }
+        List<Store> storeList = storeService.list(new QueryWrapper<Store>()
+                .eq("state", 1)
+                .eq("cityCode",cityCode));
+        if (storeList.size() > 0){
+            for (Store store : storeList) {
+                String storeLon = store.getLon();
+                String storeLat = store.getLat();
+                String result = storeLon+","+storeLat;
+                String distanceTOKilometer = gdMapGeocodingUtil.getDistanceTOKilometer(current, result);
+                StoreInfo info = new StoreInfo();
+                info.setStoreId(store.getId());
+                info.setStoreName(store.getName());
+                info.setStoreImg(store.getRealPicture());
+                info.setDistance(Long.parseLong(distanceTOKilometer));
+                info.setStoreAddr(store.getAddress());
+                storeInfos.add(info);
+            }
+            Comparator<StoreInfo> distanceComparator = new Comparator<StoreInfo>() {
+                @Override
+                public int compare(StoreInfo store1, StoreInfo store2) {
+                    return Long.compare(store1.getDistance(), store2.getDistance());
+                }
+            };
+            Collections.sort(storeInfos, distanceComparator);
+        }
+        return storeInfos;
+    }
+
+
+    @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);
+                }
+            }
+        }catch (Exception e){
+            e.printStackTrace();
+        }
+
+        return storeInfos;
+    }
+
+
+
+
 
 
     /**
@@ -50,7 +137,7 @@
 
     @ResponseBody
     @PostMapping("/base/store/queryStoreLists")
-    @ApiOperation(value = "获取门店列表", tags = {"APP-加入玩湃"})
+    @ApiOperation(value = "获取门店列表", tags = {"APP-加入玩湃", "APP-课程列表"})
     @ApiImplicitParams({
             @ApiImplicitParam(value = "经纬", name = "lon", dataType = "string", required = true),
             @ApiImplicitParam(value = "纬度", name = "lat", dataType = "string", required = true),
@@ -105,4 +192,5 @@
             return null;
         }
     }
+
 }

--
Gitblit v1.7.1