|  |  |  | 
|---|
|  |  |  | import com.stylefeng.guns.core.shiro.ShiroKit; | 
|---|
|  |  |  | import com.stylefeng.guns.modular.system.controller.resp.TBranchOfficeResp; | 
|---|
|  |  |  | import com.stylefeng.guns.modular.system.dao.*; | 
|---|
|  |  |  | import com.stylefeng.guns.modular.system.enums.StatusEnum; | 
|---|
|  |  |  | import com.stylefeng.guns.modular.system.model.*; | 
|---|
|  |  |  | import com.stylefeng.guns.modular.system.service.ITBranchOfficeService; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.service.impl.ServiceImpl; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 优惠券数据,,,通过订单找到该区域的下单人,找出优惠券信息 | 
|---|
|  |  |  | List<Integer> userIds = orders.stream().map(TOrder::getUserId).collect(Collectors.toList()); | 
|---|
|  |  |  | List<TUserToCoupon> tUserToCoupons = tUserToCouponMapper.selectList(new EntityWrapper<TUserToCoupon>().in("userId", userIds)); | 
|---|
|  |  |  | List<TUserToCoupon> tUserToCoupons = tUserToCouponMapper.selectList(new EntityWrapper<TUserToCoupon>().eq("objectId", tBranchOfficeId) | 
|---|
|  |  |  | .eq("roleType",2)); | 
|---|
|  |  |  | // 优惠券有效数量 | 
|---|
|  |  |  | int validCount = tUserToCoupons.stream().mapToInt(TUserToCoupon::getValidCount).sum(); | 
|---|
|  |  |  | // 过期数量 | 
|---|
|  |  |  | 
|---|
|  |  |  | if(Objects.nonNull(status)){ | 
|---|
|  |  |  | wrapper.eq("status",status); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | wrapper.ne("status", StatusEnum.DELETE.getCode()); | 
|---|
|  |  |  | wrapper.orderBy("createTime",false); | 
|---|
|  |  |  | // 判断代理商 分公司 | 
|---|
|  |  |  | Integer roleType = Objects.requireNonNull(ShiroKit.getUser()).getRoleType(); | 
|---|
|  |  |  | Integer objectId = Objects.requireNonNull(ShiroKit.getUser()).getObjectId(); | 
|---|
|  |  |  | 
|---|
|  |  |  | public void queryOtherInfo(List<TBranchOfficeResp> tBranchOfficeRespList) { | 
|---|
|  |  |  | List<TOrder> orders = tOrderMapper.selectList(new EntityWrapper<TOrder>()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (TBranchOfficeResp tBranchOfficeResp : tBranchOfficeRespList) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<TOrder> orderList = orders.stream().filter(t -> tBranchOfficeResp.getId().equals(t.getBranchOfficeId())).collect(Collectors.toList()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<TUserToCoupon> tUserToCoupons = tUserToCouponMapper.selectList(new EntityWrapper<TUserToCoupon>().eq("objectId", tBranchOfficeResp.getId()) | 
|---|
|  |  |  | .eq("roleType",2)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(!CollectionUtils.isEmpty(orderList)){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 优惠券数据,,,通过订单找到该区域的下单人,找出优惠券信息 | 
|---|
|  |  |  | List<Integer> userIds = orderList.stream().map(TOrder::getUserId).collect(Collectors.toList()); | 
|---|
|  |  |  | List<TUserToCoupon> tUserToCoupons = tUserToCouponMapper.selectList(new EntityWrapper<TUserToCoupon>().in("userId", userIds)); | 
|---|
|  |  |  | // 优惠券有效数量 | 
|---|
|  |  |  | int validCount = tUserToCoupons.stream().mapToInt(TUserToCoupon::getValidCount).sum(); | 
|---|
|  |  |  | // 过期数量 | 
|---|
|  |  |  | int expireCount = tUserToCoupons.stream().mapToInt(TUserToCoupon::getExpireCount).sum(); | 
|---|
|  |  |  | // 总数量 | 
|---|
|  |  |  | int totalCount = tUserToCoupons.stream().mapToInt(TUserToCoupon::getCouponTotal).sum(); | 
|---|
|  |  |  | // 已使用优惠券;总数量减去有效数量 | 
|---|
|  |  |  | tBranchOfficeResp.setUsedCount(totalCount-validCount-expireCount); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 已发放优惠券 | 
|---|
|  |  |  | tBranchOfficeResp.setTotalCount(totalCount); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BigDecimal orderPriceCount = new BigDecimal("0"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 累计优惠券金额 | 
|---|
|  |  |  | for (TUserToCoupon tUserToCoupon : tUserToCoupons) { | 
|---|
|  |  |  | TCoupon tCoupon = tCouponMapper.selectById(tUserToCoupon.getCouponId()); | 
|---|
|  |  |  | BigDecimal price = tCoupon.getCouponPreferentialAmount().multiply(new BigDecimal(tUserToCoupon.getCouponTotal())); | 
|---|
|  |  |  | orderPriceCount = orderPriceCount.add(price); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tBranchOfficeResp.setOrderPriceCount(orderPriceCount); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 优惠券有效数量 | 
|---|
|  |  |  | int validCount = tUserToCoupons.stream().mapToInt(TUserToCoupon::getValidCount).sum(); | 
|---|
|  |  |  | // 过期数量 | 
|---|
|  |  |  | int expireCount = tUserToCoupons.stream().mapToInt(TUserToCoupon::getExpireCount).sum(); | 
|---|
|  |  |  | // 总数量 | 
|---|
|  |  |  | int totalCount = tUserToCoupons.stream().mapToInt(TUserToCoupon::getCouponTotal).sum(); | 
|---|
|  |  |  | // 已使用优惠券;总数量减去有效数量 | 
|---|
|  |  |  | tBranchOfficeResp.setUsedCount(totalCount-validCount-expireCount); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 已发放优惠券 | 
|---|
|  |  |  | tBranchOfficeResp.setTotalCount(totalCount); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BigDecimal orderPriceCount = new BigDecimal("0"); | 
|---|
|  |  |  | // 累计优惠券金额 | 
|---|
|  |  |  | for (TUserToCoupon tUserToCoupon : tUserToCoupons) { | 
|---|
|  |  |  | TCoupon tCoupon = tCouponMapper.selectById(tUserToCoupon.getCouponId()); | 
|---|
|  |  |  | BigDecimal price = tCoupon.getCouponPreferentialAmount().multiply(new BigDecimal(tUserToCoupon.getCouponTotal())); | 
|---|
|  |  |  | orderPriceCount = orderPriceCount.add(price); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tBranchOfficeResp.setOrderPriceCount(orderPriceCount); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 司机数量 | 
|---|
|  |  |  | Integer driverCount = tDriverMapper.selectCount(new EntityWrapper<TDriver>().eq("branchOfficeId", tBranchOfficeResp.getId())); | 
|---|
|  |  |  | tBranchOfficeResp.setDriverCount(driverCount); | 
|---|