-
-
Notifications
You must be signed in to change notification settings - Fork 6.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #5221 from mermaid-js/3358-blocks-diagram
Adding new diagram type - Block Diagram
- Loading branch information
Showing
34 changed files
with
4,258 additions
and
141 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -25,6 +25,7 @@ const MERMAID_CONFIG_DIAGRAM_KEYS = [ | |
'gitGraph', | ||
'c4', | ||
'sankey', | ||
'block', | ||
] as const; | ||
|
||
/** | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,386 @@ | ||
import { imgSnapshotTest } from '../../helpers/util'; | ||
/* eslint-disable no-useless-escape */ | ||
describe('Block diagram', () => { | ||
it('BL1: should calculate the block widths', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 2 | ||
block | ||
id2["I am a wide one"] | ||
id1 | ||
end | ||
id["Next row"] | ||
` | ||
); | ||
}); | ||
|
||
it('BL2: should handle colums statement in sub-blocks', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
id1["Hello"] | ||
block | ||
columns 3 | ||
id2["to"] | ||
id3["the"] | ||
id4["World"] | ||
id5["World"] | ||
end | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL3: should align block widths and handle colums statement in sub-blocks', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
block | ||
columns 1 | ||
id1 | ||
id2 | ||
id2.1 | ||
end | ||
id3 | ||
id4 | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL4: should align block widths and handle colums statements in deeper sub-blocks then 1 level', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 1 | ||
block | ||
columns 1 | ||
block | ||
columns 3 | ||
id1 | ||
id2 | ||
id2.1(("XYZ")) | ||
end | ||
id48 | ||
end | ||
id3 | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL5: should align block widths and handle colums statements in deeper sub-blocks then 1 level (alt)', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 1 | ||
block | ||
id1 | ||
id2 | ||
block | ||
columns 1 | ||
id3("Wider then") | ||
id5(("id5")) | ||
end | ||
end | ||
id4 | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL6: should handle block arrows and spece statements', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
space:3 | ||
ida idb idc | ||
id1 id2 | ||
blockArrowId<["Label"]>(right) | ||
blockArrowId2<["Label"]>(left) | ||
blockArrowId3<["Label"]>(up) | ||
blockArrowId4<["Label"]>(down) | ||
blockArrowId5<["Label"]>(x) | ||
blockArrowId6<["Label"]>(y) | ||
blockArrowId6<["Label"]>(x, down) | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL7: should handle different types of edges', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
A space:5 | ||
A --o B | ||
A --> C | ||
A --x D | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL8: should handle sub-blocks without columns statements', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 2 | ||
C A B | ||
block | ||
D | ||
E | ||
end | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL9: should handle edges from blocks in sub blocks to other blocks', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
B space | ||
block | ||
D | ||
end | ||
D --> B | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL10: should handle edges from composite blocks', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
B space | ||
block BL | ||
D | ||
end | ||
BL --> B | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL11: should handle edges to composite blocks', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
B space | ||
block BL | ||
D | ||
end | ||
B --> BL | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL12: edges should handle labels', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
A | ||
space | ||
A -- "apa" --> E | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL13: should handle block arrows in different directions', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
space blockArrowId1<["down"]>(down) space | ||
blockArrowId2<["right"]>(right) blockArrowId3<["Sync"]>(x, y) blockArrowId4<["left"]>(left) | ||
space blockArrowId5<["up"]>(up) space | ||
blockArrowId6<["x"]>(x) space blockArrowId7<["y"]>(y) | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL14: should style statements and class statements', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
A | ||
B | ||
classDef blue fill:#66f,stroke:#333,stroke-width:2px; | ||
class A blue | ||
style B fill:#f9F,stroke:#333,stroke-width:4px | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL15: width alignment - D and E should share available space', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
block | ||
D | ||
E | ||
end | ||
db("This is the text in the box") | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL16: width alignment - C should be as wide as the composite block', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
block | ||
A("This is the text") | ||
B | ||
end | ||
C | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL16: width alignment - blocks shold be equal in width', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
A("This is the text") | ||
B | ||
C | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL17: block types 1 - square, rounded and circle', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
A["square"] | ||
B("rounded") | ||
C(("circle")) | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL18: block types 2 - odd, diamond and hexagon', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
A>"rect_left_inv_arrow"] | ||
B{"diamond"} | ||
C{{"hexagon"}} | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL19: block types 3 - stadium', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
A(["stadium"]) | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL20: block types 4 - lean right, lean left, trapezoid and inv trapezoid', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
A[/"lean right"/] | ||
B[\"lean left"\] | ||
C[/"trapezoid"\] | ||
D[\"trapezoid alt"/] | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL21: block types 1 - square, rounded and circle', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
A["square"] | ||
B("rounded") | ||
C(("circle")) | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL22: sizing - it should be possible to make a block wider', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
A("rounded"):2 | ||
B:2 | ||
C | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL23: sizing - it should be possible to make a composite block wider', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
block:2 | ||
A | ||
end | ||
B | ||
`, | ||
{} | ||
); | ||
}); | ||
|
||
it('BL24: block in the middle with space on each side', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
space | ||
middle["In the middle"] | ||
space | ||
`, | ||
{} | ||
); | ||
}); | ||
it('BL25: space and an edge', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 5 | ||
A space B | ||
A --x B | ||
`, | ||
{} | ||
); | ||
}); | ||
it('BL26: block sizes for regular blocks', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
a["A wide one"] b:2 c:2 d | ||
`, | ||
{} | ||
); | ||
}); | ||
it('BL27: composite block with a set width - f should use the available space', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
a:3 | ||
block:e:3 | ||
f | ||
end | ||
g | ||
`, | ||
{} | ||
); | ||
}); | ||
it('BL23: composite block with a set width - f and g should split the available space', () => { | ||
imgSnapshotTest( | ||
`block-beta | ||
columns 3 | ||
a:3 | ||
block:e:3 | ||
f | ||
g | ||
end | ||
h | ||
i | ||
j | ||
`, | ||
{} | ||
); | ||
}); | ||
}); |
Oops, something went wrong.