Relax Design System

Introduction

Foundation

Patterns

In this section we will point out some patterns that are to be used with the RELAX Style Guide.

Hover effects

We distinguish the hover effects on the type of interaction the item hovered is supposed to have. If the item is clickable, the hover effect should be enticing and including. If the hovered item is just an item that you want to be in focus, distingquised and separate, the color should be bland, but noticable.

All clickable hover effects: $color-lightGrey-secondary: #D9D9D9 Hint of Mauve Pansy, all else uses a transparent version of $color-lightestBlue-primary: rgba( 167, 192, 242, 0.1) Sky High

Example

The middle row has a random :hover color
Not hovered
This row is not clickable
Not hovered
Do not use a random color for hovering non-clickable elements
The middle row has the correct :hover color, since the row is not clickable
Not hovered
This row is not clickable
Not hovered
Use rgba( 167, 192, 242, 0.1) for hovering non-clickable elements
Do not use a random color for hovering clickable elements
Use #D9D9D9 or #113EBAfor hovering clickable elements
Adresser
  • Adresse i bruk
    Something road 123
    123123 Something
    Sweden
Use #D9D9D9 or #113EBAfor hovering clickable elements

Data presentation

When you are presenting a large data set and you find yourself imitating a table, use a table. That's what it's for! Using div's to create tables is a malpractice and you will succomb to divitis and it is not semantic!

Selection controls

When to use which selection controls

Use radio buttons or checkboxes when..

  • There is no clear default or recommended options
  • You want user to read all options
  • The options are unfamiliar to user and there is less or no chance that the user can predict them
  • You have less then 5 options
  • Comparison of options needs to be clear
  • Visibility and quick response is a priority

Use select boxes or multi selects when..

  • Displaying all options will draw user's attention
  • It is not encouraged for users to change the default option
  • A large number of familiar options are available
  • You have more than 7 options

Use input field with autocomplete when..

  • You have more than 20 options

Content discovery vs Content browsing

Pagination

Pagination is good when the user is searching for something in particular within the list of results, not just scanning and consuming the flow of information.

When the users know the number of results available they are able to make a more informed decision, rather than be left to scour an infinitely scrolling list. According to the David Kieras research Psychology in Human-Computer Interaction: “Reaching an end point provides a sense of control”. The research also clarifies that when users have limited but still relevant results, they are able to determine easily if what they’re seeking is actually there or not.

Also when users see total number of results (of course when a total amount of data isn’t infinite) they will be able to estimate how much time it’ll take to find what they’re actually looking for.

Infinite scroll

The pattern infinite scroll should rarely or never be used to present data.

Load more

With the pattern load more, the user is not flooded with new data until the user explicitly asks for more data to consume. This pattern is also a better technical approach, because the data can be fetched in sets.

Implementation example
NameAgePositionOfficeStart dateSalary
John Wicker38HitmanLondon01.01.1971833 000
John Wicker38HitmanLondon01.01.1971833 000
NameAgePositionOfficeStart dateSalary
John Wicker38HitmanLondon01.01.1971833 000
John Wicker38HitmanLondon01.01.1971833 000
NameAgePositionOfficeStart dateSalary
John Wicker38HitmanLondon01.01.1971833 000
John Wicker38HitmanLondon01.01.1971833 000
John Wicker38HitmanLondon01.01.1971833 000
John Wicker38HitmanLondon01.01.1971833 000
John Wicker38HitmanLondon01.01.1971833 000
John Wicker38HitmanLondon01.01.1971833 000
John Wicker38HitmanLondon01.01.1971833 000

Semantic components

Time and date

The HTML

<p>
  The concert took place on <time datetime="2001-05-15T19:00">May 15</time>.
</p>

Adresses

The address element may be used to hold any contact information, including a physical address as well as a website or email address. It should not include any further information than the contact information, and other content needs to be placed outside of the address element.

<address>
  <strong>Shay Howe</strong> <br/>
  <a href="http://learn.shayhowe.com">http://learn.shayhowe.com</a> <br/>
  <a href="mailto:hello@awesome.com">hello@awesome.com</a> <br/>
  600 W. Chicago Ave. <br/>
  Suite 620 <br/>
  Chicago, IL 60654 <br/>
  USA
</address>

Navigation in Single Page Applications

For best accessibility practices, follow these simple rules:

  • A link (navigation) should look like a link and be coded like a link.
  • A button (action) should look like a button and be coded like a button.

However, there are of course, exceptions to the rule:

  • If you are using a <a>-tag for an action (as in submit form, even if it takes you to a new URL), change it to a <button>
  • If you are using a <button> to change URL (location), change it to a <a>.
    • However, if it is the action that is changing the URL, keep the <button>
    • If the URL is not reachable by direct linking/deep linking, keep the <button>

Read more about it here:

Navigation

Navigation in Single Page Applications

For best accessibility practices, follow these simple rules:

  • A link (navigation) should look like a link and be coded like a link.
  • A button (action) should look like a button and be coded like a button.

However, there are of course, exceptions to the rule:

  • If you are using a <a>-tag for an action (as in submit form, even if it takes you to a new URL), change it to a <button>
  • If you are using a <button> to change URL (location), change it to a <a>.
    • However, if it is the action that is changing the URL, keep the <button>
    • If the URL is not reachable by direct linking/deep linking, keep the <button>

Read more about it here:

Typography @relax/typography@8.16.11

Text is the primary way that users digest content and accomplish work, so it’s important to use good typographic principles to establish a clear visual hierarchy and to maximize legibility. Use typography to present your design and content as clearly and efficiently as possible.

The primary typeface for Relax is the typeface made for If, If Sans.

The typeface - If Sans - Plays a key role in If's visual identity. It encapsulates our "Simply Personal" concept. Simple, light and airy shapes for optimal on readability, With details inspired by calligraphy to add personality.

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/typography
Using styles
@import '@relax/typography';

Fonts

If Sans

If Sans and all of its siblings are the standard typefaces for Waypoint Applications.

If Sans is available in Thin, Light, Regular, Medium and Bold.

Thin, Light and Regular are used for large- and medium-size headlines and sub-headings to maintain our light and airy look and feel.

Medium and Bold are only used for small text sizes and to highlight key words in body copy.

An italic version is available in Thin Italic, Light Italic, Italic, Medium Italic and Bold Italic. These should be used to emphasize certain words or legal content. Never use italic in headlines or sub- headings. Ligatures are not available in italic.

