@seed-design/stylesheet
설치
npm install @seed-design/stylesheet
yarn add @seed-design/stylesheet
가이드
HTML 메타태그 삽입하기
참고: https://web.dev/i18n/ko/color-scheme/#color-scheme
애플리케이션이 지원하는 컬러 스킴을 브라우저에게 여러 방법으로 알릴 수 있습니다. 그 중 메타태그를 사용하는 것이 가장 빠른 방법이므로 가능한 경우 명시하는 것을 권장합니다.
<meta name="color-scheme" content="light dark" />
CSS 스타일시트 로딩하기 (DOM)
웹 브라우저에서 실행되는 경우 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";
<html>
) 초기화
루트 엘리먼트(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 () {
function isIOS() {
return /iphone|ipad|ipod/i.test(window.navigator.userAgent.toLowerCase());
}
var ios = isIOS();
var prefersLight = window.matchMedia("(prefers-color-scheme: light)");
var prefersDark = window.matchMedia("(prefers-color-scheme: dark)");
var el = document.documentElement;
el.dataset.seedScaleLetterSpacing = ios ? "ios" : "android";
el.dataset.seed = "";
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() {
document.documentElement.dataset.seedScaleColor = prefersDark.matches
? "dark"
: "light";
}
apply();
})();