Skip to content

Commit

Permalink
add stations pagination
Browse files Browse the repository at this point in the history
  • Loading branch information
haseebzaki-07 committed Nov 7, 2024
1 parent a3e969d commit 899605e
Showing 1 changed file with 106 additions and 39 deletions.
145 changes: 106 additions & 39 deletions frontend/src/Pages/stations.jsx
Original file line number Diff line number Diff line change
@@ -1,32 +1,31 @@

import React, { useState , useEffect} from "react";

import { FaTrain } from "react-icons/fa"; // Using FontAwesome train icon
import { AiFillCaretDown, AiFillCaretUp, AiFillStar, AiOutlineStar } from "react-icons/ai"; // Star icons for favorites
import React, { useState, useEffect } from "react";
import { FaTrain } from "react-icons/fa";
import { AiFillStar, AiOutlineStar } from "react-icons/ai";
import { useNavigate } from "react-router-dom";
import backicon from "../assets/svg/backicon.svg";
import { div, h1 } from "framer-motion/client";
import allStations from "../dataset/stations.js"

import allStations from "../dataset/stations.js";

const RailwayStations = () => {

useEffect(() => {
document.title = 'Station Saarthi | Stations';
document.title = 'Station Saarthi | Stations';
}, []);


// Comprehensive list of railway stations with zones

const navigate = useNavigate();

const HomeClick = () => {
navigate("/"); // Navigates to the home page
};

const [stations, setStations] = useState(allStations);
const [searchTerm, setSearchTerm] = useState("");
const [favorites, setFavorites] = useState([]);
const [selectedZone, setSelectedZone] = useState("All");
const [loading, setLoading] = useState(false);

// Pagination States
const [currentPage, setCurrentPage] = useState(1); // Current page
const [stationsPerPage] = useState(30); // Increased the number of stations per page to 20

// Define the zones array
const zones = [
["All", "All"],
["ECOR", "EAST COAST RAILWAY"],
Expand All @@ -45,30 +44,24 @@ const RailwayStations = () => {
["WR", "WESTERN RAILWAY"],
["BR", "BANGLADESH RAILWAY"],
["CPT", "Kolkata Port Trust Rly."],
["DFCR", "DEDICATED FREIGHT CORRIDO"],
["DFCR", "DEDICATED FREIGHT CORRIDOR"],
["CP", "CHENNAI PORT TRUSTRAILWAY"],
["CR", "CENTRAL RAILWAY"],
["ECR", "EAST CENTRAL RAILWAY"],
["NPLR", "NEPAL RAILWAY"],
["MRK", "METRO RAILWAY KOLKATA"],
];
const [searchTerm, setSearchTerm] = useState("");
const [favorites, setFavorites] = useState([]);
const [selectedZone, setSelectedZone] = useState("All");
const [loading, setLoading] = useState(false);
const [showFavorites, setShowFavorites] = useState(false);

// Function to toggle favorite stations
const toggleFavorite = (station) => {
if (favorites.includes(station)) {
setFavorites(favorites.filter((fav) => fav !== station));
} else {
setFavorites([...favorites, station]);
console.log(favorites);
}
};

// Filter stations based on search term and selected state
// Filter stations based on search term and selected zone
const filteredStations = stations.filter((station) => {
const matchesSearch = station.name
.toLowerCase()
Expand All @@ -78,14 +71,57 @@ const RailwayStations = () => {
return matchesSearch && matchesState;
});

// Paginate stations: get the stations to display for the current page
const indexOfLastStation = currentPage * stationsPerPage;
const indexOfFirstStation = indexOfLastStation - stationsPerPage;
const currentStations = filteredStations.slice(indexOfFirstStation, indexOfLastStation);

// Calculate total number of pages
const totalPages = Math.ceil(filteredStations.length / stationsPerPage);

// Handle page change
const paginate = (pageNumber) => setCurrentPage(pageNumber);

// Handle next and previous button clicks
const handlePrev = () => {
if (currentPage > 1) {
setCurrentPage(currentPage - 1);
}
};

const handleNext = () => {
if (currentPage < totalPages) {
setCurrentPage(currentPage + 1);
}
};

// Get pagination buttons (limit the number of visible page numbers)
const getPaginationRange = () => {
const range = [];
const maxButtonsToShow = 5; // Limit to 5 page numbers shown at once

// Display the first page, last page, and some pages in between
let start = Math.max(currentPage - Math.floor(maxButtonsToShow / 2), 1);
let end = Math.min(start + maxButtonsToShow - 1, totalPages);

// Adjust the range if there are too few pages before the current page
if (end - start + 1 < maxButtonsToShow) {
start = Math.max(end - maxButtonsToShow + 1, 1);
}

// Push the page numbers into the range array
for (let i = start; i <= end; i++) {
range.push(i);
}

return range;
};

useEffect(() => {
setLoading(true);
fetch("http://localhost:3000/api/all-stations" , "https://stationguidebackend.onrender.com")
fetch("http://localhost:3000/api/all-stations")
.then((e) => e.json())
.then((e) => {
return e.json();
})
.then((e) => {
console.log(e);
setStations(e);
})
.catch((err) => {
Expand All @@ -99,7 +135,7 @@ const RailwayStations = () => {
if (loading) {
return (
<div className="relative h-screen bg-gray-100">
<div class="w-10 h-10 border-4 border-t-blue-500 border-gray-300 rounded-full animate-spin relative top-[50%] left-[50%]"></div>
<div className="w-10 h-10 border-4 border-t-blue-500 border-gray-300 rounded-full animate-spin relative top-[50%] left-[50%]"></div>
</div>
);
}
Expand All @@ -108,18 +144,18 @@ const RailwayStations = () => {
<div className="min-h-screen p-4 bg-gray-100">
{/* Header Section */}
<div>
<button onClick={HomeClick} className='absolute left-0 top-2'>
<img src={backicon} alt="" className='h-[5vh]' />
</button>
<button onClick={HomeClick} className="absolute left-0 top-2">
<img src={backicon} alt="" className="h-[5vh]" />
</button>
</div>

<div className="flex flex-col items-center mb-8">
<h1 className="text-3xl font-bold text-gray-800">Railway Stations</h1>
<p className="mt-2 text-gray-600">
Find and explore railway stations across India
</p>
</div>

{/* Main Content: Stations Grid */}
<div>
{/* Search Bar and State Filter */}
Expand All @@ -143,12 +179,12 @@ const RailwayStations = () => {
))}
</select>
</div>

{/* Stations Grid */}
<div className="flex justify-center">
<div className="grid w-full max-w-4xl grid-cols-1 gap-6 sm:grid-cols-2 md:grid-cols-3">
{filteredStations.length > 0 ? (
filteredStations.map((station, index) => (
{currentStations.length > 0 ? (
currentStations.map((station, index) => (
<div
key={index}
className="flex items-center justify-between p-4 transition duration-200 bg-white rounded-lg shadow hover:shadow-lg"
Expand Down Expand Up @@ -183,9 +219,41 @@ const RailwayStations = () => {
)}
</div>
</div>

{/* Pagination */}
<div className="flex justify-center mt-8">
<button
onClick={handlePrev}
disabled={currentPage === 1}
className="px-4 py-2 bg-gray-300 text-gray-600 rounded-md disabled:opacity-50"
>
Prev
</button>

{getPaginationRange().map((page) => (
<button
key={page}
onClick={() => paginate(page)}
className={`px-4 py-2 mx-1 rounded-md ${
currentPage === page
? "bg-blue-500 text-white"
: "bg-gray-200 text-gray-700"
}`}
>
{page}
</button>
))}

<button
onClick={handleNext}
disabled={currentPage === totalPages}
className="px-4 py-2 bg-gray-300 text-gray-600 rounded-md disabled:opacity-50"
>
Next
</button>
</div>
</div>

{/* Favorites Section - Moved to the Last */}

<div className="mt-8">
<h2 className="mb-4 text-2xl font-semibold text-gray-800">Your Favorite Stations</h2>

Expand Down Expand Up @@ -216,7 +284,6 @@ const RailwayStations = () => {
</div>
</div>
);

};

export default RailwayStations;

0 comments on commit 899605e

Please sign in to comment.