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;
|
|
/**
|
* <p>
|
* 服务实现类
|
* </p>
|
*
|
* @author ojq
|
* @since 2023-03-12
|
*/
|
@Service
|
@Slf4j
|
public class ZfContactServiceImpl extends ServiceImpl<ZfContactMapper, ZfContact> implements ZfContactService {
|
@Resource
|
ZInfoUserService zInfoUserService;
|
|
@Resource
|
ZfContactService zfContactService;
|
|
|
private LambdaQueryWrapper<ZfContact> buildCondition(ZfContact zfContact) {
|
LambdaQueryWrapper<ZfContact> 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<ZfContact> buildCondition(ZfContact zfContact, String familyIds, String secondFamilyAuthority) {
|
//模糊查询的条件
|
LambdaQueryWrapper<ZfContact> 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<ZInfoUser> 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<ZfContact> selectByCondition(ZfContact zfContact) {
|
String familyIds = listFamilyIds();
|
String secondFamilyIds = listSecondFamilyIds();
|
LambdaQueryWrapper<ZfContact> lambdaQueryWrapper = buildCondition(zfContact, familyIds, secondFamilyIds);
|
List<ZfContact> beanRecords = list(lambdaQueryWrapper);
|
log.info("从数据库中查到的为:{}", beanRecords);
|
return markOwnData(familyIds, beanRecords);
|
}
|
|
private static List<ZfContact> markOwnData(String familyIds, List<ZfContact> 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<ZfContact> lqw = buildCondition(zfContact, familyIds, secondFamilyAuthority);
|
|
Page<ZfContact> zfContactPage = new Page<>(pageNum, pageSize);
|
Page<ZfContact> pageResult = page(zfContactPage, lqw);
|
|
List<ZfContact> beanRecords = pageResult.getRecords();//得到查询出来的数据
|
|
List<ZfContact> dtoResult = markOwnData(familyIds, beanRecords);
|
|
HashMap<String, Object> 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);
|
}
|
|
if (save(zfContact)) {
|
return AjaxResult.success();
|
} else {
|
return AjaxResult.error();
|
}
|
}
|
|
|
@Override
|
@Transactional
|
public AjaxResult importExcel(MultipartFile file) {
|
ExcelUtil<ZfContact> util = new ExcelUtil<>(ZfContact.class);
|
List<ZfContact> 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("导入数据成功");
|
|
}
|
|
}
|