Compare commits

...

3 Commits

Author SHA1 Message Date
b985ea7a92 ratp: Handle more disruptions cases
All checks were successful
continuous-integration/drone/push Build is passing
2024-06-07 09:53:26 +02:00
452a6097e3 weather: Improve next hour 2024-05-18 18:54:58 +02:00
1893e7c201 Fix weather alerts 2024-05-18 18:14:52 +02:00
2 changed files with 50 additions and 15 deletions

View File

@ -194,8 +194,16 @@ class IDFMAPI:
def get_line_weather(self, res, disruptions, mode, line):
for l in res["lines"]:
if l["id"] == "line:IDFM:" + IDFMAPI.lines[mode][line]:
disruptionIds = []
disruptionTypes = {}
for impactedObject in l["impactedObjects"]:
for disruptionId in impactedObject["disruptionIds"]:
if disruptionId not in disruptionIds:
disruptionTypes[disruptionId] = impactedObject["type"]
disruptionIds.append(disruptionId)
for disruptionId in disruptionIds:
impactType = disruptionTypes[disruptionId]
status = "past"
for ap in disruptions[disruptionId]["applicationPeriods"]:
end = datetime.strptime(ap["end"], "%Y%m%dT%H%M%S")
@ -209,7 +217,12 @@ class IDFMAPI:
status = "active"
break
if "cause" in disruptions and disruptions["cause"] == "INFORMATION":
continue
disruptions[disruptionId]["status"] = status
disruptions[disruptionId]["scope"] = impactType
yield disruptions[disruptionId]
return None
@ -217,12 +230,17 @@ class IDFMAPI:
def get_line_icon(config, mode, line, size, fill="gray", state=""):
if mode == "M" or mode == "metros":
icon_mode = "metro"
mode = "metros"
line = line.replace("B", "bis")
elif mode == "T" or mode == "tramways":
icon_mode = "tram"
mode = "tramways"
line = line.replace("T", "").lower()
elif mode == "R" or mode == "rers":
icon_mode = "RER"
mode = "rers"
elif mode == "B":
mode = "buses"
img_line = None
if mode == "rers" and fill != "white":
@ -415,15 +433,20 @@ class RATPWeatherModule:
state = ""
fill = "darkgray"
if "NO_SERVICE" in states:
if disruption["scope"] == "line" and ("NO_SERVICE" in states or "BLOQUANTE" in states):
fill = "black"
state = "_trafic_grand"
elif "REDUCED_SERVICE" in states or "UNKNOWN_EFFECT" in states or "OTHER_EFFECT" in states:
elif "PERTURBEE" in states:
fill = "brown"
state = "_trafic_moyen"
elif "REDUCED_SERVICE" in states or "UNKNOWN_EFFECT" in states or "OTHER_EFFECT" in states or "NO_SERVICE" in states or "BLOQUANTE" in states:
fill = "teal"
state = "_trafic_moyen"
elif "BLOQUANTE TRAVAUX" in states:
fill = "teal"
state = "_travaux_moyen"
elif "INFORMATION" in states:
state = "_travaux_petit"
elif len(states) > 0:
fill = "gray"
state = "_trafic_petit"
@ -518,6 +541,8 @@ class RATPNextStopModule:
})
align -= int(line_height * 0.33)
if align < 0:
align = 0
image = image.crop((0,0,width, min(align, height)))
return image, alerts

View File

@ -147,8 +147,10 @@ class WeatherJumboCurrentModule:
dayweather = list(itertools.islice(WeatherAPI().get_hourly(), 2))
if dayweather[0]["weather"][0]["description"] != dayweather[1]["weather"][0]["description"]:
display_longtext(draw, (width*self.middle_align, height/1.28), dayweather[1]["weather"][0]["description"] + " la prochaine heure.\n" + thisdayweather["summary"] + ".", fill="black", anchor="lm", font=fnt_Rig, maxwidth=(1-self.middle_align)*width)
if dayweather[0]["weather"][0]["description"] != curweather["weather"][0]["description"]:
description = dayweather[0]["weather"][0]["description"]
description = description[0].upper() + description[1:]
display_longtext(draw, (width*self.middle_align, height/1.28), description + " la prochaine heure.\n" + thisdayweather["summary"] + ".", fill="black", anchor="lm", font=fnt_Rig, maxwidth=(1-self.middle_align)*width)
else:
display_longtext(draw, (width*self.middle_align, height/1.28), thisdayweather["summary"] + ".", fill="black", anchor="lm", font=fnt_Rig, maxwidth=(1-self.middle_align)*width)
@ -361,30 +363,38 @@ class WeatherAlerts:
def gen_alerts(self):
alerts = []
lastStartTime = 0
lastEndTime = 0
for alert in WeatherAPI().get_alerts():
if alert["severity"] == "Moderate":
icon = "weather/wi-small-craft-advisory.png"
elif alert["severity"] != "Moderate":
icon = "weather/wi-gale-warning.png"
else:
icon = None
icon = "weather/wi-gale-warning.png"
startTime = WeatherAPI().read_timestamp(alert["start"])
endTime = WeatherAPI().read_timestamp(alert["end"]-1)
vendTime = WeatherAPI().read_timestamp(alert["end"])
startTime = WeatherAPI().read_timestamp(alert["effective"])
endTime = WeatherAPI().read_timestamp(alert["expires"])
# Show alert timing if under a day
if startTime.hour != endTime.hour:
if startTime.hour != vendTime.hour:
subtitle = startTime.strftime(("%x " if startTime.day != datetime.now().day else "") + "%X") + " - " + endTime.strftime(("%x " if startTime.day != endTime.day else "") + "%X")
elif startTime.day != datetime.now().day:
subtitle = startTime.strftime("%x")
else:
subtitle = ""
if len(alerts) >= 1 and alerts[len(alerts)-1]["title"] == alert["event"]:
startTime = lastStartTime
if startTime.hour != vendTime.hour:
alerts[len(alerts)-1]["subtitle"] = startTime.strftime(("%x " if startTime.day != datetime.now().day else "") + "%X") + " - " + endTime.strftime(("%x " if startTime.day != endTime.day else "") + "%X")
elif startTime.day != datetime.now().day:
alerts[len(alerts)-1]["subtitle"] = startTime.strftime("%x")
continue
lastStartTime = startTime
lastEndTime = vendTime
alerts.append({
"icon": icon,
"title": alert["headline"],
"title": alert["event"],
"subtitle": subtitle,
"description": alert["desc"],
"description": alert["description"],
})
return alerts