Skip to content

Commit

Permalink
#3358 Second set of changes after review
Browse files Browse the repository at this point in the history
  • Loading branch information
knsv committed Jan 29, 2024
1 parent 1629a91 commit 37d7c7e
Show file tree
Hide file tree
Showing 10 changed files with 377 additions and 756 deletions.
16 changes: 8 additions & 8 deletions cypress/platform/knsv2.html
Original file line number Diff line number Diff line change
Expand Up @@ -64,14 +64,14 @@
</head>
<body>
<pre id="diagram" class="mermaid">
block-beta
columns 3
a:3
block:e:3
f
end
g

block-beta
blockArrowId<["Label"]>(right)
blockArrowId2<["Label"]>(left)
blockArrowId3<["Label"]>(up)
blockArrowId4<["Label"]>(down)
blockArrowId5<["Label"]>(x)
blockArrowId6<["Label"]>(y)
blockArrowId6<["Label"]>(x, down)
</pre>
<pre id="diagram" class="mermaid">
block-beta
Expand Down
126 changes: 114 additions & 12 deletions demos/block.html
Original file line number Diff line number Diff line change
Expand Up @@ -3,23 +3,125 @@
<head>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<title>States Mermaid Quick Test Page</title>
<title>Mermaid Block diagram demo page</title>
<link rel="icon" type="image/png" href="" />
<style>
div.mermaid {
font-family: 'Courier New', Courier, monospace !important;
}
</style>
</head>

<body>
<h1>Block diagram demos</h1>
<h2>TCI IP</h2>
<pre class="mermaid">
block-beta
A>"rect_left_inv_arrow"]
B{"diamond"}
C{{"hexagon"}}
<pre id="diagram" class="mermaid">
block-beta
columns 1
db(("DB"))
blockArrowId6<["&nbsp;&nbsp;&nbsp;"]>(down)
block:ID
A
B["A wide one in the middle"]
C
end
space
D
ID --> D
C --> D
style B fill:#f9F,stroke:#333,stroke-width:4px
</pre>
<pre id="diagram" class="mermaid">
block-beta
A1["square"]
B1("rounded")
C1(("circle"))
A2>"rect_left_inv_arrow"]
B2{"diamond"}
C2{{"hexagon"}}
</pre>

<pre id="diagram" class="mermaid">
block-beta
A1(["stadium"])
A2[["subroutine"]]
B1[("cylinder")]
C1>"surprise"]
A3[/"lean right"/]
B2[\"lean left"\]
C2[/"trapezoid"\]
D2[\"trapezoid"/]
</pre>

<pre id="diagram" class="mermaid">
block-beta
block:e:4
columns 2
f
g
end

</pre>
<pre id="diagram" class="mermaid">
block-beta
block:e:4
columns 2
f
g
h
end

</pre>
<pre id="diagram" class="mermaid">
block-beta
columns 3
a:3
block:e:3
f
g
end
h
i
j

</pre>
<pre id="diagram" class="mermaid">
block-beta
columns 4
a b c d
block:e:4
columns 2
f
g
h
end
i:4

</pre>
<pre id="diagram" class="mermaid">
flowchart LR
X-- "a label" -->z
</pre>
<pre id="diagram" class="mermaid">
block-beta
columns 5
A space B
A --x B
</pre>
<pre id="diagram" class="mermaid">
block-beta
columns 3
a["A wide one"] b:2 c:2 d
</pre>

<pre id="diagram" class="mermaid">
block-beta
columns 3
a b c
e:3
f g h
</pre>

<pre id="diagram" class="mermaid">
block-beta

A1:3
A2:1
A3
</pre>

<script type="module">
Expand Down
44 changes: 20 additions & 24 deletions docs/syntax/block.md
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ block-beta

This example will produce a horizontal sequence of three blocks. Each block is automatically spaced and aligned for optimal readability.

### Diagrams with Multiple Columns
### Defining the number of columns to use

#### Column Usage

Expand Down Expand Up @@ -132,13 +132,13 @@ To create a block diagram where one block spans across two columns, you can spec
```mermaid-example
block-beta
columns 3
a["A wide one"] b:2 c:2 d
a["A label"] b:2 c:2 d
```

```mermaid
block-beta
columns 3
a["A wide one"] b:2 c:2 d
a["A label"] b:2 c:2 d
```

In this example, the block labeled "A wide one" spans two columns, while blocks 'b', 'c', and 'd' are allocated their own columns. This flexibility in block sizing is crucial for accurately representing systems with components of varying significance or size.
Expand Down Expand Up @@ -183,20 +183,30 @@ In diagrams with varying block sizes, Mermaid automatically adjusts the column w
block-beta
columns 3
a:3
block:e:3
f
block:group1:2
columns 2
h i j k
end
g
block:group2:3
%% columns auto (default)
l m n o p q r
end
```

```mermaid
block-beta
columns 3
a:3
block:e:3
f
block:group1:2
columns 2
h i j k
end
g
block:group2:3
%% columns auto (default)
l m n o p q r
end
```

This example demonstrates how Mermaid dynamically adjusts the width of the columns to accommodate the widest block, in this case, 'a' and the composite block 'e'. This dynamic adjustment is essential for creating visually balanced and easy-to-understand diagrams.
Expand Down Expand Up @@ -407,14 +417,12 @@ or

```mermaid-example
block-beta
space:3
ida idb idc
ida space:3 idb idc
```

```mermaid
block-beta
space:3
ida idb idc
ida space:3 idb idc
```

Note that you can set how many columns the spece block occupied using the number notaion `space:num` where num is a number indicating the num columns width. You can alsio use `space` which defaults to one column.
Expand Down Expand Up @@ -597,7 +605,6 @@ block-beta
style Start fill:#969;
style End fill:#696;
```

```mermaid
Expand All @@ -611,19 +618,8 @@ block-beta
style Start fill:#969;
style End fill:#696;
```

This diagram depicts a simple decision-making process with two possible paths leading to an endpoint, demonstrating the use of different shapes and directional arrows.

### Real world Scenarios

Block diagrams can be employed in a variety of real-world scenarios. Here are a few examples:

- **IT Network Layouts**: Visualize the structure of IT networks, showing how different devices and services are connected.
- **Educational Diagrams**: Explain complex scientific concepts, engineering systems, or historical timelines.
- **Organizational Charts**: Represent the hierarchy and relationships within an organization or department.

These practical examples and scenarios underscore the utility of Mermaid block diagrams in simplifying and effectively communicating complex information across various domains.

The next section, 'Troubleshooting and Common Issues', will provide insights into resolving common challenges encountered when working with Mermaid block diagrams, ensuring a smooth diagramming experience.
Expand Down Expand Up @@ -705,6 +701,6 @@ Use classes to maintain consistent styling across similar elements. This not onl

#### Comments and Documentation

Use comments within the Mermaid syntax to document the purpose of various parts of the diagram. This practice is invaluable for maintaining clarity, especially when working in teams or returning to a diagram after some time.
Use comments with `%%` within the Mermaid syntax to document the purpose of various parts of the diagram. This practice is invaluable for maintaining clarity, especially when working in teams or returning to a diagram after some time.

With these troubleshooting tips and best practices, you can effectively manage and resolve common issues in Mermaid block diagrams. The final section, 'Conclusion', will summarize the key points covered in this documentation and invite user feedback for continuous improvement.
Loading

0 comments on commit 37d7c7e

Please sign in to comment.