From c9ef2687d3460da668d08d58dee6af468ed6693e Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期二, 05 十一月 2024 11:48:34 +0800 Subject: [PATCH] 最新版本541200007 --- server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java | 103 ++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 101 insertions(+), 2 deletions(-) diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java index 29a5552..b7f1b1a 100644 --- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java +++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java @@ -4,14 +4,18 @@ import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.doumee.core.annotation.excel.ExcelImporter; import com.doumee.core.constants.ResponseStatus; import com.doumee.core.exception.BusinessException; import com.doumee.core.model.LoginUserInfo; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Constants; +import com.doumee.core.utils.ScientificNotationTUtil; import com.doumee.core.utils.Utils; +import com.doumee.dao.admin.request.CarsImport; import com.doumee.dao.admin.request.CarsQuery; +import com.doumee.dao.admin.request.MemberImport; import com.doumee.dao.admin.response.CarsDTO; import com.doumee.dao.business.CarsMapper; import com.doumee.dao.business.MemberMapper; @@ -25,9 +29,11 @@ import org.apache.commons.lang3.StringUtils; import org.apache.shiro.SecurityUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; +import org.springframework.web.multipart.MultipartFile; import java.util.*; @@ -42,6 +48,8 @@ @Autowired private CarsMapper carsMapper; + @Autowired + private RedisTemplate<String, Object> redisTemplate; @Autowired private CarJoinMapper carJoinMapper; @Autowired @@ -58,11 +66,13 @@ } if(StringUtils.isBlank(model.getCode()) ||model.getType()==null + ||model.getCateId()==null ||model.getType()<0 ||model.getType()>3 ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } + if(model.getMemberId()!=null){ //妫�鏌ヨ溅涓讳俊鎭� Member member =memberMapper.selectOne(new QueryWrapper<Member>().lambda() @@ -75,6 +85,10 @@ } model.setMemberHkId(member.getHkId()); } + if(!Constants.checkCarNo(model.getCode())){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"璇疯緭鍏ユ纭殑杞︾墝!"); + }; + //妫�鏌ヨ溅鐗屽彿鏄惁閲嶅 if(carsMapper.selectCount(new QueryWrapper<Cars>().lambda() .eq(Cars::getCode,model.getCode() ) @@ -183,6 +197,7 @@ if(StringUtils.isBlank(model.getCode()) ||model.getId()==null ||model.getType()==null + ||model.getCateId()==null ||model.getType()<0 ||model.getType()>3 ){ @@ -191,8 +206,10 @@ Cars car = carJoinMapper.selectById(model.getId()); if(car ==null ||Constants.equalsInteger(car.getIsdeleted(),Constants.ONE)){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"瀵逛笉璧凤紝杞﹁締淇℃伅涓嶅瓨鍦紒"); - } + if(!Constants.checkCarNo(model.getCode())){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"璇疯緭鍏ユ纭殑杞︾墝!"); + }; if(model.getMemberId()!=null){ //妫�鏌ヨ溅涓讳俊鎭� Member member =memberMapper.selectOne(new QueryWrapper<Member>().lambda() @@ -220,12 +237,14 @@ model.setHkStatus(Constants.ZERO); model.setRemark(""); model.setAuthStatus(Constants.ZERO); - dealCancelBookBiz(model.getCode(),model.getEditDate()); + dealCancelBookBiz(car.getCode(),model.getEditDate()); carsMapper.update(null,new UpdateWrapper<Cars>().lambda() .eq(Cars::getId,model.getId()) .set(Cars::getAuthStatus,Constants.ZERO) .set(Cars::getType,model.getType()) .set(Cars::getCode,model.getCode()) + .set(Cars::getGroupId,model.getGroupId()) + .set(Cars::getCateId,model.getCateId()) .set(Cars::getEditDate,model.getEditDate()) .set(Cars::getEdirot,model.getEdirot()) .set(Cars::getMemberId,model.getMemberId()) @@ -248,6 +267,10 @@ public Cars findById(Integer id) { return carsMapper.selectById(id); } + + + + @Override public Cars findOne(Cars cars) { @@ -272,18 +295,39 @@ queryWrapper.selectAs(SystemUser::getRealname,Cars::getEditorName); queryWrapper.selectAs(Member::getPhone,Cars::getMemberPhone); queryWrapper.selectAs(Company::getCompanyNamePath,Cars::getCompanyName); + queryWrapper.selectAs(Category::getParentId,Cars::getCatePId); + queryWrapper.selectAs(Category::getName,Cars::getCateName); + queryWrapper.select(" c.name as catePName"); + queryWrapper.select(" c1.COMPANY_NAME_PATH as carCompanyNamePath"); + queryWrapper.select(" c1.name as carCompanyName"); queryWrapper.leftJoin(Member.class,Member::getId,Cars::getMemberId); queryWrapper.leftJoin(SystemUser.class,SystemUser::getId,Cars::getEdirot); queryWrapper.leftJoin(Company.class,Company::getId,Member::getCompanyId); + queryWrapper.leftJoin(Category.class,Category::getId,Cars::getCateId); + queryWrapper.leftJoin("category c on t4.PARENT_ID = c.id"); + queryWrapper.leftJoin("company c1 on t.GROUP_ID = c1.id"); queryWrapper.and(StringUtils.isNotBlank(pageWrap.getModel().getMemberName()), ms->ms.like(Member::getName,pageWrap.getModel().getMemberName()) .or().like(Member::getPhone,pageWrap.getModel().getMemberName())); queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCompanyName()),Company::getCompanyNamePath,pageWrap.getModel().getCompanyName()); queryWrapper.eq(Objects.nonNull(pageWrap.getModel().getMemberType()),Member::getType,pageWrap.getModel().getMemberType()); + queryWrapper.eq(Objects.nonNull(pageWrap.getModel().getCatePId()),Category::getParentId,pageWrap.getModel().getCatePId()); queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCode()),Cars::getCode,pageWrap.getModel().getCode()); queryWrapper.eq(Cars::getIsdeleted,Constants.ZERO); queryWrapper.eq(pageWrap.getModel().getType()!=null,Cars::getType,pageWrap.getModel().getType()); queryWrapper.eq(pageWrap.getModel().getAuthStatus()!=null,Cars::getAuthStatus,pageWrap.getModel().getAuthStatus()); queryWrapper.orderByDesc(Cars::getCreateDate); + //鏁版嵁鏉冮檺寮�濮�--------------------start---------------- + LoginUserInfo userInfo =pageWrap.getModel().getLoginUserInfo(); + if(userInfo!=null && userInfo.getCompanyIdList()!=null){ + if( userInfo.getCompanyIdList().size() ==0){ + //鍙兘鐪嬭嚜宸�(鎷滆浜猴級 + queryWrapper.eq(Cars::getMemberId,userInfo.getMemberId()); + }else{ + queryWrapper.in(Cars::getGroupId ,userInfo.getCompanyIdList()); + } + } + //鏁版嵁鏉冮檺寮�濮�--------------------end---------------- + IPage<Cars> result = carJoinMapper.selectJoinPage(page, Cars.class,queryWrapper); if(result!=null && result.getRecords()!=null && result.getRecords().size()>0){ List<String> codes = new ArrayList<>(); @@ -347,4 +391,59 @@ return PageData.from(carsDTOIPage); } + + @Override + @Transactional(rollbackFor = {BusinessException.class,Exception.class}) + public String importBatch(MultipartFile file, LoginUserInfo loginUserInfo){ + Boolean importing = (Boolean) redisTemplate.opsForValue().get(Constants.RedisKeys.IMPORTING_CARS); + if(importing!=null && importing){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝宸插瓨鍦ㄨ溅杈嗗鍏ヤ换鍔℃鍦ㄦ墽琛屼腑锛岃绋嶅悗鍐嶈瘯锛�"); + } + redisTemplate.opsForValue().set(Constants.RedisKeys.IMPORTING_CARS,true); + try { + ExcelImporter ie = null; + List<CarsImport> dataList =null; + try { + ie = new ExcelImporter(file,1,0); + dataList = ie.getDataList(CarsImport.class,null); + } catch (Exception e) { + e.printStackTrace(); + } + if(dataList == null || dataList.size() ==0){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝褰曞叆鏁版嵁涓虹┖锛�"); + } + List<Cars> list = carJoinMapper.selectJoinList(Cars.class,new MPJLambdaWrapper<Cars>() + .selectAll(Cars.class) + .eq(Cars::getIsdeleted,Constants.ZERO) + ); + List<Member> memberList = memberMapper.selectList(new QueryWrapper<Member>().lambda() + .eq(Member::getType,Constants.TWO) + .eq(Member::getIsdeleted,Constants.ZERO)); + List<Cars> newList = new ArrayList<>(); + for(int i=0;i<dataList.size();i++){ + CarsImport model = dataList.get(i); + model.setPhone(ScientificNotationTUtil.convertToString(model.getPhone())); + /* if(StringUtils.isBlank(model.getCode()) + &&StringUtils.isBlank(model.getIdcardNo()) + &&StringUtils.isBlank(model.getPhone()) + &&StringUtils.isBlank(model.getCompanyName())){ + continue; + } + Cars car = checkModelParam(model,newList,i,loginUserInfo,list,companyList,); + newList.add(car);*/ + } + if(newList == null || newList.size() ==0){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝褰曞叆鏈夋晥鏁版嵁涓虹┖锛�"); + } +// dealHkUserBizBatch(newList); + return "瀵煎叆鎴愬姛"; + }catch (BusinessException e){ + throw e; + }catch (Exception e){ + throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"杞﹁締淇℃伅瀵煎叆澶辫触锛岃绋嶅悗閲嶈瘯"); + }finally { + redisTemplate.delete(Constants.RedisKeys.IMPORTING_CARS); + } + } + } -- Gitblit v1.9.3