-
-
Notifications
You must be signed in to change notification settings - Fork 7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update C4 Diagram to new renderer #6276
base: develop
Are you sure you want to change the base?
Conversation
|
✅ Deploy Preview for mermaid-js ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
commit: |
The latest updates on your projects. Learn more about Argos notifications ↗︎
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please add a changeset.
Not familiar with C4, so haven't reviewed in detail.
`, | ||
options | ||
); | ||
}); | ||
|
||
it(`${description}should render a simple C4 diagram with the direction BT`, () => { | ||
imgSnapshotTest( | ||
` | ||
C4Context | ||
accTitle: C4 context demo | ||
accDescr: Many large C4 diagrams | ||
|
||
direction BT | ||
title System Context diagram for Internet Banking System | ||
|
||
Enterprise_Boundary(b0, "BankBoundary0") { | ||
Person(customerA, "Banking Customer A", "A customer of the bank, with personal bank accounts.") | ||
|
||
System(SystemAA, "Internet Banking System", "Allows customers to view information about their bank accounts, and make payments.") | ||
|
||
Enterprise_Boundary(b1, "BankBoundary") { | ||
System_Ext(SystemC, "E-mail system", "The internal Microsoft Exchange e-mail system.") | ||
} | ||
} | ||
|
||
BiRel(customerA, SystemAA, "Uses") | ||
Rel(SystemAA, SystemC, "Sends e-mails", "SMTP") | ||
Rel(SystemC, customerA, "Sends e-mails to") | ||
|
||
UpdateElementStyle(customerA, $fontColor="red", $bgColor="grey", $borderColor="red") | ||
UpdateRelStyle(customerA, SystemAA, $textColor="blue", $lineColor="blue", $offsetX="5") | ||
UpdateRelStyle(SystemC, customerA, $textColor="red", $lineColor="red", $offsetX="-50", $offsetY="20") | ||
`, | ||
options | ||
); | ||
}); | ||
|
||
it(`${description}should render a simple C4 diagram with the direction LR`, () => { | ||
imgSnapshotTest( | ||
` | ||
C4Context | ||
accTitle: C4 context demo | ||
accDescr: Many large C4 diagrams | ||
|
||
direction LR | ||
title System Context diagram for Internet Banking System | ||
|
||
Enterprise_Boundary(b0, "BankBoundary0") { | ||
Person(customerA, "Banking Customer A", "A customer of the bank, with personal bank accounts.") | ||
|
||
System(SystemAA, "Internet Banking System", "Allows customers to view information about their bank accounts, and make payments.") | ||
|
||
Enterprise_Boundary(b1, "BankBoundary") { | ||
System_Ext(SystemC, "E-mail system", "The internal Microsoft Exchange e-mail system.") | ||
} | ||
} | ||
|
||
BiRel(customerA, SystemAA, "Uses") | ||
Rel(SystemAA, SystemC, "Sends e-mails", "SMTP") | ||
Rel(SystemC, customerA, "Sends e-mails to") | ||
|
||
UpdateElementStyle(customerA, $fontColor="red", $bgColor="grey", $borderColor="red") | ||
UpdateRelStyle(customerA, SystemAA, $textColor="blue", $lineColor="blue", $offsetX="5") | ||
UpdateRelStyle(SystemC, customerA, $textColor="red", $lineColor="red", $offsetX="-50", $offsetY="20") | ||
`, | ||
options | ||
); | ||
}); | ||
|
||
it(`${description}should render a simple C4 diagram with the direction RL`, () => { | ||
imgSnapshotTest( | ||
` | ||
C4Context | ||
accTitle: C4 context demo | ||
accDescr: Many large C4 diagrams | ||
|
||
direction RL | ||
title System Context diagram for Internet Banking System | ||
|
||
Enterprise_Boundary(b0, "BankBoundary0") { | ||
Person(customerA, "Banking Customer A", "A customer of the bank, with personal bank accounts.") | ||
|
||
System(SystemAA, "Internet Banking System", "Allows customers to view information about their bank accounts, and make payments.") | ||
|
||
Enterprise_Boundary(b1, "BankBoundary") { | ||
System_Ext(SystemC, "E-mail system", "The internal Microsoft Exchange e-mail system.") | ||
} | ||
} | ||
|
||
BiRel(customerA, SystemAA, "Uses") | ||
Rel(SystemAA, SystemC, "Sends e-mails", "SMTP") | ||
Rel(SystemC, customerA, "Sends e-mails to") | ||
|
||
UpdateElementStyle(customerA, $fontColor="red", $bgColor="grey", $borderColor="red") | ||
UpdateRelStyle(customerA, SystemAA, $textColor="blue", $lineColor="blue", $offsetX="5") | ||
UpdateRelStyle(SystemC, customerA, $textColor="red", $lineColor="red", $offsetX="-50", $offsetY="20") | ||
`, | ||
options | ||
); | ||
}); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Write this in a loop?
} | ||
} | ||
|
||
//type, from, to, label, ?techn, ?descr, ?sprite, ?tags, $link |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
remove?
📑 Summary
Updates the C4 diagram to use the new way of rendering as well as other missing features.
Added Features:
Everything is documented in the updated documentation.
📏 Design Decisions
Since the diagram is originally based off of PlantUML's implementation I based the new features off that as well. While diagram feature specific, below are some design decisions that were made.
In this first version there are only two supported sprites: "person" and "database" but more can easily be added in the future.
The legend is placed at the bottom right of the diagram if shown and will show all tags and any elements that have an associated legend text.
Clickable links work for nodes but also relationships. A thicker invisible path is drawn on top that is clickable.
Added an octagon shape since one of the new macros is EightSidedShape() for the ?shape argument. This shape is C4 diagram specific as of now but is essentially the same as the hexagon shape and maybe should be registered as a flowchart shape as well.
Since there are multiple ways to style elements in the diagram there is a styling priority. The priority goes tags -> UpdateElementStyle() / UpdateRelStyle() -> Style and Class statements. Style and class statements are shared from the other updated diagrams and should be the highest priority since they are the recommended way to style elements.
Some examples showcasing the new rendering and some new features:
data:image/s3,"s3://crabby-images/2e72f/2e72f14012817b59141c08a2474f697258d388dd" alt="image"
data:image/s3,"s3://crabby-images/10e23/10e23fea29eebdf6e3c3d42fe48a08d63acfc08f" alt="image"
data:image/s3,"s3://crabby-images/72187/72187380f1f4c969c46276cf2651e70047a248cb" alt="image"
📋 Tasks
Make sure you
MERMAID_RELEASE_VERSION
is used for all new features.pnpm changeset
and following the prompts. Changesets that add features should beminor
and those that fix bugs should bepatch
. Please prefix changeset messages withfeat:
,fix:
, orchore:
.