Pagination
Navigation
Page navigation with pixel styling.
Import
import { PixelPagination, PixelPaginationContent, PixelPaginationItem, PixelPaginationLink, PixelPaginationNext, PixelPaginationPrevious } from "@/components/ui/pixel-pagination"Usage
Component Source
Copy and paste the following code into your project at /src/components/ui/pixel-pagination.tsx
"use client";
import type * as React from "react";
import { cn } from "@/lib/utils";
interface PixelPaginationProps extends React.ComponentProps<"nav"> {}
function PixelPagination({ className, ...props }: PixelPaginationProps) {
return (
<nav
role="navigation"
aria-label="pagination"
className={cn("mx-auto flex w-full justify-center", className)}
{...props}
/>
);
}
function PixelPaginationContent({
className,
...props
}: React.ComponentProps<"ul">) {
return (
<ul
className={cn("flex flex-row items-center gap-1", className)}
{...props}
/>
);
}
function PixelPaginationItem(props: React.ComponentProps<"li">) {
return <li {...props} />;
}
interface PixelPaginationLinkProps extends React.ComponentProps<"button"> {
isActive?: boolean;
}
function PixelPaginationLink({
className,
isActive,
...props
}: PixelPaginationLinkProps) {
return (
<button
aria-current={isActive ? "page" : undefined}
className={cn(
"inline-flex h-8 min-w-8 items-center justify-center border-2 border-black bg-[#fffacd] dark:bg-[#2a2a2a] px-3 text-xs font-bold shadow-[2px_2px_0px_0px_rgba(0,0,0,1)] duration-0",
"hover:bg-[#ffd700] active:translate-x-[2px] active:translate-y-[2px] active:shadow-none",
"font-[family-name:var(--font-press-start)]",
// ... (more code below)Accessibility
This component is built with accessibility in mind, including proper ARIA attributes, keyboard navigation, and focus management.