Loop Page Viewer MCP Server

1

Add it to Claude Code

Run this in a terminal.

Run in terminal
claude mcp add loop-page-viewer -- npx tsx /path/to/loop-page-viewer/server.ts
README.md

Renders Microsoft Loop pages inline in chat with view and edit capabilities.

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 build

2. 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: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.

Tools

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.

How it works

  1. You ask the LLM to create or fetch a Loop page (via your Loop MCP server)
  2. The LLM calls show_loop_page with the page data
  3. The host renders an interactive chicklet inline in chat (sandboxed iframe)
  4. The chicklet shows a compact card with the Loop icon, page title, and a content preview
  5. Click the chicklet to expand and see the full rendered markdown
  6. Switch to edit mode to modify the page content
  7. On save, the app calls request_page_update, and the LLM forwards the changes to mcp__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-expanded state

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 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

Tools (2)

show_loop_pageRenders a Loop page inline with view/edit UI.
request_page_updateCalled by the inline editor when the user saves to forward updates to the Loop MCP server.

Configuration

claude_desktop_config.json
{"mcpServers": {"loop-page-viewer": {"command": "npx", "args": ["tsx", "/path/to/loop-page-viewer/server.ts"]}}}

Try it

Fetch the latest project documentation from my Loop workspace and display it here.
Create a new Loop page for our meeting notes and show it in the chat.
Open the Loop page titled 'Q4 Roadmap' so I can edit the content directly.
Update the 'Project Specs' Loop page with the new requirements we just discussed.

Frequently Asked Questions

What are the key features of Loop Page Viewer?

Renders Microsoft Loop pages as interactive markdown widgets inline in chat. Supports full view and edit capabilities within the conversation interface. Provides a compact chicklet view for quick previews. Integrates with Loop MCP servers to sync updates back to the source. Accessible design with keyboard navigation and aria-expanded states.

What can I use Loop Page Viewer for?

Collaborating on project documentation without leaving the chat interface. Quickly reviewing and editing meeting notes stored in Microsoft Loop. Managing project requirements by rendering live Loop pages directly in Claude. Streamlining team communication by embedding interactive Loop content in discussions.

How do I install Loop Page Viewer?

Install Loop Page Viewer by running: npx tsx /path/to/loop-page-viewer/server.ts

What MCP clients work with Loop Page Viewer?

Loop Page Viewer works with any MCP-compatible client including Claude Desktop, Claude Code, Cursor, and other editors with MCP support.

Turn this server into reusable context

Keep Loop Page Viewer docs, env vars, and workflow notes in Conare so your agent carries them across sessions.

Need the old visual installer? Open Conare IDE.
Open Conare