From c464bb203d8d9874a97424f674f816e45bcd981b Mon Sep 17 00:00:00 2001
From: zhongrj <646384940@qq.com>
Date: Tue, 02 Jan 2024 15:12:58 +0800
Subject: [PATCH] 住户导入修改(新增字段),新增省市县树查询

---
 src/main/java/org/springblade/modules/house/service/impl/HouseServiceImpl.java |  241 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 240 insertions(+), 1 deletions(-)

diff --git a/src/main/java/org/springblade/modules/house/service/impl/HouseServiceImpl.java b/src/main/java/org/springblade/modules/house/service/impl/HouseServiceImpl.java
index fcd5ae3..e5e3ab7 100644
--- a/src/main/java/org/springblade/modules/house/service/impl/HouseServiceImpl.java
+++ b/src/main/java/org/springblade/modules/house/service/impl/HouseServiceImpl.java
@@ -46,14 +46,18 @@
 import org.springblade.modules.label.entity.LabelEntity;
 import org.springblade.modules.label.service.ILabelService;
 import org.springblade.modules.system.entity.Dept;
+import org.springblade.modules.system.entity.Region;
 import org.springblade.modules.system.entity.User;
 import org.springblade.modules.system.service.IDeptService;
+import org.springblade.modules.system.service.IRegionService;
 import org.springblade.modules.system.service.IUserService;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
