npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@financial-times/o-header

v14.1.0

Published

Responsive Financial Times page header with primary and secondary navigation, a drop down mega menu, and a collapsible drawer

Downloads

4,770

Readme

o-header

Responsive header for FT branded sites. See the Origami Navigation Service to populate o-header markup with real navigation data.

Usage

Check out how to include Origami components in your project to get started with o-header.

Markup

As there are variations on the header, and the markup for each is specific and somewhat extensive, we recommend visiting the component page in Storybook to find the markup that is most suited to your product. The demo on the component page does not use real navigation data as it may become out of date. See the Origami Navigation Service to populate o-header markup with real navigation data. The Origami Navigation Service is a JSON API which provides navigation structures for use across FT websites.

There are intentionally no classes to switch between logged in and out as we don't want to do that in the client side. This is left up to the product.

Some elements inside the header require specific data attributes so the JavaScript can add some behaviour correctly. These are:

  • data-o-header--no-js: Applied to the root element. This data attribute is removed when the JavaScript initialises
  • data-o-header--sticky: Applied to the sticky variation of the header
  • data-o-header-mega: Applied to the root <div> of the mega menu
  • data-o-header-search: Applied to the root <div> of the enhanced search row. There are two search rows, one for enhanced, another for core
  • data-o-header-drawer: Applied to the root <div> of the drawer
  • data-o-header-subnav: Applied to the root div of the subnav menu
  • data-o-header-subnav-wrapper: Applied to the inner wrapper div of the subnav menu so the JS can handle the scrolling
  • data-o-header-search-state: Optional, may be "open" or "close" to indicate the default visibility of the search bar.

The sub navigation header can be used with a modifer class o-header__subnav--primary to achieve styles consistent with the main navigation where item links are bold and capitalised and the background colour is paper.

JavaScript

An o-header object must be constructed for every <header> you have on your page that uses this component.

import oHeader from '@financial-times/o-header';
const headerEl = document.querySelector('.o-header');
const header = new oHeader(headerEl);

The o-header constructor accepts an optional options object, used to control certain behaviors:

  • searchState: may be "open" or "close" to determine whether the header's search bar is immediately visible. By default, the search bar is hidden.
import oHeader from '@financial-times/o-header';
const headerEl = document.querySelector('.o-header');
const header = new oHeader(headerEl, {searchBarOpen: true});

Alternatively, a o.DOMContentLoaded event can be dispatched on the document to auto-construct an o-header object for each element with a data-o-component="o-header" attribute:

import '@financial-times/o-header';
document.addEventListener('DOMContentLoaded', function () {
	document.dispatchEvent(new CustomEvent('o.DOMContentLoaded'));
});

Events

o-header fires the following events:

  • oHeader.MegaMenuShow: When a mega menu is shown. The target of the event is the menu itself.
  • oHeader.MegaMenuClose: When a mega menu is closed. The target of the event is the menu itself.
  • oHeader.Sticky: When the header changes to or from sticky. The event detail will contain an isActive boolean indicated sticky or not. The target of the event is the menu itself.

Sass

The header is made up of various features (e.g. nav, search, and drawer). To get everything, use the oHeader() mixin without arguments. To get only the stuff you need, you can pass in a list of options as the first argument.

The list of options is as follows:

  • top: Styles for first header row including the logo and buttons for the drawer menu and search bar.
  • nav: The primary nav, this is the nav that sits directly under the top section of the header.
  • search: The search bar that appears when a user presses the search icon.
  • anon: Styles for the row that appears when a user is not logged in.
  • sticky: Styles that make the header stick to the top of the page when scrolling down.
  • simple: Styles for the reduced slimmer header for article pages.
  • transparent: Styles for an "inverse" header with no background colour and white text and logos. For use on dark backgrounds only. Does not support the navigation drawer currently (speak to Origami if you would like to use a drawer with this variant).
  • megamenu: Styles for the mega-menu that appears when users hover over a nav item.
  • drawer: Styles for the drawer menu which is used as the primary navigation on small screens.

To output styles for a feature only, excluding base header styles required by all features, pass false as the second argument.

E.g. To get all of the CSS needed for the FT homepage you would call:

@include oHeader(('sticky', 'simple', 'anon', 'search', 'nav', 'megamenu'));

Browser Support

To use o-header setup a core and enhanced experience within your project. o-header depends on the o--if-js and o--if-no-js classes.

Migration guide

| State | Major Version | Last Minor Release | Migration guide | | :----------: | :-----------: | :----------------: | :------------------------------------------------------: | | ✨ active | 13 | N/A | migrate to v13 | | ⚠ maintained | 12 | N/A | migrate to v12 | | ⚠ maintained | 11 | N/A | migrate to v11 | | ╳ deprecated | 10 | N/A | migrate to v10 | | ╳ deprecated | 9 | N/A | migrate to v9 | | ╳ deprecated | 8 | 8.6 | migrate to v8 | | ╳ deprecated | 7 | 7.8 | migrate to v7 | | ╳ deprecated | 6 | 6.14 | migrate to v6 | | ╳ deprecated | 5 | 5.0 | - | | ╳ deprecated | 4 | 4.0 | - | | ╳ deprecated | 3 | 3.0 | - | | ╳ deprecated | 2 | 2.5 | - | | ╳ deprecated | 1 | 1.1 | - |

Contact

If you have any questions or comments about this component, or need help using it, please either raise an issue, visit #origami-support or email Origami Support.


Licence

This software is published by the Financial Times under the MIT licence.