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 🙏

© 2025 – Pkg Stats / Ryan Hefner

mcp-color-convert

v0.1.2

Published

Comprehensive color conversion, manipulation, analysis, and accessibility MCP server

Readme

MCP Color Converter

A comprehensive Model Context Protocol (MCP) server for color conversion, manipulation, analysis, and accessibility, designed for AI coding agents and assistants. This server provides a complete color toolkit for design systems, web development, and accessibility compliance using the colorizr library.

smithery badge

Use Cases for AI Agents

  • UI/UX Design: Convert design system colors between formats for different platforms
  • Web Development: Transform colors for CSS, SVG, and canvas applications
  • Data Visualization: Convert colors for charts and graphs using perceptually uniform OkLCH
  • Theme Generation: Create consistent color palettes across different color spaces
  • Accessibility: Ensure proper color contrast by working in perceptual color spaces
  • Design Systems: Generate complete swatches and harmonious color schemes
  • Color Manipulation: Lighten, darken, saturate, and rotate colors for UI states
  • Accessibility Compliance: WCAG contrast analysis and text color optimization

Once configured, your AI coding agent will be able to discover and use these color conversion tools seamlessly within your development workflow.

Installation & Configuration

MCP Client Configuration

This is the recommended way to use the MCP server. Add it to your MCP client configuration:

Claude Desktop or Gemini CLI

Add this server to your agent config file:

{
  "mcpServers": {
    "color-converter": {
      "command": "npx",
      "args": [
        "-y",
        "mcp-color-convert@latest"
      ]
    }
  }
}

Custom MCP Client Configuration

For any MCP client supporting stdio transport:

{
  "servers": [
    {
      "name": "color-converter",
      "description": "AI-powered color conversion, manipulation, analysis, and accessibility tools for design systems",
      "transport": {
        "type": "stdio",
        "command": "npx",
        "args": ["-y", "mcp-color-convert@latest"]
      }
    }
  ]
}

The npx -y mcp-color-convert@latest command ensures:

  • Automatic installation if not present
  • Always uses the latest version
  • No global dependencies required
  • Works across different environments

Consult your MCP client's documentation for specific configuration details.

Supported Color Formats

This MCP server supports conversion between the following color formats:

Input Formats (any accepted):

  • HEX: #FF0000, #ff0000
  • RGB: rgb(255, 0, 0), rgb(255,0,0)
  • RGBA: rgba(255, 0, 0, 0.5), rgba(255,0,0,0.5) (with alpha/transparency)
  • HSL: hsl(0, 100%, 50%), hsl(0,100%,50%)
  • HSLA: hsla(0, 100%, 50%, 0.5), hsla(0,100%,50%,0.5) (with alpha/transparency)
  • OkLCH: oklch(63.269% 0.25404 19.90218) (modern perceptual color space)
  • OkLCH with alpha: oklch(63.269% 0.25404 19.90218 / 0.5) (alpha uses slash syntax)
  • OkLab: oklab(0.62796 0.22486 0.12585) (perceptual color space)
  • OkLab with alpha: oklab(0.62796 0.22486 0.12585 / 0.5) (alpha uses slash syntax)
  • Named Colors: red, blue, green, purple, etc.

Alpha/Transparency Support: All major color formats support alpha values (0-1 scale):

  • RGBA/HSLA use comma syntax: rgba(255, 0, 0, 0.5)
  • OkLCH/OkLab use slash syntax: oklch(63.269% 0.25404 19.90218 / 0.5)
  • Alpha is preserved when converting between alpha-supporting formats
  • Alpha is removed when converting to formats that don't support it (like hex)

Output Formats (for convert tool):

  • hex - Returns: #FF0000
  • rgb - Returns: rgb(255 0 68)
  • hsl - Returns: hsl(344 100% 50%)
  • oklch - Returns: oklch(63.269% 0.25404 19.90218)
  • oklab - Returns: oklab(0.62796 0.22486 0.12585)

Available Tools

Color Conversion

  • convert - Universal converter between any supported formats. Accepts any valid color input (hex, rgb, rgba, hsl, hsla, oklch, oklab, or named colors like 'red', 'blue') including alpha/transparency values and converts to hex, rgb, hsl, oklch, or oklab format. Alpha is preserved when converting between alpha-supporting formats, removed when converting to non-alpha formats. Uses colorizr's built-in convert function for optimal format handling.

Color Manipulation

  • lighten - Increase color lightness by percentage amount
  • darken - Decrease color lightness by percentage amount
  • saturate - Increase color saturation/intensity by percentage amount
  • desaturate - Decrease color saturation/intensity by percentage amount
  • invert - Create exact opposite/complementary color
  • rotate - Rotate hue by degrees around color wheel

Color Analysis

  • luminance - Get WCAG relative brightness (0-1 scale)
  • chroma - Get color intensity/purity (0-1 scale)
  • opacity - Extract alpha/opacity value (0-1 scale) from any color format that supports transparency
  • name - Get common color name or hex if unnamed

Color Generation

  • palette - Generate 6-color harmonious palette from base color
  • scheme - Generate color harmonies (complementary, triadic, tetradic, etc.)
  • swatch - Generate 11-shade design system swatch (50-950)
  • random - Generate random color in specified format

Accessibility Tools

  • contrast - Calculate WCAG contrast ratio between two colors
  • compare - Full WCAG compliance analysis with recommendations
  • text_color - Get optimal text color (black/white) for background

Utility Tools

  • is_valid_color - Validate if color string is parseable

Example Usage

Convert any color format to another:

{
  "tool": "convert",
  "arguments": {
    "color": "#FF0000",
    "format": "oklch"
  }
}
// Returns: "oklch(63.269% 0.25404 19.90218)"

Convert named color to HSL:

{
  "tool": "convert",
  "arguments": {
    "color": "blue",
    "format": "hsl"
  }
}
// Returns: "hsl(240 100% 50%)"

Convert RGBA to hex (alpha removed):

{
  "tool": "convert",
  "arguments": {
    "color": "rgba(255, 0, 0, 0.5)",
    "format": "hex"
  }
}
// Returns: "#ff0000"

Convert RGBA to OkLCH (alpha preserved):

{
  "tool": "convert",
  "arguments": {
    "color": "rgba(255, 0, 0, 0.5)",
    "format": "oklch"
  }
}
// Returns: "oklch(62.796% 0.25768 29.23494 / 0.5)"

Lighten a color for hover state:

{
  "tool": "lighten",
  "arguments": {
    "color": "#FF0000",
    "amount": 20
  }
}
// Returns: "#ff3333"

Check accessibility compliance:

{
  "tool": "compare",
  "arguments": {
    "foreground": "#000000",
    "background": "#FFFFFF"
  }
}
// Returns: {"contrast": 21, "compliant": 1, "normalAA": true, "normalAAA": true, ...}

Generate design system swatch:

{
  "tool": "swatch",
  "arguments": {
    "color": "#3B82F6"
  }
}
// Returns: {"50": "#eff6ff", "100": "#dbeafe", "200": "#bfdbfe", ..., "950": "#172554"}

Publishing & Deployment

NPM Publishing

This package is published to NPM and can be used with npx:

npx -y mcp-color-convert@latest

To publish a new version:

  1. Update version in package.json
  2. Commit all changes
  3. Run npm publish (this will automatically build before publishing)

Build process:

  • TypeScript compiles to dist/ directory
  • Smithery builds for deployment to .smithery/ directory
  • Only dist/, src/, README.md, and LICENSE are included in the NPM package

Smithery Deployment

This server is compatible with Smithery for both local and remote deployment:

Local Deployment (current configuration):

  • Server runs on the user's machine
  • Users install via NPM or NPX
  • Configuration in smithery.yaml: target: local

Remote Deployment:

  • Server runs on Smithery's infrastructure
  • Change smithery.yaml: target: remote
  • Connect your GitHub repository to Smithery
  • Deploy from the Deployments tab on your server page

Smithery features:

  • Automatic discovery by MCP clients
  • Session configuration forms (via configSchema export)
  • One-click installation for users

Development

Setting Up Development Environment

  1. Clone and install dependencies:

    git clone https://github.com/bennyzen/mcp-color-convert.git
    cd mcp-color-convert
    npm install
  2. Test the MCP server locally:

    # Test the server dry BEFORE trying to use it with an MCP client to catch obvious errors
    npx -y .
  3. Using with your agent (MCP client) locally:

    • Update your MCP client configuration to point to the local installation (e.g., npx -y /path/to/mcp-color-convert)
     {
       "mcpServers": {
         "color-converter": {
           "command": "npx",
           "args": [
             "-y",
             "/path/to/mcp-color-convert"
           ]
         }
       }
     }

    Important: Restart your MCP client after making configuration changes!

  4. Testing: Use your MCP client to call the server and test various tools. You can enter phrases like:

    • "List all your color conversion tools"
    • "Convert #FF5733 to HSL"
    • "Lighten rgb(100, 150, 200) by 15%"
    • "Create a palette of red in oklch"

Adding New Tools

To add new color tools:

  1. Write the tool function following existing examples
  2. Register the tool using server.registerTool()
  3. Follow the existing pattern for input validation with Zod schemas
  4. Handle errors with McpError for consistent error reporting

Library Dependencies

  • @modelcontextprotocol/sdk - MCP server framework
  • colorizr - Color manipulation library (verify exports before use)
  • zod - Input validation schemas

Troubleshooting

Server won't start

  • Ensure Node.js 18+ is installed: node --version
  • Try clearing npm cache: npm cache clean --force
  • Reinstall dependencies: rm -rf node_modules package-lock.json && npm install

NPX execution issues

  • Use the -y flag to auto-install: npx -y mcp-color-convert@latest
  • Check NPM registry access: npm ping
  • Verify package exists: npm view mcp-color-convert

Build failures

  • Ensure TypeScript is installed: npm install
  • Clean build: rm -rf dist/ .smithery/ && npm run build
  • Check for TypeScript errors: npm run build:tsc

MCP Client connection issues

  • Restart your MCP client after configuration changes
  • Verify the server starts: node dist/index.js (should hang waiting for input - this is correct)
  • Check logs in your MCP client for connection errors
  • Ensure the path in your client config is correct

Color conversion errors

  • Verify color format matches supported types (hex, rgb, hsl, oklch, oklab)
  • Check alpha values use correct syntax (comma for rgba/hsla, slash for oklch/oklab)
  • Named colors must be valid CSS color names

License

MIT License. See LICENSE file for details.