package com.ruoyi.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.utils.MapUtils; import com.ruoyi.common.utils.SecurityUtils; import com.ruoyi.common.utils.StringUtils; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.domain.*; import com.ruoyi.domain.ZfContact; import com.ruoyi.domain.ZfContact; import com.ruoyi.mapper.ZfContactMapper; import com.ruoyi.service.ZInfoUserService; import com.ruoyi.service.ZfContactService; import com.ruoyi.service.ZfContactService; import com.ruoyi.util.ArraysUtil; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.multipart.MultipartFile; import javax.annotation.Resource; import java.util.HashMap; import java.util.List; import java.util.stream.Collectors; import static com.ruoyi.constant.MenuAuthority.CONTACT_LIST; import static com.ruoyi.constant.MenuAuthority.EVENT_LIST; /** *

* 服务实现类 *

* * @author ojq * @since 2023-03-12 */ @Service @Slf4j public class ZfContactServiceImpl extends ServiceImpl implements ZfContactService { @Resource ZInfoUserService zInfoUserService; @Resource ZfContactService zfContactService; private LambdaQueryWrapper buildCondition(ZfContact zfContact) { LambdaQueryWrapper lqw = new LambdaQueryWrapper<>(); lqw.like(StringUtils.isNotEmpty(zfContact.getMyName()),ZfContact::getMyName,zfContact.getMyName()); lqw.like(StringUtils.isNotEmpty(zfContact.getNickName()),ZfContact::getNickName,zfContact.getNickName()); lqw.like(StringUtils.isNotEmpty(zfContact.getName()),ZfContact::getName,zfContact.getName()); lqw.like(StringUtils.isNotEmpty(zfContact.getWork()),ZfContact::getWork,zfContact.getWork()); lqw.like(StringUtils.isNotEmpty(zfContact.getPhone()),ZfContact::getPhone,zfContact.getPhone()); lqw.like(StringUtils.isNotEmpty(zfContact.getWx()),ZfContact::getWx,zfContact.getWx()); lqw.like(StringUtils.isNotEmpty(zfContact.getQq()),ZfContact::getQq,zfContact.getQq()); lqw.like(StringUtils.isNotEmpty(zfContact.getTwitter()),ZfContact::getTwitter,zfContact.getTwitter()); lqw.like(StringUtils.isNotEmpty(zfContact.getRemark()),ZfContact::getRemark,zfContact.getRemark()); lqw.eq(zfContact.getHappenTime() != null, ZfContact::getHappenTime, zfContact.getHappenTime()); lqw.between(zfContact.getHappenStartTime() != null && zfContact.getHappenEndTime() != null, ZfContact::getHappenTime, zfContact.getHappenStartTime(), zfContact.getHappenEndTime()); return lqw; } private LambdaQueryWrapper buildCondition(ZfContact zfContact, String familyIds, String secondFamilyAuthority) { //模糊查询的条件 LambdaQueryWrapper lqw = buildCondition(zfContact); //定义一个布尔标记,标记第一家庭号是否有逗号 boolean flag = false; StringBuilder secondFamilyIdsBuffer = new StringBuilder(); //处理传入的secondFamilyAuthority 3{2007 2018 2015},4{2007 2019} if (StringUtils.isNotEmpty(secondFamilyAuthority)) { if (secondFamilyAuthority.contains(",")) { //逗号隔开得到如下串:3{2007 2018 2015} String[] authorityList = secondFamilyAuthority.split(","); for (String authorityAndId : authorityList) { setSecondFamilyAuthority(secondFamilyIdsBuffer, authorityAndId); } //把后面的逗号去掉 if (secondFamilyIdsBuffer.length() > 1) { secondFamilyIdsBuffer.deleteCharAt(secondFamilyIdsBuffer.length() - 1); } } else { setSecondFamilyAuthority(secondFamilyIdsBuffer, secondFamilyAuthority); //把后面的逗号去掉 if (secondFamilyIdsBuffer.length() > 1) { secondFamilyIdsBuffer.deleteCharAt(secondFamilyIdsBuffer.length() - 1); } } } //将StringBuffer转成String String secondFamilyIds = secondFamilyIdsBuffer.toString(); //第一家庭号的条件 if (familyIds.contains(",")) { flag = true; } //第二家庭号的条件 if (StringUtils.isNotEmpty(secondFamilyIds)) { if (secondFamilyIds.contains(",")) { String[] secondFamilyIdList = secondFamilyIds.split(","); if (flag) { //如果第一家庭号和第二家庭号都有逗号 String[] familyList = familyIds.split(","); String[] totalFamilyIdList = ArraysUtil.appendToArray(familyList, secondFamilyIdList); lqw.in(ZfContact::getFamilyId, totalFamilyIdList); } else { //如果第一家庭号没有逗号但是第二家庭号有逗号 String[] totalFamilyIdList = ArraysUtil.appendToArray(secondFamilyIdList, familyIds); lqw.in(ZfContact::getFamilyId, totalFamilyIdList); } } else { if (flag) { //如果第一家庭号有逗号但第二家庭号没有逗号 String[] familyList = familyIds.split(","); String[] totalFamilyIdList = ArraysUtil.appendToArray(familyList, secondFamilyIds); lqw.in(ZfContact::getFamilyId, totalFamilyIdList); } else { //如果第一家庭号和第二家庭号都没有逗号 String[] totalFamilyIdList = ArraysUtil.appendToArray(familyIds, secondFamilyIds); lqw.in(ZfContact::getFamilyId, totalFamilyIdList); } } } else { //如果没有第二家庭号 if (flag) { String[] familyList = familyIds.split(","); lqw.in(ZfContact::getFamilyId, familyList); } else { lqw.eq(ZfContact::getFamilyId, familyIds); } } lqw.orderByDesc(ZfContact::getCreateTime); return lqw; } private void setSecondFamilyAuthority(StringBuilder secondFamilyIdsBuffer, String authorityAndId) { //得到权限串 String authorities = authorityAndId.substring(2, authorityAndId.length() - 1); if (authorities.contains(" ")) { //空格隔开得到菜单id,看是否有对应的权限 String[] authorityIdList = authorities.split(" "); for (String s : authorityIdList) { if (s.equals(CONTACT_LIST)) { secondFamilyIdsBuffer.append(authorityAndId.charAt(0)).append(","); break; } } } else { if (authorities.equals(CONTACT_LIST)) { secondFamilyIdsBuffer.append(authorityAndId.charAt(0)).append(","); } } } private ZInfoUser getMySelf() { SysUser user = SecurityUtils.getLoginUser().getUser(); Long userId = user.getUserId(); LambdaQueryWrapper zInfoUserLambdaQueryWrapper = new LambdaQueryWrapper<>(); zInfoUserLambdaQueryWrapper.eq(ZInfoUser::getUserId, userId); return zInfoUserService.getOne(zInfoUserLambdaQueryWrapper); } private String listFamilyIds() { ZInfoUser mySelf = getMySelf(); return mySelf.getFamilyId(); } private String listSecondFamilyIds() { ZInfoUser mySelf = getMySelf(); return mySelf.getSecondFamilyId(); } @Override public List selectByCondition(ZfContact zfContact) { String familyIds = listFamilyIds(); String secondFamilyIds = listSecondFamilyIds(); LambdaQueryWrapper lambdaQueryWrapper = buildCondition(zfContact, familyIds, secondFamilyIds); List beanRecords = list(lambdaQueryWrapper); log.info("从数据库中查到的为:{}", beanRecords); return markOwnData(familyIds, beanRecords); } private static List markOwnData(String familyIds, List beanRecords) { return beanRecords.stream().peek(record -> { String recordFamilyId = record.getFamilyId(); if (familyIds.contains(",")) { String[] familyIdList = familyIds.split(","); for (String familyId : familyIdList) { if (familyId.equals(recordFamilyId)) { record.setOwnData(1); } } } else { if (familyIds.equals(recordFamilyId)) { record.setOwnData(1); } } }).collect(Collectors.toList()); } @Override public AjaxResult selectDataList(ZfContact zfContact, Integer pageNum, Integer pageSize) { String familyIds = listFamilyIds(); String secondFamilyAuthority = listSecondFamilyIds(); LambdaQueryWrapper lqw = buildCondition(zfContact, familyIds, secondFamilyAuthority); Page zfContactPage = new Page<>(pageNum, pageSize); Page pageResult = page(zfContactPage, lqw); List beanRecords = pageResult.getRecords();//得到查询出来的数据 List dtoResult = markOwnData(familyIds, beanRecords); HashMap data = MapUtils.getResult(pageResult, dtoResult); return AjaxResult.success(data); } @Override public AjaxResult addData(ZfContact zfContact) { String familyIds = listFamilyIds(); boolean flag = false;//判断当前用户的id是否有权加入当前家庭id的对象 if (familyIds.contains(",")) { String[] familyList = familyIds.split(","); for (String familyId : familyList) { if (familyId.equals(zfContact.getFamilyId())) { flag = true; } } } else { if (zfContact.getFamilyId().equals(familyIds)) { flag = true; } } if (flag) { if (save(zfContact)) { return AjaxResult.success(); } else { return AjaxResult.error(); } } else { throw new RuntimeException("你没有操作该家庭号为" + zfContact.getFamilyId() + "数据的权限"); } } @Override public AjaxResult addData2(ZfContact zfContact) { ZInfoUser mySelf = getMySelf(); String myFamilyId = mySelf.getFamilyId(); if (StringUtils.isNotEmpty(zfContact.getFamilyId())) { throw new RuntimeException("导入数据时您不能指定家庭号"); } if (StringUtils.isEmpty(myFamilyId)) { throw new RuntimeException("您还未加入任何家庭"); } if (myFamilyId.contains(",")) { String[] myFamilyIds = myFamilyId.split(","); //默认添加第一个家庭的数据 zfContact.setFamilyId(myFamilyIds[0]); } else { zfContact.setFamilyId(myFamilyId); } //判断是否有重复数据 LambdaQueryWrapper lqw = uniqueCondition(zfContact); List list = list(lqw); if(list.size()>0){ throw new RuntimeException("请勿新增重复数据"); } if (save(zfContact)) { return AjaxResult.success(); } else { return AjaxResult.error(); } } private LambdaQueryWrapper uniqueCondition(ZfContact zfContact) { LambdaQueryWrapper lqw = new LambdaQueryWrapper<>(); lqw.eq(StringUtils.isNotEmpty(zfContact.getMyName()),ZfContact::getMyName,zfContact.getMyName()); lqw.eq(StringUtils.isNotEmpty(zfContact.getNickName()),ZfContact::getNickName,zfContact.getNickName()); lqw.eq(StringUtils.isNotEmpty(zfContact.getName()),ZfContact::getName,zfContact.getName()); lqw.eq(StringUtils.isNotEmpty(zfContact.getWork()),ZfContact::getWork,zfContact.getWork()); lqw.eq(StringUtils.isNotEmpty(zfContact.getPhone()),ZfContact::getPhone,zfContact.getPhone()); lqw.eq(StringUtils.isNotEmpty(zfContact.getWx()),ZfContact::getWx,zfContact.getWx()); lqw.eq(StringUtils.isNotEmpty(zfContact.getQq()),ZfContact::getQq,zfContact.getQq()); lqw.eq(StringUtils.isNotEmpty(zfContact.getTwitter()),ZfContact::getTwitter,zfContact.getTwitter()); lqw.eq(StringUtils.isNotEmpty(zfContact.getRemark()),ZfContact::getRemark,zfContact.getRemark()); lqw.eq(zfContact.getHappenTime() != null, ZfContact::getHappenTime, zfContact.getHappenTime()); return lqw; } @Override @Transactional public AjaxResult importExcel(MultipartFile file) { ExcelUtil util = new ExcelUtil<>(ZfContact.class); List propertyList = null; try { propertyList = util.importExcel(file.getInputStream()); } catch (Exception e) { throw new RuntimeException(e); } log.info("资产列表为:{}", propertyList); for (ZfContact zfContact : propertyList) { zfContactService.addData2(zfContact); } return AjaxResult.success("导入数据成功"); } }