From c18ec3846c8483975de2224c1ecac9470e9b2804 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期三, 16 八月 2023 19:21:36 +0800
Subject: [PATCH] 同步代码

---
 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java |  644 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 620 insertions(+), 24 deletions(-)

diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java
index a47b5e0..cbb4924 100644
--- a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java
+++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java
@@ -1,64 +1,660 @@
 package com.stylefeng.guns.modular.system.service.impl;
 
-import com.baomidou.mybatisplus.plugins.Page;
-import com.stylefeng.guns.modular.system.model.TDriver;
-import com.stylefeng.guns.modular.system.dao.TDriverMapper;
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.mapper.EntityWrapper;
+import com.baomidou.mybatisplus.mapper.Wrapper;
+import com.stylefeng.guns.core.base.tips.SuccessTip;
+import com.stylefeng.guns.core.shiro.ShiroKit;
+import com.stylefeng.guns.core.util.DateUtil;
+import com.stylefeng.guns.core.util.ToolUtil;
+import com.stylefeng.guns.modular.system.controller.resp.TDriverCommissionResp;
+import com.stylefeng.guns.modular.system.controller.resp.TDriverResp;
+import com.stylefeng.guns.modular.system.controller.util.HttpUtils;
+import com.stylefeng.guns.modular.system.controller.util.UUIDUtil;
+import com.stylefeng.guns.modular.system.dao.*;
+import com.stylefeng.guns.modular.system.enums.OrderStateEnum;
+import com.stylefeng.guns.modular.system.enums.PayStatusEnum;
+import com.stylefeng.guns.modular.system.enums.StatusEnum;
+import com.stylefeng.guns.modular.system.enums.UserTypeEnum;
+import com.stylefeng.guns.modular.system.model.*;
+import com.stylefeng.guns.modular.system.service.IDriverOnlineTimeService;
 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.util.List;
