-
-
Notifications
You must be signed in to change notification settings - Fork 7k
Block Diagram (WIP)
data:image/s3,"s3://crabby-images/4ba01/4ba01c66e23ba3d365330558b97e228f5238ea72" alt="image"
block
block1["Block 1"]
data:image/s3,"s3://crabby-images/49953/49953fb5afa2893a97bc2b5fd32645028fd918a8" alt="image"
block
block1["Block 1"]
block2["Block 2"]
data:image/s3,"s3://crabby-images/88c54/88c54092878531cab3243ec82e2f29e756c239ca" alt="image"
block
columns 1
block1["Block 1"]
block2["Block 2"]
or
block
direction TB
block1["Block 1"]
block2["Block 2"]
data:image/s3,"s3://crabby-images/6bf1e/6bf1e01af68f6b014fc80b17fa88a20de48cd307" alt="image"
block
direction TB
block1["Block 1"]
block
block2["Block 2"]
block3["Block 3"]
end %% End the compound block
This differs from regular edges as the arrow is really a block.
data:image/s3,"s3://crabby-images/8fbb5/8fbb53bc16df8fc4946d18f5bf361fa34341aa7a" alt="image"
block
direction LR
block1["Block 1"]
<=1,1=>
block2["Block 2"]
or (equivalent)
block
direction LR
block1["Block 1"] <=1,1=> block2["Block 2"]
data:image/s3,"s3://crabby-images/173a4/173a46b02bf2c2c99070b37861804353bb5de29a" alt="image"
block
direction TB
block1["Block 1"]
<=1,1=>
block2["Block 2"]
The edges works as they do in flowcharts. From one node to the other based on the id. There will be no auto-layout but a a line from one node to the other.
block
A --> B
Would render like this:
data:image/s3,"s3://crabby-images/c56a5/c56a5268a32705495721d4c3e4d1e8fed3186179" alt="image"
If nodes do not have overlapping the arrow would be between their centers.
If nodes overlap then arrows must connect middles of overlapping parts
data:image/s3,"s3://crabby-images/2e17f/2e17fb0ed95c162e61d3ca20eccf2c549ceff5f7" alt="arrow between centers"
data:image/s3,"s3://crabby-images/be349/be34972ab829bb80a753d8ff85e3433b1487bf7f" alt="arrow between overlapping parts"
In some cases an edge can take size of the whole block
data:image/s3,"s3://crabby-images/2eb7c/2eb7ce67c1ee9e4f8dcbe4f378d7df2d4955a6fc" alt=""
data:image/s3,"s3://crabby-images/37876/37876ad37a183c55c5916fe7e9ccd482ae6a3a95" alt=""
Amount of columns are automatically calculated. So specifying it is redundant unless you specifically want to set to a value. This could for instance be the case where you want a block to take half of the space. The default state is columns auto
.
block-beta
block
block app
columns auto %% or
columns 5
end
end
block-beta
block app["Application"]
direction LR
app --> client
app --> admin
client <--> admin
client["Client Application"]
admin["Admin Application"]
end
alt
block-beta
block app["Application"]
app
<=0,2=>
block
client <= 1,1 => admin
end
direction=TB
data:image/s3,"s3://crabby-images/b5866/b5866f15e8c4964b1aa00d1d7fc574257c082597" alt=""
direction=LR
data:image/s3,"s3://crabby-images/8eb8a/8eb8a04045aa9ea93b239845d57c8af00ae02d67" alt=""
Direction is inspired by dot
language as well as flex-direction
attribute.
Layout direction for nested blocks must be switched automatically
block-beta
direction TB
block row1
col1
col2
col3
end
block row2
col1
col2
col3
end
block row3
col1
col2
col3
end
data:image/s3,"s3://crabby-images/cbf8c/cbf8c97bcb6767c00c0fdb35fd634df803660677" alt=""
The same graph with direction LR
data:image/s3,"s3://crabby-images/165ea/165eabca751e432a334523ae506564f26f9580f6" alt=""
A block with a width attached will use multiple blocks. For instance:
block
A:2 B
data:image/s3,"s3://crabby-images/30193/3019398912096bb82398a1a775dfa445dda2994f" alt="image"
If you have discrepancies the missing blocks are empty. For instance in the following block diagram you have full width block followed with another row with one block, B, using 2/3 of the width:
block
direction TB
A
block
columns 3
B:2
end
Here you can se this rendered:
data:image/s3,"s3://crabby-images/64a7f/64a7fec4860874c0ea01e5e64510692f94f54f93" alt="image"
The default width for a block is 1. In the example below A will use half of the space.
block
columns 2
A
Sometimes you might want to insert an empty block that still use space. This can be facilitated using a space block. as per the following example:
block
block
space:2 id1["X"]
end
block
space id2["X"]
end
block
id3["X"]
end
In the rendered image you can see the nameless blocks with a dashed border, in a real diagram they would be invisisble.
data:image/s3,"s3://crabby-images/b57d9/b57d9cbe4316b37275bcf1a4e3ac766b5352aec2" alt="image"
We need an intuitive way to specify if a block should have padding or not and it should have a border...
These statements should work in the same way as in flowcharts