Merge pull request #1711 from gavin-ts/unfilled-triangle-arrowhead

add unfilled triangle arrowhead
This commit is contained in:
gavin-ts 2023-11-07 18:43:32 -08:00 committed by GitHub
commit 4c091f5555
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
11 changed files with 889 additions and 29 deletions

View file

@ -1,6 +1,7 @@
#### Features 🚀
- ELK now routes `sql_table` edges to the exact columns (ty @landmaj) [#1681](https://github.com/terrastruct/d2/pull/1681)
- Adds new unfilled triangle arrowhead. [#1711](https://github.com/terrastruct/d2/pull/1711)
#### Improvements 🧹

View file

@ -202,7 +202,7 @@ func toConnection(edge *d2graph.Edge, theme *d2themes.Theme) d2target.Connection
if edge.SrcArrow {
connection.SrcArrow = d2target.DefaultArrowhead
if edge.SrcArrowhead != nil && edge.SrcArrowhead.Shape.Value != "" {
if edge.SrcArrowhead != nil {
connection.SrcArrow = edge.SrcArrowhead.ToArrowhead()
}
}
@ -220,7 +220,7 @@ func toConnection(edge *d2graph.Edge, theme *d2themes.Theme) d2target.Connection
}
if edge.DstArrow {
connection.DstArrow = d2target.DefaultArrowhead
if edge.DstArrowhead != nil && edge.DstArrowhead.Shape.Value != "" {
if edge.DstArrowhead != nil {
connection.DstArrow = edge.DstArrowhead.ToArrowhead()
}
}

View file

@ -177,13 +177,10 @@ func (a *Attributes) ApplyTextTransform() {
}
func (a *Attributes) ToArrowhead() d2target.Arrowhead {
if a.Shape.Value == "" {
return d2target.NoArrowhead
}
filled := false
var filled *bool
if a.Style.Filled != nil {
filled, _ = strconv.ParseBool(a.Style.Filled.Value)
v, _ := strconv.ParseBool(a.Style.Filled.Value)
filled = go2.Pointer(v)
}
return d2target.ToArrowhead(a.Shape.Value, filled)
}

View file

@ -138,6 +138,29 @@ func arrowheadMarker(isTarget bool, id string, connection d2target.Connection) s
)
}
path = polygonEl.Render()
case d2target.UnfilledTriangleArrowhead:
polygonEl := d2themes.NewThemableElement("polygon")
polygonEl.Fill = d2target.BG_COLOR
polygonEl.Stroke = connection.Stroke
polygonEl.ClassName = "connection"
polygonEl.Attributes = fmt.Sprintf(`stroke-width="%d"`, connection.StrokeWidth)
inset := strokeWidth / 2
if isTarget {
polygonEl.Points = fmt.Sprintf("%f,%f %f,%f %f,%f",
inset, inset,
width-inset, height/2.0,
inset, height-inset,
)
} else {
polygonEl.Points = fmt.Sprintf("%f,%f %f,%f %f,%f",
width-inset, inset,
inset, height/2.0,
width-inset, height-inset,
)
}
path = polygonEl.Render()
case d2target.TriangleArrowhead:
polygonEl := d2themes.NewThemableElement("polygon")
polygonEl.Fill = connection.Stroke

View file

@ -722,6 +722,7 @@ type Arrowhead string
const (
NoArrowhead Arrowhead = "none"
ArrowArrowhead Arrowhead = "arrow"
UnfilledTriangleArrowhead Arrowhead = "unfilled-triangle"
TriangleArrowhead Arrowhead = "triangle"
DiamondArrowhead Arrowhead = "diamond"
FilledDiamondArrowhead Arrowhead = "filled-diamond"
@ -740,29 +741,28 @@ const (
DefaultArrowhead Arrowhead = TriangleArrowhead
)
// valid values for arrowhead.shape
var Arrowheads = map[string]struct{}{
string(NoArrowhead): {},
string(ArrowArrowhead): {},
string(TriangleArrowhead): {},
string(DiamondArrowhead): {},
string(FilledDiamondArrowhead): {},
string(CircleArrowhead): {},
string(FilledCircleArrowhead): {},
string(CfOne): {},
string(CfMany): {},
string(CfOneRequired): {},
string(CfManyRequired): {},
}
func ToArrowhead(arrowheadType string, filled bool) Arrowhead {
func ToArrowhead(arrowheadType string, filled *bool) Arrowhead {
switch arrowheadType {
case string(DiamondArrowhead):
if filled {
if filled != nil && *filled {
return FilledDiamondArrowhead
}
return DiamondArrowhead
case string(CircleArrowhead):
if filled {
if filled != nil && *filled {
return FilledCircleArrowhead
}
return CircleArrowhead
@ -771,6 +771,9 @@ func ToArrowhead(arrowheadType string, filled bool) Arrowhead {
case string(ArrowArrowhead):
return ArrowArrowhead
case string(TriangleArrowhead):
if filled != nil && !(*filled) {
return UnfilledTriangleArrowhead
}
return TriangleArrowhead
case string(CfOne):
return CfOne
@ -781,6 +784,10 @@ func ToArrowhead(arrowheadType string, filled bool) Arrowhead {
case string(CfManyRequired):
return CfManyRequired
default:
if DefaultArrowhead == TriangleArrowhead &&
filled != nil && !(*filled) {
return UnfilledTriangleArrowhead
}
return DefaultArrowhead
}
}
@ -799,6 +806,11 @@ func (arrowhead Arrowhead) Dimensions(strokeWidth float64) (width, height float6
baseHeight = 4
widthMultiplier = 3
heightMultiplier = 4
case UnfilledTriangleArrowhead:
baseWidth = 7
baseHeight = 7
widthMultiplier = 3
heightMultiplier = 4
case LineArrowhead:
widthMultiplier = 5
heightMultiplier = 8

View file

@ -2868,6 +2868,7 @@ y: profits {
loadFromFile(t, "grid_outside_labels"),
loadFromFile(t, "grid_edge_across_cell"),
loadFromFile(t, "nesting_power"),
loadFromFile(t, "unfilled_triangle"),
}
runa(t, tcs)

View file

@ -0,0 +1,16 @@
direction: right
A <-> B: default {
source-arrowhead.style.filled: false
target-arrowhead.style.filled: false
}
C <-> D: triangle {
source-arrowhead: {
shape: triangle
style.filled: false
}
target-arrowhead: {
shape: triangle
style.filled: false
}
}

View file

@ -0,0 +1,307 @@
{
"name": "",
"isFolderOnly": false,
"fontFamily": "SourceSansPro",
"shapes": [
{
"id": "A",
"type": "rectangle",
"pos": {
"x": 0,
"y": 0
},
"width": 56,
"height": 66,
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"borderRadius": 0,
"fill": "B6",
"stroke": "B1",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "A",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N1",
"italic": false,
"bold": true,
"underline": false,
"labelWidth": 11,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"zIndex": 0,
"level": 1
},
{
"id": "B",
"type": "rectangle",
"pos": {
"x": 208,
"y": 0
},
"width": 54,
"height": 66,
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"borderRadius": 0,
"fill": "B6",
"stroke": "B1",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "B",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N1",
"italic": false,
"bold": true,
"underline": false,
"labelWidth": 9,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"zIndex": 0,
"level": 1
},
{
"id": "C",
"type": "rectangle",
"pos": {
"x": 1,
"y": 126
},
"width": 54,
"height": 66,
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"borderRadius": 0,
"fill": "B6",
"stroke": "B1",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "C",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N1",
"italic": false,
"bold": true,
"underline": false,
"labelWidth": 9,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"zIndex": 0,
"level": 1
},
{
"id": "D",
"type": "rectangle",
"pos": {
"x": 208,
"y": 126
},
"width": 54,
"height": 66,
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"borderRadius": 0,
"fill": "B6",
"stroke": "B1",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "D",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N1",
"italic": false,
"bold": true,
"underline": false,
"labelWidth": 9,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"zIndex": 0,
"level": 1
}
],
"connections": [
{
"id": "(A <-> B)[0]",
"src": "A",
"srcArrow": "unfilled-triangle",
"dst": "B",
"dstArrow": "unfilled-triangle",
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"stroke": "B1",
"borderRadius": 10,
"label": "default",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N2",
"italic": true,
"bold": false,
"underline": false,
"labelWidth": 48,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"labelPercentage": 0,
"route": [
{
"x": 56,
"y": 33
},
{
"x": 116.80000305175781,
"y": 33
},
{
"x": 147.1999969482422,
"y": 33
},
{
"x": 208,
"y": 33
}
],
"isCurve": true,
"animated": false,
"tooltip": "",
"icon": null,
"zIndex": 0
},
{
"id": "(C <-> D)[0]",
"src": "C",
"srcArrow": "unfilled-triangle",
"dst": "D",
"dstArrow": "unfilled-triangle",
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"stroke": "B1",
"borderRadius": 10,
"label": "triangle",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N2",
"italic": true,
"bold": false,
"underline": false,
"labelWidth": 52,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"labelPercentage": 0,
"route": [
{
"x": 55,
"y": 159
},
{
"x": 116.5999984741211,
"y": 159
},
{
"x": 147.1999969482422,
"y": 159
},
{
"x": 208,
"y": 159
}
],
"isCurve": true,
"animated": false,
"tooltip": "",
"icon": null,
"zIndex": 0
}
],
"root": {
"id": "",
"type": "",
"pos": {
"x": 0,
"y": 0
},
"width": 0,
"height": 0,
"opacity": 0,
"strokeDash": 0,
"strokeWidth": 0,
"borderRadius": 0,
"fill": "N7",
"stroke": "",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "",
"fontSize": 0,
"fontFamily": "",
"language": "",
"color": "",
"italic": false,
"bold": false,
"underline": false,
"labelWidth": 0,
"labelHeight": 0,
"zIndex": 0,
"level": 0
}
}

View file

@ -0,0 +1,107 @@
<?xml version="1.0" encoding="utf-8"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" d2Version="v0.6.1-HEAD" preserveAspectRatio="xMinYMin meet" viewBox="0 0 264 194"><svg id="d2-svg" class="d2-857282650" width="264" height="194" viewBox="-1 -1 264 194"><rect x="-1.000000" y="-1.000000" width="264.000000" height="194.000000" rx="0.000000" class=" fill-N7" stroke-width="0" /><style type="text/css"><![CDATA[
.d2-857282650 .text-bold {
font-family: "d2-857282650-font-bold";
}
@font-face {
font-family: d2-857282650-font-bold;
src: url("data:application/font-woff;base64,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");
}
.d2-857282650 .text-italic {
font-family: "d2-857282650-font-italic";
}
@font-face {
font-family: d2-857282650-font-italic;
src: url("data:application/font-woff;base64,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");
}]]></style><style type="text/css"><![CDATA[.shape {
shape-rendering: geometricPrecision;
stroke-linejoin: round;
}
.connection {
stroke-linecap: round;
stroke-linejoin: round;
}
.blend {
mix-blend-mode: multiply;
opacity: 0.5;
}
.d2-857282650 .fill-N1{fill:#0A0F25;}
.d2-857282650 .fill-N2{fill:#676C7E;}
.d2-857282650 .fill-N3{fill:#9499AB;}
.d2-857282650 .fill-N4{fill:#CFD2DD;}
.d2-857282650 .fill-N5{fill:#DEE1EB;}
.d2-857282650 .fill-N6{fill:#EEF1F8;}
.d2-857282650 .fill-N7{fill:#FFFFFF;}
.d2-857282650 .fill-B1{fill:#0D32B2;}
.d2-857282650 .fill-B2{fill:#0D32B2;}
.d2-857282650 .fill-B3{fill:#E3E9FD;}
.d2-857282650 .fill-B4{fill:#E3E9FD;}
.d2-857282650 .fill-B5{fill:#EDF0FD;}
.d2-857282650 .fill-B6{fill:#F7F8FE;}
.d2-857282650 .fill-AA2{fill:#4A6FF3;}
.d2-857282650 .fill-AA4{fill:#EDF0FD;}
.d2-857282650 .fill-AA5{fill:#F7F8FE;}
.d2-857282650 .fill-AB4{fill:#EDF0FD;}
.d2-857282650 .fill-AB5{fill:#F7F8FE;}
.d2-857282650 .stroke-N1{stroke:#0A0F25;}
.d2-857282650 .stroke-N2{stroke:#676C7E;}
.d2-857282650 .stroke-N3{stroke:#9499AB;}
.d2-857282650 .stroke-N4{stroke:#CFD2DD;}
.d2-857282650 .stroke-N5{stroke:#DEE1EB;}
.d2-857282650 .stroke-N6{stroke:#EEF1F8;}
.d2-857282650 .stroke-N7{stroke:#FFFFFF;}
.d2-857282650 .stroke-B1{stroke:#0D32B2;}
.d2-857282650 .stroke-B2{stroke:#0D32B2;}
.d2-857282650 .stroke-B3{stroke:#E3E9FD;}
.d2-857282650 .stroke-B4{stroke:#E3E9FD;}
.d2-857282650 .stroke-B5{stroke:#EDF0FD;}
.d2-857282650 .stroke-B6{stroke:#F7F8FE;}
.d2-857282650 .stroke-AA2{stroke:#4A6FF3;}
.d2-857282650 .stroke-AA4{stroke:#EDF0FD;}
.d2-857282650 .stroke-AA5{stroke:#F7F8FE;}
.d2-857282650 .stroke-AB4{stroke:#EDF0FD;}
.d2-857282650 .stroke-AB5{stroke:#F7F8FE;}
.d2-857282650 .background-color-N1{background-color:#0A0F25;}
.d2-857282650 .background-color-N2{background-color:#676C7E;}
.d2-857282650 .background-color-N3{background-color:#9499AB;}
.d2-857282650 .background-color-N4{background-color:#CFD2DD;}
.d2-857282650 .background-color-N5{background-color:#DEE1EB;}
.d2-857282650 .background-color-N6{background-color:#EEF1F8;}
.d2-857282650 .background-color-N7{background-color:#FFFFFF;}
.d2-857282650 .background-color-B1{background-color:#0D32B2;}
.d2-857282650 .background-color-B2{background-color:#0D32B2;}
.d2-857282650 .background-color-B3{background-color:#E3E9FD;}
.d2-857282650 .background-color-B4{background-color:#E3E9FD;}
.d2-857282650 .background-color-B5{background-color:#EDF0FD;}
.d2-857282650 .background-color-B6{background-color:#F7F8FE;}
.d2-857282650 .background-color-AA2{background-color:#4A6FF3;}
.d2-857282650 .background-color-AA4{background-color:#EDF0FD;}
.d2-857282650 .background-color-AA5{background-color:#F7F8FE;}
.d2-857282650 .background-color-AB4{background-color:#EDF0FD;}
.d2-857282650 .background-color-AB5{background-color:#F7F8FE;}
.d2-857282650 .color-N1{color:#0A0F25;}
.d2-857282650 .color-N2{color:#676C7E;}
.d2-857282650 .color-N3{color:#9499AB;}
.d2-857282650 .color-N4{color:#CFD2DD;}
.d2-857282650 .color-N5{color:#DEE1EB;}
.d2-857282650 .color-N6{color:#EEF1F8;}
.d2-857282650 .color-N7{color:#FFFFFF;}
.d2-857282650 .color-B1{color:#0D32B2;}
.d2-857282650 .color-B2{color:#0D32B2;}
.d2-857282650 .color-B3{color:#E3E9FD;}
.d2-857282650 .color-B4{color:#E3E9FD;}
.d2-857282650 .color-B5{color:#EDF0FD;}
.d2-857282650 .color-B6{color:#F7F8FE;}
.d2-857282650 .color-AA2{color:#4A6FF3;}
.d2-857282650 .color-AA4{color:#EDF0FD;}
.d2-857282650 .color-AA5{color:#F7F8FE;}
.d2-857282650 .color-AB4{color:#EDF0FD;}
.d2-857282650 .color-AB5{color:#F7F8FE;}.appendix text.text{fill:#0A0F25}.md{--color-fg-default:#0A0F25;--color-fg-muted:#676C7E;--color-fg-subtle:#9499AB;--color-canvas-default:#FFFFFF;--color-canvas-subtle:#EEF1F8;--color-border-default:#0D32B2;--color-border-muted:#0D32B2;--color-neutral-muted:#EEF1F8;--color-accent-fg:#0D32B2;--color-accent-emphasis:#0D32B2;--color-attention-subtle:#676C7E;--color-danger-fg:red;}.sketch-overlay-B1{fill:url(#streaks-darker);mix-blend-mode:lighten}.sketch-overlay-B2{fill:url(#streaks-darker);mix-blend-mode:lighten}.sketch-overlay-B3{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-B4{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-B5{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-B6{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-AA2{fill:url(#streaks-dark);mix-blend-mode:overlay}.sketch-overlay-AA4{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-AA5{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-AB4{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-AB5{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-N1{fill:url(#streaks-darker);mix-blend-mode:lighten}.sketch-overlay-N2{fill:url(#streaks-dark);mix-blend-mode:overlay}.sketch-overlay-N3{fill:url(#streaks-normal);mix-blend-mode:color-burn}.sketch-overlay-N4{fill:url(#streaks-normal);mix-blend-mode:color-burn}.sketch-overlay-N5{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-N6{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-N7{fill:url(#streaks-bright);mix-blend-mode:darken}.light-code{display: block}.dark-code{display: none}]]></style><g id="A"><g class="shape" ><rect x="0.000000" y="0.000000" width="56.000000" height="66.000000" class=" stroke-B1 fill-B6" style="stroke-width:2;" /></g><text x="28.000000" y="38.500000" class="text-bold fill-N1" style="text-anchor:middle;font-size:16px">A</text></g><g id="B"><g class="shape" ><rect x="208.000000" y="0.000000" width="54.000000" height="66.000000" class=" stroke-B1 fill-B6" style="stroke-width:2;" /></g><text x="235.000000" y="38.500000" class="text-bold fill-N1" style="text-anchor:middle;font-size:16px">B</text></g><g id="C"><g class="shape" ><rect x="1.000000" y="126.000000" width="54.000000" height="66.000000" class=" stroke-B1 fill-B6" style="stroke-width:2;" /></g><text x="28.000000" y="164.500000" class="text-bold fill-N1" style="text-anchor:middle;font-size:16px">C</text></g><g id="D"><g class="shape" ><rect x="208.000000" y="126.000000" width="54.000000" height="66.000000" class=" stroke-B1 fill-B6" style="stroke-width:2;" /></g><text x="235.000000" y="164.500000" class="text-bold fill-N1" style="text-anchor:middle;font-size:16px">D</text></g><g id="(A &lt;-&gt; B)[0]"><marker id="mk-2954633863" markerWidth="13.000000" markerHeight="15.000000" refX="3.000000" refY="7.500000" viewBox="0.000000 0.000000 13.000000 15.000000" orient="auto" markerUnits="userSpaceOnUse"> <polygon points="12.000000,1.000000 1.000000,7.500000 12.000000,14.000000" class="connection stroke-B1 fill-N7" stroke-width="2" /> </marker><marker id="mk-3777340426" markerWidth="13.000000" markerHeight="15.000000" refX="10.000000" refY="7.500000" viewBox="0.000000 0.000000 13.000000 15.000000" orient="auto" markerUnits="userSpaceOnUse"> <polygon points="1.000000,1.000000 12.000000,7.500000 1.000000,14.000000" class="connection stroke-B1 fill-N7" stroke-width="2" /> </marker><path d="M 60.000000 33.000000 C 116.800003 33.000000 147.199997 33.000000 204.000000 33.000000" fill="none" class="connection stroke-B1" style="stroke-width:2;" marker-start="url(#mk-2954633863)" marker-end="url(#mk-3777340426)" mask="url(#d2-857282650)" /><text x="132.000000" y="39.000000" class="text-italic fill-N2" style="text-anchor:middle;font-size:16px">default</text></g><g id="(C &lt;-&gt; D)[0]"><path d="M 59.000000 159.000000 C 116.599998 159.000000 147.199997 159.000000 204.000000 159.000000" fill="none" class="connection stroke-B1" style="stroke-width:2;" marker-start="url(#mk-2954633863)" marker-end="url(#mk-3777340426)" mask="url(#d2-857282650)" /><text x="132.000000" y="165.000000" class="text-italic fill-N2" style="text-anchor:middle;font-size:16px">triangle</text></g><mask id="d2-857282650" maskUnits="userSpaceOnUse" x="-1" y="-1" width="264" height="194">
<rect x="-1" y="-1" width="264" height="194" fill="white"></rect>
<rect x="22.500000" y="22.500000" width="11" height="21" fill="rgba(0,0,0,0.75)"></rect>
<rect x="230.500000" y="22.500000" width="9" height="21" fill="rgba(0,0,0,0.75)"></rect>
<rect x="23.500000" y="148.500000" width="9" height="21" fill="rgba(0,0,0,0.75)"></rect>
<rect x="230.500000" y="148.500000" width="9" height="21" fill="rgba(0,0,0,0.75)"></rect>
<rect x="108.000000" y="23.000000" width="48" height="21" fill="black"></rect>
<rect x="106.000000" y="149.000000" width="52" height="21" fill="black"></rect>
</mask></svg></svg>

After

Width:  |  Height:  |  Size: 16 KiB

View file

@ -0,0 +1,289 @@
{
"name": "",
"isFolderOnly": false,
"fontFamily": "SourceSansPro",
"shapes": [
{
"id": "A",
"type": "rectangle",
"pos": {
"x": 12,
"y": 12
},
"width": 56,
"height": 66,
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"borderRadius": 0,
"fill": "B6",
"stroke": "B1",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "A",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N1",
"italic": false,
"bold": true,
"underline": false,
"labelWidth": 11,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"zIndex": 0,
"level": 1
},
{
"id": "B",
"type": "rectangle",
"pos": {
"x": 260,
"y": 12
},
"width": 54,
"height": 66,
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"borderRadius": 0,
"fill": "B6",
"stroke": "B1",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "B",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N1",
"italic": false,
"bold": true,
"underline": false,
"labelWidth": 9,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"zIndex": 0,
"level": 1
},
{
"id": "C",
"type": "rectangle",
"pos": {
"x": 14,
"y": 98
},
"width": 54,
"height": 66,
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"borderRadius": 0,
"fill": "B6",
"stroke": "B1",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "C",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N1",
"italic": false,
"bold": true,
"underline": false,
"labelWidth": 9,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"zIndex": 0,
"level": 1
},
{
"id": "D",
"type": "rectangle",
"pos": {
"x": 260,
"y": 98
},
"width": 54,
"height": 66,
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"borderRadius": 0,
"fill": "B6",
"stroke": "B1",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "D",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N1",
"italic": false,
"bold": true,
"underline": false,
"labelWidth": 9,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"zIndex": 0,
"level": 1
}
],
"connections": [
{
"id": "(A <-> B)[0]",
"src": "A",
"srcArrow": "unfilled-triangle",
"dst": "B",
"dstArrow": "unfilled-triangle",
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"stroke": "B1",
"borderRadius": 10,
"label": "default",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N2",
"italic": true,
"bold": false,
"underline": false,
"labelWidth": 48,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"labelPercentage": 0,
"route": [
{
"x": 68,
"y": 45
},
{
"x": 260,
"y": 45
}
],
"animated": false,
"tooltip": "",
"icon": null,
"zIndex": 0
},
{
"id": "(C <-> D)[0]",
"src": "C",
"srcArrow": "unfilled-triangle",
"dst": "D",
"dstArrow": "unfilled-triangle",
"opacity": 1,
"strokeDash": 0,
"strokeWidth": 2,
"stroke": "B1",
"borderRadius": 10,
"label": "triangle",
"fontSize": 16,
"fontFamily": "DEFAULT",
"language": "",
"color": "N2",
"italic": true,
"bold": false,
"underline": false,
"labelWidth": 52,
"labelHeight": 21,
"labelPosition": "INSIDE_MIDDLE_CENTER",
"labelPercentage": 0,
"route": [
{
"x": 68,
"y": 131
},
{
"x": 260,
"y": 131
}
],
"animated": false,
"tooltip": "",
"icon": null,
"zIndex": 0
}
],
"root": {
"id": "",
"type": "",
"pos": {
"x": 0,
"y": 0
},
"width": 0,
"height": 0,
"opacity": 0,
"strokeDash": 0,
"strokeWidth": 0,
"borderRadius": 0,
"fill": "N7",
"stroke": "",
"shadow": false,
"3d": false,
"multiple": false,
"double-border": false,
"tooltip": "",
"link": "",
"icon": null,
"iconPosition": "",
"blend": false,
"fields": null,
"methods": null,
"columns": null,
"label": "",
"fontSize": 0,
"fontFamily": "",
"language": "",
"color": "",
"italic": false,
"bold": false,
"underline": false,
"labelWidth": 0,
"labelHeight": 0,
"zIndex": 0,
"level": 0
}
}

View file

@ -0,0 +1,107 @@
<?xml version="1.0" encoding="utf-8"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" d2Version="v0.6.1-HEAD" preserveAspectRatio="xMinYMin meet" viewBox="0 0 304 154"><svg id="d2-svg" class="d2-3330864888" width="304" height="154" viewBox="11 11 304 154"><rect x="11.000000" y="11.000000" width="304.000000" height="154.000000" rx="0.000000" class=" fill-N7" stroke-width="0" /><style type="text/css"><![CDATA[
.d2-3330864888 .text-bold {
font-family: "d2-3330864888-font-bold";
}
@font-face {
font-family: d2-3330864888-font-bold;
src: url("data:application/font-woff;base64,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");
}
.d2-3330864888 .text-italic {
font-family: "d2-3330864888-font-italic";
}
@font-face {
font-family: d2-3330864888-font-italic;
src: url("data:application/font-woff;base64,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");
}]]></style><style type="text/css"><![CDATA[.shape {
shape-rendering: geometricPrecision;
stroke-linejoin: round;
}
.connection {
stroke-linecap: round;
stroke-linejoin: round;
}
.blend {
mix-blend-mode: multiply;
opacity: 0.5;
}
.d2-3330864888 .fill-N1{fill:#0A0F25;}
.d2-3330864888 .fill-N2{fill:#676C7E;}
.d2-3330864888 .fill-N3{fill:#9499AB;}
.d2-3330864888 .fill-N4{fill:#CFD2DD;}
.d2-3330864888 .fill-N5{fill:#DEE1EB;}
.d2-3330864888 .fill-N6{fill:#EEF1F8;}
.d2-3330864888 .fill-N7{fill:#FFFFFF;}
.d2-3330864888 .fill-B1{fill:#0D32B2;}
.d2-3330864888 .fill-B2{fill:#0D32B2;}
.d2-3330864888 .fill-B3{fill:#E3E9FD;}
.d2-3330864888 .fill-B4{fill:#E3E9FD;}
.d2-3330864888 .fill-B5{fill:#EDF0FD;}
.d2-3330864888 .fill-B6{fill:#F7F8FE;}
.d2-3330864888 .fill-AA2{fill:#4A6FF3;}
.d2-3330864888 .fill-AA4{fill:#EDF0FD;}
.d2-3330864888 .fill-AA5{fill:#F7F8FE;}
.d2-3330864888 .fill-AB4{fill:#EDF0FD;}
.d2-3330864888 .fill-AB5{fill:#F7F8FE;}
.d2-3330864888 .stroke-N1{stroke:#0A0F25;}
.d2-3330864888 .stroke-N2{stroke:#676C7E;}
.d2-3330864888 .stroke-N3{stroke:#9499AB;}
.d2-3330864888 .stroke-N4{stroke:#CFD2DD;}
.d2-3330864888 .stroke-N5{stroke:#DEE1EB;}
.d2-3330864888 .stroke-N6{stroke:#EEF1F8;}
.d2-3330864888 .stroke-N7{stroke:#FFFFFF;}
.d2-3330864888 .stroke-B1{stroke:#0D32B2;}
.d2-3330864888 .stroke-B2{stroke:#0D32B2;}
.d2-3330864888 .stroke-B3{stroke:#E3E9FD;}
.d2-3330864888 .stroke-B4{stroke:#E3E9FD;}
.d2-3330864888 .stroke-B5{stroke:#EDF0FD;}
.d2-3330864888 .stroke-B6{stroke:#F7F8FE;}
.d2-3330864888 .stroke-AA2{stroke:#4A6FF3;}
.d2-3330864888 .stroke-AA4{stroke:#EDF0FD;}
.d2-3330864888 .stroke-AA5{stroke:#F7F8FE;}
.d2-3330864888 .stroke-AB4{stroke:#EDF0FD;}
.d2-3330864888 .stroke-AB5{stroke:#F7F8FE;}
.d2-3330864888 .background-color-N1{background-color:#0A0F25;}
.d2-3330864888 .background-color-N2{background-color:#676C7E;}
.d2-3330864888 .background-color-N3{background-color:#9499AB;}
.d2-3330864888 .background-color-N4{background-color:#CFD2DD;}
.d2-3330864888 .background-color-N5{background-color:#DEE1EB;}
.d2-3330864888 .background-color-N6{background-color:#EEF1F8;}
.d2-3330864888 .background-color-N7{background-color:#FFFFFF;}
.d2-3330864888 .background-color-B1{background-color:#0D32B2;}
.d2-3330864888 .background-color-B2{background-color:#0D32B2;}
.d2-3330864888 .background-color-B3{background-color:#E3E9FD;}
.d2-3330864888 .background-color-B4{background-color:#E3E9FD;}
.d2-3330864888 .background-color-B5{background-color:#EDF0FD;}
.d2-3330864888 .background-color-B6{background-color:#F7F8FE;}
.d2-3330864888 .background-color-AA2{background-color:#4A6FF3;}
.d2-3330864888 .background-color-AA4{background-color:#EDF0FD;}
.d2-3330864888 .background-color-AA5{background-color:#F7F8FE;}
.d2-3330864888 .background-color-AB4{background-color:#EDF0FD;}
.d2-3330864888 .background-color-AB5{background-color:#F7F8FE;}
.d2-3330864888 .color-N1{color:#0A0F25;}
.d2-3330864888 .color-N2{color:#676C7E;}
.d2-3330864888 .color-N3{color:#9499AB;}
.d2-3330864888 .color-N4{color:#CFD2DD;}
.d2-3330864888 .color-N5{color:#DEE1EB;}
.d2-3330864888 .color-N6{color:#EEF1F8;}
.d2-3330864888 .color-N7{color:#FFFFFF;}
.d2-3330864888 .color-B1{color:#0D32B2;}
.d2-3330864888 .color-B2{color:#0D32B2;}
.d2-3330864888 .color-B3{color:#E3E9FD;}
.d2-3330864888 .color-B4{color:#E3E9FD;}
.d2-3330864888 .color-B5{color:#EDF0FD;}
.d2-3330864888 .color-B6{color:#F7F8FE;}
.d2-3330864888 .color-AA2{color:#4A6FF3;}
.d2-3330864888 .color-AA4{color:#EDF0FD;}
.d2-3330864888 .color-AA5{color:#F7F8FE;}
.d2-3330864888 .color-AB4{color:#EDF0FD;}
.d2-3330864888 .color-AB5{color:#F7F8FE;}.appendix text.text{fill:#0A0F25}.md{--color-fg-default:#0A0F25;--color-fg-muted:#676C7E;--color-fg-subtle:#9499AB;--color-canvas-default:#FFFFFF;--color-canvas-subtle:#EEF1F8;--color-border-default:#0D32B2;--color-border-muted:#0D32B2;--color-neutral-muted:#EEF1F8;--color-accent-fg:#0D32B2;--color-accent-emphasis:#0D32B2;--color-attention-subtle:#676C7E;--color-danger-fg:red;}.sketch-overlay-B1{fill:url(#streaks-darker);mix-blend-mode:lighten}.sketch-overlay-B2{fill:url(#streaks-darker);mix-blend-mode:lighten}.sketch-overlay-B3{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-B4{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-B5{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-B6{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-AA2{fill:url(#streaks-dark);mix-blend-mode:overlay}.sketch-overlay-AA4{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-AA5{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-AB4{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-AB5{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-N1{fill:url(#streaks-darker);mix-blend-mode:lighten}.sketch-overlay-N2{fill:url(#streaks-dark);mix-blend-mode:overlay}.sketch-overlay-N3{fill:url(#streaks-normal);mix-blend-mode:color-burn}.sketch-overlay-N4{fill:url(#streaks-normal);mix-blend-mode:color-burn}.sketch-overlay-N5{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-N6{fill:url(#streaks-bright);mix-blend-mode:darken}.sketch-overlay-N7{fill:url(#streaks-bright);mix-blend-mode:darken}.light-code{display: block}.dark-code{display: none}]]></style><g id="A"><g class="shape" ><rect x="12.000000" y="12.000000" width="56.000000" height="66.000000" class=" stroke-B1 fill-B6" style="stroke-width:2;" /></g><text x="40.000000" y="50.500000" class="text-bold fill-N1" style="text-anchor:middle;font-size:16px">A</text></g><g id="B"><g class="shape" ><rect x="260.000000" y="12.000000" width="54.000000" height="66.000000" class=" stroke-B1 fill-B6" style="stroke-width:2;" /></g><text x="287.000000" y="50.500000" class="text-bold fill-N1" style="text-anchor:middle;font-size:16px">B</text></g><g id="C"><g class="shape" ><rect x="14.000000" y="98.000000" width="54.000000" height="66.000000" class=" stroke-B1 fill-B6" style="stroke-width:2;" /></g><text x="41.000000" y="136.500000" class="text-bold fill-N1" style="text-anchor:middle;font-size:16px">C</text></g><g id="D"><g class="shape" ><rect x="260.000000" y="98.000000" width="54.000000" height="66.000000" class=" stroke-B1 fill-B6" style="stroke-width:2;" /></g><text x="287.000000" y="136.500000" class="text-bold fill-N1" style="text-anchor:middle;font-size:16px">D</text></g><g id="(A &lt;-&gt; B)[0]"><marker id="mk-2954633863" markerWidth="13.000000" markerHeight="15.000000" refX="3.000000" refY="7.500000" viewBox="0.000000 0.000000 13.000000 15.000000" orient="auto" markerUnits="userSpaceOnUse"> <polygon points="12.000000,1.000000 1.000000,7.500000 12.000000,14.000000" class="connection stroke-B1 fill-N7" stroke-width="2" /> </marker><marker id="mk-3777340426" markerWidth="13.000000" markerHeight="15.000000" refX="10.000000" refY="7.500000" viewBox="0.000000 0.000000 13.000000 15.000000" orient="auto" markerUnits="userSpaceOnUse"> <polygon points="1.000000,1.000000 12.000000,7.500000 1.000000,14.000000" class="connection stroke-B1 fill-N7" stroke-width="2" /> </marker><path d="M 72.000000 45.000000 L 256.000000 45.000000" fill="none" class="connection stroke-B1" style="stroke-width:2;" marker-start="url(#mk-2954633863)" marker-end="url(#mk-3777340426)" mask="url(#d2-3330864888)" /><text x="164.000000" y="51.000000" class="text-italic fill-N2" style="text-anchor:middle;font-size:16px">default</text></g><g id="(C &lt;-&gt; D)[0]"><path d="M 72.000000 131.000000 L 256.000000 131.000000" fill="none" class="connection stroke-B1" style="stroke-width:2;" marker-start="url(#mk-2954633863)" marker-end="url(#mk-3777340426)" mask="url(#d2-3330864888)" /><text x="164.000000" y="137.000000" class="text-italic fill-N2" style="text-anchor:middle;font-size:16px">triangle</text></g><mask id="d2-3330864888" maskUnits="userSpaceOnUse" x="11" y="11" width="304" height="154">
<rect x="11" y="11" width="304" height="154" fill="white"></rect>
<rect x="34.500000" y="34.500000" width="11" height="21" fill="rgba(0,0,0,0.75)"></rect>
<rect x="282.500000" y="34.500000" width="9" height="21" fill="rgba(0,0,0,0.75)"></rect>
<rect x="36.500000" y="120.500000" width="9" height="21" fill="rgba(0,0,0,0.75)"></rect>
<rect x="282.500000" y="120.500000" width="9" height="21" fill="rgba(0,0,0,0.75)"></rect>
<rect x="140.000000" y="35.000000" width="48" height="21" fill="black"></rect>
<rect x="138.000000" y="121.000000" width="52" height="21" fill="black"></rect>
</mask></svg></svg>

After

Width:  |  Height:  |  Size: 16 KiB