-import java.util.Map;
+import javax.annotation.Resource;
+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;
 
 /**
  * <p>
- * 司机表 服务实现类
+ * 司机基础信息 服务实现类
  * </p>
  *
- * @author 吕雪
- * @since 2020-06-04
+ * @author stylefeng
+ * @since 2023-02-20
  */
 @Service
 public class TDriverServiceImpl extends ServiceImpl<TDriverMapper, TDriver> implements ITDriverService {
 
+    @Resource
+    private TAgentMapper tAgentMapper;
+    @Resource
+    private TBranchOfficeMapper tBranchOfficeMapper;
+    @Resource
+    private TOrderMapper tOrderMapper;
+    @Resource
+    private TDriverMapper tDriverMapper;
+    @Resource
+    private TAppUserMapper tAppUserMapper;
+    @Resource
+    private TOrderRefusalMapper tOrderRefusalMapper;
+    @Resource
+    private TRegionMapper tRegionMapper;
+    @Resource
+    private TRevenueMapper tRevenueMapper;
+    @Autowired
+    private ITRegionService itRegionService;
+    @Autowired
+    private HttpUtils httpUtils;
+
+    @Resource
+    private TRechargeRecordMapper tRechargeRecordMapper;
+    @Resource
+    private TCashWithdrawalMapper tCashWithdrawalMapper;
+
+    @Autowired
+    private IDriverOnlineTimeService driverOnlineTimeService;
+
+    private Logger log = LoggerFactory.getLogger(this.getClass());
     @Override
-    public List<Map<String, Object>> getAuthDriverList(Page<Map<String, Object>> page, String beginTime, String endTime, String companyName, String phone, String account, Integer addType, Integer authState) {
-        return this.baseMapper.getAuthDriverList(page, beginTime, endTime, companyName, phone, account, addType, authState);
+    public EntityWrapper<TDriver> getPageList(String createTime, String phone, Integer status) {
+        EntityWrapper<TDriver> wrapper = new EntityWrapper<>();
+        // 手机号
+        if(StringUtils.hasLength(phone)){
+            wrapper.like("phone",phone);
+        }
+        // 状态
+        if(Objects.nonNull(status)){
+            wrapper.eq("status",status);
+        }
+        // 开始,结束时间
+        if(StringUtils.hasLength(createTime)){
+            String[] split = createTime.split(" - ");
+            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");
+        // 判断是否为代理商或者分公司
+        if(Objects.requireNonNull(ShiroKit.getUser()).getRoleType() == 2){
+            // 分公司
+            wrapper.eq("branchOfficeId",ShiroKit.getUser().getObjectId());
+        }
+        if(Objects.requireNonNull(ShiroKit.getUser()).getRoleType() == 3){
+            // 代理商
+            wrapper.eq("agentId",ShiroKit.getUser().getObjectId());
+        }
+        return wrapper;
     }
 
     @Override
-    public Map<String, Object> getDriverById(Integer driverId) {
-        return this.baseMapper.getDriverById(driverId);
+    public List<TDriverResp> getTDriverResp(List<TDriver> tDrivers) {
+        List<TDriverResp> tDriverRespList = new ArrayList<>(tDrivers.size());
+
+        List<TOrder> tOrders = tOrderMapper.selectList(new EntityWrapper<TOrder>());
+
+        String monthDate = new SimpleDateFormat("yyyyMM").format(new Date());
+
+        for (TDriver tDriver : tDrivers) {
+            TDriverResp tDriverResp = new TDriverResp();
+            BeanUtils.copyProperties(tDriver,tDriverResp);
+
+            if(Objects.nonNull(tDriver.getBackgroundBalance()) && Objects.nonNull(tDriver.getBalance()) && Objects.nonNull(tDriver.getCouponBalance())){
+                // 设置余额
+                tDriverResp.setBalance(tDriver.getBackgroundBalance().add(tDriver.getBalance()).add(tDriver.getCouponBalance()));
+            }
+
+            // 所属代理商
+            TAgent tAgent = tAgentMapper.selectById(tDriver.getAgentId());
+            if(Objects.nonNull(tAgent)){
+                tDriverResp.setAgentName(tAgent.getPrincipal());
+            }
+            //所属分公司
+            TBranchOffice tBranchOffice = tBranchOfficeMapper.selectById(tDriver.getBranchOfficeId());
+            if(Objects.nonNull(tBranchOffice)){
+                tDriverResp.setBranchName(tBranchOffice.getPrincipal());
+            }
+            //累计订单量
+            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());
+            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()))
+            && new SimpleDateFormat("yyyyMM").format(order.getCreateTime()).equals(monthDate)).collect(Collectors.toList());
+            tDriverResp.setMonthOrderCount(monthOrderCount.size());
+            // 拒单次数
+            List<TOrderRefusal> driverRefusalList = tOrderRefusalMapper.selectList(new EntityWrapper<TOrderRefusal>().eq("driver_id", tDriver.getId()));
+            tDriverResp.setRefusalCount(driverRefusalList.size());
+
+            tDriverRespList.add(tDriverResp);
+        }
+        return tDriverRespList;
     }
 
     @Override
