npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@aaroncx/commitcraft

v1.1.1

Published

AI-powered conventional commit message generator

Downloads

102

Readme

CommitCraft

AI-powered conventional commit message generator CLI.

ko-fi

Install

npm install -g commitcraft

Setup

Configure your preferred AI provider:

# Anthropic (default)
commitcraft config set anthropicApiKey YOUR_ANTHROPIC_KEY

# OpenAI
commitcraft config set openaiApiKey YOUR_OPENAI_KEY
commitcraft config set provider openai

Or use environment variables:

export ANTHROPIC_API_KEY=your_key_here
export OPENAI_API_KEY=your_key_here

Usage

Generate a commit message

# Stage your changes, then run:
commitcraft generate

# Or use the short alias:
cc gen

Flags

| Flag | Description | |------|-------------| | --provider <name> | Override provider (anthropic or openai) | | --model <name> | Override the default model | | --copy | Copy the generated message to clipboard | | --commit | Auto-run git commit with the generated message | | --dry-run | Show the diff that would be sent without calling AI | | --type <type> | Constrain commit type (feat, fix, docs, style, refactor, perf, test, chore, ci, build) | | --scope <scope> | Add a conventional commit scope, e.g. feat(auth): ... | | --emoji | Prepend a gitmoji to the commit message | | --amend | Regenerate the last commit message |

Examples

# Generate and copy to clipboard
commitcraft generate --copy

# Generate and commit directly
commitcraft generate --commit

# Use OpenAI instead of default Anthropic
commitcraft generate --provider openai

# Preview what diff would be sent
commitcraft generate --dry-run

# Force a fix: type message
commitcraft --type fix

# Add scope: feat(auth): ...
commitcraft --scope auth

# Add gitmoji: ✨ feat: ...
commitcraft --emoji

# Redo the last commit message
commitcraft --amend

Init Command

Create a .commitcraftrc project config file interactively:

commitcraft init

This walks you through selecting a provider, default commit type, emoji preference, and auto-copy setting.

Project Configuration

CommitCraft supports a .commitcraftrc file in your project root. This JSON file lets you set project-specific defaults that override global config:

{
  "provider": "anthropic",
  "emoji": true,
  "autoCopy": false,
  "defaultType": "feat"
}

Supported keys: provider, model, emoji, autoCopy, defaultType

Settings are merged with global config -- project settings take priority.

Global Configuration

# Set a config value
commitcraft config set <key> <value>

# Get a config value
commitcraft config get <key>

Config keys: provider, anthropicApiKey, openaiApiKey, model, autoCopy, emoji, defaultType

Troubleshooting

| Error | Solution | |-------|----------| | "Not a git repository" | Run from inside a git project, or run git init | | "No API key found" | Set via commitcraft config set anthropicApiKey <key> or export ANTHROPIC_API_KEY=<key> | | "No changes detected" | Stage changes first with git add <files> | | "Network error" | Check your internet connection and try again | | "Invalid commit type" | Use one of: feat, fix, docs, style, refactor, perf, test, chore, ci, build |

Supported Providers

| Provider | Default Model | Package | |----------|--------------|---------| | Anthropic (Claude) | claude-haiku-4-5 | @anthropic-ai/sdk | | OpenAI | gpt-4o-mini | openai |

How It Works

  1. CommitCraft captures your staged git diff
  2. The diff is sent to your configured AI provider with a specialized system prompt
  3. The AI generates a conventional commit message following the Conventional Commits specification
  4. The message is validated, displayed, and optionally copied to clipboard or used to commit directly

Diffs are truncated to ~6000 tokens to stay within context limits. API keys are stored securely using XDG-compliant config storage and are never logged or transmitted anywhere except to the configured AI provider.

Contributing

Contributions are welcome! Here's how:

  1. Fork the repository
  2. Create a feature branch: git checkout -b feat/my-feature
  3. Make your changes and add tests
  4. Run npm test and npm run lint
  5. Commit using conventional commits
  6. Open a pull request

Support the Project

CommitCraft is free and open source. If it saves you time, consider buying me a coffee — it helps fund development and keeps the project maintained.

ko-fi

License

MIT