jiangping
2023-12-29 f9691d544e62d6c04dbfe45d05a6c7bc5e004291
server/services/src/main/java/com/doumee/service/business/impl/BikeRepairServiceImpl.java
@@ -1,5 +1,8 @@
package com.doumee.service.business.impl;
import com.doumee.biz.system.SystemDictDataBiz;
import com.doumee.core.constants.ResponseStatus;
import com.doumee.core.exception.BusinessException;
import com.doumee.core.model.LoginUserInfo;
import com.google.common.collect.Lists;
import com.doumee.biz.system.SystemDictDataBiz;
@@ -23,6 +26,7 @@
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.github.yulichang.wrapper.MPJLambdaWrapper;
import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.SecurityUtils;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@@ -52,8 +56,6 @@
    @Autowired
    private MultifileMapper multifileMapper;
//    @Autowired
//    private SystemDictDataBiz systemDictDataBiz;
    @Override
    public String create(BikeRepair bikeRepair) {
@@ -84,6 +86,23 @@
    public void updateById(BikeRepair bikeRepair) {
        bikeRepairMapper.updateById(bikeRepair);
    }
    @Override
    public   void dealDo(BikeRepair param){
        BikeRepair bikeRepair = findById(param.getId());
        if(bikeRepair == null ){
            throw new BusinessException(ResponseStatus.DATA_EMPTY);
        }
        if(Constants.formatIntegerNum(bikeRepair.getStatus()) != Constants.ZERO ){
            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"该上报已处理,无需重复处理!");
        }
        LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
        bikeRepair.setDealInfo(param.getDealInfo());
        bikeRepair.setDealUser(user.getId());
        bikeRepair.setStatus(Constants.ONE);
        bikeRepair.setDealDate(new Date());
        bikeRepairMapper.updateById(bikeRepair);
    }
    @Override
    public void updateByIdInBatch(List<BikeRepair> bikeRepairs) {
@@ -103,7 +122,7 @@
    @Override
    public BikeRepair findOne(BikeRepair bikeRepair) {
        QueryWrapper<BikeRepair> wrapper = new QueryWrapper<>(bikeRepair);
        return bikeRepairMapper.selectOne(wrapper);
        return bikeRepairMapper.selectOne(wrapper.last(" limit 1"));
    }
    @Override
@@ -118,17 +137,21 @@
        MPJLambdaWrapper<BikeRepair> queryWrapper = new MPJLambdaWrapper<>();
        Utils.MP.blankToNull(pageWrap.getModel());
        queryWrapper.leftJoin(Member.class,Member::getId,BikeRepair::getMemberId)
                    .leftJoin(Bikes.class,Bikes::getId,BikeRepair::getBinkeId)
                    .leftJoin(BaseParam.class,BaseParam::getId,Bikes::getParamId);
                    .leftJoin(BaseParam.class,BaseParam::getId,BikeRepair::getTypeId);
        queryWrapper.selectAll(BikeRepair.class)
                    .selectAs(Member::getOpenid,BikeRepairDTO::getOpenid)
                    .selectAs(Bikes::getCode,BikeRepairDTO::getBikeCode)
                    .selectAs(BikeRepair::getBinkeId,BikeRepairDTO::getBikeCode)
                    .selectAs(BaseParam::getName,BikeRepairDTO::getBikeTypeName);
        queryWrapper.like(StringUtils.isNotEmpty(pageWrap.getModel().getOpenid()),Member::getOpenid,pageWrap.getModel().getOpenid())
                    .like(StringUtils.isNotEmpty(pageWrap.getModel().getBikeCode()),Bikes::getCode,pageWrap.getModel().getBikeCode())
                    .eq( pageWrap.getModel().getStatus() !=null,BikeRepair::getStatus,pageWrap.getModel().getStatus())
                    .ge(Objects.nonNull(pageWrap.getModel().getStartDate()),BikeRepair::getCreateDate,pageWrap.getModel().getStartDate())
                    .le(Objects.nonNull(pageWrap.getModel().getEndDate()),BikeRepair::getCreateDate,pageWrap.getModel().getEndDate());
                    .like(StringUtils.isNotEmpty(pageWrap.getModel().getBikeCode()),BikeRepair::getBinkeId,pageWrap.getModel().getBikeCode())
                    .eq( pageWrap.getModel().getStatus() !=null,BikeRepair::getStatus,pageWrap.getModel().getStatus());
        if (Objects.nonNull(pageWrap.getModel().getStartDate())) {
            queryWrapper.ge(BikeRepair::getCreateDate,Utils.Date.getStart(pageWrap.getModel().getStartDate()));
        }
        if (Objects.nonNull(pageWrap.getModel().getEndDate())) {
            queryWrapper.le(BikeRepair::getCreateDate,Utils.Date.getEnd(pageWrap.getModel().getEndDate()));
        }
        queryWrapper.orderByDesc(BikeRepair::getCreateDate);
        return PageData.from(bikeRepairJoinMapper.selectJoinPage(page, BikeRepairDTO.class,queryWrapper));
    }
@@ -141,7 +164,7 @@
                .eq(Multifile::getIsdeleted,Constants.ZERO);
        List<Multifile> multifiles = multifileMapper.selectList(wrapper);
        //TODO 需要修改
        String path =systemDictDataBiz.queryByCode(Constants.OSS,Constants.RESOURCE_PATH).getCode()+ systemDictDataBiz.queryByCode(Constants.OSS, Constants.PROJECT_FILE).getCode();
        String path =systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.FILE_DIR).getCode()+ systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.REPAIR).getCode();
        if (!CollectionUtils.isEmpty(multifiles)){
            multifiles.forEach(s->{
                if(StringUtils.isNotBlank(s.getFileurl())){
@@ -167,12 +190,15 @@
        BeanUtils.copyProperties(repairRequest,bikeRepair);
        bikeRepair.setCreateDate(new Date());
        bikeRepair.setIsdeleted(Constants.ZERO);
        bikeRepair.setStatus(Constants.ZERO);
        bikeRepair.setId(Constants.getUUID());
        bikeRepairMapper.insert(bikeRepair);
        //处理附件信息
        List<String> stringList = repairRequest.getFileUrlList();
        if(!Objects.isNull(stringList)&&stringList.size()>Constants.ZERO){
            for (int i = 0; i < stringList.size(); i++) {
                Multifile multifile = new Multifile();
                multifile.setId(Constants.getUUID());
                multifile.setCreateDate(new Date());
                multifile.setIsdeleted(Constants.ZERO);
                multifile.setSortnum(i+Constants.ONE);