@seed-design/stylesheet

1.0.4 • Public • Published

@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();
})();

Readme

Keywords

none

Package Sidebar

Install

npm i @seed-design/stylesheet

Weekly Downloads

538

Version

1.0.4

License

none

Unpacked Size

53.4 kB

Total Files

3

Last publish

Collaborators

  • junghyeonsu
  • malangcat
  • cometkim