@snack-uikit/figma-tokens
v16.1.1
Published
Figma Tokens for Cloud Design System
Downloads
2,382
Readme
Figma tokens
Пакет figma-токенов дизайн-системы компании Cloud.ru и сообщества TeamSnack
- Макеты Figma
- Инструмент для пресборки токенов: Token Transformer
- Инструмент для сборки json-токенов в соответствующие стилевые файлы: Style Dictionary
Начало работы
- Установите зависимости:
npm install
- Запустите сборку:
npm run build:all
В репозитории собираются:
- CSS-файл со значениями токенов (содержит два класса для модификаций - .light и .dark):
build/css/brand.module.css
- SCSS-файлы с токенами:
build/scss
- TS-файлы с токенами:
build/ts
Работа с токенами
Семантика токенов
Есть 3 слоя токенов - базовые, тематические и компонентные (лежат в папках Base, Theme и Components соответственно)
- Базовые - самые основные токены; внутри поделены на токены цветов, шрифтов и анатомии
- Тематические токены - ссылаются на базовые токены; существуют в двух модификациях для цветов - Light и Dark
- Токены компонентов - ссылаются на тематические токены (либо напрямую на базовые, если не требуется темизация каких-либо св-в); поделены покомпонентно
Типы токенов
- Обычные - токены содержат одно св-во и применяются к конкретному св-ву css с помощью функции
simple-var
либо напрямую через css-var, если это простая переменная
.buttonLabel {
color: simple-var($theme-variables, 'sys', 'primary', 'on-accent');
// или
color: $sys-primary-on-accent;
}
- Композитные (composite, typography, border) - токен внутри содержит несколько св-в css - их нужно применять внутри класса с помощью миксина
composite-var
.buttonLabel {
@include composite-var($theme-variables, 'sans', 'label', 'size-s');
// или
@include composite-var($sans-label-size-s);
}
- Случаи-исключения:
- Токен для св-ва outline - в figma для него нет специального типа, поэтому для него используется композитный токен типа border. Соответственно, для него понадобится свой миксин
outline-var
- Токен для св-ва outline - в figma для него нет специального типа, поэтому для него используется композитный токен типа border. Соответственно, для него понадобится свой миксин
.button {
&:focus-visible {
@include outline-var($container-focused-available-size-s);
}
}
Связи слоёв токенов
Base/Colors (References palette) Базовые переменные для формирования System palette Это наборы тонов для каждого цвета, где каждый тон имеет порядковый номер. Каждый цвет разложен на 20 тонов от самого тёмного до самого светлого. Для единого представления каждым человеком о цвете, они именуются простейшими цветами радуги. Любые изменения переменных отразятся на System palette
Themes/Color (System palette) Набор семантических стилей, применяется на Components или его элементах напрямую как в figma, так и коде. Эти стили не используются в Composition токенах. Включение цвета в Composition токены приведет к порождению большого количества однообразных токенов в которых меняется только цвет, так как при изменении состояния компонента необходимо менять цвет, следовательно возникнет потребность в создании еше одного Composition токена. System палитра, в отличии от References, обладает меньшим количеством цветов. System палитра имеет 2 модификации - темная и светлая. Эти модификации наследуют разные тона References палитры, наследие тонов заведомо распределено и переопределяется при переключении модификации. Любые изменения переменных отразятся на Components.
Base/Fonts Набор базовых переменных для построения стилей типографики - семейство шрифтов, вес шрифта, высота строки, размер шрифта, интервал между буквами, интервал между абзацами, декоратор текста Любые изменения переменных отразятся на Typography
Themes/Typography Набор семантических стилей типографики, применяются к компоненту напрямую в фигма и коде.Семантика стилей разделена на 5 ролей, для каждой роли задаётся по 3 размера. Typography имеет 2 модификации - темная и светлая, возможно переопределение стилей с модификацией. Цвет типографики устанавливается в компоненте из Themes/Color Любые изменения переменных отразятся на Components
Themes/Effects Переменные для эффектов - тени или размытия Набор семантических стилей, применяется на Components или его элементах напрямую как в фигма, так и коде. Effects имеет 2 модификации - темная и светлая. Эти модификации могут быть с разными настройками эффектов. Любые изменения переменных отразятся на Components
Base/Anatomy Базовые переменные для формирования анатомических свойства компонентов - размеров, отступов, бордеров, скруглений и непрозрачности. Любые изменения переменных отразятся на Settings
Themes/Settings Переменные, семантически связанные с анатомическими свойствами Components. Это переменные для настройки анатомических свойств компонентов темы. Переменные используются в Composition tokens, это позволяет вносить изменения в анатомию компонента без изменения токена применённого на самом компоненте. Переменные могут иметь математические вычисления, что не допустимо на слое Components. Переменные сгруппированы по анатомическим свойствам. Любые изменения переменных отразятся на Composition token.
* 7.1 **Themes/Settings** Переменные, семантически связанные с анатомическими свойствами Components. Возможно прямое применение на компоненте как в фигма, так и коде в случаях когда Composition token создает ограничение в реализации компонента в коде. Например, оффсет дроплиста может применяться с одной из 4 его сторон, в зависимости от того, где расположен его триггер. В таком случае не получится задать этот оффсет в каком-то конкретном направлении (а значит, не стоит использовать Composition token). В этом случае не допустимы математические вычисления в токене. Любые изменения переменных отразятся на Components или элементе Components.
Components/Composition tokens Переменные, семантически связанные с Components или набором элементов Components. Эти переменные объединяют в себе несколько параметров анатомии компонента, значения переменных зависят от Settings Применяется на Components или его элементах напрямую как в фигма, так и коде. Не допустимы математические вычисления в значениях переменных. Любые изменения переменных отразятся на Components.
Как использовать токены в приложении
- Подключите пакет
@snack-uikit/figma-tokens
актуальной версии - Подключите файл с токенами, а затем поместите их в нужное место, используя вспомогательные функции
var
,simple-var
илиcomposite-var
- scss
@import '@snack-uikit/figma-tokens/build/scss/styles-theme-variables';
.wrapper {
color: $sys-primary-text-main-enabled;
opacity: simple-var($theme-variables, 'opacity', 'a032');
@include composite-var($sans-label-l);
}
- ts
import { styled } from '@linaria/react';
import { themeVars } from '@snack-uikit/figma-tokens';
export const Wrapper = styled.div`
color: ${themeVars.sys.primary.textMainEnabled};
${themeVars.sans.label.s};
`;
Как использовать токены в компонентах uikit-a
- Проверьте, что в uikit подключен пакет
@snack-uikit/figma-tokens
актуальной версии - Создайте файл для компонента (напр.,
ButtonFilled.tsx
) и scss-файл для стилей (styles.module.scss
), который импортируется в файл компонента - Подключите файлы с токенами в
styles.module.scss
(тематические, компонентные - какие нужны):- файлы с токенами компонентов по умолчанию уже включают в себя тематические токены
@import '@snack-uikit/figma-tokens/build/scss/styles-theme-variables';
@import '@snack-uikit/figma-tokens/build/scss/components/styles-tokens-***';
- Соберите стили компонента по макетам в figma, подключая токены через
var
,simple-var
илиcomposite-var
- в scss можно также добавлять миксины и различные функции, чтобы убирать дублирование кода, пример:
// пример миксина, в других случаях код может быть другой
$sizes: s, m, l;
$variants: label-only, icon-only, label-icon;
@mixin button-anatomy-styles {
@each $size in $sizes {
&[data-size='#{$size}'] {
@each $variant in $variants {
&[data-variant='#{$variant}'] {
@include composite-var($button-filled, 'container', $size, $variant);
}
}
}
}
}
.button {
@include button-anatomy-styles;
}
- Подключите scss-файл в компонент в виде объекта с класснеймами, и далее используйте следующим образом:
import styles from './styles.module.scss';
export type ButtonFilledProps = {
label?: string;
size?: Size;
variant?: Variant;
disabled?: boolean;
loading?: boolean;
};
export const ButtonFilled = ({ label, size, variant, disabled, loading }: ButtonFilledProps) => {
return (
<button
className={classNames.button}
data-size={size}
data-variant={variant}
data-disabled={disabled || undefined}
data-loading={loading || undefined}
>
<label className={styles.label}>{label}</label>
</button>
);
};
Процесс сборки пакета с токенами
Сборка json-ов c помощью token-transformer (в подходящий формат для style-dictionary) (
scripts/buildTokens
)- Сборка базовых и тематических токенов (папка
build/tokens/themes
)- Согласно файлу
tokens/$themes.json
происходит сборка тематических файлов (в файле лежит 2 конфига для тем, с указанием, какие наборы токенов надо включить - св-воselectedTokenSets
) - token-transformer собирает базовые токены и токены темы в 2 общих файла - для модификаций dark и light
- Сборка token-transformer-ом включает в себя резолв всех зависимостей и арифметических операций
- Согласно файлу
- Сборка токенов компонентов (папка
build/tokens/components
)- Для каждого компонента собирается отдельный файл с токенами
- Связи с токенами тем и базовыми здесь уже не резолвятся, т.к. они нужны для работы тем в дальнейшем
- Важно - в токенах компонентов должны отсутствовать арифметические операции! Должны быть только ссылки на базовые/тематические токены
- Сборка базовых и тематических токенов (папка
Сборка css, scss и ts файлов из json-ов с помощью style-dictionary (
scripts/buildStyleFiles
)- Сборка тематических файлов
- Файл с темами (
build/css/brand.module.css
) - Файлы, содержащий только токены темы:
- SCSS (
build/scss/styles-theme-variables.scss
) - TS (
build/ts/styles-theme-variables.ts
)
- SCSS (
- Файл с темами подключается в проекте в корневую директорию, где нужно навесить классы на самую верхнюю обёртку
- Файлы только с токенами подключаются в конкретном месте использования токенов
- Файл с темами (
- Сборка компонентных файлов (папка
build/scss/components
)- Для каждого компонента собирается свой scss, который содержит компонентные токены - они подключаются в конкретный компонент
- Основные понятия для работы со style-dictionary
- Transform - трансформеры для токенов - функция, которая принимает сырой токен и может его преобразовать в какой-либо формат
scripts/buildStyleFiles/transformers
- См. https://amzn.github.io/style-dictionary/#/transforms
- Filter - фильтр для токенов - функция, которая принимает токен и возвращает true/false - брать или не брать токен в итоговый список токенов
scripts/buildStyleFiles/tokenFilters.ts
- См. https://amzn.github.io/style-dictionary/#/formats?id=filtering-tokens
- Format - форматы для файлов - функция, которая принимает в себя итоговый список токенов и возвращает контент файла (т.е. на текущий момент - это контент scss файла)
scripts/buildStyleFiles/fileFormatters
- См. https://amzn.github.io/style-dictionary/#/formats
- Конфиги для style-dictionary
scripts/buildStyleFiles/utils/getCSSModuleThemeConfig.ts
- конфиг для сборки тематического css-файлаscripts/buildStyleFiles/utils/getSCSSThemeVariablesConfig.ts
- конфиг для сборки scss-файла с токенамиscripts/buildStyleFiles/utils/getTSThemeVariablesConfig.ts
- конфиг для сборки ts-файла с токенамиscripts/buildStyleFiles/utils/getComponentStylesConfig.ts
- конфиг для сборки компонентных scss файлов
- Transform - трансформеры для токенов - функция, которая принимает сырой токен и может его преобразовать в какой-либо формат
- Сборка тематических файлов
Создание собственной темы
Видео инструкция представлена по ссылке
Настройка форка figma-tokens
- Переходим на репозиторий с токенами и создаем форк
- Добавляем в Repository secrets переменную
CI_NPM_TOKEN
с Access токеном из npmjs (для публикации собственного пакета) - Создаем ветку
brand
и переносим в корень содержимое папкиguthub-settings-example
- Подставляем собственные значения (
YOUR_PACKAGE_NAME
,YOUR_BRAND
,YOUR USERNAME
,YOUR_USERNAME
) вpatch.package.json
- Пушим измения в
origin/brand
- Меняем
default branch
в настройках репозитория наbrand
Рекомендации*
- Ветка
brand
является корневой для хранения настроек для собственного бренда - Новые коммиты в
brand
добавляются только черезPull Request
- Запретить пуши в ветку
master
и держать эту ветку синхронизированной с оригиналом - Для автоматической синхронизации форка и ребейза ветки
brand
использовать воркфлоуAuto fork sync
- Для выпуска превью версии пакета использовать воркфлоу
Release Preview