🚀 Big News: Socket Acquires Coana to Bring Reachability Analysis to Every Appsec Team.Learn more
Socket
Book a DemoInstallSign in
Socket

@workday/canvas-kit-labs-react-header

Package Overview
Dependencies
Maintainers
2
Versions
296
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@workday/canvas-kit-labs-react-header

A Canvas-styled application header

4.8.1
latest
Source
npm
Version published
Weekly downloads
240
122.22%
Maintainers
2
Weekly downloads
 
Created
Source

Canvas Kit Labs React Header

LABS: Beta This component is work in progress and currently in pre-release.

A set of components to create headers for various Workday applications and sites.

For a full suite of examples, have a look at the Header Stories.

Coming Soon

  • Mobile Expanded Nav

Installation

yarn add @workday/canvas-kit-labs-react-header

Header

This component renders a responsive, Canvas-style header.

Usage

import * as React from 'react';
import {Header} from '@workday/canvas-kit-labs-react-header';
import {IconButton} from '@workday/canvas-kit-react-button';
import {Avatar} from '@workday/canvas-kit-react-avatar';
import {notificationsIcon} from '@workday/canvas-system-icons-web';
import {Button} from '@workday/canvas-kit-react-button';

<Header title="Header" brandUrl="#">
  <nav>
    <ul>
      <li className="current">
        <a href="#">Discover</a>
      </li>
      <li>
        <a href="#">Library</a>
      </li>
      <li>
        <a href="#">Create</a>
      </li>
      <li>
        <a href="#">Manage</a>
      </li>
    </ul>
  </nav>
  <IconButton
    icon={notificationsIcon}
    variant={IconButton.Variant.Circle}
    title="Notifications"
    aria-label="Notifications"
  />
  <Avatar
    onClick={() => {
      alert('clicked avatar');
    }}
    altText="Profile"
  />
  <Button variant={Button.Variant.Primary}>Sign Up</Button>
</Header>;

Special Children

nav, ul, li

For a semantic navigation menu, this component will style a child <nav> element with an un-ordered list inside (<ul>). This list can contain any number of <li> elements with <a> elements. You can visually distinguish the link that your page is currently on by adding the class name: "current" to the <li> element containing the current page link.

SystemIcon

Deprecated (but supported) - please use IconButton instead.

The Header supports Canvas SystemIcon components, but will convert them into an IconButton with the correct styling for the theme you've provided.

A Note About Buttons

Please use a Primary Canvas Button for this component's call-to-action buttons (see the usage example below).

Static Properties

Theme: HeaderTheme

<Header title="Blue Header" themeColor={Header.Theme.Blue} />

Variant: HeaderVariant

<Header title="Marketing Header" variant={Header.Variant.Full} />

Component Props

Required

None

Optional

title: string

The title displayed on the header next to the logo.

Default: ''

themeColor: HeaderTheme

The theme of the header (White, Blue, or Transparent).

ThemeDescription
WhiteWhite background with dark-colored text, blue system icons.
BlueDark blue gradient background with white text, white system icons.
TransparentTransparent background (intended for dark-colored overlays) with white text, white system icons.

Default: HeaderTheme.White

variant: HeaderVariant

Specifies the variation of the header.

VariantDescription
Dub"Dub" headers have a singular "Dub" logo and a title, separated by a equivalent-height divider. It is shorter in height (64px) than the "Full" variant.
Full"Full" headers have the full Workday logo and an optional title at minimum, separated by an equivalent-height divider (when a title is defined). It is taller in height (80px) than the "Dub" variant.

Default: HeaderVariant.Dub

brandUrl: string

The href attribute when clicking on the title logo. Default: '#'

brand: React.ReactNode

If specified, this replaces the contents of the Dub logo and title. Used for replacing Dub + title with a contained lockup and/or for adding custon design elements next to the Dub + title lockup.

Default: DubLogoTitle (for "Dub" variants) or WorkdayLogoTitle (for "Full" variants)

isCollapsed: boolean

Indicates whether the children in the header should be collapsed.

  • The nav element collapses into a hamburger icon menu. Any IconButton or SystemIcon will also collapse.

onMenuClick: (React.MouseEvent) => void

A click handler for when the user clicks the mobile collapsed nav icon.

centeredNav: boolean

When true, the header centers the nav in the middle of the header.

leftSlot: React.ReactElement

A React element for the left of the header, this is typically a search bar component

Global Header

The Global Header (or App Header) is used for Workday applications.

Usage

import {Avatar} from '@workday/canvas-kit-react-avatar';
import {GlobalHeader, DubLogoTitle} from '@workday/canvas-kit-labs-react-header';
import {Avatar} from '@workday/canvas-kit-react-avatar';
import {IconButton} from '@workday/canvas-kit-react-button';
import {notificationsIcon, inboxIcon} from '@workday/canvas-system-icons-web';

const HeaderBrand = () => <DubLogoTitle themeColor={Header.Theme.White} />
const HeaderAvatar = () => <Avatar onClick={handleMenuClick} url="https://my.cdn.amazonaws.com/assets/avatar_pic.png" />
const handleSearchSubmit = event => {
  const query = (event.target as HTMLFormElement).getElementsByTagName('input')[0].value;
  console.log("Submitted query: ", query)
}
const openMenu = e => console.log("Menu opened")

/**
 * In this instance, the right-most child will be an Avatar component, when the GlobalHeader
 * shrinks below the specified breakpoint (720 in this case), the children get replaced by a menuToggle.
 * For most GlobalHeader implementations, the menuToggle is also the Avatar component.
 */
