Skill v1.0.0
Trusted Publisher100/100version: "1.0.0" name: node-link-and-diagram-layout description: Choose and apply automatic layout strategies for node-link diagrams and connected-node visuals. Use when the user asks how to auto-arrange nodes, reduce line crossings, route edges, avoid overlaps, stabilize layout, or choose graph-layout algorithms for network diagrams, dependency graphs, database schema diagrams, ERDs, state machines, decision trees, flow diagrams, box-and-line editors, or other line-connected nodes.
Node-Link and Diagram Layout
Overview
Use this skill when the main problem is not which notation to use, but how to place connected nodes so the diagram stays readable. The job is to classify the graph family, choose a layout algorithm that matches the reading task, separate node placement from edge routing and overlap removal, and recommend a stack that can preserve those constraints in production.
Default assumption: the best automatic layout is the one that reinforces the intended reading path with the fewest crossings, bends, overlaps, and surprise placements. Do not treat force-directed layout as a generic answer for all diagrams. Trees, DAGs, port-constrained block diagrams, ERDs, and undirected exploration graphs usually need different algorithms.
For browser-facing node-link views, mobile layout is a graph-reading constraint, not only a CSS breakpoint. Use ../../references/foundations/mobile-first-responsive-visualization.md when choosing portrait focus views, optional landscape inspection, touch/pan/zoom ownership, and settings placement.
For operational graph workspaces, use ../../references/foundations/operational-visualization-workspaces.md so layout decisions account for outlines, inspectors, command bars, selected neighborhoods, URL state, mobile panels, and repeated navigation.
Core Workflow
- Classify the graph structure before choosing a renderer:
- rooted tree or forest
- directed acyclic graph
- cyclic directed graph with a dominant flow
- general undirected graph
- radial or hub-and-spoke structure
- clustered or compound graph
- port-constrained block diagram
- table-like schema or ERD
- nearly planar topology where crossing count dominates readability
- Identify the primary reading task:
- parent-child depth
- top-to-bottom or left-to-right flow
- reachability and dependency tracing
- cluster discovery
- cycle inspection
- shortest path or neighborhood exploration
- table relationship tracing
- stable editing with minimal layout drift
- Record geometry constraints up front:
- real node widths and heights, not point nodes
- labels that must fit without scaling below readability
- ports, handles, side constraints, or fixed connection order
- nested groups, lanes, clusters, or compounds
- whether some nodes are pinned or semi-pinned
- Choose the layout family that matches the structure:
- tidy tree layout for rooted ordered trees and decision trees
- layered or Sugiyama-style layout for directional processes, state machines, dependency maps, class hierarchies, ERDs, and most UML-like flow diagrams
- stress majorization or force-directed layout for undirected relational exploration where cluster shape matters more than global direction
- radial or concentric layout when distance from a root is the main story
- circular layout when cycle structure is the evidence
- planarization-driven layout when the graph is non-planar but low crossing count is the main objective
- Choose edge routing separately from node placement:
- straight or polyline when the graph is sparse and directional flow is already clear
- orthogonal when tables, ports, block diagrams, lanes, or circuit-like reading dominate
- spline routing when static aesthetics matter more than precise traceability and there is enough whitespace
- Treat overlap removal, label placement, and packing as explicit phases:
- remove node overlap after layout if the engine starts from point nodes
- reserve gutters for connector-dense tables and schemas
- keep edge labels out of node bodies and above selected paths
- pack connected components only after the component layouts are individually legible
- Prefer stability when users will edit, compare revisions, or recognize repeated diagrams:
- preserve node order when the source model has meaningful order
- preserve port order when connectors are semantically ordered
- use interactive or constraint-aware layered modes instead of re-randomizing
- Validate the result with readability criteria instead of trusting the engine:
- crossings are low enough for the task
- bends are limited and meaningful
- nodes and labels do not overlap
- directionality is obvious
- edge tracing is possible without visual hunting
- the layout stays readable on narrow widths or falls back to scrolling, filtering, or faceting
- mobile portrait starts on the most important region instead of shrinking the entire graph
- mobile landscape is offered when a wide graph, timeline, or schema materially improves tracing
- operational shells keep filters, outline trees, selected nodes, and inspectors synchronized without stealing space from the graph
Algorithm Defaults
- Rooted ordered trees and decision trees:
- Prefer Reingold-Tilford style tidy trees and Buchheim's linear-time refinement.
- Use radial tree variants only when depth from a root matters more than label density.
- Do not use generic force layout for decision trees unless the tree metaphor itself is intentionally abandoned.
- State machines, dependency graphs, workflow diagrams, class hierarchies, ERDs, and most UML-like directional diagrams:
- Prefer layered layout derived from Sugiyama.
- Use cycle breaking, layer assignment, crossing minimization, node placement, and edge routing as separate concerns.
- For table schemas, state diagrams, and block diagrams with connector semantics, prefer port-aware layered layout with orthogonal routing.
- General undirected networks:
- Prefer stress majorization or force-directed placement when cluster shape, neighborhood, or approximate graph distance is the point.
- Prefer multilevel force methods for larger graphs.
- Avoid force layout when users need strict rank order, deterministic business flow, or table-like schemas.
- Large topology where the graph is dense and not meaningfully hierarchical:
- Use multilevel force approaches, filtering, clustering, matrix fallbacks, or multiple coordinated views before cramming everything into one node-link view.
- Nearly planar but non-planar graphs:
- Consider planarization pipelines when crossing count matters more than preserving a strict hierarchy.
- Treat this as an advanced fallback, not a default for ordinary UML-like diagrams.
Stack Defaults
- Graphviz
dot: best default for static layered layouts in documentation or build-time generation. - Graphviz
neato: good default for modest undirected graphs when stress majorization is appropriate. - Graphviz
fdpandsfdp: good for force-directed and multilevel force layouts, especially for larger undirected networks. - Graphviz
twopiandcirco: use when radial or circular structure is truly the reading model. - ELK Layered: best default for interactive products that need layered layout with ports, compounds, labels, orthogonal routing, or layout constraints.
- React Flow plus ELK or Dagre: good for node editors when React owns the interaction layer and the actual layout engine remains external.
- Cytoscape.js: good when graph analysis, graph algorithms, and multiple layout modes matter as much as the rendering.
- Bespoke SVG, Canvas, or WebGL: use only when the visual composition or scale requires it after the algorithm family is already decided.
Anti-Patterns
- Using force-directed layout for ERDs, state machines, or business workflows that have a clear direction.
- Treating overlap removal as a substitute for choosing the right layout family.
- Ignoring real node dimensions and then trying to fix collisions at the end.
- Letting connectors run under schema tables, lane headers, or large node labels.
- Relying on a single dense node-link view when a matrix, tree, outline, focus view, or filtered subgraph would explain the structure better.
- Re-running unstable layout from scratch after every small edit in an interactive tool.
- Shrinking text below readable size instead of using an intrinsic canvas and scrollable viewport.
- Letting mobile controls or legends appear before the graph while the actual topology starts below the fold.
- Requiring pixel-perfect taps on dense nodes without search, step-through, or enlarged hit regions.
Reference Guide
- Read
references/algorithm-selection.mdfirst for graph-family to algorithm-family mapping. - Read
references/layered-tree-force-and-radial-layouts.mdwhen choosing among tree, layered, force, radial, circular, and multilevel approaches. - Read
references/routing-overlap-and-quality.mdfor orthogonal routing, planarization, overlap removal, port constraints, and readability criteria.
Output Expectations
- State the graph family and why it was classified that way.
- State the recommended layout family and one fallback.
- State the routing style, overlap strategy, and stability strategy.
- Call out whether ports, order constraints, fixed nodes, or compounds require a layout engine with stronger constraint support.
- For product work, recommend a concrete stack and make clear which part owns semantics, layout, and rendering.
- If the graph is too dense for a clean node-link view, say so and recommend filtering, faceting, clustering, matrix views, or overview-plus-detail.
- For mobile, state the portrait focus strategy, landscape need if any, touch target/hit-area policy, search or step-through path, and pan/zoom/browser gesture ownership.
- For operational graph workspaces, state the shell, default selected or focused neighborhood, outline/inspector synchronization, URL state, and empty-surface clear-selection behavior.
- If the problem is really notation selection, route to the UML or strategy skill instead of over-solving layout alone.
Adjacent Skills
../data-visualization/SKILL.md../uml-and-software-architecture-visualization/SKILL.md../typescript-data-visualization-engineering/SKILL.md../react-and-nextjs-data-visualization/SKILL.md../d3-data-visualization/SKILL.md../canvas2d-data-visualization/SKILL.md../threejs-data-visualization/SKILL.md../testing-data-visualizations/SKILL.md../../references/foundations/mobile-first-responsive-visualization.md../../references/foundations/operational-visualization-workspaces.md
Representative Prompts
- "How should I auto-arrange this network diagram so the lines stop crossing so much?"
- "What layout algorithm should I use for a database schema diagram?"
- "Choose between ELK, Graphviz, Dagre, force layout, and a custom approach for this state machine."
- "Make this dependency graph readable without overlapping boxes and labels."
- "How do I route edges for an ERD so foreign keys do not run under the tables?"
- "What should I use for a decision tree, a DAG, and an undirected network?"
- "We need stable auto-layout in a React node editor."