Next.js와 Tailwind를 이용한 모-던 어드민 템플릿
누구나 손쉽고 빠르게 백오피스 페이지를 개발할 수 있도록 인기있는 라이브러리를 모아 만든 Next.js + Tailwind + Ant Design 기반 어드민 템플릿입니다. 어드민 개발만 10년째..
Warning This is work in progress. 필요한 설명이나 기능/버그가 있으면 이슈에 등록해주세요. 순차적으로 검토 후 업데이트 하겠습니다.
- 어드민 페이지 만드는데 디자인하기 귀찮은 백엔드 프로그래머
- Next.js/React 기반에 자주 사용하는 라이브러리를 묶어 놓은 템플릿이 필요한 분
- ...
https://admin-ui.purple.io/login
OAuth(Google/GitHub) 또는 아이디/패스워드(admin/admin)으로 로그인하세요.
Deploy
버튼을 클릭하여 소스를 복제하고 vercel에 배포하여 테스트 할 수 있습니다.
소스를 다운로드하거나 다음 명령어를 입력하여 프로젝트를 시작할 수 있습니다.
# npm
npx create-next-app --example "https://github.com/purpleio/purple-admin-ui"
# yarn
yarn create next-app --example "https://github.com/purpleio/purple-admin-ui"
# pnpm
pnpm create next-app --example "https://github.com/purpleio/purple-admin-ui"
.env.example
파일을 복사하여 .env
파일을 생성합니다.
cp .env.example .env
키 | 설명 | 예시 |
---|---|---|
NEXTAUTH_URL | 서비스 URL | http://localhost:3000 |
NEXTAUTH_SECRET | 랜덤 비밀 키 | 랜덤생성기 발급 |
GITHUB_CLIENT_ID | GitHub OAuth Client ID | |
GITHUB_CLIENT_SECRET | GitHub OAuth Client Secret | |
GOOGLE_CLIENT_ID | Google OAuth Client ID | |
GOOGLE_CLIENT_SECRET | Google OAuth Client Secret | |
NEXT_PUBLIC_API_ENDPOINT | API 서버 엔드포인트 | http://localhost:3000 |
NEXT_PUBLIC_CODENBUTTER_SITE_ID | 팝업 플러그인 | 코드앤버터 사이트 아이디 |
샘플 코드를 통해 기본적인 사용법을 확인할 수 있습니다.
API 서버 (mock data)
일반적으로 백엔드 서버를 분리하는 경우가 많지만 간단한 테스트를 위한 샘플 코드입니다.
- src/pages/api/sample/dashboard.ts: 통계 조회
- src/pages/api/sample/products/index.ts: 상품 목록 조회 API
- src/pages/api/sample/products/[id].ts: 상품 CRUD API
API 클라이언트
프론트엔드에서 API를 호출하기 위한 함수를 모아 놓은 샘플 코드입니다.
API와 관련된 코드와 Type을 관리합니다.
- src/client/sample/dashboard.ts: 통계 조회 API
- src/client/sample/product.ts: 상품 CRUD / Type
페이지
대시보드와 상품 CRUD 샘플 페이지입니다.
세부사항은 src/components/page/[동일한 페이지 경로]
에 컴포넌트로 분리합니다.
- src/pages/index.tsx: 대시보드
- src/pages/sample/product/list.tsx: 상품 목록
- src/pages/sample/product/new.tsx: 상품 등록
- src/pages/sample/product/edit/[id].tsx: 상품 수정
컴포넌트
여러가지 라이브러리를 섞어 보기 좋게 만든 샘플 코드입니다.
통계, 검색, 리스트, 입력폼등 기본 기능을 확인할 수 있습니다.
- src/components/page/index/calendar-sample.tsx: 캘린더 샘플 컴포넌트
- src/components/page/index/statistic-sample.tsx: 통계 샘플 컴포넌트
- src/components/page/sample/product/product-form.tsx: 상품 입력폼 (생성/수정 공통 사용) 컴포넌트
- src/components/page/sample/product/product-list.tsx: 상품 목록 컴포넌트
- src/components/page/sample/product/product-search.tsx: 상품 검색 컴포넌트
샘플 이미지
- public/sample: 샘플 이미지
- Vercel – Next.js 애플리케이션 배포 서비스
- Tailwind CSS – Utility-first CSS framework
- Ant Design – 다양한 관리자 컴포넌트를 지원하는 UI 라이브러리
- Lucide – SVG 아이콘 모음
- Framer Motion – 애니메이션 라이브러리
- React CountUp - 카운팅 애니메이션
- @next/font – 웹폰트 최적화 라이브러리
- quill – 위지윅 텍스트 에디터
- codemirror – 코드 에디터
- TypeScript – Strongly typed programming language that builds on JavaScript
- Prettier – Opinionated Code Formatter
- ESLint – The pluggable linting utility for JavaScript and JSX
- Pretendard – 어느 플랫폼에서든 사용할 수 있는 system-ui 대체 글꼴
- Day.js – 날짜/시간 라이브러리
- swr - 데이터 조회를 위한 Hooks
- ky - 작고 우아한 HTTP 클라이언트
- numeral - 숫자 포멧팅 라이브러리
- codenbutter - 공지 팝업
- 인증을 제외한 모든 페이지를 정적 페이지로 제공합니다. (SSR 사용 X)
API가 죽어도 페이지는 뜹니다 - 비즈니스 로직은 백엔드 API로 제공하고 프론트엔드는 잘 표현하고 잘 전달하는 역할을 합니다.
- 폼과 관련된 부분은 Ant Design의 Form 컴포넌트를 적극적으로 사용합니다.
효율적인 관리를 위해 디렉토리 구조를 다음과 같이 정의합니다.
┌─ src
│ ├─ client # API 호출 코드
│ ├─ components
│ │ ├─ layout # 기본 레이아웃
│ │ ├─ page # 페이지별 세부 컴포넌트
│ │ └─ shared # 공통 컴포넌트
│ ├─ fonts # 웹폰트
│ ├─ lib
│ │ ├─ auth # 인증 관련 코드
│ │ └─ hooks # react hooks
│ ├─ pages # 페이지
│ ├─ styles # 기본 스타일
│ └─ types # 타입 정의
└─ public # 이미지등 정적 파일
src/client
- 각 컴포넌트에서 직접 fetch를 호출하지 않고 client 디렉토리에 정의한 함수를 사용
- 조회는
SWR
을 사용하고 POST나 PUT은ky
를 사용
src/components/layout
- 레이아웃 정의
src/components/page
- 특정 페이지에서만 사용하는 컴포넌트 정의
pages/profile
에서 사용하는 컴포넌트는components/page/profile
에 정의- component의 style은 같은 폴더에 module.css로 작성
src/components/shared
- 공통으로 사용하는 컴포넌트 정의
src/fonts
- 웹 폰트 저장
lib/auth
- 인증관련 코드 정의
lib/hooks
- 커스텀 훅 정의
DefaultTable
DefaultModal
FormSearch
FormSection
FormGroup
FieldInline
- IE 미지원
- subicura (@subicura)