diff --git a/blog/powerpoint.md b/blog/powerpoint.md
index 36eeeaaf..272890cd 100644
--- a/blog/powerpoint.md
+++ b/blog/powerpoint.md
@@ -6,6 +6,8 @@ tags: [powerpoint, show-and-tell]
image: https://raw.githubusercontent.com/terrastruct/d2-docs/master/static/img/screenshots/wcc_pptx.png
hide_table_of_contents: false
---
+import CodeBlock from '@theme/CodeBlock';
+import Cult from '@site/static/bespoke-d2/cult.d2';
D2 is a diagramming language, and it's versatile unlike any other. For example, you can
create full PowerPoint presentations with just text.
@@ -31,71 +33,9 @@ To produce this:
- copy the below
- run `d2 input.d2 cult.pptx`.
-```d2
-text: |md
- # Introduction
-
- ## How to start a cult
-
- This presentation educates the public on starting a cult
-
- This is an abridged presentation
-|
-
-layers: {
- 1: {
- text: |md
- # What is a cult?
- - *Definition*: A group or movement with a shared devotion to a charismatic leader, an ideology, or a set of rituals and beliefs
- - *Characteristics*: Totalitarian control, manipulative practices, and exploitation of members
- |
- }
- 2: {
- text: |md
- # Charismatic Leader
-
- ## Role
-
- Cult leaders have a strong, magnetic personality, and are typically seen as an authority figure
-
- ## Tips:
-
- - Cultivate a unique and compelling persona
- - Be convincing and persuasive
- - Establish yourself as an authority figure with exclusive knowledge or abilities
- |
- }
- 3: {
- text: |md
- # Recruitment
- - *Importance*: New members are vital for the growth and sustainability of a cult
- - *Methods*: Targeting vulnerable individuals, offering solutions to personal problems, and using social pressure
- |
- }
- 4: {
- text: |md
- # Control and manipulation
-
- ## Purpose
- To maintain power over members and ensure loyalty
-
- ## Techniques
- Information control, emotional manipulation, and behavior control
-
- ## Tips:
-
- - Limit members' access to outside information and discourage critical thinking
- - Use guilt, shame, and fear to manipulate members' emotions
- - Create strict rules and rituals to control behavior
- |
- }
- 5: {
- text: |md
- # Enjoy your cult
- |
- }
-}
-```
+
+ {Cult}
+
## Complex example
diff --git a/blog/sketch.md b/blog/sketch.md
index a73223d5..b696ee59 100644
--- a/blog/sketch.md
+++ b/blog/sketch.md
@@ -6,6 +6,8 @@ tags: [hand-drawn, show-and-tell]
image: https://raw.githubusercontent.com/terrastruct/d2-docs/master/static/img/blog/sketch.png
hide_table_of_contents: false
---
+import CodeBlock from '@theme/CodeBlock';
+import Animated from '@site/static/blog/sketch/animated.d2';
Sketch mode started out as a "wouldn't it be cool" weekend feature, and has since turned
into one of the things people love most about D2.
@@ -58,8 +60,8 @@ brightness of fills.
It even works with animated connections!
-```d2
-winter.snow -> summer.sun -> trees -> winter.snow: { style.animated: true }
-```
+
+ {Animated}
+
diff --git a/docs/tour/api.md b/docs/tour/api.md
index 5a599aa5..42db9c68 100644
--- a/docs/tour/api.md
+++ b/docs/tour/api.md
@@ -1,3 +1,7 @@
+---
+pagination_next: tour/studio
+---
+
# D2 Oracle
D2 has an API built on top of its AST for **programmatically creating diagrams in Go**.
@@ -63,7 +67,7 @@ _, newKey, _ = d2oracle.Create(g, nil, "a -> b")
If you have a multi-board diagram like so:
-```d2
+```d2-incomplete
x
layers: {
diff --git a/docs/tour/classes.md b/docs/tour/classes.md
index 49446d05..e0aaf7dc 100644
--- a/docs/tour/classes.md
+++ b/docs/tour/classes.md
@@ -1,43 +1,16 @@
+import CodeBlock from '@theme/CodeBlock';
+import StyleClasses1 from '@site/static/d2/style-classes-1.d2';
+import StyleClasses2 from '@site/static/d2/style-classes-2.d2';
+import MultipleClasses from '@site/static/d2/multiple-classes.d2';
+import OrderedClasses from '@site/static/d2/ordered-classes.d2';
+
# Classes
Classes let you aggregate attributes and reuse them.
-```d2
-direction: right
-classes: {
- load balancer: {
- label: load\nbalancer
- width: 100
- height: 200
- style: {
- stroke-width: 0
- fill: "#44C7B1"
- shadow: true
- border-radius: 5
- }
- }
- unhealthy: {
- style: {
- fill: "#FE7070"
- stroke: "#F69E03"
- }
- }
-}
-
-web traffic -> web lb
-web lb.class: load balancer
-
-web lb -> api1
-web lb -> api2
-web lb -> api3
-
-api2.class: unhealthy
-
-api1 -> cache lb
-api3 -> cache lb
-
-cache lb.class: load balancer
-```
+
+ {StyleClasses1}
+
@@ -65,15 +38,9 @@ a -> b
If your object defines an attribute that the class also has defined, the object's
attribute overrides the class attribute.
-```d2
-classes: {
- unhealthy: {
- style.fill: red
- }
-}
-x.class: unhealthy
-x.style.fill: orange
-```
+
+ {StyleClasses2}
+
@@ -81,20 +48,9 @@ x.style.fill: orange
You may use arrays for the value as well to apply multiple classes.
-```d2
-classes: {
- d2: {
- label: ""
- icon: https://play.d2lang.com/assets/icons/d2-logo.svg
- }
- sphere: {
- shape: circle
- style.stroke-width: 0
- }
-}
-
-logo.class: [d2; sphere]
-```
+
+ {MultipleClasses}
+
@@ -102,19 +58,9 @@ logo.class: [d2; sphere]
When multiple classes are given, they are applied left-to-right.
-```d2
-classes: {
- uno: {
- label: 1
- }
- dos: {
- label: 2
- }
-}
-
-x.class: [uno; dos]
-y.class: [dos; uno]
-```
+
+ {OrderedClasses}
+
diff --git a/docs/tour/composition.md b/docs/tour/composition.md
index 591850ec..c0e7778e 100644
--- a/docs/tour/composition.md
+++ b/docs/tour/composition.md
@@ -28,14 +28,14 @@ Each one serves different use cases. The example above is achieved by defining a
Thus far, all D2 diagrams we've encountered are single-board diagrams, the root board.
-```d2
+```d2-incomplete
# Root board
x -> y
```
Composition in D2 is when you use one of those keywords to declare another board.
-```d2
+```d2-incomplete
# Root board
x -> y
layers: {
diff --git a/docs/tour/connections.md b/docs/tour/connections.md
index 1d8e4fa9..e8cebc65 100644
--- a/docs/tour/connections.md
+++ b/docs/tour/connections.md
@@ -1,3 +1,11 @@
+import CodeBlock from '@theme/CodeBlock';
+import Connections1 from '@site/static/d2/connections-1.d2';
+import Connections2 from '@site/static/d2/connections-2.d2';
+import Connections3 from '@site/static/d2/connections-3.d2';
+import Connections4 from '@site/static/d2/connections-4.d2';
+import Connections5 from '@site/static/d2/connections-5.d2';
+import ConnectionsReference from '@site/static/d2/connections-reference.d2';
+
# Connections
Connections define relationships between shapes.
@@ -49,16 +57,9 @@ be -> fe
## Example
-```d2
-Write Replica Canada <-> Write Replica Australia
-
-Read Replica <- Master
-
-x -- y
-
-super long shape id here --\
- -> super long shape id even longer here
-```
+
+ {Connections1}
+
@@ -66,11 +67,9 @@ super long shape id here --\
Repeated connections do not override existing connections. They declare new ones.
-```d2
-Database -> S3: backup
-Database -> S3
-Database -> S3: backup
-```
+
+ {Connections2}
+
@@ -78,19 +77,17 @@ Database -> S3: backup
For readability, it may look more natural to define multiple connection in a single line.
-```d2
-# The label applies to each connection in the chain.
-High Mem Instance -> EC2 <- High CPU Instance: Hosted By
-```
+
+ {Connections3}
+
## Cycles are okay
-```d2
-Stage One -> Stage Two -> Stage Three -> Stage Four
-Stage Four -> Stage One: repeat
-```
+
+ {Connections4}
+
@@ -98,30 +95,9 @@ Stage Four -> Stage One: repeat
To override the default arrowhead shape or give a label next to arrowheads, define a special shape on connections named `source-arrowhead` and/or `target-arrowhead`.
-```d2
-a: The best way to avoid responsibility is to say, "I've got responsibilities"
-b: Whether weary or unweary, O man, do not rest
-c: I still maintain the point that designing a monolithic kernel in 1991 is a
-
-a -> b: To err is human, to moo bovine {
- source-arrowhead: 1
- target-arrowhead: * {
- shape: diamond
- }
-}
-
-b <-> c: "Reality is just a crutch for people who can't handle science fiction" {
- source-arrowhead.label: 1
- target-arrowhead: * {
- shape: diamond
- style.filled: true
- }
-}
-
-d: A black cat crossing your path signifies that the animal is going somewhere
-
-d -> a -> c
-```
+
+ {Connections5}
+
@@ -159,12 +135,8 @@ x -> y: {
You can reference a connection by specifying the original ID followed by its index.
-```d2
-x -> y: hi
-x -> y: hello
-
-(x -> y)[0].style.stroke: red
-(x -> y)[1].style.stroke: blue
-```
+
+ {ConnectionsReference}
+
diff --git a/docs/tour/containers.md b/docs/tour/containers.md
index c646be5a..2c8e89bd 100644
--- a/docs/tour/containers.md
+++ b/docs/tour/containers.md
@@ -1,16 +1,14 @@
-# Containers
-
-```d2
-server
-# Declares a shape inside of another shape
-server.process
+import CodeBlock from '@theme/CodeBlock';
+import Containers1 from '@site/static/d2/containers-1.d2';
+import Containers2 from '@site/static/d2/containers-2.d2';
+import Containers3 from '@site/static/d2/containers-3.d2';
+import ContainersUnderscore from '@site/static/d2/containers-underscore.d2';
-# Can declare the container and child in same line
-im a parent.im a child
+# Containers
-# Since connections can also declare keys, this works too
-apartment.Bedroom.Bathroom -> office.Spare Room.Bathroom: Portal
-```
+
+ {Containers1}
+
@@ -18,19 +16,9 @@ apartment.Bedroom.Bathroom -> office.Spare Room.Bathroom: Portal
You can avoid repeating containers by creating nested maps.
-```d2
-clouds: {
- aws: {
- load_balancer -> api
- api -> db
- }
- gcloud: {
- auth -> db
- }
-
- gcloud -> aws
-}
-```
+
+ {Containers2}
+
@@ -40,7 +28,7 @@ There are two ways define container labels.
### 1. Shorthand container labels
-```d2
+```d2-incomplete
gcloud: Google Cloud {
...
}
@@ -48,7 +36,7 @@ gcloud: Google Cloud {
### 2. Reserved keyword `label`
-```d2
+```d2-incomplete
gcloud: {
label: Google Cloud
...
@@ -57,24 +45,9 @@ gcloud: {
## Example
-```d2
-clouds: {
- aws: AWS {
- load_balancer -> api
- api -> db
- }
- gcloud: Google Cloud {
- auth -> db
- }
-
- gcloud -> aws
-}
-
-users -> clouds.aws.load_balancer
-users -> clouds.gcloud.auth
-
-ci.deploys -> clouds
-```
+
+ {Containers3}
+
@@ -83,15 +56,8 @@ ci.deploys -> clouds
Sometimes you want to reference something outside of the container from within. The
underscore (`_`) refers to parent.
-```d2
-christmas: {
- presents
-}
-birthdays: {
- presents
- _.christmas.presents -> presents: regift
- _.christmas.style.fill: "#ACE1AF"
-}
-```
+
+ {ContainersUnderscore}
+
diff --git a/docs/tour/dimensions.md b/docs/tour/dimensions.md
index a1b71dcf..cac3ee36 100644
--- a/docs/tour/dimensions.md
+++ b/docs/tour/dimensions.md
@@ -1,3 +1,6 @@
+import CodeBlock from '@theme/CodeBlock';
+import Dimensions from '@site/static/d2/dimensions.d2';
+
# Dimensions
You can specify the `width` and `height` of most shapes.
@@ -6,31 +9,8 @@ You can specify the `width` and `height` of most shapes.
These keywords cannot be set on containers, since containers resize to fit their children.
:::
-```d2
-direction: right
-
-small jerry: "" {
- shape: image
- icon: https://static.wikia.nocookie.net/tomandjerry/images/4/46/JerryJumbo3-1-.jpg
- width: 200
- height: 200
-}
-
-med jerry: "" {
- shape: image
- icon: https://static.wikia.nocookie.net/tomandjerry/images/4/46/JerryJumbo3-1-.jpg
- width: 300
- height: 300
-}
-
-big jerry: "" {
- shape: image
- icon: https://static.wikia.nocookie.net/tomandjerry/images/4/46/JerryJumbo3-1-.jpg
- width: 500
- height: 400
-}
-
-big jerry -> med jerry -> small jerry
-```
+
+ {Dimensions}
+
diff --git a/docs/tour/globs.md b/docs/tour/globs.md
index 3f29fa74..7e98b68a 100644
--- a/docs/tour/globs.md
+++ b/docs/tour/globs.md
@@ -1,3 +1,17 @@
+import CodeBlock from '@theme/CodeBlock';
+import GlobsIntro from '@site/static/d2/globs-intro.d2';
+import GlobsLazy from '@site/static/d2/globs-lazy.d2';
+import GlobsCasing from '@site/static/d2/globs-casing.d2';
+import GlobsMultiple from '@site/static/d2/globs-multiple.d2';
+import GlobsConnections from '@site/static/d2/globs-connections.d2';
+import GlobsIndexedConnections from '@site/static/d2/globs-indexed-connections.d2';
+import GlobsScope from '@site/static/d2/globs-scope.d2';
+import GlobsRecursive from '@site/static/d2/globs-recursive.d2';
+import GlobsRecursive2 from '@site/static/d2/globs-recursive-2.d2';
+import GlobsFilter from '@site/static/d2/globs-filter.d2';
+import GlobsFilter2 from '@site/static/d2/globs-filter-2.d2';
+import GlobsNested from '@site/static/d2/globs-nested.d2';
+
# Globs
:::note Etymology
@@ -8,17 +22,9 @@
Globs are a powerful language feature to make global changes in one line.
-```d2
-iphone 10
-iphone 11 mini
-iphone 11 pro
-iphone 12 mini
-
-*.height: 300
-*.width: 140
-*mini.height: 200
-*pro.height: 400
-```
+
+ {GlobsIntro}
+
@@ -31,37 +37,25 @@ In the following example, the instructions are as follows:
criteria. This does, so it applies to `b`.
4. Same with `c`.
-```d2
-a
-
-* -> y
-
-b
-c
-```
+
+ {GlobsLazy}
+
## Globs are case insensitive
-```d2
-diddy kong
-Donkey Kong
-
-*kong.style.fill: brown
-```
+
+ {GlobsCasing}
+
## Globs can appear multiple times
-```d2
-teacher
-thriller
-thrifter
-
-t*h*r.shape: person
-```
+
+ {GlobsMultiple}
+
@@ -69,19 +63,9 @@ t*h*r.shape: person
You can use globs to create connections.
-```d2
-vars: {
- d2-config: {
- layout-engine: elk
- }
-}
-
-Spiderman 1
-Spiderman 2
-Spiderman 3
-
-* -> *: 👉
-```
+
+ {GlobsConnections}
+
@@ -92,17 +76,9 @@ expect from globs, we feel it is more pragmatic for this to be the behavior.
You can also use globs to target modifying existing connections.
-```d2
-lady 1
-lady 2
-
-barbie
-
-lady 1 -> barbie: hi barbie
-lady 2 -> barbie: hi barbie
-
-(lady* -> barbie)[*].style.stroke: pink
-```
+
+ {GlobsIndexedConnections}
+
@@ -110,22 +86,9 @@ lady 2 -> barbie: hi barbie
Notice that in the below example, globs only apply to the scope they are specified in.
-```d2
-foods: {
- pizzas: {
- cheese
- sausage
- pineapple
- *.shape: circle
- }
- humans: {
- john
- james
- *.shape: person
- }
- humans.* -> pizzas.pineapple: eats
-}
-```
+
+ {GlobsScope}
+
@@ -133,29 +96,15 @@ foods: {
`**` means target recursively.
-```d2
-a: {
- b: {
- c
- }
-}
-
-**.style.border-radius: 7
-```
+
+ {GlobsRecursive}
+
-```d2
-zone-A: {
- machine A
- machine B: {
- submachine A
- submachine B
- }
-}
-
-zone-A.** -> load balancer
-```
+
+ {GlobsRecursive2}
+
@@ -170,39 +119,18 @@ diagramming: it only applies to non-container (AKA leaf) shapes.
Use `&` to filter what globs target.
-```d2
-bravo team.shape: person
-charlie team.shape: person
-command center.shape: cloud
-hq.shape: rectangle
-
-*: {
- &shape: person
- style.multiple: true
-}
-```
+
+ {GlobsFilter}
+
If the filtered attribute has an array value, the filter will match if it matches any
element of the array.
-```d2
-the-little-cannon: {
- class: [server; deployed]
-}
-dino: {
- class: [internal; deployed]
-}
-catapult: {
- class: [server]
-}
-
-*: {
- &class: server
- style.multiple: true
-}
-```
+
+ {GlobsFilter2}
+
@@ -214,28 +142,9 @@ We are working on adding more filters, as well as the "not-filter", `!&`.
You can nest globs, combining the features above.
-```d2
-conversation 1: {
- shape: sequence_diagram
- alice -> bob: hi
- bob -> alice: hi
-}
-
-conversation 2: {
- shape: sequence_diagram
- alice -> bob: hello again
- alice -> bob: hello?
- bob -> alice: hello
-}
-
-# Recursively target all shapes...
-**: {
- # ... that are sequence diagrams
- &shape: sequence_diagram
- # Then recursively set all shapes in them to person
- **: {shape: person}
-}
-```
+
+ {GlobsNested}
+
diff --git a/docs/tour/grid-diagrams.md b/docs/tour/grid-diagrams.md
index fce6b1d9..d46a2921 100644
--- a/docs/tour/grid-diagrams.md
+++ b/docs/tour/grid-diagrams.md
@@ -1,3 +1,13 @@
+import CodeBlock from '@theme/CodeBlock';
+import Grid from '@site/static/d2/grid.d2';
+import Grid2 from '@site/static/d2/grid-2.d2';
+import Grid3 from '@site/static/d2/grid-3.d2';
+import Grid4 from '@site/static/d2/grid-4.d2';
+import GridDimensions from '@site/static/d2/grid-dimensions.d2';
+import GridFill from '@site/static/d2/grid-fill.d2';
+import GridNestedGrid from '@site/static/d2/grid-nested-grid.d2';
+import Table from '@site/static/d2/table.d2';
+
# Grid Diagrams
Grid diagrams let you display objects in a structured grid.
@@ -15,35 +25,25 @@ Two keywords do all the magic:
Setting just `grid-rows`:
-```d2
-grid-rows: 3
-Executive
-Legislative
-Judicial
-```
+
+ {Grid2}
+
Setting just `grid-columns`:
-```d2
-grid-columns: 3
-Executive
-Legislative
-Judicial
-```
+
+ {Grid3}
+
Setting both `grid-rows` and `grid-columns`:
-```d2
-grid-rows: 2
-grid-columns: 2
-Executive
-Legislative
-Judicial
-```
+
+ {Grid4}
+
@@ -51,13 +51,9 @@ Judicial
To create specific constructions, use `width` and/or `height`.
-```d2
-grid-rows: 2
-Executive
-Legislative
-Judicial
-The American Government.width: 400
-```
+
+ {GridDimensions}
+
@@ -67,15 +63,9 @@ Notice how objects are evenly distributed within each row.
When you define only one of row or column, objects will expand.
-```d2
-grid-rows: 3
-Executive
-Legislative
-Judicial
-The American Government.width: 400
-Voters
-Non-voters
-```
+
+ {GridFill}
+
Notice how `Voters` and `Non-voters` fill the space.
@@ -88,7 +78,7 @@ dominant direction is the order in which cells are filled.
For example:
-```d2
+```d2-incomplete
grid-rows: 4
grid-columns: 2
# bunch of shapes
@@ -100,7 +90,7 @@ Since `grid-rows` is defined first, objects will fill rows before moving onto co
But if it were reversed:
-```d2
+```d2-incomplete
grid-columns: 2
grid-rows: 4
# bunch of shapes
@@ -140,38 +130,9 @@ Setting `grid-gap` is equivalent to setting both `vertical-gap` and `horizontal-
-```d2
-# Specified so that objects are written in row-dominant order
-grid-rows: 2
-grid-columns: 4
-grid-gap: 0
-
-classes: {
- header: {
- style.underline: true
- }
-}
-
-Element.class: header
-Atomic Number.class: header
-Atomic Mass.class: header
-Melting Point.class: header
-
-Hydrogen
-1
-"1.008"
-"-259.16"
-
-Carbon
-6
-"12.011"
-3500
-
-Oxygen
-8
-"15.999"
-"-218.79"
-```
+
+ {Table}
+
## Connections
@@ -201,95 +162,16 @@ i.e., no path-finding.
Currently you can nest grid diagrams within grid diagrams. Nesting other types is coming
soon.
-```d2
-grid-gap: 0
-grid-columns: 1
-header
-body: "" {
- grid-gap: 0
- grid-columns: 2
- content
- sidebar
-}
-footer
-```
+
+ {GridNestedGrid}
+
-
-
## Source code
-This is the text for the image at the top of this page.
-
-```d2
-grid-rows: 5
-style.fill: black
-
-classes: {
- white square: {
- label: ""
- width: 120
- style: {
- fill: white
- stroke: cornflowerblue
- stroke-width: 10
- }
- }
- block: {
- style: {
- text-transform: uppercase
- font-color: white
- fill: darkcyan
- stroke: black
- }
- }
-}
-
-flow1.class: white square
-flow2.class: white square
-flow3.class: white square
-flow4.class: white square
-flow5.class: white square
-flow6.class: white square
-flow7.class: white square
-flow8.class: white square
-flow9.class: white square
-
-dagger engine: {
- width: 800
- class: block
- style: {
- fill: beige
- stroke: darkcyan
- font-color: blue
- stroke-width: 8
- }
-}
-
-any docker compatible runtime: {
- width: 800
- class: block
- style: {
- fill: lightcyan
- stroke: darkcyan
- font-color: black
- stroke-width: 8
- }
- icon: https://icons.terrastruct.com/dev%2Fdocker.svg
-}
-
-any ci: {
- class: block
- style: {
- fill: gold
- stroke: maroon
- font-color: maroon
- stroke-width: 8
- }
-}
-windows.class: block
-linux.class: block
-macos.class: block
-kubernetes.class: block
-```
+This is the script for the image at the top of this page.
+
+
+ {Grid}
+
diff --git a/docs/tour/hello-world.md b/docs/tour/hello-world.md
index f24f99cb..c7c71ce3 100644
--- a/docs/tour/hello-world.md
+++ b/docs/tour/hello-world.md
@@ -1,11 +1,14 @@
---
pagination_next: tour/shapes
---
+import CodeBlock from '@theme/CodeBlock';
+import HelloWorld from '@site/static/d2/hello-world.d2';
+
# Hello World
-```d2
-x -> y: hello world
-```
+
+ {HelloWorld}
+
diff --git a/docs/tour/icons.md b/docs/tour/icons.md
index 5e06831e..3325c3b6 100644
--- a/docs/tour/icons.md
+++ b/docs/tour/icons.md
@@ -1,6 +1,10 @@
---
sidebar_label: Icons & Images
---
+import CodeBlock from '@theme/CodeBlock';
+import Icons1 from '@site/static/d2/icons-1.d2';
+import IconPlacement from '@site/static/d2/icon-placement.d2';
+import IconsImage from '@site/static/d2/icons-image.d2';
# Icons
@@ -13,11 +17,9 @@ Icons and images are an essential part of production-ready diagrams.
You can use any URL as value.
-```d2
-my network: {
- icon: https://icons.terrastruct.com/infra/019-network.svg
-}
-```
+
+ {Icons1}
+
@@ -34,35 +36,9 @@ like coexistence with a label and whether it's a container generally affect wher
is placed to not obstruct. Notice how the following diagram has container icons in the
top-left and non-container icons in the center.
-```d2
-vpc: VPC 1 10.1.0.0./16 {
- icon: https://icons.terrastruct.com/aws%2F_Group%20Icons%2FVirtual-private-cloud-VPC_light-bg.svg
- style: {
- stroke: green
- font-color: green
- fill: white
- }
- az: Availability Zone A {
- style: {
- stroke: blue
- font-color: blue
- stroke-dash: 3
- fill: white
- }
- firewall: Firewall Subnet A {
- icon: https://icons.terrastruct.com/aws%2FNetworking%20&%20Content%20Delivery%2FAmazon-Route-53_Hosted-Zone_light-bg.svg
- style: {
- stroke: purple
- font-color: purple
- fill: "#e1d5e7"
- }
- ec2: EC2 Instance {
- icon: https://icons.terrastruct.com/aws%2FCompute%2F_Instance%2FAmazon-EC2_C4-Instance_light-bg.svg
- }
- }
- }
-}
-```
+
+ {IconPlacement}
+
@@ -72,19 +48,9 @@ Icons can be positioned with the `near` keyword [introduced later](/tour/positio
## Add `shape: image` for standalone icon shapes
-```d2
-server: {
- shape: image
- icon: https://icons.terrastruct.com/tech/022-server.svg
-}
-
-github: {
- shape: image
- icon: https://icons.terrastruct.com/dev/github.svg
-}
-
-server -> github
-```
+
+ {IconsImage}
+
diff --git a/docs/tour/imported-template.md b/docs/tour/imported-template.md
index 1f26b612..f25182c3 100644
--- a/docs/tour/imported-template.md
+++ b/docs/tour/imported-template.md
@@ -1,3 +1,7 @@
+import CodeBlock from '@theme/CodeBlock';
+import ImportsTemplate from '@site/static/d2/imports-template.d2';
+import ImportsWrapperTemplate from '@site/static/d2/imports-wrapper-template.d2';
+
# Template
You make diagrams for external consulting clients. In order to appear professional, all
@@ -5,32 +9,14 @@ diagrams must be contained within a template that your designer has created that
on-brand.
- `diagram.d2`
-```d2
-template: {
- ...@wrapper-template
- synergy: {
- our firm -> yours: value add
- }
- stakeholders: {
- george.shape: person
- tim.shape: person
- tim.tooltip: is this web scale?
- }
-}
-```
+
+ {ImportsTemplate}
+
- `wrapper-template.d2`
-```d2
-style: {
- fill: "#E3EDE6"
- fill-pattern: dots
- stroke: "#820758"
- stroke-width: 3
- border-radius: 2
- shadow: true
-}
-label: ""
-```
+
+ {ImportsWrapperTemplate}
+
:::info
This use case will be made much more powerful when D2 finishes glob (`*`) support.
diff --git a/docs/tour/imports.md b/docs/tour/imports.md
index dfdc684e..0867551d 100644
--- a/docs/tour/imports.md
+++ b/docs/tour/imports.md
@@ -1,6 +1,9 @@
---
pagination_next: tour/imports-use-cases
---
+import CodeBlock from '@theme/CodeBlock';
+import ImportsTargeted from '@site/static/d2/imports-targeted.d2';
+import ImportsTargetedPeople from '@site/static/d2/imports-targeted-people.d2';
# Syntax
@@ -17,13 +20,13 @@ In the next section, we'll see examples of common import use cases.
### 1. Regular import
- `x.d2`
-```d2
+```d2-incomplete
x: {
shape: circle
}
```
- `y.d2`
-```d2
+```d2-incomplete
a: @x.d2
a -> b
```
@@ -34,13 +37,13 @@ value.
### 2. Spread import
- `x.d2`
-```d2
+```d2-incomplete
x: {
shape: circle
}
```
- `y.d2`
-```d2
+```d2-incomplete
a: {
...@x.d2
}
@@ -58,13 +61,13 @@ Spread imports only work within maps. Something like `a: ...@x.d2` is an invalid
Above, we wrote the full file name for clarity, but the correct usage is to just specify
the file name without the suffix. If you run D2's autoformatter, it'll change
-```d2
+```d2-incomplete
x: @x.d2
```
into
-```d2
+```d2-incomplete
x: @x
```
@@ -80,34 +83,16 @@ You don't have to import the full file.
For example, if you have a file that defines all the people in your organization, and you
just want to show some relations between managers, you can import a specific object.
+
`donut-flowchart.d2`
-```d2
-...@people.management
-joe -> donuts: loves
-jan -> donuts: brings
-```
+
+ {ImportsTargeted}
+
`people.d2`
-```d2
-management: {
- joe: {
- shape: person
- label: Joe Donutlover
- }
- jan: {
- shape: person
- label: Jan Donutbaker
- }
-}
-
-# Notice how these do not appear in the rendered diagram
-employees: {
- toby: {
- shape: person
- label: Toby Simonton
- }
-}
-```
+
+ {ImportsTargetedPeople}
+
:::info
Since `.` is used for targeting, if you want to import from a file with `.` in its name,
@@ -127,7 +112,7 @@ Not to the executing path.
Consider that your working directory is `/Users/You/dev`. Your D2 files:
- `/Users/you/dev/d2-stuff/x.d2`
-```d2
+```d2-incomplete
y: @../y.d2
```
diff --git a/docs/tour/interactive.md b/docs/tour/interactive.md
index d30a3387..69819b96 100644
--- a/docs/tour/interactive.md
+++ b/docs/tour/interactive.md
@@ -1,3 +1,7 @@
+import CodeBlock from '@theme/CodeBlock';
+import Tooltip from '@site/static/d2/tooltip.d2';
+import Links from '@site/static/d2/links.d2';
+
# Interactive
## Tooltips
@@ -10,11 +14,9 @@ Tooltips are text that appear on hover. They serve two purposes:
- Your diagram is getting messy. Instead of adding more text, you can tuck some into
tooltips.
-```d2
-x: { tooltip: Total abstinence is easier than perfect moderation }
-y: { tooltip: Gee, I feel kind of LIGHT in the head now,\nknowing I can't make my satellite dish PAYMENTS! }
-x -> y
-```
+
+ {Tooltip}
+
Try it out, hover over `x` and `y`. Notice that they have an icon indicating that they
have a tooltip.
@@ -39,15 +41,9 @@ tooltips.
Links are like tooltips, except you click to go to an external link.
-```d2
-x: I'm a Mac {
- link: https://apple.com
-}
-y: And I'm a PC {
- link: https://microsoft.com
-}
-x -> y: gazoontite
-```
+
+ {Links}
+
Try clicking on each.
diff --git a/docs/tour/intro.md b/docs/tour/intro.md
index 0fde3272..2398ceaa 100644
--- a/docs/tour/intro.md
+++ b/docs/tour/intro.md
@@ -2,6 +2,8 @@
sidebar_label: What is D2
pagination_next: tour/experience
---
+import CodeBlock from '@theme/CodeBlock';
+import Example from '@site/static/bespoke-d2/terminal-theme.d2';
# D2 Tour
@@ -18,51 +20,9 @@ d2 --theme=300 --dark-theme=200 -l elk --pad 0 ./input.d2
-```d2
-network: {
- cell tower: {
- satellites: {
- shape: stored_data
- style.multiple: true
- }
-
- transmitter
-
- satellites -> transmitter: send
- satellites -> transmitter: send
- satellites -> transmitter: send
- }
-
- online portal: {
- ui: {shape: hexagon}
- }
-
- data processor: {
- storage: {
- shape: cylinder
- style.multiple: true
- }
- }
-
- cell tower.transmitter -> data processor.storage: phone logs
-}
-
-user: {
- shape: person
- width: 130
-}
-
-user -> network.cell tower: make call
-user -> network.online portal.ui: access {
- style.stroke-dash: 3
-}
-
-api server -> network.online portal.ui: display
-api server -> logs: persist
-logs: {shape: page; style.multiple: true}
-
-network.data processor -> api server
-```
+
+ {Example}
+
## Using the CLI watch mode
@@ -81,3 +41,9 @@ The source code for D2 is hosted here:
The source code for these docs are here:
[https://github.com/terrastruct/d2-docs](https://github.com/terrastruct/d2-docs).
:::
+
+:::info
+For each D2 snippet, you can hover over it to open directly in the Playground and tinker.
+
+There's some exceptions like snippets that use imports.
+:::
diff --git a/docs/tour/layers.md b/docs/tour/layers.md
index 582c01ed..12a84aed 100644
--- a/docs/tour/layers.md
+++ b/docs/tour/layers.md
@@ -1,6 +1,9 @@
---
pagination_next: tour/scenarios
---
+import CodeBlock from '@theme/CodeBlock';
+import TikTok from '@site/static/bespoke-d2/tiktok.d2';
+
# Layers
A "Layer" represents "a layer of abstraction". Each Layer starts off as a blank
@@ -11,62 +14,6 @@ Try clicking on the objects.
-```d2
-explain: |md
- This is the top layer, highest level of abstraction.
-| {
- near: top-center
-}
-
-Tik Tok's User Data: {
- link: layers.tiktok
-}
-
-layers: {
- tiktok: {
- explain: |md
- One layer deeper:
-
- Tik Tok's CEO explained that user data is stored in two places currently.
- | {
- near: top-center
- }
- Virginia data center <-> Hong Kong data center
- Virginia data center.link: layers.virginia
- Hong Kong data center.link: layers.hongkong
- layers: {
- virginia: {
- direction: right
- explain: |md
- Getting deeper into details:
-
- TikTok's CEO explains that Virginia data center has strict security measures.
- | {
- near: top-center
- }
- Oracle Databases: {
- shape: cylinder
- style.multiple: true
- }
- US residents -> Oracle Databases: access
- US residents: {
- shape: person
- }
- Third party auditors -> Oracle Databases: verify
- }
- hongkong: {
- direction: right
- explain: |md
- TikTok's CEO says data is actively being deleted and should be done by the end of the year.
- | {
- near: top-center
- }
- Legacy Databases: {
- shape: cylinder
- style.multiple: true
- }
- }
- }
- }
-}
-```
+
+ {TikTok}
+
diff --git a/docs/tour/layouts.md b/docs/tour/layouts.md
index 83369783..0eb3acff 100644
--- a/docs/tour/layouts.md
+++ b/docs/tour/layouts.md
@@ -1,6 +1,9 @@
---
pagination_next: tour/dagre
---
+import CodeBlock from '@theme/CodeBlock';
+import DirectionRight from '@site/static/d2/direction-right.d2';
+import DirectionUp from '@site/static/d2/direction-up.d2';
# Overview
@@ -58,18 +61,16 @@ flows towards.
- `left`
:::
-```d2
-direction: right
-x -> y -> z: hello
-```
+
+ {DirectionRight}
+
-```d2
-direction: up
-x -> y -> z: hello
-```
+
+ {DirectionUp}
+
@@ -83,6 +84,11 @@ direction. We are investigating ways to hack it to work.
:::
```d2
+vars: {
+ d2-config: {
+ layout-engine: tala
+ }
+}
direction: down
a -> b -> c
diff --git a/docs/tour/linking.md b/docs/tour/linking.md
index ff6a5ed8..91b91bbe 100644
--- a/docs/tour/linking.md
+++ b/docs/tour/linking.md
@@ -1,3 +1,7 @@
+import CodeBlock from '@theme/CodeBlock';
+import Cat from '@site/static/bespoke-d2/cat.d2';
+import LOTR from '@site/static/bespoke-d2/lotr.d2';
+
# Linking between boards
We've introduced `link` before as a way to jump to external resources. They can also be
@@ -5,17 +9,9 @@ used to create interactivity to jump to other boards. We'll call these "internal
Example of internal link:
-```d2
-how does the cat go?: {
- link: layers.cat
-}
-
-layers: {
- cat: {
- meoowww
- }
-}
-```
+
+ {Cat}
+
@@ -24,7 +20,7 @@ layers: {
If your board name has a `.`, use quotes to target that board.
For example:
-```d2
+```d2-incomplete
a.link: layers."2012.06"
layers: {
@@ -40,33 +36,9 @@ layers: {
The underscore `_` is used to refer to the parent scope, but when used in `link` values,
they refer not to parent containers, but to parent boards.
-```d2
-The shire
-
-journey: {
- link: layers.rivendell
-}
-
-layers: {
- rivendell: {
- elves: {
- elrond -> frodo: gives advice
- }
-
- take me home sam.link: _
- go deeper: {
- link: layers.moria
- }
- layers: {
- moria: {
- dwarves
-
- take me home sam.link: _._
- }
- }
- }
-}
-```
+
+ {LOTR}
+
diff --git a/docs/tour/model-view.md b/docs/tour/model-view.md
index d1eb52b8..e32f0417 100644
--- a/docs/tour/model-view.md
+++ b/docs/tour/model-view.md
@@ -1,6 +1,10 @@
---
pagination_next: tour/modular-classes
---
+import CodeBlock from '@theme/CodeBlock';
+import ImportsMVModels from '@site/static/d2/imports-mv-models.d2';
+import ImportsMVAccessView from '@site/static/d2/imports-mv-access-view.d2';
+import ImportsMVSSHView from '@site/static/d2/imports-mv-ssh-view.d2';
# Model-view
@@ -8,37 +12,20 @@ A popular pattern defines your models once, and then reuses it across a number o
different views.
## `models.d2`
-```d2
-postgres: {
- shape: cylinder
- icon: https://icons.terrastruct.com/dev%2Fpostgresql.svg
-}
-it: IT Guy {
- shape: person
- style: {
- fill: maroon
- }
-}
-vpn: {
- style: {
- shadow: true
- }
- tooltip: IP is 192.2.2.1
-}
-```
+
+ {ImportsMVModels}
+
## `access-view.d2`
-```d2
-...@models.d2
-it -> vpn -> postgres
-```
+
+ {ImportsMVAccessView}
+
## `ssh-view.d2`
-```d2
-...@models.d2
-it -> postgres: ssh, bypassing VPN
-```
+
+ {ImportsMVSSHView}
+
diff --git a/docs/tour/modular-classes.md b/docs/tour/modular-classes.md
index 15cfa072..7b153e32 100644
--- a/docs/tour/modular-classes.md
+++ b/docs/tour/modular-classes.md
@@ -1,52 +1,19 @@
+import CodeBlock from '@theme/CodeBlock';
+import ImportsClasses from '@site/static/d2/imports-classes.d2';
+import ImportsClassesMain from '@site/static/d2/imports-classes-main.d2';
+
# Modular classes
This pattern mirrors web development, separating HTML and CSS.
## `classes.d2`
-```d2
-classes: {
- base: {
- style: {
- border-radius: 4
- shadow: true
- }
- }
- error: {
- style.fill: red
- style.stroke: red
- }
- med: {
- width: 200
- height: 200
- style.font-size: 24
- }
- large: {
- width: 300
- height: 300
- style.font-size: 28
- }
- xlarge: {
- width: 400
- height: 400
- style.font-size: 32
- }
- person: {
- shape: person
- style.stroke-dash: 3
- }
-}
-```
+
+ {ImportsClasses}
+
## `main.d2`
-```d2
-...@classes.d2
-user.class: person
-error.class: [base; error]
-modal.class: [base; med]
-
-user -> app.signup: click
-app.signup -> error: invalid fields
-app.signup -> modal: continue registration
-```
+
+ {ImportsClassesMain}
+
diff --git a/docs/tour/nested-composition.md b/docs/tour/nested-composition.md
index ddaa3df5..a38ebb90 100644
--- a/docs/tour/nested-composition.md
+++ b/docs/tour/nested-composition.md
@@ -1,3 +1,8 @@
+import CodeBlock from '@theme/CodeBlock';
+import ImportsNested from '@site/static/bespoke-d2/imports-nested.d2';
+import ImportsNestedServiceB from '@site/static/d2/imports-nested-serviceB.d2';
+import ImportsNestedData from '@site/static/d2/imports-nested-data.d2';
+
# Nested composition
Imports make large compositions much more manageable.
@@ -9,46 +14,19 @@ Rendering `overview.d2` gives us a nested diagram while each file is kept flat a
readable.
### `overview.d2`
-```d2
-serviceA -> serviceB
-serviceB.link: layers.serviceB
-layers: {
- serviceB: @serviceB.d2
-}
-```
+
+ {ImportsNested}
+
### `serviceB.d2`
-```d2
-aws vault: {
- key
- token
-}
-stripe: {
- customer id
-}
-aws vault.key -> data
-aws vault.token -> data
-stripe.customer id -> data
-data.link: layers.data
-layers: {
- data: @data.d2
-}
-```
+
+ {ImportsNestedServiceB}
+
### `data.d2`
-```d2
-users: {
- shape: sql_table
- id: int
- token: string
- customer_id: string
-}
-
-# Continue nesting as needed!
-# layers: {
-# ...
-# }
-```
+
+ {ImportsNestedData}
+
## Render of `overview.d2`
diff --git a/docs/tour/overrides.md b/docs/tour/overrides.md
index 2ec39c4b..e4bdc58a 100644
--- a/docs/tour/overrides.md
+++ b/docs/tour/overrides.md
@@ -1,15 +1,19 @@
+import CodeBlock from '@theme/CodeBlock';
+import Overrides1 from '@site/static/d2/overrides-1.d2';
+import Overrides2 from '@site/static/d2/overrides-2.d2';
+import NullBasic from '@site/static/d2/null-basic.d2';
+import NullConnection from '@site/static/d2/null-connection.d2';
+import NullAttribute from '@site/static/d2/null-attribute.d2';
+import NullImplicitConnection from '@site/static/d2/null-implicit-connection.d2';
+import NullImplicitDescendant from '@site/static/d2/null-implicit-descendant.d2';
+
# Overrides
If you redeclare a shape, the new declaration is merged with the previous declaration.
-```d2
-visual studio code text editor
-visual studio code text editor: visual_studio_code_text_editor
-# Remember that shape keys are case insensitive
-visual studio CODE text editor: VisualStudioCodeTextEditor
-visual studio code TEXT editor: Visual Studio Code Text Editor
-visual STUDIO code text editor
-```
+
+ {Overrides1}
+
@@ -17,20 +21,9 @@ The latest explicit setting of the label takes priority.
Here's a more complex example of overrides involving containers:
-```d2
-aws_s3: AWS S3 California {
- Monitoring -> California
-}
-aws_s3: "AWS S3 San Francisco, California" {
- California.San Francisco
-}
-
-# Equal to:
-# aws_s3: "AWS S3 San Francisco, California" {
-# Monitoring -> California
-# California.San Francisco
-# }
-```
+
+ {Overrides2}
+
@@ -38,12 +31,9 @@ aws_s3: "AWS S3 San Francisco, California" {
You may override with the value `null` to delete the shape/connection/attribute.
-```d2
-one
-two
-
-one: null
-```
+
+ {NullBasic}
+
@@ -56,26 +46,17 @@ When is this useful?
### Nulling a connection
-```d2
-one -> two
-
-(one -> two)[0]: null
-```
+
+ {NullConnection}
+
### Nulling an attribute
-```d2
-one: {
- style: {
- fill: pink
- stroke: green
- }
-}
-
-one.style.stroke: null
-```
+
+ {NullAttribute}
+
@@ -85,24 +66,16 @@ one.style.stroke: null
If you null a shape with connections, its connections are also nulled (since every
connection in D2 needs an endpoint).
-```d2
-one -> two
-
-two: null
-```
+
+ {NullImplicitConnection}
+
If you null a shape with descendents, those descendants are also nulled.
-```d2
-one: {
- two: {
- three
- }
-}
-
-one.two: null
-```
+
+ {NullImplicitDescendant}
+
diff --git a/docs/tour/positions.md b/docs/tour/positions.md
index dde2dcfa..93a42e89 100644
--- a/docs/tour/positions.md
+++ b/docs/tour/positions.md
@@ -1,3 +1,9 @@
+import CodeBlock from '@theme/CodeBlock';
+import NearConstant from '@site/static/d2/near-constant.d2';
+import NearContainer from '@site/static/d2/near-container.d2';
+import NearExplanation from '@site/static/d2/near-explanation.d2';
+import NearLabelIcon from '@site/static/d2/near-label-icon.d2';
+
# Positions
In general, positioning is controlled entirely by the layout engine. It's one of the
@@ -23,76 +29,25 @@ Let's explore some use cases:
### Giving your diagram a title
-```d2
-title: |md
- # A winning strategy
-| { near: top-center }
-
-poll the people -> results
-results -> unfavorable -> poll the people
-results -> favorable -> will of the people
-```
+
+ {NearConstant}
+
### Creating a legend
-```d2
-direction: right
-
-x -> y: {
- style.stroke: green
-}
-
-y -> z: {
- style.stroke: red
-}
-
-legend: {
- near: bottom-center
- color1: foo {
- shape: text
- style.font-color: green
- }
-
- color2: bar {
- shape: text
- style.font-color: red
- }
-}
-```
+
+ {NearContainer}
+
### Longform description or explanation
-```d2
-explanation: |md
- # LLMs
- The Large Language Model (LLM) is a powerful AI\
- system that learns from vast amounts of text data.\
- By analyzing patterns and structures in language,\
- it gains an understanding of grammar, facts,\
- and even some reasoning abilities. As users input text,\
- the LLM predicts the most likely next words or phrases\
- to create coherent responses. The model\
- continuously fine-tunes its output, considering both the\
- user's input and its own vast knowledge base.\
- This cutting-edge technology enables LLM to generate human-like text,\
- making it a valuable tool for various applications.
-| {
- near: center-left
-}
-
-ML Platform -> Pre-trained models
-ML Platform -> Model registry
-ML Platform -> Compiler
-ML Platform -> Validation
-ML Platform -> Auditing
-
-Model registry -> Server.Batch Predictor
-Server.Online Model Server
-```
+
+ {NearExplanation}
+
@@ -100,22 +55,9 @@ Server.Online Model Server
The `near` can be nested to `label` and `icon` to specify their positions.
-```d2
-direction: right
-x -> y
-
-x: worker {
- label.near: top-center
- icon: https://icons.terrastruct.com/essentials%2F005-programmer.svg
- icon.near: outside-top-right
-}
-
-y: profits {
- label.near: bottom-right
- icon: https://icons.terrastruct.com/essentials%2Fprofits.svg
- icon.near: outside-top-left
-}
-```
+
+ {NearLabelIcon}
+
@@ -146,6 +88,11 @@ You can also set `near` to the absolute ID of another shape to hint to the layou
that they should be in the vicinity of one another.
```d2
+vars: {
+ d2-config: {
+ layout-engine: tala
+ }
+}
aws: {
load_balancer -> api
api -> db
@@ -167,7 +114,7 @@ explanation: |md
Notice how the text is positioned near the `aws` node and not the `gcloud` node.
-
+
## Top and left
diff --git a/docs/tour/scenarios.md b/docs/tour/scenarios.md
index 2ed1bea4..77d4c1a5 100644
--- a/docs/tour/scenarios.md
+++ b/docs/tour/scenarios.md
@@ -1,3 +1,6 @@
+import CodeBlock from '@theme/CodeBlock';
+import Animated from '@site/static/bespoke-d2/animated.d2';
+
# Scenarios
A "Scenario" represents a different view of the base Layer.
@@ -10,86 +13,6 @@ new connection to show an alternate view of the deployment diagram.
-```d2
-direction: right
-
-title: {
- label: Normal deployment
- near: bottom-center
- shape: text
- style.font-size: 40
- style.underline: true
-}
-
-local: {
- code: {
- icon: https://icons.terrastruct.com/dev/go.svg
- }
-}
-local.code -> github.dev: commit
-
-github: {
- icon: https://icons.terrastruct.com/dev/github.svg
- dev
- master: {
- workflows
- }
-
- dev -> master.workflows: merge trigger
-}
-
-github.master.workflows -> aws.builders: upload and run
-
-aws: {
- builders -> s3: upload binaries
- ec2 <- s3: pull binaries
-
- builders: {
- icon: https://icons.terrastruct.com/aws/Developer%20Tools/AWS-CodeBuild_light-bg.svg
- }
- s3: {
- icon: https://icons.terrastruct.com/aws/Storage/Amazon-S3-Glacier_light-bg.svg
- }
- ec2: {
- icon: https://icons.terrastruct.com/aws/_Group%20Icons/EC2-instance-container_light-bg.svg
- }
-}
-
-local.code -> aws.ec2: {
- style.opacity: 0.0
-}
-
-scenarios: {
- hotfix: {
- title.label: Hotfix deployment
- (local.code -> github.dev)[0].style: {
- stroke: "#ca052b"
- opacity: 0.1
- }
-
- github: {
- dev: {
- style.opacity: 0.1
- }
- master: {
- workflows: {
- style.opacity: 0.1
- }
- style.opacity: 0.1
- }
-
- (dev -> master.workflows)[0].style.opacity: 0.1
- style.opacity: 0.1
- style.fill: "#ca052b"
- }
-
- (github.master.workflows -> aws.builders)[0].style.opacity: 0.1
-
- local.code -> aws.ec2: {
- style.opacity: 1
- style.stroke-dash: 5
- style.stroke: "#167c3c"
- }
- }
-}
-```
+
+ {Animated}
+
diff --git a/docs/tour/sequence-diagrams.md b/docs/tour/sequence-diagrams.md
index fd35457b..ee6f05fc 100644
--- a/docs/tour/sequence-diagrams.md
+++ b/docs/tour/sequence-diagrams.md
@@ -1,12 +1,21 @@
+import CodeBlock from '@theme/CodeBlock';
+import SequenceDiagrams1 from '@site/static/d2/sequence-diagrams-1.d2';
+import SequenceDiagrams2 from '@site/static/d2/sequence-diagrams-2.d2';
+import SequenceDiagrams3 from '@site/static/d2/sequence-diagrams-3.d2';
+import SequenceDiagrams4 from '@site/static/d2/sequence-diagrams-4.d2';
+import SequenceDiagramsScope from '@site/static/d2/sequence-diagrams-scope.d2';
+import SequenceDiagramsGroup from '@site/static/d2/sequence-diagrams-group.d2';
+import SequenceDiagramsNote from '@site/static/d2/sequence-diagrams-note.d2';
+import SequenceDiagramsSelf from '@site/static/d2/sequence-diagrams-self.d2';
+import SequenceDiagramsLifeline from '@site/static/d2/sequence-diagrams-lifeline.d2';
+
# Sequence Diagrams
Sequence diagrams are created by setting `shape: sequence_diagram` on an object.
-```d2
-shape: sequence_diagram
-alice -> bob: What does it mean\nto be well-adjusted?
-bob -> alice: The ability to play bridge or\ngolf as if they were games.
-```
+
+ {SequenceDiagrams1}
+
@@ -21,23 +30,9 @@ Children of sequence diagrams share the same scope throughout the sequence diagr
For example:
-```d2
-Office chatter: {
- shape: sequence_diagram
- alice: Alice
- bob: Bobby
- awkward small talk: {
- alice -> bob: uhm, hi
- bob -> alice: oh, hello
- icebreaker attempt: {
- alice -> bob: what did you have for lunch?
- }
- unfortunate outcome: {
- bob -> alice: that's personal
- }
- }
-}
-```
+
+ {SequenceDiagramsScope}
+
@@ -76,40 +71,9 @@ An actor in D2 is also known elsewhere as "participant".
Like every other object in D2, they can be contained, connected, relabeled, re-styled, and
treated like any other object.
-```d2
-direction: right
-Before and after becoming friends: {
- 2007: Office chatter in 2007 {
- shape: sequence_diagram
- alice: Alice
- bob: Bobby
- awkward small talk: {
- alice -> bob: uhm, hi
- bob -> alice: oh, hello
- icebreaker attempt: {
- alice -> bob: what did you have for lunch?
- }
- unfortunate outcome: {
- bob -> alice: that's personal
- }
- }
- }
-
- 2012: Office chatter in 2012 {
- shape: sequence_diagram
- alice: Alice
- bob: Bobby
- alice -> bob: Want to play with ChatGPT?
- bob -> alice: Yes!
- bob -> alice.play: Write a play...
- alice.play -> bob.play: about 2 friends...
- bob.play -> alice.play: who find love...
- alice.play -> bob.play: in a sequence diagram
- }
-
- 2007 -> 2012: Five\nyears\nlater
-}
-```
+
+ {SequenceDiagrams2}
+
@@ -123,14 +87,9 @@ A span in D2 is also known elsewhere as a "lifespan", "activation box", and "act
You can specify a span by connecting a nested object on an actor.
-```d2
-shape: sequence_diagram
-alice.t1 -> bob
-alice.t2 -> bob.a
-alice.t2.a -> bob.a
-alice.t2.a <- bob.a
-alice.t2 <- bob.a
-```
+
+ {SequenceDiagrams3}
+
@@ -146,18 +105,9 @@ We saw an example of this in an earlier example when explaining scoping rules. M
formally, a group is a container within a `sequence_diagram` shape which is not connected
to anything but has connections or objects inside.
-```d2
-shape: sequence_diagram
-# Predefine actors
-alice; bob
-shower thoughts: {
- alice -> bob: A physicist is an atom's way of knowing about atoms.
- alice -> bob: Today is the first day of the rest of your life.
-}
-life advice: {
- bob -> alice: If all else fails, lower your standards.
-}
-```
+
+ {SequenceDiagramsGroup}
+
:::caution
Due to the unique scoping rules in sequence diagrams, when you are within a group, the
@@ -172,16 +122,9 @@ example that `alice` and `bob` are explicitly declared before group declarations
Notes are declared by defining a nested object on an actor with no connections going to
it.
-```d2
-shape: sequence_diagram
-alice -> bob
-bob."In the eyes of my dog, I'm a man."
-# Notes can go into groups, too
-important insight: {
- bob."Cold hands, no gloves."
-}
-bob -> alice: Chocolate chip.
-```
+
+ {SequenceDiagramsNote}
+
@@ -189,12 +132,9 @@ bob -> alice: Chocolate chip.
Self-referential messages can be declared from an actor to the themselves.
-```d2
-shape: sequence_diagram
-son -> father: Can I borrow your car?
-friend -> father: Never lend your car to anyone to whom you have given birth.
-father -> father: internal debate ensues
-```
+
+ {SequenceDiagramsSelf}
+
@@ -203,49 +143,18 @@ father -> father: internal debate ensues
You can style shapes and connections like any other. Here we make some messages dashed and
set the shape on an actor.
-```d2
-shape: sequence_diagram
-scorer: { shape: person }
-scorer.t -> itemResponse.t: getItem()
-scorer.t <- itemResponse.t: item {
- style.stroke-dash: 5
-}
-
-scorer.t -> item.t1: getRubric()
-scorer.t <- item.t1: rubric {
- style.stroke-dash: 5
-}
-
-scorer.t -> essayRubric.t: applyTo(essayResp)
-itemResponse -> essayRubric.t.c
-essayRubric.t.c -> concept.t: match(essayResponse)
-scorer <- essayRubric.t: score {
- style.stroke-dash: 5
-}
-
-scorer.t -> itemOutcome.t1: new
-scorer.t -> item.t2: getNormalMinimum()
-scorer.t -> item.t3: getNormalMaximum()
-
-scorer.t -> itemOutcome.t2: setScore(score)
-scorer.t -> itemOutcome.t3: setFeedback(missingConcepts)
+
+ {SequenceDiagrams4}
+
-```
Lifeline edges (those lines going from top-down) inherit the actor's `stroke` and
`stroke-dash` styles.
-```d2
-shape: sequence_diagram
-alice -> bob: What does it mean\nto be well-adjusted?
-bob -> alice: The ability to play bridge or\ngolf as if they were games.
-
-alice.style: {
- stroke: red
- stroke-dash: 0
-}
-```
+
+ {SequenceDiagramsLifeline}
+
diff --git a/docs/tour/shapes.md b/docs/tour/shapes.md
index d59d0145..aa54900b 100644
--- a/docs/tour/shapes.md
+++ b/docs/tour/shapes.md
@@ -1,18 +1,16 @@
+import CodeBlock from '@theme/CodeBlock';
+import Shapes1 from '@site/static/d2/shapes-1.d2';
+import Shapes2 from '@site/static/d2/shapes-2.d2';
+
# Shapes
## Basics
You can declare shapes like so:
-```d2
-imAShape
-im_a_shape
-im a shape
-i'm a shape
-# notice that one-hyphen is not a connection
-# whereas, `a--shape` would be a connection
-a-shape
-```
+
+ {Shapes1}
+
@@ -37,12 +35,9 @@ Cloud.shape: cloud
## Example
-```d2
-pg: PostgreSQL
-Cloud: my cloud
-Cloud.shape: cloud
-SQLite; Cassandra
-```
+
+ {Shapes2}
+
diff --git a/docs/tour/sql-tables.md b/docs/tour/sql-tables.md
index d29a58f2..80db5815 100644
--- a/docs/tour/sql-tables.md
+++ b/docs/tour/sql-tables.md
@@ -1,19 +1,17 @@
+import CodeBlock from '@theme/CodeBlock';
+import Tables1 from '@site/static/d2/tables-1.d2';
+import Tables2 from '@site/static/d2/tables-2.d2';
+import Tables3 from '@site/static/d2/tables-3.d2';
+
# SQL Tables
## Basics
You can easily diagram entity-relationship diagrams (ERDs) in D2 by using the `sql_table` shape. Here's a minimal example:
-```d2
-my_table: {
- shape: sql_table
- # This is defined using the shorthand syntax for labels discussed in the containers section.
- # But here it's for the type of a constraint.
- # The id field becomes a map that looks like {type: int; constraint: primary_key}
- id: int {constraint: primary_key}
- last_updated: timestamp with time zone
-}
-```
+
+ {Tables1}
+
@@ -43,23 +41,9 @@ x: int { constraint: [primary_key; unique] }
Here's an example of how you'd define a foreign key connection between two tables:
-```d2
-objects: {
- shape: sql_table
- id: int {constraint: primary_key}
- disk: int {constraint: foreign_key}
-
- json: jsonb {constraint: unique}
- last_updated: timestamp with time zone
-}
-
-disks: {
- shape: sql_table
- id: int {constraint: primary_key}
-}
-
-objects.disk -> disks.id
-```
+
+ {Tables2}
+
@@ -73,22 +57,8 @@ connections point to the exact row.
Like all other shapes, you can nest `sql_tables` into containers and define edges
to them from other shapes. Here's an example:
-```d2
-cloud: {
- disks: {
- shape: sql_table
- id: int {constraint: primary_key}
- }
- blocks: {
- shape: sql_table
- id: int {constraint: primary_key}
- disk: int {constraint: foreign_key}
- blob: blob
- }
- blocks.disk -> disks.id
-
- AWS S3 Vancouver -> disks
-}
-```
+
+ {Tables3}
+
diff --git a/docs/tour/steps.md b/docs/tour/steps.md
index 9d613246..f07529ce 100644
--- a/docs/tour/steps.md
+++ b/docs/tour/steps.md
@@ -1,3 +1,6 @@
+import CodeBlock from '@theme/CodeBlock';
+import Chicken from '@site/static/bespoke-d2/chicken.d2';
+
# Steps
A "Step" represents a step in a sequence of events.
@@ -10,21 +13,6 @@ defined, because it was inherited from Step 2, which inherited it from Step 1.
-```d2
-Chicken's plan: {
- style.font-size: 35
- near: top-center
- shape: text
-}
-steps: {
- 1: {
- Approach road
- }
- 2: {
- Approach road -> Cross road
- }
- 3: {
- Cross road -> Make you wonder why
- }
-}
-```
+
+ {Chicken}
+
diff --git a/docs/tour/strings.md b/docs/tour/strings.md
index 48e2b1d9..471158d7 100644
--- a/docs/tour/strings.md
+++ b/docs/tour/strings.md
@@ -1,6 +1,9 @@
---
pagination_next: tour/comments
---
+import CodeBlock from '@theme/CodeBlock';
+import Strings2 from '@site/static/d2/strings-2.d2';
+
# Strings
## Unquoted strings
@@ -30,9 +33,9 @@ language. The syntax highlighting will make it clear if you're using a forbidden
If you need to use such symbols, you can use single or double quoted strings:
-```d2
-'$$$' -> "###"
-```
+
+ {Strings2}
+
diff --git a/docs/tour/style.md b/docs/tour/style.md
index 2c53b768..deae3cc1 100644
--- a/docs/tour/style.md
+++ b/docs/tour/style.md
@@ -1,3 +1,26 @@
+import CodeBlock from '@theme/CodeBlock';
+import StylesOpacity from '@site/static/d2/styles-opacity.d2';
+import StylesStroke from '@site/static/d2/styles-stroke.d2';
+import StylesFill from '@site/static/d2/styles-fill.d2';
+import StylesFillTransparent from '@site/static/d2/styles-fill-transparent.d2';
+import StylesFillPattern from '@site/static/d2/styles-fill-pattern.d2';
+import StylesStrokeWidth from '@site/static/d2/styles-stroke-width.d2';
+import StylesStrokeDash from '@site/static/d2/styles-stroke-dash.d2';
+import StylesBorderRadius from '@site/static/d2/styles-border-radius.d2';
+import Pill from '@site/static/d2/pill.d2';
+import StylesShadow from '@site/static/d2/styles-shadow.d2';
+import Styles3d from '@site/static/d2/styles-3d.d2';
+import StylesMultiple from '@site/static/d2/styles-multiple.d2';
+import StylesDoubleBorder from '@site/static/d2/styles-double-border.d2';
+import StylesFont from '@site/static/d2/styles-font.d2';
+import StylesFontSize from '@site/static/d2/styles-font-size.d2';
+import StylesFontColor from '@site/static/d2/styles-font-color.d2';
+import StylesTableColor from '@site/static/d2/styles-table-color.d2';
+import StylesAnimated from '@site/static/d2/styles-animated.d2';
+import StylesTextDecoration from '@site/static/d2/styles-text-decoration.d2';
+import StylesTextTransform from '@site/static/d2/styles-text-transform.d2';
+import StylesRoot from '@site/static/d2/styles-root.d2';
+
# Styles
If you'd like to customize the style of a shape, the following reserved keywords can be
@@ -37,15 +60,9 @@ brevity.
Float between `0` and `1`.
-```d2
-x -> y: hi {
- style: {
- opacity: 0.4
- }
-}
-x.style.opacity: 0
-y.style.opacity: 0.7
-```
+
+ {StylesOpacity}
+
@@ -53,15 +70,9 @@ y.style.opacity: 0.7
CSS color name or hex code.
-```d2
-x -> y: hi {
- style: {
- stroke: deepskyblue
- }
-}
-# We need quotes for hex otherwise it gets interpreted as comment
-x.style.stroke: "#f4a261"
-```
+
+ {StylesStroke}
+
@@ -76,11 +87,9 @@ already used to control header's `fill`).
CSS color name or hex code.
-```d2
-x -> y: hi
-x.style.fill: "#f4a261"
-y.style.fill: honeydew
-```
+
+ {StylesFill}
+
@@ -92,13 +101,9 @@ For `sql_table`s and `class`es, `fill` is applied to the header.
Want transparent?
-```d2
-x: {
- y
- y.style.fill: transparent
-}
-x.style.fill: PapayaWhip
-```
+
+ {StylesFillTransparent}
+
@@ -110,12 +115,9 @@ Available patterns:
- `lines`
- `grain`
-```d2
-style.fill-pattern: dots
-x -> y: hi
-x.style.fill-pattern: lines
-y.style.fill-pattern: grain
-```
+
+ {StylesFillPattern}
+
@@ -123,14 +125,9 @@ y.style.fill-pattern: grain
Integer between `1` and `15`.
-```d2
-x -> y: hi {
- style: {
- stroke-width: 8
- }
-}
-x.style.stroke-width: 1
-```
+
+ {StylesStrokeWidth}
+
@@ -138,14 +135,9 @@ x.style.stroke-width: 1
Integer between `0` and `10`.
-```d2
-x -> y: hi {
- style: {
- stroke-dash: 3
- }
-}
-x.style.stroke-dash: 5
-```
+
+ {StylesStrokeDash}
+
@@ -153,11 +145,9 @@ x.style.stroke-dash: 5
Integer between `0` and `20`.
-```d2
-x -> y: hi
-x.style.border-radius: 3
-y.style.border-radius: 8
-```
+
+ {StylesBorderRadius}
+
@@ -169,9 +159,9 @@ on connections whose routes have corners.
Specifying a very high value creates a "pill" effect.
-```d2
-tylenol.style.border-radius: 999
-```
+
+ {Pill}
+
@@ -179,10 +169,9 @@ tylenol.style.border-radius: 999
`true` or `false`.
-```d2
-x -> y: hi
-x.style.shadow: true
-```
+
+ {StylesShadow}
+
@@ -190,10 +179,9 @@ x.style.shadow: true
`true` or `false`.
-```d2
-x -> y: hi
-x.style.3d: true
-```
+
+ {Styles3d}
+
@@ -201,10 +189,9 @@ x.style.3d: true
`true` or `false`.
-```d2
-x -> y: hi
-x.style.multiple: true
-```
+
+ {StylesMultiple}
+
@@ -212,12 +199,9 @@ x.style.multiple: true
`true` or `false`.
-```d2
-x -> y: hi
-x.style.double-border: true
-y.shape: circle
-y.style.double-border: true
-```
+
+ {StylesDoubleBorder}
+
@@ -225,15 +209,9 @@ y.style.double-border: true
Currently the only option is to specify `mono`. More coming soon.
-```d2
-x -> y: hi {
- style: {
- font: mono
- }
-}
-x.style.font: mono
-y.style.font: mono
-```
+
+ {StylesFont}
+
@@ -241,15 +219,9 @@ y.style.font: mono
Integer between `8` and `100`.
-```d2
-x -> y: hi {
- style: {
- font-size: 28
- }
-}
-x.style.font-size: 8
-y.style.font-size: 55
-```
+
+ {StylesFontSize}
+
@@ -257,14 +229,9 @@ y.style.font-size: 55
CSS color name or hex code.
-```d2
-x -> y: hi {
- style: {
- font-color: red
- }
-}
-x.style.font-color: "#f4a261"
-```
+
+ {StylesFontColor}
+
@@ -279,11 +246,9 @@ controls other colors in the body).
`true` or `false`.
-```d2
-x -> y: hi {
- style.animated: true
-}
-```
+
+ {StylesAnimated}
+
@@ -291,18 +256,9 @@ x -> y: hi {
`true` or `false`.
-```d2
-x -> y: hi {
- style: {
- bold: true
- }
-}
-x.style.underline: true
-y.style.italic: true
-# By default, shape labels are bold. Bold has precedence over italic, so unbold to see
-# italic style
-y.style.bold: false
-```
+
+ {StylesTextDecoration}
+
@@ -315,15 +271,9 @@ y.style.bold: false
- `title`
- `none` (used for negating caps lock that special themes may apply)
-```d2
-x -> y: hi {
- style: {
- text-transform: capitalize
- }
-}
-x.style.text-transform: lowercase
-y.style.text-transform: uppercase
-```
+
+ {StylesTextTransform}
+
@@ -341,14 +291,9 @@ Currently the set of supported keywords are:
- `stroke-dash`
- `double-border`: two frames, which is a popular framing method
-```d2
-x -> y: hi
-style: {
- fill: LightBlue
- stroke: FireBrick
- stroke-width: 2
-}
-```
+
+ {StylesRoot}
+
diff --git a/docs/tour/text.md b/docs/tour/text.md
index dbcb367d..7cdff843 100644
--- a/docs/tour/text.md
+++ b/docs/tour/text.md
@@ -2,19 +2,20 @@
sidebar_label: Text & Code
pagination_next: tour/icons
---
+import CodeBlock from '@theme/CodeBlock';
+import Markdown from '@site/static/d2/markdown.d2';
+import Text2 from '@site/static/d2/text-2.d2';
+import Code2 from '@site/static/d2/code-2.d2';
+import NonMarkdownText from '@site/static/d2/non-markdown-text.d2';
+import Latex from '@site/static/d2/latex.d2';
+
# Text
## Standalone text is Markdown
-```d2
-explanation: |md
- # I can do headers
- - lists
- - lists
-
- And other normal markdown stuff
-|
-```
+
+ {Markdown}
+
@@ -29,14 +30,9 @@ Chinese, Japanese, Korean, even emojis!
You can use `latex` or `tex` to specify a LaTeX language block.
-```d2
-plankton -> formula: will steal
-formula: {
- equation: |latex
- \\lim_{h \\rightarrow 0 } \\frac{f(x+h)-f(x)}{h}
- |
-}
-```
+
+ {Text2}
+
@@ -72,15 +68,9 @@ This is coming soon.
Change `md` to a programming language for code blocks
-```d2
-explanation: |go
- awsSession := From(c.Request.Context())
- client := s3.New(awsSession)
-
- ctx, cancelFn := context.WithTimeout(c.Request.Context(), AWS_TIMEOUT)
- defer cancelFn()
-|
-```
+
+ {Code2}
+
@@ -90,20 +80,9 @@ In some cases, you may want non-Markdown text. Maybe you just don't like Markdow
GitHub-styling of Markdown that D2 uses, or you want to quickly change a shape to text.
Just set `shape: text`.
-```d2
-title: A winning strategy {
- shape: text
- near: top-center
- style: {
- font-size: 55
- italic: true
- }
-}
-
-poll the people -> results
-results -> unfavorable -> poll the people
-results -> favorable -> will of the people
-```
+
+ {NonMarkdownText}
+
@@ -142,68 +121,8 @@ my_code: |`ts
D2 includes the following LaTeX plugins:
-```d2
-grid-columns: 3
-grid-gap: 100
-
-*.style.fill: transparent
-*.style.stroke: black
-
-amscd plugin: {
- ex: |tex
- \\begin{CD} B @>{\\text{very long label}}>> C S^{{\\mathcal{W}}_\\Lambda}\\otimes T @>j>> T\\\\ @VVV V \\end{CD}
- |
-}
-
-braket plugin: {
- ex: |tex
- \\bra{a}\\ket{b}
- |
-}
-
-cancel plugin: {
- ex: |tex
- \\cancel{Culture + 5}
- |
-}
-
-color plugin: {
- ex: |tex
- \\textcolor{red}{y} = \\textcolor{green}{\\sin} x
- |
-}
-
-gensymb plugin: {
- ex: |tex
- \\lambda = 10.6\\,\\micro\\mathrm{m}
- |
-}
-
-mhchem plugin: {
- ex: |tex
- \ce{SO4^2- + Ba^2+ -> BaSO4 v}
- |
-}
-
-physics plugin: {
- ex: |tex
- \\var{F[g(x)]}
- \\dd(\\cos\\theta)
- |
-}
-
-multilines: {
- ex: |tex
- \\displaylines{x = a + b \\\\ y = b + c}
- \\sum_{k=1}^{n} h_{k} \\int_{0}^{1} \\bigl(\\partial_{k} f(x_{k-1}+t h_{k} e_{k}) -\\partial_{k} f(a)\\bigr) \\,dt
- |
-}
-
-asm: {
- ex: |latex
- \\min_{ \\mathclap{\\substack{ x \\in \\mathbb{R}^n \\ x \\geq 0 \\ Ax \\leq b }}} c^T x
- |
-}
-```
+
+ {Latex}
+
diff --git a/docs/tour/themes.md b/docs/tour/themes.md
index ec815377..ae0efe85 100644
--- a/docs/tour/themes.md
+++ b/docs/tour/themes.md
@@ -1,6 +1,9 @@
---
pagination_next: tour/style
---
+import CodeBlock from '@theme/CodeBlock';
+import TerminalTheme from '@site/static/bespoke-d2/terminal-theme.d2';
+
# Themes
D2 comes with many themes that make your diagram look professional and ready to insert
@@ -91,51 +94,9 @@ Source code for the above diagram (rendered with ELK) is as follows. Notice that
the properties apparent in the diagram do not appear in the source, such as the casing of
the labels, because the special theme uses different defaults.
-```d2
-network: {
- cell tower: {
- satellites: {
- shape: stored_data
- style.multiple: true
- }
-
- transmitter
-
- satellites -> transmitter: send
- satellites -> transmitter: send
- satellites -> transmitter: send
- }
-
- online portal: {
- ui: {shape: hexagon}
- }
-
- data processor: {
- storage: {
- shape: cylinder
- style.multiple: true
- }
- }
-
- cell tower.transmitter -> data processor.storage: phone logs
-}
-
-user: {
- shape: person
- width: 130
-}
-
-user -> network.cell tower: make call
-user -> network.online portal.ui: access {
- style.stroke-dash: 3
-}
-
-api server -> network.online portal.ui: display
-api server -> logs: persist
-logs: {shape: page; style.multiple: true}
-
-network.data processor -> api server
-```
+
+ {TerminalTheme}
+
## Customizing themes
@@ -149,7 +110,7 @@ This is controlled by two [configuration variables](/tour/vars#configuration-var
Adding this snippet to the above code results in the following diagram.
-```d2
+```d2-incomplete
vars: {
d2-config: {
theme-overrides: {
diff --git a/docs/tour/uml-classes.md b/docs/tour/uml-classes.md
index bcfbc346..d54e1875 100644
--- a/docs/tour/uml-classes.md
+++ b/docs/tour/uml-classes.md
@@ -1,17 +1,16 @@
+import CodeBlock from '@theme/CodeBlock';
+import Classes1 from '@site/static/d2/classes-1.d2';
+import Classes2 from '@site/static/d2/classes-2.d2';
+
# UML Classes
## Basics
D2 fully supports UML Class diagrams. Here's a minimal example:
-```d2
-MyClass: {
- shape: class
-
- field: "[]string"
- method(a uint64): (x, y int)
-}
-```
+
+ {Classes1}
+
@@ -38,29 +37,8 @@ See https://www.uml-diagrams.org/visibility.html
Here's an example with differing visibilities and more complex types:
-```d2
-D2 Parser: {
- shape: class
-
- # Default visibility is + so no need to specify.
- +reader: io.RuneReader
- readerPos: d2ast.Position
-
- # Private field.
- -lookahead: "[]rune"
-
- # Protected field.
- # We have to escape the # to prevent the line from being parsed as a comment.
- \#lookaheadPos: d2ast.Position
-
- +peek(): (r rune, eof bool)
- rewind()
- commit()
-
- \#peekn(n int): (s string, eof bool)
-}
-
-"github.com/terrastruct/d2parser.git" -> D2 Parser
-```
+
+ {Classes2}
+
diff --git a/docs/tour/vars.md b/docs/tour/vars.md
index 130f0b15..23ac6499 100644
--- a/docs/tour/vars.md
+++ b/docs/tour/vars.md
@@ -1,18 +1,19 @@
+import CodeBlock from '@theme/CodeBlock';
+import VarsIntro from '@site/static/d2/vars-intro.d2';
+import VarsNested from '@site/static/d2/vars-nested.d2';
+import VarsScoped from '@site/static/d2/vars-scoped.d2';
+import VarsEscaped from '@site/static/d2/vars-escaped.d2';
+import VarsSpread from '@site/static/d2/vars-spread.d2';
+import VarsConfig from '@site/static/d2/vars-config.d2';
+
# Variables & Substitutions
`vars` is a special keyword that lets you define variables. These variables can be
referenced with the substitution syntax: `${}`.
-```d2
-vars: {
- server-name: Cat
-}
-
-server1: ${server-name}-1
-server2: ${server-name}-2
-
-server1 <-> server2
-```
+
+ {VarsIntro}
+
@@ -20,26 +21,9 @@ server1 <-> server2
Use `.` to refer to nested variables.
-```d2
-vars: {
- primaryColors: {
- button: {
- active: "#4baae5"
- border: black
- }
- }
-}
-
-button: {
- width: 100
- height: 40
- style: {
- border-radius: 5
- fill: ${primaryColors.button.active}
- stroke: ${primaryColors.button.border}
- }
-}
-```
+
+ {VarsNested}
+
@@ -49,34 +33,17 @@ They work just like variable scopes in programming. Substitutions can refer to v
defined in a more outer scope, but not a more inner scope. If a variable appears in two
scopes, the one closer to the substitution is used.
-```d2
-vars: {
- region: Global
- font: mono
-}
-
-lb: ${region} load balancer
-lb.style.font: ${font}
-
-zone1: {
- vars: {
- region: us-east-1
- }
- server: ${region} API
- server.style.font: ${font}
-}
-```
+
+ {VarsScoped}
+
## Single quotes bypass substitutions
-```d2
-vars: {
- names: John and Joyce
-}
-a -> b: 'Send field ${names}'
-```
+
+ {VarsEscaped}
+
@@ -85,24 +52,9 @@ a -> b: 'Send field ${names}'
If `x` is a map or an array, `...${x}` will spread the contents of `x` into either a map
or an array.
-```d2
-vars: {
- base-constraints: [NOT NULL; UNQ]
- disclaimer: DISCLAIMER {
- I am not a lawyer
- near: top-center
- }
-}
-
-data: {
- shape: sql_table
- a: int {constraint: [PK; ...${base-constraints}]}
-}
-
-custom-disclaimer: DRAFT DISCLAIMER {
- ...${disclaimer}
-}
-```
+
+ {VarsSpread}
+
@@ -111,21 +63,9 @@ custom-disclaimer: DRAFT DISCLAIMER {
Some configurations can be made directly in `vars` instead of using flags or environment
variables.
-```d2
-vars: {
- d2-config: {
- theme-id: 4
- dark-theme-id: 200
- pad: 0
- center: true
- sketch: true
- layout-engine: elk
- }
-}
-
-direction: right
-x -> y
-```
+
+ {VarsConfig}
+
This is equivalent to calling the following with no `vars`:
```shell
diff --git a/docs/tour/version-visualization.md b/docs/tour/version-visualization.md
index 99d97f1b..8d47d7df 100644
--- a/docs/tour/version-visualization.md
+++ b/docs/tour/version-visualization.md
@@ -1,6 +1,10 @@
---
pagination_next: tour/imported-template
---
+import CodeBlock from '@theme/CodeBlock';
+import ImportsVVHistory from '@site/static/d2/imports-vv-history.d2';
+import ImportsVVUsersCurrent from '@site/static/d2/imports-vv-users-current.d2';
+import ImportsVVUsersV01 from '@site/static/d2/imports-vv-users-v0.1.d2';
# Version visualization
@@ -10,38 +14,19 @@ You want to understand how the schema of a system has evolved over time. As long
diagram is modularized with imports, such a visualization is easy to whip up.
- `history.d2`
-```d2
-direction: right
-Users 1: Users Table (v0.1) {
- ...@"users-v0.1"
-}
-
-Users 2: Users Table (current) {
- ...@"users-current"
-}
-
-Users 1 -> Users 2
-```
+
+ {ImportsVVHistory}
+
- `users.d2` (latest version, 0.2)
-```d2
-users: {
- id: int {constraint: primary_key}
- email: int {constraint: foreign_key}
- name: string
- password: text
- created_at: timestamp
- last_updated: timestamp
-}
+
+ {ImportsVVUsersCurrent}
+
-emails: {
- id: int {constraint: [primary_key; unique]}
- local: string
- domain: string
- verified: boolean
-}
-users.email -> emails.id
-```
+- `users.d2` (0.1)
+
+ {ImportsVVUsersV01}
+
Since you want how `users.d2` looked like at `v0.1`, you use `git` to get that version:
@@ -61,7 +46,7 @@ the two results. The evaluation starts by comparing their design decisions in an
overarching diagram projected in a dark room behind a closed door.
- `compare.d2`
-```d2
+```d2-incomplete
Team Alpha: {
Quick facts: |md
- 3 L6 engineers
diff --git a/docusaurus.config.js b/docusaurus.config.js
index a46ed1ba..9740676a 100644
--- a/docusaurus.config.js
+++ b/docusaurus.config.js
@@ -154,6 +154,10 @@ const config = {
test: /\.wasm$/,
type: "asset",
},
+ {
+ test: /\.d2/,
+ type: "asset/source",
+ },
{
test: new RegExp(`d2-vscode/syntaxes/.*\.json$`),
type: "asset",
diff --git a/package.json b/package.json
index 4f923370..7cb215dc 100644
--- a/package.json
+++ b/package.json
@@ -16,6 +16,7 @@
"@mdx-js/react": "^1.6.22",
"clsx": "^1.1.1",
"docusaurus-plugin-sass": "^0.2.3",
+ "pako": "^2.1.0",
"prettier": "^2.7.1",
"prism-react-renderer": "^1.3.1",
"react": "^17.0.2",
diff --git a/src/pages/index.js b/src/pages/index.js
index 7b753603..641db825 100644
--- a/src/pages/index.js
+++ b/src/pages/index.js
@@ -11,52 +11,7 @@ import FeatureHighlights from "@site/src/components/Directory/FeatureHighlights"
import MoreFeatures from "@site/src/components/Directory/MoreFeatures";
import D2CodeBlock from "@theme/CodeBlock";
import Example from "@site/static/img/generated/terminal-theme.svg2";
-
-const exampleD2 = `logs: {
- shape: page
- style.multiple: true
-}
-user: User {shape: person}
-network: Network {
- tower: Cell Tower {
- satellites: {
- shape: stored_data
- style.multiple: true
- }
-
- satellites -> transmitter
- satellites -> transmitter
- satellites -> transmitter
- transmitter
- }
- processor: Data Processor {
- storage: Storage {
- shape: cylinder
- style.multiple: true
- }
- }
- portal: Online Portal {
- UI
- }
-
- tower.transmitter -> processor: phone logs
-}
-server: API Server
-
-user -> network.tower: Make call
-network.processor -> server
-network.processor -> server
-network.processor -> server
-
-server -> logs
-server -> logs
-server -> logs: persist
-
-server -> network.portal.UI: display
-user -> network.portal.UI: access {
- style.stroke-dash: 3
-}
-`;
+import ExampleCode from "@site/static/bespoke-d2/terminal-theme.d2";
export default function Home() {
const context = useDocusaurusContext();
@@ -94,7 +49,7 @@ export default function Home() {
className="language-d2"
containerClassName="Directory__Example--Code"
>
- {exampleD2}
+ {ExampleCode}