Skip to main content
Version: v8.1.0-alpha.2

ontario-header

Use the ontario type header for all pages that are part of the main ontario.ca website. This header is mandatory.

Use the application type header for applications and subsites outside of the main ontario.ca website.

Use the serviceOntario type header for ServiceOntario sites/apps. This type is for use by ServiceOntario teams only.

Usage guidance

Please refer to the Ontario Design System Ontario.ca header for current documentation guidance for the Ontario.ca header.

Please refer to the Ontario Design System Application header for current documentation guidance for the Application header.

Please refer to the Ontario Design System ServiceOntario header for current documentation guidance for the ServiceOntario header.

Configuration

Once the component package has been installed (see Ontario Design System Component Library for installation instructions), the header component can be added directly into the project's code, and can be customized by updating the properties outlined here. Additional information on custom types for header properties are outlined here. Please see the examples below for how to configure the component.

Examples

Example of an Ontario.ca header component.

<ontario-header
type="ontario"
language-toggle-options='{
"englishLink": "/driving-and-roads",
"frenchLink" : "/fr/conduite-et-routes"
}'
menu-items='[
{
"title": "Arts and Culture",
"href": "https://www.ontario.ca/page/arts-and-culture",
"linkIsActive": "false"
},
{
"title": "Business and economy",
"href": "https://www.ontario.ca/page/business-and-economy",
"linkIsActive": "false"
},
{
"title": "Driving and Roads",
"href": "https://www.ontario.ca/page/driving-and-roads",
"linkIsActive": "false"
},
{
"title": "Education and training",
"href": "https://www.ontario.ca/page/education-and-training",
"linkIsActive": "false"
},
{
"title": "Environment and energy",
"href": "https://www.ontario.ca/page/environment-and-energy",
"linkIsActive": "false"
},
{
"title": "Government",
"href": "https://www.ontario.ca/page/government",
"linkIsActive": "false"
},
{
"title": "Health and wellness",
"href": "https://www.ontario.ca/page/health-care-ontario",
"linkIsActive": "false"
},
{
"title": "Home and community",
"href": "https://www.ontario.ca/page/home-and-community",
"linkIsActive": "false"
},
{
"title": "Jobs and employment",
"href": "https://www.ontario.ca/page/jobs-and-employment",
"linkIsActive": "false"
},
{
"title": "Law and safety",
"href": "https://www.ontario.ca/page/law-and-safety",
"linkIsActive": "false"
},
{
"title": "Rural and north",
"href": "https://www.ontario.ca/page/rural-and-north",
"linkIsActive": "false"
},
{
"title": "Taxes and benefits",
"href": "https://www.ontario.ca/page/taxes-and-benefits",
"linkIsActive": "false"
},
{
"title": "Travel and recreation",
"href": "https://www.ontario.ca/page/travel-and-recreation",
"linkIsActive": "false"
}
]'
>
</ontario-header>

Example of an Application header component.

<ontario-header
type="application"
disable-dynamic-menu="true"
application-header-info='{
"title": "Driving and roads",
"href": "/driving-and-roads",
"title": "Driving and roads",
"href": "/driving-and-roads",
"maxSubheaderLinks": "{
"desktop": "3",
"tablet": "1"
}"
}'
language-toggle-options='{
"englishLink": "/",
"frenchLink" : "/fr"
}'
menu-items='[
{
"title": "Vehicle registration",
"href": "/vehicle-registration",
"linkIsActive": "false"
},
{
"title": "Driver records",
"href": "/driver-records",
"linkIsActive": "false"
},
{
"title": "Accessible Parking Permits",
"href": "/accessible-parking-permits",
"linkIsActive": "false"
},
{
"title": "Highway traveler information",
"href": "/highway-traveler-information",
"linkIsActive": "true"
}
]'
custom-language-toggle="{changeLanguage}"
>
</ontario-header>

<script>
const changeLanguage = (e: Event) => {
e.preventDefault();
// Logic to change language below
};
</script>

Custom property types

languageToggleOptions

language-toggle-options='{ "englishLink": "/en", "frenchLink": "/fr" }'
Property nameTypeDescription
englishLinkstringThe URL link for the English page
frenchLinkstringThe URL link for the French page

For the Ontario.ca header, the menu items will automatically be rendered in a dropdown menu button.

If maxSubheaderLinks is set within applicationHeaderInfo on the ontario-header component for an application type header, some of these links will be dispersed as links within the subheader menu bar relative to the breakpoint and number set.

