이 곳을 진실의 원천으로 삼고 동기화 작업에서 해방됩시다.
- 🎨 컬러 스킴 라이브러리 제공
- ⚙️ 토큰에 대한 TypeScript 지원
- 🔄 Figma 프로토타이핑과 애플리케이션 형상 동기화
- 프로젝트/디자인 시스템 명이 Seed Design으로 리브랜딩 됩니다.
- 패키지 명이
@seed-design/*
으로 변경됩니다. @karrot-ui/*
packages are deprecated.color-scheme: light dark
지원이 기본값이 됩니다.- 디자인 토큰이 KDT 의미론을 따릅니다.
참고: https://web.dev/i18n/ko/color-scheme/#color-scheme
애플리케이션이 지원하는 컬러 스킴을 브라우저에게 여러 방법으로 알릴 수 있습니다. 그 중 메타태그를 사용하는 것이 가장 빠른 방법이므로 가능한 경우 명시하는 것을 권장합니다.
<meta name="color-scheme" content="light dark" />
웹 브라우저에서 실행되는 경우 Seed Design 의 모든 속성 정의는 CSS Variables를 통해 제공됩니다.
Seed Design의 스타일시트 리소스를 사용할 수 있도록 우선 로딩 해야합니다.
<!-- 브라우저가 자산을 우선적으로 처리하도록 preload 표시 -->
<link rel="preload" href="uri/to/global.css" as="style" />
<link rel="stylesheet" href="uri/to/global.css" />
웹팩 등 자바스크립트 번들러에 의해 처리되는 경우, MiniCssExtractPlugin 등으로 사전에 추출되어 주요 렌더링 경로에 배치해야합니다.
import '@seed-design/stylesheet/global.css';
Seed Design 에서 제공하는 속성은 사용하기 전에 명시적인 초기화가 필요합니다.
- 페이지 루트 요소에
data-seed
어트리뷰트를 지정합니다. - 사용자가 선호하는 컬러 스킴에 따라
data-seed-scale-color
어트리뷰트를 지정합니다. - 시스템 폰트에 적합한 타이포그래피를 적용하기 위해
data-seed-scale-letter-spacing
어트리뷰트를 지정합니다.- ios
- android
예시) HTML (light-only)
<html
lang="ko"
data-seed="light-only"
data-seed-scale-color="light"
data-seed-scale-letter-spacing="ios"
>
<head>
<meta name="color-scheme" content="light" />
</head>
</html>
예시) DOM API로 동적 초기화
(CSS-in-JS 라이브러리 통합 시, 또는 pre-hydration 스크립트에서 수행 될 수 있습니다)
(function() {
var el = document.documentElement;
el.dataset.seed = '';
var prefersLight = window.matchMedia('(prefers-color-scheme: light)');
var prefersDark = window.matchMedia('(prefers-color-scheme: dark)');
if (prefersLight.matches) {
if ('addEventListener' in prefersLight) {
prefersLight.addEventListener('change', apply);
} else if ('addListener' in prefersLight) {
prefersLight.addListener(apply);
}
} else if (prefersDark.matches) {
if ('addEventListener' in prefersDark) {
prefersDark.addEventListener('change', apply);
} else if ('addListener' in prefersDark) {
prefersDark.addListener(apply);
}
}
function apply() {
el.dataset.seedScaleColor = prefersDark.matches ? 'dark' : 'light';
el.dataset.seedScaleLetterSpacing = 'ios';
}
apply();
})();
packages
에 있는 패키지들 사용법은 각 워크스페이스 README.md
를 참고해주세요.