Skip to content

formsandlines/boxmodel-layout-for-d3

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Custom CSS-like boxmodel layout for D3.js

This custom layout for hierarchical data is inspired by the CSS box-model and adds margin and padding on all four sides of nested elements.

  • Boxes are arranged horizontally in lines; if a maximum line width is exceeded, they flow into a new line.
  • Padding is added inside, margins outside the boundary of boxes.
  • Width and height of the boxes is defined by their combined child sizes (width/height plus margins) as well as the padding of the box itself.
  • Empty boxes collapse to their padding, but you can also specify a minimal width and height for containers.
  • Elements that are not intended as boxes must set the boolean isContainer to false and can have a fixed width and height.

See it in action

Usage

npm install boxmodel-layout-for-d3 --save
// ES6:
import boxmodel from 'boxmodel-layout-for-d3';

// CommonJS:
var boxmodel = require('boxmodel-layout-for-d3');

Or you can just embed the library via script-tag, but make sure you also include d3.js as a dependency:

<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/5.9.2/d3.min.js"></script>

<script src="<yourpath>/boxmodel-d3.min.js"></script>
// or just use the unpkg link:
<script src="https://unpkg.com/boxmodel-layout-for-d3@latest/dist/boxmodel-d3.min.js"></script>

About

Custom D3.js-layout to generate CSS-like boxmodel in SVG

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published