<GlobalHeader
  brand={<HeaderBrand />}
  menuToggle={<HeaderAvatar />}
  onMenuClick={openMenu}
  leftSlot={<SearchBar
    isCollapsed={false}
    grow={true}
    onSubmit={handleSearchSubmit}
  />}
  isCollapsed={false}
>
  <IconButton icon={notificationsIcon} variant={IconButton.Variant.Circle} />
  <IconButton icon={inboxIcon} variant={IconButton.Variant.Circle} />
  <HeaderAvatar />
</GlobalHeader>

Static Properties

None

Component Props

Required

None

Optional

brand: React.ReactNode

If specified, this replaces the contents of the Dub logo and title. Used for replacing Dub + title with a branded element and/or for adding custon design elements next to the Dub + title lockup.

Default: <DubLogoTitle />

menuToggle: React.ReactNode

Note: This menuToggle slot only appears when the screen size shrinks below the breakpoint.

For most GlobalHeader implementations, this is generally the same as the users' Avatar. If not specified, menuToggle defaults to a "hamburger" menu icon or "justify" icon.

Default: justifyIcon from @workday/canvas-system-icons-web

onMenuClick: (React.MouseEvent) => void

A click handler for when the user clicks the menuToggle element.

Default: <DubLogoTitle />

leftSlot: React.ReactElement

A React element for the left of the header, this is typically a search bar component

isCollapsed: boolean

If true, renders the header with the children collapsed.

"Dub" Logo and Title

Intended to be used in conjunction with the Header component

A component that encapsulates the 'Dub' logo and a title (we call this the contained lockup). This is used whenever you want to override the contained lockup that comes default with a header, or if you want to add more elements next to the title with custom components or markup, or change the background color of the contained lockup

Usage

import {Header, DubLogoTitle} from '@workday/canvas-kit-labs-react-header';
import {colors} from '@workday/canvas-kit-react-core';

<Header
  brand={<DubLogoTitle title="This title will show up instead" bgColor={colors.blueberry600} />}
/>;

Static Properties

None

Component Props

Required

title: string

The title displayed on the header next to the logo.

Default: ''

Optional

themeColor: HeaderTheme

The theme of the header (White, Blue, or Transparent).

Default: HeaderTheme.White

bgColor: string

Sets the background CSS property for the contained lockup.

Default: 'none'

Workday Logo and Title

Intended to be used in conjunction with the Header component

A component that contains the full Workday logo and a title. This is used whenever you want to override the contained lockup that comes default with a header, or if you want to add more elements next to the title with custom components or markup.

Usage

import {Header, WorkdayLogoTitle} from '@workday/canvas-kit-labs-react-header';

<Header brand={<WorkdayLogoTitle title="Display Title" />} />;

Static Properties

None

Component Props

Required

None

Optional

themeColor: HeaderTheme

The theme of the header (White, Blue, or Transparent). See the themeColor prop on the Header component.

Default: HeaderTheme.White

title: string

The title displayed on the header next to the logo.

Default ''

Intended to be used in conjunction with the Header component

A component that contains a search bar with autocomplete functionality.

Usage

import {SearchBar} from '@workday/canvas-kit-labs-react-header';
import {MenuItem} from '@workday/canvas-kit-labs-react-menu';

const handleInputChange = event => console.log('Adjust menu items here');
const handleSearchSubmit = event => {
  const query = (event.target as HTMLFormElement).getElementsByTagName('input')[0].value;
  console.log('Submitted query: ', query);
};

<SearchBar
  autocompleteItems={[<MenuItem>Item 1</MenuItem>]}
  isCollapsed={false}
  onInputChange={this.autocompleteCallback}
  placeholder={`Search with Autocomplete`}
  grow={true}
  searchTheme={SearchBar.Theme.Dark}
  onSubmit={handleSearchSubmit}
/>;

Static Properties

None

Component Props

Required

onSubmit: React.FormEventHandler<HTMLFormElement>

An function that gets called and passed the current input value when the search form is submitted.

Optional

isCollapsed: boolean

True if the search input should be collapsed into a toggle icon (for responsive).

onInputChange: React.ChangeEventHandler<HTMLInputElement>

Callback to listen when the TextInput changes. This is usually used to update the autocomplete items.

autocompleteItems: React.ReactElement<MenuItemProps>[]

An array of MenuItems to show under the search bar.

searchTheme?: SearchTheme | SearchThemeAttributes

The theme of the header the search input is being rendered in. There are 3 build in themes, but the styles are customizable via SearchThemeAttributes.

ThemeDescription
LightWhite background with dark-colored text, blue focus ring.
DarkDark semi transparent background with white text. Inverts on focus.
TransparentTransparent background (intended for light-colored header) with dark text. Also used in collapsed state.

Default: SearchTheme.Light

placeholder: string

Placeholder for search input.

Default: 'Search'

initialValue: string;

Initial value to set the input to.

rightAlign: boolean;

False if the search input should grow to left align it. True if it should right align.

inputLabel: string

Screenreader label for text input.

Default: 'Search'

submitLabel: string

Screenreader label for submit button

Default: 'Search'

clearButtonAriaLabel: string

Screenreader Label for clear button

openButtonLabel: string

Screenreader Label to open collapsed search bar

Default: 'Open Search'

closeButtonLabel: string

Screenreader Label to close collapsed search bar

Default: 'Cancel'

showClearButton: string

Show button to clear input field

Default: true

Keywords

canvas

FAQs

Package last updated on 09 Jul 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts