aboutsummaryrefslogtreecommitdiff
path: root/src/frontend/app/routes
diff options
context:
space:
mode:
authorCopilot <198982749+Copilot@users.noreply.github.com>2025-11-18 00:27:51 +0100
committerGitHub <noreply@github.com>2025-11-18 00:27:51 +0100
commit133db456a4bd069daecb60b3ec6fa147868493a3 (patch)
tree23c3ec3aea66a0012c00b2456490ebc0eedd77fb /src/frontend/app/routes
parent276e73412abef28c222c52a84334d49f5e414f3c (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.tsx4
-rw-r--r--src/frontend/app/routes/timetable-$id.tsx13
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)}