-    public List<Map<String, Object>> getDriverList(Page<Map<String, Object>> page, Integer roleType,Integer nowUserId,String beginTime, String endTime, String companyName, String phone, String name, Integer addType, Integer authState) {
-        return this.baseMapper.getDriverList(page,roleType,nowUserId, beginTime, endTime, companyName, phone, name, addType, authState);
+    public void auditPage(Integer id, Model model) {
+
+        TDriver tDriver = tDriverMapper.selectById(id);
+
+        model.addAttribute("id",tDriver.getId());
+        model.addAttribute("code",tDriver.getCode());
+        model.addAttribute("name",tDriver.getName());
+        model.addAttribute("avatar",tDriver.getAvatar());
+        model.addAttribute("phone",tDriver.getPhone());
+        model.addAttribute("sex",tDriver.getSex());
+        model.addAttribute("driverLicenseNumber",tDriver.getDriverLicenseNumber());
+        model.addAttribute("driverLicense",tDriver.getDriverLicense());
+        model.addAttribute("idcard",tDriver.getIdcard());
+        model.addAttribute("idcardFront",tDriver.getIdcardFront());
+        model.addAttribute("idcardBack",tDriver.getIdcardBack());
+        model.addAttribute("emergencyContact",tDriver.getEmergencyContact());
+        model.addAttribute("emergencyPhone",tDriver.getEmergencyPhone());
+        model.addAttribute("provinceName",tDriver.getProvinceName());
+        model.addAttribute("cityName",tDriver.getCityName());
+        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()));
+        model.addAttribute("balance", tDriver.getBalance().add(tDriver.getCouponBalance()).add(tDriver.getBackgroundBalance()).add(tDriver.getCommission()).doubleValue());
+
+        // 计算驾龄
+        if(Objects.nonNull(tDriver.getFirstCertificateTime())){
+            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);
+        }
+
+        // 所属代理商
+        TAgent tAgent = tAgentMapper.selectById(tDriver.getAgentId());
+        if(Objects.nonNull(tAgent)){
+            model.addAttribute("agentName",tAgent.getPrincipal());
+        }else {
+            model.addAttribute("agentName","");
+        }
+        //所属分公司
+        TBranchOffice tBranchOffice = tBranchOfficeMapper.selectById(tDriver.getBranchOfficeId());
+        if(Objects.nonNull(tBranchOffice)){
+            model.addAttribute("principal",tBranchOffice.getPrincipal());
+        }else {
+            model.addAttribute("principal","");
+        }
+
+        if(Objects.nonNull(tDriver.getInviterId())){
+            // 查询邀请人
+            if(Objects.nonNull(tDriver.getInviterType()) && 1 == tDriver.getInviterType()){
+                TAppUser tAppUser = tAppUserMapper.selectById(tDriver.getInviterId());
+                model.addAttribute("inviterName",tAppUser.getNickname());
+                model.addAttribute("inviterPhone",tAppUser.getPhone());
+            }else if(Objects.nonNull(tDriver.getInviterType()) && 2 == tDriver.getInviterType()){
+                TDriver tDriver1 = tDriverMapper.selectById(tDriver.getInviterId());
+                model.addAttribute("inviterName",tDriver1.getName());
+                model.addAttribute("inviterPhone",tDriver1.getPhone());
+            }
+        }else {
+            model.addAttribute("inviterName","");
+            model.addAttribute("inviterPhone","");
+        }
+
+        // 查询当前用户邀请了哪些人
+        List<TDriver> list = tDriverMapper.selectList(new EntityWrapper<TDriver>().eq("inviterId", tDriver.getId()));
+        List<TAppUser> tAppUsers = tAppUserMapper.selectList(new EntityWrapper<TAppUser>().eq("inviterType", 2).eq("inviterId", tDriver.getId()));
+        model.addAttribute("inviterDriverCount",list.size());
+        model.addAttribute("inviterUserCount",tAppUsers.size());
+        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()));
+
+        //累计订单量
+        Integer cumulativeOrderCount = tOrderMapper.selectCount(new EntityWrapper<TOrder>().eq("driverId", tDriver.getId()).eq("status", 1));
+        model.addAttribute("cumulativeOrderCount", cumulativeOrderCount);
+        //有效订单数
+        Integer effectiveOrderCount = tOrderMapper.selectCount(new EntityWrapper<TOrder>().eq("driverId", tDriver.getId()).eq("status", 1).in("state", Arrays.asList(106, 107, 108)));
+        model.addAttribute("effectiveOrderCount", effectiveOrderCount);
+        model.addAttribute("commission", tDriver.getCommission().doubleValue());
+        // 拒单次数
+        List<TOrderRefusal> driverRefusalList = tOrderRefusalMapper.selectList(new EntityWrapper<TOrderRefusal>().eq("driver_id", tDriver.getId()));
+        model.addAttribute("refusalCount",driverRefusalList.size());
+        List<TRevenue> tRevenues = tRevenueMapper.selectList(new EntityWrapper<TRevenue>()
+                .eq("userType", 2)
+                .eq("userId", tDriver.getId()));
+        Optional<BigDecimal> reduce1 = tRevenues.stream().map(TRevenue::getAmount).reduce(BigDecimal::add);
+        // 减去充值金额
+        if(reduce1.isPresent()){
+            model.addAttribute("cumulativeIncome", reduce1.get());
+        }else {
+            model.addAttribute("cumulativeIncome",0);
+        }
+        //消单次数
+        Integer cancelOrderCount = tOrderMapper.selectCount(new EntityWrapper<TOrder>().eq("driverId", tDriver.getId()).eq("status", 1).in("state", Arrays.asList(301)));
+        model.addAttribute("cancelOrderCount",cancelOrderCount);
+        //有效在线时长
+        Long onlineTime = tDriver.getOnlineTime();
+        Long s = onlineTime % 60;
+        Long m = onlineTime / 60;
+        model.addAttribute("onlineTime", (m < 10 ? ("0" + m) : m) + ":" + (s < 10 ? ("0" + s) : s));
     }
 
     @Override
