Agent skill
wiki-ado-convert
Converts VitePress/GFM wiki markdown to Azure DevOps Wiki-compatible format. Generates a Node.js build script that transforms Mermaid syntax, strips front matter, fixes links, and outputs ADO-compatible copies to dist/ado-wiki/.
Install this agent skill to your Project
npx add-skill https://github.com/microsoft/skills/tree/main/.github/plugins/deep-wiki/skills/wiki-ado-convert
SKILL.md
ADO Wiki Converter
Generate a Node.js build script that transforms VitePress/GFM markdown documentation into Azure DevOps Wiki-compatible format. The source files remain untouched — the script produces transformed copies in dist/ado-wiki/.
Source Repository Resolution (MUST DO FIRST)
Before generating the build script, resolve the source repository context:
- Check for git remote: Run
git remote get-url origin - Ask the user: "Is this a local-only repository, or do you have a source repository URL?"
- Remote URL → store as
REPO_URL, preserve linked citations in converted output - Local → preserve local citations as-is
- Remote URL → store as
- Do NOT proceed until resolved
Why This Is Needed
Azure DevOps Wikis use a markdown dialect that differs from GFM and VitePress in several critical ways. Documentation that renders perfectly in VitePress will have broken diagrams, raw front matter, dead links, and rendering issues when published as an ADO Wiki.
ADO Wiki Incompatibilities
CRITICAL — Will Break Rendering
| Issue | VitePress/GFM | ADO Wiki | Fix |
|---|---|---|---|
| Mermaid code fences | ```mermaid ... ``` |
::: mermaid ... ::: |
Convert opening/closing fences |
flowchart keyword |
flowchart TD |
graph TD |
Replace flowchart with graph (preserve direction) |
<br> in Mermaid labels |
Node[Label<br>Text] |
Not supported | Strip <br> variants (replace with space) |
Long arrows ----> |
A ---->B |
Not supported | Replace with --> |
| YAML front matter | --- ... --- at file start |
Rendered as visible raw text | Strip entirely |
| Parent-relative source links | [text](../../src/file.cs) |
Broken (wiki is separate) | Convert to plain text |
| VitePress container directives | ::: tip / ::: warning |
Not supported | Convert to ADO alert blockquotes > [!TIP] / > [!WARNING] |
MODERATE — May Not Render Optimally
| Issue | Notes |
|---|---|
Mermaid style directives |
ADO's Mermaid version may ignore inline styling. Leave as-is (cosmetic). |
Mermaid thick arrows ==> |
May work. Leave as-is. |
Mermaid dotted arrows -.-> |
May work. Leave as-is. |
| Subgraph linking | Links to/from subgraphs not supported, but nodes inside subgraphs work fine. |
NOT AN ISSUE (Compatible As-Is)
- ✅ Standard markdown tables, blockquotes, horizontal rules
- ✅ Unicode emoji, fenced code blocks with language identifiers
- ✅ Same-directory relative links (
./other-page.md) - ✅ External HTTP/HTTPS links
- ✅ Bold, italic, strikethrough, inline code
- ✅ Lists (ordered, unordered, nested), headings 1-6
- ✅ Images with relative paths
ADO Wiki Mermaid Supported Diagram Types
As of 2025:
- ✅
sequenceDiagram,gantt,graph(NOTflowchart),classDiagram - ✅
stateDiagram,stateDiagram-v2,journey,pie,erDiagram - ✅
requirementDiagram,gitGraph,timeline - ❌
mindmap,sankey,quadrantChart,xychart,block
Build Script Structure
The generated script should be a Node.js ESM module (scripts/build-ado-wiki.js) using only built-in Node.js modules (node:fs/promises, node:path, node:url). No external dependencies.
Transformation Functions
1. Strip YAML Front Matter
Remove --- delimited YAML blocks at file start. ADO renders these as visible text.
function stripFrontMatter(content) {
if (!content.startsWith('---')) return content;
const endIndex = content.indexOf('\n---', 3);
if (endIndex === -1) return content;
let rest = content.slice(endIndex + 4);
if (rest.startsWith('\n')) rest = rest.slice(1);
return rest;
}
2. Convert Mermaid Blocks
Process line-by-line, tracking mermaid block state. Apply fixes ONLY inside mermaid blocks:
- Opening:
```mermaid→::: mermaid - Closing:
```→::: flowchart→graph(preserve direction: TD, LR, TB, RL, BT)- Strip
<br>,<br/>,<br />(replace with space) - Replace long arrows (
---->with 4+ dashes) with-->
function convertMermaidBlocks(content) {
const lines = content.split('\n');
const result = [];
let inMermaid = false;
for (const line of lines) {
const trimmed = line.trimEnd();
if (!inMermaid && /^```mermaid\s*$/.test(trimmed)) {
result.push('::: mermaid');
inMermaid = true;
continue;
}
if (inMermaid && /^```\s*$/.test(trimmed)) {
result.push(':::');
inMermaid = false;
continue;
}
if (inMermaid) {
let fixed = line;
fixed = fixed.replace(/^(\s*)flowchart(\s+)/, '$1graph$2');
fixed = fixed.replace(/<br\s*\/?>/gi, ' ');
fixed = fixed.replace(/-{4,}>/g, '-->');
result.push(fixed);
} else {
result.push(line);
}
}
return result.join('\n');
}
3. Convert Parent-Relative Source Links
Convert [text](../path) to plain text. Preserves same-directory .md links and external URLs.
function convertSourceLinks(content) {
return content.replace(
/\[([^\]]*)\]\(\.\.\/[^)]*\)/g,
(match, linkText) => linkText
);
}
4. Convert VitePress Container Directives (Optional)
Convert ::: tip / ::: warning / ::: danger to ADO alert blockquotes:
function convertContainerDirectives(content) {
// ::: tip → > [!TIP]
// ::: warning → > [!WARNING]
// ::: danger → > [!CAUTION]
// ::: info → > [!NOTE]
// closing ::: → (blank line)
}
Script Main Flow
async function main() {
const files = await collectMarkdownFiles(ROOT);
const stats = { frontMatter: 0, mermaid: 0, sourceLinks: 0, containers: 0 };
for (const filePath of files) {
let content = await readFile(filePath, 'utf-8');
content = stripFrontMatter(content);
content = convertMermaidBlocks(content);
content = convertSourceLinks(content);
const outPath = join(OUTPUT, relative(ROOT, filePath));
await mkdir(dirname(outPath), { recursive: true });
await writeFile(outPath, content, 'utf-8');
}
// Print transformation statistics
}
Skip Directories
The script should skip: node_modules, .vitepress, .git, dist, build, out, target, and any non-documentation directories.
npm Script Integration
{
"scripts": {
"build:ado": "node scripts/build-ado-wiki.js"
}
}
Verification Checklist
After the script runs, verify:
- File count in
dist/ado-wiki/matches source (minus skipped dirs) - Zero
```mermaidfences remaining — all converted to::: mermaid - Zero
flowchartkeywords remaining — all converted tograph - No YAML front matter in output files
- Parent-relative links converted to plain text
- Same-directory
.mdlinks preserved - Directory structure preserved
- Non-markdown files (images, etc.) copied as-is
index.mdat root is a proper wiki home page (NOT a placeholder)
Index Page Generation (CRITICAL)
The ADO Wiki's index.md MUST be a proper wiki landing page, NOT a generic placeholder with "TODO" text.
Logic
- If VitePress source has
index.md: Transform it (strip front matter, strip VitePress hero/features blocks). If meaningful content remains, use it. - If no meaningful content remains (empty after stripping, or only VitePress hero markup): Generate a proper landing page with:
- Project title as
# heading - Overview paragraph (from README or wiki overview page)
- Quick Navigation table (Section, Description columns linking to wiki sections)
- Links to onboarding guides if they exist
- Project title as
- NEVER leave a placeholder — if
index.mdcontains "TODO:", "Give a short introduction", or similar placeholder text, replace it entirely
ADO Wiki .order Files
Generate .order files in each directory to control sidebar ordering:
- Onboarding guides first, then numbered sections
- List page names without
.mdextension, one per line
Citation & Diagram Preservation
The converted ADO wiki must maintain the same quality standards:
- Linked citations (
[file:line](URL)) are standard markdown — preserve them as-is <!-- Sources: ... -->comment blocks after Mermaid diagrams — preserve (HTML comments work in ADO)- Tables with "Source" columns — preserve as-is (standard markdown tables)
- Mermaid diagrams — convert fences only; diagram content, types, and structure are preserved
- All Mermaid diagram types supported by ADO (graph, sequenceDiagram, classDiagram, stateDiagram, erDiagram, etc.) pass through unchanged
Important Notes
- Source files are NEVER modified — only copies in
dist/ado-wiki/ - Images must be copied too — if source has images, copy them with same relative paths
- The script should work with any VitePress wiki, not just this specific one
- Print statistics at the end showing count of each transformation type
- Script uses zero external dependencies — only Node.js builtins
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
podcast-generation
Generate AI-powered podcast-style audio narratives using Azure OpenAI's GPT Realtime Mini model via WebSocket. Use when building text-to-speech features, audio narrative generation, podcast creation from content, or integrating with Azure OpenAI Realtime API for real audio output. Covers full-stack implementation from React frontend to Python FastAPI backend with WebSocket streaming.
mcp-builder
Guide for creating high-quality MCP (Model Context Protocol) servers that enable LLMs to interact with external services through well-designed tools. Use when building MCP servers to integrate external APIs or services, whether in Python (FastMCP), Node/TypeScript (MCP SDK), or C#/.NET (Microsoft MCP SDK).
frontend-design-review
Review and create distinctive, production-grade frontend interfaces with high design quality and design system compliance. Evaluates using three pillars: frictionless insight-to-action, quality craft, and trustworthy building. USE FOR: PR reviews, design reviews, accessibility audits, design system compliance checks, creative frontend design, UI code review, component reviews, responsive design checks, theme testing, and creating memorable UI. DO NOT USE FOR: Backend API reviews, database schema reviews, infrastructure or DevOps work, pure business logic without UI, or non-frontend code.
entra-agent-id
Microsoft Entra Agent ID (preview) for creating OAuth2-capable AI agent identities via Microsoft Graph beta API. Covers Agent Identity Blueprints, BlueprintPrincipals, Agent Identities, required permissions, sponsors, and Workload Identity Federation. Includes Microsoft Entra SDK for AgentID (containerized sidecar) for polyglot agent authentication (Docker/Kubernetes), 3P agent integration, autonomous and interactive agent patterns. Triggers: "agent identity", "agent id", "Agent Identity Blueprint", "BlueprintPrincipal", "entra agent", "agent identity provisioning", "Graph agent identity", "entra sidecar", "agent id sidecar", "auth sidecar", "3P agent", "third-party agent identity", "polyglot agent auth".
github-issue-creator
Convert raw notes, error logs, voice dictation, or screenshots into crisp GitHub-flavored markdown issue reports. Use when the user pastes bug info, error messages, or informal descriptions and wants a structured GitHub issue. Supports images/GIFs for visual evidence.
copilot-sdk
Build applications powered by GitHub Copilot using the Copilot SDK. Use when creating programmatic integrations with Copilot across Node.js/TypeScript, Python, Go, or .NET. Covers session management, custom tools, streaming, hooks, MCP servers, BYOK providers, session persistence, custom agents, skills, and deployment patterns. Requires GitHub Copilot CLI installed and a GitHub Copilot subscription (unless using BYOK).
Didn't find tool you were looking for?