diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/controller/StationAttributeController.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/controller/StationAttributeController.java index eede11e..0f6a0d0 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/controller/StationAttributeController.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/controller/StationAttributeController.java @@ -91,12 +91,13 @@ public class StationAttributeController extends BladeController { return R.status(stationAttributeService.deleteLogic(Func.toLongList(ids))); } - @PutMapping("/bandingMonitor") + @GetMapping("/bandingMonitor") @ApiOperation("根据设备编码更新集中监控监测点绑定") @ApiOperationSupport(order = 4) - public R> bandingMonitor(@ApiParam(value = "设备编码",required = true) String emCode, + public R> bandingMonitor(@ApiParam(value = "站点编码",required = true) String stationCode, + @ApiParam(value = "设备编码",required = true) String emCode, @ApiParam(value = "站点类型",required = true) String stationType, - @ApiParam(value = "设备类型",required = true) String emType) { - return R.data(stationAttributeService.bandingMonitor(emCode,stationType,emType)); + @ApiParam(value = "机组类型",required = true) String setType) { + return R.data(stationAttributeService.bandingMonitor(stationCode,emCode,stationType,setType)); } } diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/service/IStationAttributeService.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/service/IStationAttributeService.java index d3ecdb8..9f0bdff 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/service/IStationAttributeService.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/service/IStationAttributeService.java @@ -45,5 +45,5 @@ public interface IStationAttributeService extends BaseService bandingMonitor(String emCode,String stationType,String emType); + List bandingMonitor(String stationCode,String emCode,String stationType,String setType); } diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/service/impl/StationAttributeServiceImpl.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/service/impl/StationAttributeServiceImpl.java index e9dd316..9a60ed7 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/service/impl/StationAttributeServiceImpl.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/station/service/impl/StationAttributeServiceImpl.java @@ -209,13 +209,14 @@ public class StationAttributeServiceImpl extends BaseServiceImpl bandingMonitor(String emCode,String stationType,String emType) { + public List bandingMonitor(String stationCode,String emCode,String stationType,String setType) { List result; // 获取集中监控属性配置 List attributes = attributeService.list(Wrappers.lambdaQuery() .eq(FocusAttributeEntity::getDomainId, stationType) - .eq(FocusAttributeEntity::getGroupId, emType) + .eq(FocusAttributeEntity::getGroupId, setType) .eq(FocusAttributeEntity::getStatus, 0) + .orderByAsc(FocusAttributeEntity::getSort) ); // 标识 List signages = attributes.stream().map(FocusAttributeEntity::getSignage).filter(Func::isNotEmpty).collect(Collectors.toList()); @@ -225,19 +226,64 @@ public class StationAttributeServiceImpl extends BaseServiceImpl> deviceChildrenListResult = deviceClient.getRealId(deviceChildrenDTO); - boolean facAttrFlag = deviceChildrenListResult.isSuccess() && CollectionUtil.isNotEmpty(deviceChildrenListResult.getData()); - // 根据集中监控属性配置获取站点集中监控属性配置 - Function convert = focusAttr -> { - StationAttributeVo vo = BeanUtil.copy(focusAttr,StationAttributeVo.class); - if(facAttrFlag) { - List data = deviceChildrenListResult.getData(); - Optional facAttrOptional = data.stream().filter(attr -> focusAttr.getSignage().equals(attr.getSignage())).findAny(); - vo.setMonitorId(facAttrOptional.map(DeviceChildrenVO::getRealId).orElse(null)); - vo.setMonitorName(facAttrOptional.map(DeviceChildrenVO::getName).orElse(null)); - } - return vo; - }; - result = attributes.stream().map(convert).collect(Collectors.toList()); + List modelAttr = deviceChildrenListResult.isSuccess() && CollectionUtil.isNotEmpty(deviceChildrenListResult.getData()) + ? deviceChildrenListResult.getData() : new ArrayList<>(); + // 获取 + LambdaQueryWrapper queryWrapper = Wrappers.lambdaQuery() + .eq(StationAttributeEntity::getStationId, stationCode) + .eq(StationAttributeEntity::getEmCode, emCode); + List stationAttrList = this.list(queryWrapper); + result = attributes.stream().map(focusAttr -> this.fillFacAttr(modelAttr,focusAttr,stationCode,emCode)) + .map(stationAttr -> this.fillAttrId(stationAttrList,stationAttr)) + .sorted(Comparator.comparing(StationAttributeVo::getSort,Comparator.nullsLast(Integer::compareTo))) + .collect(Collectors.toList()); return result; } + + /** + * 根据请求设备实例物模型属性填充集中监控属性配置采集点 + * @param modelAttr 设备实例物模型属性 + * @param focusAttr 集中监控属性配置 + * @return + */ + private StationAttributeVo fillFacAttr(List modelAttr,FocusAttributeEntity focusAttr,String stationCode,String emCode) { + StationAttributeVo vo = BeanUtil.copy(focusAttr,StationAttributeVo.class); + Optional facAttrOptional = modelAttr.stream().filter(attr -> focusAttr.getSignage().equals(attr.getSignage())).findAny(); + vo.setMonitorId(facAttrOptional.map(DeviceChildrenVO::getRealId).orElse(null)); + vo.setMonitorName(facAttrOptional.map(DeviceChildrenVO::getName).orElse(null)); + vo.setStationId(stationCode); + vo.setEmCode(emCode); + vo.setEnableShow(true); + vo.setId(null); + vo.setCreateUser(null); + vo.setCreateDept(null); + vo.setCreateTime(null); + vo.setUpdateTime(null); + vo.setUpdateUser(null); + return vo; + } + + /** + * 填充属性ID + * @param stationAttrList 已保存进数据库的记录 + * @param stationAttr 填充采集点后的属性模板 + * @return + */ + private StationAttributeVo fillAttrId(List stationAttrList,StationAttributeVo stationAttr) { + if(CollectionUtil.isNotEmpty(stationAttrList)) { + Optional attribute = stationAttrList.stream().filter(sa -> stationAttr.getAttributes().equals(sa.getAttributes())).findAny(); + if(attribute.isPresent()) { + StationAttributeVo result = BeanUtil.copy(attribute.get(),StationAttributeVo.class); + result.setSignage(stationAttr.getSignage()); + result.setSignageName(stationAttr.getSignageName()); + result.setMonitorId(stationAttr.getMonitorId()); + result.setMonitorName(stationAttr.getMonitorName()); + result.setUpdateUser(null); + result.setUpdateTime(null); + return result; + } + stationAttr.setSort(null); + } + return stationAttr; + } }