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.bean.BeanUtils;
|
import com.ruoyi.common.utils.poi.ExcelUtil;
|
import com.ruoyi.domain.ZInfoUser;
|
import com.ruoyi.domain.ZfProperty;
|
import com.ruoyi.domain.dto.ZfPropertyDto;
|
import com.ruoyi.mapper.ZfPropertyMapper;
|
import com.ruoyi.service.IZfPropertyService;
|
import com.ruoyi.service.ZInfoUserService;
|
import com.ruoyi.util.ArraysUtil;
|
import lombok.extern.slf4j.Slf4j;
|
import org.springframework.stereotype.Service;
|
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.PROPERTY_LIST;
|
|
|
/**
|
* @Version 1.0
|
* @Author Jin_quan Ou
|
* @Date 2023-03-09 10:36
|
*/
|
@Slf4j
|
@Service
|
public class IZfPropertyServiceImpl extends ServiceImpl<ZfPropertyMapper, ZfProperty> implements IZfPropertyService {
|
|
@Resource
|
ZInfoUserService zInfoUserService;
|
|
@Resource
|
IZfPropertyService zfPropertyService;
|
|
@Override
|
public List<ZfProperty> selectByCondition(ZfProperty zfProperty) {
|
String familyIds = listFamilyIds();
|
String secondFamilyIds = listSecondFamilyIds();
|
LambdaQueryWrapper<ZfProperty> lambdaQueryWrapper = buildCondition(zfProperty, familyIds, secondFamilyIds);
|
List<ZfProperty> list = list(lambdaQueryWrapper);
|
log.info("返回的数据为:{}", list);
|
return list;
|
}
|
|
private LambdaQueryWrapper<ZfProperty> buildCondition(ZfProperty zfProperty) {
|
LambdaQueryWrapper<ZfProperty> lqw = new LambdaQueryWrapper<>();
|
|
lqw.like(!StringUtils.isEmpty(zfProperty.getType()), ZfProperty::getType, zfProperty.getType())
|
.like(!StringUtils.isEmpty(zfProperty.getTitle()), ZfProperty::getTitle, zfProperty.getTitle())
|
.like(!StringUtils.isEmpty(zfProperty.getLocation()), ZfProperty::getLocation, zfProperty.getLocation())
|
.like(!StringUtils.isEmpty(zfProperty.getHolder()), ZfProperty::getHolder, zfProperty.getHolder())
|
.like(!StringUtils.isEmpty(zfProperty.getAddress()), ZfProperty::getAddress, zfProperty.getAddress())
|
.like(!StringUtils.isEmpty(zfProperty.getRemark()), ZfProperty::getRemark, zfProperty.getRemark())
|
.like(zfProperty.getCreateTime() != null, ZfProperty::getCreateTime, zfProperty.getCreateTime());
|
return lqw;
|
}
|
|
private LambdaQueryWrapper<ZfProperty> buildCondition(ZfProperty zfProperty, String familyIds, String secondFamilyAuthority) {
|
//模糊查询的条件
|
LambdaQueryWrapper<ZfProperty> lqw = buildCondition(zfProperty);
|
|
//定义一个布尔标记,标记第一家庭号是否有逗号
|
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) {
|
|
//得到权限串
|
String authorities = authorityAndId.substring(2, authorityAndId.length() - 1);
|
|
if (authorities.contains(" ")) {
|
//空格隔开得到菜单id,看是否有对应的权限
|
String[] authorityIdList = authorities.split(" ");
|
for (String s : authorityIdList) {
|
if (s.equals(PROPERTY_LIST)) {
|
secondFamilyIdsBuffer.append(authorityAndId.charAt(0)).append(",");
|
break;
|
}
|
}
|
} else {
|
if (authorities.equals(PROPERTY_LIST)) {
|
secondFamilyIdsBuffer.append(authorityAndId.charAt(0)).append(",");
|
}
|
}
|
}
|
|
//把后面的逗号去掉
|
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(ZfProperty::getFamilyId, totalFamilyIdList);
|
} else {
|
//如果第一家庭号没有逗号但是第二家庭号有逗号
|
String[] totalFamilyIdList = ArraysUtil.appendToArray(secondFamilyIdList, familyIds);
|
lqw.in(ZfProperty::getFamilyId, totalFamilyIdList);
|
}
|
|
} else {
|
if (flag) {
|
//如果第一家庭号有逗号但第二家庭号没有逗号
|
String[] familyList = familyIds.split(",");
|
String[] totalFamilyIdList = ArraysUtil.appendToArray(familyList, secondFamilyIds);
|
lqw.in(ZfProperty::getFamilyId, totalFamilyIdList);
|
} else {
|
//如果第一家庭号和第二家庭号都没有逗号
|
String[] totalFamilyIdList = ArraysUtil.appendToArray(familyIds, secondFamilyIds);
|
lqw.in(ZfProperty::getFamilyId, totalFamilyIdList);
|
}
|
}
|
} else {
|
//如果没有第二家庭号
|
if (flag) {
|
String[] familyList = familyIds.split(",");
|
lqw.in(ZfProperty::getFamilyId, familyList);
|
} else {
|
lqw.eq(ZfProperty::getFamilyId, familyIds);
|
}
|
|
}
|
|
lqw.orderByDesc(ZfProperty::getId);
|
return lqw;
|
}
|
|
|
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 AjaxResult selectPropertyList(ZfProperty zfProperty, Integer pageNum, Integer pageSize) {
|
String familyIds = listFamilyIds();
|
String secondFamilyAuthority = listSecondFamilyIds();
|
LambdaQueryWrapper<ZfProperty> lqw = buildCondition(zfProperty, familyIds, secondFamilyAuthority);
|
|
Page<ZfProperty> zfPropertyPage = new Page<>(pageNum, pageSize);
|
Page<ZfProperty> pageResult = page(zfPropertyPage, lqw);
|
|
List<ZfProperty> beanRecords = pageResult.getRecords();//得到查询出来的数据
|
|
List<ZfPropertyDto> dtoResult = beanRecords.stream().map(record -> {
|
String recordFamilyId = record.getFamilyId();
|
ZfPropertyDto zfPropertyDto = new ZfPropertyDto();
|
BeanUtils.copyProperties(record, zfPropertyDto);
|
|
if (familyIds.contains(",")) {
|
String[] familyIdList = familyIds.split(",");
|
for (String familyId : familyIdList) {
|
if (familyId.equals(recordFamilyId)) {
|
zfPropertyDto.setOwnData(1);
|
}
|
}
|
} else {
|
if (familyIds.equals(recordFamilyId)) {
|
zfPropertyDto.setOwnData(1);
|
}
|
}
|
return zfPropertyDto;
|
}).collect(Collectors.toList());
|
|
HashMap<String, Object> data = MapUtils.getResult(pageResult, dtoResult);
|
return AjaxResult.success(data);
|
}
|
|
@Override
|
public int addProperty(ZfProperty zfProperty) {
|
|
String familyIds = listFamilyIds();
|
boolean flag = false;//判断当前用户的id是否有权加入当前家庭id的对象
|
if (familyIds.contains(",")) {
|
String[] familyList = familyIds.split(",");
|
for (String familyId : familyList) {
|
if (familyId.equals(zfProperty.getFamilyId())) {
|
flag = true;
|
}
|
}
|
} else {
|
if (zfProperty.getFamilyId().equals(familyIds)) {
|
flag = true;
|
}
|
}
|
if (flag) {
|
boolean save = save(zfProperty);
|
return save ? 1 : 0;
|
} else {
|
throw new RuntimeException("你没有操作该家庭号为" + zfProperty.getFamilyId() + "数据的权限");
|
}
|
}
|
|
@Override
|
public AjaxResult importExcel(MultipartFile file) {
|
ExcelUtil<ZfProperty> util = new ExcelUtil<>(ZfProperty.class);
|
List<ZfProperty> propertyList = null;
|
try {
|
propertyList = util.importExcel(file.getInputStream());
|
} catch (Exception e) {
|
throw new RuntimeException(e);
|
}
|
log.info("资产列表为:{}", propertyList);
|
|
for (ZfProperty zfProperty : propertyList) {
|
zfPropertyService.addProperty(zfProperty);
|
}
|
|
return AjaxResult.success("导入数据成功");
|
|
}
|
|
}
|