@workday/canvas-kit-docs
Version:
Documentation components of Canvas Kit components
133 lines (101 loc) • 5.57 kB
text/mdx
import {ExampleCodeBlock, SymbolDoc, Specifications} from '@workday/canvas-kit-docs';
import Basic from './examples/Basic';
import OverflowBreadcrumbs from './examples/Overflow';
import RTLOverflowList from './examples/RTL';
import CurrentItemTruncation from './examples/CurrentItemTruncation';
import LinkTruncation from './examples/LinkTruncation';
# Canvas Kit Breadcrumbs
Breadcrumbs is a
[compound component](/get-started/for-developers/documentation/compound-components/) that allows
users to keep track and maintain awareness of their location as they navigate through pages,
folders, files, etc.
[> Workday Design Reference](https://design.workday.com/components/navigation/breadcrumbs)
## Installation
```sh
yarn add /canvas-kit-react
```
## Usage
### Basic Example
`Breadcrumbs` includes a container `Breadcrumbs` component and the following subcomponents which can
be composed in a variety of ways: `Breadcrumbs.List`, `Breadcrumbs.Item`, `Breadcrumbs.CurrentItem`
and `Breadcrumbs.Link`.
Accessibility is built into `Breadcrumbs` in a way that allows you to create an inclusive experience
with little additional configuration. As seen in the example below, you don't need to pass any
accessibility attributes, because they are baked into the component. You only need to add
`aria-label` attribute to a `nav` component through a `aria-label` prop of `Breadcrumbs`.
<ExampleCodeBlock code={Basic} />
Note that all links require an `href` to be properly identified.
### Overflow Breadcrumbs
`Breadcrumbs` is a responsive component based on the width of its container. If the rendered links
exceed the width of the `Breadcrumbs.List`, an overflow menu will be rendered. This only works
against the dynamic API where you give the `BreadcrumbsModel` an array of items to be rendered. The
dynamic API handles the React `key` for you based on the item's identifier. The dynamic API requires
either an `id` on each item object or a `getId` function that returns an identifier based on the
item. The example below uses an `id` property on each item.
<ExampleCodeBlock code={OverflowBreadcrumbs} />
The dynamic API takes in any object, but since nothing is known about your object, a
[render prop](https://reactjs.org/docs/render-props.html) is necessary to instruct a list how it
should render.
### Truncating a Link
`Breadcrumbs.Link` is a styled `<a>` element that also renders a tooltip if the text is truncated.
The built-in truncation and tooltip functionality provides an easy-to-use, accessible feature for
managing the length of link text. The `maxWidth` is set to `350px` by default and can be adjusted as
needed. Note that tooltips will only render when text is truncated. The example below uses a
`maxWidth` of `150px`.
<ExampleCodeBlock code={LinkTruncation} />
### Item Truncation
`Breadcrumbs.CurrentItem` is a styled `<li>` element that also renders a tooltip if the text is
truncated. The built-in truncation and tooltip functionality provides an easy-to-use, accessible
feature for managing the length of the text. The `maxWidth` is set to `350px` by default and can be
adjusted as needed. Normally, this is a non-focusable element; when truncated, however, it sets the
`tabIndex` to `0` to enable the tooltip to appear on keyboard focus. Note that tooltips will only
render when text is truncated. The example below uses a `maxWidth` of `100px`.
<ExampleCodeBlock code={CurrentItemTruncation} />
### Right-to-Left (RTL)
`Breadcrumbs` has bidirectional support out of the box. That means outside of setting the content
direction in your application's Canvas theme, you don't need to do anything else to make it work.
All you need to supply is the translated text for items and ARIA labels.
<ExampleCodeBlock code={RTLOverflowList} />
### Handling Redirects
`Breadcrumbs.Link` defaults to redirecting with an `href`, which means the page will hard-redirect
when the link is clicked. However, if you're in a single-page application (SPA) environment, you
might want to use the internal SPA router instead. You can override that behavior with a custom
`onClick` handler that blocks the default behavior of the event and passes along the link path to
your SPA router. Most of our consumers use `react-router-dom` for managing SPA routing, so below is
an example of how to do this in V5 and V6 of `react-router-dom`.
```tsx
// React Router DOM V5 API
import {useHistory} from 'react-router-dom';
import {Breadcrumbs} from '/canvas-kit-react/breadcrumbs';
...
const history = useHistory();
const handleClick = (event: React.MouseEvent<HTMLAnchorElement, MouseEvent>, link?: string) => {
event.preventDefault();
// if no link is provided, default to the current path
history.push(link || window.location.pathname);
}
return (
<Breadcrumbs.Link href="/account" onClick={handleClick}>
Account
</Breadcrumbs.Link>
);
// React Router DOM V6 API
import {useNavigate} from 'react-router-dom';
import {Breadcrumbs} from '/canvas-kit-react/breadcrumbs';
...
const navigate = useNavigate();
const handleClick = (event: React.MouseEvent<HTMLAnchorElement, MouseEvent>, link?: string) => {
event.preventDefault();
// if no link is provided, default to the current path
navigate(link || window.location.pathname);
}
return (
<Breadcrumbs.Link href="/account" onClick={handleClick}>
Account
</Breadcrumbs.Link>
);
```
## Component API
<SymbolDoc name="Breadcrumbs" fileName="/react/" />
## Specifications
<Specifications file="Breadcrumbs.spec.ts" name="Breadcrumbs" />