bear2u

nextjs15-init

710
189
# Install this skill:
npx skills add bear2u/my-skills --skill "nextjs15-init"

Install specific skill from multi-skill repository

# 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

# SKILL.md


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)

그 후 자동으로 다음 단계가 실행됩니다:

# 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)
  3. 지원 타입: string, number, boolean, Date
  4. createdAt, updatedAt은 자동 추가됨
  5. 주요 기능: 필터링/정렬 기준이 될 필드를 선택하세요

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 프로젝트 생성:
  2. 사용자가 지정한 폴더명으로 프로젝트 생성
  3. 명령어: npx create-next-app@latest [폴더명] --typescript --tailwind --app --use-npm
  4. 폴더명과 프로젝트명이 다른 경우, 생성 후 package.json의 name 필드를 수정

  5. 선택된 패키지 설치: npm install [패키지들]

  6. 폴더 구조 생성: 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)

  7. 도메인별 보일러플레이트 생성:

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

  1. ShadCN 설치 및 구성 (Essential 이상):
    bash npx shadcn@latest init npx shadcn@latest add button card input form table

  2. 코드 검증 및 오류 수정:

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

  2. 성공 예시:
    ✔ No ESLint warnings or errors

  3. 실패 예시 (error가 있으면 반드시 수정):
    Error: 'useState' is defined but never used Error: Missing return type on function

  4. 프로덕션 빌드 검증:
    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 경로 문제를 수정하고 다시 빌드해야 합니다.

  1. 검증 결과 요약 (lint와 build 모두 성공 시):
    ✅ Next.js 15 프로젝트 생성 완료! ✅ 패키지 설치 완료 (ShadCN, Zustand, Tanstack Query 등) ✅ ESLint 검증 통과 (0 errors) ✅ TypeScript 빌드 성공 ✅ 프로덕션 빌드 완료

  2. 프로젝트 정보 제공:

  3. 폴더명: [사용자 입력값] (예: my-todo-app)
  4. 프로젝트명: [사용자 입력값] (예: todo-app)
  5. 도메인: [선택된 도메인] (Todo/Blog/Dashboard/E-commerce/Custom)
  6. 선택된 스택: [프리셋명] (ShadCN, Zustand, Tanstack Query 등)
  7. 주요 기능: [도메인] CRUD, API Routes, 타입 안전성
  8. 생성된 파일: XX개 TypeScript 파일 (app, components, lib)

  9. 실행 방법 안내:
    bash cd [폴더명] npm run dev # http://localhost:3000 에서 확인

  10. 다음 단계 제안 (선택사항, 도메인별):

  11. Todo: 항목 추가/수정/삭제, 필터링(전체/진행중/완료), 완료 토글
  12. Blog: 글 작성/수정, 목록/상세 페이지, 검색, 태그
  13. Dashboard: 데이터 시각화, 차트, 사용자 관리, 필터링
  14. E-commerce: 상품 목록/상세, 장바구니, 주문, 카테고리
  15. 공통: 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 - 완전한 가이드
- 기본 셋업 (도메인별 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

# Supported AI Coding Agents

This skill is compatible with the SKILL.md standard and works with all major AI coding agents:

Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.