space
The use-design-tokens rule checks that CSS spacing declarations (e.g. margins,
padding, gaps, inset, etc.) use design token variables instead of hardcoded values.
This ensures consistent spacing across the application and makes it easier to
maintain design system consistency.
This rule applies to the following properties:
paddingand all of its longhand propertiesmarginand all of its longhand propertiesinsetand all of its longhand propertiesgap,column-gap,row-gapPositioning attributes:
left,right,top, andbottom.
Note that the following properties accept both space and size tokens:
insetand all of its longhand propertiesPositioning attributes:
left,right,top, andbottom
Use space tokens when these properties represent spacing/positioning offsets, and size tokens when they represent element dimensions.
Examples of incorrect code for this rule:
.custom-button {
padding: 0.5rem;
}
.card {
margin-inline: 8px;
}
.overlay {
inset: 1rem;
}
.grid {
gap: 4px 12px;
}
Examples of correct token usage for this rule:
.custom-button {
padding-block: var(--space-small);
}
.custom-button {
padding-inline: var(--space-medium);
}
.custom-button {
column-gap: var(--space-xxsmall);
}
.custom-button {
margin-block-start: var(--space-large);
}
/* Local CSS variables that reference valid space tokens are allowed */
:root {
--custom-space: var(--space-xsmall);
}
.custom-button {
padding: var(--custom-space);
}
.custom-button {
margin-inline-end: var(--custom-space, --space-xlarge);
}
.overlay {
inset: var(--space-small);
}
.positioned-element {
top: var(--space-large);
left: var(--space-medium);
}
The rule also allows these values to be non-token values:
.inherited-inset {
inset: inherit;
}
.unset-padding {
padding: unset;
}
.initial-row-gap {
row-gap: initial;
}
.auto-margin {
margin-inline: auto;
}
.zero-padding {
padding: 0;
}
Autofix functionality
This rule can automatically fix some violations by replacing common pixel values with appropriate space tokens. Examples of autofixable violations:
/* Before */
.a {
margin: 2px;
}
/* After autofix */
.a {
margin: var(--space-xxsmall);
}
/* Before */
.a {
padding: 8px 16px;
}
/* After autofix */
.a {
padding: var(--space-small) var(--space-large);
}
/* Before */
.a {
gap: 24px 32px;
}
/* After autofix */
.a {
gap: var(--space-xlarge) var(--space-xxlarge);
}