| | |
| | | package com.doumee.service.business.impl; |
| | | |
| | | import com.doumee.core.constants.Constants; |
| | | import com.doumee.core.constants.ResponseStatus; |
| | | import com.doumee.core.exception.BusinessException; |
| | | import com.doumee.core.constants.Constants; |
| | | import com.doumee.core.model.PageData; |
| | | import com.doumee.core.model.PageWrap; |
| | | import com.doumee.core.utils.DateUtil; |
| | |
| | | import com.doumee.dao.business.model.Goodsorder; |
| | | import com.doumee.dao.business.model.Member; |
| | | import com.doumee.dao.business.model.MemberRides; |
| | | import com.doumee.dao.business.web.request.MemberRidesQuery; |
| | | import com.doumee.dao.business.web.response.BikeLogDTO; |
| | | import com.doumee.dao.business.web.response.MemberRidesDTO; |
| | | import com.doumee.dao.business.web.response.MemberRidesQuery; |
| | | import com.doumee.service.business.DeviceService; |
| | | import com.doumee.service.business.MemberRidesService; |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | |
| | | return memberRidesMapper.selectList(wrapper); |
| | | } |
| | | |
| | | /** |
| | | * |
| | | * @param pageWrap 分页对象 |
| | | * @return |
| | | */ |
| | | @Override |
| | | public PageData<MemberRidesDTO> findPage(PageWrap<MemberRidesQuery> pageWrap) { |
| | | IPage<MemberRides> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); |
| | | MPJLambdaWrapper<MemberRides> queryWrapper = new MPJLambdaWrapper<>(); |
| | | Utils.MP.blankToNull(pageWrap.getModel()); |
| | | queryWrapper.orderByDesc(MemberRides::getCreateDate); |
| | | queryWrapper.leftJoin(Member.class,Member::getId,MemberRides::getMemberId) |
| | | .leftJoin(BaseParam.class,BaseParam::getId,MemberRides::getParamId) |
| | | .leftJoin(Goodsorder.class,Goodsorder::getId,MemberRides::getOrdreId) |
| | | .eq(BaseParam::getType, Constants.THREE) |
| | | .like(StringUtils.isNotBlank(pageWrap.getModel().getOpenid()),Member::getOpenid,pageWrap.getModel().getOpenid()) |
| | | .like(StringUtils.isNotBlank(pageWrap.getModel().getBikeCode()),MemberRides::getBikeCode,pageWrap.getModel().getBikeCode()) |
| | | .between((Objects.nonNull(pageWrap.getModel().getRentDateStart())&&Objects.nonNull(pageWrap.getModel().getRentDateEnd())), |
| | | MemberRides::getRentDate, |
| | | pageWrap.getModel().getRentDateStart(),pageWrap.getModel().getRentDateEnd()); |
| | | if (Objects.nonNull(pageWrap.getModel().getStatus()) |
| | | && Constants.GOODSORDER_STATUS.CLOSE.getKey().equals(pageWrap.getModel().getStatus())){ |
| | | queryWrapper.eq(Goodsorder::getStatus,pageWrap.getModel().getStatus()); |
| | | }else if (Objects.nonNull(pageWrap.getModel().getStatus()) |
| | | && !Constants.GOODSORDER_STATUS.CLOSE.getKey().equals(pageWrap.getModel().getStatus())){ |
| | | queryWrapper.ne(Goodsorder::getStatus,pageWrap.getModel().getStatus()); |
| | | } |
| | | queryWrapper.selectAs(Member::getOpenid,MemberRidesDTO::getOpenid) |
| | | .selectAs(MemberRides::getBikeCode,MemberRidesDTO::getBikeCode) |
| | | .selectAs(Goodsorder::getStatus,MemberRidesDTO::getStatus) |
| | | .selectAs(BaseParam::getName,MemberRidesDTO::getBikeType) |
| | | .selectAs(MemberRides::getDuration,MemberRidesDTO::getDuration) |
| | | .selectAs(MemberRides::getRentDate,MemberRidesDTO::getRentDate) |
| | | .selectAs(MemberRides::getBackDate,MemberRidesDTO::getBackDate); |
| | | MPJLambdaWrapper<MemberRides> queryWrapper = initQueryParamByModel(pageWrap.getModel()); |
| | | IPage<MemberRidesDTO> memberRidesDTOIPage = memberRidesJoinMapper.selectJoinPage(page, MemberRidesDTO.class, queryWrapper); |
| | | if (!CollectionUtils.isEmpty(memberRidesDTOIPage.getRecords())){ |
| | | memberRidesDTOIPage.getRecords().forEach(s->{ |
| | |
| | | return memberRidesMapper.selectCount(wrapper); |
| | | } |
| | | |
| | | |
| | | @Override |
| | | public PageData<BikeLogDTO> findBikeLog(PageWrap<MemberRidesQuery> pageWrap) { |
| | | |
| | | IPage<MemberRides> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); |
| | | MPJLambdaWrapper<MemberRides> queryWrapper = new MPJLambdaWrapper<>(); |
| | | Utils.MP.blankToNull(pageWrap.getModel()); |
| | | queryWrapper.orderByDesc(MemberRides::getCreateDate); |
| | | queryWrapper.leftJoin(Member.class,Member::getId,MemberRides::getMemberId) |
| | | .leftJoin(BaseParam.class,BaseParam::getId,MemberRides::getParamId) |
| | | .eq(BaseParam::getType, Constants.THREE) |
| | | .like(StringUtils.isNotBlank(pageWrap.getModel().getOpenid()),Member::getOpenid,pageWrap.getModel().getOpenid()) |
| | | .like(StringUtils.isNotBlank(pageWrap.getModel().getBikeCode()),MemberRides::getBikeCode,pageWrap.getModel().getBikeCode()) |
| | | .between((Objects.nonNull(pageWrap.getModel().getRentDateStart())&&Objects.nonNull(pageWrap.getModel().getRentDateEnd())), |
| | | MemberRides::getRentDate, |
| | | pageWrap.getModel().getRentDateStart(),pageWrap.getModel().getRentDateEnd()); |
| | | if (Objects.nonNull(pageWrap.getModel().getHasBack()) |
| | | && pageWrap.getModel().getHasBack()){ |
| | | queryWrapper.isNotNull(MemberRides::getBackDate); |
| | | }else if (Objects.nonNull(pageWrap.getModel().getStatus()) |
| | | && !pageWrap.getModel().getHasBack()){ |
| | | queryWrapper.isNull(MemberRides::getBackDate); |
| | | } |
| | | queryWrapper.orderByDesc(MemberRides::getCreateDate); |
| | | queryWrapper.leftJoin("locks rl on rl.id = t.rent_lock_id and rl.site_id = t.rent_site_id") |
| | | .leftJoin("sites rs on rs.id = rl.site_id") |
| | | .leftJoin("locks bl on bl.id = t.rent_lock_id and bl.site_id = t.rent_site_id") |
| | | .leftJoin("sites bs on bs.id = rl.site_id"); |
| | | queryWrapper.selectAs(Member::getOpenid,BikeLogDTO::getOpenid) |
| | | .selectAs(MemberRides::getBikeCode,BikeLogDTO::getBikeCode) |
| | | .selectAs(BaseParam::getName,BikeLogDTO::getBikeType) |
| | | .selectAs(MemberRides::getRentDate,BikeLogDTO::getRentDate) |
| | | .selectAs(MemberRides::getBackDate,BikeLogDTO::getBackDate) |
| | | .select("rs.Name as rentSiteName, rl.name as rentLockName") |
| | | .select("bs.Name as backSiteName, bl.name as backLockName"); |
| | | |
| | | MPJLambdaWrapper<MemberRides> queryWrapper = initQueryParamByModel(pageWrap.getModel()); |
| | | IPage<BikeLogDTO> bikeLogDTOIPage = memberRidesJoinMapper.selectJoinPage(page, BikeLogDTO.class, queryWrapper); |
| | | if (!CollectionUtils.isEmpty(bikeLogDTOIPage.getRecords())){ |
| | | bikeLogDTOIPage.getRecords().forEach(s->{ |
| | |
| | | return PageData.from(bikeLogDTOIPage); |
| | | } |
| | | |
| | | private MPJLambdaWrapper<MemberRides> initQueryParamByModel(MemberRidesQuery model) { |
| | | MPJLambdaWrapper<MemberRides> queryWrapper = new MPJLambdaWrapper<>(); |
| | | Utils.MP.blankToNull(model); |
| | | queryWrapper.orderByDesc(MemberRides::getCreateDate); |
| | | queryWrapper.leftJoin(Member.class,Member::getId,MemberRides::getMemberId) |
| | | .leftJoin(BaseParam.class,BaseParam::getId,MemberRides::getParamId) |
| | | .eq(BaseParam::getType, Constants.THREE) |
| | | .like(StringUtils.isNotBlank(model.getOpenid()),Member::getOpenid,model.getOpenid()) |
| | | .like(StringUtils.isNotBlank(model.getBikeCode()),MemberRides::getBikeCode,model.getBikeCode()); |
| | | queryWrapper.ge(model.getRentDateStart()!=null, MemberRides::getRentDate,model.getRentDateStart()); |
| | | queryWrapper.le(model.getRentDateEnd()!=null, MemberRides::getRentDate,model.getRentDateEnd()); |
| | | queryWrapper.eq(model.getCloseStatus()!=null,MemberRides::getCloseStatus, model.getCloseStatus()); |
| | | queryWrapper.selectAs(Member::getOpenid,MemberRidesDTO::getOpenid) |
| | | .selectAs(MemberRides::getBikeCode,MemberRidesDTO::getBikeCode) |
| | | .selectAs(MemberRides::getCloseStatus,MemberRidesDTO::getCloseStatus) |
| | | .selectAs(MemberRides::getStatus,MemberRidesDTO::getStatus) |
| | | .selectAs(BaseParam::getName,MemberRidesDTO::getBikeType) |
| | | .selectAs(MemberRides::getDuration,MemberRidesDTO::getDuration) |
| | | .selectAs(MemberRides::getRentDate,MemberRidesDTO::getRentDate) |
| | | .selectAs(MemberRides::getBackDate,MemberRidesDTO::getBackDate); |
| | | return queryWrapper; |
| | | } |
| | | |
| | | @Override |
| | | public String getOnlineBike(String memberId){ |
| | | MemberRides memberRides = memberRidesMapper.selectOne(new QueryWrapper<MemberRides>() |