+import java.text.ParseException;
+import java.text.SimpleDateFormat;
 import java.util.*;
 
 /**
@@ -80,6 +84,9 @@
 
 	@Autowired
 	private IUserService userService;
+
+	@Autowired
+	private IRegionService regionService;
 
 	@Override
 	public IPage<HouseVO> selectHousePage(IPage<HouseVO> page, HouseVO house) {
@@ -256,7 +263,14 @@
 			houseEntity.setBuilding(houseAndHoldExcel.getBuilding());
 			houseEntity.setArea(houseAndHoldExcel.getArea());
 			houseEntity.setPropertyPrice(houseAndHoldExcel.getPropertyPrice());
-			houseEntity.setServiceDue(houseAndHoldExcel.getServiceDue());
+			if (!Strings.isBlank(houseAndHoldExcel.getServiceDue())) {
+				try {
+					Date date = new SimpleDateFormat("yyyy-MM-dd").parse(houseAndHoldExcel.getServiceDue());
+					houseEntity.setServiceDue(date);
+				} catch (ParseException e) {
+					e.printStackTrace();
+				}
+			}
 			houseEntity.setRemark(houseAndHoldExcel.getRemark());
 			houseEntity.setCreateTime(new Date());
 			houseEntity.setCreateUser(AuthUtil.getUserId().toString());
@@ -302,6 +316,7 @@
 					saveOrUpdateUser(householdEntity);
 				}
 			}
+			/// 是否主要联系人
 			if (!Strings.isBlank(houseAndHoldExcel.getIsPrimaryContact())){
 				householdEntity.setIsPrimaryContact(Integer.parseInt(houseAndHoldExcel.getIsPrimaryContact()));
 			}
@@ -320,22 +335,72 @@
 			}
 			householdEntity.setHkmtPass(houseAndHoldExcel.getHkmtPass());
 			householdEntity.setPassport(houseAndHoldExcel.getPassport());
+			// 民族
 			if (!Strings.isBlank(houseAndHoldExcel.getEthnicity())){
 				householdEntity.setEthnicity(Integer.parseInt(houseAndHoldExcel.getEthnicity()));
 			}
+			// 学历
 			if (!Strings.isBlank(houseAndHoldExcel.getEducation())){
 				householdEntity.setEducation(Integer.parseInt(houseAndHoldExcel.getEducation()));
 			}
+			// 户籍类型
+			if (!Strings.isBlank(houseAndHoldExcel.getResidentType())){
+				householdEntity.setResidentType(Integer.parseInt(houseAndHoldExcel.getResidentType()));
+			}
+			// 户籍地区县
+			if (!Strings.isBlank(houseAndHoldExcel.getResidentAdcode())){
+				String adCode = shiftResidentResidentAdCode(houseAndHoldExcel.getResidentProvinceAdcode(),
+					houseAndHoldExcel.getResidentCityAdcode(),
+					houseAndHoldExcel.getResidentAdcode());
+				// 转换行政区code
+				houseAndHoldExcel.setResidentAdcode(adCode);
+			}
 			householdEntity.setHukouRegistration(houseAndHoldExcel.getHukouRegistration());
+			// 籍贯地区县
+			if (!Strings.isBlank(houseAndHoldExcel.getNativePlaceAdcode())){
+				String adCode = shiftResidentResidentAdCode(null,
+					null,
+					houseAndHoldExcel.getNativePlaceAdcode());
+				// 转换行政区code
+				houseAndHoldExcel.setNativePlaceAdcode(adCode);
+			}
+			// 健康状况
+			if (!Strings.isBlank(houseAndHoldExcel.getHealthStatus())){
+				householdEntity.setHealthStatus(Integer.parseInt(houseAndHoldExcel.getHealthStatus()));
+			}
+			householdEntity.setDiseaseName(houseAndHoldExcel.getDiseaseName());
+			householdEntity.setReligiousBelief(houseAndHoldExcel.getReligiousBelief());
+			// 工作状态
 			if (!Strings.isBlank(houseAndHoldExcel.getWorkStatus())){
 				householdEntity.setWorkStatus(Integer.parseInt(houseAndHoldExcel.getWorkStatus()));
 			}
 			householdEntity.setEmployer(houseAndHoldExcel.getEmployer());
+			householdEntity.setOccupation(houseAndHoldExcel.getOccupation());
+			householdEntity.setCmpyRegAddr(houseAndHoldExcel.getCmpyRegAddr());
+			householdEntity.setGoOutReason(houseAndHoldExcel.getGoOutReason());
+			if (!Strings.isBlank(houseAndHoldExcel.getGoOutTime())) {
+				try {
+					Date date = new SimpleDateFormat("yyyy-MM-dd").parse(houseAndHoldExcel.getGoOutTime());
+					householdEntity.setGoOutTime(date);
+				} catch (ParseException e) {
+					e.printStackTrace();
+				}
+			}
+			householdEntity.setGoOutWhere(houseAndHoldExcel.getGoOutWhere());
+			householdEntity.setGoOutAddr(houseAndHoldExcel.getGoOutAddr());
+			// 婚姻状态
 			if (!Strings.isBlank(houseAndHoldExcel.getMaritalStatus())){
 				householdEntity.setMaritalStatus(Integer.parseInt(houseAndHoldExcel.getMaritalStatus()));
 			}
 			householdEntity.setCardNumber(houseAndHoldExcel.getCardNumber());
 			householdEntity.setOtherContact(houseAndHoldExcel.getOtherContact());
+			if (Strings.isBlank(householdEntity.getHouseCode())){
+				// 暂时不处理,导入数据目前都有house_code
+				String adCode = shiftResidentHomeAdcode(houseAndHoldExcel.getHomeAdcode());
+				// 转换行政区code
+				houseAndHoldExcel.setHomeAdcode(adCode);
+			}
+			householdEntity.setCurrentAddress(houseAndHoldExcel.getCurrentAddress());
 			householdEntity.setDisabilityCert(houseAndHoldExcel.getDisabilityCert());
 			householdEntity.setRemark(houseAndHoldExcel.getRemarks());
 			householdEntity.setCreateTime(new Date());
@@ -365,10 +430,184 @@
 					}
 				}
 			}
+		}else {
+			// 更新
+			one.setHouseCode(houseAndHoldExcel.getHouseCode());
+			one.setName(houseAndHoldExcel.getName());
+			one.setPhoneNumber(houseAndHoldExcel.getPhoneNumber());
+			if (!Strings.isBlank(houseAndHoldExcel.getRoleType())){
+				one.setRoleType(Integer.parseInt(houseAndHoldExcel.getRoleType()));
+			}
+			// 与角色关系
+			if (!Strings.isBlank(houseAndHoldExcel.getRelationship())){
+				one.setRelationship(Integer.parseInt(houseAndHoldExcel.getRelationship()));
+				// 如果是业主,则需要往用户表插入用户
+				if (one.getRelationship()==1){
+					saveOrUpdateUser(one);
+				}
+			}
+			/// 是否主要联系人
+			if (!Strings.isBlank(houseAndHoldExcel.getIsPrimaryContact())){
+				one.setIsPrimaryContact(Integer.parseInt(houseAndHoldExcel.getIsPrimaryContact()));
+			}
+			// 居住状态
+			if (!Strings.isBlank(houseAndHoldExcel.getResidentialStatus())){
+				one.setResidentialStatus(Integer.parseInt(houseAndHoldExcel.getResidentialStatus()));
+			}
+			// 性别
+			if (!Strings.isBlank(houseAndHoldExcel.getGender())){
+				one.setGender(Short.parseShort(houseAndHoldExcel.getGender()));
+			}
+			one.setIdCard(houseAndHoldExcel.getIdCard());
+			// 党员
+			if (!Strings.isBlank(houseAndHoldExcel.getPartyEmber())){
+				one.setPartyEmber(Integer.parseInt(houseAndHoldExcel.getPartyEmber()));
+			}
+			one.setHkmtPass(houseAndHoldExcel.getHkmtPass());
+			one.setPassport(houseAndHoldExcel.getPassport());
+			// 民族
+			if (!Strings.isBlank(houseAndHoldExcel.getEthnicity())){
+				one.setEthnicity(Integer.parseInt(houseAndHoldExcel.getEthnicity()));
+			}
+			// 学历
+			if (!Strings.isBlank(houseAndHoldExcel.getEducation())){
+				one.setEducation(Integer.parseInt(houseAndHoldExcel.getEducation()));
+			}
+			// 户籍类型
+			if (!Strings.isBlank(houseAndHoldExcel.getResidentType())){
+				one.setResidentType(Integer.parseInt(houseAndHoldExcel.getResidentType()));
+			}
+			// 户籍地区县
+			if (!Strings.isBlank(houseAndHoldExcel.getResidentAdcode())){
+				String adCode = shiftResidentResidentAdCode(houseAndHoldExcel.getResidentProvinceAdcode(),
+					houseAndHoldExcel.getResidentCityAdcode(),
+					houseAndHoldExcel.getResidentAdcode());
+				// 转换行政区code
+				houseAndHoldExcel.setResidentAdcode(adCode);
+			}
+			one.setHukouRegistration(houseAndHoldExcel.getHukouRegistration());
+			// 籍贯地区县
+			if (!Strings.isBlank(houseAndHoldExcel.getNativePlaceAdcode())){
+				String adCode = shiftResidentResidentAdCode(null,
+					null,
+					houseAndHoldExcel.getNativePlaceAdcode());
+				// 转换行政区code
+				houseAndHoldExcel.setNativePlaceAdcode(adCode);
+			}
+			// 健康状况
+			if (!Strings.isBlank(houseAndHoldExcel.getHealthStatus())){
+				one.setHealthStatus(Integer.parseInt(houseAndHoldExcel.getHealthStatus()));
+			}
+			one.setDiseaseName(houseAndHoldExcel.getDiseaseName());
+			one.setReligiousBelief(houseAndHoldExcel.getReligiousBelief());
+			// 工作状态
+			if (!Strings.isBlank(houseAndHoldExcel.getWorkStatus())){
+				one.setWorkStatus(Integer.parseInt(houseAndHoldExcel.getWorkStatus()));
+			}
+			one.setEmployer(houseAndHoldExcel.getEmployer());
+			one.setOccupation(houseAndHoldExcel.getOccupation());
+			one.setCmpyRegAddr(houseAndHoldExcel.getCmpyRegAddr());
+			one.setGoOutReason(houseAndHoldExcel.getGoOutReason());
+			if (!Strings.isBlank(houseAndHoldExcel.getGoOutTime())) {
+				try {
+					Date date = new SimpleDateFormat("yyyy-MM-dd").parse(houseAndHoldExcel.getGoOutTime());
+					one.setGoOutTime(date);
+				} catch (ParseException e) {
+					e.printStackTrace();
+				}
+			}
+			one.setGoOutWhere(houseAndHoldExcel.getGoOutWhere());
+			one.setGoOutAddr(houseAndHoldExcel.getGoOutAddr());
+			// 婚姻状态
+			if (!Strings.isBlank(houseAndHoldExcel.getMaritalStatus())){
+				one.setMaritalStatus(Integer.parseInt(houseAndHoldExcel.getMaritalStatus()));
+			}
+			one.setCardNumber(houseAndHoldExcel.getCardNumber());
+			one.setOtherContact(houseAndHoldExcel.getOtherContact());
+			if (Strings.isBlank(one.getHouseCode())){
+				// 暂时不处理,导入数据目前都有house_code
+				String adCode = shiftResidentHomeAdcode(houseAndHoldExcel.getHomeAdcode());
+				// 转换行政区code
+				houseAndHoldExcel.setHomeAdcode(adCode);
+			}
+			one.setCurrentAddress(houseAndHoldExcel.getCurrentAddress());
+			one.setDisabilityCert(houseAndHoldExcel.getDisabilityCert());
+			one.setRemark(houseAndHoldExcel.getRemarks());
+			one.setUpdateTime(new Date());
+			one.setUpdateUser(AuthUtil.getUserId());
+			// 新增
+			boolean update = householdService.updateById(one);
+			if (update) {
+				String labelId = houseAndHoldExcel.getLabelId();
+				if (StringUtils.isBlank(labelId)) {
+					return;
+				}
+				String[] split = labelId.split(",");
+				IUserHouseLabelService bean = SpringUtils.getBean(IUserHouseLabelService.class);
+				ILabelService bean1 = SpringUtils.getBean(ILabelService.class);
+				for (String s : split) {
+					LabelEntity one1 = bean1.getOne(Wrappers.<LabelEntity>lambdaQuery().eq(LabelEntity::getLabelName, s));
+					if (one1 != null) {
+						UserHouseLabelEntity userHouseLabelEntity = new UserHouseLabelEntity();
+						userHouseLabelEntity.setLabelId(BigDecimal.valueOf(one1.getId()).longValue());
+						userHouseLabelEntity.setHouseholdId(one.getId());
+						userHouseLabelEntity.setLableType(1);
+						userHouseLabelEntity.setLabelName(s);
+						userHouseLabelEntity.setHouseCode(houseAndHoldExcel.getHouseCode());
+						bean.save(userHouseLabelEntity);
+					}
+				}
+			}
 		}
 	}
 
 	/**
+	 * 现居住地街道转换
+	 * @param homeAdcode
+	 * @return
+	 */
+	public String shiftResidentHomeAdcode(String homeAdcode) {
+		// 只根据区县名称查询
+		QueryWrapper<Region> wrapper = new QueryWrapper<>();
+		wrapper.eq("town_name",homeAdcode);
+		List<Region> list = regionService.list(wrapper);
+		if (list.size()==1){
+			return list.get(0).getTownCode();
+		}
+		return "";
+	}
+
+	/**
+	 * 根据名称转成code
+	 * @param residentProvinceAdcode 省名称
+	 * @param residentCityAdcode 市名称
+	 * @param residentAdcode 区县名称
+	 */
+	public String shiftResidentResidentAdCode(String residentProvinceAdcode,String residentCityAdcode,String residentAdcode) {
+		if (!Strings.isBlank(residentProvinceAdcode)
+			&& !Strings.isBlank(residentCityAdcode)){
+			// 根据省市县三级查询对应的区县code
+			QueryWrapper<Region> wrapper = new QueryWrapper<>();
+			wrapper.eq("province_name",residentProvinceAdcode)
+				.eq("city_name",residentCityAdcode)
+				.eq("district_name",residentAdcode);
+			List<Region> list = regionService.list(wrapper);
+			if (list.size()>0){
+				return list.get(0).getDistrictCode();
+			}
+		}else {
+			// 只根据区县名称查询
+			QueryWrapper<Region> wrapper = new QueryWrapper<>();
+			wrapper.eq("district_name",residentAdcode);
+			List<Region> list = regionService.list(wrapper);
+			if (list.size()==1){
+				return list.get(0).getDistrictCode();
+			}
+		}
+		return "";
+	}
+
+	/**
 	 * 保存或更新用户(业主)
 	 * @param householdEntity
 	 */

--
Gitblit v1.9.3