From 12b75ea8869fa6e65b1bd53d4460328e73a66125 Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期三, 22 三月 2023 22:35:20 +0800 Subject: [PATCH] 新增加司机端接口 --- driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderServiceImpl.java | 151 ++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 146 insertions(+), 5 deletions(-) diff --git a/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderServiceImpl.java b/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderServiceImpl.java index dcb3bf1..21016f6 100644 --- a/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderServiceImpl.java +++ b/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderServiceImpl.java @@ -91,6 +91,9 @@ @Autowired private IAccountChangeDetailService accountChangeDetailService; + @Autowired + private IRevenueService revenueService; + private Map<String, Timer> timerMap = new HashMap<>(); @@ -173,7 +176,6 @@ city = null != weatherCity ? weatherCity.getId().toString() : ""; } order = getOrderPrice(1, d, 0, order, city); - order.setHallOrder(0); order.setState(null == order.getDriverId() ? 101 : 102); order.setStatus(1); order.setCreateTime(new Date()); @@ -517,9 +519,12 @@ pageNum = (pageNum - 1) * pageSize; List<HallOrderList> hallOrderLists = this.baseMapper.queryOrderHall(pageNum, pageSize); hallOrderLists.forEach(hallOrderList -> { - Map<String, Double> distance = GeodesyUtil.getDistance(hallOrderList.getStartLng() + "," + hallOrderList.getStartLat(), hallOrderList.getEndLng() + "," + hallOrderList.getEndLat()); - Double wgs84 = distance.get("WGS84"); - hallOrderList.setCurrentDistance(wgs84); + hallOrderList.setCurrentDistance(0D); + if(ToolUtil.isNotEmpty(hallOrderList.getEndLng())){ + Map<String, Double> distance = GeodesyUtil.getDistance(hallOrderList.getStartLng() + "," + hallOrderList.getStartLat(), hallOrderList.getEndLng() + "," + hallOrderList.getEndLat()); + Double wgs84 = distance.get("WGS84"); + hallOrderList.setCurrentDistance(wgs84); + } }); return hallOrderLists; } @@ -557,6 +562,7 @@ Integer num10 = JSON.parseObject(systemConfig.getContent()).getInteger("num10"); if (num10 > 0) { AccountChangeDetail accountChangeDetail = new AccountChangeDetail(); + accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3)); accountChangeDetail.setUserType(2); accountChangeDetail.setUserId(order.getDriverId()); accountChangeDetail.setType(2); @@ -685,10 +691,13 @@ orderInfoWarpper.setBalance(appUser.getAccountBalance()); orderInfoWarpper.setCurrentDistance(0D); String value = redisUtil.getValue("DRIVER" + uid); + orderInfoWarpper.setPickUpTime(0); if(ToolUtil.isNotEmpty(value)){ Map<String, Double> distance = GeodesyUtil.getDistance(orderInfoWarpper.getStartLng() + "," + orderInfoWarpper.getStartLat(), value); Double wgs84 = distance.get("WGS84"); - orderInfoWarpper.setCurrentDistance(wgs84); + orderInfoWarpper.setCurrentDistance(null == wgs84 ? 0d : wgs84); + Map<String, String> distance1 = MapUtil.getDistance(orderInfoWarpper.getStartLng() + "," + orderInfoWarpper.getStartLat(), value, 0); + orderInfoWarpper.setPickUpTime(Integer.valueOf(distance1.get("duration")) / 60); } return orderInfoWarpper; } @@ -789,6 +798,7 @@ Integer num5 = JSON.parseObject(systemConfig.getContent()).getInteger("num5"); if(num5 > 0){ AccountChangeDetail accountChangeDetail = new AccountChangeDetail(); + accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3)); accountChangeDetail.setUserType(2); accountChangeDetail.setUserId(order.getDriverId()); accountChangeDetail.setType(2); @@ -802,6 +812,7 @@ Integer num8 = JSON.parseObject(systemConfig.getContent()).getInteger("num8"); if(num8 > 0){ AccountChangeDetail accountChangeDetail = new AccountChangeDetail(); + accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3)); accountChangeDetail.setUserType(2); accountChangeDetail.setUserId(order.getDriverId()); accountChangeDetail.setType(2); @@ -830,6 +841,7 @@ } Driver driver1 = driverService.selectById(appUser.getInviterId()); AccountChangeDetail accountChangeDetail = new AccountChangeDetail(); + accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3)); accountChangeDetail.setUserType(2); accountChangeDetail.setUserId(driver1.getId()); accountChangeDetail.setType(2); @@ -1104,4 +1116,133 @@ pageNum = (pageNum - 1) * pageSize; return this.baseMapper.queryInviteList(driverId, time, pageNum, pageSize); } + + + /** + * 获取业绩汇总数据 + * @param driverId + * @return + * @throws Exception + */ + @Override + public PerformanceSummaryWarpper queryPerformanceSummary(Integer driverId, Integer type, String time, Integer dayType) throws Exception { + Driver driver = driverService.selectById(driverId); + PerformanceSummaryWarpper performanceSummaryWarpper = new PerformanceSummaryWarpper(); + BeanUtils.copyProperties(driver, performanceSummaryWarpper); + Double amount = revenueService.queryTotalAmount(driverId); + performanceSummaryWarpper.setGrossIncome(amount); + List<Integer> state = Arrays.asList(107, 108, 109); + int count = this.selectCount(new EntityWrapper<Order>().eq("driverId", driverId).in("state", state).eq("status", 1)); + performanceSummaryWarpper.setTotalOrder(count); + List<PerformanceRankingWarpper> list = new ArrayList<>(); + int position = 0; + Double d = 0D; + List<PerformanceRankingWarpper> performanceRankingWarppers = null; + if(type == 1){//订单量 + performanceRankingWarppers = this.baseMapper.queryDriverRank(time, dayType); + } + if(type == 2){//佣金 + performanceRankingWarppers = revenueService.queryDriverRank(2, time, dayType); + } + if(type == 3){//收入 + performanceRankingWarppers = revenueService.queryDriverRank(null, time, dayType); + } + for (int i = 0; i < performanceRankingWarppers.size(); i++) { + PerformanceRankingWarpper performanceRankingWarpper = performanceRankingWarppers.get(i); + Double amountOfData = performanceRankingWarpper.getAmountOfData(); + if(amountOfData.compareTo(d) != 0){ + position++; + d = amountOfData; + } + if(position <= 10){ + list.add(performanceRankingWarpper); + } + if(performanceRankingWarpper.getDriverId().compareTo(driverId) == 0){ + break; + } + } + performanceSummaryWarpper.setPosition(position); + performanceSummaryWarpper.setList(list); + return performanceSummaryWarpper; + } + + + /** + * 获取我的业绩 + * @param driverId + * @param time + * @return + * @throws Exception + */ + @Override + public List<MyAchievementWarpper> queryMyAchievement(Integer driverId, String time) throws Exception { + List<MyAchievementWarpper> list = new ArrayList<>(); + time = time.replaceAll("-", "年") + "月"; + //订单量 + List<PerformanceRankingWarpper> performanceRankingWarppers = performanceRankingWarppers = this.baseMapper.queryDriverRank(time, 2); + int position = 0; + Double d = 0D; + for (int i = 0; i < performanceRankingWarppers.size(); i++) { + PerformanceRankingWarpper performanceRankingWarpper = performanceRankingWarppers.get(i); + Double amountOfData = performanceRankingWarpper.getAmountOfData(); + if(amountOfData.compareTo(d) != 0){ + position++; + d = amountOfData; + } + if(performanceRankingWarpper.getDriverId().compareTo(driverId) == 0){ + break; + } + } + MyAchievementWarpper myAchievementWarpper = new MyAchievementWarpper(); + myAchievementWarpper.setType("订单"); + myAchievementWarpper.setTime(time); + myAchievementWarpper.setRank(position); + myAchievementWarpper.setAmountOfData(d); + list.add(myAchievementWarpper); + + //收入 + performanceRankingWarppers = revenueService.queryDriverRank(null, time, 2); + position = 0; + d = 0D; + for (int i = 0; i < performanceRankingWarppers.size(); i++) { + PerformanceRankingWarpper performanceRankingWarpper = performanceRankingWarppers.get(i); + Double amountOfData = performanceRankingWarpper.getAmountOfData(); + if(amountOfData.compareTo(d) != 0){ + position++; + d = amountOfData; + } + if(performanceRankingWarpper.getDriverId().compareTo(driverId) == 0){ + break; + } + } + myAchievementWarpper = new MyAchievementWarpper(); + myAchievementWarpper.setType("收入"); + myAchievementWarpper.setTime(time); + myAchievementWarpper.setRank(position); + myAchievementWarpper.setAmountOfData(d); + list.add(myAchievementWarpper); + + //佣金 + performanceRankingWarppers = revenueService.queryDriverRank(2, time, 2); + position = 0; + d = 0D; + for (int i = 0; i < performanceRankingWarppers.size(); i++) { + PerformanceRankingWarpper performanceRankingWarpper = performanceRankingWarppers.get(i); + Double amountOfData = performanceRankingWarpper.getAmountOfData(); + if(amountOfData.compareTo(d) != 0){ + position++; + d = amountOfData; + } + if(performanceRankingWarpper.getDriverId().compareTo(driverId) == 0){ + break; + } + } + myAchievementWarpper = new MyAchievementWarpper(); + myAchievementWarpper.setType("佣金"); + myAchievementWarpper.setTime(time); + myAchievementWarpper.setRank(position); + myAchievementWarpper.setAmountOfData(d); + list.add(myAchievementWarpper); + return list; + } } -- Gitblit v1.7.1