bear2u / nextjs15-init
Install for your project team
Run this command in your project directory to install the skill for your entire team:
mkdir -p .claude/skills/nextjs15-init && curl -o .claude/skills/nextjs15-init/SKILL.md https://fastmcp.me/Skills/DownloadRaw?id=182
Project Skills
This skill will be saved in .claude/skills/nextjs15-init/ and checked into git. All team members will have access to it automatically.
Important: Please verify the skill by reviewing its instructions before using it.
Use when user wants to create a new Next.js 15 project (Todo/Blog/Dashboard/E-commerce/Custom domain) with App Router, ShadCN, Zustand, Tanstack Query, and modern Next.js stack
1 views
0 installs
Skill Content
---
name: nextjs15-init
description: Use when user wants to create a new Next.js 15 project (Todo/Blog/Dashboard/E-commerce/Custom domain) with App Router, ShadCN, Zustand, Tanstack Query, and modern Next.js stack
---
# NextJS 15 Init Skill
도메인 기반 Next.js 15 프로젝트를 생성하고 현대적인 스택으로 자동 설정합니다.
Todo, Blog, Dashboard, E-commerce 또는 Custom 도메인을 선택하여 App Router 기반의 완전한 CRUD 앱을 즉시 생성할 수 있습니다.
## Quick Start
스킬 실행 시 다음 정보를 입력받습니다:
- 폴더명 (예: my-todo-app)
- 프로젝트명 (예: todo-app)
- 도메인 선택 (Todo/Blog/Dashboard/E-commerce/Custom)
- 스택 프리셋 (Minimal/Essential/Full Stack/Custom)
그 후 자동으로 다음 단계가 실행됩니다:
```bash
# 1. Next.js 15 프로젝트 생성 (App Router, TypeScript, Tailwind)
npx create-next-app@latest [폴더명] --typescript --tailwind --app --use-npm
# 2. 패키지 설치
npm install
# 3. 도메인별 App Router 구조 자동 생성
# - app/[domain]/ (페이지)
# - components/[domain]/ (컴포넌트)
# - lib/stores/[domain].ts (Zustand 스토어)
# - lib/api/[domain].ts (API 로직)
# - lib/validations/[domain].ts (Zod 스키마)
# 4. 코드 품질 검증 (필수)
npm run lint
# 5. 개발 서버 실행
npm run dev
```
## Task Instructions
**IMPORTANT**: 이 스킬은 대화형으로 진행됩니다.
### Step 1: 도메인 및 프로젝트 설정 질문
**먼저 사용자에게 이렇게 물어보세요:**
"Next.js 15 앱을 생성합니다. 다음 정보를 알려주세요:
**1. 도메인(엔티티) 선택**
어떤 도메인의 앱을 만드시겠습니까?
**A) Todo (할 일 관리)**
- 필드: title, description, completed, createdAt, updatedAt
- 기능: CRUD, 필터링(전체/진행중/완료), 체크박스 토글
- API: /api/todos (GET, POST, PATCH, DELETE)
**B) Blog (블로그/CMS)**
- 필드: title, content, excerpt, slug, published, createdAt, updatedAt
- 기능: CRUD, 글 작성/수정, 목록/상세 페이지, 검색
- API: /api/posts (GET, POST, PATCH, DELETE)
**C) Dashboard (대시보드/어드민)**
- 필드: 통계, 차트 데이터, 사용자 관리
- 기능: 데이터 시각화, 테이블, 필터링, 페이지네이션
- API: /api/analytics, /api/users
**D) E-commerce (쇼핑몰)**
- 필드: name, price, description, images, stock, category
- 기능: 상품 목록/상세, 장바구니, 주문
- API: /api/products, /api/cart, /api/orders
**E) Custom (직접 정의)**
- 엔티티명과 필드를 직접 입력
**2. 프로젝트 정보**
- **폴더명**: 프로젝트를 생성할 폴더 이름 (기본값: [도메인]-app, 예: todo-app)
- 이 폴더에 Next.js 프로젝트가 생성됩니다
- **프로젝트명**: Next.js 프로젝트 이름 (기본값: 폴더명과 동일)
- package.json의 name 필드에 사용됩니다
**3. 스택 프리셋 선택**
다음 중 하나를 선택해주세요:
**A) Essential (권장)**
- ✅ Next.js 15 (App Router)
- ✅ TypeScript
- ✅ Tailwind CSS
- ✅ ShadCN/ui (UI 컴포넌트)
- ✅ Zustand (클라이언트 상태 관리)
- ✅ React Hook Form + Zod (폼 관리 + 검증)
- ✅ Lucide Icons
- ❌ Tanstack Query 제외
- ❌ Prisma 제외
- ❌ NextAuth 제외
**B) Minimal (가장 단순)**
- ✅ Next.js 15 (App Router)
- ✅ TypeScript
- ✅ Tailwind CSS
- ❌ ShadCN 제외
- ❌ Zustand 제외
- ❌ React Hook Form 제외
- ❌ 기타 라이브러리 제외
**C) Full Stack (모든 기능)**
- ✅ Next.js 15 (App Router)
- ✅ TypeScript
- ✅ Tailwind CSS
- ✅ ShadCN/ui
- ✅ Zustand (클라이언트 상태)
- ✅ Tanstack Query (서버 상태)
- ✅ React Hook Form + Zod
- ✅ Drizzle ORM (TypeScript-first ORM)
- ✅ Better Auth (인증)
- ✅ Framer Motion (애니메이션)
- ✅ Lucide Icons
**D) Custom (직접 선택)**
- 각 기능을 개별적으로 선택
어떤 도메인과 프리셋을 선택하시겠습니까? (도메인: A/B/C/D/E, 프리셋: A/B/C/D)"
### Step 2: Custom 선택 시 추가 질문
#### 2-1. Custom 도메인 (E) 선택 시:
1. **엔티티명**: 엔티티 이름을 입력하세요 (예: Product, Post, User)
2. **필드 정의**: 각 필드를 입력하세요 (형식: 필드명:타입, 예: title:string, price:number, isActive:boolean)
- 지원 타입: string, number, boolean, Date
- createdAt, updatedAt은 자동 추가됨
3. **주요 기능**: 필터링/정렬 기준이 될 필드를 선택하세요
#### 2-2. Custom 스택 프리셋 (D) 선택 시:
다음 질문들을 순차적으로 하세요:
1. **UI 컴포넌트**: ShadCN/ui를 사용하시겠습니까? (예/아니오)
2. **상태 관리**: Zustand를 사용하시겠습니까? (예/아니오)
3. **서버 상태**: Tanstack Query를 사용하시겠습니까? (예/아니오)
4. **폼 관리**: React Hook Form + Zod를 사용하시겠습니까? (예/아니오)
5. **데이터베이스**: Drizzle ORM을 사용하시겠습니까? (예/아니오)
6. **인증**: Better Auth를 사용하시겠습니까? (예/아니오)
7. **애니메이션**: Framer Motion을 사용하시겠습니까? (예/아니오)
### Step 3: 선택된 도메인과 스택에 따라 프로젝트 생성
1. **Next.js 15 프로젝트 생성**:
- 사용자가 지정한 **폴더명**으로 프로젝트 생성
- 명령어: `npx create-next-app@latest [폴더명] --typescript --tailwind --app --use-npm`
- 폴더명과 프로젝트명이 다른 경우, 생성 후 package.json의 `name` 필드를 수정
2. **선택된 패키지 설치**: `npm install [패키지들]`
3. **폴더 구조 생성**: App Router 기반 구조
```
app/
├── (auth)/
├── [domain]/
├── api/[domain]/
├── layout.tsx
└── page.tsx
components/
├── ui/ (ShadCN)
├── [domain]/
└── layouts/
lib/
├── db/ (Prisma)
├── stores/ (Zustand)
├── api/
├── utils/
└── validations/ (Zod)
```
4. **도메인별 보일러플레이트 생성**:
**A) Todo**: title, description, completed, createdAt, updatedAt
- API Routes: /api/todos (CRUD)
- Pages: /todos (리스트), /todos/[id] (상세)
- Components: TodoList, TodoItem, TodoForm
- Store: useTodoStore (Zustand)
- Validation: todoSchema (Zod)
**B) Blog**: title, content, excerpt, slug, published, createdAt, updatedAt
- API Routes: /api/posts (CRUD)
- Pages: /blog (목록), /blog/[slug] (상세), /blog/write (작성)
- Components: PostList, PostCard, PostEditor
- Store: usePostStore (Zustand)
- Validation: postSchema (Zod)
**C) Dashboard**: 통계, 차트, 사용자 관리
- API Routes: /api/analytics, /api/users
- Pages: /dashboard (메인), /dashboard/users (사용자)
- Components: Chart, StatsCard, DataTable
- Store: useDashboardStore (Zustand)
- Validation: userSchema (Zod)
**D) E-commerce**: name, price, description, images, stock, category
- API Routes: /api/products, /api/cart, /api/orders
- Pages: /products (목록), /products/[id] (상세), /cart (장바구니)
- Components: ProductCard, ProductGrid, Cart
- Store: useCartStore, useProductStore (Zustand)
- Validation: productSchema, cartSchema (Zod)
**E) Custom**: 사용자 정의 필드
- API Routes: 기본 CRUD
- Pages: 기본 List/Detail
- Components: 기본 CRUD 컴포넌트
- Store: 기본 store
- Validation: 기본 schema
5. **ShadCN 설치 및 구성** (Essential 이상):
```bash
npx shadcn@latest init
npx shadcn@latest add button card input form table
```
6. **코드 검증 및 오류 수정**:
a. `npm run lint` 실행
b. 발견된 오류 수정:
- **Import 경로**: @/ alias 사용 (tsconfig.json 설정)
- **TypeScript 타입**: 모든 타입 명시
- **ESLint 규칙**: 사용하지 않는 변수, import 제거
- **Next.js 규칙**: metadata, generateStaticParams 등
- **'use client' 지시어**: useState, useEffect 등 React Hooks 사용 시 파일 최상단에 추가
c. `npm run build` 또는 `pnpm build` 실행
d. 빌드 오류 수정:
- **TypeScript 타입 오류**: 타입 불일치, nullable 체크 누락 등
- **모듈 import 오류**: 경로 확인, 패키지 설치 확인
- **Server/Client Component 오류**: 적절한 'use client' 지시어 추가
- **Dynamic import 오류**: server-only 코드가 클라이언트에서 사용되지 않도록 확인
e. 재검증: lint와 build 모두 성공할 때까지 반복
f. 목표:
- `npm run lint` 결과가 "0 errors"
- `npm run build` 또는 `pnpm build` 성공
**✅ CRITICAL**: 이 단계는 필수입니다. lint와 build 모두 성공해야 다음 단계로 진행할 수 있습니다.
### Step 4: 최종 검증 및 안내
**✅ CRITICAL**: 이 단계는 프로젝트 완료의 필수 조건입니다. lint와 build 모두 성공해야 합니다.
1. **ESLint 검증**:
```bash
npm run lint
```
- ✅ **성공 예시**:
```
✔ No ESLint warnings or errors
```
- ❌ **실패 예시** (error가 있으면 반드시 수정):
```
Error: 'useState' is defined but never used
Error: Missing return type on function
```
2. **프로덕션 빌드 검증**:
```bash
npm run build
```
**또는 pnpm 사용 시**:
```bash
pnpm build
```
- ✅ **성공 예시**:
```
✓ Compiled successfully
✓ Linting and checking validity of types
✓ Collecting page data
✓ Generating static pages
```
- ❌ **실패 예시** (빌드 에러 발생 시 반드시 수정):
```
Type error: Property 'xyz' does not exist on type 'ABC'
Error: Module not found: Can't resolve '@/...'
```
**중요**: 빌드가 실패하면 TypeScript 타입 오류나 import 경로 문제를 수정하고 다시 빌드해야 합니다.
3. **검증 결과 요약** (lint와 build 모두 성공 시):
```
✅ Next.js 15 프로젝트 생성 완료!
✅ 패키지 설치 완료 (ShadCN, Zustand, Tanstack Query 등)
✅ ESLint 검증 통과 (0 errors)
✅ TypeScript 빌드 성공
✅ 프로덕션 빌드 완료
```
4. **프로젝트 정보 제공**:
- **폴더명**: [사용자 입력값] (예: my-todo-app)
- **프로젝트명**: [사용자 입력값] (예: todo-app)
- **도메인**: [선택된 도메인] (Todo/Blog/Dashboard/E-commerce/Custom)
- **선택된 스택**: [프리셋명] (ShadCN, Zustand, Tanstack Query 등)
- **주요 기능**: [도메인] CRUD, API Routes, 타입 안전성
- **생성된 파일**: XX개 TypeScript 파일 (app, components, lib)
5. **실행 방법 안내**:
```bash
cd [폴더명]
npm run dev
# http://localhost:3000 에서 확인
```
6. **다음 단계 제안** (선택사항, 도메인별):
- **Todo**: 항목 추가/수정/삭제, 필터링(전체/진행중/완료), 완료 토글
- **Blog**: 글 작성/수정, 목록/상세 페이지, 검색, 태그
- **Dashboard**: 데이터 시각화, 차트, 사용자 관리, 필터링
- **E-commerce**: 상품 목록/상세, 장바구니, 주문, 카테고리
- **공통**: TypeScript 타입 안전성, API 테스트, 배포 (Vercel)
## Core Principles
- **App Router**: Next.js 15 App Router 기반 구조
- **타입 안전성**: TypeScript Strict Mode
- **컴포넌트 재사용**: ShadCN/ui 활용
- **상태 관리**: Zustand (클라이언트), Tanstack Query (서버)
- **코드 품질**: ESLint + Prettier
- **폼 검증**: React Hook Form + Zod
## Reference Files
[references/setup-guide.md](references/setup-guide.md) - 완전한 가이드
- 기본 셋업 (도메인별 CRUD, API Routes, 컴포넌트)
- 선택 옵션: ShadCN, Zustand, Tanstack Query, Drizzle ORM, Better Auth, Framer Motion
## Notes
- **대화형 스킬**: 사용자에게 도메인과 프리셋 선택을 통해 맞춤형 앱 구성
- **도메인 지원**: Todo, Blog, Dashboard, E-commerce, Custom (사용자 정의)
- **프리셋 제공**: Full Stack, Essential, Minimal, Custom
- **선택 가능 기능**: ShadCN, Zustand, Tanstack Query, Drizzle ORM, Better Auth, Framer Motion
- **기본 포함**: Next.js 15 (App Router), TypeScript, Tailwind CSS, ESLint
- **플랫폼**: Web (Vercel 최적화)
- **품질 보증**:
- 모든 프로젝트는 `npm run lint` 통과 필수
- TypeScript Strict Mode
- 타입 안전성 보장
- App Router 패턴 준수
- 도메인별 최적화된 UI/UX
<!--
PROGRESSIVE DISCLOSURE GUIDELINES:
- Keep this file ~50 lines total (max ~150 lines)
- Use 1-2 code blocks only (recommend 1)
- Keep description <200 chars for Level 1 efficiency
- Move detailed docs to references/ for Level 3 loading
- This is Level 2 - quick reference ONLY, not a manual
-->