If Sans should be used in most formats With the exception of digital platforms where it is only possible to use system fonts.

  1. ABCČĆDĐEFGHIJKLMNOPQRSŠTUVWXYZŽabcčćdđefghijklmnopqrsštuvwxyzžАБВГҐДЂЕЁЄЖЗЅИІЇЙЈКЛЉМНЊОПРСТЋУЎФХЦЧЏШЩЪЫЬЭЮЯабвгґдђеёєжзѕиіїйјклљмнњопрстћуўфхцчџшщъыьэюяΩμΏĂÂÊÔăâêô1234567890‘?’“!”(%)[#]{@}/&\<-+÷×=>®©$€£¥¢:;,.*
  2. ABCČĆDĐEFGHIJKLMNOPQRSŠTUVWXYZŽabcčćdđefghijklmnopqrsštuvwxyzžАБВГҐДЂЕЁЄЖЗЅИІЇЙЈКЛЉМНЊОПРСТЋУЎФХЦЧЏШЩЪЫЬЭЮЯабвгґдђеёєжзѕиіїйјклљмнњопрстћуўфхцчџшщъыьэюяΩμΏĂÂÊÔăâêô1234567890‘?’“!”(%)[#]{@}/&\<-+÷×=>®©$€£¥¢:;,.*
  1. If Sans Thin
  2. If Sans Medium Italic
  1. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  2. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  3. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  4. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  5. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  6. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  7. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  8. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  9. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  10. The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps over the lazy dog
  1. If Sans Light
  2. If Sans Light Italic
  3. If Sans
  4. If Sans Italic
  5. If Sans
  6. If Sans Italic
  7. If Sans Medium
  8. If Sans Medium Italic
  9. If Sans Bold
  10. If Sans Bold Italic

Barlow

Barlow is a slightly rounded, low-contrast, grotesk type family designed by Jeremy Tribby. Drawing from the visual style of the California public, Barlow shares qualities with the state's car plates, highway signs, busses, and trains.

  1. The quick brown fox jumps over the lazy dog
  2. The quick brown fox jumps over the lazy dog
  3. The quick brown fox jumps over the lazy dog
  4. The quick brown fox jumps over the lazy dog

Only one font size is displayed, since this is a scarcely used font

  1. Barlow Regular Light 22
  2. Barlow Regular 70
  3. Barlow Regular Semibold 116
  4. Barlow Regular Bold 188

Consuming the fonts

Download the correct font files and place them in the ./fonts directory relative to your raw file. You can use the build tool of your choice, i.e. webpack to help with aliases if you have placed the fonts elsewhere.

Usage

  1. If Sans Bold 24px / 1.5rem / 24pt

  2. If Sans Bold 18px / 1.125rem / 18dp

  3. If Sans Medium 16px / 1rem / 16dp
  4. If Sans 16px / 1rem / 16dp
  5. If Sans Bold 16px / 1rem / 16dp
  6. If Sans 14px / 0.875rem / 14dp
  7. 3 173
  8. 23 135
  9. 3
  10. 426 879

Headings

Use this heading only as h1 or .relax-heading-class at the top of pages to indicate the main subject matter of the page.

<h1>If Sans Bold 24px / 1.5rem / 24pt</h1>

Subheadings

Use this .relax-sub-heading-class to separate content by subject.

<h2 class="relax-sub-heading">If Sans Bold 18px / 1.125rem / 18dp</h2>

Labels and table headings

Use the class .relax-label-heading for labels for form elements and table headings.

<label class="relax-label-heading">If Sans Medium 16px / 1rem / 16dp</label>

Body text / data output text

Use the class .relax-text for body text and displaying output data.

<span class="relax-font-sansN4">If Sans 16px / 1rem / 16dp</span>
<span class="relax-font-sansN4">Line-height 140%</span>
<div class="relax-text">...</div>

Bold text

Use the <strong>-tag or the class .relax-font-sansN7 if bold text is needed.

<span class="relax-font-sansN7">If Sans Bold 16px / 1rem / 16dp</span><br/>
<strong>Bold text</strong>

Small text

Use the <small>-tag if when there is a need for small text, such as text in tooltip and captions for tables and images.

<small class="relax-font-sansN4">If Sans 14px / 0.875rem / 14dp</small><br/>
<small class="relax-font-sansN4">Line-height 120%</small>
<small>Small text</small>

Infographic headings

asd

Helpers

A set of helper classes for fonts

If Sans Thin
If Sans Thin Italic
If Sans Light
If Sans Light Italic
If Sans
If Sans Italic
If Sans Medium
If Sans Medium Italic
If Sans Bold
If Sans Bold Italic
Barlow Regular Light
Barlow Regular
Barlow Regular Semibold
Barlow Regular Bold
<span class="relax-font-sansN1">If Sans Thin</span>
<span class="relax-font-sansI3">If Sans Thin Italic</span>
<span class="relax-font-sansN1">If Sans Light</span>
<span class="relax-font-sansI3">If Sans Light Italic</span>
<span class="relax-font-sansN4">If Sans</span>
<span class="relax-font-sansI4">If Sans Italic</span>
<span class="relax-font-sansN5">If Sans Medium</span>
<span class="relax-font-sansI5">If Sans Medium Italic</span>
<span class="relax-font-sansN7">If Sans Bold</span>
<span class="relax-font-sansI7">If Sans Bold Italic</span>
<span class="relax-font-infoN1">Barlow Regular Light</span>
<span class="relax-font-infoN">Barlow Regular</span>
<span class="relax-font-infoN2">Barlow Regular Semibold</span>
<span class="relax-font-infoN3">Barlow Regular Bold</span>

Iconography @relax/icons@8.16.11

Our icons are carefully designed to be as simple as possible, in a minimalistic style without unnecessary details. They serve a purely functional purpose and assist With clear and direct navigation.

The icons are based on Nucleo, a third-party library of symbols for iOS, Android and web projects. By adding a set of customized icons specially designed for If, we created a generic yet personal icon library.

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/icons
Using styles
@import '@relax/icons';

Usage

Icons help the user find a desired action or piece of information relevant to their task. Icons can be used to mark a type of notification, status or validation, an action link or button, a type of insurance or sometimes (but rarely) an action button.

The icon should speak for itself and the user should understand what the icon means without reading the supporting text. Icons help the user scan to the correct action without reading text.

Do not use icons just for the sake of using an icon, or for decoration. We don't want to clutter the user interface with anything that is not absolutely necessary or beneficial to the user.

Categories

  1. Main icons
  2. UI icons
  3. Customer states icons
  4. Product icons

All of the icons can be used as background icons, providing the following syntax is used:

<button type="button" class="relax-button relax-icon-[ui|main|producs]-<Icon Name>[--white|grey|blue]">Check coverage</button>

You are also required to fit the icon in the component. This is how we do it with buttons:

.relax-button[class*='relax-icon-'] {
  position: relative;
  background-position: 1rem center;
  background-size: 1.5rem;
  padding-left: 3rem;
}

Example usage

  1. Notification of a successful action or event.

    Notification with some information.
    Notification of a failed action or event.
    Something is in progress.
  1. In buttons
  2. Icon only buttons
  3. Notifications

Colors

We provide four colors for our icons, when used as background images:

  1. Mine shaft, #333333, .relax-icon-ui-trashcan
  2. Curious Blue, #1a8dcc, .relax-icon-ui-trashcan--white
  3. White solid, #FFFFFF, .relax-icon-ui-trashcan--blue
  4. Tin Soldier, #d9d9d9, .relax-icon-ui-trashcan--grey

Accessibility

Modern versions of assistive technologies will announce CSS generated content, as well as specific Unicode characters. To avoid unintended and confusing output in screen readers (particularly when icons are used purely for decoration), we hide them with the aria-hidden="true" attribute.

If you're creating controls with no other text (such as a <button> that only contains an icon), you should always provide alternative content to identify the purpose of the control, so that it will make sense to users of assistive technologies. In this case, you could add an aria-label attribute on the control itself.

Main icons

filled-rip
filled-settings
line-business-daughter
line-business-division
line-business
line-calendar
line-close
line-coinstacks
line-communication
line-damage
line-dude
line-help
line-inbox
line-insurance
line-links
line-megafone
line-menulist
line-notified
line-paper
line-parrot
line-pay
line-phone-incoming
line-phone-outgoing
line-rip
RLX-icon-line-seacreature
line-seacreature
line-search
line-settings
line-tasks
line-wp-logo

UI icons

add notificationadd notification
add-notification
a adda add
add-user
alarmalarm
alarm
arrow downarrow down
arrow-down
arrow leftarrow left
arrow-left
arrow rightarrow right
arrow-right
arrow uparrow up
arrow-up
attachattach
attach
back arrowback arrow
back-arrow
billbill
bill
agenda bookmarkagenda bookmark
bookmark
energyenergy
bug
bulb-on
camera 3camera 3
camera
credit cardcredit card
card
cart returncart return
cart-return
chart bar 33chart bar 33
chart-bar
b chatb chat
chat
manga 62manga 62
chatbot
checkcheck
check
chequecheque
cheque
down arrowdown arrow
chevron-down
left arrowleft arrow
chevron-left
right arrowright arrow
chevron-right
up arrowup arrow
chevron-up
time clocktime clock
clock
e removee remove
close
cockadecockade
cockade
settings gearsettings gear
cog
coinscoins
coins
officeoffice
company
corner left roundcorner left round
corner-left-round
curve directionscurve directions
curve-directions
data downloaddata download
data-download
data uploaddata upload
data-upload
calendarcalendar
date
deductibledeductible
deductible
d editd edit
direct-edit
doctordoctor
doctor
documentdocument
document
small downsmall down
drop-down
small leftsmall left
drop-left
small rightsmall right
drop-right
small upsmall up
drop-up
dropdrop
drop
editedit
edit
energyenergy
energy
factoryfactory
factory
file download 89file download 89
file-download
fingerprint
flag points 32flag points 32
flag
fullscreenfullscreen
fullscreen
globeglobe
globe
handshake 2handshake 2
handshake
headphones micheadphones mic
headphones-mic
a hearta heart
heart-person
c questionc question
help
hourglasshourglass
hourglass
househouse
house
imgimg
img
incomming call 2incomming call 2
incomming-call
c infoc info
info
interest 2interest 2
interest
invertinvert
invert
knight
leaveleave
leave
linklink
link
bullet list 69bullet list 69
list
unlockedunlocked
lock-open
locklock
lock
log inlog in
log-in
log outlog out
log-out
loop 30loop 30
loop
b loveb love
love
mailmail
mail
man 20man 20
man-symbol
man 23man 23
man
map pinmap pin
map-pin
pin 3pin 3
marker
mathmath
math
megaphonemegaphone
megaphone
menu 8menu 8
menu
microsoftmicrosoft
microsoft
e deletee delete
minus
mobile chatmobile chat
mobile-chat
menu 5menu 5
more-horizontal
more-vertical
path unitepath unite
open-in-new
outgoing call 2outgoing call 2
outgoing-call
parentparent
parent
penpen
pencil
multiple 11multiple 11
people
single 01single 01
person
pin 4pin 4
pin
e adde add
plus
b previewb preview
preview-off
previewpreview
preview
printerprinter
printer
real estatereal estate
real-estate
cheque 3cheque 3
receipt
reciperecipe
recipe
redoredo
redo
reloadreload
refresh
replacereplace
replace
report claimreport claim
report-claim
resend 2resend 2
resend
responsiveresponsive
responsive
return policy B 2return policy B 2
return-policy
zoomzoom
search
secure messagesecure message
secure-message
securitysecurity
security
send messagesend message
send-message
shareshare
share
shopping cartshopping cart
shopping-cart
signature
single bodysingle body
single-body
single copy 04single copy 04
single-copy
single foldedsingle folded
single-folded
soundsound
sound
stackstack
stack
star-filled
shape starshape star
star
tasks
binbin
trashcan
trophytrophy
trophy
volume mutevolume mute
volume-mute
c warningc warning
warning-light
t warningt warning
warning
woman 21woman 21
woman-symbol
woman 24woman 24
woman
wrench toolwrench tool
wrench-tool

Products icons

aiai
ai
antique carantique car
antique-car
apartment
assistanceassistance
assistance
atvatv
atv
bagbag
bag
bikebike
bike
boat small 02boat small 02
boat
bodyshop
building
bulldozer
bus
camera flash 2camera flash 2
camera-flash
campercamper
camper
car 2car 2
car
caravancaravan
caravan
catcat
cat
cement-truck
childchild
child
cloud lightcloud light
cloud-light
heavy truckheavy truck
collection-truck
company-daughter
company-division
officeoffice
company
cottagecottage
cottage
deathdeath
death
diamonddiamond
diamond
dogdog
dog
favoritefavorite
favorite
floodingflooding
flooding
forest
forkliftforklift
forklift
furnished propertyfurnished property
furnished-property
glasses 2glasses 2
glasses
globe 2globe 2
globe
handouthandout
handout
heartbeatheartbeat
health
home 3home 3
home
horsehorse
horse
l securityl security
it-security
laptop 1laptop 1
laptop
heavy truckheavy truck
large-truck
liabilityliability
liability
pin 3pin 3
location
marine cargomarine cargo
marine-cargo
motorbikemotorbike
mc
minicar
moped-car
moped-eu
vespavespa
moped
patch 34patch 34
patch
pawpaw
paw
plane
pregnancypregnancy
pregnancy
boatboat
ship
small-boat
phone camera frontphone camera front
smartphone
snowmobilesnowmobile
snowmobile
stock 2stock 2
stock
strikestrike
strike
tablet 2tablet 2
tablet
theft burglary_Atheft burglary_A
theft-burglary
tractortractor
tractor
trailertrailer
trailer
light trucklight truck
truck
vanvan
van
vehiclesvehicles
vehicles
watch 2watch 2
watch
water damagewater damage
water-damage

Logo icons

if
new-wp
wp

Color @relax/color@8.16.11

The Design System for Waypoint, Relax is designed with ease and usability in mind, therefore the colors have been chosen to be easy on the eye, as well as easy to tell them apart. The usage of colors with Relax, Design System for Waypoint should be playfully unexpected.

The color palette concists of grouped colors; primary, secondary and support colors.

Conveying meaning to assistive technologies

Using color to add meaning only provides a visual indication, which will not be conveyed to users of assistive technologies – such as screen readers. Ensure that information denoted by the color is either obvious from the content itself (e.g. the visible text), or is included through alternative means, such as additional text hidden with the .sr-only class.

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/color
Using styles
@import '@relax/color';

Themes

Themes let you apply a consistent tone to an app. The theme specifies the darkness of the surfaces, level of shadow, and appropriate opacity of elements. To promote greater consistency between apps, light and dark themes are available to choose from.

Primary

Primary colors..

#0F2A6E Dark sapphire rgb(15, 42, 110) Darkest blue
#143694 North star blue rgb(20, 54, 148) Darker blue
#113EBA Persian blue rgb(17, 62, 186) Dark blue
#0054f0 Megaman helmet rgb(0, 84, 240) Blue
#4271D9 Andrea blue rgb(66, 113, 217) Light blue
#5585E6 Blue jay rgb(85, 133, 230) Lighter blue
#A7C0F2 Sky high rgb(167, 192, 242) Lightest blue
#141c2c Sambucus rgb(20, 28, 44) Darker slate
#192130 Dark rgb(25, 33, 48) Dark slate
#252D3C Navy blazer rgb(37, 45, 60) Slate
#333A48 Blue nights rgb(51, 58, 72) Light slate
#585E6A Evening east rgb(88, 94, 106) Lightest slate
<div class="relax-color relax-color-primary relax-color-[darkerSlate|darkSlate|slate|lightSlate|lightestSlate|darkestBlue|darkerBlue|darkBlue|blue|lightBlue|lighterBlue|lightestBlue]"></div>

Secondary

Secondary colors..

#332A26 Betel nut dye rgb(51, 42, 38) Darkest brown
#6E645A Ploughed earth rgb(110, 100, 90) Darker brown
#8f8377 Fungi rgb(143, 131, 119) Dark brown
#B0A298 Natural stone rgb(176, 162, 152) Brown
#D5C4B7 New wool rgb(213, 196, 183) Light brown
#ddd0c5 Pearl bush rgb(221, 208, 197) Lighter brown
#ebe3dc Fuzzy unicorn rgb(235, 227, 220) Lightest brown
#f1ece8 Valhallan blizzard rgb(241, 236, 232) Light beige
#f6f3f0 The speed of light rgb(246, 243, 240) Lighter beige
#faf9f7 Doctor rgb(250, 249, 247) Lightest beige
#333333 Carbon rgb(51, 51, 51) Darker grey
#5c5c5c Knights armor rgb(92, 92, 92) Dark grey
#BEBEBE Tin soldier rgb(190, 190, 190) Grey
#D9D9D9 Hint of mauve pansy rgb(217, 217, 217) Light grey
#F4F4F4 Lighthouse rgb(244, 244, 244) Lighter grey
#FFFFFF White rgb(255, 255, 255) White
<div class="relax-color relax-color-secondary relax-color-[darkGrey|grey|lightGrey|lighterGrey|white|darkBrown|brown|lightBrown]"></div>

Support

Support colors...

#CA3C3E Heart throb rgb(202, 60, 62) Dark red
#F2B87A Rosy skin rgb(242, 184, 122) Dark yellow
#699C55 Astro turf rgb(105, 156, 85) Dark green
#76BBB2 Polished aqua rgb(118, 187, 178) Dark turqois
#68AAC8 Delicate girl blue rgb(104, 170, 200) Blue
#8C3980 Dahlia rgb(140, 57, 128) Purple
#F16C8F Cupids arrow rgb(241, 108, 143) Pink
#F06064 Dubarry rgb(240, 96, 100) Red
#FFF09E Sun surprise rgb(255, 240, 158) Yellow
#91D169 Bright lettuce rgb(145, 209, 105) Green
#D0E6C3 Sweet spring rgb(208, 230, 195) Turqois
#BADDE7 Alpine alabaster rgb(186, 221, 231) Light blue
#C790C1 Pomtini rgb(199, 144, 193) Light purple
#F8C6C9 Sunday best rgb(248, 198, 201) Light pink
<div class="relax-color relax-color-support relax-color-[darkRed|red|darkYellow|yellow|darkGreen|green|darkTurqois|turqois|blue|lightBlue|purple|lightPurple|pink|lightPunk]"></div>

Usage

<div class="relax-color relax-color-secondary relax-color-brown"></div>

Grid @relax/grid@8.16.11

RELAX includes a responsive, mobile first fluid grid system that appropriately scales up to 12 columns as the device or viewport size increases. The grid comes with multiple tiers, one tier for each breakpoint (media query range).

The RELAX grid is inspired by the v4 grid from Twitter Boostrap: https://v4-alpha.getbootstrap.com/layout/grid/.

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/grid
Using styles
@import '@relax/grid';

How it works

.relax-col-4--xs
.relax-col-4--xs
.relax-col-4--xs
.relax-col
.relax-col
.relax-col
.relax-col
.relax-col
.relax-col-6--xs
.relax-col
.relax-col-1--xs
.relax-col-3--xs
<div class="relax-grid [--fluid]">
  <div class="relax-row">
    <div class="relax-col-[1-12]--[xs|md|lg|xl]">..</div>
  </div>
</div>

Grid options

Responsive UI

Responsive layouts in RELAX should adapt to any possible screen size. This UI guidance includes a flexible grid that ensures consistency across layouts and breakpoint details about how content reflows on different screens.

Breakpoints

For optimal user experience, Waypoint user interfaces should adapt layouts for the following breakpoint widths: 480, 720, 960, 1440, and 1920px.

Extra small
≥30rem / 480px
Small
≥45rem / 720px
Medium
≥60rem / 960px
Large
≥90rem / 1440px
Extra large
≥120rem / 1920px
Grid behaviorHorizontal at all timesCollapsed to start, horizontal above breakpoints
Class prefix.relax-col--xs.relax-col--sm-.relax-col--md-.relax-col--lg-.relax-col--xl-
# of columns12
Gutter width1.5rem (0.75rem on each side of a column)
NestableYes
OffsetsYes

Max width

If the .relax-grid--fluid-class is omitted, the grid comes with these max-widths:

.relax-grid {
  max-width: 100%;
  width: 100%;
}
@media screen and (min-width: 45rem) {
  .relax-grid {
    width: 100%;
    max-width: 100%;
  }
}
@media screen and (min-width: 60rem) {
  .relax-grid {
    width: 90%;
    max-width: 71.25rem;
  }
}

Auto-layout columns

Utilize breakpoint-specific column classes for equal-width columns. Add any number of unit-less classes for each breakpoint you need and every column will be the same width.

Equal-width

For example, here are two grid layouts that apply to every device and viewport, from xs to xl.

1 of 2
1 of 2
1 of 3
1 of 3
1 of 3
<div class="relax-grid">
  <div class="relax-row">
    <div class="relax-col">
      1 of 2
    </div>
    <div class="relax-col">
      1 of 2
    </div>
  </div>
  <div class="relax-row">
    <div class="relax-col">
      1 of 3
    </div>
    <div class="relax-col">
      1 of 3
    </div>
    <div class="relax-col">
      1 of 3
    </div>
  </div>
</div>
Setting one column width

Auto-layout for flexbox grid columns also means you can set the width of one column and the others will automatically resize around it. You may use predefined grid classes (as shown below), grid mixins, or inline widths. Note that the other columns will resize no matter the width of the center column.

1 of 3
2 of 3 (wider)
3 of 3
1 of 3
2 of 3 (wider)
3 of 3
<div class="relax-grid">
  <div class="relax-row">
    <div class="relax-col">
      1 of 3
    </div>
    <div class="relax-col-5--xs">
      2 of 3 (wider)
    </div>
    <div class="relax-col">
      3 of 3
    </div>
  </div>
  <div class="relax-row">
    <div class="relax-col">
      1 of 3
    </div>
    <div class="relax-col-8--xs">
      2 of 3 (wider)
    </div>
    <div class="relax-col">
      3 of 3
    </div>
  </div>
</div>
Column-less grid

If the need for a column-less grid arise, for example, if you want to put fixed width components into a grid, you can use the .relax-col-wrap class. To add alignment, use it with .relax-col-justifyCenter, .relax-col-justifyStart or .relax-col-justifyEnd.

Columnless
Grid
Columnless
Grid
Columnless
Grid
Columnless
Grid
<div class="relax-grid">
  <div class="relax-row">
    <div class="relax-col-wrap [relax-col-justifyCenter|relax-col-justifyStart|relax-col-justifyEnd]">
      Columnless Grid!
    </div>
  </div>
</div>
Variable width content

Using the relax-col-auto--{breakpoint} classes, columns can size itself based on the natural width of its content. This is super handy with single line content like inputs, numbers, etc. This, in conjunction with horizontal alignment classes, is very useful for centering layouts with uneven column sizes as viewport width changes.

1 of 3
Variable width content
3 of 3
1 of 3
Variable width content
3 of 3
<div class="relax-grid">
  <div class="relax-row">
    <div class="relax-col-3--xs">
      1 of 3
    </div>
    <div class="relax-col-auto--md">
       Variable width content
    </div>
    <div class="relax-col-3--xs">
      3 of 3
    </div>
  </div>
  <div class="relax-row">
    <div class="relax-col-4--xs">
      1 of 3
    </div>
    <div class="relax-col-auto--md">
      Variable width content
    </div>
    <div class="relax-col">
      3 of 3
    </div>
  </div>
</div>

Reordering

Offsetting columns

Move columns to the right using .relax-col-offset-*--md classes. These classes increase the left margin of a column by * columns. For example, .relax-col-offset-4--md moves .relax-col-4--md over four columns.

.relax-col-5--xs
.relax-col-5--xs
.relax-col-5--xs
.relax-col-4--md
.relax-col-4--md .relax-col-offset-4--md
.relax-col-3--md .relax-col-offset-3--md
.relax-col-3--md .relax-col-offset-3--md
.relax-col-6--md .relax-col-offset-3--md
.relax-col-offset-3--xs .relax-col-offset-5--md .relax-col-7--xs .relax-col-5--md
.relax-col-2--xs
.relax-col-offset-8--xs .relax-col-offset-4--md .relax-col-offset-3--lg .relax-col-2--xs .relax-col-4--md .relax-col-5--lg
.relax-col-2--xs .relax-col-4--md .relax-col-4--md
<div class="relax-row">
  <div class="relax-col-4--md">.relax-col-4--md</div>
  <div class="relax-col-4--md relax-col-offset-4--md">.relax-col-4--md .relax-col-offset-4--md</div>
</div>
<div class="relax-row">
  <div class="relax-col-3--md relax-col-offset-3--md">.relax-col-3--md .relax-col-offset-3--md</div>
  <div class="relax-col-3--md relax-col-offset-3--md">.relax-col-3--md .relax-col-offset-3--md</div>
</div>
<div class="relax-row">
  <div class="relax-col-6--md relax-col-offset-3--md">.relax-col-6--md .relax-col-offset-3--md</div>
</div>
Push and pull

Easily change the order of our built-in grid columns with .relax-col-push-*--md and .relax-col-pull-*--md modifier classes.

.relax-col-9--md .relax-col-push-3--md
.relax-col-3--md .relax-col-pull-9--md
<div class="relax-row">
  <div class="relax-col-9--md relax-col-push-3--md">.relax-col-9--md .relax-col-push-3--md</div>
  <div class="relax-col-3--md relax-col-pull-9--md">.relax-col-3--md .relax-col-pull-9--md</div>
</div>

Mesh @relax/mesh@8.16.11

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/mesh
Using styles
@import '@relax/mesh';

Usage

Narrow

A mesh can be narrow with .relax-mesh.relax-narrow

Fixed grid

A fixed grid is a mesh where the columns and rows strictly follows 18rem x 18rem grid

A mesh can be fixed with .relax-mesh.relax-fixed-grid

Narrow + Fixed grid

A mesh can be fixed and narrow with .relax-mesh.relax-narrow.relax-fixed-grid

Levels

Title
Title
Title
Title
Title
Title
Title
Title
Title
Meshes can be set in levels

Tile

Title
Title
Title
Tiles stack equally
Title
Title
Tiles can span several columns
Title
Title
Title
Title
Title
Tiles can span several rows
Title
Title
Title
Tiles can span columns and rows
Title
Title
Title
Title
Title
Title
Tiles can have a set of colors
Title
Adresser
  • Adresse i bruk
    Something road 123
    123123 Something
    Sweden
  • Adresse i bruk
    Something road 123
    123123 Something
    Sweden
Title

Tiles can have embedded content.

Title
Title
Title
Display help texts
Title

Tile can have different controls.

Importance

Title
Title
Title
Title
Title
Title
Title
Title
Title
Tiles can have different priorities.
<div class="relax-main">
  <div class="relax-mesh">
    <div class="relax-tile">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Tile menu</span>
      </button>
    </div>
    <div class="relax-tile relax-low">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Tile menu</span>
      </button>
    </div>
    <div class="relax-tile relax-normal">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Tile menu</span>
      </button>
    </div>
    <div class="relax-tile relax-low">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Tile menu</span>
      </button>
    </div>
    <div class="relax-tile relax-important">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Tile menu</span>
      </button>
    </div>
    <div class="relax-tile">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Tile menu</span>
      </button>
    </div>
    <div class="relax-tile relax-important">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Tile menu</span>
      </button>
    </div>
    <div class="relax-tile relax-normal">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Tile menu</span>
      </button>
    </div>
    <div class="relax-tile relax-low">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Tile menu</span>
      </button>
    </div>
  </div>
</div>
Hero

Company AS

Title
Title
A hero tile is a big tile, normally used as a page masthead. A page can have 1 hero tile.
Usage

Fixed grid

A fixed grid is a mesh where the columns and rows strictly follows 18rem x 18rem grid

Title Subtitle

A hero tile can have a subtitle.

  1. Title

  2. Title

  3. Title

  4. Title

  1. Company icon a.relax-company, span.relax-company
  2. Person icon a.relax-person, span.relax-person
  3. Division icon a.relax-division, span.relax-division
  4. Daughter icon a.relax-daughter, span.relax-daughter
Anatomy

asd

Anatomy

  1. Title
  2. Title
    Title
  3. Title
  4. Title
    Title
    Title
  5. Title
    Title
    Title
    Display help texts
    Title
  1. Default min-height
  2. Default
    1. Title (optional)
    2. Vertical menu (optional)
    3. Menu scales and is emphasized on hover
  3. Embedded content
    1. No padding, title or menu
  4. Embedded content
    1. Full width
  5. Different controls
    1. Action buttons, always placed at the bottom. If the form/tile is large, consider using them on top aswell
    2. Tabs
    3. Filtering/Search
    4. Toggle control
    5. Menu

Title

The title should reflect the content and be as short and concise as possible. Do not use long sentences. The content inside the box should be easily identifiable enough.

Menu

If there are any actions related to the content, or the box itself, the actions should reside in the menu.

Embedded content

You can put embedded content inside the boxes with this syntax:

<div class="relax-tile relax-embed"></div>

Implementation

<div class="relax-main">
  <div class="relax-mesh">
    <div class="relax-tile relax-row-2 relax-col-2">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Box menu</span>
      </button>
    </div>
    <div class="relax-tile">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Box menu</span>
      </button>
    </div>
    <div class="relax-tile">
      <span class="relax-tile-title">Title</span>
      <button class="relax-tile-menu" type="button">
        <span class="relax-axe-sr-only">Box menu</span>
      </button>
    </div>
  </div>
</div>
Hero implementation
<div class="relax-main">
  <div class="relax-mesh relax-level-1">
    <div class="relax-tile relax-hero">
      <h1 class="relax-tile-title"><a href="/">Title</a> <span class="relax-tile-subtitle">Subtitle</span></h1>
      <button class="relax-tile-menu" type="button"><span class="relax-axe-sr-only">Tile menu</span></button>
    </div>
  </div>
</div>

Util @relax/util@8.16.11

The util section contains usefull helper classes.

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/util
Using styles
@import '@relax/util';

Spacing

To set some standard spacing, we provide some classes for this usage.

<div class="relax-margin-(bottom|top)[--[largest|larger|large|small|smaller|smallest]]">...</div>
<div class="relax-padding-(bottom|top)[--[largest|larger|large|small|smaller|smallest]]">...</div>
Usage with grid rows
A row with margin bottom
A row without margin bottom
A row without margin bottom
<div class="relax-row relax-margin-bottom--largest">
  <div class="relax-col-12--xs">A row with margin bottom</div>
</div>
<div class="relax-row">
  <div class="relax-col-12--xs">A row without margin bottom</div>
</div>
<div class="relax-row">
  <div class="relax-col-12--xs">A row without margin bottom</div>
</div>

Overflow text

To add an ellipsis to a text for it to not overflow, use the class relax-overflow-text

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum
<div class="relax-row">
  <div class="relax-grid-col-1--xs" style="max-width: 10rem;">
    <span class="relax-overflow-text">
      Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum
    </span>
  </div>
</div>

Text align

  1. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque convallis, leo nec porta placerat, leo ligula tempor nibh, id auctor nunc purus aliquam nulla. Integer commodo, nisi eu eleifend viverra, mauris quam ultricies leo, vel lacinia ipsum tortor ac metus. Duis bibendum mollis mollis. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Cras fermentum ante elit, eu dictum massa tristique non. Cras nec dolor et leo lacinia cursus id accumsan lorem. Aenean non metus magna. Quisque iaculis gravida tellus et laoreet. In hac habitasse platea dictumst. Vivamus vel nunc a tellus vestibulum semper. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec sollicitudin lacinia ipsum, quis egestas augue feugiat id. Donec et vulputate neque. Donec dapibus metus ut blandit feugiat.
  2. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque convallis, leo nec porta placerat, leo ligula tempor nibh, id auctor nunc purus aliquam nulla. Integer commodo, nisi eu eleifend viverra, mauris quam ultricies leo, vel lacinia ipsum tortor ac metus. Duis bibendum mollis mollis. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Cras fermentum ante elit, eu dictum massa tristique non. Cras nec dolor et leo lacinia cursus id accumsan lorem. Aenean non metus magna. Quisque iaculis gravida tellus et laoreet. In hac habitasse platea dictumst. Vivamus vel nunc a tellus vestibulum semper. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec sollicitudin lacinia ipsum, quis egestas augue feugiat id. Donec et vulputate neque. Donec dapibus metus ut blandit feugiat.
  3. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque convallis, leo nec porta placerat, leo ligula tempor nibh, id auctor nunc purus aliquam nulla. Integer commodo, nisi eu eleifend viverra, mauris quam ultricies leo, vel lacinia ipsum tortor ac metus. Duis bibendum mollis mollis. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Cras fermentum ante elit, eu dictum massa tristique non. Cras nec dolor et leo lacinia cursus id accumsan lorem. Aenean non metus magna. Quisque iaculis gravida tellus et laoreet. In hac habitasse platea dictumst. Vivamus vel nunc a tellus vestibulum semper. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec sollicitudin lacinia ipsum, quis egestas augue feugiat id. Donec et vulputate neque. Donec dapibus metus ut blandit feugiat.
  1. Left aligned
  2. Center aligned
  3. Right aligned
<h5 class="relax-u-alignLeft">This should be left aligned</h5>
<h5 class="relax-u-alignRight">This should be right aligned</h5>
<h5 class="relax-u-alignCenter">This should be center aligned</h5>

Hidden

We provide easy to use classes to hide content on specific breakpoints.

Usage

  1. This is hidden from xs-breakpoint and up
  2. This is hidden from sm-breakpoint and up
  3. This is hidden from md-breakpoint and up
  4. This is hidden from lg-breakpoint and up
  5. This is hidden from xl-breakpoint and up
  6. This is hidden from xs-breakpoint and down
  7. This is hidden from sm-breakpoint and down
  8. This is hidden from md-breakpoint and down
  9. This is hidden from lg-breakpoint and down
  10. This is hidden from xl-breakpoint and down

Implementation

<span class="relax-hidden-down--[xs|sm|md|lg|xl]">This is hidden from given breakpoint and down</span>
<span class="relax-hidden-up--[xs|sm|md|lg|xl]">This is hidden from given breakpoint and up</span>

Guidelines

Usability

Accessibility

The Design System for Waypoint, Relax provides accessible markup which will serve as a foundation for your application development. In order to make sure you build accessible components, however, you will need to follow the accessibility guidance for our interactive components. This includes keyboard behavior as well as the management of ARIA roles and properties.

What is Accessibility?

Web accessibility ensures that people with disabilities can perceive, understand, navigate, interact with, and contribute to the applications you create. This means that pages are Perceivable, Operable, Understandable and Robust. This includes providing keyboard interaction alternatives for all mouse-based actions, properly identifying all form fields and buttons, providing text based alternatives for all images, videos, icons and SVGs, as well as building components that properly convey their identity, operation model, and state to assistive technologies.

The style guide enables accessible development by providing a set of semantically correct components, each with appropriate ARIA markup so they can be identified correctly to users of assistive technologies.

Standards Compliant Markup

The semantic markup and use of ARIA roles in our components are based on W3C standards and industry best practices. This markup is the perfect starting point for building accessible components.

Keyboard Navigation

While we do not provide the JavaScript that is necessary to make our components interactive, we offer advice on how to use scripting languages to create keyboard-accessible components.

Appropriate use of color

Our components aspire to follow the two main rules of accessibility as it relates to color:

  • We never use color as the only means of providing information or requesting an action.
  • The combinations of text and their background colors do not fall below the WCAG recommended threshold ratio of 4.5:1 for standard or small text and 3:1 for larger text.

Accessible Forms

Our forms offer proper use of <fieldset> and <legend> tags as well as appropriate labeling for input controls. Our radio button and checkbox controls provide a balanced solution that offers accessibility as well as design flexibility.

Images and icons

We provide a means of offering text-based alternatives for all images, icons and SVGs.

Component Identity

Our interactive components are created in accordance with the latest ARIA Authoring Practices, with attributes that are understandable by screen reader users on key page elements. It is important to note that as a component is interacted with, the ARIA attributes may need updating to reflect the new state. Hence, we provided detailed guidance on how and when to do this.

Validating your applications

The style guide is only the foundation for accessible application development. We recommend that you review the accessibility of your applications before release and ensure that it meets the WCAG Standard at the AA Level.

Resources for accessibility

Blue light filtering

.relax-axe-filter-blue is a helper class to fake blue light filtering to ease the strain on the eyes of the users.

<!DOCTYPE html>
<html lang="en">
  <body class="relax-axe-filter-blue">
    ...
  </body>
</html>
Focus
Screen readers

There are occasional instances where content should be made available to screen reader users, but hidden from sighted users. In most cases, if content (particularly content that provides functionality or interactivity) is important enough to provide to screen reader users, it should probably be made available to all users.

Cases where verbose cues or instructions are provided only for screen reader users are most likely a reflection of poor design and accessibility. However, there are a few cases where information is apparent visually, but may not be apparent to screen reader users. In these cases, it may be appropriate to mark-up content in a way that it is read by a screen reader, but invisible to sighted users.

You can use the class .relax-sr-only to accomplish this.

<div>
  <img … />
  <span class="relax-axe-sr-only">Descriptive text to the image</span>
</div>

Forms @relax/forms@8.16.11

Register account

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/forms
Using styles
@import '@relax/forms';

Usage

  1. Register account
    Register account
    Please fill inn your first name.
    Register account

Be as concise as possible when designing forms. Think about each field and what value the data will provide. What do you gain by collecting this information?

Begin by asking: Is this a piece of information that is valuable to us? Is this a piece of information that is so valuable that it's worth preventing the user from continuing if they choose not to provide it?

Form setup

Following examples on how to layout a form:

Default

This setup has two .relax-form-group that is layed out vertically.

The `fieldset`-tag is used in RELAX forms for semantics. Due to the current spec is not fully implemented, `fieldset` can not be a flexbox (`display:flex;`). To fully utilize the layouts, use a inline wrapper `div` with class `.relax-form`!
<form class="relax-form">
  <fieldset>
    <div class="relax-form">
      <legend>Legend</legend>
      <div class="relax-form-group">
        …
      </div>
      <div class="relax-form-group">
        …
      </div>
    </div>
  </fieldset>
</form>

Horizontal

This setup has two fieldsets, one has a horizontal layout with the .relax-form--horizontal class, the other is the default layout.

<form class="relax-form relax-form--horizontal">
  <fieldset style="min-width:16rem;">
    <div class="relax-form relax-form--horizontal">
      <legend>Legend</legend>
      <div class="relax-form-group">
        …
      </div>
      <div class="relax-form-group">
        …
      </div>
    </div>
  </fieldset>
  <fieldset style="min-width:16rem;">
    <div class="relax-form">
      <legend>Legend</legend>
      <div class="relax-form-group">
        …
      </div>
      <div class="relax-form-group">
        …
      </div>
    </div>
  </fieldset>
</form>

Horizontal form group

This setup has a horizontal layout on the form groups with the .relax-form--horizontal class on the .relax-form-group-div.

<form class="relax-form">
  <fieldset>
    <div class="relax-form">
      <legend>Legend</legend>
      <div class="relax-form-group relax-form--horizontal">
        <input type="text" /><input type="text" />
      </div>
      <div class="relax-form-group">
        <input type="text" /><input type="text" />
      </div>
    </div>
  </fieldset>
</form>

Anatomy

All forms are comprised of 5 elements:

  • Labels: Inform users what the corresponding input fields mean.
  • Input fields: Enable users to provide information. Information can be entered through a variety of different input fields ranging from text fields, checkboxes, and many other types.
  • Placeholder text: Provides assistance on how to fill out a field.
  • Actions: Allow users to submit a form.
  • Validation: Ensures the data submitted by the user conforms to acceptable parameters.
  1. Register account
    Register account
    Please fill inn your first name.
  2. Register account
    Register account
    Please fill inn your first name.
  3. Insurance details
    Insured object
    ELL861 Husbil, Fiat Capron
    Insurance time
    28.12.17 tom 27.01.18
    Tariff date
    28.01.18
    Yearly price
    3 123 NOK
    Yearly taxes
    123 NOK
    Vehicle license
    ELL861
    Make
    Registered
    Age of vehicle
    Power output (kW)
    Driver under 25 yeras
    Direct import
    Mileage per year
    Discount
  1. Vertical form
    1. Label
    2. Placeholder (optional)
    3. Actions
  2. Horizontal form
  3. Inline matrix editing
    1. Affected data
    2. Fixed width text fields

Form patterns

Form components

We've grouped together some components (atoms) to be presented as one component (molecule).

Phone number

States

  1. Something is wrong with the input
  2. Something is wrong with the input
  3. Something is wrong with the input
  4. Something is wrong with the input
  5. Something is wrong with the input
  6. Something is wrong with the input
  1. Enabled
  2. Disabled
  3. Focus
  4. Invalid phone number
  5. Focus + Invalid phone number
  6. Invalid land code
<form action="">
  <fieldset>
    <legend>Phonenumber component</legend>
    <div class="relax-form-group">
      <label for="full-phonenumber-label" id="full-phonenumber-label">Full phonenumber</label>
      <div class="relax-form-group relax-form--horizontal relax-fullPhoneNumber" id="full-phonenumber">
        <label id="landcode-label" for="landcode" style="display:none;">Land code</label>
        <input aria-labelledby="full-phonenumber-label landcode-label" data-size="smallest" id="landcode" type="text" value="+47" readonly class="relax-landCode">
        <label id="phonenumber-label" for="phonenumber" style="display:none;">Phonenumber</label>
        <input aria-labelledby="full-phonenumber-label phonenumber-label" data-size="medium" id="phonenumber" type="tel" value="93598910" class="relax-phoneNumber">
        <div class="relax-validation-message">
          Something is wrong with the input
        </div>
      </div>
    </div>
  </fieldset>
</form>

Selection controls @relax/selection-controls@8.16.11

Selection controls allow the user to select options.

Three types of selection controls are covered in this guidance:

  • Checkboxes allow the selection of multiple options from a set
  • Radio buttons allow the selection of a single option from a set
  • Toggle button Switches allow a selection to be turned on or off
Radio button
Checkbox
Toggle controls
Show the favorites bar
Auto-brigtness
Bluetooth

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/selection-controls
Using styles
@import '@relax/selection-controls';
Radio buttons

Radio buttons allow the user to select one option from a set. Use radio buttons for exclusive selection if you think that the user needs to see all available options side-by-side.

Radio Buttons are used when there is a list of two or more options that are mutually exclusive and the user must select exactly one choice. In other words, clicking a non-selected radio button will deselect whatever other button was previously selected in the list.

Usage

To find out more about when to use radio buttons, read this section in the style guide about selection control patterns.
States
  1. Something is wrong with the input
  2. Something is wrong with the input
Radio button states

Anatomy

Using fieldset and legend

It's a best practice to use fieldset and legend when composing HTML for radio buttons. Unlike checkboxes, radio buttons should always be grouped.

Headings

If necessary, a heading can accompany a set of Radio Buttons to provide further clarity for the user. Use sentence-style capitalization (only the first word in a phrase and any proper nouns capitalized).

Labels

Always use a clear and concise label for Radio Buttons. Be explicit about the action that will follow if the Radio Button is selected. Labels appear to the right of Radio Buttons. Use sentence-style capitalization (only the first word in a phrase and any proper nouns capitalized) and no more than three words.

Default selection

A set of Radio Buttons should default to having one option selected. Never display them without a default selection.

Implementation

<form action="">
  <fieldset>
    <div class="relax-form">
      <div class="relax-form-group">
        <div class="relax-selection-controls">
          <input type="radio" id="radio1" class="relax-selection-control" name="radios"/>
          <label for="radio1">A duck</label>
        </div>
        <div class="relax-selection-controls">
          <input disabled id="radio2" type="radio" class="relax-selection-control" name="radios"/>
          <label for="radio2">Shrubbery</label>
        </div>
        <div class="relax-selection-controls">
          <input id="radio3" type="radio" class="relax-selection-control" name="radios"/>
          <label for="radio3">A path! A path!</label>
        </div>
        <div class="relax-selection-controls">
          <input id="radio4" checked type="radio" class="relax-selection-control" name="radios"/>
          <label for="radio4">Blue! No! Red! AAAaahhh...</label>
          <div class="relax-validation-message">
            Something is wrong with the input
          </div>
        </div>
      </div>
    </div>
  </fieldset>
</form>
Checkboxes

Checkboxes are used when there are lists of options and the user may select any number of choices, including zero, one, or several. In other words, each checkbox is independent of all other checkboxes in the list, so checking one box doesn’t uncheck the others. A stand-alone checkbox, or a toggle can be used for a single option that the user can turn on or off.

Usage

To find out more about when to use checkboxes, read this section in the style guide about selection control patterns.
Send me activation notifications
Send me monthly performance summaries
Send me newsletter and promotions
Checkboxes are preferred when an explicit action is required to apply settings.
States
  1. Something is wrong with the input
  2. Something is wrong with the input
Checkbox states

Anatomy

  1. Checkbox
    1. Short and concise text label
    2. Clear, tapable area
Headings

If necessary, a heading can accompany a set of Checkboxes to provide further context or clarity. Use sentence case for Checkbox headings.

Labels

Always use clear and concise labels for Checkboxes. Be explicit about the action that will follow if the Checkbox is selected. Labels appear to the right of Checkboxes.

Click target

Users should be able to select the checkbox by clicking on the box directly or by clicking on its label.

Default selection

The default view of a set of Checkboxes is having no option selected.

Implementation

<form action="">
  <fieldset>
    <div class="relax-form">
      <div class="relax-form-group">
        <div class="relax-selection-controls">
          <input id="checkbox3" type="checkbox" class="relax-selection-control"/>
          <label for="checkbox3">A path! A path!</label>
        </div>
        <div class="relax-selection-controls">
          <input id="checkbox3123" checked type="checkbox" class="relax-selection-control"/>
          <label for="checkbox3123">A path! A path!</label>
        </div>
        <div class="relax-selection-controls">
          <input id="checkbox3123123" disabled type="checkbox" class="relax-selection-control"/>
          <label for="checkbox3123123">A path! A path!</label>
        </div>
      </div>
    </div>
  </fieldset>
</form>
Toggle controls

Best Practice

Toggles are used for binary actions that occur immediately after the user “flips” the Toggle switch. They are commonly used for “On/Off” situations.

For some actions, either a toggle switch or a check box might work. To decide which control would work better, follow these tips:

  1. Use a toggle switch for binary settings when changes become effective immediately after the user changes them
  2. Use checkboxes for optional ("nice to have") items
  3. Use a checkbox when the user has to perform extra steps for changes to be effective. For example, if the user must click a "submit" or "next" button to apply changes, use a check box
  4. Use checkboxes when the user can select multiple items that are related to a single setting or feature
Show the favorites bar
Auto-Brightness
Wi-Fi
The options that require instant response are best selected using a toggle switch.

Heading

A heading may accompany a Toggle to further clarify on the action the Toggle will perform.

Labels

Use labels with a Toggle so the action is clear. Labels should be three words or less and appear on both sides of a Toggle.

Language

Use adjectives rather than verbs to describe labels and the state of the object affected.

Let me know when prices change
E-consent
<form class="relax-form">
  <div class="relax-panel">
    <div class="relax-panel-item">
      <div class="relax-panel-content">
        Let me know when prices change
        <div class="relax-selection-controls">
          <div class="relax-toggle">
            <input type="checkbox" name="relax-toggle" class="relax-toggle-checkbox" id="myrelax-toggle" checked>
            <label class="relax-toggle-label" for="myrelax-toggle"></label>
          </div>
        </div>
      </div>
    </div>
    <div class="relax-panel-item">
      <div class="relax-panel-content">
        E-consent
        <div class="relax-selection-controls">
          <div class="relax-toggle">
            <input type="checkbox" name="relax-toggle" class="relax-toggle-checkbox" id="myrelax-toggle2">
            <label class="relax-toggle-label" for="myrelax-toggle2"></label>
          </div>
        </div>
      </div>
    </div>
  </div>
</form>
Select box

Select is a type of input that is used in forms, where a user is submitting data and chooses one option from a list. For fields in which a single selection is required and there are a large number of possible options, consider using a Select element.

Usage

To find out more about when to use select boxes, read this section in the style guide about selection control patterns.
States
Select box states

Anatomy

Labels

Labels are essential to the usability of forms because they provide guidance to the data a user might provide. Do not place a label inside a Select element. Use sentence case and no more than three words.

Validation

Real time validation helps to streamline the process and keep data clean when the user is filling out forms. For full guidelines, refer to the Forms usage page.

Order

The order of the Select list should be based on the frequency of use. If applicable, the list should be in increasing order relative to the content. In cases of Forms, alternative orders such as alphabetical may be more fitting. A horizontal rule can be used to group similar items together.

Implementation

<div class="relax-select">
  <select>
    <option value="100">Select 100</option>
    <option value="200">Select 200</option>
    <option value="300">Select 300</option>
  </select>
</div>

Specs

Select box
Multi select
  • Option 1
  • Option 2
  • Option 3
  • OtherOption 4
  • Option 5
  • Option 6
  • OtherOption 7
  • OtherOption 8
  • OtherOption 9
  • Option 10
  • Option 1
  • OtherOption 12
  • Option 13
  • OtherOption 14
  • Option 15
  • Option 16
  • Option 17
  • Option 18

Usage

To find out more about when to use multi-select boxes, read this section in the style guide about selection control patterns.
States
Multi-select box states

Anatomy

    • Option 1
    • Option 7
    • OtherOption 8
    • Option 9
    • Option 10
    • Option 11
    • Option 12
    • Option 1
    • Option 3
    • OtherOption 4
    • Option 5
    • Option 6
    • OtherOption 7
    • Option 13
    • OtherOption 14
    • Option 15
    • Option 18
  1. Multiselect, none selected
    1. Short and concise text label
    2. Nothing selected
  2. Multiselect, open + hover
    1. A pane with options
    2. Option hovered
  3. Multiselect, two selected
    1. Selected items have a filled background
    2. Selected items have a filled background

Implementation

<label for="multiSelect1">Nothing selected</label>
<div class="relax-multiSelect" aria-expanded="false" aria-controls="multiSelect-options1">
  <input name="multiSelect1" class="" type="text">
  <div class="relax-multiSelect-input"></div>
  <ul class="relax-multiSelect-options" id="multiSelect-options1">
    <li>...</li>
  </ul>
</div>

Specs

Multi-select box
Multi-select box with selected items open
  • Option 1
  • Option 2
  • Option 3
  • OtherOption 4
  • Option 5
  • Option 6
  • OtherOption 7
  • OtherOption 8
  • OtherOption 9
  • Option 10
  • Option 1
  • OtherOption 12
  • Option 13
  • OtherOption 14
  • Option 15
  • Option 16
  • Option 17
  • Option 18
Multi-select box with selected items closed
Star rating

Usage

States
  1. Toggled
  2. Untoggled
  3. Disabled

Implementation

<div class="relax-selection-controls">
  <input class="relax-selection-control relax-selection-control--star" id="iconToggle1" name="checkboxes" type="checkbox"> <label for="iconToggle1"></label>
</div>

Text field @relax/text-field@8.16.11

Text fields let users enter and edit text.

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/text-field
Using styles
@import '@relax/text-field';
Usage

Text field types

Here is examples on how the different input types look like. For more information on the different types, please see the MDN documentation.

Please use the semantically correct input type for your needs! If you want regex pattern matching, use the pattern-attribute. If you want to format the input, use input[type="text"] and an appropriate addon, i.e. cleave.js
  1. Text
  2. Date
  3. Tel
  4. Number
  5. File
  6. Email
  7. Password
  8. Search
  9. Time
  10. Url

Field length

With given attributes (data-size), you can vary the length of the input field. For optimal usability, use a size that corresponds with the type/amount of characters in the text-field. For example, the field for a postal code containing a maximum of 5 characters should use the attribute data-zize="small".

  1. Largest
  2. Larger
  3. Large
  4. Medium
  5. Small
  6. Smallest
<form class="relax-form">
  <fieldset>
  <legend>
    <i>Small input</i>
  </legend>
  <div class="relax-form-group">
    <label for="zipcode-04">Zip code</i></label>
    <input data-size="[largest|large|medium|small|smallest]" value="02148" id="zipcode-04" type="text" />
  </div>
</fieldset>
</form>
Do not use over sized input lengths for small input
Use input lengths appropriate for the input
Insurance details
Insured object
ELL861 Husbil, Fiat Capron
Insurance time
28.12.17 tom 27.01.18
Tariff date
28.01.18
Yearly price
3 123 NOK
Yearly taxes
123 NOK
Vehicle license
ELL861
Make
Registered
Age of vehicle
Power output (kW)
Driver under 25 yeras
Direct import
Mileage per year
Discount
However, in tabular/grid forms, the field should be equal size.
Anatomy
  1. Text field anatomy
  1. Text field
    1. Text label
    2. Placeholder text (optional)
    3. Wide enough for the relevant data

Labels

Effective form labeling helps users understand what information to enter into a Text Input. Using a placeholder text as a label is often applied as a space-saving method. However, this is not recommended because it hides context and presents accessibility issues.

Clear text labels

The users wants to know what kind of data to enter in an input field and clear label text is one of the primary ways to tell them that. Of course there are situation when users can rely on icon in order to figure out the meaning of the field (e.g. users recognize a magnifying-glass icon as meaning ‘search’ even without a textual label), but in most cases you should provide clear, always visible labels for each input field.

Clear labels makes users feel more confident that they are understanding things in the right way, and taking the right actions.

Short text labels

Labels are not help texts. You should use succinct, short and descriptive labels (a word or two) so users can quickly scan it. If extra information, clarification or context is required use help text to do this rather than long rambling labels.

Do not use long label texts. If you need to add more clarification, use help texts
Use short, succinct labels

Placeholder text

Placeholder text provides hints or examples of what to enter. Placeholder text should disappear after the user has entered data into the Text Input. Use sentence-style capitalization, and in most cases, write the text as full sentences with punctuation.

A placeholder attribute should not be used as an alternative to a label. The placeholder is a short hint intended to aid the user with data entry so it should not be identical to the label element. The placeholder may not be available to assistive technology and thus may not be relied upon to convey an accessible name or description -- it acts similar to fallback content.

Placeholder should not be the same as the label
Let the placeholder be a short hint

Default values

Where possible, add programmatic assistance. Detect and pre-fill inputs to reduce errors and save time. When the software can't determine the value that belongs in an input, use type-ahead to make suggestions. Use sentence-case for default values, detected values, and auto-completion text.

Validation and errors

Real time validation helps to streamline the process and keep data clean when the user is filling out forms. For full guidelines, refer to the Validation section.

Accessibility best practices for labels:

  • Labels must be visible when an input gets focus.
  • Labels must be announced to the screen reader on focus.
  • Ensure the helper text that appears under an input is read when an assistive technology user stops at an input using ARIA.
  • Use sentence-style capitalization (only the first word in a phrase and any proper nouns capitalized).

Avoid CAPS labels

You should never use all CAPS, or else the labels would be difficult to read and much harder to quickly scan, as there are no differences in character height any more.

UPPERCASE text is harder to read because the shapes of all the uppercase letters are all rectangular and users are not used to reading text that way.

Do not use CAPS in labels
Use normal text transforms on labels

Make input field keyboard-friendly

Users should be able to trigger and edit every field using only the keyboard. Power users, who tend to use keyboards heavily, should be able to easily tab through the fields and make necessary edits, all without lifting their fingers off the keyboard. You can find detailed requirements for keyboard interaction pattern in W3C’s Authoring Practices for Design Patterns.

States
  1. Text field states
  2. Text field states
    Something is wrong with the input
  3. Text field states
    Something is wrong with the input
  4. Text field states
  5. Text field states
    Something is wrong with the input Something is wrong with the input Something is wrong with the input Something is wrong with the input
  1. Enabled
  2. Disabled
  3. Invalid
  4. Focus
  5. Focus + Invalid
Textarea

Textareas are to be used when you need multi line input from the user. The textarea is expandable. If you want it to expand to fullwidth, use the class relax-textarea--fullWidth.

<form action="">
  <div class="relax-form-group">
    <textarea class="relax-textarea [relax-textarea--fullWidth]">This is a textarea</textarea>
  </div>
</form>
Input type date
The native datepicker is not supported in IE or Firefox/Safari, so you need to supply a polyfill.

Date picker validation

To maintain consistency in error messaging, push the calendar layover (that displays months) down so that the error message displays under the input field, but above the calendar overlay. This preserves the users´ context and also provides them the ability to correct the error by choosing a valid date.

Validation example

Implementation example

<fieldset class="relax-form-group">
  <label for="date">Date:</label> <input data-size="large" placeholder="Input date" type="date" id="date" name="date" />
</fieldset>

Sliders @relax/sliders@8.16.11

Sliders provide a visual indication of adjustable content, where the user can move the handle along a horizontal track to increase or decrease the value.

0 100
Submit

Installation

If you do not want to use the complete bundle, you can install the component separately.
$ npm i @relax/sliders
Using styles
@import '@relax/sliders';
Usage

The Slider in its basic form should be accompanied by a label and a number input that can demonstrate the slider input's increase or decrease. The basic slider does not include values as the slider represents a percentage of 0-100. In this case it is not necessary for a user to choose a specific value, but instead generally increase or decrease an input. For example, the user increases the Slider amount and the volume of the music gets louder. The more complex versions should be used for selecting a specific value within a value range.

Users can choose a numerical value by:

  • Entering the exact value into the text field.
  • Moving the Slider handle with their mouse, which automatically updates the value in the Text Input.
  • Using the arrow keys automatically updates the value in the Text Input and moves the Slider handle to the corresponding value.
  • The step size increment is how many increments the inputted value and Slider handle will jump when using the arrow keys. Make sure to set the step size increments to reasonable values.
  • changes the value by one step size increment. (Example: Pressing changes the inputted value from 59 to 60, increasing the value by 1 unit.)
  • Shift + changes the value by 10 step size increments. (Example: Typing Shift + changes the value from 60 to 70, increasing the inputted value by 10 units.)
If you want a range slider, use the styling from the this component and use whatever JS-framework (or not) you want to create a range slider. See #6 for reference.
Anatomy

Best practices

  • The Slider label should indicate what value the Slider is changing.
  • Range values are used to describe the range in numbers.
  • Do not use for ranges that are extremely large (ex. 1-1000).
  • Do not use for ranges that are too small (ex. 1-3).
0 10000
Do not use a slider for large ranges
1 10
Do not use a slider for low ranges
Implementation
<form class="relax-form">
  <fieldset>
    <div class="relax-form">
      <label for="fader">Volume</label>
      <div class="relax-form-group relax-form--horizontal" style="flex-wrap: nowrap;">
          <span class="relax-slider-min">0</span>
          <input aria-valuemax="100" oninput="onUpdate(value)" aria-valuemin="1" aria-valuenow="50" id="fader" max="100" min="1" step="1" type="range" value="50">
          <span class="relax-slider-max">100</span>
          <input id="volume" type="number" value="50">
      </div>
    </div>
  </fieldset>
</form>
const onUpdate = vol => {
  document.querySelector('#volume').value = vol;
  document.querySelector('#fader').setAttribute('aria-valuenow', vol);
};