/seed-design

The Seed Design System

Primary LanguageTypeScriptApache License 2.0Apache-2.0

SEED Design

이 곳을 진실의 원천으로 삼고 동기화 작업에서 해방됩시다.

  • 🎨 컬러 스킴 라이브러리 제공
  • ⚙️ 토큰에 대한 TypeScript 지원
  • 🔄 Figma 프로토타이핑과 애플리케이션 형상 동기화

Karrot UI → Seed Design 주요 변경 사항

  • 프로젝트/디자인 시스템 명이 Seed Design으로 리브랜딩 됩니다.
  • 패키지 명이 @seed-design/* 으로 변경됩니다.
  • @karrot-ui/* packages are deprecated.
  • color-scheme: light dark 지원이 기본값이 됩니다.
  • 디자인 토큰이 KDT 의미론을 따릅니다.

공통 가이드

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() {
  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를 참고해주세요.