|  |  |  | 
|---|
|  |  |  | import com.stylefeng.guns.modular.system.service.ITDriverService; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.service.impl.ServiceImpl; | 
|---|
|  |  |  | import com.stylefeng.guns.modular.system.service.ITRegionService; | 
|---|
|  |  |  | import org.apache.commons.io.FileUtils; | 
|---|
|  |  |  | import org.apache.poi.hdf.extractor.TC; | 
|---|
|  |  |  | import org.slf4j.Logger; | 
|---|
|  |  |  | import org.slf4j.LoggerFactory; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.format.annotation.DateTimeFormat; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.ui.Model; | 
|---|
|  |  |  | import org.springframework.util.CollectionUtils; | 
|---|
|  |  |  | import org.springframework.util.StringUtils; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.io.File; | 
|---|
|  |  |  | import java.io.IOException; | 
|---|
|  |  |  | import java.io.InputStream; | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | import java.net.URL; | 
|---|
|  |  |  | import java.net.URLConnection; | 
|---|
|  |  |  | import java.text.SimpleDateFormat; | 
|---|
|  |  |  | import java.time.LocalDate; | 
|---|
|  |  |  | import java.time.LocalDateTime; | 
|---|
|  |  |  | import java.time.Period; | 
|---|
|  |  |  | import java.time.ZoneId; | 
|---|
|  |  |  | import java.time.format.DateTimeFormatter; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  | import java.util.concurrent.atomic.AtomicInteger; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TRegionMapper tRegionMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TRevenueMapper tRevenueMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ITRegionService itRegionService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private HttpUtils httpUtils; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TCashWithdrawalMapper tCashWithdrawalMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Logger log = LoggerFactory.getLogger(this.getClass()); | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public EntityWrapper<TDriver> getPageList(String createTime, String phone, Integer status) { | 
|---|
|  |  |  | EntityWrapper<TDriver> wrapper = new EntityWrapper<>(); | 
|---|
|  |  |  | 
|---|
|  |  |  | // 开始,结束时间 | 
|---|
|  |  |  | if(StringUtils.hasLength(createTime)){ | 
|---|
|  |  |  | String[] split = createTime.split(" - "); | 
|---|
|  |  |  | Date startTime = DateUtil.getDate_str4(split[0]); | 
|---|
|  |  |  | Date endTime = DateUtil.getDate_str4(split[1]); | 
|---|
|  |  |  | Date startTime = DateUtil.getDate_str3(split[0]+" 00:00:00"); | 
|---|
|  |  |  | Date endTime = DateUtil.getDate_str3(split[1]+" 23:59:59"); | 
|---|
|  |  |  | wrapper.between("createTime",startTime,endTime); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | wrapper.orderBy(true,"approvalStatus"); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //累计订单量 | 
|---|
|  |  |  | List<TOrder> cumulativeOrderCount = tOrders.stream().filter(order -> tDriver.getId().equals(order.getDriverId()) | 
|---|
|  |  |  | && order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode()) && order.getState().equals(OrderStateEnum.FINISH.getCode())).collect(Collectors.toList()); | 
|---|
|  |  |  | && (order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode()) || order.getState().equals(OrderStateEnum.FINISH.getCode()))).collect(Collectors.toList()); | 
|---|
|  |  |  | tDriverResp.setCumulativeOrderCount(cumulativeOrderCount.size()); | 
|---|
|  |  |  | //当月订单量 | 
|---|
|  |  |  | List<TOrder> monthOrderCount = tOrders.stream().filter(order -> tDriver.getId().equals(order.getDriverId()) | 
|---|
|  |  |  | && order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode()) && order.getState().equals(OrderStateEnum.FINISH.getCode()) | 
|---|
|  |  |  | && (order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode()) || order.getState().equals(OrderStateEnum.FINISH.getCode())) | 
|---|
|  |  |  | && new SimpleDateFormat("yyyyMM").format(order.getCreateTime()).equals(monthDate)).collect(Collectors.toList()); | 
|---|
|  |  |  | tDriverResp.setMonthOrderCount(monthOrderCount.size()); | 
|---|
|  |  |  | // 拒单次数 | 
|---|
|  |  |  | 
|---|
|  |  |  | model.addAttribute("areaName",tDriver.getAreaName()); | 
|---|
|  |  |  | model.addAttribute("integral",tDriver.getIntegral()); | 
|---|
|  |  |  | model.addAttribute("score",tDriver.getScore()); | 
|---|
|  |  |  | model.addAttribute("source",tDriver.getSource()); | 
|---|
|  |  |  | model.addAttribute("createTime",new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(tDriver.getCreateTime())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 计算驾龄 | 
|---|
|  |  |  | if(Objects.nonNull(tDriver.getFirstCertificateTime())){ | 
|---|
|  |  |  | ZoneId zoneId = ZoneId.systemDefault(); | 
|---|
|  |  |  | LocalDate firstTime = tDriver.getFirstCertificateTime().toInstant().atZone(zoneId).toLocalDate(); | 
|---|
|  |  |  | LocalDate now = tDriver.getFirstCertificateTime().toInstant().atZone(zoneId).toLocalDate(); | 
|---|
|  |  |  | Period period = Period.between(firstTime, now); | 
|---|
|  |  |  | model.addAttribute("drivingExperience",period.getYears()); | 
|---|
|  |  |  | Period period = Period.between(LocalDate.now(), com.stylefeng.guns.modular.system.util.DateUtil.dateToLocalDate(tDriver.getFirstCertificateTime())); | 
|---|
|  |  |  | model.addAttribute("drivingExperience",Math.max(Math.abs(period.getYears()), 1)); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | model.addAttribute("drivingExperience",0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | TDriver tDriver1 = tDriverMapper.selectById(tDriver.getInviterId()); | 
|---|
|  |  |  | model.addAttribute("inviterName",tDriver1.getName()); | 
|---|
|  |  |  | model.addAttribute("inviterPhone",tDriver1.getPhone()); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | model.addAttribute("inviterName",""); | 
|---|
|  |  |  | model.addAttribute("inviterPhone",""); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | model.addAttribute("inviterName",""); | 
|---|
|  |  |  | model.addAttribute("inviterPhone",""); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 查询当前用户邀请了哪些人 | 
|---|
|  |  |  | List<TDriver> list = tDriverMapper.selectList(new EntityWrapper<TDriver>().eq("inviterId", tDriver.getId())); | 
|---|
|  |  |  | if(!CollectionUtils.isEmpty(list)){ | 
|---|
|  |  |  | List<TCashWithdrawal> tCashWithdrawals = tCashWithdrawalMapper.selectList(new EntityWrapper<TCashWithdrawal>() | 
|---|
|  |  |  | .eq("type", UserTypeEnum.DRIVER.getCode()) | 
|---|
|  |  |  | .eq("userDriverId", tDriver.getId()) | 
|---|
|  |  |  | .eq("businessType", 11) | 
|---|
|  |  |  | .eq("state", 2)); | 
|---|
|  |  |  | Optional<BigDecimal> reduce = tCashWithdrawals.stream().map(TCashWithdrawal::getAmount).reduce(BigDecimal::add); | 
|---|
|  |  |  | BigDecimal bigDecimal = BigDecimal.ZERO; | 
|---|
|  |  |  | reduce.ifPresent(bigDecimal::add); | 
|---|
|  |  |  | model.addAttribute("inviterCommission",bigDecimal.add(tDriver.getCommission())); | 
|---|
|  |  |  | model.addAttribute("inviterCount",list.size()); | 
|---|
|  |  |  | model.addAttribute("inviterCommission",0); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | model.addAttribute("inviterCommission",0); | 
|---|
|  |  |  | model.addAttribute("inviterCount",0); | 
|---|
|  |  |  | 
|---|
|  |  |  | if(!CollectionUtils.isEmpty(tOrders)){ | 
|---|
|  |  |  | //累计订单量 | 
|---|
|  |  |  | List<TOrder> cumulativeOrderCount = tOrders.stream().filter(order -> tDriver.getId().equals(order.getDriverId()) | 
|---|
|  |  |  | && order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode()) && order.getState().equals(OrderStateEnum.FINISH.getCode())).collect(Collectors.toList()); | 
|---|
|  |  |  | && (order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode()) || order.getState().equals(OrderStateEnum.FINISH.getCode()))).collect(Collectors.toList()); | 
|---|
|  |  |  | model.addAttribute("cumulativeOrderCount",cumulativeOrderCount.size()); | 
|---|
|  |  |  | //当月订单量 | 
|---|
|  |  |  | List<TOrder> monthOrderCount = tOrders.stream().filter(order -> tDriver.getId().equals(order.getDriverId()) | 
|---|
|  |  |  | && order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode()) && order.getState().equals(OrderStateEnum.FINISH.getCode()) | 
|---|
|  |  |  | && (order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode()) || order.getState().equals(OrderStateEnum.FINISH.getCode())) | 
|---|
|  |  |  | && new SimpleDateFormat("yyyyMM").format(order.getCreateTime()).equals(monthDate)).collect(Collectors.toList()); | 
|---|
|  |  |  | model.addAttribute("monthOrderCount",monthOrderCount.size()); | 
|---|
|  |  |  | // 拒单次数 | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq("userDriverId", tDriver.getId()) | 
|---|
|  |  |  | .eq("state", 2)); | 
|---|
|  |  |  | BigDecimal balance = tDriver.getBalance(); | 
|---|
|  |  |  | if(!CollectionUtils.isEmpty(tCashWithdrawals)){ | 
|---|
|  |  |  | Optional<BigDecimal> reduce = tCashWithdrawals.stream().map(TCashWithdrawal::getAmount).reduce(BigDecimal::add); | 
|---|
|  |  |  | if(reduce.isPresent()){ | 
|---|
|  |  |  | balance = balance.add(reduce.get()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<TRechargeRecord> tRechargeRecords = tRechargeRecordMapper.selectList(new EntityWrapper<TRechargeRecord>() | 
|---|
|  |  |  | .eq("type", UserTypeEnum.DRIVER.getCode()) | 
|---|
|  |  |  | .eq("userId", tDriver.getId()) | 
|---|
|  |  |  | .eq("payType", 1) | 
|---|
|  |  |  | .eq("payStatus", PayStatusEnum.FINISH.getCode())); | 
|---|
|  |  |  | if(!CollectionUtils.isEmpty(tRechargeRecords)){ | 
|---|
|  |  |  | Optional<BigDecimal> reduce = tRechargeRecords.stream().map(TRechargeRecord::getAmount).reduce(BigDecimal::add); | 
|---|
|  |  |  | if(reduce.isPresent()){ | 
|---|
|  |  |  | balance = balance.subtract(reduce.get()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //            if(!CollectionUtils.isEmpty(tCashWithdrawals)){ | 
|---|
|  |  |  | //                Optional<BigDecimal> reduce = tCashWithdrawals.stream().map(TCashWithdrawal::getAmount).reduce(BigDecimal::add); | 
|---|
|  |  |  | //                if(reduce.isPresent()){ | 
|---|
|  |  |  | //                    balance = balance.add(reduce.get()); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //            List<TRechargeRecord> tRechargeRecords = tRechargeRecordMapper.selectList(new EntityWrapper<TRechargeRecord>() | 
|---|
|  |  |  | //                    .eq("type", UserTypeEnum.DRIVER.getCode()) | 
|---|
|  |  |  | //                    .eq("userId", tDriver.getId()) | 
|---|
|  |  |  | //                    .eq("payType", 1) | 
|---|
|  |  |  | //                    .eq("payStatus", PayStatusEnum.FINISH.getCode())); | 
|---|
|  |  |  | //            if(!CollectionUtils.isEmpty(tRechargeRecords)){ | 
|---|
|  |  |  | //                Optional<BigDecimal> reduce = tRechargeRecords.stream().map(TRechargeRecord::getAmount).reduce(BigDecimal::add); | 
|---|
|  |  |  | //                if(reduce.isPresent()){ | 
|---|
|  |  |  | //                    balance = balance.subtract(reduce.get()); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | List<TRevenue> tRevenues = tRevenueMapper.selectList(new EntityWrapper<TRevenue>() | 
|---|
|  |  |  | .eq("userType", 2) | 
|---|
|  |  |  | .eq("userId", tDriver.getId())); | 
|---|
|  |  |  | Optional<BigDecimal> reduce = tRevenues.stream().map(TRevenue::getAmount).reduce(BigDecimal::add); | 
|---|
|  |  |  | // 减去充值金额 | 
|---|
|  |  |  | model.addAttribute("cumulativeIncome",balance); | 
|---|
|  |  |  | if(reduce.isPresent()){ | 
|---|
|  |  |  | model.addAttribute("cumulativeIncome", reduce.get()); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | model.addAttribute("cumulativeIncome",0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | model.addAttribute("cumulativeOrderCount",0); | 
|---|
|  |  |  | model.addAttribute("monthOrderCount",0); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public JSONObject ocr(String imgUrl) { | 
|---|
|  |  |  | File file = new File(imgUrl); | 
|---|
|  |  |  | public JSONObject ocr(File file) { | 
|---|
|  |  |  | String result = httpUtils.ocr("2", file); | 
|---|
|  |  |  | JSONObject jsonObject = JSONObject.parseObject(result); | 
|---|
|  |  |  | return jsonObject; | 
|---|
|  |  |  | return JSONObject.parseObject(result); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | commissionResp.setConnectedPersons(connectedPersons.get()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 已提现佣金  查询该司机的佣金提现记录 | 
|---|
|  |  |  | commissionResp.setWithdrawnAmount(BigDecimal.ZERO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<TCashWithdrawal> tCashWithdrawals = tCashWithdrawalMapper.selectList(new EntityWrapper<TCashWithdrawal>() | 
|---|
|  |  |  | .eq("type", UserTypeEnum.DRIVER.getCode()) | 
|---|
|  |  |  | .eq("userDriverId", driver.getId()) | 
|---|
|  |  |  | .eq("businessType", 11) | 
|---|
|  |  |  | .eq("state", 2)); | 
|---|
|  |  |  | BigDecimal bigDecimal = BigDecimal.ZERO; | 
|---|
|  |  |  | if(!CollectionUtils.isEmpty(tCashWithdrawals)){ | 
|---|
|  |  |  | Optional<BigDecimal> reduce = tCashWithdrawals.stream().map(TCashWithdrawal::getAmount).reduce(BigDecimal::add); | 
|---|
|  |  |  | if(reduce.isPresent()){ | 
|---|
|  |  |  | bigDecimal.add(reduce.get()); | 
|---|
|  |  |  | commissionResp.setWithdrawnAmount(bigDecimal); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | commissionResp.setWithdrawnAmount(bigDecimal); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 累计佣金  可提现佣金+已提现佣金 | 
|---|
|  |  |  | commissionResp.setAccumulatedCommission(BigDecimal.ZERO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | commissionResp.setAccumulatedCommission(bigDecimal.add(commissionResp.getCommission())); | 
|---|
|  |  |  | commissionRespList.add(commissionResp); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void driverCommissionDetail(Integer tDriverId, Model model) { | 
|---|
|  |  |  | public void driverCommissionDetail(Integer tDriverId, Integer levelFlag,Model model) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 查询司机 | 
|---|
|  |  |  | TDriver driver = tDriverMapper.selectById(tDriverId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | model.addAttribute("levelFlag",levelFlag); | 
|---|
|  |  |  | // 司机信息封装 | 
|---|
|  |  |  | model.addAttribute("driverId",tDriverId); | 
|---|
|  |  |  | model.addAttribute("name",driver.getName()); | 
|---|
|  |  |  | 
|---|
|  |  |  | model.addAttribute("numberPromoters",0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | model.addAttribute("connectedPersons",connectedPersons.get()); | 
|---|
|  |  |  | // 已提现佣金  查询该司机的佣金提现记录 | 
|---|
|  |  |  | model.addAttribute("withdrawnAmount",BigDecimal.ZERO); | 
|---|
|  |  |  | List<TCashWithdrawal> tCashWithdrawals = tCashWithdrawalMapper.selectList(new EntityWrapper<TCashWithdrawal>() | 
|---|
|  |  |  | .eq("type", UserTypeEnum.DRIVER.getCode()) | 
|---|
|  |  |  | .eq("userDriverId", driver.getId()) | 
|---|
|  |  |  | .eq("businessType", 11) | 
|---|
|  |  |  | .eq("state", 2)); | 
|---|
|  |  |  | BigDecimal bigDecimal = BigDecimal.ZERO; | 
|---|
|  |  |  | if(!CollectionUtils.isEmpty(tCashWithdrawals)){ | 
|---|
|  |  |  | Optional<BigDecimal> reduce = tCashWithdrawals.stream().map(TCashWithdrawal::getAmount).reduce(BigDecimal::add); | 
|---|
|  |  |  | if(reduce.isPresent()){ | 
|---|
|  |  |  | bigDecimal.add(reduce.get()); | 
|---|
|  |  |  | // 已提现佣金  查询该司机的佣金提现记录 | 
|---|
|  |  |  | model.addAttribute("withdrawnAmount",bigDecimal); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | // 已提现佣金  查询该司机的佣金提现记录 | 
|---|
|  |  |  | model.addAttribute("withdrawnAmount",bigDecimal); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        commissionResp.setWithdrawnAmount(BigDecimal.ZERO); | 
|---|
|  |  |  | // 累计佣金  可提现佣金+已提现佣金 | 
|---|
|  |  |  | model.addAttribute("accumulatedCommission",BigDecimal.ZERO); | 
|---|
|  |  |  | model.addAttribute("accumulatedCommission",bigDecimal.add(driver.getCommission())); | 
|---|
|  |  |  | //        commissionResp.setAccumulatedCommission(BigDecimal.ZERO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void getDataStatistics(Integer agentId, Model model,Map<String, Object> map) { | 
|---|
|  |  |  | // 司机总数 | 
|---|
|  |  |  | Integer driverTotal = tDriverMapper.selectCount(new EntityWrapper<TDriver>() | 
|---|
|  |  |  | .eq("agentId", agentId)); | 
|---|
|  |  |  | // 司机最近一月数量 | 
|---|
|  |  |  | LocalDateTime now = LocalDateTime.now(); | 
|---|
|  |  |  | LocalDateTime localDateTime = now.minusMonths(1); | 
|---|
|  |  |  | Integer driverMonthTotal = tDriverMapper.selectCount(new EntityWrapper<TDriver>() | 
|---|
|  |  |  | .eq("agentId", agentId) | 
|---|
|  |  |  | .between("createTime", localDateTime, now)); | 
|---|
|  |  |  | model.addAttribute("driverTotal",driverTotal); | 
|---|
|  |  |  | model.addAttribute("driverMonthTotal",driverMonthTotal); | 
|---|
|  |  |  | map.put("driverTotal",driverTotal); | 
|---|
|  |  |  | map.put("driverMonthTotal",driverMonthTotal); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void getDataStatisticsByIds(List<Integer> ids, Model model, Map<String, Object> map) { | 
|---|
|  |  |  | // 司机总数 | 
|---|
|  |  |  | Integer driverTotal = tDriverMapper.selectCount(new EntityWrapper<TDriver>() | 
|---|
|  |  |  | .in("agentId", ids)); | 
|---|
|  |  |  | // 司机最近一月数量 | 
|---|
|  |  |  | LocalDateTime now = LocalDateTime.now(); | 
|---|
|  |  |  | LocalDateTime localDate = now.minusMonths(1); | 
|---|
|  |  |  | Integer driverMonthTotal = tDriverMapper.selectCount(new EntityWrapper<TDriver>() | 
|---|
|  |  |  | .in("agentId", ids) | 
|---|
|  |  |  | .between("createTime", localDate, now)); | 
|---|
|  |  |  | model.addAttribute("driverTotal",driverTotal); | 
|---|
|  |  |  | model.addAttribute("driverMonthTotal",driverMonthTotal); | 
|---|
|  |  |  | map.put("driverTotal",driverTotal); | 
|---|
|  |  |  | map.put("driverMonthTotal",driverMonthTotal); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|