ghdtjgus
article thumbnail
[와우 디자인 시스템 개발기] 코드 스플리팅 및 성능 최적화 (barrel file vs multiple entry point)

프로젝트를 진행하며 처음에 프로젝트 세팅한 거에서 조금 더 개선해 볼 만한 것들이 있어 번들링 최적화를 진행하게 되었다. 코드 스플리팅처음에 내가 세팅한 wow-ui 폴더를 살펴보도록 하자. 아래와 같이 components 폴더 내부에 각각 컴포넌트별 폴더를 생성했고, 이를 index.ts라는 배럴 파일을 통해 export 하도록 세팅했었다.export { default as Box } from "./Box";export { default as Button } from "./Button"; package.json 쪽에도 살펴보자면, 아래와 같았다.즉, 모든 타입, cjs 방식, esm 방식 각각 다 하나의 파일에서 export 하도록 되어 있었다."exports": {    "./styles.css": ..

article thumbnail
[와우 디자인 시스템 개발기] 롤업 번들링 시 use client 주석 삭제하는 문제 해결

우리는 이 디자인 시스템을 결국 next.js 14 버전에서 쓰려고 개발하고 있었다.그래서, 개발하는 컴포넌트마다 맨 위에 use client라는 주석을 달아주고 있었는데, 이는 리액트 훅 등의 클라이언트 단에서 쓰는 로직들을 문제없이 인식하도록 하기 위한 것이었다. 그런데, 디자인 시스템 컴포넌트들을 next.js 14 버전 프로젝트에서 실행해보니 아래와 같은 에러가 난다는 코드 리뷰를 받았다. 분명 나는 스위치 컴포넌트를 개발하면서 맨 위에 use client 주석을 달아줬었는데 왜 그런 거지?라는 생각에 좀 더 찾아보게 되었다.결국 문제는 롤업 번들링 과정이었는데, 지금 우리 디자인 시스템에서는 번들 크기를 조금이라도 더 줄이기 위해서 terser라는 플러그인을 사용하고 있었다.이 terser를 사..

article thumbnail
[와우 디자인 시스템 개발기] svg 파일 리액트 컴포넌트 변환 자동화 스크립트 작성

이번엔 svg 파일을 리액트 컴포넌트 방식으로 변환시켜 주는 자동화 스크립트를 작성했다. 이걸 한 이유는... svg 파일을 일일이 컴포넌트 방식으로 변환시켜 주는 게 너무 번거로워서 자동화할 방법이 없을까 싶어서였다.하고 보니까 너무 편하더라.그리고, 사실 스크립트 작성하면서 로직을 많이 생각해보는 과정에서 많이 공부할 수 있었던 거 같다.처음에는 단순히 svg 파일을 리액트 컴포넌트 파일로 변환만 하는 스크립트를 작성했었는데, svg 파일을 삭제하고 나서 다시 스크립트를 실행시켜도 기존에 변환된 컴포넌트 파일은 삭제되지 않아서 이 부분을 고려하는 과정에서 자료구조도 생각해 보고 로직도 개선했던 거 같다. 주요 로직내가 작성한 스크립트 파일은 generateReactComponentFromSvg라는 파..

[warrr-ui 디자인 시스템 개발기] 토큰 배포 및 자동화

이번 주 과제는 토큰 관리 방법 및 자동화에 대해서 생각해 보는 시간이었다. GDSC 와우 디자인 시스템에서도 warrr-ui처럼 panda css를 사용해서 개발하고 있었기 때문에 와우 디자인 시스템의 토큰 관리 방법을 많이 참고해서 생각해 볼 수 있었다. 와우 디자인 시스템 토큰 관리 방법일단, 와우 디자인 시스템에서는 wow-tokens라는 패키지에서 토큰 값들을 객체나 다른 구조가 아니라 string 값으로 관리하고 있다. 이는, 사용자가 원하는 대로 커스텀해서 사용하기 용이하게 하기 위해서 그렇다. 아래 링크를 들어가보면 어떤 방식으로 관리하고 있는지 한 번에 알아챌 거다. https://github.com/GDSC-Hongik/wow-design-system/tree/main/packages/..

[warrr-ui 디자인 시스템 개발기] 아이콘 배포 및 자동화

이번 주는 아이콘에 대해서 자세히 알아보는 시간을 가졌다.아이콘 npm 배포 및 자동화할 수 있는 방법이 있는지에 대해서 공부했다. 일단, 내가 GDSC 디자인 시스템을 개발하며 느꼈던 아이콘 관련 문제 상황은 다음과 같다.1. svg 파일들을 일일이 내 프로젝트에 넣어 두어야 한다.2. 해당 svg 파일을 리액트 컴포넌트 방식으로 변환해야 한다. 이 작업들을 수작업으로 하려다 보니 화가 났다.그래서, 어떻게 하면 이 두 가지를 자동화할 수 있는지에 대해서 조사했던 것 같다.다만, 시간 부족 이슈로 완전 자세하게는 못했는데, 다다음주에 직접 실습해 보면서 자세히 알아보려고 한다. 여러 디자인 시스템 아이콘 관리 방법 조사일단, 여러 디자인 시스템 깃허브 레포를 둘러보면서, 어떤 방식으로 관리하고 있는지 ..

[warrr-ui 디자인 시스템 개발기] 스토리북과 테스트

이번 주 주제는 스토리북과 테스트였다. 사실, 개발하면서 스토리북을 자주 썼지만,,, 여러 기능들을 활용해 본 것도 아니었고, 문서화를 제대로 한 것도 아니었다.그래서, 스토리북에 대해서 보다 알아가는 시간이 필요하다고 생각했었고, 문서화, 애드온, 테스트 관련해서 어떤 기능들이 있는지 알아보는 시간을 가졌다.그리고 테스트 관련해서도 정말 자잘하게 단위 테스트 작성해 본 게 다라서 우리 디자인 시스템에는 어떤 테스트를 적용하는 게 좋을지에 대해서도 생각해 보는 시간을 가졌다. 먼저 스토리북부터 알아보도록 하자. 스토리북 문서화스토리북 문서화는 상당히 중요하다.근데 나는 이때까지 제대로 한 적이 없었다. ㅋㅋ 이제부터 열심히 할게요!어쨌든 중요도를 따지는게 별 의미는 없겠지만, 디자인 시스템에 있어서 자세..

[warrr-ui 디자인 시스템 개발기] CI/CD

이번 주에는 cicd + changeset이라는 주제로 과제를 해오기로 했다. 이전에 cli 프로그램을 npm에 배포한 적이 있었는데 그때 changeset을 활용해서 배포해 봤기 때문에 이번에는 좀 더 새로운 걸 해보고 싶었다.cli 프로그램에 대해서 궁금한 사람은 아래 글을 읽어보도록 하자.https://gugu76.tistory.com/138 디자인 시스템에 적용할 액션 탐방어쨌든, 이번 주에는 우리 디자인 시스템에 써볼만한 액션들이 있는지 좀 둘러보는 시간을 가졌다.깃허브 마켓플레이스를 하나씩 둘러보면서 디자인 시스템에 적합한 게 있나 찾아봤다.생각보다 내가 몰랐던 것들이 많아서 신기해하면서 찾아봤다. 아래 액션들은 그렇게 찾아낸 것들이다. 아래 액션은 stark라는 웹 접근성 검사기 관련 액션인..

article thumbnail
[와우 디자인 시스템 개발기] 프로젝트 세팅

이번에는 씨엠씨 친구들과 하는 디자인 시스템이 아니다.GDSC Hongik이라는 단체에서 개발팀으로 참여하고 있는데, 여기서 개발하는 디자인 시스템에 관한 글이다.이름은 와우 디자인 시스템이다. warrr-ui 덕분에 계속해서 디자인 시스템 관련 공부를 해오다 보니, GDSC에서도 많이 적용해 볼 수 있었다.와우 디자인 시스템을 개발하기 위해서 약 5주간 공부를 해왔었는데, warrr-ui와 상당히 비슷한 플로우였다.다만, 다른 점은 시간적 제약으로 인해서 딥다이브까지는 못한 거 같다. GDSC에서 만드는 프로덕트는 약 300명의 학회원들이 실제로 사용해본다.그래서, 더 완성도 있게, 기한에 맞춰서 개발해야 한다. 이번에 개발하는 와우 디자인 시스템도 추후 GDSC 어드민, 스터디 서비스, 학회원들의 프..

검색 태그