mirror of
https://github.com/Kunsi/scheduled-plugin-pretalx-broadcast-tools.git
synced 2025-01-08 00:09:11 +00:00
try to keep schedule order in generated schedule.json
This commit is contained in:
parent
0ff25fb301
commit
0206873096
1 changed files with 20 additions and 3 deletions
23
service
23
service
|
@ -16,6 +16,22 @@ config.restart_on_update()
|
||||||
SEND_PREFIX = os.environ["NODE"].replace("root/", "root/plugin/")
|
SEND_PREFIX = os.environ["NODE"].replace("root/", "root/plugin/")
|
||||||
|
|
||||||
|
|
||||||
|
class TalkSorter(object):
|
||||||
|
def __init__(self, obj):
|
||||||
|
self.obj = obj
|
||||||
|
|
||||||
|
def __lt__(self, other):
|
||||||
|
if not isinstance(other, TalkSorter) or "start_ts" not in other.obj:
|
||||||
|
raise ValueError("TalkSorter can only compare talk dicts")
|
||||||
|
if (
|
||||||
|
"room_idx" in self.obj
|
||||||
|
and "room_idx" in other.obj
|
||||||
|
and self.obj["start_ts"] == other.obj["start_ts"]
|
||||||
|
):
|
||||||
|
return self.obj["room_idx"] < other.obj["room_idx"]
|
||||||
|
return self.obj["start_ts"] < other.obj["start_ts"]
|
||||||
|
|
||||||
|
|
||||||
def log(msg):
|
def log(msg):
|
||||||
sys.stderr.write("[pretalx] {}\n".format(msg))
|
sys.stderr.write("[pretalx] {}\n".format(msg))
|
||||||
|
|
||||||
|
@ -151,7 +167,7 @@ def main():
|
||||||
"color": color,
|
"color": color,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
schedule["talks"] = sorted(schedule["talks"], key=lambda t: t["start_ts"])
|
schedule["talks"] = sorted(schedule["talks"], key=TalkSorter)
|
||||||
node.write_json("schedule.json", schedule)
|
node.write_json("schedule.json", schedule)
|
||||||
log("updated schedule json")
|
log("updated schedule json")
|
||||||
elif config["json_flavour"] == "voc-schema":
|
elif config["json_flavour"] == "voc-schema":
|
||||||
|
@ -195,7 +211,7 @@ def main():
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
for room in day["rooms"].values():
|
for room_idx, (room_name, room) in enumerate(day["rooms"].items()):
|
||||||
for talk in room:
|
for talk in room:
|
||||||
start = event_tz.localize(
|
start = event_tz.localize(
|
||||||
datetime.strptime(
|
datetime.strptime(
|
||||||
|
@ -228,6 +244,7 @@ def main():
|
||||||
talk["track"] = track
|
talk["track"] = track
|
||||||
|
|
||||||
talk["room_uuid"] = room_uuid_mapping.get(talk["room"])
|
talk["room_uuid"] = room_uuid_mapping.get(talk["room"])
|
||||||
|
talk["room_idx"] = room_idx
|
||||||
|
|
||||||
persons = []
|
persons = []
|
||||||
for p in talk["persons"]:
|
for p in talk["persons"]:
|
||||||
|
@ -237,7 +254,7 @@ def main():
|
||||||
talk["persons"] = persons
|
talk["persons"] = persons
|
||||||
|
|
||||||
schedule["talks"].append(talk)
|
schedule["talks"].append(talk)
|
||||||
schedule["talks"] = sorted(schedule["talks"], key=lambda t: t["start_ts"])
|
schedule["talks"] = sorted(schedule["talks"], key=TalkSorter)
|
||||||
node.write_json("schedule.json", schedule)
|
node.write_json("schedule.json", schedule)
|
||||||
log("updated schedule json")
|
log("updated schedule json")
|
||||||
else:
|
else:
|
||||||
|
|
Loading…
Reference in a new issue