Component
  
  
Service Navigation
Renders a box with a link to sign up for email notifications
How it looks (preview) (preview all)
How to call this component
<%= render "govuk_publishing_components/components/service_navigation", {
  navigation_items: [
    {
      text: "Navigation item 1",
      href: "#",
      active: true
    },
    {
      text: "Navigation item 2",
      href: "#"
    },
    {
      text: "Navigation item 3",
      href: "#"
    }
  ]
} %>GOV.UK Design System
This component incorporates components from the GOV.UK Design System:
Accessibility acceptance criteria
- the component must use the correct heading level for the page
- text should have a text contrast ratio higher than 4.5:1 against the background colour to meet WCAG AA
- the icon must not be focusable or shown to screenreaders
Links in the component must:
- accept focus
- be focusable with a keyboard
- be usable with a keyboard
- indicate when they have focus
- change in appearance when touched (in the touch-down state)
- change in appearance when hovered
- be usable with touch
- be usable with voice commands
- have visible text
- have meaningful text
Other examples
Standard options
This component uses the component wrapper helper. It accepts the following options and applies them to the parent element of the component. See the component wrapper helper documentation for more detail.
- id- accepts a string for the element ID attribute
- data_attributes- accepts a hash of data attributes
- aria- accepts a hash of aria attributes
- classes- accepts a space separated string of classes, these should not be used for styling and must be prefixed with- js-
- margin_bottom- accepts a number from- 0to- 9(- 0pxto- 60px) using the GOV.UK Frontend spacing scale
- role- accepts a space separated string of roles
- lang- accepts a language attribute value
- open- accepts an open attribute value (true or false)
- hidden- accepts an empty string, ‘hidden’, or ‘until-found’
- tabindex- accepts an integer. The integer can also be passed as a string
- dir- accepts ‘rtl’, ‘ltr’, or ‘auto’
- type- accepts any valid type attribute e.g. ‘button’, ‘submit’, ‘text’
- rel- accepts any valid rel attribute e.g. ‘nofollow’
- target- accepts a valid target attribute e.g. ‘_blank’
- title- accepts any string
- draggable- accepts a draggable attribute value (“true” or “false”)
With service name (preview)
<%= render "govuk_publishing_components/components/service_navigation", {
  service_name: "My service name"
} %>With service name and service name url (preview)
<%= render "govuk_publishing_components/components/service_navigation", {
  service_name: "My service name",
  service_name_url: "#"
} %>With data attributes on items (preview)
<%= render "govuk_publishing_components/components/service_navigation", {
  navigation_items: [
    {
      text: "Navigation item 1",
      href: "#",
      active: true,
      data: {
        module: "example",
        something_else: "hello"
      }
    },
    {
      text: "Navigation item 2",
      href: "#",
      active: true,
      data: {
        module: "example-2",
        something_else: "hello 2"
      }
    }
  ]
} %>Full width (preview)
<%= render "govuk_publishing_components/components/service_navigation", {
  navigation_items: [
    {
      text: "Navigation item 1",
      href: "#",
      active: true
    },
    {
      text: "Navigation item 2",
      href: "#"
    }
  ],
  full_width: true
} %>