<ontario-header
menu-items='[
{
"title": "Vehicle registration",
"href": "/vehicle-registration",
"linkIsActive": "false"
},
{
"title": "Driver records",
"href": "/driver-records",
"linkIsActive": "false"
},
{
"title": "Accessible Parking Permits",
"href": "/accessible-parking-permits",
"linkIsActive": "false"
},
{
"title": "Highway traveler information",
"href": "/highway-traveler-information",
"linkIsActive": "true",
"onClickHandler": (e: Event) => { e.preventDefault(); alert("Menu item clicked!") }
}
]'
></ontario-header>
Property nameTypeDescription
titlestringThe title of the menu item (this is what will appear as the label in the header/dropdown menu)
hrefstringThe URL for the menu item
linkIsActivebooleanA boolean flag for whether or not the current menu item link is active. If set to true, active classes and styles will be applied to the menu item.
onClickHandler(event: Event) => voidAn optional custom function to add to the menu item. This can be used if any additional logic should happen when the menu item is clicked.

applicationHeaderInfo

Note that this is only required for the Application and ServiceOntario header types.

application-header-info='{ "title": "Application name", "href": "/", "maxSubheaderLinks": {"desktop": "4", "tablet":
"2", "mobile": "1"}}'
Property nameTypeDescription
titlestringThe title of the application (this is what will appear as the label for the application sub header title)
hrefstringThe URL for the application name
maxSubheaderLinksnumberThe number of links to appear in the Ontario application type header's subheader. This is optional.

These links will display in the order they are described in the menuItems prop. For example, if the maxSubheaderLinks.desktop number is '4', the first four menuItems items will appear in the application subheader on desktop, and the rest will appear in the menu dropdown.

If no dropdown item is needed, the maxSubheaderLinks number should match the menuItems items length.

Accessibility

Application header

To ensure best practices, it is important to limit the number of navigation links passed to the menuItems property. We recommend a maximum of seven links, and to keep the labels for these links concise.

Technical Note: SSR (Server-Side Rendering) Considerations

The Ontario Header component supports server-side rendering, with a few important limitations:

  • Hydrated-only menu fetching: Dynamic menu fetching through fetchOntarioMenu is browser-only and will not execute during SSR.
  • Language prop: Pass language explicitly during SSR. Runtime language detection via document.documentElement.lang and window is hydrated-only.
  • Hydrated-only interactions: Interactive state such as menuToggle and searchToggle requires JavaScript and is unavailable before hydration.
  • Framework guidance: For SSR-critical applications, prefer static menuItems and only enable dynamic menu fetching in guaranteed client-side contexts.

Overview

Ontario Header renders Ontario.ca, application, and ServiceOntario header variants.

For component guidance, see:

Properties

PropertyAttributeDescriptionTypeDefault
applicationHeaderInfoapplication-header-infoInformation pertaining to the application and ServiceOntario headers. For the 'application' header type, this includes the application name, URL and optional props for the number of links in the subheader for desktop, tablet, and mobile views. For the 'serviceOntario' header type, the 'title' property is used as the service name displayed in the subheader.ApplicationHeaderInfo | stringundefined
assetBasePathasset-base-pathThe base path to an assets folder containing the Design System assetsstringundefined
customLanguageTogglecustom-language-toggleA custom function to pass to the language toggle button.((event: Event) => void) | undefinedundefined
customSignInTogglecustom-sign-in-toggleA custom function to pass to the sign-in button.((event: Event) => void) | undefinedundefined
disableDynamicMenudisable-dynamic-menuOption to disable fetching of the dynamic menu from the Ontario Header API. When set to true, the static menuItems prop will be used instead of fetching from the API. When set to false (default), menu items are fetched dynamically from the Ontario Header API endpoint. This property only applies to the 'ontario' header type. The 'application' and 'serviceOntario' types always use static menu items.booleanfalse
languagelanguageThe language of the component. This is used for translations, and is by default set through event listeners checking for a language property from the header. If none is passed, it will default to English."en" | "fr" | undefined'en'
languageToggleOptionslanguage-toggle-optionsInformation pertaining to the language toggle links.LanguageToggleOptions | string | undefinedundefined
menuItemsmenu-itemsThe items that will go inside the menu dropdown. For the 'ontario' header type, these items are displayed in the overflow menu. If disableDynamicMenu is false, static items will be overridden by dynamically fetched items from the Ontario Header API. For the 'application' and 'serviceOntario' header types, these items are displayed in the subheader menu and overflow menu.MenuItem[] | stringundefined
signInMenuItemssign-in-menu-itemsInformation pertaining to the sign-in menu items for the Ontario header.MenuItem[] | string | undefinedundefined
typetypeThe type of header."application" | "ontario" | "serviceOntario" | undefined'application'

Events

EventDescriptionType
menuButtonToggledThis event is toggled when the menu button is pressed. The <ontario-header-overflow-menu> sub-component listens for this event To trigger the showing and hiding of the overflow menu.CustomEvent<boolean>

Dependencies

Depends on

Graph


Built with StencilJS