From 624c9eec90d59297800f03276f8518daa1bd9f94 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期五, 04 八月 2023 09:23:02 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java |   41 +++++++++++++++++++++++++++++++++++------
 1 files changed, 35 insertions(+), 6 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 0ee10ba..5290264 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,6 +1,7 @@
 package com.dsh.other.controller;
 
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.dsh.other.entity.Store;
 import com.dsh.other.feignclient.model.*;
@@ -44,8 +45,11 @@
 
     @PostMapping("/base/protocol/storeDetail/nearbyStore")
     public List<StoreInfo> getAllNearbyStoreList(@RequestBody GetAllNearbyStoreList list ){
-        String current = list.getLongitude()+","+list.getLatitude();
         List<StoreInfo> storeInfos = new ArrayList<>();
+        if (ToolUtil.isEmpty(list.getLongitude()) && ToolUtil.isEmpty(list.getLatitude())){
+            return storeInfos;
+        }
+        String current = list.getLongitude()+","+list.getLatitude();
         String cityCode = "";
         try {
             Map<String, String> geocode = gdMapGeocodingUtil.geocode(list.getLongitude(), list.getLatitude());
@@ -62,11 +66,17 @@
                 String storeLat = store.getLat();
                 String result = storeLon+","+storeLat;
                 String distanceTOKilometer = gdMapGeocodingUtil.getDistanceTOKilometer(current, result);
+                long l = 0;
+                try {
+                    l = Long.parseLong(distanceTOKilometer);
+                }catch (Exception e){
+                    l = 0;
+                }
                 StoreInfo info = new StoreInfo();
                 info.setStoreId(store.getId());
                 info.setStoreName(store.getName());
                 info.setStoreImg(store.getRealPicture());
-                info.setDistance(Long.parseLong(distanceTOKilometer));
+                info.setDistance(l);
                 info.setStoreAddr(store.getAddress());
                 info.setLatitude(storeLat);
                 info.setLongitude(storeLon);
@@ -89,12 +99,11 @@
      * @return
      */
     @PostMapping("/base/protocol/storeDetail/distanceCal")
-    public long calculateDistance(@RequestBody GetDistanceVo distanceVo){
+    public String 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);
+        return gdMapGeocodingUtil.getDistanceTOKilometer(current, result);
     }
 
 
@@ -105,12 +114,16 @@
                 .eq("state",1 )
                 .eq("cityCode",citycodeResp.getCityCode()));
         if (list.size() > 0 ){
+            if (ToolUtil.isEmpty(citycodeResp.getLongitude()) && ToolUtil.isEmpty(citycodeResp.getLatitude())){
+                return detailLists;
+            }
             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()){
+//                取5公里范围内的门店
+                if ( l > 5){
                     continue;
                 }
                 StoreDetailList detailList = new StoreDetailList();
@@ -149,6 +162,22 @@
     }
 
 
+    /**
+     * 获取门店列表
+     * @return
+     */
+    @ResponseBody
+    @PostMapping("/store/queryStoreByIds")
+    public List<Store> queryStoreByIds(List<Integer> ids){
+        try {
+            return storeService.list(new LambdaQueryWrapper<Store>()
+                    .in(Store::getId,ids));
+        }catch (Exception e){
+            e.printStackTrace();
+            return new ArrayList<>();
+        }
+    }
+
 
 
 

--
Gitblit v1.7.1