package com.doumee.service.business.impl; import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.baomidou.mybatisplus.extension.toolkit.SqlHelper; import com.doumee.biz.system.SystemDictDataBiz; import com.doumee.core.constants.ResponseStatus; import com.doumee.core.exception.BusinessException; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Constants; import com.doumee.core.utils.Utils; import com.doumee.dao.business.MultifileMapper; import com.doumee.dao.business.model.Multifile; import com.doumee.service.business.MultifileService; 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 org.apache.commons.collections.SetUtils; import org.apache.commons.collections4.MapUtils; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import org.springframework.util.StringUtils; import java.util.*; import java.util.stream.Collectors; /** * 附件上传信息表Service实现 * @author 江蹄蹄 * @date 2023/02/15 08:55 */ @Service public class MultifileServiceImpl extends ServiceImpl implements MultifileService { @Autowired private MultifileMapper multifileMapper; @Autowired SystemDictDataBiz systemDictDataBiz; @Override public Integer create(Multifile multifile) { multifileMapper.insert(multifile); return multifile.getId(); } @Override public void deleteById(Integer id) { multifileMapper.deleteById(id); } @Override public void delete(Multifile multifile) { if (multifile.getObjId() == null ||(multifile.getObjType() == null && (multifile.getTypeList() ==null || multifile.getTypeList().size()==0) )){ throw new BusinessException(ResponseStatus.SERVER_ERROR); } UpdateWrapper deleteWrapper = new UpdateWrapper<>(multifile); if((multifile.getTypeList() != null && multifile.getTypeList().size()>0)){ deleteWrapper.lambda().in(Multifile::getObjType,multifile.getTypeList()); } multifileMapper.delete(deleteWrapper); } @Override public void deleteByIdInBatch(List ids) { if (CollectionUtils.isEmpty(ids)) { return; } multifileMapper.deleteBatchIds(ids); } // @Override // public void updateById(Multifile multifile) { // multifileMapper.updateById(multifile); // } @Override public void updateByIdInBatch(List multifiles) { if (CollectionUtils.isEmpty(multifiles)) { return; } for (Multifile multifile: multifiles) { this.updateById(multifile); } } // @Override // public Multifile updateMultifile(Multifile multifile, Wrapper wrapper) { // // int update = multifileMapper.update(multifile, wrapper); // return multifile; // } @Override public Multifile findById(Integer id) { return multifileMapper.selectById(id); } @Override public Multifile findOne(Multifile multifile) { QueryWrapper wrapper = new QueryWrapper<>(multifile); return multifileMapper.selectOne(wrapper.last(" limit 1")); } @Override public List findList(Multifile multifile) { QueryWrapper wrapper = new QueryWrapper<>(multifile); if(multifile.getTypeList()!=null){ wrapper.lambda().in(Multifile::getObjType,multifile.getTypeList()); } return multifileMapper.selectList(wrapper); } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); QueryWrapper queryWrapper = new QueryWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); if (pageWrap.getModel().getId() != null) { queryWrapper.lambda().eq(Multifile::getId, pageWrap.getModel().getId()); } if (pageWrap.getModel().getCreator() != null) { queryWrapper.lambda().eq(Multifile::getCreator, pageWrap.getModel().getCreator()); } if (pageWrap.getModel().getCreateDate() != null) { queryWrapper.lambda().ge(Multifile::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate())); queryWrapper.lambda().le(Multifile::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate())); } if (pageWrap.getModel().getEditor() != null) { queryWrapper.lambda().eq(Multifile::getEditor, pageWrap.getModel().getEditor()); } if (pageWrap.getModel().getEditDate() != null) { queryWrapper.lambda().ge(Multifile::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate())); queryWrapper.lambda().le(Multifile::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate())); } if (pageWrap.getModel().getIsdeleted() != null) { queryWrapper.lambda().eq(Multifile::getIsdeleted, pageWrap.getModel().getIsdeleted()); } if (pageWrap.getModel().getName() != null) { queryWrapper.lambda().eq(Multifile::getName, pageWrap.getModel().getName()); } if (pageWrap.getModel().getInfo() != null) { queryWrapper.lambda().eq(Multifile::getInfo, pageWrap.getModel().getInfo()); } if (pageWrap.getModel().getObjId() != null) { queryWrapper.lambda().eq(Multifile::getObjId, pageWrap.getModel().getObjId()); } if (pageWrap.getModel().getType() != null) { queryWrapper.lambda().eq(Multifile::getType, pageWrap.getModel().getType()); } if (pageWrap.getModel().getObjType() != null) { queryWrapper.lambda().eq(Multifile::getObjType, pageWrap.getModel().getObjType()); } if (pageWrap.getModel().getFileurl() != null) { queryWrapper.lambda().eq(Multifile::getFileurl, pageWrap.getModel().getFileurl()); } for(PageWrap.SortData sortData: pageWrap.getSorts()) { if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { queryWrapper.orderByDesc(sortData.getProperty()); } else { queryWrapper.orderByAsc(sortData.getProperty()); } } return PageData.from(multifileMapper.selectPage(page, queryWrapper)); } @Override public long count(Multifile multifile) { QueryWrapper wrapper = new QueryWrapper<>(multifile); return multifileMapper.selectCount(wrapper); } @Override public Map> getOBJAllFileUrl(Integer objId,Integer type) { String path =systemDictDataBiz.queryByCode(Constants.OSS,Constants.RESOURCE_PATH).getCode(); String companyPath = systemDictDataBiz.queryByCode(Constants.OSS, Constants.COMPANY_FILE).getCode(); String projectFile = systemDictDataBiz.queryByCode(Constants.OSS, Constants.PROJECT_FILE).getCode(); QueryWrapper wrapper = new QueryWrapper<>(); wrapper.lambda().eq(Multifile::getObjId,objId) .eq(Multifile::getIsdeleted, Constants.ZERO) .eq(Objects.nonNull(type),Multifile::getType,type); List multifiles = multifileMapper.selectList(wrapper); Map> collect1 = multifiles.stream() .map(s->{ if(Constants.MultiFile.multifileCompanyType().contains(s.getObjType())){ s.setFileurl(path+companyPath+s.getFileurl()); } else if (Constants.MultiFile.multifileProjectType().contains(s.getObjType())){ s.setFileurl(path+projectFile+s.getFileurl()); } return s; }) .collect(Collectors.groupingBy(s -> s.getObjType())); return collect1; } @Override public Map> getOBJFileUrl(List objIds, Integer objType) { String path =systemDictDataBiz.queryByCode(Constants.OSS,Constants.RESOURCE_PATH).getCode(); String companyPath = systemDictDataBiz.queryByCode(Constants.OSS, Constants.COMPANY_FILE).getCode(); String projectFile = systemDictDataBiz.queryByCode(Constants.OSS, Constants.PROJECT_FILE).getCode(); QueryWrapper wrapper = new QueryWrapper<>(); wrapper.lambda(). in(Multifile::getObjId,objIds) .eq(Multifile::getIsdeleted, Constants.ZERO) .eq(Objects.nonNull(objType),Multifile::getObjType,objType); List multifiles = multifileMapper.selectList(wrapper); Map> collect1 = multifiles.stream() .map(s->{ if(Constants.MultiFile.multifileCompanyType().contains(s.getObjType())){ s.setFileurl(path+companyPath+s.getFileurl()); s.setFileurlfull(s.getFileurl()); } else if (Constants.MultiFile.multifileProjectType().contains(s.getObjType())){ s.setFileurl(path+projectFile+s.getFileurl()); s.setFileurlfull(s.getFileurl()); } return s; }) .collect(Collectors.groupingBy(s -> s.getObjId())); return collect1; } }