Guidelines

Spacing

Spacing tokens are used to consistently apply margin and padding across components and layouts. With a set spacing, information can be structured to have a consistent and intuitive user interface across the website.

Two spacing scales

ECL provides two separate sets of scales:

  1. Inner spacing: the spacing within the components
  2. Layout spacing: the spacing between the omponents (+ other elements outside of a component)

For spacing tokens to be able to conform in the baseline grid and contribute to the vertical rhythm, all sizes must be multiples of 4px. A vertical rhythm starts from a baseline and it’s the basis for everything from the font sizes, line height and image sizes. The spacing tokens always referring to fixed values and thus they are not responsive. All spacing tokens can be used as values for both margins and paddings.

Use of space

Space is used to create hierarchy and visual relationships. By using the space tokens, you can achieve visual grouping and other associations both between and within the components. Along with the typography system, they contribute to an overall visual hierarchy, providing users with a structured way of organising information.

Inner component space

Whenever we need a fixed horizontal or vertical spacing inside components then these spacing tokens are to be used. All the values are multiples of 4px so they can complement the typography when placed in a 4px vertical grid. The values are based on a geometric progression. There are some exceptions like the 12px/0.75rem and 48px/3rem that they don't fit in the geometric progression, but the need of having was apparent for some rare occasions where the only using geometric progression values wasn't enough

Space token of components

Layout spacing

Whenever we need a fixed horizontal or vertical spacing to place components in a layout then the below tokens need to be used. In most cases, the horizontal spacing is been determined to be the 12 column horizontal grid (If there are cases of fixed horizontal spacing, then the tokens need to be used). So the layout spacing tokens are used mostly to define the vertical relationships between components. These spaces are always fixed (thus we use the tokens).

Space token of components
NameToken (example)Size
4xl$layout-4xl64px - 4rem
3xl$layout-3xl48px - 3rem
2xl$layout-2xl40px - 2.5rem
xl$layout-xl32px - 2rem
l$layout-lg24px - 1.5rem
m$layout-md16px - 1rem
s$layout-sm12px - 0.75rem
xs$layout-xs8px - 0.5rem
2xs$layout-2xs4px - 0.25rem

Do's

  • always use the spacing token when spacing out element (either margin or padding)

Don'ts

  • don't go outside the provided spacing tokens
  • don't stack the spacing tokens (e.g. 12px + 16px)

When to use

  • whenever you need to space out the inner parts within a component (when creating a new component that is outside what ECL provided)
  • whenever you need to space out one component from another or other elements outside of a component

When not to use

  • do not use when you want to have responsive spacing since the token are fixed values