Loading...
Loading...
Generate structured planning documentation for web projects with context-safe phases, verification criteria, and exit conditions. Creates IMPLEMENTATION_PHASES.md plus conditional docs (DATABASE_SCHEMA, API_ENDPOINTS, UI_COMPONENTS, CRITICAL_WORKFLOWS). Use when: starting new Cloudflare Workers/React projects, adding major features to existing apps, breaking large work into manageable phases, or need verified planning before coding begins.
npx skill4agent add ovachiever/droid-tings project-planning/plan-project/plan-project/plan-feature/plan-featureBefore generating planning docs, a few quick checks:
1. **Have you built a prototype or POC for this project?** (yes/no)
- If no: "I recommend building a small spike first to validate key assumptions (especially for new frameworks). Should I help you prototype first, or proceed with planning?"
2. **Any complex setup workflows or gotchas discovered?** (describe or skip)
- Examples: Database binding order, auth factory patterns, build configuration
- If described: "I'll create CRITICAL_WORKFLOWS.md to document these."
3. **Tech stack familiarity:** (expert/comfortable/learning)
- If learning: "I'll add extra time buffer (+30%) for learning curve in estimates."I'll help structure this project. A few questions to optimize the planning:
1. **Authentication**: Do users need accounts, or is this a public tool?
- If accounts: Social auth (Google/GitHub)? Roles/permissions?
2. **Data Model**: You mentioned [entities]. Any relationships I should know about?
- One-to-many? Many-to-many? Hierarchical?
3. **Key Features**: Which of these apply?
- Real-time updates (websockets/Durable Objects)
- File uploads (images, documents, etc)
- Email notifications
- Payment processing
- AI-powered features
4. **Scope**: Is this an MVP or full-featured app?
- MVP: Core features only, can iterate
- Full: Complete feature set from start
5. **Timeline**: Any constraints? (helps with phase sizing)⚠️ Phase 4 "Complete User Management" is too large (12 files, 8-10 hours).
Suggested split:
- Phase 4a: User CRUD API (5 files, 4 hours)
- Phase 4b: User Profile UI (6 files, 5 hours)# Implementation Phases: [Project Name]
**Project Type**: [Web App / Dashboard / API / etc]
**Stack**: Cloudflare Workers + Vite + React + D1
**Estimated Total**: [X hours] (~[Y minutes] human time)
---
## Phase 1: [Name]
**Type**: [Infrastructure/Database/API/UI/Integration/Testing]
**Estimated**: [X hours]
**Files**: [file1.ts, file2.tsx, ...]
**Tasks**:
- [ ] Task 1
- [ ] Task 2
- [ ] Task 3
- [ ] Test basic functionality
**Verification Criteria**:
- [ ] Specific test 1
- [ ] Specific test 2
- [ ] Specific test 3
**Exit Criteria**: [Clear definition of when this phase is complete]
---
## Phase 2: [Name]
[... repeat structure ...]
---
## Notes
**Testing Strategy**: [Inline per-phase / Separate testing phase / Both]
**Deployment Strategy**: [Deploy per phase / Deploy at milestones / Final deploy]
**Context Management**: Phases sized to fit in single session with verification# Database Schema: [Project Name]
**Database**: Cloudflare D1
**Migrations**: Located in `migrations/`
**ORM**: [Drizzle / Raw SQL / None]
---
## Tables
### `users`
**Purpose**: User accounts and authentication
| Column | Type | Constraints | Notes |
|--------|------|-------------|-------|
| id | INTEGER | PRIMARY KEY | Auto-increment |
| email | TEXT | UNIQUE, NOT NULL | Used for login |
| created_at | INTEGER | NOT NULL | Unix timestamp |
**Indexes**:
- `idx_users_email` on `email` (for login lookups)
**Relationships**:
- One-to-many with `tasks`
---
### `tasks`
[... repeat structure ...]
---
## Migrations
### Migration 1: Initial Schema
**File**: `migrations/0001_initial.sql`
**Creates**: users, tasks tables
### Migration 2: Add Tags
**File**: `migrations/0002_tags.sql`
**Creates**: tags, task_tags tables
---
## Seed Data
For development, seed with:
- 3 sample users
- 10 sample tasks across users
- 5 tags# API Endpoints: [Project Name]
**Base URL**: `/api`
**Auth**: Clerk JWT (custom template with email + metadata)
**Framework**: Hono (on Cloudflare Workers)
---
## Authentication
### POST /api/auth/verify
**Purpose**: Verify JWT token
**Auth**: None (public)
**Request**:
```json
{
"token": "string"
}{ "valid": true, "email": "user@example.com" }{ "error": "Invalid token" }{ "id": 1, "email": "user@example.com", "created_at": 1234567890 }{
"error": "Human-readable message",
"code": "ERROR_CODE",
"details": {} // optional
}
### ARCHITECTURE.md Template
```markdown
# Architecture: [Project Name]
**Deployment**: Cloudflare Workers
**Frontend**: Vite + React (served as static assets)
**Backend**: Worker handles API routes
---
## System Overview
---
## Data Flow
### User Authentication
1. User submits login form
2. Frontend sends credentials to Clerk
3. Clerk returns JWT
4. Frontend includes JWT in API requests
5. Worker middleware verifies JWT
6. Protected routes accessible
### Task Creation
1. User submits task form
2. Frontend validates with Zod
3. POST /api/tasks with validated data
4. Worker validates again server-side
5. Insert into D1 database
6. Return created task
7. Frontend updates UI via TanStack Query
[... more flows as needed ...]
---
## Service Boundaries
**Frontend Responsibilities**:
- User interaction
- Client-side validation
- Optimistic updates
- State management (TanStack Query + Zustand)
**Worker Responsibilities**:
- Request routing
- Authentication/authorization
- Server-side validation
- Business logic
- Database operations
- Third-party API calls
**Cloudflare Services**:
- D1: Persistent relational data
- R2: File storage (images, documents)
- KV: Configuration, feature flags, cache
---
## Security
**Authentication**: Clerk JWT with custom claims
**Authorization**: Middleware checks user ownership before mutations
**Input Validation**: Zod schemas on client AND server
**CORS**: Restricted to production domain
**Secrets**: Environment variables in wrangler.jsonc (not committed)# UI Components: [Project Name]
**Framework:** shadcn/ui + Tailwind v4
**Installation:** Components copied to @/components/ui (fully customizable)
**Strategy:** Install components as needed per phase (not all upfront)
---
## Installation Strategy: By Phase
### Phase [N]: [Phase Name] ([X] components)
**When:** During [description of when this phase happens]
**Components:**
- `button` - [specific use cases in this phase]
- `input` - [specific use cases]
- `card` - [specific use cases]
[... list all components for this phase ...]
**Install:**
\`\`\`bash
pnpm dlx shadcn@latest add button input card [...]
\`\`\`
**Usage:** [Which routes/features use these]
**Critical Notes:**
- [Any gotchas, e.g., "Use sonner instead of toast for better UX"]
- [Component-specific warnings, e.g., "data-table essential for TanStack Table integration"]
---
[Repeat for each phase...]
---
## Quick Reference Commands
### MVP Install (All Core Components)
\`\`\`bash
pnpm dlx shadcn@latest add button input label card sonner [essential components...]
\`\`\`
### Full Featured Install
\`\`\`bash
pnpm dlx shadcn@latest add button input [all components...]
\`\`\`
### Update All Components
\`\`\`bash
pnpm dlx shadcn@latest update
\`\`\`
---
## Component Usage by Route
### [Route Name] (\`/route\`)
- [List of components used]
[Repeat for each major route...]
---
## Design Decisions
### [Component Choice 1]
**Recommendation:** [Chosen component]
**Why:** [Justification]
**Alternatives considered:** [What else was evaluated]
**Savings:** [Time/token savings if applicable]
[Repeat for each significant component decision...]
---
## Component Count Breakdown
### By Category
- **Forms:** X components ([list])
- **Data Display:** X components ([list])
- **Feedback:** X components ([list])
- **Layout:** X components ([list])
- **Navigation:** X components ([list])
### By Priority
- **Essential (MVP):** X components
- **Recommended:** X additional components
- **Optional (Enhanced UX):** X additional components
---
## Installation Checklist
### Phase [N]: [Name] ✅
- [ ] component1
- [ ] component2
[...]
[Repeat for each phase...]
---
## Best Practices
1. **Install as Needed** - Don't install all components upfront. Add them when implementing the feature.
2. **Customize After Installation** - All components copied to @/components/ui are fully customizable.
3. **Keep Components Updated** - Run \`pnpm dlx shadcn@latest update\` periodically.
4. **Check for New Components** - shadcn/ui adds new components regularly.
5. **Dark Mode Works Automatically** - All components respect Tailwind v4 theming.
6. **Bundle Size Optimization** - Only installed components are included - unused code is tree-shaken.
---
## References
- **shadcn/ui Docs:** https://ui.shadcn.com/docs/components
- **Tailwind v4 Integration:** See \`tailwind-v4-shadcn\` skill
- **Component Installation:** https://ui.shadcn.com/docs/installation/vite# Critical Workflows: [Project Name]
**Purpose:** Document non-obvious setup steps and order-sensitive workflows to prevent getting stuck
**Date:** [YYYY-MM-DD]
---
## ⚠️ [Workflow Name 1] ([Phase it applies to])
**STOP! Read this before [starting X].**
**Context:** [Why this workflow is tricky]
**Order matters:**
1. [Step 1 with specific command/action]
2. [Step 2]
3. [Step 3]
[...]
**Why this order:** [Explanation of what breaks if done wrong]
**Code Example:**
\`\`\`bash
# Step 1: [Description]
[command]
# Step 2: [Description]
[command]
\`\`\`
**Common Mistake:** [What people typically do wrong]
**Fix if broken:** [How to recover]
---
## ⚠️ [Workflow Name 2]
[Repeat structure...]
---
## Quick Checklist
Before starting each phase, check if it has critical workflows:
- [ ] Phase [N]: [Workflow name] (see above)
- [ ] Phase [N+1]: No critical workflows
- [ ] Phase [N+2]: [Workflow name] (see above)
---
## References
- **[Link to official docs]**
- **[Link to GitHub issue explaining gotcha]**
- **[Link to skill that prevents this issue]**# Installation Commands: [Project Name]
**Purpose:** Copy-paste commands for each phase (no more "what was that command again?")
**Date:** [YYYY-MM-DD]
---
## Phase 0: Planning
[None - just docs]
---
## Phase 1: [Phase Name]
### Scaffold Project
\`\`\`bash
npm create cloudflare@latest -- --framework=[framework]
cd [project-name]
\`\`\`
### Install Dependencies
\`\`\`bash
pnpm add [packages]
pnpm add -D [dev-packages]
\`\`\`
### Initialize Tools
\`\`\`bash
npx [tool] init
\`\`\`
### Verify Setup
\`\`\`bash
pnpm dev
# Should see: [expected output]
\`\`\`
---
## Phase 2: [Phase Name]
[Repeat structure for each phase...]
---
## Database Commands (Phase [N])
### Create Database
\`\`\`bash
npx wrangler d1 create [db-name]
# Copy database_id and add to wrangler.jsonc under [[d1_databases]]
\`\`\`
### Run Migrations
\`\`\`bash
# Local (dev)
npx wrangler d1 execute [db-name] --local --file=migrations/0001_initial.sql
# Production
npx wrangler d1 execute [db-name] --remote --file=migrations/0001_initial.sql
\`\`\`
### Query Database
\`\`\`bash
# Local
npx wrangler d1 execute [db-name] --local --command="SELECT * FROM users"
# Production
npx wrangler d1 execute [db-name] --remote --command="SELECT * FROM users"
\`\`\`
---
## Deployment Commands
### Deploy to Cloudflare
\`\`\`bash
npm run build
npx wrangler deploy
\`\`\`
### Set Production Secrets
\`\`\`bash
npx wrangler secret put [SECRET_NAME]
# Enter value when prompted
\`\`\`
### Check Deployment
\`\`\`bash
npx wrangler tail
# Watch logs in real-time
\`\`\`
---
## Development Commands
### Start Dev Server
\`\`\`bash
pnpm dev
\`\`\`
### Run Tests
\`\`\`bash
pnpm test
\`\`\`
### Lint & Format
\`\`\`bash
pnpm lint
pnpm format
\`\`\`
---
## Troubleshooting Commands
### Clear Build Cache
\`\`\`bash
rm -rf dist/ .wrangler/
pnpm dev
\`\`\`
### Check Wrangler Version
\`\`\`bash
npx wrangler --version
# Should be: [expected version]
\`\`\`
### Verify Bindings
\`\`\`bash
npx wrangler d1 list
npx wrangler r2 bucket list
\`\`\`# Environment Variables: [Project Name]
**Purpose:** All secrets, API keys, and configuration needed for this project
**Date:** [YYYY-MM-DD]
---
## Development (.dev.vars)
**File:** \`.dev.vars\` (local file, NOT committed to git)
\`\`\`bash
# Auth
CLERK_PUBLISHABLE_KEY=pk_test_...
CLERK_SECRET_KEY=sk_test_...
# Database
DATABASE_URL=local
# API Keys
[SERVICE]_API_KEY=[value]
# Feature Flags
ENABLE_[FEATURE]=true
\`\`\`
**How to get these keys:**
1. **Clerk Keys:** https://dashboard.clerk.com → API Keys
2. **[Other Service]:** [Steps to obtain]
---
## Production (wrangler.jsonc secrets)
**Secrets (set via CLI):**
\`\`\`bash
# Set via: npx wrangler secret put SECRET_NAME
CLERK_SECRET_KEY=sk_live_...
[SERVICE]_API_KEY=[production-value]
\`\`\`
**Bindings (configured in wrangler.jsonc):**
\`\`\`jsonc
{
"name": "[project-name]",
"d1_databases": [
{
"binding": "DB",
"database_name": "[db-name]",
"database_id": "[copy from wrangler d1 create output]"
}
],
"r2_buckets": [
{
"binding": "BUCKET",
"bucket_name": "[bucket-name]"
}
],
"kv_namespaces": [
{
"binding": "KV",
"id": "[namespace-id]"
}
]
}
\`\`\`
---
## Environment Variable Reference
| Variable | Required | Where Used | Notes |
|----------|----------|------------|-------|
| CLERK_PUBLISHABLE_KEY | Yes | Frontend | Public, safe to commit in example files |
| CLERK_SECRET_KEY | Yes | Worker | SECRET - never commit |
| DATABASE_URL | Local only | Development | Points to local .wrangler/state |
| [OTHER_VAR] | [Yes/No] | [Where] | [Notes] |
---
## Setup Checklist
### Local Development
- [ ] Create \`.dev.vars\` in project root
- [ ] Add \`.dev.vars\` to \`.gitignore\` (should already be there)
- [ ] Copy values from \`.dev.vars.example\` (if exists)
- [ ] Get API keys from services (links above)
- [ ] Run \`pnpm dev\` to verify
### Production Deployment
- [ ] Set all secrets via \`npx wrangler secret put\`
- [ ] Configure all bindings in \`wrangler.jsonc\`
- [ ] Deploy: \`npx wrangler deploy\`
- [ ] Verify secrets are set: \`npx wrangler secret list\`
- [ ] Test production deployment
---
## Security Notes
**Never commit:**
- \`.dev.vars\`
- Any file with actual secret values
- Production API keys
**Safe to commit:**
- \`.dev.vars.example\` (with placeholder values)
- \`wrangler.jsonc\` (bindings config, NOT secret values)
- Public keys (Clerk publishable key, etc.)
**If secrets leaked:**
1. Rotate all affected keys immediately
2. Update production secrets: \`npx wrangler secret put [KEY]\`
3. Revoke old keys in service dashboards
4. Check git history for leaked secrets
---
## References
- **Cloudflare Secrets:** https://developers.cloudflare.com/workers/configuration/secrets/
- **Wrangler Configuration:** https://developers.cloudflare.com/workers/wrangler/configuration/
- **[Service] API Docs:** [link]# Session State
**Current Phase**: Phase 0 (Planning)
**Current Stage**: Planning
**Last Checkpoint**: None yet
**Planning Docs**: \`docs/IMPLEMENTATION_PHASES.md\`, \`docs/CRITICAL_WORKFLOWS.md\` (if exists)
---
## Phase 0: Planning ✅
**Completed**: [YYYY-MM-DD]
**Summary**: Planning docs created
**Deliverables**: [List generated docs]
## Phase 1: [Name] ⏸️
**Spec**: \`docs/IMPLEMENTATION_PHASES.md#phase-1\`
**Type**: [Infrastructure/Database/API/UI/Integration]
**Time**: [X hours]
**Progress**: Not started
**Next Action**: [Specific file + line + what to do]
## Phase 2: [Name] ⏸️
**Spec**: \`docs/IMPLEMENTATION_PHASES.md#phase-2\`
**Type**: [Type]
**Time**: [X hours]
**Progress**: Not started
[Collapse remaining phases to 2-3 lines each...]
---
## Critical Reminders
**Before Starting:**
- [ ] Read \`docs/CRITICAL_WORKFLOWS.md\` (if exists)
- [ ] Review \`docs/INSTALLATION_COMMANDS.md\` for phase commands
- [ ] Check \`docs/ENV_VARIABLES.md\` for required secrets
**Critical Workflows:**
[Link to specific workflows from CRITICAL_WORKFLOWS.md, if exists]
---
## Known Risks
**High-Risk Phases:**
- Phase [N]: [Name] - [Why risky]
- Phase [N+1]: [Name] - [Why risky]
**Mitigation:** [Strategy]
---
**Status Legend**: ⏸️ Pending | 🔄 In Progress | ✅ Complete | 🚫 Blocked | ⚠️ Issues### File Map
- `src/routes/tasks.ts` (estimated ~150 lines)
- **Purpose**: CRUD endpoints for tasks
- **Key exports**: GET, POST, PATCH, DELETE handlers
- **Dependencies**: schemas.ts (validation), auth.ts (middleware), D1 binding
- **Used by**: Frontend task components
- `src/lib/schemas.ts` (estimated ~80 lines)
- **Purpose**: Zod validation schemas for request/response
- **Key exports**: taskSchema, createTaskSchema, updateTaskSchema
- **Dependencies**: zod package
- **Used by**: routes/tasks.ts, frontend forms
- `src/middleware/auth.ts` (existing, no changes)
- **Purpose**: JWT verification middleware
- **Used by**: All authenticated routes### Data Flow
\`\`\`mermaid
sequenceDiagram
participant C as Client
participant W as Worker
participant A as Auth Middleware
participant V as Validator
participant D as D1 Database
C->>W: POST /api/tasks
W->>A: authenticateUser()
A->>W: user object
W->>V: validateSchema(createTaskSchema)
V->>W: validated data
W->>D: INSERT INTO tasks
D->>W: task record
W->>C: 201 + task JSON
\`\`\`### Data Flow
\`\`\`mermaid
flowchart TB
A[TaskList Component] --> B{Has Tasks?}
B -->|Yes| C[Render TaskCard]
B -->|No| D[Show Empty State]
C --> E[TaskCard Component]
E -->|Edit Click| F[Open TaskDialog]
E -->|Delete Click| G[Confirm Delete]
F --> H[Update via API]
G --> I[Delete via API]
H --> J[Refetch Tasks]
I --> J
\`\`\`sequenceDiagramflowchart TB/LRgraph TDerDiagram### Critical Dependencies
**Internal** (codebase files):
- Auth middleware (`src/middleware/auth.ts`)
- Zod schemas (`src/lib/schemas.ts`)
- D1 binding (via `env.DB`)
**External** (npm packages):
- `zod` - Schema validation
- `hono` - Web framework
- `@clerk/backend` - JWT verification
**Configuration** (environment variables, config files):
- `CLERK_SECRET_KEY` - JWT verification key (wrangler.jsonc secret)
- None needed for this phase (uses JWT from headers)
**Cloudflare Bindings**:
- `DB` (D1 database) - Must be configured in wrangler.jsonc### Gotchas & Known Issues
**Ownership Verification Required**:
- PATCH/DELETE must check `task.user_id === user.id`
- Failing to check allows users to modify others' tasks (security vulnerability)
- Pattern: Fetch task, verify ownership, then mutate
**Pagination Required for GET**:
- Without pagination, endpoint returns ALL tasks (performance issue for users with 1000+ tasks)
- Max: 50 tasks per page
- Pattern: `SELECT * FROM tasks WHERE user_id = ? LIMIT ? OFFSET ?`
**Soft Delete Pattern**:
- Don't use `DELETE FROM tasks` (hard delete)
- Use `UPDATE tasks SET deleted_at = ? WHERE id = ?` (soft delete)
- Reason: Audit trail, undo capability, data recovery
**Timezone Handling**:
- Store all timestamps as UTC in database (INTEGER unix timestamp)
- Convert to user's timezone in frontend only
- Pattern: `new Date().getTime()` for storage, `new Date(timestamp)` for display## Phase 3: Tasks API
**Type**: API
**Estimated**: 4 hours (~4 minutes human time)
**Files**: `src/routes/tasks.ts`, `src/lib/schemas.ts`, `src/middleware/auth.ts` (modify)
### File Map
- `src/routes/tasks.ts` (estimated ~150 lines)
- **Purpose**: CRUD endpoints for tasks
- **Key exports**: GET, POST, PATCH, DELETE handlers
- **Dependencies**: schemas.ts, auth middleware, D1 binding
- `src/lib/schemas.ts` (add ~40 lines)
- **Purpose**: Task validation schemas
- **Key exports**: taskSchema, createTaskSchema, updateTaskSchema
- **Modifications**: Add to existing schema file
### Data Flow
\`\`\`mermaid
sequenceDiagram
Client->>Worker: POST /api/tasks
Worker->>AuthMiddleware: authenticateUser()
AuthMiddleware->>Worker: user object
Worker->>Validator: validateSchema(createTaskSchema)
Validator->>Worker: validated data
Worker->>D1: INSERT INTO tasks
D1->>Worker: task record
Worker->>Client: 201 + task JSON
\`\`\`
### Critical Dependencies
**Internal**: auth.ts, schemas.ts, D1 binding
**External**: zod, hono, @clerk/backend
**Configuration**: CLERK_SECRET_KEY (wrangler.jsonc)
**Bindings**: DB (D1)
### Gotchas & Known Issues
- **Ownership verification**: PATCH/DELETE must check task.user_id === user.id
- **Pagination required**: GET must limit to 50 tasks per page
- **Soft delete**: Use deleted_at timestamp, not hard DELETE
- **UTC timestamps**: Store as unix timestamp, convert in frontend
### Tasks
- [ ] Create task validation schemas in schemas.ts
- [ ] Implement GET /api/tasks endpoint with pagination
- [ ] Implement POST /api/tasks endpoint with validation
- [ ] Implement PATCH /api/tasks/:id with ownership check
- [ ] Implement DELETE /api/tasks/:id with soft delete
- [ ] Add error handling for invalid IDs
- [ ] Test all endpoints with valid/invalid data
### Verification Criteria
- [ ] GET /api/tasks returns 200 with array of tasks
- [ ] GET /api/tasks?page=2 returns correct offset
- [ ] POST /api/tasks with valid data returns 201 + created task
- [ ] POST /api/tasks with invalid data returns 400 + error details
- [ ] PATCH /api/tasks/:id updates task and returns 200
- [ ] PATCH /api/tasks/:id with wrong user returns 403
- [ ] DELETE /api/tasks/:id soft deletes (sets deleted_at)
- [ ] All endpoints return 401 without valid JWT
### Exit Criteria
All CRUD operations work correctly with proper status codes, validation, authentication, and ownership checks. Pagination prevents performance issues. Soft delete preserves data.### File Map
- src/routes/tasks.ts (CRUD endpoints)
- src/lib/schemas.ts (validation)## Phase 3: Tasks API 🔄
**Progress**:
- [x] GET /api/tasks endpoint (commit: abc123)
- [x] POST /api/tasks endpoint (commit: def456)
- [ ] PATCH /api/tasks/:id ← **CURRENT**
**Next Action**: Implement PATCH /api/tasks/:id in src/routes/tasks.ts:47, handle validation and ownership check
**Key Files** (from IMPLEMENTATION_PHASES.md file map):
- src/routes/tasks.ts
- src/lib/schemas.tsUser: "Add task endpoints"
Claude: [Reads 5-8 files via Glob/Grep to understand structure]
Claude: [Writes code in wrong location]
User: "That should be in routes/tasks.ts, not api/tasks.ts"
Claude: [Reads more files, rewrites code]User: "Add task endpoints"
Claude: [Reads IMPLEMENTATION_PHASES.md file map]
Claude: [Writes code in correct location on first try]create-cloudflare/docsUser: [Describes project]
↓
Skill: "I'll help structure this. A few questions..."
[Ask 3-5 targeted questions]
↓
User: [Answers]
↓
Skill: "Great! I'll generate:
- IMPLEMENTATION_PHASES.md
Should I also create DATABASE_SCHEMA.md? [Y/n]"
↓
User: [Confirms]
↓
Skill: ⚡ [Generates all confirmed docs immediately - this step is key!]
"Planning docs created in /docs:
- IMPLEMENTATION_PHASES.md (8 phases, ~15 hours)
- DATABASE_SCHEMA.md (4 tables)
Review these docs and let me know if any phases need adjustment.
When ready, we'll create SESSION.md and start Phase 1."I've structured your [Project Name] into [N] phases. Here's the planning documentation:
---
## IMPLEMENTATION_PHASES.md
[Full content of IMPLEMENTATION_PHASES.md]
---
## DATABASE_SCHEMA.md
[Full content of DATABASE_SCHEMA.md if generated]
---
[Additional docs if generated]
---
**Summary**:
- **Total Phases**: [N]
- **Estimated Duration**: [X hours] (~[Y minutes] human time)
- **Phases with Testing**: All phases include verification criteria
- **Deployment Strategy**: [When to deploy]
- **Docs Generated**: [List all docs created]
---
## ✅ Post-Generation Validation Checklist
**Files Created:**
- [ ] docs/IMPLEMENTATION_PHASES.md
- [ ] docs/SESSION.md (compact template)
- [ ] [Other generated docs...]
**Before Starting Phase 1:**
**Files:**
- [ ] All planning docs reviewed
- [ ] SESSION.md references correct file names (docs/IMPLEMENTATION_PHASES.md exists)
- [ ] CRITICAL_WORKFLOWS.md read (if exists)
- [ ] INSTALLATION_COMMANDS.md available for quick reference
- [ ] ENV_VARIABLES.md lists all required secrets
- [ ] "Next Action" in SESSION.md is concrete (file + line + what to do)
**Understanding:**
- [ ] Phase 1 tasks understood
- [ ] Phase dependencies clear (what blocks what)
- [ ] High-risk phases identified
- [ ] Timeline realistic (includes buffer for learning curve if needed)
- [ ] Critical workflows documented (D1 binding order, auth setup, etc.)
**Environment:**
- [ ] GitHub repo created (if needed)
- [ ] Development environment ready (Node.js, pnpm, CLI tools)
- [ ] Cloudflare account set up (if using Cloudflare)
- [ ] Wrangler CLI installed and authenticated (if using Cloudflare)
---
## ⚠️ Common Mistakes to Avoid
Before starting implementation, make sure you haven't made these common planning mistakes:
1. **SESSION.md too verbose** - Should be <200 lines, reference IMPLEMENTATION_PHASES.md instead of duplicating
2. **Missing IMPLEMENTATION_PHASES.md** - SESSION.md expects this file to exist
3. **No critical workflows** - If complex setup exists, must be documented in CRITICAL_WORKFLOWS.md
4. **Vague next action** - "Continue working on API" → Should be "Implement POST /api/tasks in src/routes/tasks.ts:47"
5. **Phase numbering confusion** - Document whether Phase 0 (Planning) exists or starts at Phase 1
6. **No timeline methodology** - Explain how estimates were calculated (prototype-based, estimated, etc.)
7. **Planning before prototyping** - If using new framework, should build spike first (warned in pre-planning validation)
---
**Next Steps**:
1. **Review** all planning docs above
2. **Validate** using checklist (files, understanding, environment)
3. **Refine** any phases that feel wrong
4. **Start Phase 1** when ready
⭐ **SESSION.md already created** - Use it to track your progress through these phases. Update it after significant progress, checkpoint frequently.
Let me know if you'd like me to adjust any phases or add more detail anywhere!project-session-managementproject-session-management