Merge pull request #1711 from gavin-ts/unfilled-triangle-arrowhead
add unfilled triangle arrowhead
This commit is contained in:
commit
4c091f5555
11 changed files with 889 additions and 29 deletions
|
|
@ -1,6 +1,7 @@
|
||||||
#### Features 🚀
|
#### Features 🚀
|
||||||
|
|
||||||
- ELK now routes `sql_table` edges to the exact columns (ty @landmaj) [#1681](https://github.com/terrastruct/d2/pull/1681)
|
- 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 🧹
|
#### Improvements 🧹
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -202,7 +202,7 @@ func toConnection(edge *d2graph.Edge, theme *d2themes.Theme) d2target.Connection
|
||||||
|
|
||||||
if edge.SrcArrow {
|
if edge.SrcArrow {
|
||||||
connection.SrcArrow = d2target.DefaultArrowhead
|
connection.SrcArrow = d2target.DefaultArrowhead
|
||||||
if edge.SrcArrowhead != nil && edge.SrcArrowhead.Shape.Value != "" {
|
if edge.SrcArrowhead != nil {
|
||||||
connection.SrcArrow = edge.SrcArrowhead.ToArrowhead()
|
connection.SrcArrow = edge.SrcArrowhead.ToArrowhead()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -220,7 +220,7 @@ func toConnection(edge *d2graph.Edge, theme *d2themes.Theme) d2target.Connection
|
||||||
}
|
}
|
||||||
if edge.DstArrow {
|
if edge.DstArrow {
|
||||||
connection.DstArrow = d2target.DefaultArrowhead
|
connection.DstArrow = d2target.DefaultArrowhead
|
||||||
if edge.DstArrowhead != nil && edge.DstArrowhead.Shape.Value != "" {
|
if edge.DstArrowhead != nil {
|
||||||
connection.DstArrow = edge.DstArrowhead.ToArrowhead()
|
connection.DstArrow = edge.DstArrowhead.ToArrowhead()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -177,13 +177,10 @@ func (a *Attributes) ApplyTextTransform() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Attributes) ToArrowhead() d2target.Arrowhead {
|
func (a *Attributes) ToArrowhead() d2target.Arrowhead {
|
||||||
if a.Shape.Value == "" {
|
var filled *bool
|
||||||
return d2target.NoArrowhead
|
|
||||||
}
|
|
||||||
|
|
||||||
filled := false
|
|
||||||
if a.Style.Filled != nil {
|
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)
|
return d2target.ToArrowhead(a.Shape.Value, filled)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -138,6 +138,29 @@ func arrowheadMarker(isTarget bool, id string, connection d2target.Connection) s
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
path = polygonEl.Render()
|
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:
|
case d2target.TriangleArrowhead:
|
||||||
polygonEl := d2themes.NewThemableElement("polygon")
|
polygonEl := d2themes.NewThemableElement("polygon")
|
||||||
polygonEl.Fill = connection.Stroke
|
polygonEl.Fill = connection.Stroke
|
||||||
|
|
|
||||||
|
|
@ -720,13 +720,14 @@ func (c Connection) GetID() string {
|
||||||
type Arrowhead string
|
type Arrowhead string
|
||||||
|
|
||||||
const (
|
const (
|
||||||
NoArrowhead Arrowhead = "none"
|
NoArrowhead Arrowhead = "none"
|
||||||
ArrowArrowhead Arrowhead = "arrow"
|
ArrowArrowhead Arrowhead = "arrow"
|
||||||
TriangleArrowhead Arrowhead = "triangle"
|
UnfilledTriangleArrowhead Arrowhead = "unfilled-triangle"
|
||||||
DiamondArrowhead Arrowhead = "diamond"
|
TriangleArrowhead Arrowhead = "triangle"
|
||||||
FilledDiamondArrowhead Arrowhead = "filled-diamond"
|
DiamondArrowhead Arrowhead = "diamond"
|
||||||
CircleArrowhead Arrowhead = "circle"
|
FilledDiamondArrowhead Arrowhead = "filled-diamond"
|
||||||
FilledCircleArrowhead Arrowhead = "filled-circle"
|
CircleArrowhead Arrowhead = "circle"
|
||||||
|
FilledCircleArrowhead Arrowhead = "filled-circle"
|
||||||
|
|
||||||
// For fat arrows
|
// For fat arrows
|
||||||
LineArrowhead Arrowhead = "line"
|
LineArrowhead Arrowhead = "line"
|
||||||
|
|
@ -740,29 +741,28 @@ const (
|
||||||
DefaultArrowhead Arrowhead = TriangleArrowhead
|
DefaultArrowhead Arrowhead = TriangleArrowhead
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// valid values for arrowhead.shape
|
||||||
var Arrowheads = map[string]struct{}{
|
var Arrowheads = map[string]struct{}{
|
||||||
string(NoArrowhead): {},
|
string(NoArrowhead): {},
|
||||||
string(ArrowArrowhead): {},
|
string(ArrowArrowhead): {},
|
||||||
string(TriangleArrowhead): {},
|
string(TriangleArrowhead): {},
|
||||||
string(DiamondArrowhead): {},
|
string(DiamondArrowhead): {},
|
||||||
string(FilledDiamondArrowhead): {},
|
string(CircleArrowhead): {},
|
||||||
string(CircleArrowhead): {},
|
string(CfOne): {},
|
||||||
string(FilledCircleArrowhead): {},
|
string(CfMany): {},
|
||||||
string(CfOne): {},
|
string(CfOneRequired): {},
|
||||||
string(CfMany): {},
|
string(CfManyRequired): {},
|
||||||
string(CfOneRequired): {},
|
|
||||||
string(CfManyRequired): {},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func ToArrowhead(arrowheadType string, filled bool) Arrowhead {
|
func ToArrowhead(arrowheadType string, filled *bool) Arrowhead {
|
||||||
switch arrowheadType {
|
switch arrowheadType {
|
||||||
case string(DiamondArrowhead):
|
case string(DiamondArrowhead):
|
||||||
if filled {
|
if filled != nil && *filled {
|
||||||
return FilledDiamondArrowhead
|
return FilledDiamondArrowhead
|
||||||
}
|
}
|
||||||
return DiamondArrowhead
|
return DiamondArrowhead
|
||||||
case string(CircleArrowhead):
|
case string(CircleArrowhead):
|
||||||
if filled {
|
if filled != nil && *filled {
|
||||||
return FilledCircleArrowhead
|
return FilledCircleArrowhead
|
||||||
}
|
}
|
||||||
return CircleArrowhead
|
return CircleArrowhead
|
||||||
|
|
@ -771,6 +771,9 @@ func ToArrowhead(arrowheadType string, filled bool) Arrowhead {
|
||||||
case string(ArrowArrowhead):
|
case string(ArrowArrowhead):
|
||||||
return ArrowArrowhead
|
return ArrowArrowhead
|
||||||
case string(TriangleArrowhead):
|
case string(TriangleArrowhead):
|
||||||
|
if filled != nil && !(*filled) {
|
||||||
|
return UnfilledTriangleArrowhead
|
||||||
|
}
|
||||||
return TriangleArrowhead
|
return TriangleArrowhead
|
||||||
case string(CfOne):
|
case string(CfOne):
|
||||||
return CfOne
|
return CfOne
|
||||||
|
|
@ -781,6 +784,10 @@ func ToArrowhead(arrowheadType string, filled bool) Arrowhead {
|
||||||
case string(CfManyRequired):
|
case string(CfManyRequired):
|
||||||
return CfManyRequired
|
return CfManyRequired
|
||||||
default:
|
default:
|
||||||
|
if DefaultArrowhead == TriangleArrowhead &&
|
||||||
|
filled != nil && !(*filled) {
|
||||||
|
return UnfilledTriangleArrowhead
|
||||||
|
}
|
||||||
return DefaultArrowhead
|
return DefaultArrowhead
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -799,6 +806,11 @@ func (arrowhead Arrowhead) Dimensions(strokeWidth float64) (width, height float6
|
||||||
baseHeight = 4
|
baseHeight = 4
|
||||||
widthMultiplier = 3
|
widthMultiplier = 3
|
||||||
heightMultiplier = 4
|
heightMultiplier = 4
|
||||||
|
case UnfilledTriangleArrowhead:
|
||||||
|
baseWidth = 7
|
||||||
|
baseHeight = 7
|
||||||
|
widthMultiplier = 3
|
||||||
|
heightMultiplier = 4
|
||||||
case LineArrowhead:
|
case LineArrowhead:
|
||||||
widthMultiplier = 5
|
widthMultiplier = 5
|
||||||
heightMultiplier = 8
|
heightMultiplier = 8
|
||||||
|
|
|
||||||
|
|
@ -2868,6 +2868,7 @@ y: profits {
|
||||||
loadFromFile(t, "grid_outside_labels"),
|
loadFromFile(t, "grid_outside_labels"),
|
||||||
loadFromFile(t, "grid_edge_across_cell"),
|
loadFromFile(t, "grid_edge_across_cell"),
|
||||||
loadFromFile(t, "nesting_power"),
|
loadFromFile(t, "nesting_power"),
|
||||||
|
loadFromFile(t, "unfilled_triangle"),
|
||||||
}
|
}
|
||||||
|
|
||||||
runa(t, tcs)
|
runa(t, tcs)
|
||||||
|
|
|
||||||
16
e2etests/testdata/files/unfilled_triangle.d2
vendored
Normal file
16
e2etests/testdata/files/unfilled_triangle.d2
vendored
Normal 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
|
||||||
|
}
|
||||||
|
}
|
||||||
307
e2etests/testdata/stable/unfilled_triangle/dagre/board.exp.json
generated
vendored
Normal file
307
e2etests/testdata/stable/unfilled_triangle/dagre/board.exp.json
generated
vendored
Normal 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
|
||||||
|
}
|
||||||
|
}
|
||||||
107
e2etests/testdata/stable/unfilled_triangle/dagre/sketch.exp.svg
vendored
Normal file
107
e2etests/testdata/stable/unfilled_triangle/dagre/sketch.exp.svg
vendored
Normal 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 <-> 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 <-> 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 |
289
e2etests/testdata/stable/unfilled_triangle/elk/board.exp.json
generated
vendored
Normal file
289
e2etests/testdata/stable/unfilled_triangle/elk/board.exp.json
generated
vendored
Normal 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
|
||||||
|
}
|
||||||
|
}
|
||||||
107
e2etests/testdata/stable/unfilled_triangle/elk/sketch.exp.svg
vendored
Normal file
107
e2etests/testdata/stable/unfilled_triangle/elk/sketch.exp.svg
vendored
Normal 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 <-> 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 <-> 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 |
Loading…
Reference in a new issue