8.19.2 β€’ Published 3 days ago

@croquiscom/pds v8.19.2

Weekly downloads
-
License
MIT
Repository
github
Last release
3 days ago

npm version

PDS

PDS(νŒŒνŠΈλ„ˆ λ””μžμΈ μ‹œμŠ€ν…œ)은 μΉ΄μΉ΄μ˜€μŠ€νƒ€μΌ νŒŒνŠΈλ„ˆμ„Όν„° λ””μžμΈ μ‹œμŠ€ν…œμ„ μœ„ν•œ λ¦¬μ•‘νŠΈ 기반의 λΌμ΄λΈŒλŸ¬λ¦¬μž…λ‹ˆλ‹€.

μ‚¬μš©

ν”„λ‘œμ νŠΈμ— @croquiscom/pds와 peer dependenciesλ₯Ό μΆ”κ°€ν•΄μ€λ‹ˆλ‹€.

npm install --save @croquiscom/pds @emotion/react @emotion/styled react react-dom
import React from 'react'
import { value color, value text_styles, value HStack } from '@croquiscom/pds';
import styled from '@emotion/styled';

export default function Test() {
  return (
    <HStack spacing={10}>
      <BaseText kind='Heading_24_Bold' color={colors.gray900}>Hello</BaseText>
      <StyledText>PDS UI</StyledText>
    </HStack>
  );
}

const StyledText = styled.p`
  ${text_styles.Body_14_SemiBold};
  color: ${colors.gray600};
`;

개발

μš”κ΅¬λ˜λŠ” 개발 ν™˜κ²½

Node.js v20+, Yarn v1.22+

λ‘œμ»¬μ— 클둠된 λ ˆν¬μ§€ν† λ¦¬λ‘œ μ΄λ™ν•˜μ—¬, node_modulesλ₯Ό μ„€μΉ˜ν•©λ‹ˆλ‹€.

yarn

