mirror of
https://gitlab.com/foxixus/neomovies.git
synced 2025-10-29 18:38:50 +05:00
- /public/file.svg - /public/globe.svg - /public/next.svg - /public/vercel.svg - /public/window.svg - /public/google.svg - /public/logo.png - /src/eslint.config.mjs - /src/api.ts - /src/middleware.ts - /src/app/favicon.ico - /src/app/globals.css - /src/app/layout.tsx - /src/app/page.tsx - /src/app/providers.tsx - /src/app/not-found.tsx - /src/app/error.tsx - /src/app/metadata.ts - /src/app/styles.tsx - /src/app/api/auth/[...nextauth]/route.ts - /src/app/api/auth/register/route.ts - /src/app/api/auth/verify/route.ts - /src/app/api/auth/check-verification/route.ts - /src/app/api/auth/resend-code/route.ts - /src/app/api/movies/search/route.ts - /src/app/api/movies/sync/route.ts - /src/app/api/admin/send-verification/route.ts - /src/app/api/admin/verify-code/route.ts - /src/app/api/admin/movies/route.ts - /src/app/api/admin/movies/toggle-visibility/route.ts - /src/app/api/admin/create/route.ts - /src/app/api/admin/users/toggle-admin/route.ts - /src/app/api/admin/toggle-admin/route.ts - /src/app/login/page.tsx - /src/app/login/LoginClient.tsx - /src/app/verify/page.tsx - /src/app/verify/VerificationClient.tsx - /src/app/profile/page.tsx - /src/app/movie/[id]/page.tsx - /src/app/movie/[id]/MoviePage.tsx - /src/app/movie/[id]/MovieContent.tsx - /src/app/settings/page.tsx - /src/app/tv/[id]/page.tsx - /src/app/tv/[id]/TVShowPage.tsx - /src/app/tv/[id]/TVShowContent.tsx - /src/app/admin/login/page.tsx - /src/app/admin/login/AdminLoginClient.tsx - /src/lib/db.ts - /src/lib/jwt.ts - /src/lib/registry.tsx - /src/lib/api.ts - /src/lib/mongodb.ts - /src/lib/mailer.ts - /src/lib/auth.ts - /src/lib/utils.ts - /src/lib/email.ts - /src/lib/movieSync.ts - /src/models/User.ts - /src/models/index.ts - /src/models/Movie.ts - /src/types/auth.ts - /src/types/movie.ts - /src/components/MovieCard.tsx - /src/components/Notification.tsx - /src/components/Pagination.tsx - /src/components/GoogleIcon.tsx - /src/components/StyleProvider.tsx - /src/components/Providers.tsx - /src/components/VerificationCodeInput.tsx - /src/components/GlassCard.tsx - /src/components/AppLayout.tsx - /src/components/SearchModal.tsx - /src/components/DarkReaderFix.tsx - /src/components/ClientLayout.tsx - /src/components/MenuItem.tsx - /src/components/MoviePlayer.tsx - /src/components/PageLayout.tsx - /src/components/SettingsContent.tsx - /src/components/Navbar.tsx - /src/components/LayoutContent.tsx - /src/components/SearchResults.tsx - /src/components/Icons/Icons.tsx - /src/components/Icons/HeartIcon.tsx - /src/components/Icons/PlayIcon.tsx - /src/components/admin/MovieSearch.tsx - /src/hooks/useUser.ts - /src/hooks/useMovies.ts - /src/hooks/useSettings.ts - /src/hooks/useSearch.ts - /src/styles/GlobalStyles.ts - /src/styles/GlobalStyles.tsx - /src/providers/AuthProvider.tsx - /src/data/movies.ts - /types/next-auth.d.ts - /middleware.ts - /next.config.js - /next-env.d.ts - /package.json - /postcss.config.mjs - /README.md - /tailwind.config.ts - /tsconfig.json - /package-lock.json
107 lines
2.4 KiB
TypeScript
107 lines
2.4 KiB
TypeScript
'use client';
|
||
|
||
import React from 'react';
|
||
import styled from 'styled-components';
|
||
|
||
const PaginationContainer = styled.div`
|
||
display: flex;
|
||
justify-content: center;
|
||
align-items: center;
|
||
gap: 0.5rem;
|
||
margin: 2rem 0;
|
||
`;
|
||
|
||
const PageButton = styled.button<{ $active?: boolean }>`
|
||
padding: 0.5rem 1rem;
|
||
border: none;
|
||
border-radius: 0.5rem;
|
||
background: ${props => props.$active ? props.theme.colors.primary : 'rgba(255, 255, 255, 0.1)'};
|
||
color: white;
|
||
cursor: pointer;
|
||
transition: background 0.2s;
|
||
|
||
&:hover {
|
||
background: ${props => props.$active ? props.theme.colors.primary : 'rgba(255, 255, 255, 0.2)'};
|
||
}
|
||
|
||
&:disabled {
|
||
opacity: 0.5;
|
||
cursor: not-allowed;
|
||
}
|
||
`;
|
||
|
||
const PageInfo = styled.span`
|
||
color: white;
|
||
padding: 0 1rem;
|
||
`;
|
||
|
||
interface PaginationProps {
|
||
currentPage: number;
|
||
totalPages: number;
|
||
onPageChange: (page: number) => void;
|
||
}
|
||
|
||
export default function Pagination({ currentPage, totalPages, onPageChange }: PaginationProps) {
|
||
const maxVisiblePages = 5;
|
||
const halfVisible = Math.floor(maxVisiblePages / 2);
|
||
|
||
const getPageNumbers = () => {
|
||
let start = Math.max(1, currentPage - halfVisible);
|
||
let end = Math.min(totalPages, start + maxVisiblePages - 1);
|
||
|
||
if (end - start + 1 < maxVisiblePages) {
|
||
start = Math.max(1, end - maxVisiblePages + 1);
|
||
}
|
||
|
||
return Array.from({ length: end - start + 1 }, (_, i) => start + i);
|
||
};
|
||
|
||
const handlePageClick = (page: number) => {
|
||
if (page !== currentPage) {
|
||
onPageChange(page);
|
||
}
|
||
};
|
||
|
||
if (totalPages <= 1) return null;
|
||
|
||
return (
|
||
<PaginationContainer>
|
||
<PageButton
|
||
onClick={() => handlePageClick(1)}
|
||
disabled={currentPage === 1}
|
||
>
|
||
«
|
||
</PageButton>
|
||
<PageButton
|
||
onClick={() => handlePageClick(currentPage - 1)}
|
||
disabled={currentPage === 1}
|
||
>
|
||
‹
|
||
</PageButton>
|
||
|
||
{getPageNumbers().map(page => (
|
||
<PageButton
|
||
key={page}
|
||
$active={page === currentPage}
|
||
onClick={() => handlePageClick(page)}
|
||
>
|
||
{page}
|
||
</PageButton>
|
||
))}
|
||
|
||
<PageButton
|
||
onClick={() => handlePageClick(currentPage + 1)}
|
||
disabled={currentPage === totalPages}
|
||
>
|
||
›
|
||
</PageButton>
|
||
<PageButton
|
||
onClick={() => handlePageClick(totalPages)}
|
||
disabled={currentPage === totalPages}
|
||
>
|
||
»
|
||
</PageButton>
|
||
</PaginationContainer>
|
||
);
|
||
}
|