From c37acfa5fd70c1d658295f5635b630d3beef7ce0 Mon Sep 17 00:00:00 2001
From: lisy <linlangsur163@163.com>
Date: 星期五, 21 七月 2023 18:25:48 +0800
Subject: [PATCH] 探索玩湃-门店:列表+详情+评价

---
 cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java |   52 +++++++++++++++++++++++++++++-----------------------
 1 files changed, 29 insertions(+), 23 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 5f79410..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
@@ -4,13 +4,11 @@
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.dsh.other.entity.Store;
 import com.dsh.other.feignclient.model.*;
-import com.dsh.other.model.BaseVo;
-import com.dsh.other.model.ProvinceAndCityVo;
-import com.dsh.other.model.QueryStoreList;
-import com.dsh.other.model.StoreFreeBenefitVo;
+import com.dsh.other.model.*;
 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;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
@@ -70,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>() {
@@ -98,28 +98,34 @@
     }
 
 
-    @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;
     }
 
 

--
Gitblit v1.7.1