[openweathermap] Fix display of alert data (#12697)
* fix display of alert data * improve javadoc * add javadoc to updateMinutelyForecastChannel Signed-off-by: Hans Böhm <h.boehm@gmx.at>
This commit is contained in:
parent
b51c930390
commit
cb60d891fb
|
@ -263,7 +263,7 @@ public class OpenWeatherMapOneCallHandler extends AbstractOpenWeatherMapHandler
|
||||||
}
|
}
|
||||||
Matcher alertsMatcher = CHANNEL_GROUP_ALERTS_PREFIX_PATTERN.matcher(channelGroupId);
|
Matcher alertsMatcher = CHANNEL_GROUP_ALERTS_PREFIX_PATTERN.matcher(channelGroupId);
|
||||||
if (alertsMatcher.find() && (i = Integer.parseInt(alertsMatcher.group(1))) >= 1) {
|
if (alertsMatcher.find() && (i = Integer.parseInt(alertsMatcher.group(1))) >= 1) {
|
||||||
updateAlertsChannel(channelUID, i);
|
updateAlertsChannel(channelUID, i - 1);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -371,6 +371,12 @@ public class OpenWeatherMapOneCallHandler extends AbstractOpenWeatherMapHandler
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the channel from the last OpenWeatherMap data retrieved.
|
||||||
|
*
|
||||||
|
* @param channelUID the id identifying the channel to be updated
|
||||||
|
* @param count the index of the minutely data referenced by the channel (minute 1 is count 0)
|
||||||
|
*/
|
||||||
private void updateMinutelyForecastChannel(ChannelUID channelUID, int count) {
|
private void updateMinutelyForecastChannel(ChannelUID channelUID, int count) {
|
||||||
String channelId = channelUID.getIdWithoutGroup();
|
String channelId = channelUID.getIdWithoutGroup();
|
||||||
String channelGroupId = channelUID.getGroupId();
|
String channelGroupId = channelUID.getGroupId();
|
||||||
|
@ -410,7 +416,7 @@ public class OpenWeatherMapOneCallHandler extends AbstractOpenWeatherMapHandler
|
||||||
* Update the channel from the last OpenWeatherMap data retrieved.
|
* Update the channel from the last OpenWeatherMap data retrieved.
|
||||||
*
|
*
|
||||||
* @param channelUID the id identifying the channel to be updated
|
* @param channelUID the id identifying the channel to be updated
|
||||||
* @param count the number of the hour referenced by the channel
|
* @param count the index of the hourly data referenced by the channel (hour 1 is count 0)
|
||||||
*/
|
*/
|
||||||
private void updateHourlyForecastChannel(ChannelUID channelUID, int count) {
|
private void updateHourlyForecastChannel(ChannelUID channelUID, int count) {
|
||||||
String channelId = channelUID.getIdWithoutGroup();
|
String channelId = channelUID.getIdWithoutGroup();
|
||||||
|
@ -509,7 +515,7 @@ public class OpenWeatherMapOneCallHandler extends AbstractOpenWeatherMapHandler
|
||||||
* Update the channel from the last OpenWeatherMap data retrieved.
|
* Update the channel from the last OpenWeatherMap data retrieved.
|
||||||
*
|
*
|
||||||
* @param channelUID the id identifying the channel to be updated
|
* @param channelUID the id identifying the channel to be updated
|
||||||
* @param count
|
* @param count the index of the daily data referenced by the channel (today is count 0)
|
||||||
*/
|
*/
|
||||||
private void updateDailyForecastChannel(ChannelUID channelUID, int count) {
|
private void updateDailyForecastChannel(ChannelUID channelUID, int count) {
|
||||||
String channelId = channelUID.getIdWithoutGroup();
|
String channelId = channelUID.getIdWithoutGroup();
|
||||||
|
@ -672,7 +678,7 @@ public class OpenWeatherMapOneCallHandler extends AbstractOpenWeatherMapHandler
|
||||||
* Update the channel from the last OpenWeaterhMap data retrieved.
|
* Update the channel from the last OpenWeaterhMap data retrieved.
|
||||||
*
|
*
|
||||||
* @param channelUID the id identifying the channel to be updated
|
* @param channelUID the id identifying the channel to be updated
|
||||||
* @param count
|
* @param count the index of the alert data referenced by the channel (alert 1 is count 0)
|
||||||
*/
|
*/
|
||||||
private void updateAlertsChannel(ChannelUID channelUID, int count) {
|
private void updateAlertsChannel(ChannelUID channelUID, int count) {
|
||||||
String channelId = channelUID.getIdWithoutGroup();
|
String channelId = channelUID.getIdWithoutGroup();
|
||||||
|
@ -681,7 +687,7 @@ public class OpenWeatherMapOneCallHandler extends AbstractOpenWeatherMapHandler
|
||||||
List<Alert> alerts = localWeatherData != null ? localWeatherData.alerts : null;
|
List<Alert> alerts = localWeatherData != null ? localWeatherData.alerts : null;
|
||||||
State state = UnDefType.UNDEF;
|
State state = UnDefType.UNDEF;
|
||||||
if (alerts != null && alerts.size() > count) {
|
if (alerts != null && alerts.size() > count) {
|
||||||
Alert alert = alerts.get(count - 1);
|
Alert alert = alerts.get(count);
|
||||||
switch (channelId) {
|
switch (channelId) {
|
||||||
case CHANNEL_ALERT_EVENT:
|
case CHANNEL_ALERT_EVENT:
|
||||||
state = getStringTypeState(alert.event);
|
state = getStringTypeState(alert.event);
|
||||||
|
|
Loading…
Reference in New Issue