project-wizard

Installation
SKILL.md

Project Wizard: New Project Setup

Guide users through creating properly configured new projects with security, repository integration, and task tracking. This skill ensures every project starts with consistent structure and best practices.

Triggers

Use this skill when:

  • Creating a new project
  • Setting up a new repository
  • Initializing a new codebase
  • Starting a new workspace
  • Cloning a template for new work
  • Keywords: new project, create project, setup project, initialize, project wizard, scaffold, template

What Gets Created

The setup wizard now performs selective copying based on project type, language, and framework:

  • Only relevant skills copied (from groups: core + project-type-specific + framework-specific)
  • Only relevant commands copied (core + selected dev frameworks like PRP, Harness, etc.)
  • Project-specific README.md generated from templates
  • CLAUDE.md with conditional sections (only includes PRP/Harness/SpecKit docs if those frameworks are selected)
  • Language-specific .gitignore
  • template_profile section written to .claude/config.yaml for sync/update tracking
  • Security configurations (pre-commit hooks, secret detection)
  • GitHub repository with branch protection
  • Archon project for task management

Interactive Setup Flow

PROJECT WIZARD FLOW (v2.0 - Selective Setup)

  ┌─────────┐   ┌──────────┐   ┌───────────┐   ┌─────────┐   ┌─────────┐
  │ Basics  │──>│ Language │──>│ Framework │──>│ GitHub  │──>│ Archon  │
  │ Info    │   │ & Type   │   │ & DevFwks │   │ Setup   │   │ Project │
  └─────────┘   └──────────┘   └───────────┘   └─────────┘   └─────────┘
                                                           ┌──────┴──────┐
                                                           │  Selective  │
                                                           │  Copy &    │
                                                           │  Summary   │
                                                           └─────────────┘

Skills and commands are filtered based on project type + language + framework. Only relevant files are copied to the new project.


Phase 1: Gather Project Information

Basic Information

## Project Basics

1. **Project Location**
   Where to create the project folder?
   > Enter parent directory path (e.g., E:\Repos\MyOrg)

2. **Project Name**
   What should the project be called?
   > Must be lowercase with hyphens (e.g., my-awesome-project)

3. **Project Type**
   What kind of project is this?
   - [ ] Web Frontend (React, Vue, Angular, etc.)
   - [ ] Backend API (Node.js, Python, .NET, etc.)
   - [ ] Full-Stack Application
   - [ ] CLI Tool / Library
   - [ ] Infrastructure / DevOps
   - [ ] Other

4. **Project Description**
   Brief description (under 200 characters)
   > Used for README and GitHub repo description

Technical Stack

## Technical Stack

5. **Primary Language**
   - TypeScript/JavaScript
   - Python
   - C# / .NET
   - Go
   - Rust
   - Java/Kotlin
   - Other

6. **Framework** (if applicable)
   Frontend: React, Vue, Svelte, Next.js, etc.
   Backend: Express, FastAPI, ASP.NET, Gin, etc.

7. **Package Manager**
   npm, yarn, pnpm, pip/poetry, dotnet, go mod, cargo

GitHub Configuration

## GitHub Configuration

8. **GitHub Organization**
   Where to create the repository?
   > List available with: gh org list
   > Or use personal account

9. **Repository Visibility**
   - [ ] Private (recommended)
   - [ ] Public

Phase 2: Create Project Structure

Directory Structure

<project_name>/
├── .github/
│   ├── workflows/           # CI/CD workflows
│   ├── CODEOWNERS          # Code ownership
│   └── dependabot.yml      # Dependency updates
├── .claude/
│   ├── commands/           # Custom slash commands
│   ├── context/            # Path-specific context
│   └── skills/             # Project-specific skills
├── src/                    # Source code
├── tests/                  # Test files
├── docs/                   # Documentation
├── .gitignore              # Git ignore rules
├── .pre-commit-config.yaml # Pre-commit hooks
├── README.md               # Project documentation
└── CLAUDE.md               # Claude Code configuration

Language-Specific Additions

TypeScript/JavaScript:

├── package.json
├── tsconfig.json
├── .eslintrc.js
└── .prettierrc

Python:

├── pyproject.toml
├── requirements.txt
├── .python-version
└── ruff.toml

C# / .NET:

