loading…
Search for a command to run...
loading…
Enables users to view and edit Microsoft Loop pages as interactive markdown widgets directly within the chat interface. It supports inline rendering and provide
Enables users to view and edit Microsoft Loop pages as interactive markdown widgets directly within the chat interface. It supports inline rendering and provides tools for requesting page updates through a host's Loop MCP server.
MCP App that renders Microsoft Loop pages inline in chat with view and edit capabilities.
When an LLM creates or fetches a Loop page, this server displays it as an interactive widget — rendered markdown with an edit mode — directly in the conversation instead of just returning text.
@microsoft/loop-mcp)git clone https://github.com/yemi33/loop-page-viewer.git
cd loop-page-viewer
npm install
npm run build
Add to your ~/.claude/settings.json:
{
"mcpServers": {
"loop-page-viewer": {
"command": "npx",
"args": ["tsx", "/path/to/loop-page-viewer/server.ts"],
"tools": ["*"]
}
}
}
Replace /path/to/loop-page-viewer with the actual path to the cloned repo.
Add to your .vscode/mcp.json:
{
"servers": {
"loop-page-viewer": {
"type": "stdio",
"command": "npx",
"args": ["tsx", "/path/to/loop-page-viewer/server.ts"]
}
}
}
Start the server in HTTP mode:
npm run serve:http
Then connect your host to http://localhost:3001/mcp. For Claude Desktop, use cloudflared to tunnel:
npx cloudflared tunnel --url http://localhost:3001
Add the generated URL as a custom connector in Claude Desktop settings.
| Tool | Description |
|---|---|
show_loop_page |
Renders a Loop page inline with view/edit UI. Accepts title, content (markdown), link, workspaceId, and pageId. |
request_page_update |
Called by the inline editor when the user saves. Returns instructions for the host to forward the update to the Loop MCP server. |
show_loop_page with the page datarequest_page_update, and the LLM forwards the changes to mcp__loop__update_pageThe default rendering is a compact inline card inspired by the office-web-host embedded component pattern:
aria-expanded statenpm run build # Build the UI bundle
npm run serve # Start in stdio mode (for Claude Code)
npm run serve:http # Start in HTTP mode (for web hosts, port 3001)
npm run dev # Build + start HTTP mode
To test with the MCP Inspector:
npx @modelcontextprotocol/inspector npx tsx server.ts
To test the chicklet view in a browser with mock data:
npm run build
npx vite --port 5173
# Open http://localhost:5173/test.html
To test rendering with the basic-host:
npm run serve:http
# In another terminal:
git clone https://github.com/modelcontextprotocol/ext-apps.git
cd ext-apps/examples/basic-host
npm install
SERVERS='["http://localhost:3001/mcp"]' npm start
# Open http://localhost:8080
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"loop-page-viewer": {
"command": "npx",
"args": []
}
}
}