Skip to content
import {PageLayout} from '@primer/react'

Examples

See storybook for fullscreen examples.

Default

With dividers

With connected dividers

With pane on left

With pane hidden on narrow viewports

With condensed spacing

With a sticky pane

With a custom sticky header

Add offsetHeader prop to specify the height of the custom sticky header along with sticky prop

With aria-label

Using aria-label along with PageLayout.Header, PageLayout.Content, or PageLayout.Footer creates a unique label for that landmark role that can make it easier to navigate between sections of content on a page.

With aria-labelledby

Using aria-labelledby along with PageLayout.Header, PageLayout.Content, or PageLayout.Footer creates a unique label for each landmark role by using the given id to associate the landmark with the content with the corresponding id. This is helpful when you have a visible item that visually communicates the type of content which you would like to associate to the landmark itself.

Accessibility

The PageLayout component uses landmark roles for PageLayout.Header, PageLayout.Content, and PageLayout.Footer in order to make it easier for screen reader users to navigate between sections of the page.

ComponentLandmark role
PageLayout.Headerbanner
PageLayout.Contentmain
PageLayout.Footercontentinfo

Each component may be labeled through either aria-label or aria-labelledby in order to provide a unique label for the landmark. This can be helpful when there are multiple landmarks of the same type on the page.

Links & Resources

Screen readers

Most screen readers provide a mechanism through which you can navigate between landmarks on the page. Typically, this is done through a specific keyboard shortcut or through an option in a rotor.

JAWS

JAWS supports landmark regions and the details in which it presents them depends on the Web Verbosity Level setting. You can navigate to the next landmark on the page by pressing R and the previous landmark by pressing Shift-R.

NVDA

NVDA supports landmark regions and you can navigate to the next landmark by using pressing D and to the previous landmark by pressing Shift-D. You may also list out the landmarks by pressing Insert-F7.

VoiceOver

VoiceOver supports assigning landmark roles to areas of a page. In order to navigate between landmarks, you can use the rotor.

On macOS, you can open the VoiceOver rotor by pressing VO-U. You can navigate between lists to find the Landmarks list by using the Right Arrow or Left Arrow key. From that list, you can use the Down Arrow and Up Arrow keys to navigate between landmarks identified on the page.

Props

PageLayout

NameTypeDefaultDescription
containerWidth
| 'full'
| 'medium'
| 'large'
| 'xlarge'
'xlarge'The maximum width of the page container.
padding
| 'none'
| 'condensed'
| 'normal'
'normal'The spacing between the outer edges of the page container and the viewport
columnGap
| 'none'
| 'condensed'
| 'normal'
'normal'
rowGap
| 'none'
| 'condensed'
| 'normal'
'normal'
sx
SystemStyleObject
Style overrides to apply to the component. See also overriding styles.

PageLayout.Header

NameTypeDefaultDescription
aria-label
string | undefined
A unique label for the rendered banner landmark
aria-labelledby
string | undefined
An id to an element which uniquely labels the rendered banner landmark
padding
| 'none'
| 'condensed'
| 'normal'
'none'The amount of padding inside the header.
divider
| 'none'
| 'line'
| {
    narrow?:
      | 'none'
      | 'line' 
      | 'filled'
    regular?:
      | 'none'
      | 'line'
    wide?:
      | 'none'
      | 'line'
  }
'none'
dividerWhenNarrow Deprecated
| 'inherit'
| 'none'
| 'line'
| 'filled'
'inherit'Use the divider prop with a responsive value instead.
hidden
| boolean
| {
    narrow?: boolean
    regular?: boolean
    wide?: boolean
  }
falseWhether the header is hidden.
sx
SystemStyleObject
Style overrides to apply to the component. See also overriding styles.

PageLayout.Content

NameTypeDefaultDescription
aria-label
string | undefined
A unique label for the rendered main landmark
aria-labelledby
string | undefined
An id to an element which uniquely labels the rendered main landmark
width
| 'full'
| 'medium'
| 'large'
| 'xlarge'
'full'The maximum width of the content region.
padding
| 'none'
| 'condensed'
| 'normal'
'none'The amount of padding inside the content.
hidden
| boolean
| {
    narrow?: boolean
    regular?: boolean
    wide?: boolean
  }
falseWhether the content is hidden.
sx
SystemStyleObject
Style overrides to apply to the component. See also overriding styles.

PageLayout.Pane

NameTypeDefaultDescription
position
| 'start'
| 'end'
| {
    narrow?:
      | 'start'
      | 'end'
    regular?:
      | 'start'
      | 'end'
    wide?:
      | 'start'
      | 'end'
  }
'end'
positionWhenNarrow Deprecated
| 'inherit'
| 'start'
| 'end'
'inherit'Use the position prop with a responsive value instead.
width
| 'small'
| 'medium'
| 'large'
'medium'The width of the pane.
sticky
boolean
falseWhether the pane should stick to the top of the screen while the content scrolls.
offsetHeader
number | string
0Use offsetHeader along with the sticky prop to push the sticky pane down to make room for a sticky header if necessary. Use the type `string` to specify the height with a unit i.e. 5rem; otherwise the type `number` will be taken as px.
padding
| 'none'
| 'condensed'
| 'normal'
'none'The amount of padding inside the pane.
divider
| 'none'
| 'line'
| {
    narrow?:
      | 'none'
      | 'line' 
      | 'filled'
    regular?:
      | 'none'
      | 'line'
    wide?:
      | 'none'
      | 'line'
  }
'none'
dividerWhenNarrow Deprecated
| 'inherit'
| 'none'
| 'line'
| 'filled'
'inherit'Use the divider prop with a responsive value instead.
hidden
| boolean
| {
    narrow?: boolean
    regular?: boolean
    wide?: boolean
  }
falseWhether the pane is hidden.
sx
SystemStyleObject
Style overrides to apply to the component. See also overriding styles.

PageLayout.Footer

NameTypeDefaultDescription
aria-label
string | undefined
A unique label for the rendered contentinfo landmark
aria-labelledby
string | undefined
An id to an element which uniquely labels the rendered contentinfo landmark
padding
| 'none'
| 'condensed'
| 'normal'
'none'The amount of padding inside the footer.
divider
| 'none'
| 'line'
| {
    narrow?:
      | 'none'
      | 'line' 
      | 'filled'
    regular?:
      | 'none'
      | 'line'
    wide?:
      | 'none'
      | 'line'
  }
'none'
dividerWhenNarrow Deprecated
| 'inherit'
| 'none'
| 'line'
| 'filled'
'inherit'Use the divider prop with a responsive value instead.
hidden
| boolean
| {
    narrow?: boolean
    regular?: boolean
    wide?: boolean
  }
falseWhether the footer is hidden.
sx
SystemStyleObject
Style overrides to apply to the component. See also overriding styles.

Status

Alpha

  • Component props are documented on primer.style/react.
  • Component does not have any unnecessary third-party dependencies.
  • Component can adapt to different themes.
  • Component can adapt to different screen sizes.
  • Component has 100% test coverage.

Beta

  • Component is used in a production application.
  • Common usage examples are documented on primer.style/react.
  • Common usage examples are documented in storybook stories.
  • Component has been reviewed by a systems designer and any resulting issues have been addressed.
  • Component has been manually reviewed by the accessibility team and any resulting issues have been addressed.

Stable

  • Component API has been stable with no breaking changes for at least one month.
  • Feedback on API usability has been sought from developers using the component and any resulting issues have been addressed.
  • Component has corresponding design guidelines documented in the interface guidelines.
  • Component has corresponding Figma component in the Primer Web library.