@royalnavy/design-tokens
TypeScript icon, indicating that this package has built-in type declarations

4.25.2 • Public • Published

Design Tokens

An agnostic way to store variables such as typography, color, and spacing.

Installation

The Royal Navy Design Tokens are available as an NPM package.

// npm
npm install @royalnavy/design-tokens

// pnpm
pnpm add @royalnavy/design-tokens

Selectors

The reccomended way to access tokens is using the supplied selector functions.

Simply import the selector object and then destructure the selectors you want to use out of this.

import { selectors } from '@royalnavy/design-tokens'

const { color, spacing, mediaQuery } = selectors

// inside a styled-component
const StyledExample = styled.div`
  color: ${color('action', '500')};
  margin-top: ${spacing('2')};

  ${mediaQuery({ gte: 'xs', lt: 'xl', media: '' })`
    // @media and (min-width:576px) and (max-width:1400px)
    color: black;
  `}
`
Selector Alias Example Return Value Description
animation 0.2s Animation timing values.
breakpoint { breakpoint: '768px' } Raw object containing breakpoint.
mediaQuery mq See usage example above. Tagged template literal that generates a media query string.
color #FFFFFF A color value as a hex string.
shadow 0 1px 3px rgba(0, 0, 0, 0.04) Preset box-shadow values.
spacing 0.5rem Fixed spacing value in REMs.
fontSize 0.5rem Fixed font-size value in REMs.
zIndex 6001 Scoped z-index value with optional modifier.

The selectors are typed. We reccomend using the hinting in your IDE to see the signatures and available arguments for each selector. Alternatively, you can see the raw tokens here on GitHub.

Raw Tokens

It's also possible to access the raw underlying tokens.

We consider these to be implementation detail (they may change without notice), as such we recommend using selectors over raw tokens in most instances.

JavaScript

import { ColorNeutral100 } from '@royalnavy/design-tokens'

SASS

@use '@royalnavy/design-tokens' as $vars;

Questions

The Design System is maintained by a team at the Royal Navy. If you want to know more about the Royal Navy Design System, please email the Design System Team.

Documentation

The documentation website contains all the information you need to build your application using the Royal Navy Design System.

Contributing

The contributing guide resource presents information about our development process.

Changelog

If you have recently updated then read the release notes

Roadmap

The Design System Roadmap Board contains the work that has been prioritised for the next 12 months.

License

The Royal Navy Design System is licensed under the Apache License 2.0.

Dependents (2)

Package Sidebar

Install

npm i @royalnavy/design-tokens

Weekly Downloads

343

Version

4.25.2

License

Apache-2.0

Unpacked Size

905 kB

Total Files

23

Last publish

Collaborators

  • rndsbot
  • m7kvqbe1
  • royal-navy
  • thyhjwb6