Skip to main content
Glama
rogerio-ignacio-filho

grocers-design-mcp

grocers-design-mcp

MCP server exposing the Grocers Design System as queryable tools for coding agents.

Hosted on Fly.io. Auth is a single long-lived token embedded in the URL path — no OAuth, no client config beyond pasting the URL.

Live: https://grocers-design-mcp.fly.dev/<TOKEN>/mcp Health (no auth): https://grocers-design-mcp.fly.dev/health

What it serves

  • Design tokens — every CSS custom property from the Grocers DS (colors, spacing, radii, shadows, type scale, motion). 101 tokens indexed at boot.

  • Semantic type classest-h1, t-display, t-body, t-price, etc. (16 ready-to-apply utility classes).

  • UI components — JSX source from the web, mobile, and admin UI kits. 44 components — Dashboard, KpiCard, OrdersScreen, OrderRow, CartSheet, MProductTile, etc.

  • Brand foundations — content rules (tone, casing, no-emoji), visual rules (red ≠ error, destructive uses ink + type-to-confirm), iconography (Lucide, 2px stroke, 24px grid).

  • Skill manifest — one-paragraph brand brief for fast agent bootstrap.

Tools

Tool

Purpose

list_tokens({category?, group?})

Discover tokens by category/group

get_token({name})

Full detail for one token (with -- prefix)

list_semantic_classes()

t-* pre-built typography classes

list_components({kit?})

Components by kit (web/mobile/admin)

get_component({name, kit?})

JSX source + metadata

get_foundations({section?})

README sections: visual/content/iconography/…

get_skill()

The SKILL.md manifest

search({query, limit?})

Full-text search with pt-BR↔en synonyms

validate_snippet({snippet, language?})

Lint CSS/JSX against 11 brand rules

suggest_component({intent, kit?, include_source?})

Intent → idiomatic component or pattern

Lint rules in validate_snippet

Rule

Severity

Catches

no-emoji

error

Any emoji in source (incl. composed sequences)

no-hardcoded-brand-color

warning

#ff4444, #ed1f1f, … → suggests exact token

no-hardcoded-ink-color

warning

#0b0119, #14081f, … → suggests exact token

no-arbitrary-tailwind

warning

bg-[#ff4444], p-[13px], rounded-[7px]

red-is-not-error

warning

Brand red near 'erro/error/invalid' → use danger

destructive-uses-ink-not-red

warning

Destructive cue + brand red → ink + type-to-confirm

off-scale-radius

warning

border-radius not in {4,6,10,14,18,24,pill}

off-scale-spacing

warning

padding/margin/gap not in 4px scale

non-brand-font

warning

font-family not Neue Montreal/Geist Mono

heavy-cta-weight

info

font-weight: 600+ in button context

missing-tabular-nums

info

R$ N without tabular-nums or .t-price

off-scale-shadow

info

box-shadow not via var(--shadow-*)

Intent map in suggest_component

30 curated entries spanning all three kits plus 5 non-component patterns (destructive-action, error-state, price-display, icon-usage, tone-of-voice). Kit inference from natural language ("mobile", "painel", "web") biases the ranking.

Using with Claude Code

Add to ~/.claude.json or project .mcp.json:

{
  "mcpServers": {
    "grocers-design": {
      "type": "http",
      "url": "https://grocers-design-mcp.fly.dev/<TOKEN>/mcp"
    }
  }
}

The token lives in fly secrets and rotates via fly secrets set GROCERS_MCP_TOKEN=$(openssl rand -hex 32) -a grocers-design-mcp.

Quick example flow (agent building a Grocers admin screen)

1. get_foundations({section:"visual"})         → brand rules
2. suggest_component({intent:"tabela de pedidos no admin"})
                                                → admin/OrdersScreen
3. suggest_component({intent:"modal de cancelar pedido"})
                                                → pattern destructive-action
                                                  (ink + type-to-confirm)
4. get_component({name:"OrdersScreen", kit:"admin"})
                                                → JSX source
5. validate_snippet({snippet: <composed JSX>})  → catch drift before ship

Local dev

npm install
GROCERS_MCP_TOKEN="$(openssl rand -hex 32)" PORT=8080 npm run dev
# Health:  http://localhost:8080/health
# MCP:     http://localhost:8080/<TOKEN>/mcp

Architecture

  • Hono + @hono/node-server for HTTP.

  • @modelcontextprotocol/sdk for JSON-RPC / streamable HTTP transport, stateless mode (fresh McpServer per request — no session state).

  • Token-in-URL middleware: timingSafeEqual against GROCERS_MCP_TOKEN; wrong token returns 404 (not 401 — hides existence).

  • The DS bundle ships inside the container at bundle/ and is indexed once at boot into in-memory maps (O(1) lookups).

  • Fly app runs 2 machines (HA) in gru, 256MB each, auto-stops when idle.

Deploy

fly deploy -a grocers-design-mcp --remote-only

Layout

bundle/                              # Grocers DS handoff bundle (source of truth)
  project/
    colors_and_type.css              # all design tokens
    README.md                        # foundations
    SKILL.md                         # one-paragraph brand brief
    ui_kits/{web,mobile,admin}/      # React/JSX components
    preview/*.html                   # visual specimens (not served by MCP)
src/
  index.ts                           # entrypoint
  server.ts                          # Hono app + token middleware
  indexer.ts                         # CSS + JSX + README parser
  tools/
    tokens.ts                        # list_tokens, get_token, list_semantic_classes
    components.ts                    # list_components, get_component
    foundations.ts                   # get_foundations, get_skill
    search.ts                        # search (synonym-aware)
    validate.ts                      # validate_snippet (11 rules)
    suggest.ts                       # suggest_component (30 entries)
Dockerfile
fly.toml

Roadmap

Out of scope for v0.3, candidates for next iteration:

  • Multi-theme support (Zona Sul and other clients as override layers).

  • validate_snippet: semantic copy lint (e.g. "Erro: ..." string detection).

  • suggest_component: broader UI primitive coverage (TableHeader, Pagination states, EmptyState variants).

  • get_screen(name): return a parent component + all its children in one call.

  • shadcn/ui compatibility layer (map Grocers semantic tokens → --primary/--background etc.).

F
license - not found
-
quality - not tested
C
maintenance

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/rogerio-ignacio-filho/grocers-design-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server