μŠ€ν† λ¦¬λΆμ„ 톡해 ν™•μΈν•˜κΈ° μœ„ν•΄μ„  λ‹€μŒ λͺ…λ Ήμ–΄λ₯Ό μ‹€ν–‰ν•©λ‹ˆλ‹€. (λΈŒλΌμš°μ €μ—μ„œ http://localhost:6006/ 둜 μ΄λ™ν•˜μ„Έμš”.)

yarn storybook

ꡬ쑰

β”œβ”€β”€ assets
β”‚   β”œβ”€β”€ icons
β”‚   └── images
β”œβ”€β”€ src
β”‚   β”œβ”€β”€ components
β”‚   β”‚   β”œβ”€β”€[COMPONENT]
β”‚   β”‚   β”‚   β”œβ”€β”€ index.ts
β”‚   β”‚   β”‚   β”œβ”€β”€ [COMPONENT].tsx
β”‚   β”‚   β”‚   β”œβ”€β”€ [COMPONENT].mdx
β”‚   β”‚   β”‚   β”œβ”€β”€ types.ts
β”‚   β”‚   β”‚   └── styles.ts
β”‚   β”‚   β”œβ”€β”€ icons
β”‚   β”‚   β”‚   β”œβ”€β”€ generated
β”‚   β”‚   β”‚   β”œβ”€β”€ Icon.stories.tsx
β”‚   β”‚   β”‚   └── Icons.mdx
β”‚   β”‚   β”œβ”€β”€ images
β”‚   β”‚   β”‚   β”œβ”€β”€ generated
β”‚   β”‚   β”‚   β”œβ”€β”€ Image.stories.tsx
β”‚   β”‚   β”‚   └── Images.mdx
β”‚   β”œβ”€β”€ container
β”‚   β”‚   β”œβ”€β”€[CONTAINER]
β”‚   β”‚   β”‚   β”œβ”€β”€ index.ts
β”‚   β”‚   β”‚   β”œβ”€β”€ [CONTAINER].tsx
β”‚   β”‚   β”‚   β”œβ”€β”€ [CONTAINER].mdx
β”‚   β”‚   β”‚   β”œβ”€β”€ types.ts
β”‚   β”‚   β”‚   └── styles.ts
β”‚   β”œβ”€β”€ constants
β”‚   β”œβ”€β”€ foundation
β”‚   β”œβ”€β”€ global_styles
β”‚   β”œβ”€β”€ styles
β”‚   β”œβ”€β”€ hooks
β”‚   β”œβ”€β”€ stories
β”‚   β”œβ”€β”€ types
β”‚   β”œβ”€β”€ utils
β”‚   β”œβ”€β”€ locales
β”‚   └── index.ts
└── tools
    β”œβ”€β”€ svgr-icons-component-template.js
    β”œβ”€β”€ svgr-icons-template.js
    β”œβ”€β”€ svgr-images-component-template.js
    └── svgr-images-template.js
  • COMPONENT|CONTAINER: μ»΄ν¬λ„ŒνŠΈ 디렉토리 이름은 μ†Œλ¬Έμž, κ΅¬λΆ„μžλŠ” -둜 (eg. toggle-switch) μž‘μ„±ν•©λ‹ˆλ‹€. ν•˜μœ„μ—λŠ” κ΄€λ ¨ μ»΄ν¬λ„ŒνŠΈ 파일과 ν•΄λ‹Ή μ»΄ν¬λ„ŒνŠΈμ˜ μŠ€ν† λ¦¬λΆ(*.stories.tsx) νŒŒμΌμ„ ν¬ν•¨ν•©λ‹ˆλ‹€.
    • styles.ts, types.tsκ³Ό 같은 νŒŒμΌμ„ 포함할 수 μžˆμŠ΅λ‹ˆλ‹€.
    • μ»΄ν¬λ„ŒνŠΈλŠ” Named Exports ν•©λ‹ˆλ‹€.
    • 각 μ»΄ν¬λ„ŒνŠΈ 디렉토리와 src ν•˜μœ„μ˜ index.tsλ₯Ό 톡해 export ν•©λ‹ˆλ‹€.
  • global_styles: 리셋 μŠ€νƒ€μΌμ„ ν¬ν•¨ν•œ κΈ€λ‘œλ²Œ μŠ€νƒ€μΌμ„ ν¬ν•¨ν•©λ‹ˆλ‹€.
    • 리셋 μŠ€νƒ€μΌμ„ μœ„ν•œ class λ„€μž„μ€ prefix둜 pds-λ₯Ό λΆ™μ—¬μ€λ‹ˆλ‹€.
  • foundation: color, typography와 같은 themeκ³Ό κ΄€λ ¨λœ μŠ€νƒ€μΌ, μŠ€νƒ€μΌ 토큰을 ν¬ν•¨ν•©λ‹ˆλ‹€.
  • styles: μ»΄ν¬λ„ŒνŠΈμ— 곡용으둜 μ‚¬μš©ν•  μŠ€νƒ€μΌ, μŠ€νƒ€μΌ ν•¨μˆ˜λ₯Ό ν¬ν•¨ν•©λ‹ˆλ‹€.
  • hooks: μ»€μŠ€ν…€ 훅을 ν¬ν•¨ν•©λ‹ˆλ‹€.
  • stories: μŠ€ν† λ¦¬λΆμš© μ»΄ν¬λ„ŒνŠΈλ‚˜ μŠ€νƒ€μΌ, μ»΄ν¬λ„ŒνŠΈ μ™Έμ˜ μŠ€ν† λ¦¬λΆ λ¬Έμ„œ
  • utils: μ»΄ν¬λ„ŒνŠΈμ— 곡용으둜 μ‚¬μš©ν•  μœ ν‹Έλ¦¬ν‹° ν•¨μˆ˜λ“€μ„ ν¬ν•¨ν•©λ‹ˆλ‹€.
  • constants: μƒμˆ˜ μ •μ˜λ₯Ό ν¬ν•¨ν•©λ‹ˆλ‹€.
  • types: νƒ€μž… μ •μ˜λ₯Ό ν¬ν•¨ν•©λ‹ˆλ‹€.
  • assets: svg λ“±μ˜ 에셋을 ν¬ν•¨ν•©λ‹ˆλ‹€.
  • locales: κΈ°λ³Έν‘œκΈ°λ“±μ— μ‚¬μš©λ˜λŠ” 언어셋을 ν¬ν•¨ν•©λ‹ˆλ‹€.
  • tools: svgr template λ“±μ˜ 라이브러리 μ œμž‘μ„ μœ„ν•œ 슀크립트λ₯Ό ν¬ν•¨ν•©λ‹ˆλ‹€.

μ•„μ΄μ½˜ μΆ”κ°€

⚠️ SVGR을 톡해 svgνŒŒμΌμ„ λ¦¬μ•‘νŠΈ μ»΄ν¬λ„ŒνŠΈλ‘œ μ œλ„€λ ˆμ΄νŠΈν•©λ‹ˆλ‹€. src/[icons|images]/generated ν•˜μœ„μ—μ„œ 직접 μˆ˜μ •ν•˜μ§€ λ§μ•„μ£Όμ„Έμš”!

  • assets/icons, assets/images에 svgλ₯Ό μΆ”κ°€ν•©λ‹ˆλ‹€.
  • yarn svgr을 μ‹€ν–‰ν•©λ‹ˆλ‹€.
  • src/[icons|images]/generated ν•˜μœ„μ— μ œλ„€λ ˆμ΄νŠΈλœ μ•„μ΄μ½˜ λ¦¬μ•‘νŠΈ μ»΄ν¬λ„ŒνŠΈμ™€ src/[icons|images]/generated/index.ts에 ν•΄λ‹Ή μ»΄ν¬λ„ŒνŠΈμ˜ exportκ°€ μΆ”κ°€λœ 것을 ν™•μΈν•©λ‹ˆλ‹€.
  • yarn storybook을 μ‹€ν–‰ν•˜μ—¬ μŠ€ν† λ¦¬λΆ λ‚΄μ—μ„œ Icon/Icons, Image/Images λ©”λ‰΄λ‘œ μ΄λ™ν•˜μ—¬ λͺ©λ‘μ—μ„œ ν•΄λ‹Ή μ•„μ΄μ½˜μ΄ 잘 μΆ”κ°€λ˜μ—ˆλŠ”μ§€ ν™•μž…λ‹ˆλ‹€.

PR

  • main을 base 브랜치둜 ν•œ μž‘μ—… 브랜치λ₯Ό μƒμ„±ν•©λ‹ˆλ‹€.
  • 배포 및 버전관리λ₯Ό changeset을 톡해 κ΄€λ¦¬ν•˜κ³  μžˆμŠ΅λ‹ˆλ‹€. PR μƒμ„±μ‹œ changeset README.md λ¬Έμ„œλ₯Ό μ°Έκ³ ν•˜μ—¬ νŒŒμΌμ„ μƒμ„±ν•΄μ£Όμ„Έμš”.
  • PR 및 λ§ˆμŠ€ν„° 머지 μ‹œμ— chromatic으둜 μžλ™ λ°°ν¬λ©λ‹ˆλ‹€.

배포

Github Action을 톡해 μžλ™μœΌλ‘œ λ°°ν¬ν•˜κ³  μžˆμŠ΅λ‹ˆλ‹€.

changeset νŒŒμΌμ„ ν¬ν•¨ν•œ PR이 main에 λ¨Έμ§€λ˜λ©΄, Github Action μ›Œν¬ν”Œλ‘œμš°κ°€ λ™μž‘λ˜λ©°, 버전 배포λ₯Ό μœ„ν•œ Version Packages PR이 μƒμ„±λ©λ‹ˆλ‹€. ν•΄λ‹Ή PR을 λ¨Έμ§€ν•˜κ²Œ 되면 Github Action의 μ›Œν¬ν”Œλ‘œμš°κ°€ λ™μž‘λ˜λ©° νŒ¨ν‚€μ§€κ°€ λ°°ν¬λ©λ‹ˆλ‹€.

Github Action을 ν†΅ν•œ 배포가 λΆˆκ°€λŠ₯ν•  경우

npm κΆŒν•œμ΄ ν•„μš”ν•©λ‹ˆλ‹€. npm에 κ°€μž… ν›„ κΆŒν•œμ„ μš”μ²­ν•΄μ£Όμ„Έμš”.

  • Version Packages PR이 μƒμ„±λ˜μ§€ μ•Šμ•˜μ„ 경우, λ‹€μŒμ„ μˆ˜ν–‰ν•΄ changelog와 package.json을 version bumpλ₯Ό ν¬ν•¨ν•œ μž‘μ—… PR을 μƒμ„±ν•©λ‹ˆλ‹€.
yarn changeset version
git commit -m "chore: version bump"
  • Version Packages PR이 μƒμ„±λ˜μ—ˆμ„ 경우 ν•΄λ‹Ή PR을 λ¨Έμ§€ν•˜κ³  main을 μ΅œμ‹  μƒνƒœλ‘œ PULL λ°›μ•„μ£Όμ„Έμš”.
yarn release
8.19.2

3 days ago

8.19.1

9 days ago

8.18.0

11 days ago

8.17.0

17 days ago

8.16.3

19 days ago

8.16.2

24 days ago

8.16.1

25 days ago

8.16.0

1 month ago

8.14.1

1 month ago

8.15.0

1 month ago

8.12.1

1 month ago

8.13.0

1 month ago

8.14.0

1 month ago

8.12.0

1 month ago

8.11.0

1 month ago

8.10.4

2 months ago

8.10.3

2 months ago

8.10.2

2 months ago

8.10.1

2 months ago

8.10.0

2 months ago

8.9.2

2 months ago

8.9.1

2 months ago

8.8.3

3 months ago

8.9.0

3 months ago

8.8.2

3 months ago

8.8.1

3 months ago

8.8.0

3 months ago

8.6.0

3 months ago

8.5.1

3 months ago

8.4.0

3 months ago

8.5.0

3 months ago

8.4.0-next.0

3 months ago

8.3.0

3 months ago

8.2.1

3 months ago

8.2.0

4 months ago

8.1.0

4 months ago

8.2.0-next.0

4 months ago

8.2.0-next.1

4 months ago

7.5.0

4 months ago

8.0.0

4 months ago

7.4.0

4 months ago

7.3.2

4 months ago

7.3.1

4 months ago

7.3.0

4 months ago

7.3.0-next.2

4 months ago

7.3.0-next.0

4 months ago

7.3.0-next.1

4 months ago

7.1.2

5 months ago

7.2.0

5 months ago

7.1.1

5 months ago

7.0.0

5 months ago

7.0.1

5 months ago

7.1.0

5 months ago

6.6.1

5 months ago

6.6.0

5 months ago

6.5.0

5 months ago

6.4.3

5 months ago

6.4.2

6 months ago

6.4.4

5 months ago

6.5.1

5 months ago

4.9.0

9 months ago

4.9.1

9 months ago

5.8.1

7 months ago

5.8.0

7 months ago

5.0.0

9 months ago

4.8.5

9 months ago

4.8.4

9 months ago

4.8.1

10 months ago

4.8.0

10 months ago

4.8.3

9 months ago

4.8.2

9 months ago

4.7.0

10 months ago

5.9.0

7 months ago

5.1.0

9 months ago

4.7.5

10 months ago

4.7.2

10 months ago

4.7.1

10 months ago

4.7.4

10 months ago

4.7.3

10 months ago

4.6.0

10 months ago

5.2.0

9 months ago

6.0.1

7 months ago

6.0.0

7 months ago

4.5.0

10 months ago

5.3.2

9 months ago

5.3.1

9 months ago

5.3.0

9 months ago

6.1.0

6 months ago

6.1.1

6 months ago

4.4.1

10 months ago

4.4.0

10 months ago

4.4.2

10 months ago

5.4.1

9 months ago

5.4.0

9 months ago

6.2.0

6 months ago

4.3.1

10 months ago

4.3.0

10 months ago

5.5.0

8 months ago

6.3.0

6 months ago

6.3.1

6 months ago

4.2.2

10 months ago

4.2.1

10 months ago

4.2.0

10 months ago

5.6.1

8 months ago

5.6.0

8 months ago

6.4.1

6 months ago

6.4.0

6 months ago

4.1.4

10 months ago

4.1.3

10 months ago

4.1.6

10 months ago

4.1.5

10 months ago

5.7.0

8 months ago

4.1.2

11 months ago

4.1.0

11 months ago

4.1.1

11 months ago

3.2.1

1 year ago

3.2.0

1 year ago

3.6.0

12 months ago

3.12.0

11 months ago

3.10.0-alpha.0

11 months ago

3.10.0-alpha.5

11 months ago

3.10.0-alpha.6

11 months ago

3.10.0-alpha.1

11 months ago

4.0.0

11 months ago

3.10.0-alpha.2

11 months ago

3.10.0-alpha.3

11 months ago

3.10.0-alpha.4

11 months ago

3.1.1

1 year ago

3.5.1

12 months ago

3.5.0

1 year ago

3.9.0

11 months ago

3.4.0

1 year ago

3.8.0

12 months ago

3.10.0

11 months ago

3.4.3

1 year ago

3.4.2

1 year ago

3.4.1

1 year ago

4.0.0-next.0

11 months ago

3.8.3

12 months ago

3.8.2

12 months ago

3.8.1

12 months ago

3.3.1

1 year ago

3.3.0

1 year ago

3.11.0

11 months ago

3.7.0

12 months ago

2.4.1

1 year ago

2.4.0

1 year ago

2.4.2

1 year ago

2.8.1

1 year ago

2.8.0

1 year ago

2.3.0

1 year ago

2.7.0

1 year ago

3.1.0

1 year ago

2.2.1

1 year ago

2.2.2

1 year ago

2.6.0

1 year ago

3.0.1

1 year ago

3.0.0

1 year ago

2.5.0

1 year ago

1.2.1

1 year ago

2.0.0

1 year ago

1.1.0

1 year ago

2.2.0

1 year ago

1.3.0

1 year ago

2.1.2

1 year ago

2.1.1

1 year ago

2.1.0

1 year ago

1.0.1

1 year ago

1.0.0

1 year ago

0.47.5

1 year ago

0.43.0

1 year ago

0.41.0

1 year ago

0.46.2

1 year ago

0.46.0

1 year ago

0.42.4

1 year ago

0.46.1

1 year ago

0.42.5

1 year ago

0.44.0

1 year ago

0.42.2

1 year ago

0.42.3

1 year ago

0.42.0

1 year ago

0.42.1

1 year ago

0.47.3

1 year ago

0.45.5

1 year ago

0.47.4

1 year ago

0.47.1

1 year ago

0.45.3

1 year ago

0.47.2

1 year ago

0.45.4

1 year ago

0.45.1

1 year ago

0.47.0

1 year ago

0.45.2

1 year ago

0.45.0

1 year ago

0.38.1

1 year ago

0.38.0

1 year ago

0.36.0

1 year ago

0.34.0

1 year ago

0.30.3

1 year ago

0.32.0

1 year ago

0.30.2

1 year ago

0.30.1

1 year ago

0.30.0

1 year ago

0.29.0

2 years ago

0.27.0

2 years ago

0.25.0

2 years ago

0.29.2

1 year ago

0.29.1

1 year ago

0.40.2

1 year ago

0.40.3

1 year ago

0.40.0

1 year ago

0.40.1

1 year ago

0.39.0

1 year ago

0.37.1

1 year ago

0.37.0

1 year ago

0.35.1

1 year ago

0.35.0

1 year ago

0.33.2

1 year ago

0.33.1

1 year ago

0.33.0

1 year ago

0.31.1

1 year ago

0.31.0

1 year ago

0.28.0

2 years ago

0.26.0

2 years ago

0.20.0

2 years ago

0.19.0

2 years ago

0.18.1

2 years ago

0.18.2

2 years ago

0.18.0

2 years ago

0.24.3

2 years ago

0.24.2

2 years ago

0.24.1

2 years ago

0.23.2

2 years ago

0.23.1

2 years ago

0.23.0

2 years ago

0.22.0

2 years ago

0.21.1

2 years ago

0.12.0

2 years ago

0.13.0

2 years ago

0.14.0

2 years ago

0.11.3

2 years ago

0.15.0

2 years ago

0.16.0

2 years ago

0.17.0

2 years ago

0.11.2

2 years ago

0.11.1

2 years ago

0.11.0

2 years ago

0.10.1

2 years ago

0.10.0

2 years ago

0.9.0

2 years ago

0.8.0

2 years ago

0.7.2

2 years ago

0.7.1

2 years ago

0.7.0

2 years ago

0.6.0

2 years ago

0.5.2

2 years ago

0.5.1

2 years ago

0.5.0

2 years ago

0.4.0

2 years ago

0.3.0

2 years ago

0.2.0

2 years ago

0.1.0

2 years ago

0.0.1

2 years ago