GoJS, a JavaScript Library for HTML Diagrams
GoJS is a JavaScript and TypeScript library for creating and manipulating diagrams, charts, and graphs.
See GoJS Samples
Get Started with GoJS
GoJS is a flexible library that can be used to create a number of different kinds of interactive diagrams,
including data visualizations, drawing tools, and graph editors.
There are samples for
flowchart,
org chart,
business process BPMN,
swimlanes,
timelines,
state charts,
kanban,
network,
mindmap,
sankey,
family trees and genogram charts,
fishbone diagrams,
floor plans,
UML,
decision trees,
PERT charts,
Gantt, and
hundreds more.
GoJS includes a number of built in layouts including tree layout, force directed, circular, and layered digraph layout,
and many custom layout extensions and examples.
GoJS is renders either to an HTML Canvas element (with export to SVG or image formats) or directly as SVG DOM.
GoJS can run in a web browser, or server side in Node or Puppeteer.
GoJS Diagrams are backed by Models, with saving and loading typically via JSON-formatted text.
Read more about GoJS at gojs.net
This repository contains only the library.
The sources for all samples, extensions, and documentation can be installed by running:
$ npm create gojs-kit@latest
You can use the GitHub repository to quickly search through all of the sources.
Minimal Sample
Graphs are constructed by creating one or more templates, with desired properties data-bound, and adding model data.
<div id="myDiagramDiv" style="width:400px; height:150px;"></div>
<script src="https://unpkg.com/gojs"></script>
<script>
const myDiagram = new go.Diagram(
'myDiagramDiv',
{ 'undoManager.isEnabled': true }
);
myDiagram.nodeTemplate = new go.Node('Auto')
.add(
new go.Shape('RoundedRectangle', { strokeWidth: 0, fill: 'white' })
.bind('fill', 'color')
)
.add(
new go.TextBlock({ margin: 8, stroke: '#333' })
.bind('text', 'key')
);
myDiagram.model = new go.GraphLinksModel(
[
{ key: 'Alpha', color: 'lightblue' },
{ key: 'Beta', color: 'orange' },
{ key: 'Gamma', color: 'lightgreen' },
{ key: 'Delta', color: 'pink' },
],
[
{ from: 'Alpha', to: 'Beta' },
{ from: 'Alpha', to: 'Gamma' },
{ from: 'Beta', to: 'Beta' },
{ from: 'Gamma', to: 'Delta' },
{ from: 'Delta', to: 'Alpha' },
]
);
</script>
The above diagram and model code creates the following graph.
The user can now click on nodes or links to select them, copy-and-paste them, drag them, delete them, scroll, pan, and zoom, with a mouse or with fingers.
Click the image to see the interactive GoJS Diagram
Support
Northwoods Software offers a month of free developer-to-developer support for GoJS to prospective customers so you can finish your project faster.
Read and search the official GoJS forum for any topics related to your questions.
Posting in the forum is the fastest and most effective way of obtaining support for any GoJS related inquiries.
Please register for support at Northwoods Software's registration form before posting in the forum.
For any nontechnical questions about GoJS, such as about sales or licensing,
please visit Northwoods Software's contact form.
License
The GoJS software license.
Copyright (c) Northwoods Software Corporation