|
|
@@ -4,8 +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.floor.IFloorInnerServiceSMO;
|
|
|
import com.java110.core.smo.hardwareAdapation.IApplicationKeyInnerServiceSMO;
|
|
|
+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.hardwareAdapation.ApplicationKeyDto;
|
|
|
+import com.java110.dto.hardwareAdapation.ApplicationKeyDto;
|
|
|
+import com.java110.dto.unit.FloorAndUnitDto;
|
|
|
import com.java110.event.service.api.ServiceDataFlowEvent;
|
|
|
import com.java110.utils.constant.ServiceCodeApplicationKeyConstant;
|
|
|
import com.java110.utils.util.Assert;
|
|
|
@@ -30,6 +38,18 @@ public class ListApplicationKeysListener extends AbstractServiceApiListener {
|
|
|
@Autowired
|
|
|
private IApplicationKeyInnerServiceSMO applicationKeyInnerServiceSMOImpl;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private ICommunityInnerServiceSMO communityInnerServiceSMOImpl;
|
|
|
+
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IFloorInnerServiceSMO floorInnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IUnitInnerServiceSMO unitInnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IRoomInnerServiceSMO roomInnerServiceSMOImpl;
|
|
|
@Override
|
|
|
public String getServiceCode() {
|
|
|
return ServiceCodeApplicationKeyConstant.LIST_APPLICATIONKEYS;
|
|
|
@@ -72,7 +92,10 @@ public class ListApplicationKeysListener extends AbstractServiceApiListener {
|
|
|
List<ApiApplicationKeyDataVo> applicationKeys = null;
|
|
|
|
|
|
if (count > 0) {
|
|
|
- applicationKeys = BeanConvertUtil.covertBeanList(applicationKeyInnerServiceSMOImpl.queryApplicationKeys(applicationKeyDto), ApiApplicationKeyDataVo.class);
|
|
|
+ List<ApplicationKeyDto> applicationKeyDtos = applicationKeyInnerServiceSMOImpl.queryApplicationKeys(applicationKeyDto);
|
|
|
+ // 刷新 位置信息
|
|
|
+ refreshMachines(applicationKeyDtos);
|
|
|
+ applicationKeys = BeanConvertUtil.covertBeanList(applicationKeyDtos, ApiApplicationKeyDataVo.class);
|
|
|
} else {
|
|
|
applicationKeys = new ArrayList<>();
|
|
|
}
|
|
|
@@ -88,4 +111,156 @@ public class ListApplicationKeysListener extends AbstractServiceApiListener {
|
|
|
context.setResponseEntity(responseEntity);
|
|
|
|
|
|
}
|
|
|
+
|
|
|
+
|
|
|
+ private void refreshMachines(List<ApplicationKeyDto> applicationKeyDtos) {
|
|
|
+
|
|
|
+ //批量处理 小区
|
|
|
+ refreshCommunitys(applicationKeyDtos);
|
|
|
+
|
|
|
+ //批量处理单元信息
|
|
|
+ refreshUnits(applicationKeyDtos);
|
|
|
+
|
|
|
+ //批量处理 房屋信息
|
|
|
+ refreshRooms(applicationKeyDtos);
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取批量小区
|
|
|
+ *
|
|
|
+ * @param applicationKeyDtos 设备信息
|
|
|
+ * @return 批量userIds 信息
|
|
|
+ */
|
|
|
+ private void refreshCommunitys(List<ApplicationKeyDto> applicationKeyDtos) {
|
|
|
+ List<String> communityIds = new ArrayList<String>();
|
|
|
+ List<ApplicationKeyDto> tmpApplicationKeyDtos = new ArrayList<>();
|
|
|
+ for (ApplicationKeyDto applicationKeyDto : applicationKeyDtos) {
|
|
|
+
|
|
|
+ if (!"2000".equals(applicationKeyDto.getLocationTypeCd())
|
|
|
+ && !"3000".equals(applicationKeyDto.getLocationTypeCd())
|
|
|
+ ) {
|
|
|
+ communityIds.add(applicationKeyDto.getLocationObjId());
|
|
|
+ tmpApplicationKeyDtos.add(applicationKeyDto);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ 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 (ApplicationKeyDto applicationKeyDto : tmpApplicationKeyDtos) {
|
|
|
+ for (CommunityDto tmpCommunityDto : communityDtos) {
|
|
|
+ if (applicationKeyDto.getLocationObjId().equals(tmpCommunityDto.getCommunityId())) {
|
|
|
+ applicationKeyDto.setLocationObjName(tmpCommunityDto.getName() + " " + applicationKeyDto.getLocationTypeName());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取批量单元
|
|
|
+ *
|
|
|
+ * @param applicationKeyDtos 设备信息
|
|
|
+ * @return 批量userIds 信息
|
|
|
+ */
|
|
|
+ private void refreshUnits(List<ApplicationKeyDto> applicationKeyDtos) {
|
|
|
+ List<String> unitIds = new ArrayList<String>();
|
|
|
+ List<ApplicationKeyDto> tmpApplicationKeyDtos = new ArrayList<>();
|
|
|
+ for (ApplicationKeyDto applicationKeyDto : applicationKeyDtos) {
|
|
|
+
|
|
|
+ if ("2000".equals(applicationKeyDto.getLocationTypeCd())) {
|
|
|
+ unitIds.add(applicationKeyDto.getLocationObjId());
|
|
|
+ tmpApplicationKeyDtos.add(applicationKeyDto);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ 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 (ApplicationKeyDto applicationKeyDto : tmpApplicationKeyDtos) {
|
|
|
+ for (FloorAndUnitDto tmpUnitDto : unitDtos) {
|
|
|
+ if (applicationKeyDto.getLocationObjId().equals(tmpUnitDto.getUnitId())) {
|
|
|
+ applicationKeyDto.setLocationObjName(tmpUnitDto.getFloorNum() + "栋" + tmpUnitDto.getUnitNum() + "单元");
|
|
|
+ BeanConvertUtil.covertBean(tmpUnitDto, applicationKeyDto);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取批量单元
|
|
|
+ *
|
|
|
+ * @param applicationKeyDtos 设备信息
|
|
|
+ * @return 批量userIds 信息
|
|
|
+ */
|
|
|
+ private void refreshRooms(List<ApplicationKeyDto> applicationKeyDtos) {
|
|
|
+ List<String> roomIds = new ArrayList<String>();
|
|
|
+ List<ApplicationKeyDto> tmpApplicationKeyDtos = new ArrayList<>();
|
|
|
+ for (ApplicationKeyDto applicationKeyDto : applicationKeyDtos) {
|
|
|
+
|
|
|
+ if ("3000".equals(applicationKeyDto.getLocationTypeCd())) {
|
|
|
+ roomIds.add(applicationKeyDto.getLocationObjId());
|
|
|
+ tmpApplicationKeyDtos.add(applicationKeyDto);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (roomIds.size() < 1) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ String[] tmpRoomIds = roomIds.toArray(new String[roomIds.size()]);
|
|
|
+
|
|
|
+ RoomDto roomDto = new RoomDto();
|
|
|
+ roomDto.setRoomIds(tmpRoomIds);
|
|
|
+ roomDto.setCommunityId(applicationKeyDtos.get(0).getCommunityId());
|
|
|
+ //根据 userId 查询用户信息
|
|
|
+ List<RoomDto> roomDtos = roomInnerServiceSMOImpl.queryRooms(roomDto);
|
|
|
+
|
|
|
+ for (ApplicationKeyDto applicationKeyDto : tmpApplicationKeyDtos) {
|
|
|
+ for (RoomDto tmpRoomDto : roomDtos) {
|
|
|
+ if (applicationKeyDto.getLocationObjId().equals(tmpRoomDto.getRoomId())) {
|
|
|
+ applicationKeyDto.setLocationObjName(tmpRoomDto.getFloorNum() + "栋" + tmpRoomDto.getUnitNum() + "单元" + tmpRoomDto.getRoomNum() + "室");
|
|
|
+ BeanConvertUtil.covertBean(tmpRoomDto, applicationKeyDto);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public IFloorInnerServiceSMO getFloorInnerServiceSMOImpl() {
|
|
|
+ return floorInnerServiceSMOImpl;
|
|
|
+ }
|
|
|
+
|
|
|
+ public void setFloorInnerServiceSMOImpl(IFloorInnerServiceSMO floorInnerServiceSMOImpl) {
|
|
|
+ this.floorInnerServiceSMOImpl = floorInnerServiceSMOImpl;
|
|
|
+ }
|
|
|
+
|
|
|
+ public IUnitInnerServiceSMO getUnitInnerServiceSMOImpl() {
|
|
|
+ return unitInnerServiceSMOImpl;
|
|
|
+ }
|
|
|
+
|
|
|
+ public void setUnitInnerServiceSMOImpl(IUnitInnerServiceSMO unitInnerServiceSMOImpl) {
|
|
|
+ this.unitInnerServiceSMOImpl = unitInnerServiceSMOImpl;
|
|
|
+ }
|
|
|
+
|
|
|
+ public IRoomInnerServiceSMO getRoomInnerServiceSMOImpl() {
|
|
|
+ return roomInnerServiceSMOImpl;
|
|
|
+ }
|
|
|
+
|
|
|
+ public void setRoomInnerServiceSMOImpl(IRoomInnerServiceSMO roomInnerServiceSMOImpl) {
|
|
|
+ this.roomInnerServiceSMOImpl = roomInnerServiceSMOImpl;
|
|
|
+ }
|
|
|
}
|