Loop Page Viewer

Loop Page Viewer

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.

Category
Visit Server

README

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 viewer inline in chat (sandboxed iframe)
  4. You can view the rendered markdown or switch to edit mode
  5. On save, the app calls request_page_update, and the LLM forwards the changes to mcp__loop__update_page

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

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured