CivicTheme
  • Docs
  • Changelog
  • Getting started
    • Introduction
    • Installation
    • Getting help
    • Security policy
    • Partnerships
  • Installation
    • Drupal theme
  • Contributing
    • Contribution model
    • Contribution basics
    • Small contribution spec
    • Medium contribution spec
    • Major (RFC-level) contribution spec
    • Code of conduct
    • Figma contributions
  • Components
    • Component list
    • Atoms
      • Button
      • Chip
      • Content link
      • Check box
      • Field description
      • Field message
      • Fieldset
      • Label
      • Radio
      • Select
      • Textarea
      • Text field
      • Heading
      • Link
      • Paragraph
      • Popover
      • Quote
      • Table
      • Tag
      • Text list
    • Molecules
      • Accordion
      • Attachment
      • Breadcrumb
      • Callout
      • Event Card
      • Field
      • Figure
      • Group filter
      • Logo
      • Map
      • Navigation card
      • Next step
      • Pagination
      • Promo card
      • Search
      • Service card
      • Single filter
      • Snippet
      • Subject Card
      • Table of Contents
      • Tabs
      • Tag List
      • Tooltip
      • Video Player
    • Organisms
      • Alert
      • Banner
      • Campaign
      • Footer
      • Header
      • List
      • Message
      • Mobile Navigation
      • Navigation
      • Promo
      • Side Navigation
      • Skip link
      • Slider
      • Social links
  • Content Authoring
    • Overview
    • Global settings
      • Favicon
      • Header
        • Site slogan
        • Header logos
        • Primary navigation
        • Secondary navigation
      • Banner
      • Search
      • Link
      • Skip link
      • Side navigation
      • Signup
      • Footer
        • Footer logo
        • Social links
        • Footer navigation
        • Acknowledgement of Country
        • Copyright
      • Colours
    • Content types
      • Page
        • Configure the banner
      • Event
      • Alert
    • Content components
      • Accordion
      • Automated list
      • Attachment
      • Callout
      • Campaign
      • Content
        • Quote
      • iFrame
      • Manual List
        • Event card
        • Event reference card
        • Navigation card
        • Navigation reference card
        • Promo card
        • Promo reference card
        • Publication card
        • Service card
        • Subject card
        • Subject reference card
        • Snippet
      • Map
      • Next step
      • Promo
      • Slider
      • Webform
    • Vocabularies
      • Topics
      • Site sections
    • User accounts & roles
Powered by GitBook
On this page
  • When to use
  • When not to use
  • Best practice guidelines
  • Variations
  • Accessibility
  • Security
  • Component inspiration and uplift
  • User research on this component
  • Known issues
  • More research needed
  • Help improve this component
  • Resources
  • References
  • Changelog
  • Contact us

Was this helpful?

Edit on GitHub
Export as PDF
  1. Components
  2. Molecules

Pagination

A navigation component that helps users move through multiple pages of content with intuitive controls for previous, next, and specific page selection.

When to use

Use the pagination component when:

  • Content is divided into multiple pages and users need a way to navigate between them

  • You have search results, long articles, catalogue listings, or other content that is better broken into digestible chunks

  • Users need to maintain context of where they are within a sequence of content pages

  • You want to improve performance by loading content incrementally rather than all at once

When not to use

Do not use the pagination component when:

  • Content fits naturally on a single page without being overwhelming

  • Infinite scrolling is more appropriate for the content type (such as social media feeds)

  • A "load more" button would provide a better user experience for gradually revealing additional content

  • The sequence of content is very short (only 2-3 pages), where simple "next" and "previous" buttons may suffice


Best practice guidelines

  • Clear labelling: Provide clear labels for navigation controls such as "Previous" and "Next" rather than just arrows, making functionality immediately evident to all users.

  • Current page indication: Clearly highlight the current page to help users maintain context of their position within content.

  • Logical ordering: Maintain a consistent and logical order of pagination controls (previous, page numbers, next) to create a predictable interface.

  • Appropriate sizing: Ensure touch targets are sufficiently large (at least 44 by 44 pixels recommended, minimum 24 by 24 pixels required) to support touch device users.

  • Responsive adaptation: Adapt pagination presentation for smaller screens, displaying fewer page numbers on mobile devices while maintaining core functionality.

  • Page count visibility: Show the total number of pages when possible to help users understand the scope of content available.

  • URL reflection: Ensure each paginated page has its own URL to enable bookmarking, sharing, and using browser navigation.

  • Items per page control: Offer users the ability to control how many items are displayed per page when appropriate for the content type.

Variations

Desktop pagination

The full pagination component displays numerical page links and previous/next navigation. It includes:

  • Previous page button

  • Numbered page links

  • Current page indicator

  • Next page button

  • Items per page selection

Mobile pagination

A simplified pagination component designed for smaller screens with:

  • Previous page button

  • Next page button

  • Items per page selection

  • Reduced number of visible page numbers (or none) to save space


Accessibility

This component meets WCAG 2.2 AA accessibility guidelines, with the exception of Target Size (Minimum) requirement.

Summary of the most recent accessibility test results from CivicTheme v1.7.0 Accessibility Assessments:

Standard
Result
Comment

1.1.1 Non-text Content (Level A)

Pass

The image is considered decoration and can be ignored by screen readers.

1.4.3 Contrast (Minimum) (Level AA)

Pass

Contrast meets the minimum 4.5:1.

1.4.4 Resize text (Level AA)

Pass

Text is still visible and readable when resized to at least 200%.

2.1.1 Keyboard (Level A)

Pass

Elements are accessible using a keyboard only.

2.4.4 Link Purpose (In Context) (Level A)

Pass

The purpose of each link can be determined from the text alone.

2.4.7 Focus Visible (Level AA)

Pass

Focus is visible when navigating using a keyboard.

4.1.2 Name, Role, Value (Level A)

Pass

For all elements the name and role can be programmatically determined.

1.4.12 Text Spacing (Level AA)

Pass

Text is visible/readable when the line spacing is at least 1.5 times the font size, letter spacing is at least 0.12 times the font size, and word spacing is at least 0.16 times the font size.

2.5.8 Target Size (Minimum) (Level AA)

Fail

The size of the target for pointer inputs is at least 24 by 24 CSS pixels.

Security

No specific security concerns have been identified for this component. As with all interactive components, ensure that pagination parameters in URLs are properly validated to prevent any potential injection attacks.

Component inspiration and uplift

This component has been modelled after the Direction Links component from the Australian Government Design System. It has been uplifted by Salsa Digital, as the custodian of the CivicTheme Design System, in the following ways:

  • The links remain in the brand's primary colours

  • Underline and more visually-prominent active states have been added

  • Mobile-optimized variant shows only previous/next navigation to reduce screen clutter and improve usability

  • Added "Items per page" selection functionality to provide users with greater control

As noted in the CivicTheme documentation: "It was discovered during early rapid prototyping that, occasionally, direction links may appear near/alongside links and buttons that are greater priority to the reader's journey. For this reason, CivicTheme reserves the primary and secondary colour palette for those key activities to help reduce the number of coloured elements competing for the user's attention."


User research on this component

★★★☆☆ Confidence rating = Moderate (Based on established patterns with limited direct testing)

Limited direct user research has been conducted specifically on the CivicTheme pagination component. The current implementation is based on established navigation patterns that have been consistently validated across digital platforms.

Industry research indicates that pagination is a well-understood navigation pattern when implemented consistently. Key findings from general pagination research that have informed this component include:

  • Users expect pagination to be located at the bottom of content

  • Clear visual indication of the current page is essential for orientation

  • Previous/next labels are more accessible than icon-only controls

More focused user testing of the CivicTheme pagination component would be beneficial to validate specific implementation decisions.

Known issues

  • Accessibility target size: As noted in the accessibility assessment, the current implementation does not meet the WCAG 2.2 AA requirement for minimum target size (2.5.8). This should be addressed in future updates to ensure all interactive elements are at least 24 by 24 CSS pixels.

  • Mobile usability: On very small screens, the "Items per page" selection may compete for space with navigation controls, potentially creating a cluttered interface.

  • Screen reader announcements: Current implementation may benefit from enhanced ARIA attributes to better announce pagination state changes to screen reader users.

More research needed

More user research is needed in the following areas:

  • Mobile interaction patterns: Additional testing should focus on how users interact with pagination on small screens to determine the optimal balance between functionality and simplicity.

  • Accessibility improvements: Research is needed to identify the best approach to resolving the target size issue while maintaining the component's visual design integrity.

  • Items per page functionality: Testing to determine the most intuitive placement and interaction model for the "Items per page" selector, especially on mobile devices.

  • User comprehension: Research to validate that users understand the relationship between the pagination controls and the content being paginated, especially when multiple paginated components appear on the same page.

If you have conducted user research that addresses any of these gaps, you can submit your research findings to help improve this component.

Help improve this component

To help make this component useful and up-to-date, you can:

  • Contribute to our pagination component discussion on GitHub

  • Submit your user research findings to help improve the pagination component

  • Propose a change to the pagination component to address known issues


Resources

  • Storybook

  • GitHub

References

Changelog

Version
Date
Changes

1.7.0

2023-11-15

Renamed from "Pagination (Directional Links)" to "Pagination"

1.6.0

2023-06-22

Added "Items per page" functionality

1.5.0

2023-01-18

Improved mobile responsiveness

1.0.0

2022-03-10

Initial component released

Contact us

PreviousNext stepNextPromo card

Last updated 29 days ago

Was this helpful?

Check out our to learn more.

If you have a question about the CivicTheme design system or need our help, visit the page for guidance.

contributing section
Figma
Nielsen Norman Group. (2018). Pagination in Web Design
Web Content Accessibility Guidelines (WCAG) 2.2
Digital Service Standard
Getting Help