From c4a098e3f88bc5071e36b92b9e5dcceb51129957 Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期四, 01 六月 2023 23:25:07 +0800 Subject: [PATCH] 同步后台代码 --- management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java | 68 ++++++++++++++++++++++++++++++++-- 1 files changed, 64 insertions(+), 4 deletions(-) diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java index a4789e6..ab3dabf 100644 --- a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/THomePageController.java @@ -1,20 +1,27 @@ package com.stylefeng.guns.modular.system.controller.general; +import com.alibaba.fastjson.JSONArray; +import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; +import com.stylefeng.guns.GunsApplication; import com.stylefeng.guns.core.base.controller.BaseController; import com.stylefeng.guns.core.common.constant.state.Order; import com.stylefeng.guns.core.shiro.ShiroKit; import com.stylefeng.guns.core.util.ToolUtil; import com.stylefeng.guns.modular.system.controller.resp.TOrderServerResp; +import com.stylefeng.guns.modular.system.controller.util.HttpUtils; import com.stylefeng.guns.modular.system.enums.OrderStateEnum; import com.stylefeng.guns.modular.system.enums.StatusEnum; import com.stylefeng.guns.modular.system.model.TAgent; import com.stylefeng.guns.modular.system.model.TDriver; import com.stylefeng.guns.modular.system.model.TDriverWork; import com.stylefeng.guns.modular.system.model.TOrder; +import com.stylefeng.guns.modular.system.pojo.GaoDePoJo; import com.stylefeng.guns.modular.system.service.*; import com.stylefeng.guns.modular.system.util.DateUtil; import com.stylefeng.guns.modular.system.util.RedisUtil; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; @@ -28,6 +35,7 @@ import java.time.LocalDate; import java.time.Period; import java.util.*; +import java.util.concurrent.atomic.AtomicInteger; import java.util.stream.Collectors; /** @@ -39,6 +47,8 @@ @Controller @RequestMapping("/tHomePage") public class THomePageController extends BaseController { + + private final static Logger log = LoggerFactory.getLogger(THomePageController.class); @Autowired private IUserService userService; @@ -52,6 +62,10 @@ private ITRevenueService tRevenueService; @Autowired private ITDriverWorkService tDriverWorkService; + @Autowired + private GaoDePoJo gaoDePoJo; + @Autowired + private HttpUtils httpUtils; @Autowired private RedisUtil redisUtil; @@ -74,6 +88,10 @@ .ne("status", StatusEnum.DELETE.getCode()) .ne("principal","")); model.addAttribute("agentList",agentList); + // 查询广东省广州市的地址解析 + Map<String, String> map = geocode("广东省广州市"); + model.addAttribute("addressLon",map.get("addressLon")); + model.addAttribute("addressLat",map.get("addressLat")); // 查询广东全区域数据 查询广东所有的代理商 List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>() .eq("provinceCode", "440000")); @@ -130,7 +148,15 @@ } model.addAttribute("allList",list); List<List<String>> list1 = new ArrayList<>(); + AtomicInteger count = new AtomicInteger(0); for (TDriver tDriver : onLineDriver) { + + String value1 = redisUtil.getValue("DRIVER_" + tDriver.getPhone()); + String value2 = redisUtil.getValue(value1); + if(ToolUtil.isNotEmpty(value2)){ + count.addAndGet(1); + } + List<String> obj = new ArrayList<>(3); String value = redisUtil.getValue("DRIVER" + tDriver.getId()); if(ToolUtil.isEmpty(value)){ @@ -141,7 +167,7 @@ obj.add(String.valueOf(tDriver.getServerStatus()));// 服务状态 list1.add(obj); } - model.addAttribute("onLineDriverCount",list1.size()); + model.addAttribute("onLineDriverCount",count.get()); // 拿到所有在线司机地址 model.addAttribute("onLineDriver",list1); return PREFIX + "tHomePageMap.html"; @@ -150,7 +176,7 @@ @RequestMapping("/getMap") @ResponseBody public Object getMap(Integer agentId,Integer type,Model model) { - Integer objectId = ShiroKit.getUser().getObjectId(); + Integer objectId = Objects.requireNonNull(ShiroKit.getUser()).getObjectId(); Integer roleType = ShiroKit.getUser().getRoleType(); if(roleType == 3 && Objects.nonNull(objectId)){ agentId = objectId; @@ -163,6 +189,11 @@ map.put("agentList",agentList); if(Objects.nonNull(agentId)){ + // 查询当前代理商 + TAgent tAgent = tAgentService.selectById(agentId); + Map<String, String> mapAddress = geocode(tAgent.getProvinceName()+tAgent.getCityName()); + map.put("addressLon",mapAddress.get("addressLon")); + map.put("addressLat",mapAddress.get("addressLat")); // 查询统计在线司机,待接单,服务中,已完成,已取消 List<TDriver> onLineDriver = tDriverService.selectList(new EntityWrapper<TDriver>() .eq("agentId", agentId)); @@ -244,6 +275,10 @@ // 查询统计在线司机,待接单,服务中,已完成,已取消 List<TDriver> onLineDriver = tDriverService.selectList(new EntityWrapper<TDriver>() .in("agentId", ids)); + + Map<String, String> mapAddress = geocode("广东省广州市"); + map.put("addressLon",mapAddress.get("addressLon")); + map.put("addressLat",mapAddress.get("addressLat")); List<TAgent> tAgentAllList = tAgentService.selectList(new EntityWrapper<TAgent>()); List<Integer> allIds = tAgentAllList.stream().map(TAgent::getId).collect(Collectors.toList()); @@ -618,8 +653,7 @@ }else { // 业绩排名 performanceTable // 查询广东全区域数据 查询广东所有的代理商 - List<TAgent> tAgentList = tAgentService.selectList(new EntityWrapper<TAgent>() - .eq("provinceCode", "440000")); + List<TAgent> tAgentList = tAgentService.selectList(null); List<Integer> ids = tAgentList.stream().map(TAgent::getId).collect(Collectors.toList()); if (1 == type){ // 单量 @@ -660,4 +694,30 @@ return map; } + private Map<String,String> geocode(String address){ + Map<String,String> map = new HashMap<>(2); + try { + String url = "https://restapi.amap.com/v3/geocode/geo?address=" + address + "&key=" + gaoDePoJo.getKey(); + url = url.trim().replace("#", "").replace(" ", ""); + String result = httpUtils.get(url); + log.info("地址解析结果:{}", result); + JSONObject jsonObject = JSONObject.parseObject(result); + if (jsonObject.getString("status").equals("1")) { + String geocodes = jsonObject.getString("geocodes"); + JSONArray objects = JSONObject.parseArray(geocodes); + String string = objects.getString(0); + JSONObject geocodesObject = JSONObject.parseObject(string); + log.info("地址数据:{}", geocodesObject); + String location = geocodesObject.getString("location"); + String[] split = location.split(","); + map.put("addressLon",split[0]); + map.put("addressLat",split[1]); + } + } catch (Exception e) { + log.error("解析地址失败============:{}", e.getMessage()); + e.printStackTrace(); + } + return map; + } + } -- Gitblit v1.7.1