From 32b9ab49a84dc8610f7034b25e5ff98b2686408e Mon Sep 17 00:00:00 2001 From: Rsclub2_2 Date: Thu, 12 Oct 2023 18:52:17 +0200 Subject: [PATCH] Things --- Hafas_Main_web.py | 132 ++++++--------------- Hafas_Main_web_old.py | 41 +++++++ templates/index.html | 265 ++++++++++++++++++++---------------------- 3 files changed, 204 insertions(+), 234 deletions(-) create mode 100644 Hafas_Main_web_old.py diff --git a/Hafas_Main_web.py b/Hafas_Main_web.py index 11c3c47..c284060 100644 --- a/Hafas_Main_web.py +++ b/Hafas_Main_web.py @@ -1,111 +1,51 @@ -import datetime -from typing import List -from flask import Flask, render_template, request, make_response -import json - -# Part 1: Importieren der erforderlichen Module und Erstellen des Hafas-Clients -from pyhafas import HafasClient -from pyhafas.profile import DBProfile -from pyhafas.types.fptf import Leg +from flask import Flask, render_template, request, make_response, jsonify +import requests app = Flask(__name__) -client = HafasClient(DBProfile()) - -# Part 2: Suchen Sie nach der Haltestelle basierend auf der Benutzereingabe -def get_departures(station_name): - locations = client.locations(station_name) - if locations: - best_found_location = locations[0] - return best_found_location - else: - return None - -def station_board_leg_to_dict(leg): - delay_in_seconds = 0 - if leg.delay is not None: - delay_in_seconds = leg.delay.total_seconds() // 60 - return { - "name": leg.name, - "direction": leg.direction, - "dateTime": leg.dateTime.strftime("%Y-%m-%d %H:%M:%S"), - "delay": delay_in_seconds, - "platform": leg.platform, - } - - -# Part 3: Rufen Sie Abfahrtsinformationen für die gefundene Haltestelle ab -def get_departure_info(station_name): - best_found_location = get_departures(station_name) - if best_found_location: - departures: List[Leg] = client.departures( - station=best_found_location, - date=datetime.datetime.now(), - max_trips=15, - products={ - 'long_distance_express': True, - 'regional_express': True, - 'regional': True, - 'suburban': True, - 'bus': True, - 'ferry': True, - 'subway': True, - 'tram': True, - 'taxi': True - } - ) - return departures - else: - return [] @app.route('/', methods=['GET', 'POST']) def index(): + station_name = request.cookies.get('station_name', '') # Versuche, den Stationsnamen aus dem Cookie zu lesen departures = [] - station_name = "" - - # Get the station name from the cookie, if it exists - if request.cookies.get('station_name'): - station_name = request.cookies.get('station_name') if request.method == 'POST': - station_name = request.form['station_name'] - departures = get_departure_info(station_name) + station_name = request.form.get('station_name', '') + if station_name: + # Speichere den Stationsnamen im Cookie + url = f"https://dbf.finalrewind.org/{station_name}.json?version=3" + response = requests.get(url) - # Set the station name cookie - response = make_response(render_template('index.html', departures=departures, station_name=station_name)) - response.set_cookie('station_name', station_name) - return response + if response.status_code == 200: + data = response.json() + departures = data.get("departures", []) + resp = make_response(render_template('index.html', station_name=station_name, departures=departures)) + resp.set_cookie('station_name', station_name) + return resp - return render_template('index.html', departures=departures, station_name=station_name) + if station_name: # Überprüfe, ob ein Stationsname aus dem Cookie gelesen wurde + url = f"https://dbf.finalrewind.org/{station_name}.json?version=3" + response = requests.get(url) -@app.route('/departures', methods=['GET']) -def departures(): - """ - Gibt die aktuellen Abfahrtsinformationen zurück. + if response.status_code == 200: + data = response.json() + departures = data.get("departures", []) - Returns: - JSON-Objekt mit den Abfahrtsinformationen. - """ - station_name=request.cookies.get('station_name') - departures = client.departures( - station=get_departures(station_name), - date=datetime.datetime.now(), - max_trips=15, - products={ - 'long_distance_express': True, - 'regional_express': True, - 'regional': True, - 'suburban': True, - 'bus': True, - 'ferry': True, - 'subway': True, - 'tram': True, - 'taxi': True - } - ) + return render_template('index.html', station_name=station_name, departures=departures) - # Konvertiere die Abfahrtsinformationen in ein JSON-Objekt - departures_json = json.dumps([station_board_leg_to_dict(leg) for leg in departures]) - return departures_json +@app.route('/update_departures', methods=['GET']) +def update_departures(): + station_name = request.cookies.get('station_name', '') + departures = [] + + if station_name: + url = f"https://dbf.finalrewind.org/{station_name}.json?version=3" + response = requests.get(url) + + if response.status_code == 200: + data = response.json() + departures = data.get("departures", []) + + return jsonify({'departures': departures}) if __name__ == '__main__': - app.run(host="0.0.0.0", debug=False) + app.run(debug=True) diff --git a/Hafas_Main_web_old.py b/Hafas_Main_web_old.py new file mode 100644 index 0000000..4594ffe --- /dev/null +++ b/Hafas_Main_web_old.py @@ -0,0 +1,41 @@ +import datetime +from typing import List +from flask import Flask, render_template, request, make_response +import json +import requests + +app = Flask(__name__) + +def get_departure_info(station_name): + url = f"https://dbf.finalrewind.org/{station_name}.json?version=3" + response = requests.get(url) + if response.status_code == 200: + departures_data = response.json().get("departures", []) + departures = [station_board_leg_to_dict(leg) for leg in departures_data] + return departures + else: + return [] + +def station_board_leg_to_dict(leg): + return { + "name": leg["train"], + "direction": leg["destination"], + "dateTime": leg["scheduledDeparture"], + "delay": leg["delayDeparture"], + "platform": leg["scheduledPlatform"], + } + +@app.route('/', methods=['GET', 'POST']) +def index(): + departures = [] + station_name = "" + + # Get the station name from the form input + if request.method == 'POST': + station_name = request.form['station_name'] + departures = get_departure_info(station_name) + + return render_template('index.html', departures=departures, station_name=station_name) + +if __name__ == '__main__': + app.run(host="0.0.0.0", debug=False) diff --git a/templates/index.html b/templates/index.html index f656fe5..c154626 100644 --- a/templates/index.html +++ b/templates/index.html @@ -1,136 +1,123 @@ + - - - - - - Abfahrtsinformationen - - - - + h1 { + text-align: center; + } + h2 { + text-align: center; + } + + form { + display: flex; + justify-content: center; + margin-top: 20px; + } + + label { + font-weight: bold; + margin-right: 10px; + } + + input[type="text"] { + padding: 5px; + border: 1px solid #ccc; + border-radius: 5px; + } + + button[type="submit"] { + background-color: #007bff; + color: white; + border: none; + border-radius: 5px; + padding: 5px 10px; + cursor: pointer; + } + + table { + width: 100%; + border-collapse: collapse; + margin-top: 20px; + } + + table, th, td { + border: 1px solid #ccc; + } + + th, td { + padding: 10px; + text-align: left; + } + + th { + background-color: #007bff; + color: white; + } + + /* Dark-Mode-Schalter */ + #dark-mode-toggle { + position: absolute; + top: 10px; + right: 10px; + background-color: transparent; + border: none; + cursor: pointer; + font-size: 20px; + color: #007bff; + } + + + +

Abfahrten / Departures

Station: {{ station_name }}

@@ -142,12 +129,13 @@ {% if departures %} - +
- + + @@ -155,11 +143,12 @@ {% for leg in departures %} - - - - - + + + + + + {% endfor %} @@ -198,4 +187,4 @@ }); - \ No newline at end of file +
Name Richtung / DirectionGeplante Abfahrtszeit / Planned depatureÜber/ viaGeplante Abfahrtszeit / Planned departure Verspätung (Minuten) / Delay (minutes) Bahnsteig / Platform
{{ leg.name }}{{ leg.direction }}{{ leg.dateTime.strftime('%Y-%m-%d %H:%M:%S') }}{% if leg.delay %}{{ leg.delay.total_seconds() / 60 }}{% else %}0{% endif %}{{ leg.platform }}{{ leg.train }}
({{leg.trainNumber}})
{{ leg.destination }}{{ leg.via | join(', ') }}{{ leg.scheduledDeparture }}{{ leg.delayDeparture }}{{ leg.scheduledPlatform }}