sprite-extend-dagre
sprite-extend-dagre copied to clipboard
Draws simple flow chart diagrams with spritejs. Powered by dagre.js.
Sprite-Dagre
Draws simple flow chart diagrams with spritejs. Powered by Dagre and Rough.js. Inspired by MermaidJS.
Usage
<script src="https://unpkg.com/spritejs/dist/spritejs.min.js"></script>
<script src="https://unpkg.com/sprite-extend-rough/dist/sprite-extend-rough.js"></script>
<script src="https://unpkg.com/sprite-extend-dagre/dist/sprite-extend-dagre.js"></script>
<script>
const {Scene, Dagre} = spritejs;
const scene = new Scene('#container', {
viewport: 'auto',
resolution: 'flex',
useDocumentCSS: true,
});
const fglayer = scene.layer('fglayer');
const dagreGroup = new Dagre({
pos: fglayer.center,
anchor: 0.5,
lineWidth: 5,
});
fglayer.append(dagreGroup);
dagreGroup.layoutGraph(`
graph TB
A->B~~D
B~>C
`);
</script>
data:image/s3,"s3://crabby-images/05a0e/05a0e932f0241a7cb90e047988bfe188d81bb1dc" alt=""
Flow charts
Graph [direction] declares a new graph and the direction of the graph layout.
Possible directions are:
- TB - top bottom (default)
- BT - bottom top
- RL - right left
- LR - left right
dagreGroup.layoutGraph(`
graph LR
A->B~~D
B~>C
`);
This declares a graph oriented from left to right.
data:image/s3,"s3://crabby-images/c0bc2/c0bc2c1235c776adadaf968ff9ac6b108afafce7" alt=""
Nodes & Shapes
A node (default)
dagreGroup.layoutGraph(`
graph LR
id
`);
data:image/s3,"s3://crabby-images/3b985/3b9851d2d66e0237ce5bf0256490249c56ce5c80" alt=""
A node with text
dagreGroup.layoutGraph(`
graph LR
id1[This is the text in the box]
`);
data:image/s3,"s3://crabby-images/39d9d/39d9d54c1a43ac55dc1c0f0da236bbc941e5939c" alt=""
A node with round edges
dagreGroup.layoutGraph(`
graph LR
id1(This is the text in the box)
`);
data:image/s3,"s3://crabby-images/dff03/dff0354142d6ccffeb30b6289a02a6855da73245" alt=""
A node in the form of an ellipse
dagreGroup.layoutGraph(`
graph LR
id1((This is the text in the ellipse))
`);
data:image/s3,"s3://crabby-images/0b21a/0b21afee8b04f56968d8a56a60fbb2882b532394" alt=""
A node (rhombus)
dagreGroup.layoutGraph(`
graph LR
id1<This is the text in the box>
`);
data:image/s3,"s3://crabby-images/3291a/3291a0cb20e4487874ea288cf4bffebc571776e1" alt=""
A node (parallelogram)
dagreGroup.layoutGraph(`
graph LR
id1/This is the text in the box/
`);
data:image/s3,"s3://crabby-images/d9c45/d9c45d27c15368241565a507a3b3828012cd4d25" alt=""
A user defined node
dagreGroup.layoutGraph(`
graph LR
id1!star
`, {
star() {
const star = new Star();
star.attr({
radius: 100,
color: 'red',
angles: 5,
fillColor: 'red',
});
return star;
},
});
data:image/s3,"s3://crabby-images/d74b3/d74b3852cc5946838f252884b4b24bb0b0024b21" alt=""
Links between nodes
A link with arrow head
dagreGroup.layoutGraph(`
graph LR
A->B
`);
data:image/s3,"s3://crabby-images/d0b1b/d0b1bf9142d521d8320099994e86e7f423f47191" alt=""
An open link
dagreGroup.layoutGraph(`
graph LR
A--B
`);
data:image/s3,"s3://crabby-images/d4c59/d4c5926274132ddb061e3d181727aa6ad2ce8277" alt=""
A dashed link
dagreGroup.layoutGraph(`
graph LR
A~>B
`);
data:image/s3,"s3://crabby-images/11436/1143637e157970800aa1bebfcc7e5c732bc64707" alt=""
A dashed open link
dagreGroup.layoutGraph(`
graph LR
A~~B
`);
data:image/s3,"s3://crabby-images/81a8f/81a8f92985e1b0f6702d1504609039febd7bbf55" alt=""
A link with text
dagreGroup.layoutGraph(`
graph LR
A->B{"Link text"}
`);
data:image/s3,"s3://crabby-images/69f22/69f22e2c2f80e0ed2a39b786cd921c9be811bda4" alt=""
A link with colored text
dagreGroup.layoutGraph(`
graph LR
A->B{"Link text" red}
`);
data:image/s3,"s3://crabby-images/bc1ed/bc1ed6a17f4d35a14ba8c532389a7fda7f701c7b" alt=""
Demo
const {Scene, Dagre} = spritejs;
const scene = new Scene('#container', {
viewport: 'auto',
resolution: 'flex',
useDocumentCSS: true,
});
const fglayer = scene.layer('fglayer');
const dagreGroup = new Dagre({
pos: fglayer.center,
lineWidth: 5,
anchor: 0.5,
});
fglayer.append(dagreGroup);
dagreGroup.layoutGraph(`
graph TB
start((S))
step1[proceed]
step2<decision?>
step3/read file/
step4(done)
start->step1->step2
step2~>step4{no}
step2->step3{yes}
step3->step4
`);
data:image/s3,"s3://crabby-images/49ef8/49ef84431e7c19c1c857f39a714765090f276cf5" alt=""
Styling nodes & links
#step1 {
--sprite-fillColor: red;
--sprite-labelBg: white;
}
#step2 {
--sprite-strokeColor: blue;
--sprite-labelColor: red;
}
dagreedge[connection="[step1,step2]"] {
--sprite-strokeColor: green;
}
const {Scene, Dagre} = spritejs;
const scene = new Scene('#container', {
viewport: 'auto',
resolution: 'flex',
useDocumentCSS: true,
});
const fglayer = scene.layer('fglayer');
const dagreGroup = new Dagre({
pos: fglayer.center,
lineWidth: 5,
anchor: 0.5,
});
fglayer.append(dagreGroup);
dagreGroup.layoutGraph(`
graph TB
start((S))
step1[proceed]
step2<decision?>
step3/read file/
step4(done)
start->step1->step2
step2~>step4{no}
step2->step3{yes}
step3->step4
`);
data:image/s3,"s3://crabby-images/5d424/5d424133121e551f91d09fb56ecb87a9ff7cfcd6" alt=""