├── *.sln
├── src/*.csproj
├── .editorconfig
└── Directory.Build.props

Phase 3: Initialize Git Repository

Commands Executed

# Initialize git
git init

# Install pre-commit hooks
pip install pre-commit
pre-commit install
pre-commit install --hook-type commit-msg

# Create initial commit
git add .
git commit -m "feat: initial project setup"

Pre-commit Configuration

# .pre-commit-config.yaml
repos:
  - repo: https://github.com/pre-commit/pre-commit-hooks
    rev: v4.5.0
    hooks:
      - id: trailing-whitespace
      - id: end-of-file-fixer
      - id: check-yaml
      - id: check-added-large-files
      - id: detect-private-key
      - id: check-merge-conflict

  - repo: https://github.com/gitleaks/gitleaks
    rev: v8.18.0
    hooks:
      - id: gitleaks

  - repo: https://github.com/commitizen-tools/commitizen
    rev: v3.13.0
    hooks:
      - id: commitizen
        stages: [commit-msg]

Phase 4: Create GitHub Repository

Repository Creation

# Create remote repository
gh repo create "<org>/<project_name>" \
  --private \
  --source=. \
  --push \
  --description "<description>"

Branch Protection

# Configure branch protection for main
gh api repos/<org>/<project_name>/branches/main/protection \
  -X PUT \
  -f required_status_checks='{"strict":true,"contexts":[]}' \
  -f enforce_admins=false \
  -f required_pull_request_reviews='{"required_approving_review_count":1}' \
  -f restrictions=null

Security Features

# Enable secret scanning
gh api repos/<org>/<project_name> \
  -X PATCH \
  -f security_and_analysis='{"secret_scanning":{"status":"enabled"},"secret_scanning_push_protection":{"status":"enabled"}}'

Phase 5: Create Archon Project

Project Creation

# Create the project in Archon
result = manage_project("create",
    title="<Project Name>",
    description="<Project Description>",
    github_repo="https://github.com/<org>/<project_name>"
)

project_id = result["project"]["id"]

Initial Tasks

# Setup completion task
manage_task("create",
    project_id=project_id,
    title="Complete project setup",
    description="Review and customize copied template files:\n- Update README.md\n- Configure CI/CD workflows\n- Set up development environment",
    status="todo",
    feature="Setup",
    task_order=100
)

# Architecture documentation task
manage_task("create",
    project_id=project_id,
    title="Define project architecture",
    description="Create architecture documentation:\n- System overview\n- Component diagram\n- Data flow\n- Technology decisions",
    status="todo",
    feature="Documentation",
    task_order=90
)

Phase 6: Generate Summary

Success Output

# Project Created Successfully!

## Project Details
| Item | Value |
|------|-------|
| **Name** | <project_name> |
| **Location** | <full_path> |
| **Type** | <project_type> |
| **Repository** | https://github.com/<org>/<project_name> |
| **Archon Project** | <project_id> |

## What's Included
- Pre-configured .gitignore
- Pre-commit hooks with secret detection
- GitHub Actions workflows
- Claude Code configuration
- Branch protection enabled
- Secret scanning enabled

## Next Steps
1. Open the project: `code <project_path>`
2. Review and customize README.md
3. Check Archon tasks: `find_tasks(project_id="<project_id>")`
4. Start building!

## Quick Commands
| Command | Description |
|---------|-------------|
| `npm install` / `pip install -e .` | Install dependencies |
| `npm test` / `pytest` | Run tests |
| `pre-commit run --all-files` | Run all hooks |
| `gh pr create` | Create pull request |

Error Handling

Error Resolution
Path doesn't exist Create directory or choose different path
Project folder exists Overwrite or choose different name
gh CLI not installed Install from https://cli.github.com
gh CLI not authenticated Run gh auth login
Pre-commit install fails pip install pre-commit manually
Archon MCP not available Skip Archon, note in summary

Quick Mode

For experienced users, use quick setup:

# All settings in one command
/project-wizard --quick \
  --path "E:\Repos\MyOrg" \
  --name "my-api" \
  --type "backend" \
  --lang "python" \
  --org "MyOrg" \
  --private

# Or accept all smart defaults
/project-wizard --auto --name "my-project"

Auto mode will:

  • Use current directory as parent
  • Detect language from existing files or prompt
  • Use first available GitHub org
  • Default to private repository
  • Create Archon project automatically

Template Customization

README Template by Project Type

Web Frontend:

# Project Name

## Getting Started

npm install
npm run dev

## Available Scripts
- `npm run dev` - Start development server
- `npm run build` - Build for production
- `npm run test` - Run tests

Backend API:

# Project Name

## Getting Started

pip install -e ".[dev]"
uvicorn src.main:app --reload

## API Documentation
- Swagger UI: http://localhost:8000/docs
- ReDoc: http://localhost:8000/redoc

CLAUDE.md Template

# CLAUDE.md - Project Configuration

## Project Overview
[Description]

## Tech Stack
- Language: [Language]
- Framework: [Framework]
- Database: [Database]

## Development Commands
- Build: [command]
- Test: [command]
- Lint: [command]

## Archon Project
- Project ID: [id]
- GitHub: [url]

Notes

  • Always verify paths exist before creating
  • Pre-commit hooks are essential for security
  • Archon integration enables task tracking across sessions
  • Branch protection prevents accidental main branch pushes
  • Secret scanning catches leaked credentials before they're exposed
Related skills

More from housegarofalo/claude-code-base

Installs
4
GitHub Stars
2
First Seen
Mar 15, 2026