diff options
| author | Copilot <198982749+Copilot@users.noreply.github.com> | 2025-11-18 00:27:51 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-11-18 00:27:51 +0100 |
| commit | 133db456a4bd069daecb60b3ec6fa147868493a3 (patch) | |
| tree | 23c3ec3aea66a0012c00b2456490ebc0eedd77fb /src/frontend/app/routes | |
| parent | 276e73412abef28c222c52a84334d49f5e414f3c (diff) | |
Handle GTFS times exceeding 24 hours for night services (#98)
Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: arielcostas <94913521+arielcostas@users.noreply.github.com>
Co-authored-by: Ariel Costas Guerrero <ariel@costas.dev>
Diffstat (limited to 'src/frontend/app/routes')
| -rw-r--r-- | src/frontend/app/routes/estimates-$id.tsx | 4 | ||||
| -rw-r--r-- | src/frontend/app/routes/timetable-$id.tsx | 13 |
2 files changed, 12 insertions, 5 deletions
diff --git a/src/frontend/app/routes/estimates-$id.tsx b/src/frontend/app/routes/estimates-$id.tsx index e4006ef..74f24e6 100644 --- a/src/frontend/app/routes/estimates-$id.tsx +++ b/src/frontend/app/routes/estimates-$id.tsx @@ -65,9 +65,9 @@ const loadTimetableData = async ( throw new Error("Timetable not available for this region"); } - const today = new Date().toISOString().split("T")[0]; // YYYY-MM-DD format + // Use "today" to let server determine date based on Europe/Madrid timezone const resp = await fetch( - `${regionConfig.timetableEndpoint}?date=${today}&stopId=${stopId}`, + `${regionConfig.timetableEndpoint}?date=today&stopId=${stopId}`, { headers: { Accept: "application/json", diff --git a/src/frontend/app/routes/timetable-$id.tsx b/src/frontend/app/routes/timetable-$id.tsx index af5e42a..8a1cba7 100644 --- a/src/frontend/app/routes/timetable-$id.tsx +++ b/src/frontend/app/routes/timetable-$id.tsx @@ -38,9 +38,9 @@ const loadTimetableData = async ( // Add delay to see skeletons in action (remove in production) await new Promise((resolve) => setTimeout(resolve, 1000)); - const today = new Date().toISOString().split("T")[0]; // YYYY-MM-DD format + // Use "today" to let server determine date based on Europe/Madrid timezone const resp = await fetch( - `${regionConfig.timetableEndpoint}?date=${today}&stopId=${stopId}`, + `${regionConfig.timetableEndpoint}?date=today&stopId=${stopId}`, { headers: { Accept: "application/json", @@ -61,6 +61,13 @@ const timeToMinutes = (time: string): number => { return hours * 60 + minutes; }; +// Utility function to format GTFS time for display (handle hours >= 24) +const formatTimeForDisplay = (time: string): string => { + const [hours, minutes] = time.split(":").map(Number); + const normalizedHours = hours % 24; + return `${normalizedHours.toString().padStart(2, "0")}:${minutes.toString().padStart(2, "0")}`; +}; + // Filter past entries (keep only a few recent past ones) const filterTimetableData = ( data: ScheduledTable[], @@ -402,7 +409,7 @@ const TimetableTableWithScroll: React.FC<{ <div className="time-info"> <span className="departure-time"> - {entry.calling_time.slice(0, 5)} + {formatTimeForDisplay(entry.calling_time)} </span> <div className="service-id"> {parseServiceId(entry.service_id)} |
