Loop Page Viewer
Provides an interactive interface for rendering and editing Markdown content, allowing users to view formatted Loop pages and make real-time updates directly within the chat interface.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Loop Page Vieweropen the 'Project Roadmap' page from Loop"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Loop Page Viewer
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.
Prerequisites
Node.js 18+
An MCP host that supports MCP Apps (Claude Desktop, claude.ai, VS Code Copilot, Goose, etc.)
A Loop MCP server for fetching/updating pages (e.g.,
@microsoft/loop-mcp)
Setup
1. Clone and build
git clone https://github.com/yemi33/loop-page-viewer.git
cd loop-page-viewer
npm install
npm run build2. Add to Claude Code
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.
3. Add to VS Code (Copilot)
Add to your .vscode/mcp.json:
{
"servers": {
"loop-page-viewer": {
"type": "stdio",
"command": "npx",
"args": ["tsx", "/path/to/loop-page-viewer/server.ts"]
}
}
}4. Add to Claude Desktop or other web hosts
Start the server in HTTP mode:
npm run serve:httpThen connect your host to http://localhost:3001/mcp. For Claude Desktop, use cloudflared to tunnel:
npx cloudflared tunnel --url http://localhost:3001Add the generated URL as a custom connector in Claude Desktop settings.
Tools
Tool | Description |
| Renders a Loop page inline with view/edit UI. Accepts title, content (markdown), link, workspaceId, and pageId. |
| Called by the inline editor when the user saves. Returns instructions for the host to forward the update to the Loop MCP server. |
How it works
You ask the LLM to create or fetch a Loop page (via your Loop MCP server)
The LLM calls
show_loop_pagewith the page dataThe host renders an interactive chicklet inline in chat (sandboxed iframe)
The chicklet shows a compact card with the Loop icon, page title, and a content preview
Click the chicklet to expand and see the full rendered markdown
Switch to edit mode to modify the page content
On save, the app calls
request_page_update, and the LLM forwards the changes tomcp__loop__update_page
Chicklet view
The default rendering is a compact inline card inspired by the office-web-host embedded component pattern:
Collapsed (default): Loop icon, page title, content preview snippet, expand chevron
Expanded (on click): Full rendered markdown with "Open in Loop" link and Edit/Save/Cancel buttons
Transparent background so the component blends into the host UI
Accessible: keyboard navigable with
aria-expandedstate
Development
npm 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 modeTo test with the MCP Inspector:
npx @modelcontextprotocol/inspector npx tsx server.tsTo test the chicklet view in a browser with mock data:
npm run build
npx vite --port 5173
# Open http://localhost:5173/test.htmlTo 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:8080This server cannot be installed
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/yemi33/loop-page-viewer'
If you have feedback or need assistance with the MCP directory API, please join our Discord server