aboutsummaryrefslogtreecommitdiff
path: root/src/frontend/app/components/TimetableSkeleton.tsx
diff options
context:
space:
mode:
authorAriel Costas Guerrero <ariel@costas.dev>2025-09-07 19:22:28 +0200
committerAriel Costas Guerrero <ariel@costas.dev>2025-09-07 19:22:28 +0200
commit80bcf4a5f29ab926c2208d5efb4c19087c600323 (patch)
tree1e5826b29d8a22e057616e16069232f95788f3ba /src/frontend/app/components/TimetableSkeleton.tsx
parent8182a08f60e88595984ba80b472f29ccf53c19bd (diff)
feat: Enhance StopSheet component with error handling and loading states
- Added skeleton loading state to StopSheet for better UX during data fetch. - Implemented error handling with descriptive messages for network and server errors. - Introduced manual refresh functionality to reload stop estimates. - Updated styles for loading and error states. - Created StopSheetSkeleton and TimetableSkeleton components for consistent loading indicators. feat: Improve StopList component with loading indicators and network data fetching - Integrated loading state for StopList while fetching stops from the network. - Added skeleton loading indicators for favourite and recent stops. - Refactored data fetching logic to include favourite and recent stops with full data. - Enhanced user experience with better loading and error handling. feat: Update Timetable component with loading and error handling - Added loading skeletons to Timetable for improved user experience. - Implemented error handling for timetable data fetching. - Refactored data loading logic to handle errors gracefully and provide retry options. chore: Update package dependencies - Upgraded react-router, lucide-react, and other dependencies to their latest versions. - Updated types for TypeScript compatibility.
Diffstat (limited to 'src/frontend/app/components/TimetableSkeleton.tsx')
-rw-r--r--src/frontend/app/components/TimetableSkeleton.tsx67
1 files changed, 67 insertions, 0 deletions
diff --git a/src/frontend/app/components/TimetableSkeleton.tsx b/src/frontend/app/components/TimetableSkeleton.tsx
new file mode 100644
index 0000000..01956ee
--- /dev/null
+++ b/src/frontend/app/components/TimetableSkeleton.tsx
@@ -0,0 +1,67 @@
+import React from "react";
+import Skeleton, { SkeletonTheme } from "react-loading-skeleton";
+import "react-loading-skeleton/dist/skeleton.css";
+import { useTranslation } from "react-i18next";
+
+interface TimetableSkeletonProps {
+ rows?: number;
+}
+
+export const TimetableSkeleton: React.FC<TimetableSkeletonProps> = ({
+ rows = 4
+}) => {
+ const { t } = useTranslation();
+
+ return (
+ <SkeletonTheme baseColor="#f0f0f0" highlightColor="#e0e0e0">
+ <div className="timetable-container">
+ <div className="timetable-caption">
+ <Skeleton width="250px" height="1.1rem" />
+ </div>
+
+ <div className="timetable-cards">
+ {Array.from({ length: rows }, (_, index) => (
+ <div key={`timetable-skeleton-${index}`} className="timetable-card">
+ <div className="card-header">
+ <div className="line-info">
+ <Skeleton width="40px" height="24px" style={{ borderRadius: "4px" }} />
+ </div>
+
+ <div className="destination-info">
+ <Skeleton width="120px" height="0.95rem" />
+ </div>
+
+ <div className="time-info">
+ <Skeleton
+ width="60px"
+ height="1.1rem"
+ style={{ fontFamily: "monospace" }}
+ />
+ </div>
+ </div>
+
+ <div className="card-body">
+ <div className="route-streets">
+ <Skeleton
+ width="50px"
+ height="0.8rem"
+ style={{
+ display: "inline-block",
+ borderRadius: "3px",
+ marginRight: "0.5rem"
+ }}
+ />
+ <Skeleton
+ width="200px"
+ height="0.85rem"
+ style={{ display: "inline-block" }}
+ />
+ </div>
+ </div>
+ </div>
+ ))}
+ </div>
+ </div>
+ </SkeletonTheme>
+ );
+};