Compare commits

...

2 commits

View file

@ -10,6 +10,7 @@ from datetime import date, datetime, timedelta
import dateutil.rrule import dateutil.rrule
import dateutil.tz import dateutil.tz
import holidays # type: ignore import holidays # type: ignore
import isodate
import lxml import lxml
import pytz import pytz
import yaml import yaml
@ -22,7 +23,6 @@ from . import (
economist, economist,
fx, fx,
gwr, gwr,
markets,
stock_market, stock_market,
subscription, subscription,
sun, sun,
@ -144,10 +144,22 @@ def get_yaml_event_date_field(item: dict[str, str]) -> str:
) )
def get_yaml_event_end_date_field(item: dict[str, str]) -> str:
"""Event date field name."""
return (
"end_date"
if item["name"] == "travel_insurance"
else ("start_date" if "start_date" in item else "date")
)
def read_events_yaml(data_dir: str, start: date, end: date) -> list[Event]: def read_events_yaml(data_dir: str, start: date, end: date) -> list[Event]:
"""Read eventes from YAML file.""" """Read eventes from YAML file."""
events: list[Event] = [] events: list[Event] = []
for item in yaml.safe_load(open(os.path.join(data_dir, "events.yaml"))): for item in yaml.safe_load(open(os.path.join(data_dir, "events.yaml"))):
duration = (
isodate.parse_duration(item["duration"]) if "duration" in item else None
)
dates = ( dates = (
dates_from_rrule(item["rrule"], start, end) dates_from_rrule(item["rrule"], start, end)
if "rrule" in item if "rrule" in item
@ -158,7 +170,13 @@ def read_events_yaml(data_dir: str, start: date, end: date) -> list[Event]:
name=item["name"], name=item["name"],
date=dt, date=dt,
end_date=( end_date=(
item.get("end_date") if item["name"] != "travel_insurance" else None dt + duration
if duration
else (
item.get("end_date")
if item["name"] != "travel_insurance"
else None
)
), ),
title=item.get("title"), title=item.get("title"),
url=item.get("url"), url=item.get("url"),
@ -217,13 +235,7 @@ async def get_data(now: datetime) -> typing.Mapping[str, str | object]:
minus_365, plus_365, "us_clock_change", "America/New_York" minus_365, plus_365, "us_clock_change", "America/New_York"
), ),
"mothers_day": uk_holiday.get_mothers_day(today), "mothers_day": uk_holiday.get_mothers_day(today),
# "fathers_day": uk_holiday.get_fathers_day(today),
"gwr_advance_tickets": gwr_advance_tickets, "gwr_advance_tickets": gwr_advance_tickets,
"market": (
markets.windmill_hill(last_year, next_year)
+ markets.tobacco_factory(last_year, next_year)
+ markets.nailsea_farmers(last_year, next_year)
),
"rockets": rockets, "rockets": rockets,
} }