Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

dagre-d3

Package Overview
Dependencies
Maintainers
2
Versions
58
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

dagre-d3

A D3-based renderer for Dagre

  • 0.6.4
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
112K
increased by60%
Maintainers
2
Weekly downloads
 
Created

What is dagre-d3?

The dagre-d3 npm package is a JavaScript library that provides tools for creating directed graphs and rendering them using D3.js. It is built on top of the Dagre layout engine, which is responsible for computing the layout of the graph, and D3.js, which is used for rendering the graph in a web browser.

What are dagre-d3's main functionalities?

Creating a basic graph

This code demonstrates how to create a basic directed graph with two nodes and one edge using dagre-d3. The graph is then rendered using D3.js.

const dagreD3 = require('dagre-d3');
const d3 = require('d3');

// Create a new directed graph
const g = new dagreD3.graphlib.Graph().setGraph({});

// Add nodes to the graph
g.setNode('A', { label: 'Node A' });
g.setNode('B', { label: 'Node B' });

// Add an edge between nodes
g.setEdge('A', 'B');

// Create the renderer
const render = new dagreD3.render();

// Set up an SVG group so that we can translate the final graph.
const svg = d3.select('svg'),
    svgGroup = svg.append('g');

// Run the renderer. This is what draws the final graph.
render(d3.select('svg g'), g);

Customizing node and edge styles

This code demonstrates how to customize the styles of nodes and edges in a directed graph using dagre-d3. Nodes and edges are styled using CSS properties.

const dagreD3 = require('dagre-d3');
const d3 = require('d3');

// Create a new directed graph
const g = new dagreD3.graphlib.Graph().setGraph({});

// Add nodes with custom styles
g.setNode('A', { label: 'Node A', style: 'fill: #f77' });
g.setNode('B', { label: 'Node B', style: 'fill: #7f7' });

// Add an edge with a custom style
g.setEdge('A', 'B', { style: 'stroke: #333; stroke-width: 2px;' });

// Create the renderer
const render = new dagreD3.render();

// Set up an SVG group so that we can translate the final graph.
const svg = d3.select('svg'),
    svgGroup = svg.append('g');

// Run the renderer. This is what draws the final graph.
render(d3.select('svg g'), g);

Adding tooltips to nodes

This code demonstrates how to add tooltips to nodes in a directed graph using dagre-d3. Tooltips are added by appending a 'title' element to each node.

const dagreD3 = require('dagre-d3');
const d3 = require('d3');

// Create a new directed graph
const g = new dagreD3.graphlib.Graph().setGraph({});

// Add nodes with tooltips
g.setNode('A', { label: 'Node A', title: 'This is Node A' });
g.setNode('B', { label: 'Node B', title: 'This is Node B' });

// Add an edge between nodes
g.setEdge('A', 'B');

// Create the renderer
const render = new dagreD3.render();

// Set up an SVG group so that we can translate the final graph.
const svg = d3.select('svg'),
    svgGroup = svg.append('g');

// Run the renderer. This is what draws the final graph.
render(d3.select('svg g'), g);

// Add tooltips
svg.selectAll('g.node').append('title').text(function(d) { return g.node(d).title; });

Other packages similar to dagre-d3

Keywords

FAQs

Package last updated on 03 Dec 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc