Back to Global Minimal Header-guidelines

CSS ComponentThe latest version of this package is: 14.1.0, Opens in new window

Global Minimal Header is a page header that provides only basic functionality

This component provides .css, .styl, .less and .scss -files.

To be able to install this component, please refer to the Project Setup documentation.

$ npm i @ids-core/global-minimal-header@14.1.0

Table of Contents

Edit this section, Opens in new window

Usage

Below is an example markup for Global Minimal Header implementation.

  • Be aware of the semantics which are required for your solution and follow accessibility guidelines for a header and menu.
<div class="if">
  <div class="if block">
    <div class="if container">
      <header class="if global-minimal-header">
        <a href="#content" class="if axe skip-to-content">Skip to content</a>

        <nav class="if primary" role="navigation">
          <div class="if mobile">
            <ul role="presentation" class="if mobile-menu-list">
              <li role="presentation" class="if mobile-menu-item logo-holder">
                <a href="#" class="if mobile-menu-action logo small"><span class="if axe sr-only">Home</span></a>
              </li>

              <li role="presentation" class="if mobile-menu-item change-language-holder">
                <button id="mobile-language-trigger" type="button" class="if mobile-menu-action button change-language">
                  Language
                </button>

                <div
                  id="language-menu"
                  class="if accordion-menu"
                  role="menu"
                  tabindex="-1"
                  aria-labelledby="mobile-language-trigger"
                >
                  <div class="if mobile-language">
                    <ul class="if mobile-language-list">
                      <li role="presentation" class="if mobile-language-item">
                        <button
                          tabindex="-1"
                          role="menuitem"
                          type="button"
                          class="if mobile-language-action"
                          data-language="nb"
                        >
                          NB
                        </button>
                      </li>
                      <li role="presentation" class="if mobile-language-item">
                        <button
                          tabindex="-1"
                          role="menuitem"
                          type="button"
                          class="if mobile-language-action"
                          data-language="da"
                        >
                          DA
                        </button>
                      </li>
                      <li role="presentation" class="if mobile-language-item is-active">
                        <button
                          tabindex="-1"
                          role="menuitem"
                          type="button"
                          class="if mobile-language-action"
                          data-language="sv"
                        >
                          SV
                        </button>
                      </li>
                      <li role="presentation" class="if mobile-language-item">
                        <button
                          tabindex="-1"
                          role="menuitem"
                          type="button"
                          class="if mobile-language-action"
                          data-language="fi"
                        >
                          FI
                        </button>
                      </li>
                      <li role="presentation" class="if mobile-language-item">
                        <button
                          tabindex="-1"
                          role="menuitem"
                          type="button"
                          class="if mobile-language-action"
                          data-language="en"
                        >
                          EN
                        </button>
                      </li>
                    </ul>
                  </div>
                </div>
              </li>

              <li role="presentation" class="if mobile-menu-item mypages-holder">
                <button type="button" class="if mobile-menu-action button mypages">Profile</button>
              </li>
            </ul>
          </div>

          <div class="if desktop container">
            <ul role="presentation" class="if desktop-menu-list">
              <li role="presentation" class="if desktop-menu-item logo-holder">
                <a href="#" class="if desktop-menu-action logo small"><span class="if axe sr-only">Home</span></a>
              </li>

              <li role="presentation" class="if desktop-menu-item change-language-holder is-parent">
                <button id="desktop-language-trigger" type="button" class="if desktop-menu-action change-language">
                  Language
                </button>

                <div class="if dropdown-menu top" role="menu" aria-labelledby="desktop-language-trigger">
                  <ul class="if">
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="nb">
                        Norsk bokmål
                      </button>
                    </li>
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="da">Dansk</button>
                    </li>
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="sv">Svenska</button>
                    </li>
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="fi">
                        Suomen kieli
                      </button>
                    </li>
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="kl">
                        Kalaallit oqaasii
                      </button>
                    </li>
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="en">English</button>
                    </li>
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="lv">
                        Latviešu valoda
                      </button>
                    </li>
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="lt">
                        Lietuvių kalba
                      </button>
                    </li>
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="et">
                        Eesti keel
                      </button>
                    </li>
                    <li role="presentation" class="if">
                      <button tabindex="-1" role="menuitem" type="button" class="if" data-language="ru">
                        Pусский язык
                      </button>
                    </li>
                  </ul>
                </div>
              </li>

              <li role="presentation" class="if desktop-menu-item mypages-holder">
                <button type="button" class="if desktop-menu-action button mypages">
                  Firstname Lastname
                </button>
              </li>
            </ul>
          </div>
        </nav>
      </header>
    </div>
  </div>
</div>
Edit this section, Opens in new window

Accessibility

<header class="if global-minimal-header">
  <!-- 1. Skip link -->
  <a href="#content" class="if axe skip-to-content">Skip to content</a>

  <!-- 2. role="navigation" -->
  <nav class="if primary" role="navigation">
    <div class="if [mobile | desktop]">
      <ul role="presentation" class="if mobile-menu-list"></ul>
    </div>
  </nav>
</header>
  1. Skip links located at header ensure quick access to main content for vision deficient users.
  2. [role="navigation"] is used to denote group of links intended for page navigation. read more at w3

As the component is a derivative of global header and incorporates menu inside, it is a good idea to refer to the global header, the Dropdown Menu and the Accordion Menu accessibility sections for more info on how to make it accessible.

Check out Usage section to see example on how Global Minimal Header might be implemented.

Edit this section, Opens in new window

Changelog

Change Log

All notable changes to this project will be documented in this file. See Conventional Commits for commit guidelines.

14.0.0 (2021-11-09)

chore

  • 🤖 Rename util to utils (f78721f)

Code Refactoring

  • 💡 Rename scope and repository (3ea5423)
  • 💡 Use new navigation structure for documentation (415aee5), closes #490579

Documentation

  • ✏️ Update links and change navigation structure (0bfd27d), closes #490579

BREAKING CHANGES

  • 🧨 The scope for If Design System npm packages has now changed from

@if-design-system to @ids-core. We have also renamed the repository from if-design-system to ids-core

  • 🧨 Util is now renamed to Utils
  • 🧨 We have now changed the navigation structure for the documentation site.

Please update any saved links!

  • 🧨 Navigation structure has now changed. Please see release notes!

13.11.0 (2021-10-19)

Features

  • 🎸 Input field hot reload (eac76b7)

13.9.2 (2021-09-30)

Bug Fixes

  • 🐛 Complete the pseudo-element fix (1dcee2c)

13.6.3 (2021-09-17)

Bug Fixes

12.13.1 (2021-08-11)

Bug Fixes

12.13.0 (2021-08-11)

Bug Fixes

12.12.1 (2021-08-10)

Bug Fixes

  • 🐛 Make sure components using fonts, have fonts bundled (d5bb642), closes #354912

12.6.0 (2021-05-27)

Bug Fixes

12.13.1 (2021-08-11)

Bug Fixes

12.13.0 (2021-08-11)

Bug Fixes

12.12.1 (2021-08-10)

Bug Fixes

  • 🐛 Make sure components using fonts, have fonts bundled (d5bb642), closes #354912

12.6.0 (2021-05-27)

Bug Fixes

  • 🐛 Manually set firstPublished and lastModified (e83af7d)
  • 🐛 We don't need lastModified (e458a12)

12.0.0 (2021-05-05)

Code Refactoring

  • 💡 Remove Teasers, added Text and Lifestyle cards (1247479), closes #336508
  • 💡 Rename and consolidate mixins (67cf470), closes #268081
  • 💡 Rename Minimal Header to Global Minimal Header (d600118)
  • 💡 Rename Notification to Alert Banner (8b4e48d), closes #336508

BREAKING CHANGES

  • 🧨 All of the mixins have now been renamed
  • 🧨 Teasers are no more. It has been replaces with Lifestyle Navigational

Card, Text Navigational Card. Studio Teasers is gone, use Studio Navigational Card instead, which is based on the old Studio Crosslinks

  • 🧨 Notification is now renamed to Alert Banner
  • 🧨 The Minimal Header component is now known as Global Minimal Header

8.2.0 (2021-01-13)

Bug Fixes

  • 🐛 Use correct version (40cd689)

Features

Edit this section, Opens in new window
Contact us, Opens in new window