-    public String getUseCarIdStr(Integer carId) {
-        return this.baseMapper.getUseCarIdStr(carId);
+    public JSONObject ocr(File file) {
+        String result = httpUtils.ocr("2", file);
+        return JSONObject.parseObject(result);
     }
 
     @Override
-    public List<Map<String, Object>> getCanSelectCarList(Page<Map<String, Object>> page, Integer roleType, Integer nowUserId, String carIdStr, String carLicensePlate, String brandName, String modelName, String color, String serverStr) {
-        return this.baseMapper.getCanSelectCarList(page, roleType, nowUserId, carIdStr, carLicensePlate, brandName, modelName, color, serverStr);
+    public Object addOrUpdate(TDriver tDriver) {
+        // 对省市区做处理
+        String[] split = tDriver.getAreaId().split("/");
+        // 查询省市
+        // 黑龙江省/大兴安岭地区
+        // 702/852
+        TRegion province = tRegionMapper.selectById(split[0]);
+        tDriver.setProvinceName(province.getName());
+        tDriver.setProvinceCode(province.getCode());
+
+        TRegion city = tRegionMapper.selectById(split[1]);
+        if(Objects.isNull(city)){
+            city = itRegionService.selectOne(new EntityWrapper<TRegion>().eq("name",split[1]));
+        }
+        tDriver.setCityName(city.getName());
+        tDriver.setCityCode(city.getCode());
+
+//        TRegion area = tRegionMapper.selectById(split[2]);
+//        if(Objects.isNull(area)){
+//            area = itRegionService.selectOne(new EntityWrapper<TRegion>().eq("name",split[2]));
+//        }
+//        tDriver.setAreaName(area.getName());
+//        tDriver.setAreaCode(area.getCode());
+        TRegion area = null;
+        if(split.length>2){
+            area = itRegionService.selectById(split[2]);
+            if(Objects.isNull(area)){
+                area = itRegionService.selectOne(new EntityWrapper<TRegion>().eq("name",split[2]));
+            }
+            tDriver.setAreaName(area.getName());
+            tDriver.setAreaCode(area.getCode());
+        }else {
+            tDriver.setAreaName(city.getName());
+            tDriver.setAreaCode(city.getCode());
+        }
+
+        // 通过省市查询代理商
+        List<TAgent> tAgent = tAgentMapper.selectList(new EntityWrapper<TAgent>().eq("provinceCode", province.getCode())
+                .eq("cityCode", city.getCode())
+                .eq("status", StatusEnum.NORMAL.getCode())
+                .last("LIMIT 1"));
+        if(!CollectionUtils.isEmpty(tAgent)){
+            tDriver.setAgentId(tAgent.get(0).getId());
+        }else {
+            return new SuccessTip(500, "该区域代理商被冻结或不存在");
+        }
+        if(StringUtils.hasLength(tDriver.getInviterPhone())){
+            // 查询邀约人(司机端)
+            List<TDriver> emergencyDriver = tDriverMapper.selectList(new EntityWrapper<TDriver>().eq("phone", tDriver.getInviterPhone())
+                    .last("LIMIT 1"));
+            if(!CollectionUtils.isEmpty(emergencyDriver)){
+                tDriver.setInviterId(emergencyDriver.get(0).getId());
+                tDriver.setInviterType(2);
+            }else {
+                return new SuccessTip(500, "该邀约人:"+tDriver.getInviterName()+"不存在");
+            }
+        }
+        List<TBranchOffice> tBranchOffice;
+        if(split.length>2){
+            // 通过省市区查询分公司
+            tBranchOffice = tBranchOfficeMapper.selectList(new EntityWrapper<TBranchOffice>().eq("provinceCode", province.getCode())
+                    .eq("cityCode", city.getCode())
+                    .eq("status", StatusEnum.NORMAL.getCode())
+                    .eq("districtCode", area.getCode())
+                    .last("LIMIT 1"));
+        }else {
+            // 通过省市区查询分公司
+            tBranchOffice = tBranchOfficeMapper.selectList(new EntityWrapper<TBranchOffice>().eq("provinceCode", province.getCode())
+                    .eq("cityCode", city.getCode())
+                    .eq("status", StatusEnum.NORMAL.getCode())
+                    .last("LIMIT 1"));
+//            tBranchOffice = tBranchOfficeMapper.selectList(new EntityWrapper<TBranchOffice>().eq("provinceCode", province.getCode())
+//                    .eq("cityCode", city.getCode())
+//                    .eq("status", StatusEnum.NORMAL.getCode())
+//                    .eq("districtCode", city.getCode())
+//                    .last("LIMIT 1"));
+        }
+        if(!CollectionUtils.isEmpty(tBranchOffice)){
+            tDriver.setBranchOfficeId(tBranchOffice.get(0).getId());
+        }else {
+            return new SuccessTip(500, "该区域分公司被冻结或不存在");
+        }
+
+        // ocr识别
+//        JSONObject ocr = this.ocr("E:\\071bf986db0b00355c0ed190bbd3b16.png");
+//        System.err.println(ocr);
+        return null;
     }
 
     @Override
-    public void updateCompanyDriverState(Integer authState, Integer companyId) {
-        this.baseMapper.updateCompanyDriverState(authState, companyId);
+    public EntityWrapper<TDriver> getCommissionPageList(String name, String phone, Integer status) {
+        EntityWrapper<TDriver> wrapper = new EntityWrapper<>();
+        // 手机号
+        if(StringUtils.hasLength(phone)){
+            wrapper.like("phone",phone);
+        }
+        // 状态
+        if(Objects.nonNull(status)){
+            wrapper.eq("status",status);
+        }
+        // 姓名
+        if(StringUtils.hasLength(name)){
+            wrapper.like("name",name);
+        }
+        wrapper.orderBy(true,"approvalStatus");
+        // 判断是否为代理商或者分公司
+        if(Objects.requireNonNull(ShiroKit.getUser()).getRoleType() == 2){
+            // 分公司
+            wrapper.eq("branchOfficeId",ShiroKit.getUser().getObjectId());
+        }
+        if(Objects.requireNonNull(ShiroKit.getUser()).getRoleType() == 3){
+            // 代理商
+            wrapper.eq("agentId",ShiroKit.getUser().getObjectId());
+        }
+        return wrapper;
     }
 
     @Override
-    public void updateFranchiseeDriverState(Integer authState, Integer franchiseeId) {
-        this.baseMapper.updateFranchiseeDriverState(authState, franchiseeId);
+    public List<TDriverCommissionResp> getTDriverCommissionResp(List<TDriver> drivers) {
+        List<TDriverCommissionResp> commissionRespList = new ArrayList<>(drivers.size());
+        for (TDriver driver : drivers) {
+            TDriverCommissionResp commissionResp = new TDriverCommissionResp();
+            BeanUtils.copyProperties(driver,commissionResp);
+
+            // 查询代理商
+            // 所属代理商
+            TAgent tAgent = tAgentMapper.selectById(driver.getAgentId());
+            if(Objects.nonNull(tAgent)){
+                commissionResp.setAgentName(tAgent.getPrincipal());
+            }
+
+            // 关联人数
+            AtomicInteger connectedPersons = new AtomicInteger(0);
+
+            List<TDriver> inviterTwoList = tDriverMapper.selectList(new EntityWrapper<TDriver>().eq("inviterId", driver.getId()));
+            if(!CollectionUtils.isEmpty(inviterTwoList)){
+                // 推广人数
+                commissionResp.setNumberPromoters(inviterTwoList.size());
+                List<Integer> inviterTwoIds = inviterTwoList.stream().map(TDriver::getId).collect(Collectors.toList());
+                connectedPersons.addAndGet(inviterTwoList.size());
+                // 查询三级
+                List<TDriver> inviterThreeList = tDriverMapper.selectList(new EntityWrapper<TDriver>().in("inviterId", inviterTwoIds));
+                if(!CollectionUtils.isEmpty(inviterThreeList)){
+                    List<Integer> inviterThreeIds = inviterThreeList.stream().map(TDriver::getId).collect(Collectors.toList());
+                    connectedPersons.addAndGet(inviterThreeList.size());
+                    // 查询四级
+                    List<TDriver> inviterFourList = tDriverMapper.selectList(new EntityWrapper<TDriver>().in("inviterId", inviterThreeIds));
+                    connectedPersons.addAndGet(inviterFourList.size());
+
+                }
+            }
+
+            commissionResp.setConnectedPersons(connectedPersons.get());
+
+            // 已提现佣金  查询该司机的佣金提现记录
+            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.add(commissionResp.getCommission()));
+            commissionRespList.add(commissionResp);
+
+        }
+        return commissionRespList;
     }
 
     @Override
-    public List<Map<String, Object>> getDriverListNoPage(Integer roleType, Integer nowUserId) {
-        return this.baseMapper.getDriverListNoPage(roleType, nowUserId);
+    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("phone",driver.getPhone());
+        model.addAttribute("sex",driver.getSex());
+        model.addAttribute("status",driver.getStatus());
+        model.addAttribute("commission",driver.getCommission());
+        model.addAttribute("startTimeToEndTime",new SimpleDateFormat("yyyy-MM-dd").format(driver.getCreateTime()).replace("-",".")+"-"+
+                new SimpleDateFormat("yyyy-MM-dd").format(new Date()).replace("-","."));
+
+        // 所属代理商
+        TAgent tAgent = tAgentMapper.selectById(driver.getAgentId());
+        if(Objects.nonNull(tAgent)){
+            model.addAttribute("agentName",tAgent.getPrincipal());
+        }else {
+            model.addAttribute("agentName","");
+        }
+
+        // 关联人数
+        AtomicInteger connectedPersons = new AtomicInteger(0);
+        // 推广人数
+        List<TDriver> inviterTwoList = tDriverMapper.selectList(new EntityWrapper<TDriver>().eq("inviterId", driver.getId()));
+        if(!CollectionUtils.isEmpty(inviterTwoList)){
+            model.addAttribute("numberPromoters",inviterTwoList.size());
+            List<Integer> inviterTwoIds = inviterTwoList.stream().map(TDriver::getId).collect(Collectors.toList());
+            connectedPersons.addAndGet(inviterTwoList.size());
+            // 查询三级
+            List<TDriver> inviterThreeList = tDriverMapper.selectList(new EntityWrapper<TDriver>().in("inviterId", inviterTwoIds));
+            if(!CollectionUtils.isEmpty(inviterThreeList)){
+                List<Integer> inviterThreeIds = inviterThreeList.stream().map(TDriver::getId).collect(Collectors.toList());
+                connectedPersons.addAndGet(inviterThreeList.size());
+                // 查询四级
+                List<TDriver> inviterFourList = tDriverMapper.selectList(new EntityWrapper<TDriver>().in("inviterId", inviterThreeIds));
+                connectedPersons.addAndGet(inviterFourList.size());
+            }
+        }else {
+            model.addAttribute("numberPromoters",0);
+        }
+        model.addAttribute("connectedPersons",connectedPersons.get());
+        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.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);
+    }
+
+
+    /**
+     * 获取司机详情汇总数据
+     * @param driverId
+     * @param time
+     * @return
+     */
+    @Override
+    public Map<String, Object> querySummaryData(Integer driverId, String time) {
+        String startTime = "";
+        String endTime = "";
+        if(ToolUtil.isNotEmpty(time)){
+            String[] split = time.split(" - ");
+            startTime = split[0];
+            endTime = split[1];
+        }
+        Map<String, Object> map = new HashMap<>();
+        TDriver tDriver = this.selectById(driverId);
+        //累计订单量
+        Wrapper<TOrder> cumulativeOrderCountWrapper = new EntityWrapper<TOrder>().eq("driverId", tDriver.getId()).eq("status", 1);
+        if(ToolUtil.isNotEmpty(time)){
+            cumulativeOrderCountWrapper.last(" and DATE_FORMAT(createTime, '$Y-$m-$d') between '" + startTime + "' and  '" + endTime + "'");
+        }
+        Integer cumulativeOrderCount = tOrderMapper.selectCount(cumulativeOrderCountWrapper);
+        map.put("cumulativeOrderCount", cumulativeOrderCount);
+        //有效订单数
+        Wrapper<TOrder> effectiveOrderCountWrapper = new EntityWrapper<TOrder>().eq("driverId", tDriver.getId()).eq("status", 1).in("state", Arrays.asList(106, 107, 108));
+        if(ToolUtil.isNotEmpty(time)){
+            effectiveOrderCountWrapper.last(" and DATE_FORMAT(createTime, '$Y-$m-$d') between '" + startTime + "' and  '" + endTime + "'");
+        }
+        Integer effectiveOrderCount = tOrderMapper.selectCount(effectiveOrderCountWrapper);
+        map.put("effectiveOrderCount", effectiveOrderCount);
+        map.put("commission", tDriver.getCommission().doubleValue());
+        map.put("balance", tDriver.getBalance().add(tDriver.getCouponBalance()).add(tDriver.getBackgroundBalance()).add(tDriver.getCommission()).doubleValue());
+        // 查询当前用户邀请了哪些人
+        Wrapper<TDriver> inviterDriverCountWrapper = new EntityWrapper<TDriver>().eq("inviterId", tDriver.getId());
+        if(ToolUtil.isNotEmpty(time)){
+            inviterDriverCountWrapper.last(" and DATE_FORMAT(createTime, '$Y-$m-$d') between '" + startTime + "' and  '" + endTime + "'");
+        }
+        List<TDriver> list = tDriverMapper.selectList(inviterDriverCountWrapper);
+        map.put("inviterDriverCount",list.size());
+        Wrapper<TAppUser> inviterUserCountWrapper = new EntityWrapper<TAppUser>().eq("inviterType", 2).eq("inviterId", tDriver.getId());
+        if(ToolUtil.isNotEmpty(time)){
+            inviterUserCountWrapper.last(" and DATE_FORMAT(createTime, '$Y-$m-$d') between '" + startTime + "' and  '" + endTime + "'");
+        }
+        List<TAppUser> tAppUsers = tAppUserMapper.selectList(inviterUserCountWrapper);
+        map.put("inviterUserCount",tAppUsers.size());
+        Wrapper<TRevenue> cumulativeIncomeWrapper = new EntityWrapper<TRevenue>().eq("userType", 2).eq("userId", tDriver.getId());
+        if(ToolUtil.isNotEmpty(time)){
+            cumulativeIncomeWrapper.last(" and DATE_FORMAT(createTime, '$Y-$m-$d') between '" + startTime + "' and  '" + endTime + "'");
+        }
+        List<TRevenue> tRevenues = tRevenueMapper.selectList(cumulativeIncomeWrapper);
+        Optional<BigDecimal> reduce1 = tRevenues.stream().map(TRevenue::getAmount).reduce(BigDecimal::add);
+        // 减去充值金额
+        if(reduce1.isPresent()){
+            map.put("cumulativeIncome", reduce1.get());
+        }else {
+            map.put("cumulativeIncome",0);
+        }
+        Wrapper<TCashWithdrawal> inviterCommissionWrapper = new EntityWrapper<TCashWithdrawal>().eq("type", UserTypeEnum.DRIVER.getCode()).eq("userDriverId", tDriver.getId())
+                .eq("businessType", 11).eq("state", 2);
+        if(ToolUtil.isNotEmpty(time)){
+            inviterCommissionWrapper.last(" and DATE_FORMAT(createTime, '$Y-$m-$d') between '" + startTime + "' and  '" + endTime + "'");
+        }
+        List<TCashWithdrawal> tCashWithdrawals = tCashWithdrawalMapper.selectList(inviterCommissionWrapper);
+        Optional<BigDecimal> reduce = tCashWithdrawals.stream().map(TCashWithdrawal::getAmount).reduce(BigDecimal::add);
+        BigDecimal bigDecimal = BigDecimal.ZERO;
+        reduce.ifPresent(bigDecimal::add);
+        map.put("inviterCommission",bigDecimal.add(tDriver.getCommission()));
+        //消单次数
+        Wrapper<TOrder> cancelOrderCountWrapper = new EntityWrapper<TOrder>().eq("driverId", tDriver.getId()).eq("status", 1).in("state", Arrays.asList(301));
+        if(ToolUtil.isNotEmpty(time)){
+            cancelOrderCountWrapper.last(" and DATE_FORMAT(createTime, '$Y-$m-$d') between '" + startTime + "' and  '" + endTime + "'");
+        }
+        Integer cancelOrderCount = tOrderMapper.selectCount(cancelOrderCountWrapper);
+        map.put("cancelOrderCount",cancelOrderCount);
+        Wrapper<DriverOnlineTime> driverOnlineTimeWrapper = new EntityWrapper<DriverOnlineTime>().eq("driverId", driverId);
+        if(ToolUtil.isNotEmpty(time)){
+            driverOnlineTimeWrapper.last(" and DATE_FORMAT(`day`, '$Y-$m-$d') between '" + startTime + "' and  '" + endTime + "'");
+        }
+        Long onlineTime = 0L;
+        List<DriverOnlineTime> driverOnlineTimes = driverOnlineTimeService.selectList(driverOnlineTimeWrapper);
+        for (DriverOnlineTime driverOnlineTime : driverOnlineTimes) {
+            onlineTime += driverOnlineTime.getOnlineTime().longValue();
+        }
+        Long s = onlineTime % 60;
+        Long m = onlineTime / 60;
+        map.put("onlineTime", (m < 10 ? ("0" + m) : m) + ":" + (s < 10 ? ("0" + s) : s));
+        return map;
+    }
 }

--
Gitblit v1.7.1