diff --git a/src/components/header/_macro-options.md b/src/components/header/_macro-options.md index 76837cfafd..78571609a7 100644 --- a/src/components/header/_macro-options.md +++ b/src/components/header/_macro-options.md @@ -1,22 +1,22 @@ -| Name | Type | Required | Description | -| --------------------- | ------------------------------------------------- | -------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------- | -| phase | `PhaseBanner` [_(ref)_](/components/phase-banner) | false | Settings to set the Phase banner component within the HTML `
` element | -| wide | boolean | false | Set to “true” to increase the maximum width of the layout container to 1280px | -| fullWidth | boolean | false | Set to “true” to increase the maximum width of the layout container to the full width of the viewport | -| classes | string | false | Classes to add to the wrapping `header` | -| variants | array or string | false | An array of values or single value (string) to adjust the component using available variants: “internal”, "neutral" and “description” | -| mastheadLogoUrl | string | false | Wraps the masthead logo in a link. Set the URL for the HTML `href` attribute for the link. | -| mastheadLogo | object`` | false | Settings for a [custom organisation logo](#mastheadlogo) in the masthead. Defaults to the ONS logo. | -| language | object`` | false | Settings for the [language selector](#language) | -| serviceLinks | object`` | false | Settings for the [service links](#servicelinks) in the masthead | -| title | string | true (unless `titleLogo` is set) | The title for the service | -| description | string | false | Tagline or description for the service | -| titleAsH1 | boolean | false | Override to wrap the header `title` in an `

` heading | -| titleLogo | object`` | false | Settings for a [custom title logo](#titlelogo) in the header. | -| titleUrl | string | false | Wraps the title logo in a link. Set the URL for the HTML `href` attribute for the link. | -| button | object`` | false | Settings for the [sign out button](#signoutbutton) in the header used to exit a transactional service | -| navigation | array`` | false | Settings for the [main menu links](#navigation) | -| siteSearchAutosuggest | `Autosuggest` [_(ref)_](/components/autosuggest) | false | Sets the autosuggest functionality in the header | +| Name | Type | Required | Description | +| --------------------- | ------------------------------------------------- | -------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------- | +| phase | `PhaseBanner` [_(ref)_](/components/phase-banner) | false | Settings to set the Phase banner component within the HTML `
` element | +| wide | boolean | false | Set to “true” to increase the maximum width of the layout container to 1280px | +| fullWidth | boolean | false | Set to “true” to increase the maximum width of the layout container to the full width of the viewport | +| classes | string | false | Classes to add to the wrapping `header` | +| variants | array or string | false | An array of values or single value (string) to adjust the component using available variants: “internal”, "neutral" and “description” | +| mastheadLogoUrl | string | false | Wraps the masthead logo in a link. Set the URL for the HTML `href` attribute for the link. | +| mastheadLogo | object`` | false | Settings for a [custom organisation logo](#mastheadlogo) in the masthead. Defaults to the ONS logo. | +| language | object`` | false | Settings for the [language selector](#language) | +| serviceLinks | object`` | false | Settings for the [service links](#servicelinks) in the masthead | +| title | string | true (unless `titleLogo` is set or variant is set to nav-only) | The title for the service | +| description | string | false | Tagline or description for the service | +| titleAsH1 | boolean | false | Override to wrap the header `title` in an `

` heading | +| titleLogo | object`` | false | Settings for a [custom title logo](#titlelogo) in the header. | +| titleUrl | string | false | Wraps the title logo in a link. Set the URL for the HTML `href` attribute for the link. | +| button | object`` | false | Settings for the [sign out button](#signoutbutton) in the header used to exit a transactional service | +| navigation | array`` | false | Settings for the [main menu links](#navigation) | +| siteSearchAutosuggest | `Autosuggest` [_(ref)_](/components/autosuggest) | false | Sets the autosuggest functionality in the header | ## MastheadLogo diff --git a/src/components/header/_macro.njk b/src/components/header/_macro.njk index 317e314464..dff3f8fd3a 100644 --- a/src/components/header/_macro.njk +++ b/src/components/header/_macro.njk @@ -218,118 +218,120 @@ {% endif %} -
-
-
-
- {% if params.titleLogo.large %} + {% if params.variants != "nav-only" %} +
+
+
+
+ {% if params.titleLogo.large %} - {% set title %} - - {% if params.titleLogo.small %} + {% set title %} - {% endif %} - {% endset %} + {% if params.titleLogo.small %} + + {% endif %} + {% endset %} - {% if params.titleUrl %} - {{ title | safe }} + {% if params.titleUrl %} + {{ title | safe }} + {% else %} + {{ title | safe }} + {% endif %} {% else %} - {{ title | safe }} - {% endif %} - {% else %} - {% set title %} - {{ openingTag | safe }} - class="ons-header__title">{{ params.title }}{{ closingTag | safe }} - {% endset %} + {% set title %} + {{ openingTag | safe }} + class="ons-header__title">{{ params.title }}{{ closingTag | safe }} + {% endset %} - {% if params.titleUrl %} - {{ title | safe }} - {% else %} - {{ title | safe }} + {% if params.titleUrl %} + {{ title | safe }} + {% else %} + {{ title | safe }} + {% endif %} {% endif %} - {% endif %} - {% if params.description %} -

{{ params.description }}

- {% endif %} -
+ {% if params.description %} +

{{ params.description }}

+ {% endif %} +
- {% if params.button %} - {% if params.variants == 'neutral' %} - {% set buttonVariant = "ghost-dark" %} - {% else %} - {% set buttonVariant = "ghost" %} + {% if params.button %} + {% if params.variants == 'neutral' %} + {% set buttonVariant = "ghost-dark" %} + {% else %} + {% set buttonVariant = "ghost" %} + {% endif %} +
+ {{ + onsButton({ + "text": params.button.text, + "classes": "ons-u-d-no@2xs@l" if params.navigation else "ons-u-d-no@2xs@m", + "variants": buttonVariant, + "name": params.button.name, + "attributes": params.button.attributes, + "url": params.button.url, + "iconType": "exit", + "iconPosition": "after" + }) + }} +
{% endif %} -
- {{ - onsButton({ - "text": params.button.text, - "classes": "ons-u-d-no@2xs@l" if params.navigation else "ons-u-d-no@2xs@m", - "variants": buttonVariant, - "name": params.button.name, - "attributes": params.button.attributes, - "url": params.button.url, - "iconType": "exit", - "iconPosition": "after" - }) - }} -
- {% endif %} - {% if params.navigation or params.siteSearchAutosuggest %} -
- {% if params.siteSearchAutosuggest %} - {% if params.variants == 'neutral' %} - {% set buttonVariant = ["small", "ghost-dark"] %} - {% else %} - {% set buttonVariant = ["small", "ghost"] %} + {% if params.navigation or params.siteSearchAutosuggest %} +
+ {% if params.siteSearchAutosuggest %} + {% if params.variants == 'neutral' %} + {% set buttonVariant = ["small", "ghost-dark"] %} + {% else %} + {% set buttonVariant = ["small", "ghost"] %} + {% endif %} + + {{ + onsButton({ + "text": "Search", + "classes": "ons-btn--search ons-u-ml-2xs ons-u-d-no ons-js-toggle-search", + "variants": buttonVariant, + "iconType": "search", + "iconPosition": "only", + "attributes": { + "aria-label": "Toggle search" , + "aria-controls": "ons-site-search", + "aria-expanded": "false" + } + }) + }} + {% endif %} - + {% if params.navigation.toggleNavigationButton %} + {% set buttonVariant = ["mobile", "ghost"] %} {{ onsButton({ - "text": "Search", - "classes": "ons-btn--search ons-u-ml-2xs ons-u-d-no ons-js-toggle-search", + "text": params.navigation.toggleNavigationButton.text, + "classes": "ons-u-ml-2xs ons-u-d-no ons-js-navigation-button ons-u-d-no@l", "variants": buttonVariant, - "iconType": "search", - "iconPosition": "only", "attributes": { - "aria-label": "Toggle search" , - "aria-controls": "ons-site-search", + "aria-label": params.navigation.toggleNavigationButton.ariaLabel | default("Toggle main menu") , + "aria-controls": params.navigation.id, "aria-expanded": "false" } }) }} - - {% endif %} - {% if params.navigation.toggleNavigationButton %} - {% set buttonVariant = ["mobile", "ghost"] %} - {{ - onsButton({ - "text": params.navigation.toggleNavigationButton.text, - "classes": "ons-u-ml-2xs ons-u-d-no ons-js-navigation-button ons-u-d-no@l", - "variants": buttonVariant, - "attributes": { - "aria-label": params.navigation.toggleNavigationButton.ariaLabel | default("Toggle main menu") , - "aria-controls": params.navigation.id, - "aria-expanded": "false" - } - }) - }} - {% endif %} -
- {% endif %} + {% endif %} +
+ {% endif %} +
-
+ {% endif %} {% if params.navigation %} {{ onsNavigation(params) }} {% endif %} diff --git a/src/components/header/_macro.spec.js b/src/components/header/_macro.spec.js index 1505ab3112..9c833f5511 100644 --- a/src/components/header/_macro.spec.js +++ b/src/components/header/_macro.spec.js @@ -43,6 +43,16 @@ describe('FOR: Macro: Header', () => { expect($('.ons-header--variant-b').length).toBe(1); }); }); + describe('WHEN: variants is set to nav-only', () => { + test('THEN: does not render ons-header__main class ', () => { + const $ = cheerio.load( + renderComponent('header', { + variants: 'nav-only', + }), + ); + expect($('.ons-header').hasClass('ons-header__main')).toBe(false); + }); + }); }); describe('GIVEN: Params: classes', () => { describe('WHEN: classes are provided', () => { diff --git a/src/components/header/example-header-with-navigation-only.njk b/src/components/header/example-header-with-navigation-only.njk new file mode 100644 index 0000000000..db6fc04a95 --- /dev/null +++ b/src/components/header/example-header-with-navigation-only.njk @@ -0,0 +1,11 @@ +--- +'fullWidth': true +--- + +{% from "components/header/_macro.njk" import onsHeader %} + +{{ + onsHeader({ + "variants": 'nav-only' + }) +}}