Skip to content

Effortless Pagination with the usePagination React Hook

  • #Tips & Tricks
Read time: 13 minutes
a shocked ugly fish holding a sticky note with the text "usePagination", next to a fishing hook underwater, film still from the 3D animated movie Finding Nemo

Pagination is an essential feature for blogs and content-heavy websites, allowing users to navigate through posts or items efficiently without overwhelming them. In the SanityPress starter template, a single-file custom React hook was built specifically to handle this functionality for the new Blog Frontpage module.

This custom hook generates a paginated list of items when passed specific options. The hook is flexible, allowing for control over the number of items displayed per page, and it can be easily paired with a customizable <Pagination> component for a seamless user experience.

Why Build a Custom Pagination Hook?πŸ”—

The idea behind this hook is to offer a simple, lightweight solution to pagination without relying on third-party libraries. It allows developers to:

  • Paginate items dynamically based on the current page.
  • Control how many items appear per page.
  • Integrate a fully customizable pagination UI.

The custom hook is actively used within the SanityPress project and can be easily implemented in other React/Next.js projects requiring a paginated display of items, such as blog posts or product listings.

How to Add Pagination to Your ProjectπŸ”—

If you want to integrate this pagination hook into your own project, it’s easy to get started. Here’s a quick guide:

1. Copy and paste the codeπŸ”—

You can copy and paste the code directly from the SanityPress GitHub repository and integrate it into your project.

⚠️ SanityPress uses nuqs as a dependency as of v5.2.0

[@portabletext/react] Unknown block type "custom-html", specify a component for it in the `components.types` prop

2. Use the hook and pass optionsπŸ”—

Here's a basic implementation of the hook and the <Pagination> component:

'use client'

export default function MyComponent({ itemsToPaginate }) {
  const { paginatedItems, Pagination } = usePagination({
    items: itemsToPaginate, // your items
    itemsPerPage: 6,
  })

  function scrollToList() {
    if (typeof window !== 'undefined')
      document.querySelector('#list')?.scrollIntoView({ behavior: 'smooth' })
	}

  return (
    <div>
      <ul id="list">
        {paginatedItems.map(...)}
      </ul>

      <Pagination className="..." onClick={scrollToList} />
    </div>
  )
}

The <Pagination> component can be styled and customized according to your needs. You can also build one from scratch by retrieving additional properties from the destructured object, giving you complete control over the UI.

Find all options and available properties in the source code here.

Use in SanityPress, or use anywhere!πŸ”—

In SanityPress, this hook powers the new Blog Frontpage module, where paginated blog posts are fetched from Sanity CMS and displayed to users. It's designed to be easily adaptable to various use cases beyond blogging, providing developers with the flexibility they need.

By leveraging this hook, you can enhance user experience, improve performance by loading only necessary content, and maintain a clean, easy-to-navigate interface. For a deeper look and to add this feature to your project, head over to the GitHub repo and use usePagination and <Pagination>!

a happy Jack Sparrow holding a modern fishing rod off and a orange fish, standing next to the Huntington Beach pier, the Restaurant "React" with a red roof in the distant background, Hasselblad film still