From workflows
Creates quick visual mockups (interactive HTML or matplotlib PNG) of diagrams before coding CeTZ, Fletcher, TikZ, or similar. Saves compile-fix cycles by letting users approve layouts first.
How this skill is triggered — by the user, by Claude, or both
Slash command
/workflows:visual-mockupThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
**Announce:** "I'll create a mockup so you can see the layout before I code the real diagram."
Announce: "I'll create a mockup so you can see the layout before I code the real diagram."
Diagram code (CeTZ, Fletcher, TikZ) is slow to iterate on — you write coordinates, compile, discover the layout is wrong, rewrite. A 30-second sketch lets the user see and approve the spatial layout before any real code gets written. This saves 3-5 compile-fix cycles on complex diagrams.
You don't need this for simple diagrams (2-3 nodes in a line). Use your judgment — if the layout is obvious, skip the mockup and go straight to code.
| Mode | When | Output |
|---|---|---|
| Interactive (default for node diagrams) | Fletcher diagrams, 4+ nodes, precise positioning | Drag-and-drop HTML → Fletcher JSON |
| Matplotlib (for charts/plots) | CeTZ charts, stock prices, timelines, data series | Static PNG → iterate data → translate to CeTZ |
Default to interactive for node-edge diagrams. Use matplotlib for anything with axes, data series, or time-based plots.
From conversation context or the user's request, identify:
Write the layout as JSON and run the generator:
cat > /tmp/layout.json << 'LAYOUT'
{
"title": "Diagram Name",
"nodes": [
{"id": "n1", "label": "Issuer", "x": 200, "y": 100, "color": "#89b4fa"},
{"id": "n2", "label": "Buyer", "x": 200, "y": 300, "color": "#a6e3a1"}
],
"edges": [
{"from": "n1", "to": "n2", "label": "§11 claim"}
],
"regions": [
{"id": "r1", "label": "Primary Market", "x": 140, "y": 60, "w": 250, "h": 280, "color": "#89b4fa"}
]
}
LAYOUT
uv run python3 ${SKILL_DIR}/scripts/interactive_mockup.py /tmp/layout.json --open
${SKILL_DIR} resolves to this skill's base directory (e.g., skills/visual-mockup).
The browser opens with a Catppuccin-themed drag-and-drop canvas:
Best for Fletcher diagrams. The exported grid coords drop directly into node((x, y), ...) calls. CeTZ diagrams require manual arrow routing that the mockup can't capture — use matplotlib mode for CeTZ instead.
Tell the user: "Drag nodes where you want them, select Fletcher in the Export dropdown, then click Copy Layout JSON and paste it here."
The user pastes JSON with Fletcher grid coordinates. Use these positions directly in node((x, y), ...) calls — no coordinate transform needed.
If the user wants further changes, regenerate with updated JSON and --open again. When approved, proceed to real diagram code.
Identify the chart's data series, axes, annotations, and shaded regions. For node diagrams, identify nodes, edges, regions.
Write a Python script that uses matplotlib/seaborn to sketch the visual:
For charts/plots:
For node diagrams:
matplotlib.patches.FancyBboxPatch with rounded corners for nodesax.annotate with arrowprops for edgesOutput to /tmp/visual-mockup.png at 150 DPI, then open it:
plt.savefig('/tmp/visual-mockup.png', dpi=150, bbox_inches='tight')
open /tmp/visual-mockup.png
Show the mockup and ask if the data shape / layout is right. This is where the value lives — catching problems like "the stock price doesn't bounce back" or "the damage bracket is in the wrong place" takes seconds in matplotlib vs. minutes in CeTZ compile cycles.
When approved, translate to CeTZ. For charts, the data arrays transfer directly — matplotlib and CeTZ use the same coordinate space, just different syntax.
figsize=(12, 6) for side-by-side, (8, 6) for single diagramsboxstyle="round,pad=0.1" for nodesax.set_aspect('equal') and ax.axis('off') for node diagramsvisual-verify for that)ds workflow for charts/plots)npx claudepluginhub edwinhu/workflows --plugin workflowsGenerates Excalidraw diagram JSON files that argue visually, not just display information. Use for workflows, architectures, or concepts.
Generates architecture diagrams on a live Excalidraw canvas from text, components, or samples for data flows, call chains, and exports to PNG/SVG/Excalidraw.
Creates technical and product diagrams (architecture, flowchart, sequence, etc.) as standalone HTML files with inline SVG. Includes style guide setup and 14 diagram types.