Back to list
alex-popov-tech

prettier

by alex-popov-tech

💻 My settings for macOS, wezterm, zsh, nvim, and more 🛠

92🍴 3📅 Jan 16, 2026

SKILL.md


name: prettier description: Detects Prettier configuration and formats code. This skill should be used for final cosmetic formatting before commits, after all logic and type fixes have been verified. Returns structured JSON with detection and format results.

Prettier Formatter

Purpose

Detect Prettier presence in a repository and format code. This skill handles detection of configuration and commands, then executes formatting. Designed for use as the final cosmetic pass before committing changes.

When to Use

This skill should be invoked:

  • After all quality checks have passed (eslint, typescript)
  • Before committing changes
  • When purely cosmetic code formatting is needed

This skill should NOT be invoked:

  • During active development (formatting may be overwritten)
  • Before quality checks (fixes may undo formatting)

Detection Process

Step 1: Check for Prettier Configuration

Search for Prettier configuration files using Glob tool:

  • .prettierrc
  • .prettierrc.json
  • .prettierrc.js
  • .prettierrc.yaml
  • .prettierrc.yml
  • prettier.config.js
  • prettier.config.cjs
  • package.json (check for prettier field or dependency)

If NO configuration found:

  • Set prettierDetected: false
  • Return early with JSON indicating not configured

If configuration found:

  • Set prettierDetected: true
  • Proceed to Step 2

Step 2: Detect Format Command

Search for format commands in priority order:

2a. Check CLAUDE.md (Highest Priority)

If CLAUDE.md exists:

  • Read the file
  • Search for sections: "Formatting", "Development Commands", "Code Style"
  • Look for command patterns: prettier, format, npm run format
  • Extract exact command mentioned
  • Record CLAUDE.md as source if found

2b. Check package.json Scripts

Read package.json and examine the scripts section:

Format commands (look for these script names):

  • "format"
  • "format:write"
  • "prettier"
  • "prettier:write"
  • Extract as: npm run <script-name>

Record package.json as source if found.

2c. Check Makefile

If Makefile exists:

  • Search for targets containing prettier or format
  • Common target patterns: format, prettier, fmt
  • Extract as: make <target-name>
  • Record Makefile as source if found

2d. Fallback Command

If no command found in any source:

  • Use fallback: npx prettier --write .
  • Record source as: "fallback"

Step 3: Execute Formatting

Run the detected format command:

<detected-command>

Capture the output to determine files changed.

Step 4: Build and Return JSON Response

Construct JSON object with this structure:

{
  "prettierDetected": true,
  "configFile": ".prettierrc.json",
  "command": {
    "format": "npm run format",
    "source": "package.json"
  },
  "result": {
    "status": "formatted",
    "filesChanged": 5,
    "message": "Formatted 5 files"
  }
}

Field Specifications:

  • prettierDetected (boolean): true if config found, false otherwise
  • configFile (string): Path to detected config file
  • command (object): Format command details
    • format (string): Exact command executed
    • source (string): Where command was found
  • result (object): Execution results
    • status (string): "formatted", "no-changes", or "not-configured"
    • filesChanged (number): Count of files modified
    • message (string): Human-readable summary

Output Format

Return the JSON structure with a summary:

## Prettier Format Results

```json
{
  "prettierDetected": true,
  ...
}

Summary:

  • Prettier detected: Yes/No
  • Files formatted:
  • Command used:

## Edge Cases

**No Prettier configuration found:**
```json
{
  "prettierDetected": false,
  "configFile": null,
  "command": {},
  "result": {
    "status": "not-configured",
    "filesChanged": 0,
    "message": "Prettier not configured in this repository"
  }
}

Prettier configured but no files changed:

{
  "prettierDetected": true,
  "configFile": ".prettierrc",
  "command": {
    "format": "npm run format",
    "source": "package.json"
  },
  "result": {
    "status": "no-changes",
    "filesChanged": 0,
    "message": "All files already formatted"
  }
}

Command execution error:

  • Report the error in the result message
  • Set status to "error"
  • Include error details for troubleshooting

Score

Total Score

65/100

Based on repository quality metrics

SKILL.md

SKILL.mdファイルが含まれている

+20
LICENSE

ライセンスが設定されている

+10
説明文

100文字以上の説明がある

0/10
人気

GitHub Stars 100以上

0/15
最近の活動

1ヶ月以内に更新

+10
フォーク

10回以上フォークされている

0/5
Issue管理

オープンIssueが50未満

+5
言語

プログラミング言語が設定されている

+5
タグ

1つ以上のタグが設定されている

+5

Reviews

💬

Reviews coming soon