|
|
@@ -4,10 +4,16 @@ import com.alibaba.fastjson.JSONObject;
|
|
|
import com.java110.api.listener.AbstractServiceApiListener;
|
|
|
import com.java110.core.annotation.Java110Listener;
|
|
|
import com.java110.core.context.DataFlowContext;
|
|
|
+import com.java110.core.smo.community.ICommunityInnerServiceSMO;
|
|
|
import com.java110.core.smo.inspectionRoute.IInspectionRouteInnerServiceSMO;
|
|
|
import com.java110.core.smo.inspectionRoute.IInspectionRoutePointRelInnerServiceSMO;
|
|
|
+import com.java110.core.smo.room.IRoomInnerServiceSMO;
|
|
|
+import com.java110.core.smo.unit.IUnitInnerServiceSMO;
|
|
|
+import com.java110.dto.RoomDto;
|
|
|
+import com.java110.dto.community.CommunityDto;
|
|
|
import com.java110.dto.inspectionRoute.InspectionRouteDto;
|
|
|
import com.java110.dto.inspectionRoute.InspectionRoutePointRelDto;
|
|
|
+import com.java110.dto.unit.FloorAndUnitDto;
|
|
|
import com.java110.event.service.api.ServiceDataFlowEvent;
|
|
|
import com.java110.utils.constant.ServiceCodeInspectionRouteConstant;
|
|
|
import com.java110.utils.util.Assert;
|
|
|
@@ -34,6 +40,15 @@ public class ListInspectionRoutePointsListener extends AbstractServiceApiListene
|
|
|
@Autowired
|
|
|
private IInspectionRoutePointRelInnerServiceSMO inspectionRoutePointRelInnerServiceSMOImpl;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private IRoomInnerServiceSMO roomInnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private ICommunityInnerServiceSMO communityInnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IUnitInnerServiceSMO unitInnerServiceSMOImpl;
|
|
|
+
|
|
|
@Override
|
|
|
public String getServiceCode() {
|
|
|
return ServiceCodeInspectionRouteConstant.LIST_INSPECTIONROUTE_POINTS;
|
|
|
@@ -77,6 +92,8 @@ public class ListInspectionRoutePointsListener extends AbstractServiceApiListene
|
|
|
|
|
|
if (count > 0) {
|
|
|
inspectionPoints = BeanConvertUtil.covertBeanList(inspectionRoutePointRelInnerServiceSMOImpl.queryInspectionRoutePointRels(inspectionRoutePointRelDto), ApiInspectionPointDataVo.class);
|
|
|
+ // 刷新 位置信息
|
|
|
+ refreshMachines(inspectionPoints);
|
|
|
} else {
|
|
|
inspectionPoints = new ArrayList<>();
|
|
|
}
|
|
|
@@ -92,4 +109,119 @@ public class ListInspectionRoutePointsListener extends AbstractServiceApiListene
|
|
|
context.setResponseEntity(responseEntity);
|
|
|
|
|
|
}
|
|
|
+
|
|
|
+
|
|
|
+ private void refreshMachines(List<ApiInspectionPointDataVo> inspectionPoints) {
|
|
|
+ //批量处理 小区
|
|
|
+ refreshCommunitys(inspectionPoints);
|
|
|
+ //批量处理单元信息
|
|
|
+ refreshUnits(inspectionPoints);
|
|
|
+ //批量处理 房屋信息
|
|
|
+ refreshRooms(inspectionPoints);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 处理小区信息
|
|
|
+ */
|
|
|
+ private void refreshCommunitys(List<ApiInspectionPointDataVo> inspectionPoints) {
|
|
|
+ List<String> communityIds = new ArrayList<String>();
|
|
|
+ List<ApiInspectionPointDataVo> inspectionPointDataVo = new ArrayList<>();
|
|
|
+ for (ApiInspectionPointDataVo inspectionPoint : inspectionPoints) {
|
|
|
+
|
|
|
+ if (!"2000".equals(inspectionPoint.getLocationTypeCd()) && !"3000".equals(inspectionPoint.getLocationTypeCd())) {
|
|
|
+ communityIds.add(inspectionPoint.getLocationObjId());
|
|
|
+ inspectionPointDataVo.add(inspectionPoint);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if (communityIds.size() < 1) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ String[] tmpCommunityIds = communityIds.toArray(new String[communityIds.size()]);
|
|
|
+
|
|
|
+ CommunityDto communityDto = new CommunityDto();
|
|
|
+ communityDto.setCommunityIds(tmpCommunityIds);
|
|
|
+ //根据 userId 查询用户信息
|
|
|
+ List<CommunityDto> communityDtos = communityInnerServiceSMOImpl.queryCommunitys(communityDto);
|
|
|
+
|
|
|
+ for (ApiInspectionPointDataVo inspectionPoint : inspectionPointDataVo) {
|
|
|
+ for (CommunityDto tmpCommunityDto : communityDtos) {
|
|
|
+ if (inspectionPoint.getLocationObjId().equals(tmpCommunityDto.getCommunityId())) {
|
|
|
+ inspectionPoint.setLocationObjName(tmpCommunityDto.getName() + " " + inspectionPoint.getLocationTypeName());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取批量单元
|
|
|
+ *
|
|
|
+ * @param inspectionPoints
|
|
|
+ * @return 批量userIds 信息
|
|
|
+ */
|
|
|
+ private void refreshUnits(List<ApiInspectionPointDataVo> inspectionPoints) {
|
|
|
+ List<String> unitIds = new ArrayList<String>();
|
|
|
+ List<ApiInspectionPointDataVo> tmpInspectionPoints = new ArrayList<>();
|
|
|
+ for (ApiInspectionPointDataVo inspectionPointDataVo : inspectionPoints) {
|
|
|
+ if ("2000".equals(inspectionPointDataVo.getLocationTypeCd())) {
|
|
|
+ unitIds.add(inspectionPointDataVo.getLocationObjId());
|
|
|
+ tmpInspectionPoints.add(inspectionPointDataVo);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if (unitIds.size() < 1) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ String[] tmpUnitIds = unitIds.toArray(new String[unitIds.size()]);
|
|
|
+
|
|
|
+ FloorAndUnitDto floorAndUnitDto = new FloorAndUnitDto();
|
|
|
+ floorAndUnitDto.setUnitIds(tmpUnitIds);
|
|
|
+ //根据 userId 查询用户信息
|
|
|
+ List<FloorAndUnitDto> unitDtos = unitInnerServiceSMOImpl.getFloorAndUnitInfo(floorAndUnitDto);
|
|
|
+
|
|
|
+ for (ApiInspectionPointDataVo inspectionPointDataVo : tmpInspectionPoints) {
|
|
|
+ for (FloorAndUnitDto tmpUnitDto : unitDtos) {
|
|
|
+ if (inspectionPointDataVo.getLocationObjId().equals(tmpUnitDto.getUnitId())) {
|
|
|
+ inspectionPointDataVo.setLocationObjName(tmpUnitDto.getFloorNum() + "栋" + tmpUnitDto.getUnitNum() + "单元");
|
|
|
+ BeanConvertUtil.covertBean(tmpUnitDto, inspectionPointDataVo);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取批量单元
|
|
|
+ */
|
|
|
+ private void refreshRooms(List<ApiInspectionPointDataVo> inspectionPoints) {
|
|
|
+ List<String> roomIds = new ArrayList<String>();
|
|
|
+ List<ApiInspectionPointDataVo> tmpInspectionPoint = new ArrayList<>();
|
|
|
+ for (ApiInspectionPointDataVo inspectionPointDataVo : inspectionPoints) {
|
|
|
+
|
|
|
+ if ("3000".equals(inspectionPointDataVo.getLocationTypeCd())) {
|
|
|
+ roomIds.add(inspectionPointDataVo.getLocationObjId());
|
|
|
+ tmpInspectionPoint.add(inspectionPointDataVo);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (roomIds.size() < 1) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ String[] tmpRoomIds = roomIds.toArray(new String[roomIds.size()]);
|
|
|
+
|
|
|
+ RoomDto roomDto = new RoomDto();
|
|
|
+ roomDto.setRoomIds(tmpRoomIds);
|
|
|
+ roomDto.setCommunityId(inspectionPoints.get(0).getCommunityId());
|
|
|
+ //根据 userId 查询用户信息
|
|
|
+ List<RoomDto> roomDtos = roomInnerServiceSMOImpl.queryRooms(roomDto);
|
|
|
+
|
|
|
+ for (ApiInspectionPointDataVo inspectionPointDataVo : tmpInspectionPoint) {
|
|
|
+ for (RoomDto tmpRoomDto : roomDtos) {
|
|
|
+ if (inspectionPointDataVo.getLocationObjId().equals(tmpRoomDto.getRoomId())) {
|
|
|
+ inspectionPointDataVo.setLocationObjName(tmpRoomDto.getFloorNum() + "栋" + tmpRoomDto.getUnitNum() + "单元" + tmpRoomDto.getRoomNum() + "室");
|
|
|
+ BeanConvertUtil.covertBean(tmpRoomDto, inspectionPoints);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|