From 2bcbf32c439a5d7fbb20234b86e410347d5b806f Mon Sep 17 00:00:00 2001 From: Jinquan_Ou <Jinquan@gdut.com> Date: 星期六, 15 四月 2023 16:04:48 +0800 Subject: [PATCH] 456 --- zhang-content/src/main/java/com/ruoyi/service/impl/ZInfoUserServiceImpl.java | 273 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 273 insertions(+), 0 deletions(-) diff --git a/zhang-content/src/main/java/com/ruoyi/service/impl/ZInfoUserServiceImpl.java b/zhang-content/src/main/java/com/ruoyi/service/impl/ZInfoUserServiceImpl.java index 97d663b..93b18ec 100644 --- a/zhang-content/src/main/java/com/ruoyi/service/impl/ZInfoUserServiceImpl.java +++ b/zhang-content/src/main/java/com/ruoyi/service/impl/ZInfoUserServiceImpl.java @@ -2,11 +2,35 @@ +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; +import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; +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.domain.ZInfoUser; +import com.ruoyi.domain.ZfEvent; +import com.ruoyi.domain.ZfRelation; +import com.ruoyi.domain.dto.EmpowerDto; +import com.ruoyi.domain.dto.UserRelationDto; import com.ruoyi.mapper.ZInfoUserMapper; import com.ruoyi.service.ZInfoUserService; +import com.ruoyi.service.ZfRelationService; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.BeanUtils; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.HashMap; +import java.util.List; +import java.util.stream.Collectors; /** * <p> @@ -17,6 +41,255 @@ * @since 2023-03-14 */ @Service +@Slf4j public class ZInfoUserServiceImpl extends ServiceImpl<ZInfoUserMapper, ZInfoUser> implements ZInfoUserService { + @Autowired + private ZfRelationService zfRelationService; + + @Override + public AjaxResult selectInfoList(ZInfoUser zInfoUser, Integer pageNum, Integer pageSize) { + + LambdaQueryWrapper<ZInfoUser> lqw = buildCondition(zInfoUser); + + Page<ZInfoUser> zInfoUserPage = new Page<>(pageNum,pageSize); + Page<ZInfoUser> pageResult = page(zInfoUserPage, lqw); + + HashMap<String, Object> data = MapUtils.getResult(pageResult); + return AjaxResult.success(data); + + } + + private LambdaQueryWrapper<ZInfoUser> buildCondition(ZInfoUser zInfoUser) { + + LambdaQueryWrapper<ZInfoUser> lqw = new LambdaQueryWrapper<>(); + lqw.eq(zInfoUser.getUserId()!=null,ZInfoUser::getUserId,zInfoUser.getUserId()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getAlwaysAddress()),ZInfoUser::getAlwaysAddress,zInfoUser.getAlwaysAddress()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getAlwaysPolice()),ZInfoUser::getAlwaysPolice,zInfoUser.getAlwaysPolice()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getIdNum()),ZInfoUser::getIdNum,zInfoUser.getIdNum()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getLocationAddress()),ZInfoUser::getLocationAddress,zInfoUser.getLocationAddress()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getLocationPolice()),ZInfoUser::getLocationPolice,zInfoUser.getLocationPolice()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getNation()),ZInfoUser::getNation,zInfoUser.getNation()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getNationality()),ZInfoUser::getNationality,zInfoUser.getNationality()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getNickName()),ZInfoUser::getNickName,zInfoUser.getNickName()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getOldName()),ZInfoUser::getOldName,zInfoUser.getOldName()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getPhoneNumber()),ZInfoUser::getPhoneNumber,zInfoUser.getPhoneNumber()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getPoliticalOutlook()),ZInfoUser::getPoliticalOutlook,zInfoUser.getPoliticalOutlook()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getPosition()),ZInfoUser::getPosition,zInfoUser.getPosition()); + lqw.like(StringUtils.isNotEmpty(zInfoUser.getUnit()),ZInfoUser::getUnit,zInfoUser.getUnit()); + lqw.like(zInfoUser.getSex()!=null,ZInfoUser::getSex,zInfoUser.getSex()); + lqw.like(zInfoUser.getMaritalStatus()!=null,ZInfoUser::getMaritalStatus,zInfoUser.getMaritalStatus()); + lqw.like(zInfoUser.getBirth()!=null,ZInfoUser::getBirth,zInfoUser.getBirth()); + return lqw; + + } + + @Override + public List<ZInfoUser> selectByCondition(ZInfoUser zInfoUser) { + LambdaQueryWrapper<ZInfoUser> lambdaQueryWrapper = buildCondition(zInfoUser); + List<ZInfoUser> list = list(lambdaQueryWrapper); + log.info("杩斿洖鐨勬暟鎹负:{}",list); + return list; + + } + + @Override + public AjaxResult searchMyRelation(Long userId) { + + LambdaQueryWrapper<ZfRelation> lqw = new LambdaQueryWrapper<>(); + lqw.eq(ZfRelation::getMyId,userId); + List<ZfRelation> relationList = zfRelationService.list(lqw); + + ArrayList<UserRelationDto> otherUserList = new ArrayList<>(); + + relationList.stream().map( + (relation)->{ + Long otherId = relation.getOtherId(); + ZInfoUser otherUser = getById(otherId); + UserRelationDto userRelationDto = new UserRelationDto(); + BeanUtils.copyProperties(otherUser,userRelationDto); + userRelationDto.setRelation(relation.getRelation()); + userRelationDto.setId(relation.getId()); + otherUserList.add(userRelationDto); + return relation; + } + ).collect(Collectors.toList()); + + return AjaxResult.success(otherUserList); + } + + /** + * 妫�鏌ヤ紶鍏ュ鏂圭殑id鏄惁瀛樺湪 + * @param zfRelation + */ + private void checkRelation(ZfRelation zfRelation){ + + LambdaQueryWrapper<ZInfoUser> lqw = new LambdaQueryWrapper<>(); + lqw.eq(ZInfoUser::getUserId, zfRelation.getOtherId()); + + ZInfoUser zInfoUser2 = getOne(lqw); + if (zInfoUser2==null){ + throw new RuntimeException("瀵规柟鐨刬d涓嶅瓨鍦�"); + } + } + + @Override + @Transactional + public AjaxResult addRelation(ZfRelation zfRelation) { + checkRelation(zfRelation); + + //鑾峰彇鑷繁鐨刬d骞朵紶鍏� + SysUser user = SecurityUtils.getLoginUser().getUser(); + Long userId = user.getUserId(); + zfRelation.setMyId(userId); + + zfRelationService.save(zfRelation); + return AjaxResult.success(); + } + + @Override + @Transactional + public AjaxResult updateRelation(ZfRelation zfRelation) { + checkRelation(zfRelation); + zfRelationService.updateById(zfRelation); + return AjaxResult.success(); + } + + @Override + public AjaxResult deleteRelation(Long[] ids) { + boolean flag = zfRelationService.removeByIds(Arrays.asList(ids)); + if (flag){ + return AjaxResult.success(); + }else { + return AjaxResult.error(); + } + } + + /** + * 缁欑敤鎴锋巿鏉冪殑鏂规硶 + * @param empowerDto + * @return + */ + @Override + @Transactional + public AjaxResult empower(EmpowerDto empowerDto) { + + //寰楀埌dto涓殑淇℃伅 + String otherUserId = empowerDto.getUserId(); + String destinationFamilyId = empowerDto.getFamilyId(); + List<String> authorityList = empowerDto.getAuthorityList(); + + String familyId = getMyFamilyId(); + checkAuthorization(familyId, destinationFamilyId,true); + + //鎺堟潈 //3{2007 1988 1004} + String finalStr = getFinalStr(destinationFamilyId, authorityList); + + //鏇存柊琚巿鏉冪敤鎴风殑鏉冮檺 + LambdaQueryWrapper<ZInfoUser> lqw2 = new LambdaQueryWrapper<>(); + lqw2.eq(ZInfoUser::getUserId,otherUserId); + ZInfoUser otherUser = getOne(lqw2); + String secondFamilyId = otherUser.getSecondFamilyId(); + + String replaceFamilyId=null; + + boolean save=true; + + if (StringUtils.isNotEmpty(secondFamilyId)){ + //濡傛灉鍘熸潵灏卞凡缁忔湁琚祴浜堟潈闄愪簡锛岄偅涔堥渶瑕佸垽鏂槸涓嶆槸璺熻繖涓搴彿鏈夊叧鐨勬潈闄� + + //杩欎釜secondFamilyId鏄綋鍓嶇敤鎴风殑瀹屾暣鏉冮檺瀛楁 + if(secondFamilyId.contains(",")){ + String[] split = secondFamilyId.split(","); + for (int i = 0; i < split.length; i++) { + String fid = split[i].substring(0, split[i].indexOf("{"));//浠庢潈闄愬潡涓嬁鍒拌鎺堟潈鐨勫搴彿 + if(fid.equals(finalStr.substring(0,finalStr.indexOf("{")))){ + //濡傛灉鍖归厤鍒颁簡瀵瑰簲鐨勫搴彿锛岄偅涔堝氨鏇挎崲鎺夊搴旂殑鏉冮檺鍧楀氨鍙互浜嗭紝涓嶉渶瑕佽拷鍔� + save=false; + split[i]=finalStr; + break; + } + } + List<String> finalList = Arrays.asList(split); + StringBuilder stringBuilder = new StringBuilder(); + for (String s : finalList) { + stringBuilder.append(s).append(","); + } + stringBuilder.deleteCharAt(stringBuilder.length()-1); + + replaceFamilyId = stringBuilder.toString(); + + }else { + String fid = secondFamilyId.substring(0, secondFamilyId.indexOf("{"));//浠庢潈闄愬潡涓嬁鍒拌鎺堟潈鐨勫搴彿 + if(fid.equals(finalStr.substring(0,finalStr.indexOf("{")))){ + //濡傛灉鍖归厤鍒颁簡瀵瑰簲鐨勫搴彿锛岄偅涔堝氨鏇挎崲鎺夊搴旂殑鏉冮檺鍧楀氨鍙互浜嗭紝涓嶉渶瑕佽拷鍔� + save=false; + replaceFamilyId=finalStr; + } + } + + if(save){ + //闇�瑕佽拷鍔�,娌℃湁鍖归厤鍒板搴旂殑瀹跺涵鍙� + replaceFamilyId=secondFamilyId+","+finalStr; + }else { + //涓嶉渶瑕佽拷鍔� + } + + }else { + //鍘熸潵灏辨病鏈夋潈闄愪簡 + replaceFamilyId=finalStr; + } + + LambdaUpdateWrapper<ZInfoUser> uw = new LambdaUpdateWrapper<>(); + uw.eq(ZInfoUser::getUserId,otherUserId).set(ZInfoUser::getSecondFamilyId,replaceFamilyId); + if (update(null,uw)) { + return AjaxResult.success(); + }else { + return AjaxResult.error(); + } + + } + + private void checkAuthorization(String familyId, String destinationFamilyId,boolean flag) { + String text=null; + if(flag){ + text="鎺堟潈"; + }else { + text="鍙栨秷鎺堟潈"; + } + + //瀵规湰浜虹殑瀹跺涵鍙疯繘琛屽鐞� + if(familyId.contains(",")){ + String[] familyIds = familyId.split(","); + List<String> idList = Arrays.asList(familyIds); + if (!idList.contains(destinationFamilyId)) { + throw new RuntimeException("涓嶈兘"+text+"涓嶅睘浜庤嚜宸卞搴殑鏁版嵁"); + } + }else { + if (!familyId.equals(destinationFamilyId)){ + throw new RuntimeException("涓嶈兘"+text+"涓嶅睘浜庤嚜宸卞搴殑鏁版嵁"); + } + } + } + + private String getMyFamilyId() { + //寰楀埌鑷繁鐨勫搴璱d淇℃伅 + SysUser user = SecurityUtils.getLoginUser().getUser(); + Long myUserId = user.getUserId(); + LambdaQueryWrapper<ZInfoUser> lqw = new LambdaQueryWrapper<>(); + lqw.eq(ZInfoUser::getUserId,myUserId); + ZInfoUser zInfoUser = getOne(lqw); + String familyId = zInfoUser.getFamilyId(); + return familyId; + } + + + + private String getFinalStr(String destinationFamilyId, List<String> authorityList) { + String authorityListStr = authorityList.stream().collect(Collectors.joining(" ", "{", "}")); + String finalStr= destinationFamilyId +authorityListStr; //3{2007 1988 1004} + return finalStr; + } + + } -- Gitblit v1.9.1