|  |  |  | 
|---|
|  |  |  | package com.panzhihua.service_user.service.impl;/** | 
|---|
|  |  |  | * @program: springcloud_k8s_panzhihuazhihuishequ | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @description: 居民导入 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @author: huang.hongfa weixin hhf9596 qq 959656820 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @create: 2021-02-05 17:42 | 
|---|
|  |  |  | **/ | 
|---|
|  |  |  | public class SysUserInputServiceImpl { | 
|---|
|  |  |  | package com.panzhihua.service_user.service.impl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson.JSONArray; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | 
|---|
|  |  |  | import com.panzhihua.common.exceptions.ServiceException; | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.user.EexcelUserDTO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.R; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.ComMngStructAreaVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.ComMngStructHouseVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.ComMngVolunteerMngVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.user.ComMngFamilyInfoVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.user.CommunityUserInfoVO; | 
|---|
|  |  |  | import com.panzhihua.common.utlis.IdCard; | 
|---|
|  |  |  | import com.panzhihua.service_user.dao.SysUserInputDAO; | 
|---|
|  |  |  | import com.panzhihua.service_user.model.dos.ComMngFamilyInfoDO; | 
|---|
|  |  |  | import com.panzhihua.service_user.model.dos.SysUserDO; | 
|---|
|  |  |  | import com.panzhihua.service_user.model.dos.SysUserInputDO; | 
|---|
|  |  |  | import com.panzhihua.service_user.service.SysUserInputService; | 
|---|
|  |  |  | import org.apache.commons.lang3.ObjectUtils; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.data.redis.core.StringRedisTemplate; | 
|---|
|  |  |  | import org.springframework.data.redis.core.ValueOperations; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @program: springcloud_k8s_panzhihuazhihuishequ | 
|---|
|  |  |  | * @description: 居民导入 | 
|---|
|  |  |  | * @author: huang.hongfa weixin hhf9596 qq 959656820 | 
|---|
|  |  |  | * @create: 2021-02-05 17:42 | 
|---|
|  |  |  | **/ | 
|---|
|  |  |  | @Service | 
|---|
|  |  |  | public class SysUserInputServiceImpl extends ServiceImpl<SysUserInputDAO, SysUserInputDO> implements SysUserInputService { | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private SysUserInputDAO sysUserInputDAO; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private StringRedisTemplate stringRedisTemplate; | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 批量导入居民用户 | 
|---|
|  |  |  | * @param list 居民用户集合 | 
|---|
|  |  |  | * @param areaName 小区名字 | 
|---|
|  |  |  | * @return 导入结果 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public R batchSaveUser(List<EexcelUserDTO> list, StringBuffer areaName) { | 
|---|
|  |  |  | List<SysUserInputDO> sysUserInputDOS=new ArrayList<>(); | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(list)) { | 
|---|
|  |  |  | ComMngStructAreaVO comMngStructAreaVO=sysUserInputDAO.selectByAreaName(areaName.toString()); | 
|---|
|  |  |  | //            查询该小区所有房屋信息用来进行匹配房屋编码 | 
|---|
|  |  |  | String key="house_"+areaName; | 
|---|
|  |  |  | Boolean aBoolean = stringRedisTemplate.hasKey(key); | 
|---|
|  |  |  | ValueOperations<String, String> stringStringValueOperations = stringRedisTemplate.opsForValue(); | 
|---|
|  |  |  | List<ComMngStructHouseVO> comMngStructHouseVOS=new ArrayList<>(); | 
|---|
|  |  |  | if (aBoolean) { | 
|---|
|  |  |  | String value = stringStringValueOperations.get(key); | 
|---|
|  |  |  | comMngStructHouseVOS= JSONArray.parseArray(value,ComMngStructHouseVO.class); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | comMngStructHouseVOS=sysUserInputDAO.selectHouserByareaName(areaName.toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<ComMngStructHouseVO> comMngStructHouseVOS1=comMngStructHouseVOS; | 
|---|
|  |  |  | list.forEach(eexcelUserDTO -> { | 
|---|
|  |  |  | SysUserInputDO sysUserInputDO=new SysUserInputDO(); | 
|---|
|  |  |  | String doorNumber = eexcelUserDTO.getDoorNumber(); | 
|---|
|  |  |  | List<ComMngStructHouseVO> collect = comMngStructHouseVOS1.stream().filter(comMngStructHouseVO -> comMngStructHouseVO.getHouseName().equals(doorNumber)).collect(Collectors.toList()); | 
|---|
|  |  |  | if (ObjectUtils.isEmpty(collect)) { | 
|---|
|  |  |  | throw new ServiceException("门牌号后台不存在或格式错误,错误门牌号为"+doorNumber); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | sysUserInputDO.setHouseCode(collect.get(0).getHouseCode()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | sysUserInputDO.setAreaId(comMngStructAreaVO.getId()); | 
|---|
|  |  |  | sysUserInputDO.setCommunityId(comMngStructAreaVO.getCommunityId()); | 
|---|
|  |  |  | sysUserInputDO.setCompany(eexcelUserDTO.getCompany()); | 
|---|
|  |  |  | sysUserInputDO.setDoorNumber(doorNumber); | 
|---|
|  |  |  | sysUserInputDO.setEducation(eexcelUserDTO.getEducation()); | 
|---|
|  |  |  | sysUserInputDO.setIdCard(eexcelUserDTO.getIdCard()); | 
|---|
|  |  |  | sysUserInputDO.setIsContact(eexcelUserDTO.getIsContact().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setIsPanzhihua(eexcelUserDTO.getIsPanZhiHua().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setIsRent(eexcelUserDTO.getIsRent().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setKeyPersonnel(eexcelUserDTO.getKeyPersonnel().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setLowincomeHouseholds(eexcelUserDTO.getLowIncomeHouseholds().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setLowincomePeople(eexcelUserDTO.getLowIncomePeople().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setMajor(eexcelUserDTO.getMajor().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setMaritalStatus(eexcelUserDTO.getMaritalStatus().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setName(eexcelUserDTO.getName()); | 
|---|
|  |  |  | sysUserInputDO.setNation(eexcelUserDTO.getNation()); | 
|---|
|  |  |  | sysUserInputDO.setOldPeople(eexcelUserDTO.getOldPeople().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setDisability(eexcelUserDTO.getDisability().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setPhone(eexcelUserDTO.getPhone()); | 
|---|
|  |  |  | String politicalOutlook = eexcelUserDTO.getPoliticalOutlook(); | 
|---|
|  |  |  | sysUserInputDO.setPoliticalOutlook(politicalOutlook.equals("党员")?1:politicalOutlook.equals("团员")?2:3); | 
|---|
|  |  |  | sysUserInputDO.setResidence(eexcelUserDTO.getResidence()); | 
|---|
|  |  |  | sysUserInputDO.setSituation(eexcelUserDTO.getSituation()); | 
|---|
|  |  |  | sysUserInputDO.setSoldier(eexcelUserDTO.getSoldier().equals("是")?1:0); | 
|---|
|  |  |  | sysUserInputDO.setSpecialServiceFamily(eexcelUserDTO.getSpecialServiceFamily().equals("是")?1:0); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | sysUserInputDOS.add(sysUserInputDO); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | this.saveBatch(sysUserInputDOS); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 社区人员详情包括导入人员 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @param userId 人员id | 
|---|
|  |  |  | * @return CommunityUserInfoVO | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public CommunityUserInfoVO detailUserComunity(Long userId) { | 
|---|
|  |  |  | CommunityUserInfoVO communityUserInfoVO=new CommunityUserInfoVO(); | 
|---|
|  |  |  | userId=userId-100000000l; | 
|---|
|  |  |  | SysUserInputDO sysUserInputDO = sysUserInputDAO.selectById(userId); | 
|---|
|  |  |  | if (!org.springframework.util.ObjectUtils.isEmpty(sysUserInputDO)) { | 
|---|
|  |  |  | BeanUtils.copyProperties(sysUserInputDO,communityUserInfoVO); | 
|---|
|  |  |  | String idCard = sysUserInputDO.getIdCard(); | 
|---|
|  |  |  | if (!org.springframework.util.ObjectUtils.isEmpty(idCard)) { | 
|---|
|  |  |  | communityUserInfoVO.setAge(IdCard.IdNOToAge(idCard)); | 
|---|
|  |  |  | communityUserInfoVO.setBirthday(IdCard.birthDay(idCard)); | 
|---|
|  |  |  | communityUserInfoVO.setIdCard(idCard); | 
|---|
|  |  |  | communityUserInfoVO.setSex(IdCard.sex(idCard)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String phone = sysUserInputDO.getPhone(); | 
|---|
|  |  |  | communityUserInfoVO.setPhone(phone); | 
|---|
|  |  |  | Integer keyPersonnel = sysUserInputDO.getKeyPersonnel(); | 
|---|
|  |  |  | Integer specialServiceFamily = sysUserInputDO.getSpecialServiceFamily(); | 
|---|
|  |  |  | Integer soldier = sysUserInputDO.getSoldier(); | 
|---|
|  |  |  | Integer lowincomeHouseholds = sysUserInputDO.getLowincomeHouseholds(); | 
|---|
|  |  |  | Integer lowincomePeople = sysUserInputDO.getLowincomePeople(); | 
|---|
|  |  |  | Integer oldPeople = sysUserInputDO.getOldPeople(); | 
|---|
|  |  |  | Integer disability = sysUserInputDO.getDisability(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | StringBuilder stringBuilder=new StringBuilder(""); | 
|---|
|  |  |  | if (keyPersonnel.intValue()==1) { | 
|---|
|  |  |  | stringBuilder.append("重点人员,"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (specialServiceFamily.intValue()==1) { | 
|---|
|  |  |  | stringBuilder.append("特服家庭,"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (soldier.intValue()==1) { | 
|---|
|  |  |  | stringBuilder.append("军人,"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (lowincomeHouseholds.intValue()==1) { | 
|---|
|  |  |  | stringBuilder.append("低保户,"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (lowincomePeople.intValue()==1) { | 
|---|
|  |  |  | stringBuilder.append("低收入人员,"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (oldPeople.intValue()==1) { | 
|---|
|  |  |  | stringBuilder.append("高龄老人,"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (disability.intValue()==1) { | 
|---|
|  |  |  | stringBuilder.append("残疾人,"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | communityUserInfoVO.setTags(stringBuilder.toString()); | 
|---|
|  |  |  | communityUserInfoVO.setUserId(userId); | 
|---|
|  |  |  | communityUserInfoVO.setIsVolunteer(0); | 
|---|
|  |  |  | String doorNumber = sysUserInputDO.getDoorNumber(); | 
|---|
|  |  |  | List<ComMngFamilyInfoVO> comMngFamilyInfoVOS = sysUserInputDAO.selectListFamily(doorNumber,userId); | 
|---|
|  |  |  | communityUserInfoVO.setComMngFamilyInfoVOS(comMngFamilyInfoVOS); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return communityUserInfoVO; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|