Documentation ¶
Index ¶
Constants ¶
const ( LIFELINE_Z_INDEX = 1 SPAN_Z_INDEX = 2 GROUP_Z_INDEX = 3 MESSAGE_Z_INDEX = 4 NOTE_Z_INDEX = 5 )
const GROUP_CONTAINER_PADDING = 24.
const HORIZONTAL_PAD = 50.
leaves at least 25 units of space on the left/right when computing the space required between actors
const LIFELINE_LABEL_PAD = 5.
pad when the actor has the label placed OutsideMiddleBottom so that the lifeline is not so close to the text
const LIFELINE_STROKE_DASH int = 6
const LIFELINE_STROKE_WIDTH int = 2
const MIN_ACTOR_DISTANCE = 250.
const MIN_ACTOR_WIDTH = 150.
const MIN_MESSAGE_DISTANCE = 80.
min vertical distance between messages
const MIN_SPAN_HEIGHT = 80.
when a span has a single messages
const SELF_MESSAGE_HORIZONTAL_TRAVEL = 100.
const SPAN_BASE_WIDTH = 12.
default size
const SPAN_DEPTH_GROWTH_FACTOR = 8.
as the spans start getting nested, their size grows
const SPAN_MESSAGE_PAD = 16.
const VERTICAL_PAD = 50.
leaves at least 25 units of space on the top/bottom when computing the space required between messages
Variables ¶
This section is empty.
Functions ¶
func Layout ¶
func Layout(ctx context.Context, g *d2graph.Graph, layout func(ctx context.Context, g *d2graph.Graph) error) error
Layout runs the sequence diagram layout engine on objects of shape sequence_diagram
1. Traverse graph from root, skip objects with shape not `sequence_diagram` 2. Construct a sequence diagram from all descendant objects and edges 3. Remove those objects and edges from the main graph 4. Run layout on sequence diagrams 5. Set the resulting dimensions to the main graph shape 6. Run core layouts (still without sequence diagram innards) 7. Put back sequence diagram innards in correct location
Types ¶
This section is empty.