Anchor Points
The sample demonstrates what anchor patterns are, how to create your own anchor patterns or load one of the predefined and how to apply them on diagram nodes.
data:image/s3,"s3://crabby-images/edb49/edb4952f7c73cc4b41b6f028d4f75695e33fdd80" alt="JS Flowchart: Anchor Patterns JS Flowchart: Anchor Patterns"
Animations
The sample teaches you how to use the Animation object to achieve effective diagram rendering. You can test various animation and easing types applied on a flowchart that is built dynamically based on user input.
data:image/s3,"s3://crabby-images/13518/13518874cfba66a370e842066c67c1ede314f96a" alt="JavaScript Diagram Library: Animations JavaScript Diagram Library: Animations"
BPMN Diagram
This is a sample BPMN diagram application. Click on a button to select the connector type. Change the color of nodes with the color picker. Double click on a link or node to add text. Save and load the diagram to/from local storage.
data:image/s3,"s3://crabby-images/5f923/5f92377dfcebc8bb39eb76cb2b9327a17afe3907" alt="Online BPMN Diagram APplication Online BPMN Diagram APplication"
Christmas Diagram
An interactive Christmas diagram web application that loads custom shapes from a shape library and uses link customization to draw garlands.
data:image/s3,"s3://crabby-images/05e2d/05e2de0f3370be81d8ac51263c84df6b4e1df918" alt="An interactive Christmas app in JavaScript An interactive Christmas app in JavaScript"
Class Inheritance
TableNodes are used to represent all major classes in the diagram library. The prototype of each class is questioned for a list of the available properties. After the diagram was built, the tree layout is applied to arrange it.
data:image/s3,"s3://crabby-images/d5ad5/d5ad555072d5c93505650153d64d0e79a6aaea21" alt="JavaScript Class Inheritance Diagram JavaScript Class Inheritance Diagram"
Containers
Container nodes are used to demonstrate how you can group and sort items using the ContainerNode object. Containers can be folded, styled and participate in layout algorithms just like the other ShapeNode types.
data:image/s3,"s3://crabby-images/9ce49/9ce49197aafc1ea27974a450b28638da0fcb7cf3" alt="JS Diagram Control: Container Nodes JS Diagram Control: Container Nodes"
Controls
A presentation of the auxiliary controls that go with the diagram library - Overview, NodeListView control and Zoom control.
data:image/s3,"s3://crabby-images/a2b24/a2b249eb6a2df14c250cd78583747e073e034e0b" alt="JavaScript Diagram Component: Auxiliary Controls JavaScript Diagram Component: Auxiliary Controls"
Database Designer
A database designer application that generates the SQL for updating the database. Users can create and rename tables, link them row to row as well delete them. They can also create, edit and delete table rows.
data:image/s3,"s3://crabby-images/4229e/4229e6129f8ec447f521b0e37f8967b2e2a33908" alt="Database Designer in JavaScript with SQL Generator Database Designer in JavaScript with SQL Generator"
Decision Tree
The sample demonstrates how to build a step-by-step decision tree with nodes that list available options at each step. Nodes at the last level are arranged with the TreeLayout.
data:image/s3,"s3://crabby-images/fe2c7/fe2c70421fc74ce406d9ff0e1b006b72e1976276" alt="Interactive Decision Tree in JavaScript Interactive Decision Tree in JavaScript"
DOM Tree
Build a tree dynamically and let users expand or collapse tree branches. In addition, the sample demonstrates how to apply and customize the tree layout.
data:image/s3,"s3://crabby-images/c9606/c96060d762880c11535003a15030ff254c04f0e9" alt="Dynamically Built HTML DOM Tree in JavaScript Dynamically Built HTML DOM Tree in JavaScript"
Event Sequence Diagram
A typical event sequence diagram, which users can customize with a change of background colour for nodes as well as adding/deleting nodes and connectors.
data:image/s3,"s3://crabby-images/6617f/6617f22ec6d5731e010ada1a9f135a1055066365" alt="Event Sequence Diagram in JavaScript Event Sequence Diagram in JavaScript"
Export/Import To/From Custom Json
The sample exports only a part of the diagram data into a json and loads it. The built-in toJson/fromJson methods export/import all the diagram data.
data:image/s3,"s3://crabby-images/3c20b/3c20b8d7bd6e5bec48a5e152d7d7f74eb5960e66" alt="Export and import of a diagram into/from custom json file Export and import of a diagram into/from custom json file"
Flowcharter
A complete ready-to-use diagramming application that initializes with a flowchart built in code. Users can customize the diagram nodes, add / delete nodes and save / load diagram through localSotrage.
data:image/s3,"s3://crabby-images/e5aaa/e5aaae2190d70ee58be5314ee39efd777e82207a" alt="Complete JS Application for Drawing Flowcharts Complete JS Application for Drawing Flowcharts"
Fractal Layout
The fractal layout is used to arrange a randomly generated diagram. This algorithm places child nodes symmetrically around their parent node and the result diagram has fractal-like appearance. Each graph subset looks like a scaled-down version of the whole graph.
data:image/s3,"s3://crabby-images/64afe/64afe76405de3436b14737649c61f55033c1de4c" alt="Javascript Flowchart Library: Fractal Layout Javascript Flowchart Library: Fractal Layout"
Improving Link Legibility
A demonstration of some of the options to position links in such a way that makes them easy to follow.
data:image/s3,"s3://crabby-images/197b5/197b59fd72fed6e4d365988ad80ea087a066695e" alt="Arranging Diagram Links in JavaScript Arranging Diagram Links in JavaScript"
Lanes
The diagram's lane grid is used to render a Gantt chart where grid columns are painted differently. Each newly created flowchart item is aligned automatically to a lane chosen by the user.
data:image/s3,"s3://crabby-images/fc3d6/fc3d6420ac0371d01135877e357c81cdd057d7a8" alt="JavaScript Lane Diagram JavaScript Lane Diagram"
Layered Layout
The layered layout algorithm is applied on a randomly generated graph with large number of nodes. The layout aims to order nodes at similar distance from the root in layers.
data:image/s3,"s3://crabby-images/b8214/b8214aeb4c28da9711dcb3f58ac104f828499068" alt="Automatic Graph Arrangement Algorithms in JavaScript: Layered Layout Automatic Graph Arrangement Algorithms in JavaScript: Layered Layout"
Mouse Events
Learn how to implement programmatically pan and zoom in a JavaScript diagram.
data:image/s3,"s3://crabby-images/a1959/a1959b3a554f792c52a18b1e308507b272ba35e9" alt="Diagramming for JavaScript: Mouse Events Diagramming for JavaScript: Mouse Events"
Multiple Parents
This sample loads a graph where nodes can have multiple parents. The graph is arranged with the LayeredLayout automatic algorithm. Click on a button to select the connector type. Change the color of nodes with the color picker. Double click on a link or node to add text. Save and load the diagram to/from local storage.
data:image/s3,"s3://crabby-images/5b9b5/5b9b5ff2c9163fbd22bf20fdfc16cd89442005e9" alt="Diagram Nodes with Multiple Parents Diagram Nodes with Multiple Parents"
Organizational Chart
An organizational chart that uses custom TableNode-s to represent a hierarchy of employees. The sample offers plenty of user interaction - new nodes can be created, nodes can be rearranged and fields edited.
data:image/s3,"s3://crabby-images/1ec7f/1ec7faaa10b4bc2cddf85e6437839d67cf958294" alt="Org Chart in JavaScript Org Chart in JavaScript"
Pull Links Apart
This sample creates a flowchart and adds a few methods that distribute links connecting the same nodes.
data:image/s3,"s3://crabby-images/a6c62/a6c62fb57b80f4d1c68cca4c43f431b8c04eaddc" alt="Pull Apart of Diagram Links in JavaScript Pull Apart of Diagram Links in JavaScript"
Spanning Cells
Three table nodes with numerous cells and rows demonstrate how you can apply the apabilities of the library to span rows, columns and create links between table rows of your choice.
data:image/s3,"s3://crabby-images/abe28/abe28795e597588d6293ae39430827113c6f465d" alt="JavaScript Table Nodes with Spanning Cells JavaScript Table Nodes with Spanning Cells"
Stock Shapes
An overview of the stock shapes available with the library. Besides a large set of ready-to-use flowchart node shapes, you can create your own shapes and save them.
data:image/s3,"s3://crabby-images/42eb8/42eb81ef6565a6c4fe076923f595449799ea86d0" alt="JavaScript Flowchart: Stock Shapes JavaScript Flowchart: Stock Shapes"
SVG Nodes
SvgNode objects are created here to imitate vehicles on a parking place. The background of each node is a SvgImage, the background of the diagram is a png image file.
data:image/s3,"s3://crabby-images/796e8/796e8de22c634188348dee4cb447710313a0ecf1" alt="JavaScript Svg Diagram Nodes JavaScript Svg Diagram Nodes"
Tree Layout
Users can drag nodes from the NodeListView control to the left and drop them onto each other. The newly created nodes automatically get arranged using the TreeLayout algorithm. The final result is a graph imitating a tree where each node is a leaf.
data:image/s3,"s3://crabby-images/19b72/19b7202cd020b2ec428d9a71ed0cc15689890e1e" alt="JS Flowchart Control: Tree Layout JS Flowchart Control: Tree Layout"
TreeMap
The treemap layout uses given weigh value for each node as a guide about the size of each rectangular node it draws. A second criteria determines the coloring of the nodes.
data:image/s3,"s3://crabby-images/f0b62/f0b62a7a37af54c42039bad2c1df34c864f0cbc1" alt="JS Diagram Component: TreeMap Layout Algorithm JS Diagram Component: TreeMap Layout Algorithm"
TreeMap Chart for Lithium Production
A TreeMap diagram that reads its data from an XML file and applies the TreeMapLayout. The diagram has a tiled background image, nodes contain text and image and render tooltips.
data:image/s3,"s3://crabby-images/98634/986340078e4850318a5172ab96080cf3bd99af68" alt="MindFusion Diagramming for JavaScript: TreeMap MindFusion Diagramming for JavaScript: TreeMap"
Tutorial #1
A basic guide on how to build diagram nodes and links from jason data and how to apply the layered layout on the new graph.
data:image/s3,"s3://crabby-images/cafb5/cafb55e7de700066605953b7de1673a1a85fdc73" alt="Basic Flowchart in JavaScript Basic Flowchart in JavaScript"
Tutorial #2
Here you read information for the flowchart from json data and arrange the newly created diagram with the BorderedTreeLayout.
data:image/s3,"s3://crabby-images/0ac78/0ac78cf4128f7bf0dc4c9e2cb0241ff60ddfb29d" alt="Flowchart arranged with the BorderedTreeLayout Algorithm Flowchart arranged with the BorderedTreeLayout Algorithm"
Tutorial #3
Here a custom node class is used that exposes some new properties in addition to the ones defined by DiagramNode and implements its own drawing logic.
data:image/s3,"s3://crabby-images/e92f9/e92f95b6dde3da44a1f9b43e35304fbbfbcaaf44" alt="Custom Diagram Node Class in JavaScript Custom Diagram Node Class in JavaScript"