|
|
@@ -2,19 +2,25 @@ package com.java110.store.bmo.contractChangePlan.impl;
|
|
|
|
|
|
import com.java110.core.annotation.Java110Transactional;
|
|
|
import com.java110.core.factory.GenerateCodeFactory;
|
|
|
+import com.java110.dto.RoomDto;
|
|
|
import com.java110.dto.contract.ContractDto;
|
|
|
import com.java110.dto.contractChangePlan.ContractChangePlanDto;
|
|
|
import com.java110.dto.contractChangePlanDetail.ContractChangePlanDetailDto;
|
|
|
import com.java110.dto.contractChangePlanRoom.ContractChangePlanRoomDto;
|
|
|
import com.java110.dto.contractRoom.ContractRoomDto;
|
|
|
import com.java110.dto.contractType.ContractTypeDto;
|
|
|
+import com.java110.dto.owner.OwnerRoomRelDto;
|
|
|
import com.java110.intf.common.IContractChangeUserInnerServiceSMO;
|
|
|
+import com.java110.intf.community.IRoomInnerServiceSMO;
|
|
|
import com.java110.intf.store.*;
|
|
|
+import com.java110.intf.user.IOwnerRoomRelInnerServiceSMO;
|
|
|
import com.java110.po.contract.ContractPo;
|
|
|
import com.java110.po.contractChangePlan.ContractChangePlanPo;
|
|
|
import com.java110.po.contractChangePlanDetail.ContractChangePlanDetailPo;
|
|
|
import com.java110.po.contractChangePlanRoom.ContractChangePlanRoomPo;
|
|
|
import com.java110.po.contractRoom.ContractRoomPo;
|
|
|
+import com.java110.po.owner.OwnerRoomRelPo;
|
|
|
+import com.java110.po.room.RoomPo;
|
|
|
import com.java110.store.bmo.contractChangePlan.ISaveContractChangePlanBMO;
|
|
|
import com.java110.utils.constant.StatusConstant;
|
|
|
import com.java110.utils.util.Assert;
|
|
|
@@ -50,6 +56,12 @@ public class SaveContractChangePlanBMOImpl implements ISaveContractChangePlanBMO
|
|
|
@Autowired
|
|
|
private IContractTypeInnerServiceSMO contractTypeInnerServiceSMOImpl;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private IOwnerRoomRelInnerServiceSMO ownerRoomRelInnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IRoomInnerServiceSMO roomInnerServiceSMOImpl;
|
|
|
+
|
|
|
/**
|
|
|
* 添加小区信息
|
|
|
*
|
|
|
@@ -75,7 +87,7 @@ public class SaveContractChangePlanBMOImpl implements ISaveContractChangePlanBMO
|
|
|
contractTypeDto.setStoreId(contractDtos.get(0).getStoreId());
|
|
|
List<ContractTypeDto> contractTypeDtos = contractTypeInnerServiceSMOImpl.queryContractTypes(contractTypeDto);
|
|
|
|
|
|
- Assert.listOnlyOne(contractTypeDtos,"合同类型不存在");
|
|
|
+ Assert.listOnlyOne(contractTypeDtos, "合同类型不存在");
|
|
|
|
|
|
contractChangePlanPo.setPlanId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_planId));
|
|
|
int flag = contractChangePlanInnerServiceSMOImpl.saveContractChangePlan(contractChangePlanPo);
|
|
|
@@ -101,7 +113,7 @@ public class SaveContractChangePlanBMOImpl implements ISaveContractChangePlanBMO
|
|
|
throw new IllegalArgumentException("保存变更记录失败");
|
|
|
}
|
|
|
|
|
|
- dealContractChangePlanRooms(contractChangePlanPo,contractChangePlanRoomPos);
|
|
|
+ dealContractChangePlanRooms(contractChangePlanPo, contractChangePlanRoomPos);
|
|
|
|
|
|
//需要审核时才写 工作流
|
|
|
if (!ContractTypeDto.NO_AUDIT.equals(contractTypeDtos.get(0).getAudit())) {
|
|
|
@@ -109,7 +121,7 @@ public class SaveContractChangePlanBMOImpl implements ISaveContractChangePlanBMO
|
|
|
ContractChangePlanDto contractChangePlanDto = BeanConvertUtil.covertBean(contractChangePlanPo, ContractChangePlanDto.class);
|
|
|
contractChangePlanDto.setCurrentUserId(contractChangePlanPo.getChangePerson());
|
|
|
contractChangeUserInnerServiceSMO.startProcess(contractChangePlanDto);
|
|
|
- }else{
|
|
|
+ } else {
|
|
|
ContractChangePlanPo tmpContractChangePlanPo = new ContractChangePlanPo();
|
|
|
tmpContractChangePlanPo.setPlanId(contractChangePlanPo.getPlanId());
|
|
|
tmpContractChangePlanPo.setState(ContractDto.STATE_AUDIT_FINISH);
|
|
|
@@ -127,15 +139,20 @@ public class SaveContractChangePlanBMOImpl implements ISaveContractChangePlanBMO
|
|
|
ContractPo contractPo = BeanConvertUtil.covertBean(contractChangePlanDetailDtos.get(0), ContractPo.class);
|
|
|
|
|
|
contractInnerServiceSMOImpl.updateContract(contractPo);
|
|
|
- dealContractChangePlanRoom(tmpContractChangePlanPo);
|
|
|
+ dealContractChangePlanRoom(tmpContractChangePlanPo, contractDtos.get(0));
|
|
|
}
|
|
|
|
|
|
|
|
|
-
|
|
|
return ResultVo.createResponseEntity(ResultVo.CODE_OK, "保存成功");
|
|
|
}
|
|
|
|
|
|
- private void dealContractChangePlanRoom(ContractChangePlanPo contractChangePlanPo) {
|
|
|
+ private void dealContractChangePlanRoom(ContractChangePlanPo contractChangePlanPo, ContractDto contractDto) {
|
|
|
+
|
|
|
+ //查询合同房屋
|
|
|
+ ContractRoomDto contractRoomDto = new ContractRoomDto();
|
|
|
+ contractRoomDto.setStoreId(contractChangePlanPo.getStoreId());
|
|
|
+ contractRoomDto.setContractId(contractDto.getContractId());
|
|
|
+ List<ContractRoomDto> oldContractRoomDtos = contractRoomInnerServiceSMOImpl.queryContractRooms(contractRoomDto);
|
|
|
// 查询 是否有资产变更
|
|
|
|
|
|
ContractChangePlanRoomDto contractChangePlanRoomDto = new ContractChangePlanRoomDto();
|
|
|
@@ -146,19 +163,27 @@ public class SaveContractChangePlanBMOImpl implements ISaveContractChangePlanBMO
|
|
|
List<ContractChangePlanRoomDto> contractChangePlanRoomDtos
|
|
|
= contractChangePlanRoomInnerServiceSMOImpl.queryContractChangePlanRooms(contractChangePlanRoomDto);
|
|
|
|
|
|
- if(contractChangePlanRoomDtos == null || contractChangePlanRoomDtos.size() < 1){
|
|
|
- return ;
|
|
|
+ if (contractChangePlanRoomDtos == null || contractChangePlanRoomDtos.size() < 1) {
|
|
|
+ //删除老的关系值
|
|
|
+ doDelOldRoomRel(contractChangePlanRoomDtos, oldContractRoomDtos);
|
|
|
+ return;
|
|
|
}
|
|
|
+ doAddRoomRel(contractDto, oldContractRoomDtos, contractChangePlanRoomDtos);
|
|
|
|
|
|
- //删除之前数据 插入新数据
|
|
|
- ContractRoomPo contractRoomPo = new ContractRoomPo();
|
|
|
- contractRoomPo.setContractId(contractChangePlanRoomDtos.get(0).getContractId());
|
|
|
- contractRoomPo.setStoreId(contractChangePlanRoomDtos.get(0).getStoreId());
|
|
|
- contractRoomInnerServiceSMOImpl.deleteContractRoom(contractRoomPo);
|
|
|
+ //删除老的关系值
|
|
|
+ doDelOldRoomRel(contractChangePlanRoomDtos, oldContractRoomDtos);
|
|
|
|
|
|
- //插入新的关系值
|
|
|
|
|
|
- for(ContractChangePlanRoomDto tmpContractChangePlanRoomDto : contractChangePlanRoomDtos){
|
|
|
+ }
|
|
|
+
|
|
|
+ private void doAddRoomRel(ContractDto contractDto, List<ContractRoomDto> oldContractRoomDtos, List<ContractChangePlanRoomDto> contractChangePlanRoomDtos) {
|
|
|
+ //删除之前数据 插入新数据
|
|
|
+ ContractRoomPo contractRoomPo = null;
|
|
|
+ //插入新的关系值
|
|
|
+ for (ContractChangePlanRoomDto tmpContractChangePlanRoomDto : contractChangePlanRoomDtos) {
|
|
|
+ if (isOldRoom(tmpContractChangePlanRoomDto, oldContractRoomDtos)) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
contractRoomPo = new ContractRoomPo();
|
|
|
contractRoomPo.setContractId(contractChangePlanRoomDtos.get(0).getContractId());
|
|
|
contractRoomPo.setStoreId(contractChangePlanRoomDtos.get(0).getStoreId());
|
|
|
@@ -168,10 +193,133 @@ public class SaveContractChangePlanBMOImpl implements ISaveContractChangePlanBMO
|
|
|
contractRoomPo.setRoomId(tmpContractChangePlanRoomDto.getRoomId());
|
|
|
contractRoomPo.setRoomName(tmpContractChangePlanRoomDto.getRoomName());
|
|
|
contractRoomInnerServiceSMOImpl.saveContractRoom(contractRoomPo);
|
|
|
+
|
|
|
+ //刷业主
|
|
|
+ OwnerRoomRelDto ownerRoomRelDto = new OwnerRoomRelDto();
|
|
|
+ ownerRoomRelDto.setRoomId(contractRoomPo.getRoomId());
|
|
|
+ List<OwnerRoomRelDto> ownerRoomRelDtos = ownerRoomRelInnerServiceSMOImpl.queryOwnerRoomRels(ownerRoomRelDto);
|
|
|
+
|
|
|
+ if (ownerRoomRelDtos != null && ownerRoomRelDtos.size() > 0) { // 说明业主没有发生变化,后续工作不做处理
|
|
|
+ if (contractDto.getObjId().equals(ownerRoomRelDtos.get(0).getOwnerId())) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ //绑定关系
|
|
|
+ String relId = GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_relId);
|
|
|
+ OwnerRoomRelPo ownerRoomRelPo = new OwnerRoomRelPo();
|
|
|
+ ownerRoomRelPo.setEndTime(contractDto.getEndTime());
|
|
|
+ ownerRoomRelPo.setStartTime(contractDto.getStartTime());
|
|
|
+ ownerRoomRelPo.setOwnerId(contractDto.getObjId());
|
|
|
+ ownerRoomRelPo.setRelId(relId);
|
|
|
+ ownerRoomRelPo.setRemark("签订合同自动绑定");
|
|
|
+ ownerRoomRelPo.setRoomId(contractRoomPo.getRoomId());
|
|
|
+ ownerRoomRelPo.setState("2001");
|
|
|
+ ownerRoomRelPo.setUserId("-1");
|
|
|
+ ownerRoomRelPo.setOperate("ADD");
|
|
|
+ ownerRoomRelPo.setbId("-1");
|
|
|
+ ownerRoomRelInnerServiceSMOImpl.saveBusinessOwnerRoomRels(ownerRoomRelPo);
|
|
|
+
|
|
|
+ ownerRoomRelPo = new OwnerRoomRelPo();
|
|
|
+ ownerRoomRelPo.setEndTime(contractDto.getEndTime());
|
|
|
+ ownerRoomRelPo.setStartTime(contractDto.getStartTime());
|
|
|
+ ownerRoomRelPo.setOwnerId(contractDto.getObjId());
|
|
|
+ ownerRoomRelPo.setRelId(relId);
|
|
|
+ ownerRoomRelPo.setRemark("签订合同自动绑定");
|
|
|
+ ownerRoomRelPo.setRoomId(contractRoomPo.getRoomId());
|
|
|
+ ownerRoomRelPo.setState("2001");
|
|
|
+ ownerRoomRelPo.setUserId("-1");
|
|
|
+ ownerRoomRelInnerServiceSMOImpl.saveOwnerRoomRels(ownerRoomRelPo);
|
|
|
+
|
|
|
+ //修改房屋状态
|
|
|
+ RoomPo roomPo = new RoomPo();
|
|
|
+ roomPo.setRoomId(contractRoomPo.getRoomId());
|
|
|
+ roomPo.setState(RoomDto.STATE_SELL);
|
|
|
+ roomPo.setStatusCd(StatusConstant.STATUS_CD_VALID);
|
|
|
+ roomInnerServiceSMOImpl.updateRooms(roomPo);
|
|
|
+ //删除老的
|
|
|
+ if (ownerRoomRelDtos != null && ownerRoomRelDtos.size() > 0) {
|
|
|
+ ownerRoomRelPo = new OwnerRoomRelPo();
|
|
|
+ ownerRoomRelPo.setStatusCd(StatusConstant.STATUS_CD_INVALID);
|
|
|
+ ownerRoomRelPo.setRelId(ownerRoomRelDtos.get(0).getRelId());
|
|
|
+ ownerRoomRelInnerServiceSMOImpl.updateOwnerRoomRels(ownerRoomRelPo);
|
|
|
+ ownerRoomRelPo = BeanConvertUtil.covertBean(ownerRoomRelDtos.get(0), OwnerRoomRelPo.class);
|
|
|
+ ownerRoomRelPo.setbId("-1");
|
|
|
+ ownerRoomRelPo.setOperate("DEL");
|
|
|
+ ownerRoomRelInnerServiceSMOImpl.saveBusinessOwnerRoomRels(ownerRoomRelPo);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ private void doDelOldRoomRel(List<ContractChangePlanRoomDto> contractChangePlanRoomDtos, List<ContractRoomDto> oldContractRoomDtos) {
|
|
|
+ ContractRoomPo contractRoomPo;
|
|
|
+ OwnerRoomRelPo ownerRoomRelPo = null;
|
|
|
+ for (ContractRoomDto oldContractRoomDto : oldContractRoomDtos) {
|
|
|
+ if (isDelOldRoom(oldContractRoomDto, contractChangePlanRoomDtos)) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ contractRoomPo = new ContractRoomPo();
|
|
|
+ contractRoomPo.setContractId(oldContractRoomDtos.get(0).getContractId());
|
|
|
+ contractRoomPo.setStoreId(oldContractRoomDtos.get(0).getStoreId());
|
|
|
+ contractRoomPo.setCrId(oldContractRoomDto.getCrId());
|
|
|
+ contractRoomInnerServiceSMOImpl.deleteContractRoom(contractRoomPo);
|
|
|
+
|
|
|
+ //刷业主
|
|
|
+ OwnerRoomRelDto ownerRoomRelDto = new OwnerRoomRelDto();
|
|
|
+ ownerRoomRelDto.setRoomId(oldContractRoomDto.getRoomId());
|
|
|
+ List<OwnerRoomRelDto> ownerRoomRelDtos = ownerRoomRelInnerServiceSMOImpl.queryOwnerRoomRels(ownerRoomRelDto);
|
|
|
+
|
|
|
+ if (ownerRoomRelDtos == null || ownerRoomRelDtos.size() < 1) { // 说明房屋没有业主
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ //删除关系
|
|
|
+ ownerRoomRelPo = new OwnerRoomRelPo();
|
|
|
+ ownerRoomRelPo.setStatusCd(StatusConstant.STATUS_CD_INVALID);
|
|
|
+ ownerRoomRelPo.setRelId(ownerRoomRelDtos.get(0).getRelId());
|
|
|
+ ownerRoomRelInnerServiceSMOImpl.updateOwnerRoomRels(ownerRoomRelPo);
|
|
|
+
|
|
|
+ //插入删除关系
|
|
|
+ ownerRoomRelPo = BeanConvertUtil.covertBean(ownerRoomRelDtos.get(0), OwnerRoomRelPo.class);
|
|
|
+ ownerRoomRelPo.setbId("-1");
|
|
|
+ ownerRoomRelPo.setOperate("DEL");
|
|
|
+ ownerRoomRelInnerServiceSMOImpl.saveBusinessOwnerRoomRels(ownerRoomRelPo);
|
|
|
+
|
|
|
+
|
|
|
+ //修改房屋状态
|
|
|
+ RoomPo roomPo = new RoomPo();
|
|
|
+ roomPo.setRoomId(oldContractRoomDto.getRoomId());
|
|
|
+ roomPo.setState(RoomDto.STATE_FREE);
|
|
|
+ roomPo.setStatusCd(StatusConstant.STATUS_CD_VALID);
|
|
|
+ roomInnerServiceSMOImpl.updateRooms(roomPo);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ private boolean isDelOldRoom(ContractRoomDto oldContractRoomDto, List<ContractChangePlanRoomDto> contractChangePlanRoomDtos) {
|
|
|
+ if (contractChangePlanRoomDtos == null || contractChangePlanRoomDtos.size() > 0) {
|
|
|
+ return false;
|
|
|
}
|
|
|
|
|
|
+ for (ContractChangePlanRoomDto contractChangePlanRoomDto : contractChangePlanRoomDtos) {
|
|
|
+ if (contractChangePlanRoomDto.getRoomId().equals(oldContractRoomDto.getRoomId())) {
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return false;
|
|
|
+ }
|
|
|
|
|
|
+ private boolean isOldRoom(ContractChangePlanRoomDto tmpContractChangePlanRoomDto, List<ContractRoomDto> oldContractRoomDtos) {
|
|
|
+ if (oldContractRoomDtos == null || oldContractRoomDtos.size() > 0) {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+
|
|
|
+ for (ContractRoomDto contractRoomDto : oldContractRoomDtos) {
|
|
|
+ if (tmpContractChangePlanRoomDto.getRoomId().equals(contractRoomDto.getRoomId())) {
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+ }
|
|
|
|
|
|
+ return false;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
@@ -186,7 +334,7 @@ public class SaveContractChangePlanBMOImpl implements ISaveContractChangePlanBMO
|
|
|
return;
|
|
|
}
|
|
|
ContractChangePlanRoomPo tmpContractChangePlanRoomPo = null;
|
|
|
- for(ContractChangePlanRoomPo contractChangePlanRoomPo : contractChangePlanRoomPos){
|
|
|
+ for (ContractChangePlanRoomPo contractChangePlanRoomPo : contractChangePlanRoomPos) {
|
|
|
|
|
|
ContractRoomDto contractRoomDto = new ContractRoomDto();
|
|
|
contractRoomDto.setContractId(contractChangePlanPo.getContractId());
|
|
|
@@ -194,7 +342,7 @@ public class SaveContractChangePlanBMOImpl implements ISaveContractChangePlanBMO
|
|
|
List<ContractRoomDto> contractRoomDtos
|
|
|
= contractRoomInnerServiceSMOImpl.queryContractRooms(contractRoomDto);
|
|
|
|
|
|
- if(contractRoomDtos != null && contractRoomDtos.size()> 0){
|
|
|
+ if (contractRoomDtos != null && contractRoomDtos.size() > 0) {
|
|
|
tmpContractChangePlanRoomPo = new ContractChangePlanRoomPo();
|
|
|
tmpContractChangePlanRoomPo.setContractId(contractChangePlanPo.getContractId());
|
|
|
tmpContractChangePlanRoomPo.setOwnerId(contractRoomDtos.get(0).getOwnerId());
|