imjac0b/iconify-mcp-server
If you are the rightful owner of iconify-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
Iconify MCP Server provides AI assistants with access to a vast collection of open source vector icons from Iconify.
Iconify MCP Server
An MCP (Model Context Protocol) server that provides AI assistants with access to Iconify's extensive collection of over 200,000 open source vector icons from 200+ icon sets.
Features
- Get all icon sets: Browse all available icon collections
- Get specific icon set: Retrieve detailed information about a specific icon set
- Search icons: Search through icons with flexible query parameters
- Get icon data: Retrieve specific icon data with usage examples for popular frameworks
Installation
Install in Cursor
Go to: Settings
-> Cursor Settings
-> MCP
-> Add new global MCP server
Pasting the following configuration into your Cursor ~/.cursor/mcp.json
file is the recommended approach. You may also install in a specific project by creating .cursor/mcp.json
in your project folder. See Cursor MCP docs for more info.
{
"mcpServers": {
"iconify": {
"command": "npx",
"args": ["-y", "iconify-mcp-server@latest"]
}
}
}
Install in Claude Code
Run this command. See Claude Code MCP docs for more info.
claude mcp add iconify -- npx -y iconify-mcp-server@latest
Install in Windsurf
Add this to your Windsurf MCP config file. See Windsurf MCP docs for more info.
{
"mcpServers": {
"iconify": {
"command": "npx",
"args": ["-y", "iconify-mcp-server@latest"]
}
}
}
Cursor One-Click Install
Usage
This MCP server runs as a stdio server and can be integrated with MCP-compatible clients.
Available Tools
get_all_icon_sets
Get a list of all available icon sets from Iconify.
Response: JSON object containing all icon collections with metadata.
get_icon_set
Retrieve detailed information about a specific icon set.
Parameters:
set
(string): The icon set prefix (e.g., "mdi", "heroicons", "lucide")
Response: JSON object with icon set information including total icons, categories, etc.
search_icons
Search for icons across all or specific icon sets.
Parameters:
query
(string): Search querylimit
(number, optional): Maximum results (32-999, default: 64)start
(number, optional): Starting index for paginationprefix
(string, optional): Icon set prefix to limit search scope
Response: JSON array of matching icons with metadata.
get_icon
Get detailed information about a specific icon.
Parameters:
set
(string): Icon set prefixicon
(string): Icon name
Response: Icon data with usage examples for:
- UnoCSS
- Tailwind CSS
- Iconify Icon web component
- Vue (Iconify)
- React (Iconify)
- Svelte (Iconify)
- Astro
- Unplugin Icons
Build
bun run build
Development
Prerequisites
- Node.js >= 18.0.0
- Bun runtime
Setup
- Clone the repository:
git clone https://github.com/imjac0b/iconify-mcp-server.git
cd iconify-mcp-server
- Install dependencies:
bun install
- Build the project:
bun run build
- Run in development mode:
bun run dist/index.js
Project Structure
src/
āāā index.ts # Main MCP server implementation
āāā utils.ts # Utility functions
āāā ...
dist/ # Built output
āāā index.js # ES module build
āāā index.cjs # CommonJS build
āāā index.d.ts # TypeScript definitions
Testing
Test the MCP server using the MCP Inspector:
npx -y @modelcontextprotocol/inspector bun run dist/index.js
This will open a web interface where you can test all available tools interactively.
Usage Examples
Get All Icon Sets
# This would be called by your MCP client
# Returns: JSON object with all available icon collections
get_all_icon_sets
Get Specific Icon Set
# Get information about Material Design Icons
get_icon_set({"set": "mdi"})
Search Icons
# Search for "home" icons across all sets
search_icons({"query": "home", "limit": 10})
# Search for "heart" icons in Lucide set only
search_icons({"query": "heart", "prefix": "lucide"})
Get Icon Data
# Get detailed information about a specific icon
get_icon({"set": "heroicons", "icon": "home"})
API Reference
All tools return structured JSON responses. See the tool definitions above for detailed parameter and response information.
Contributing
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add some amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
License
This project is licensed under the GPL-3.0 License - see the file for details.
Support
If you find this MCP server useful, please consider:
- ā Starring the repository
- š Reporting bugs or issues
- š” Suggesting new features
- š Sharing with other developers
Changelog
v1.0.0
- Initial release
- Support for all major Iconify operations
- Compatible with Cursor, Claude Code, and Windsurf
- Comprehensive icon set and search functionality