|  |  |  | 
|---|
|  |  |  | package com.doumee.service.business.impl; | 
|---|
|  |  |  | import com.doumee.biz.system.SystemDictDataBiz; | 
|---|
|  |  |  | import com.google.common.collect.Lists; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.doumee.biz.system.SystemDictDataBiz; | 
|---|
|  |  |  | import com.doumee.core.constants.Constants; | 
|---|
|  |  |  | import com.doumee.core.dingding.DingDingNotice; | 
|---|
|  |  |  | import com.doumee.core.model.PageData; | 
|---|
|  |  |  | import com.doumee.core.model.PageWrap; | 
|---|
|  |  |  | import com.doumee.core.utils.Utils; | 
|---|
|  |  |  | import com.doumee.dao.business.BikeRepairMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.model.BikeRepair; | 
|---|
|  |  |  | import com.doumee.dao.business.MultifileMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.join.BikeRepairJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.model.*; | 
|---|
|  |  |  | import com.doumee.dao.business.web.request.BikeRepairDTO; | 
|---|
|  |  |  | import com.doumee.dao.business.web.request.BikeRepairProblemDTO; | 
|---|
|  |  |  | import com.doumee.dao.business.web.request.BikeRepairQuery; | 
|---|
|  |  |  | import com.doumee.dao.business.web.request.RepairRequest; | 
|---|
|  |  |  | import com.doumee.service.business.BikeRepairService; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | 
|---|
|  |  |  | 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.github.yulichang.wrapper.MPJLambdaWrapper; | 
|---|
|  |  |  | import org.apache.commons.lang3.StringUtils; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.util.CollectionUtils; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Objects; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 车辆问题上报信息表Service实现 | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BikeRepairMapper bikeRepairMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BikeRepairJoinMapper bikeRepairJoinMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | SystemDictDataBiz systemDictDataBiz; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private MultifileMapper multifileMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public String create(BikeRepair bikeRepair) { | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public BikeRepair findOne(BikeRepair bikeRepair) { | 
|---|
|  |  |  | QueryWrapper<BikeRepair> wrapper = new QueryWrapper<>(bikeRepair); | 
|---|
|  |  |  | return bikeRepairMapper.selectOne(wrapper); | 
|---|
|  |  |  | return bikeRepairMapper.selectOne(wrapper.last(" limit 1")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | QueryWrapper<BikeRepair> wrapper = new QueryWrapper<>(bikeRepair); | 
|---|
|  |  |  | return bikeRepairMapper.selectList(wrapper); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PageData<BikeRepair> findPage(PageWrap<BikeRepair> pageWrap) { | 
|---|
|  |  |  | public PageData<BikeRepairDTO> findPage(PageWrap<BikeRepairQuery> pageWrap) { | 
|---|
|  |  |  | IPage<BikeRepair> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); | 
|---|
|  |  |  | QueryWrapper<BikeRepair> queryWrapper = new QueryWrapper<>(); | 
|---|
|  |  |  | MPJLambdaWrapper<BikeRepair> queryWrapper = new MPJLambdaWrapper<>(); | 
|---|
|  |  |  | Utils.MP.blankToNull(pageWrap.getModel()); | 
|---|
|  |  |  | if (pageWrap.getModel().getId() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getId, pageWrap.getModel().getId()); | 
|---|
|  |  |  | queryWrapper.leftJoin(Member.class,Member::getId,BikeRepair::getMemberId) | 
|---|
|  |  |  | .leftJoin(BaseParam.class,BaseParam::getId,BikeRepair::getTypeId); | 
|---|
|  |  |  | queryWrapper.selectAll(BikeRepair.class) | 
|---|
|  |  |  | .selectAs(Member::getOpenid,BikeRepairDTO::getOpenid) | 
|---|
|  |  |  | .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()); | 
|---|
|  |  |  | return PageData.from(bikeRepairJoinMapper.selectJoinPage(page, BikeRepairDTO.class,queryWrapper)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Multifile> getBikeRepairProblemDTO(String id) { | 
|---|
|  |  |  | QueryWrapper<Multifile> wrapper = new QueryWrapper<>(); | 
|---|
|  |  |  | wrapper.lambda() | 
|---|
|  |  |  | .eq(Multifile::getObjId,id) | 
|---|
|  |  |  | .eq(Multifile::getObjType,Constants.ZERO) | 
|---|
|  |  |  | .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(); | 
|---|
|  |  |  | if (!CollectionUtils.isEmpty(multifiles)){ | 
|---|
|  |  |  | multifiles.forEach(s->{ | 
|---|
|  |  |  | if(StringUtils.isNotBlank(s.getFileurl())){ | 
|---|
|  |  |  | //完整附件地址 | 
|---|
|  |  |  | s.setFileurlfull(path+s.getFileurl()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getCreateDate() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().ge(BikeRepair::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate())); | 
|---|
|  |  |  | queryWrapper.lambda().le(BikeRepair::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getCreator() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getCreator, pageWrap.getModel().getCreator()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getEditDate() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().ge(BikeRepair::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate())); | 
|---|
|  |  |  | queryWrapper.lambda().le(BikeRepair::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getEditor() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getEditor, pageWrap.getModel().getEditor()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getIsdeleted() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getIsdeleted, pageWrap.getModel().getIsdeleted()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getBinkeId() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getBinkeId, pageWrap.getModel().getBinkeId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getLongitude() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getLongitude, pageWrap.getModel().getLongitude()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getLatitude() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getLatitude, pageWrap.getModel().getLatitude()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getAddr() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getAddr, pageWrap.getModel().getAddr()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getParamId() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getParamId, pageWrap.getModel().getParamId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getParam() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getParam, pageWrap.getModel().getParam()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getStatus() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getStatus, pageWrap.getModel().getStatus()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getInfo() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getInfo, pageWrap.getModel().getInfo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getLinkname() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getLinkname, pageWrap.getModel().getLinkname()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getLinkphone() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getLinkphone, pageWrap.getModel().getLinkphone()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getDealUser() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getDealUser, pageWrap.getModel().getDealUser()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getDealDate() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().ge(BikeRepair::getDealDate, Utils.Date.getStart(pageWrap.getModel().getDealDate())); | 
|---|
|  |  |  | queryWrapper.lambda().le(BikeRepair::getDealDate, Utils.Date.getEnd(pageWrap.getModel().getDealDate())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getDealInfo() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getDealInfo, pageWrap.getModel().getDealInfo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getContent() != null) { | 
|---|
|  |  |  | queryWrapper.lambda().eq(BikeRepair::getContent, pageWrap.getModel().getContent()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for(PageWrap.SortData sortData: pageWrap.getSorts()) { | 
|---|
|  |  |  | if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { | 
|---|
|  |  |  | queryWrapper.orderByDesc(sortData.getProperty()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | queryWrapper.orderByAsc(sortData.getProperty()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return PageData.from(bikeRepairMapper.selectPage(page, queryWrapper)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return multifiles; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | QueryWrapper<BikeRepair> wrapper = new QueryWrapper<>(bikeRepair); | 
|---|
|  |  |  | return bikeRepairMapper.selectCount(wrapper); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void saveRepair(RepairRequest repairRequest) throws Exception{ | 
|---|
|  |  |  | BikeRepair bikeRepair = new BikeRepair(); | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | multifile.setObjId(bikeRepair.getId()); | 
|---|
|  |  |  | multifile.setType(Constants.ZERO); | 
|---|
|  |  |  | multifile.setObjType(Constants.ZERO); | 
|---|
|  |  |  | multifile.setFileurl(stringList.get(i)); | 
|---|
|  |  |  | multifileMapper.insert(multifile); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //发送钉钉通知 | 
|---|
|  |  |  | DingDingNotice.bikeRepair(repairRequest, | 
|---|
|  |  |  | systemDictDataBiz.queryByCode(Constants.DINGDING,Constants.DINGDING_URL).getCode(), | 
|---|
|  |  |  | systemDictDataBiz.queryByCode(Constants.DINGDING,Constants.DINGDING_SECRET).getCode()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|