LoaderUse the loader component to communicate to the user that an action is being processed and is awaiting output or result. The purpose is to prevent the user from taking other actions that might interrupt the current action/process
Small and adaptive badge for adding context to just about any content.
John Doe White
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/badges
Using styles
@import '@relax/badges';
Usage
Badges are used to tag content, and for selection purposes.
Buttons express what action will occur when the user clicks or touches it. Buttons are used to initialize an action, either in the background or foreground of an experience.
Edit customer
Do you want to save?
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/buttons
Using styles
@import '@relax/buttons';
Usage
Buttons communicate actions that uses can take.
Principles
Buttons should indicate that they can trigger an action.
Buttons should be easy to find among other elements, including other buttons.
A button's action and state should be clear.
Types
No spacing, no background or outline, link button
No background or outline, text button
Outlined, secondary button
Filled, primary button
Filled, warning button
Small Outlined, secondary button
Small Filled, primary button
Small Filled, warning button
Icon button, no label
Hierarchy and placement
Hierarchy
A single primary button
A layout/view should contain a single primary button that makes it clear that other buttons have less importance in the hierarchy. This primary button commands the most attention.
Other buttons
An view can show more than one button in a layout at a time, so a primary button can be accompanied by secondary or text buttons that perform less important actions.
Placement
Are you ready for this?
Do not use two or more primary buttons together
Are you ready for this?
Only use one primary button per view
Secondary buttons
Secondary buttons are, secondary. They contain actions that are important, but not the primary action.
The primary button is the preferred call-to-action button. The button is used to dictate what the primary action of a view is. Never use more than one primary button for one view.
Text labels describe the action that will occur if a user taps a button. If a text label is not used, an icon should be present to signify what the button does. Text labels should be short, concise and descriptive.
Do not use long labels
Use short and distinct labels for the action
If you are using an icon instead of a text label, you must also use a hidden label describing what the action is: Action
Use the loader component to communicate to the user that an action is being processed and is awaiting output or result. The purpose is to prevent the user from taking other actions that might interrupt the current action/process.
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/loader
Using styles
@import '@relax/loader';
Usage
Types
Not contained
Inside buttons
Inside buttons
On primary buttons, the loader (white #ffffff) should appear centered in the button (depressed state) and replace the button text. The loader should only appear if the action or request takes more than 1000ms to process.
Other usage
The larger blue loader can be used to communicate that content or data is loading into, for example, a card, panel, table or even an entire page.
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/media
Using styles
@import '@relax/media';
Implementation
<figure role="img" aria-labelledby="relax-last-seven-inches-caption">
<img alt="A picture of a seven inch record in a thin paper sleeve. The record is Frankie Goes to Hollywood - Relax" src="https://upload.wikimedia.org/wikipedia/en/4/4a/Relax_Last_Seven_Inches.jpg" longdesc="https://en.wikipedia.org/wiki/File:Relax_Last_Seven_Inches.jpg"/>
<figcaption id="relax-last-seven-inches-caption">
By Personal camera, <a href="//en.wikipedia.org/wiki/File:Relax_Last_Seven_Inches.jpg" title="This image is of a cover of an audio recording, and the copyright for it is most likely owned by either the publisher of the work or the artist(s) which produced the recording or cover artwork in question.">Fair use</a>, <a href="https://en.wikipedia.org/w/index.php?curid=7795516">Link</a>
</figcaption>
</figure>
Provide contextual feedback messages for typical user actions with the handful of available and flexible alert messages
This is a notification with some information.
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/notifications
Using styles
@import '@relax/notifications';
Usage
Large vs. small notifications
Use notifications to indicate the status of an event or action, for example saving a change. If the change loads a new page, the notification should span the entire width of the content container (100%). If the change is within the page, for example inside a panel, use a small notification (toast) inline with the buttons that were used to make the change (save, submit, etc.).
Message
The body of the notification should be contained within two lines. Be descriptive and include any troubleshooting actions or next steps. When possible, communicate the main message using just the title.
This is a general notification that is way to long and non descriptive, really not doing anything good. Perhaps you could find better use for this?
Don't let messages span over more than two lines
This is a general and concise notification.
Use short, descriptive messages
Dismissal
All notifications can have at least one method of dismissal. Typically, it is a small “x” in the upper right hand corner. Some notifications should not be dismissable, for example warnings about overdue payments, or status of a particular view.
Types
This is a general notification.
This is a general notification.
Endring av polisen feilet
Feilkode #632 Fikk ikke kontakt med server. Vennligst prøv igjen senere. Hvis problemet vedvarer..
Normal notification
Toast
Hero notification
Toasts
You can use the notification component as toasts aswell. Just add the .relax-notification-toast-class!
Toast Notifications
Toast Notifications slide in and out a page from the top-right corner. Actionable notifications do not appear on mobile screen widths.
Inline Notifications
Inline Notifications appear near its related item.
This is a notification of a successful action or event.
<div class="relax-notification relax-notification--success relax-notification-toast">
This is a notification of a successful action or event.
</div>
Hero
You can use the notification component as hero aswell. Just add the .relax-notification-hero-class!
Endring av polisen feilet
Feilkode #632 Fikk ikke kontakt med server. Vennligst prøv igjen senere. Hvis problemet vedvarer..
<div class="relax-notification relax-notification--error relax-notification-hero">
<div class="relax-notification-content">
<div>
<h1>Endring av polisen feilet</h1><span class="relax-error-code"><strong>Feilkode #632</strong><span><br>
<span class="relax-error-message">Fikk ikke kontakt med server. Vennligst prøv igjen senere. Hvis problemet vedvarer..</span></span></span>
</div>
<ul style="list-style: none; margin: 0; margin-top: auto;">
<li><button class="relax-button relax-button--small relax-button-link relax-icon-ui-arrow-right--white" type="button">Gå til denne tjenesten</button></li>
<li><button class="relax-button relax-button--small relax-button-link relax-icon-ui-arrow-right--white" type="button">Rapporter feilen her</button></li>
</ul>
</div>
</div>
A `relax-notification-hero` can only be used embedded in a `relax-tile`!
States
This is a notification of a successful action or event.
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
This is a notification with some information.
This is a notification of a failed action or event.
Warning, something happened, you need to pay attention
Something is in progress.
This is a general notification.
Notification states
<div class="relax-notification[--[general|error|success|info|warning|progress]]">
<div class="relax-notification-content">
<p>
This is a general notification.
</p>
</div>
</div>
Dismiss
A notification can be dismissed.
This is a notification of a successful action or event.
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
<div class="relax-notification relax-notification--general">
<div class="relax-notification-content">
<p>
This is a general notification.
</p>
</div>
<button type="button" class="relax-notification-close"><span class="relax-axe-sr-only">Close</span></button>
</div>
Anatomy
This is a notification of a successful action or event.
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Lorem ipsum dolor sit amet, consectetur adipiscing elit.
Endring av polisen feilet
Feilkode #632 Fikk ikke kontakt med server. Vennligst prøv igjen senere. Hvis problemet vedvarer..
Notification
Fill (State based)
Title (optional)
Message
Close (optional)
Toast
Fill (State based)
Title (optional)
Close (optional)
Notification hero
Fill (State based)
Title
Message
Actionable links (optional)
Specs
Notification
This is a general notification.
Notification toast
This is a general notification.
Notification hero
Endring av polisen feilet
Feilkode #632 Fikk ikke kontakt med server. Vennligst prøv igjen senere. Hvis problemet vedvarer..
Tooltips provide additional information upon hover or focus. They often contain helper text that is contextual to an element.
The tooltip or infotip or a hint is a common graphical user interface element. It is used in conjunction with a cursor, usually a pointer. The user hovers the pointer over an item, without clicking it, and a tooltip may appear—a small "hover box" with information about the item being hovered over. Tooltips do not usually appear on mobile operating systems, because there is no cursor (though tooltips may be displayed when using a mouse).
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/tooltip
Using styles
@import '@relax/tooltip';
Usage
Principles
If you have space, don't use tooltips or toggletips. Just provide clear labels and sufficient body text.
If it's a tooltip you are looking to use, decide whether the tip's content should be provided as the label or description and choose ARIA properties accordingly.
Don't rely on title attributes. They are not keyboard accessible and are not supported in many screen reader setups.
Don't describe toggletips with aria-describedby. It makes the subject button non-functional to screen reader users.
Don't put interactive content such as close and confirm buttons or links in tooltips or toggletips. This is the job of more complex menu and dialog components.
<input type="text" title="Your name"/>
Do not use a `title`-attribute to provide information for input fields
<label for="tooltip-example-input">
Your Name
</label>
<input type="text" id="tooltip-example-input"/>
Use an element that fits the component
Length
Due to its disruptive nature, Tooltip content should be kept to an absolute minimum. For larger sets of content or data, consider using a Passive Modal. The Modal will be triggered when the user clicks the information icon, as opposed to the regular :hoverinteraction of a generic Tooltip.
Interactive elements
The primary purpose of a Tooltip is to provide additional help or context to an item. Therefore, they should contain read-only text. The use of interactive elements, such as Buttons or Links, is discouraged.
Types
...is a common graphical user interface element.
In text
With icon buttons
The animation delay on tooltips in text, i.e. usage of abbr, is longer (0.8s) than the animation delay on other tooltip items (0.2s). This is done to ensure a better user experience.
To fully utilize the power of abbr, please use the JavaScript sequence below (in your preferred library/framework): (All it does is to remove the title-attribute from the element to prevent the default browser mechanism for abbr)
A card provide an at-a-glance preview of the content they link to and frequently contain easily consumable content. Use a card pattern when creating a collection of items, where each item surfaces a large amount of information in a similar schema.
A card may be as minimal as having a title with an icon and description to being more detailed to include a chart, live metrics, lists, tables or other data.
John Doe White
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/cards
Using styles
@import '@relax/cards';
Usage
Types
Card header
An empty card
Card header
An empty card
Card header
An empty card
Normal card
Normal card with arrow in header
Large card
Group of Cards
When displaying a group of cards, use ul[class="relax-cards"] with li[class="relax-card"]-items. This will ensure cards are equal height. Card groups automatically uses flex styles to match height between cards in the same row. This will also make the groups of cards more semantic and enhance assistive technology users' experience. Briefly:
Screen readers provide shortcuts to lists and between list items
Screen readers enumerate the items so users know how many are available
Header
Sub title
Pellentesque ac magna quis sapien egestas lobortis vel sit amet velit. Pellentesque at aliquam enim, sit amet auctor ligula. In placerat vitae lorem ut laoreet. Ut blandit efficitur augue at lacinia. Quisque pellentesque semper sapien ut varius. Quisque maximus consequat lacus, eu cursus diam porttitor eget. Nunc fermentum sem eu turpis ornare, a blandit leo gravida.
Header
Sub title
Pellentesque ac magna quis sapien egestas lobortis vel sit amet velit. Pellentesque at aliquam enim, sit amet auctor ligula. In placerat vitae lorem ut laoreet. Ut blandit efficitur augue at lacinia. Quisque pellentesque semper sapien ut varius. Quisque maximus consequat lacus, eu cursus diam porttitor eget. Nunc fermentum sem eu turpis ornare, a blandit leo gravida.
Header
Sub title
Pellentesque ac magna quis sapien egestas lobortis vel sit amet velit. Pellentesque at aliquam enim, sit amet auctor ligula. In placerat vitae lorem ut laoreet. Ut blandit efficitur augue at lacinia. Quisque pellentesque semper sapien ut varius. Quisque maximus consequat lacus, eu cursus diam porttitor eget. Nunc fermentum sem eu turpis ornare, a blandit leo gravida.
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
John Doe White
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
John Doe White
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
John Doe White
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
<div class="relax-card relax-card--centered">
<div class="relax-card-header">
John Doe <span class="relax-badge relax-badge-white relax-icon-ui-bandaid--blue">White</span>
</div>
<div class="relax-card-content" style="filter: blur(6px);">
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
</div>
</div>
Anatomy
A card can consist of a title, content and a footer.
Title
Titles describe the subject of the data on a Card. If you want an arrow in the card title, to indicate that this is a link, use .relax-card-header-a with the .relax-card-header class.
Content
The Card's content section lives just below the title, and can be used to provide additional information/content.
Use .relax-card-content for a plain box, .relax-card-table to place a table inside the card, and .relax-card-list for a list of items, links, etc.
Footer
The footer is commonly used for interactive elements, which can be any of the following: secondary buttons, links, and action icons. It can also contain additional informational content, such as plan name or app status.
John Doe White
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
A card is always coded semantically. You can use cards with: a, button and div-tags. Please see the source code.
Allthough we say you can use `a` and `button`-tags as card holders, are you sure you should?
When wrapping the card content with a `a` or `button`-tag, when screen readers read the element, the whole content is read.
It's not disastrous in terms of comprehension, but verbose — especially if the card evolves to contain more content — especially when it's interactive content. It's also quite unexpected to find a block element like an `h2` inside an inline element like an `a`, even though it's technically permissible in HTML5.
When using `button` or a clickable div (`div[role=link]` or `div[role=button]`), remember to add correct `aria-label`/`aria-labelledby`, `onclick`, `onkeydown` and `tabindex` attributes!
If you want the whole card to get interactive styling (clickable/focusable/hoverable) and you have not wrapped the content in a `a` or `button`-tag, you can add the `relax-interactive`-class to `relax-card`. This will ensure proper interactive styling.
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/list
Using styles
@import '@relax/list';
Usage
Length of lists
Generally, Lists should be used to present simple pieces of information. For more complex sets of data, consider using a Data Table.
Order
Arrange List items in a logical way. For example, if the List is about resource use, the default order might be highest resource use to lowest. Grouping items in categories into smaller, more specific lists might be more meaningful in some contexts. Alternatively, organize in alphabetical or numeric order.
Text
Use List items that are grammatically parallel. For example, do not mix passive voice with active voice or declarative sentences (statements) with imperative sentences (direct command).
For the .relax-list-link-items, you can use a <button> or a <a href="/">-tag.
Display actions as disabled when they can only be used sometimes, under certain conditions. They should be displayed as disabled rather than removing them.
Modals communicate information via a secondary window and allow the user to maintain the context of a particular task.
Title
Are you ready for this?
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/modal
Using styles
@import '@relax/modal';
Usage
Modals inform users about a specific task and may contain critical information, require decisions, or involve multiple tasks.
Modals contain text and UI controls. They retain focus until dismissed or a required action has been taken. Use dialogs sparingly because they are interruptive.
Modals should never be obscured, either by other elements or the screen edge. Modals always retain focus until dismissed or a required action has been taken.
Modals
Modals may be dismissed in 3 ways:
Using the “x” in the upper right-hand corner of the Modal
Pressing the ESC key
Clicking / touching outside of the Modal area
Dialogs
Dialogs can only be dismissed by taking one of the actions presented.
Types
Title
Are you ready for this?
Should we fire the laser?
Modal
Dialog
Should we fire the laser?
Do not present too many actions for the user in a dialog
Should we fire the laser?
Prefer as few actions as possible
Title
Should we fire the laser?
A dialog cannot be dismissed by pressing esc, clicking outside the dialog or by pressing "x"
Should we fire the laser?
A dialog can only be dissmissed by taking one of the actions presented
Anatomy
Header (optional)
Include a heading within the Modal that mirrors the action or button that was clicked by the user.
Body
The body content within a Modal should be as minimal as possible. Components that may be used in Modals include: Form fields, Text Area, Select, and Radio Buttons.
Footer
The footer area of a Modal typically contains a set of actions. Refer to Button guidelines for usage.
Pagination is used for splitting data, usually lists or tables, into several pages, with a control for navigating to the next or previous page.
Displaying page 4 of 12
This is
a
table
With
three
rows
With
three
rows
With
three
rows
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/pagination
Using styles
@import '@relax/pagination';
Usage
Generally, Pagination is used if there are more than 25 items displayed in one view. The default number displayed will vary depending on the context.
Identify the current page
Clearly identify which page the user is on by displaying the current page number. By providing context into how many pages there are in total (eg. 1 of 4 pages), you can help provide clarity around the data displayed.
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis bibendum massa. Aenean ultricies aliquet metus id accumsan. Nullam sed condimentum lectus, sed fermentum nunc
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/panel
Using styles
@import '@relax/panel';
Usage
Types
Basic panel example
You can also add .relax-no-padding to the .relax-panel-content-element to let the content flow with no gutter.
Basic panel example
Basic panel example
Basic panel example
Alle
This is some content
This is a panel
With some grid cells
As an example
This is some preview content
This is a panel item
This is a content preview
This is a panel title
This is some content
This is a panel title
This is some content
Panel link title
Panel link title
Expandable title
Content
Expandable title
Content
Expandable title
Content
Expandable title
Content
Basic panel
No padding
Border dashed
Border thick
Border thick dashed
Panel with filter
Panel with menu
Panel with preview
Panel with action
Panel with title
Panels as links
Expandable panels
Anatomy
Panel width
Base the width of your panel on the amount of content to be displayed. Perhaps your panel only needs to be 6, or 4 columns wide.
If you need some content associated with the panel, use a preview element. Add another .relax-panel-item below the main panel item with the .relax-is-preview class to it.
This is a panel item
This is a content preview
<div class="relax-panel">
<div class="relax-panel-item relax-panel-item--title">
<div class="relax-panel-content">
This is a panel item
</div>
</div>
<div class="relax-panel-item relax-is-preview">
<div class="relax-panel-content">
This is a content preview
</div>
</div>
</div>
Panel with title
If you need a title to your panels, add another .relax-panel-item, before the main panel item, with the .relax-panel-item--title class to it. Remember to add . class to the following div to fix border/border-radius issues.
This is a panel title
This is some content
<div class="relax-panel">
<div class="relax-panel-item relax-panel-item--title">
<div class="relax-panel-content">
This is a panel title
</div>
</div>
<div class="relax-panel-item">
<div class="relax-panel-content">
This is some content
</div>
</div>
</div>
Panel with title and button
If you need a button with your title, just add it!
Remember, only use ONE action in a panel header. The button should be a small button. The title on a panel should just be a title and an action if required.
This is a panel title
This is some content
<div class="relax-panel">
<div class="relax-panel-item relax-panel-item--title">
<div class="relax-panel-content">
This is a panel title
<button type="button" class="relax-panel-action relax-button relax-button--primary relax-button--small">
Action
</button>
</div>
</div>
<div class="relax-panel-item">
<div class="relax-panel-content">
This is some content
</div>
</div>
</div>
Panel with menu
Sometimes the amount of data and actions to be presented to the user is in abundance. In this scenario, you might want to combine the panel with an overflow menu
This is the title
This is a panel
With some grid cells
As an example
<div class="relax-panel">
<div class="relax-panel-item">
<div class="relax-panel-content">
<div class="relax-row">
<div class="relax-col">This is a panel</div>
<div class="relax-col">With some grid cells</div>
<div class="relax-col">As an example</div>
</div>
</div>
<button type="button" class="relax-panel-menuButton"></button>
</div>
</div>
Use tabs to alternate between views within the same context, not to navigate to different areas. Staying in place while alternating views is the reason we have tabs in the first place.
Logically chunk the content behind the tabs so users can easily predict what they'll find when they select a given tab.
Use tabs only when users don't need to see content from multiple tabs simultaneously.
Tabs should be parallel in nature. If the tabs are significantly dissimilar, users will interpret them as site navigation.
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam euismod, tortor nec pharetra ultricies, ante erat imperdiet velit, nec laoreet enim lacus a velit. Nam luctus, enim in interdum condimentum, nisl diam iaculis lorem, vel volutpat mi leo sit amet lectus. Praesent non odio bibendum magna bibendum accumsan.
Section 2
Nullam at diam nec arcu suscipit auctor non a erat. Sed et magna semper, eleifend magna non, facilisis nisl. Proin et est et lorem dictum finibus ut nec turpis. Aenean nisi tortor, euismod a mauris a, mattis scelerisque tortor. Sed dolor risus, varius a nibh id, condimentum lacinia est. In lacinia cursus odio a aliquam. Curabitur tortor magna, laoreet ut rhoncus at, sodales consequat tellus.
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/tabs
Using styles
@import '@relax/tabs';
Usage
When should we use tabbed interfaces?
When we have lengthy content with multiple headings, each heading can become a tab with its respective content as that tabpanel's content
When we have progression with multiple steps, and
When the next section only becomes available when the current section is "complete", or
When all sections are available at any given time
Types
Section 1
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam euismod, tortor nec pharetra ultricies, ante erat imperdiet velit, nec laoreet enim lacus a velit. Nam luctus, enim in interdum condimentum, nisl diam iaculis lorem, vel volutpat mi leo sit amet lectus. Praesent non odio bibendum magna bibendum accumsan.
Section 2
Nullam at diam nec arcu suscipit auctor non a erat. Sed et magna semper, eleifend magna non, facilisis nisl. Proin et est et lorem dictum finibus ut nec turpis. Aenean nisi tortor, euismod a mauris a, mattis scelerisque tortor. Sed dolor risus, varius a nibh id, condimentum lacinia est. In lacinia cursus odio a aliquam. Curabitur tortor magna, laoreet ut rhoncus at, sodales consequat tellus.
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam euismod, tortor nec pharetra ultricies, ante erat imperdiet velit, nec laoreet enim lacus a velit. Nam luctus, enim in interdum condimentum, nisl diam iaculis lorem, vel volutpat mi leo sit amet lectus. Praesent non odio bibendum magna bibendum accumsan.
Section 2
Nullam at diam nec arcu suscipit auctor non a erat. Sed et magna semper, eleifend magna non, facilisis nisl. Proin et est et lorem dictum finibus ut nec turpis. Aenean nisi tortor, euismod a mauris a, mattis scelerisque tortor. Sed dolor risus, varius a nibh id, condimentum lacinia est. In lacinia cursus odio a aliquam. Curabitur tortor magna, laoreet ut rhoncus at, sodales consequat tellus.
<div class="relax-tabs relax-tabs--fluid relax-tabs--large" style="max-width: 25rem; background-color: white;">
<section aria-labelledby="tab1" id="section1" role="tabpanel" class="relax-tab-panel">
<h2>Section 1</h2>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam euismod, tortor nec pharetra ultricies, ante erat imperdiet velit, nec laoreet enim lacus a velit. <a href="/">Nam luctus</a>, enim in interdum condimentum, nisl diam iaculis lorem, vel volutpat mi leo sit amet lectus. Praesent non odio bibendum magna bibendum accumsan.</p>
</section>
<section aria-labelledby="tab2" id="section2" role="tabpanel" class="relax-tab-panel relax-tab-panel--selected">
<h2>Section 2</h2>
<p>Nullam at diam nec arcu suscipit auctor non a erat. Sed et magna semper, eleifend magna non, facilisis nisl. Proin et est et lorem dictum finibus ut nec turpis. Aenean nisi tortor, euismod a mauris a, mattis scelerisque tortor. Sed dolor risus, varius a nibh id, condimentum lacinia est. In lacinia cursus odio a aliquam. Curabitur tortor magna, laoreet ut rhoncus at, sodales consequat tellus.</p>
</section>
<ul role="tablist">
<li role="presentation">
<a href="#section1" id="tab1" role="tab" class="relax-icon-ui-pencil--white">Section 1</a>
</li>
<li role="presentation">
<a aria-selected="true" href="#section2" id="tab2" role="tab" class="relax-icon-ui-menu--blue">Section 2</a>
</li>
</ul>
</div>
Specs
Default
Section 1
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam euismod, tortor nec pharetra ultricies, ante erat imperdiet velit, nec laoreet enim lacus a velit. Nam luctus, enim in interdum condimentum, nisl diam iaculis lorem, vel volutpat mi leo sit amet lectus. Praesent non odio bibendum magna bibendum accumsan.
Section 2
Nullam at diam nec arcu suscipit auctor non a erat. Sed et magna semper, eleifend magna non, facilisis nisl. Proin et est et lorem dictum finibus ut nec turpis. Aenean nisi tortor, euismod a mauris a, mattis scelerisque tortor. Sed dolor risus, varius a nibh id, condimentum lacinia est. In lacinia cursus odio a aliquam. Curabitur tortor magna, laoreet ut rhoncus at, sodales consequat tellus.
When the user starts to type, the list is updated with suggestions, an autocomplete, for the input. The user can choose to either search in the current customer context or in entire Waypoint. The user can select with arrow up or down.
Data tables present raw data sets and lend meaning to the data, while maintaining that the data is readable, scannable, and easily comparable.
Displaying page 4 of 12
Name
Age
Position
Office
Start date
Salary
John Wicker
38
Hitman
London
01.01.1971
833 000
John Wicker
38
Hitman
London
01.01.1971
833 000
John Wicker
38
Hitman
London
01.01.1971
833 000
John Wicker
38
Hitman
London
01.01.1971
833 000
John Wicker
38
Hitman
London
01.01.1971
833 000
Displaying page 4 of 12
Installation
If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/tables
Using styles
@import '@relax/tables';
Usage
Data tables display information in a way that’s easy to scan, so that users can look for patterns and insights. They can be embedded in primary content, such as cards.
Principles
Header row Use meaningful text to label the table data and provide clarity to the content below.
Number of columns For large sets of data, it is preferable to use rows instead of columns in order to guide the eye across the page. It is quicker and easier to scan down a single row rather than scan across multiple columns of related data.
Batch actions Batch actions are functions that may be performed on multiple items within a table. Use an Overflow Menu to present batch actions to the user. The Overflow Menu appears when the user clicks on the icon. If there is only one batch action available for the table data, that action should be styled as a Small Button and live outside of the Overflow menu.
Inline actions Inline actions are functions that may be performed on a specific table item. Each row is accompanied by an Overflow Menu that contains actions related specifically to that table row.
Expandable rows Expandable rows show minimal information at a high-level and a more detailed view nested within that row.
Display density
Use the classes .relax-table--dense or .relax-table--denser to make the table more dense.
Alternate colors on rows to increase readability. This also helps to guide the user through data in a table. Just add the class .relax-table--striped to your table.
All tables should by default be sortable. The sorting should occur when clicking on the header cell, and when the sorting is active, it should be indicated by an arrow. Caret up if it's ascending sort, caret down if the sort is descending. Clickable headers enable users to sort table data up or down.
Age
Color
Year
8
Black
2914
4
Blue
432
3
Brown
2019
<table class="relax-table" >
<thead>
<tr>
<th>
Can you sort me?
</th>
<th [class="relax-asc"]>
By color
</th>
<th [class="relax-desc"]>
or by smell?
</th>
</tr>
</thead>
<tbody>
<tr>...</tr>
</tbody>
</table>
Pellentesque quis sem quis dolor mattis blandit et id dolor. Morbi venenatis arcu ac nunc luctus iaculis quis nec enim. Phasellus at lectus ut lectus porta elementum. Vivamus consequat sagittis fermentum. Nam rutrum purus magna, elementum suscipit risus euismod sed. Donec commodo vitae lorem sit amet porta. Sed at laoreet libero, et sodales odio. Cras vitae convallis diam. Fusce ut mattis lacus, vitae feugiat libero. In feugiat velit sem, gravida hendrerit lorem viverra in. Aenean ut urna venenatis, tempus ante sed, ullamcorper arcu. Praesent finibus, quam sit amet dignissim mollis, lacus eros venenatis metus, et placerat nisl mi eu ligula.