yamanahlawat/mcp-server-untitled-ui Server

Offline MCP server for Untitled UI components. No API keys, no remote calls at runtime, no rate limits.

Documentation

mcp-server-untitled-ui

The offline Model Context Protocol (MCP) server for Untitled UI. No API keys. No remote calls at runtime. No rate limits. Downloads components from GitHub once, builds a local index, and serves it locally forever.

This MCP server provides access to Untitled UI component source code, interfaces/props, dependencies, and icons, complete with fuzzy-search capabilities, pre-built workflow prompts, and browsable resources.


Key Features

  • 100% Offline at Runtime: Downloads and indexes the Untitled UI components and icons on the first run. Subsequent server startups are instant and completely local.
  • Cascading Fuzzy Search: Rich scoring algorithm for components based on name, exports, subcategory, and path.
  • TypeScript Interface/Props Extraction: Dynamically parses TypeScript interface and type declarations from the components so the LLM gets exact prop types.
  • Internal Dependency Analysis: Reveals internal library dependencies for components so you import everything required.
  • Protocol Compliant: Built on the latest Model Context Protocol SDK with full support for Tools, Resources, and Prompts.

Configuration

To use this server with your AI assistant, add it to your client's configuration file. The server will automatically download the components and build the search index on its first run.

Claude Desktop / Claude Code

Add this to your claude_desktop_config.json:

{
  "mcpServers": {
    "untitled-ui": {
      "command": "npx",
      "args": ["-y", "mcp-server-untitled-ui"]
    }
  }
}

Cursor

  1. Go to Settings > Features > MCP.
  2. Click + Add New MCP Server.
  3. Fill in:
    • Name: untitled-ui
    • Type: command
    • Command: npx -y mcp-server-untitled-ui

Continue / Other stdio clients

Configure using the standard stdio protocol pattern by executing npx -y mcp-server-untitled-ui.


CLI Options & Manual Setup (Optional)

If you want to manually run the download/index setup or rebuild the local cache, you can run the server directly in your terminal:

npx mcp-server-untitled-ui [options]

Options:
  --setup              Download/rebuild index only and exit (useful for CI/CD or pre-setup)
  --rebuild            Force re-download from GitHub and rebuild index
  --ttl <days>         Days before the index is automatically refreshed on startup (default: 7)
  --no-auto-refresh    Disable automatic index refresh on startup
  --version            Print server version
  --help               Show this help menu

First Run Experience

When the server starts (either manually or via an MCP client) for the first time, it will:

  1. Download the latest component tarball from GitHub (untitleduico/react and untitleduico/icons).
  2. Extract them to a temporary directory.
  3. Parse and index all .tsx and .ts files (ignoring stories, demos, and tests).
  4. Save the generated search index to ~/.mcp-server-untitled-ui/index.json.
  5. Start the stdio MCP server.

Subsequent starts run the server instantly using the local index.

Auto-Refresh

The server tracks when the index was built (generatedAt). On each startup it compares the index age against a TTL (default: 7 days). If the index is older than the TTL, it silently re-downloads and rebuilds the index before starting — keeping your component library current without any user action.

To override the TTL:

# Rebuild if the index is older than 14 days
npx mcp-server-untitled-ui --ttl 14

# Never auto-refresh (serve the cached index indefinitely)
npx mcp-server-untitled-ui --no-auto-refresh

The TTL can also be set persistently via the MCP_SERVER_UNTITLED_UI_REFRESH_DAYS environment variable (see Environment Variables below).


Environment Variables

The following environment variables can be used to customize server behaviour without passing CLI flags:

VariableDefaultDescription
MCP_SERVER_UNTITLED_UI_DATA_DIR~/.mcp-server-untitled-uiOverride the directory where the index and cache are stored. Useful for running multiple isolated instances or in CI environments.
MCP_SERVER_UNTITLED_UI_REFRESH_DAYS7Days before the cached index is considered stale and automatically rebuilt on startup. Set to 0 to always rebuild.
MCP_SERVER_UNTITLED_UI_SEARCH_LIMIT20Override the default result limit for search_components and search_icons tool calls.
MCP_SERVER_UNTITLED_UI_SEARCH_THRESHOLD0.4Override the Fuse.js fuzzy match threshold (0 = exact match only, 1 = match anything). Lower values are stricter.
MCP_SERVER_UNTITLED_UI_COMPONENTS_URLGitHub main tarballOverride the URL for the components tarball. Useful for pinning a specific release or pointing at a private mirror.
MCP_SERVER_UNTITLED_UI_ICONS_URLGitHub main tarballOverride the URL for the icons tarball.

Example — store the index in a project-local cache:

MCP_SERVER_UNTITLED_UI_DATA_DIR=./.cache/untitled-ui npx mcp-server-untitled-ui

MCP Capabilities Exposed

1. Tools

ToolInput ParametersDescription
search_componentsquery (string), limit (number, default: 20)Fuzzy search components by name, category, subcategory, or export name.
list_componentscategory (string), subcategory (string, optional)List all components in a category (case-insensitive).
get_componentname (string)Retrieve full TypeScript source code of a component by name.
get_component_filepath (string)Retrieve component source code by relative path.
search_iconsquery (string), limit (number, default: 20)Search Untitled UI icon names.
get_component_propsname (string)Get TypeScript prop interfaces/types for a component.
get_component_dependenciesname (string)Show internal Untitled UI imports utilized by the component.

2. Resources

Enables client side resource browsing for components without requiring tool calls:

  • untitled-ui://components — JSON array of all component categories with counts.
  • untitled-ui://components/{category} — JSON array of components under the specified category.
  • untitled-ui://components/{category}/{name} — Full raw TypeScript source code of a specific component.
  • untitled-ui://icons — JSON list of all icons.

3. Prompts

Provides templated workflows to assist LLMs in building UI screens:

  • build_component (description): Emits system context and matches existing components relevant to the UI screen you want to build.
  • map_design_to_components (design_description): Guides the LLM to break a visual design description into logical sections and map them to Untitled UI components.
  • component_usage (component_name): Generates imports, props descriptions, and a complete usage example for a component.

Development

Run Tests

This project uses Node.js's native test runner. You can execute the test suites by running:

npm test

Run Locally

To run the server locally during development:

npm start

To force a rebuild of the index locally:

node bin/cli.mjs --rebuild

License

This project is licensed under the MIT License.