UNPKG

mermaid

Version:

Markdown-ish syntax for generating flowcharts, mindmaps, sequence diagrams, class diagrams, gantt charts, git graphs and more.

1,617 lines (1,616 loc) 46.8 kB
/** * This file was automatically generated by json-schema-to-typescript. * DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file, * and run json-schema-to-typescript to regenerate this file. */ /** * JavaScript function that returns a `FontConfig`. * * By default, these return the appropriate `*FontSize`, `*FontFamily`, `*FontWeight` * values. * * For example, the font calculator called `boundaryFont` might be defined as: * * ```javascript * boundaryFont: function () { * return { * fontFamily: this.boundaryFontFamily, * fontSize: this.boundaryFontSize, * fontWeight: this.boundaryFontWeight, * }; * } * ``` * * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "FontCalculator". */ export type FontCalculator = () => Partial<FontConfig>; /** * Picks the color of the sankey diagram links, using the colors of the source and/or target of the links. * * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "SankeyLinkColor". */ export type SankeyLinkColor = 'source' | 'target' | 'gradient'; /** * Controls the alignment of the Sankey diagrams. * * See <https://github.com/d3/d3-sankey#alignments>. * * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "SankeyNodeAlignment". */ export type SankeyNodeAlignment = 'left' | 'right' | 'center' | 'justify'; /** * Configuration options to pass to the `dompurify` library. */ export type DOMPurifyConfiguration = import('dompurify').Config; /** * The font size to use */ export type CSSFontSize = string | number; export interface MermaidConfig { /** * Theme, the CSS style sheet. * You may also use `themeCSS` to override this value. * */ theme?: 'default' | 'base' | 'dark' | 'forest' | 'neutral' | 'null'; themeVariables?: any; themeCSS?: string; /** * Defines which main look to use for the diagram. * */ look?: 'classic' | 'handDrawn'; /** * Defines the seed to be used when using handDrawn look. This is important for the automated tests as they will always find differences without the seed. The default value is 0 which gives a random seed. * */ handDrawnSeed?: number; /** * Defines which layout algorithm to use for rendering the diagram. * */ layout?: string; /** * The maximum allowed size of the users text diagram */ maxTextSize?: number; /** * Defines the maximum number of edges that can be drawn in a graph. * */ maxEdges?: number; elk?: { /** * Elk specific option that allows edges to share path where it convenient. It can make for pretty diagrams but can also make it harder to read the diagram. * */ mergeEdges?: boolean; /** * Elk specific option affecting how nodes are placed. * */ nodePlacementStrategy?: 'SIMPLE' | 'NETWORK_SIMPLEX' | 'LINEAR_SEGMENTS' | 'BRANDES_KOEPF'; /** * This strategy decides how to find cycles in the graph and deciding which edges need adjustment to break loops. * */ cycleBreakingStrategy?: 'GREEDY' | 'DEPTH_FIRST' | 'INTERACTIVE' | 'MODEL_ORDER' | 'GREEDY_MODEL_ORDER'; /** * The node order given by the model does not change to produce a better layout. E.g. if node A is before node B in the model this is not changed during crossing minimization. This assumes that the node model order is already respected before crossing minimization. This can be achieved by setting considerModelOrder.strategy to NODES_AND_EDGES. * */ forceNodeModelOrder?: boolean; /** * Preserves the order of nodes and edges in the model file if this does not lead to additional edge crossings. Depending on the strategy this is not always possible since the node and edge order might be conflicting. * */ considerModelOrder?: 'NONE' | 'NODES_AND_EDGES' | 'PREFER_EDGES' | 'PREFER_NODES'; }; darkMode?: boolean; htmlLabels?: boolean; /** * Specifies the font to be used in the rendered diagrams. * Can be any possible CSS `font-family`. * See https://developer.mozilla.org/en-US/docs/Web/CSS/font-family * */ fontFamily?: string; altFontFamily?: string; /** * This option decides the amount of logging to be used by mermaid. * */ logLevel?: 'trace' | 0 | 'debug' | 1 | 'info' | 2 | 'warn' | 3 | 'error' | 4 | 'fatal' | 5; /** * Level of trust for parsed diagram */ securityLevel?: 'strict' | 'loose' | 'antiscript' | 'sandbox'; /** * Dictates whether mermaid starts on Page load */ startOnLoad?: boolean; /** * Controls whether or arrow markers in html code are absolute paths or anchors. * This matters if you are using base tag settings. * */ arrowMarkerAbsolute?: boolean; /** * This option controls which `currentConfig` keys are considered secure and * can only be changed via call to `mermaid.initialize`. * This prevents malicious graph directives from overriding a site's default security. * */ secure?: string[]; /** * This option specifies if Mermaid can expect the dependent to include KaTeX stylesheets for browsers * without their own MathML implementation. If this option is disabled and MathML is not supported, the math * equations are replaced with a warning. If this option is enabled and MathML is not supported, Mermaid will * fall back to legacy rendering for KaTeX. * */ legacyMathML?: boolean; /** * This option forces Mermaid to rely on KaTeX's own stylesheet for rendering MathML. Due to differences between OS * fonts and browser's MathML implementation, this option is recommended if consistent rendering is important. * If set to true, ignores legacyMathML. * */ forceLegacyMathML?: boolean; /** * This option controls if the generated ids of nodes in the SVG are * generated randomly or based on a seed. * If set to `false`, the IDs are generated based on the current date and * thus are not deterministic. This is the default behavior. * * This matters if your files are checked into source control e.g. git and * should not change unless content is changed. * */ deterministicIds?: boolean; /** * This option is the optional seed for deterministic ids. * If set to `undefined` but deterministicIds is `true`, a simple number iterator is used. * You can set this attribute to base the seed on a static string. * */ deterministicIDSeed?: string; flowchart?: FlowchartDiagramConfig; sequence?: SequenceDiagramConfig; gantt?: GanttDiagramConfig; journey?: JourneyDiagramConfig; timeline?: TimelineDiagramConfig; class?: ClassDiagramConfig; state?: StateDiagramConfig; er?: ErDiagramConfig; pie?: PieDiagramConfig; quadrantChart?: QuadrantChartConfig; xyChart?: XYChartConfig; requirement?: RequirementDiagramConfig; architecture?: ArchitectureDiagramConfig; mindmap?: MindmapDiagramConfig; kanban?: KanbanDiagramConfig; gitGraph?: GitGraphDiagramConfig; c4?: C4DiagramConfig; sankey?: SankeyDiagramConfig; packet?: PacketDiagramConfig; block?: BlockDiagramConfig; radar?: RadarDiagramConfig; dompurifyConfig?: DOMPurifyConfiguration; wrap?: boolean; fontSize?: number; markdownAutoWrap?: boolean; /** * Suppresses inserting 'Syntax error' diagram in the DOM. * This is useful when you want to control how to handle syntax errors in your application. * */ suppressErrorRendering?: boolean; } /** * The object containing configurations specific for flowcharts * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "FlowchartDiagramConfig". */ export interface FlowchartDiagramConfig extends BaseDiagramConfig { /** * Margin top for the text over the diagram */ titleTopMargin?: number; /** * Defines a top/bottom margin for subgraph titles * */ subGraphTitleMargin?: { top?: number; bottom?: number; }; arrowMarkerAbsolute?: boolean; /** * The amount of padding around the diagram as a whole so that embedded * diagrams have margins, expressed in pixels. * */ diagramPadding?: number; /** * Flag for setting whether or not a html tag should be used for rendering labels on the edges. * */ htmlLabels?: boolean; /** * Defines the spacing between nodes on the same level * * Pertains to horizontal spacing for TB (top to bottom) or BT (bottom to top) graphs, * and the vertical spacing for LR as well as RL graphs. * */ nodeSpacing?: number; /** * Defines the spacing between nodes on different levels * * Pertains to horizontal spacing for TB (top to bottom) or BT (bottom to top) graphs, * and the vertical spacing for LR as well as RL graphs. * */ rankSpacing?: number; /** * Defines how mermaid renders curves for flowcharts. * */ curve?: 'basis' | 'bumpX' | 'bumpY' | 'cardinal' | 'catmullRom' | 'linear' | 'monotoneX' | 'monotoneY' | 'natural' | 'step' | 'stepAfter' | 'stepBefore'; /** * Represents the padding between the labels and the shape * * **Only used in new experimental rendering.** * */ padding?: number; /** * Decides which rendering engine that is to be used for the rendering. * */ defaultRenderer?: 'dagre-d3' | 'dagre-wrapper' | 'elk'; /** * Width of nodes where text is wrapped. * * When using markdown strings the text is wrapped automatically, this * value sets the max width of a text before it continues on a new line. * */ wrappingWidth?: number; /** * If true, subgraphs without explicit direction will inherit the global graph direction * (e.g., LR, TB, RL, BT). Defaults to false to preserve legacy layout behavior. * */ inheritDir?: boolean; } /** * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "BaseDiagramConfig". */ export interface BaseDiagramConfig { useWidth?: number; /** * When this flag is set to `true`, the height and width is set to 100% * and is then scaled with the available space. * If set to `false`, the absolute space required is used. * */ useMaxWidth?: boolean; } /** * The object containing configurations specific for sequence diagrams * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "SequenceDiagramConfig". */ export interface SequenceDiagramConfig extends BaseDiagramConfig { arrowMarkerAbsolute?: boolean; hideUnusedParticipants?: boolean; /** * Width of the activation rect */ activationWidth?: number; /** * Margin to the right and left of the sequence diagram */ diagramMarginX?: number; /** * Margin to the over and under the sequence diagram */ diagramMarginY?: number; /** * Margin between actors */ actorMargin?: number; /** * Width of actor boxes */ width?: number; /** * Height of actor boxes */ height?: number; /** * Margin around loop boxes */ boxMargin?: number; /** * Margin around the text in loop/alt/opt boxes */ boxTextMargin?: number; /** * Margin around notes */ noteMargin?: number; /** * Space between messages. */ messageMargin?: number; /** * Multiline message alignment */ messageAlign?: 'left' | 'center' | 'right'; /** * Mirror actors under diagram * */ mirrorActors?: boolean; /** * forces actor popup menus to always be visible (to support E2E testing). * */ forceMenus?: boolean; /** * Prolongs the edge of the diagram downwards. * * Depending on css styling this might need adjustment. * */ bottomMarginAdj?: number; /** * Curved Arrows become Right Angles * * This will display arrows that start and begin at the same node as * right angles, rather than as curves. * */ rightAngles?: boolean; /** * This will show the node numbers */ showSequenceNumbers?: boolean; /** * This sets the font size of the actor's description */ actorFontSize?: string | number; /** * This sets the font family of the actor's description */ actorFontFamily?: string; /** * This sets the font weight of the actor's description */ actorFontWeight?: string | number; /** * This sets the font size of actor-attached notes */ noteFontSize?: string | number; /** * This sets the font family of actor-attached notes */ noteFontFamily?: string; /** * This sets the font weight of actor-attached notes */ noteFontWeight?: string | number; /** * This sets the text alignment of actor-attached notes */ noteAlign?: 'left' | 'center' | 'right'; /** * This sets the font size of actor messages */ messageFontSize?: string | number; /** * This sets the font family of actor messages */ messageFontFamily?: string; /** * This sets the font weight of actor messages */ messageFontWeight?: string | number; /** * This sets the auto-wrap state for the diagram */ wrap?: boolean; /** * This sets the auto-wrap padding for the diagram (sides only) */ wrapPadding?: number; /** * This sets the width of the loop-box (loop, alt, opt, par) */ labelBoxWidth?: number; /** * This sets the height of the loop-box (loop, alt, opt, par) */ labelBoxHeight?: number; messageFont?: FontCalculator; noteFont?: FontCalculator; actorFont?: FontCalculator; } /** * The object containing configurations specific for gantt diagrams * * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "GanttDiagramConfig". */ export interface GanttDiagramConfig extends BaseDiagramConfig { /** * Margin top for the text over the diagram */ titleTopMargin?: number; /** * The height of the bars in the graph */ barHeight?: number; /** * The margin between the different activities in the gantt diagram */ barGap?: number; /** * Margin between title and gantt diagram and between axis and gantt diagram. * */ topPadding?: number; /** * The space allocated for the section name to the right of the activities * */ rightPadding?: number; /** * The space allocated for the section name to the left of the activities * */ leftPadding?: number; /** * Vertical starting position of the grid lines */ gridLineStartPadding?: number; /** * Font size */ fontSize?: number; /** * Font size for sections */ sectionFontSize?: string | number; /** * The number of alternating section styles */ numberSectionStyles?: number; /** * Date/time format of the axis * * This might need adjustment to match your locale and preferences. * */ axisFormat?: string; /** * axis ticks * * Pattern is: * * ```javascript * /^([1-9][0-9]*)(millisecond|second|minute|hour|day|week|month)$/ * ``` * */ tickInterval?: string; /** * When this flag is set, date labels will be added to the top of the chart * */ topAxis?: boolean; /** * Controls the display mode. * */ displayMode?: '' | 'compact'; /** * On which day a week-based interval should start * */ weekday?: 'monday' | 'tuesday' | 'wednesday' | 'thursday' | 'friday' | 'saturday' | 'sunday'; } /** * The object containing configurations specific for journey diagrams * * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "JourneyDiagramConfig". */ export interface JourneyDiagramConfig extends BaseDiagramConfig { /** * Margin to the right and left of the c4 diagram, must be a positive value. * */ diagramMarginX?: number; /** * Margin to the over and under the c4 diagram, must be a positive value. * */ diagramMarginY?: number; /** * Margin between actors */ leftMargin?: number; /** * Maximum width of actor labels */ maxLabelWidth?: number; /** * Width of actor boxes */ width?: number; /** * Height of actor boxes */ height?: number; /** * Margin around loop boxes */ boxMargin?: number; /** * Margin around the text in loop/alt/opt boxes */ boxTextMargin?: number; /** * Margin around notes */ noteMargin?: number; /** * Space between messages. */ messageMargin?: number; /** * Multiline message alignment */ messageAlign?: 'left' | 'center' | 'right'; /** * Prolongs the edge of the diagram downwards. * * Depending on css styling this might need adjustment. * */ bottomMarginAdj?: number; /** * Curved Arrows become Right Angles * * This will display arrows that start and begin at the same node as * right angles, rather than as curves. * */ rightAngles?: boolean; taskFontSize?: string | number; taskFontFamily?: string; taskMargin?: number; /** * Width of activation box */ activationWidth?: number; /** * text placement as: tspan | fo | old only text as before * */ textPlacement?: string; actorColours?: string[]; sectionFills?: string[]; sectionColours?: string[]; /** * Color of the title text in Journey Diagrams */ titleColor?: string; /** * Font family to be used for the title text in Journey Diagrams */ titleFontFamily?: string; /** * Font size to be used for the title text in Journey Diagrams */ titleFontSize?: string; } /** * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "TimelineDiagramConfig". */ export interface TimelineDiagramConfig extends BaseDiagramConfig { /** * Margin to the right and left of the c4 diagram, must be a positive value. * */ diagramMarginX?: number; /** * Margin to the over and under the c4 diagram, must be a positive value. * */ diagramMarginY?: number; /** * Margin between actors */ leftMargin?: number; /** * Width of actor boxes */ width?: number; /** * Height of actor boxes */ height?: number; padding?: number; /** * Margin around loop boxes */ boxMargin?: number; /** * Margin around the text in loop/alt/opt boxes */ boxTextMargin?: number; /** * Margin around notes */ noteMargin?: number; /** * Space between messages. */ messageMargin?: number; /** * Multiline message alignment */ messageAlign?: 'left' | 'center' | 'right'; /** * Prolongs the edge of the diagram downwards. * * Depending on css styling this might need adjustment. * */ bottomMarginAdj?: number; /** * Curved Arrows become Right Angles * * This will display arrows that start and begin at the same node as * right angles, rather than as curves. * */ rightAngles?: boolean; taskFontSize?: string | number; taskFontFamily?: string; taskMargin?: number; /** * Width of activation box */ activationWidth?: number; /** * text placement as: tspan | fo | old only text as before * */ textPlacement?: string; actorColours?: string[]; sectionFills?: string[]; sectionColours?: string[]; disableMulticolor?: boolean; } /** * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "ClassDiagramConfig". */ export interface ClassDiagramConfig extends BaseDiagramConfig { /** * Margin top for the text over the diagram */ titleTopMargin?: number; /** * Controls whether or arrow markers in html code are absolute paths or anchors. * This matters if you are using base tag settings. * */ arrowMarkerAbsolute?: boolean; dividerMargin?: number; padding?: number; textHeight?: number; /** * Decides which rendering engine that is to be used for the rendering. * */ defaultRenderer?: 'dagre-d3' | 'dagre-wrapper' | 'elk'; nodeSpacing?: number; rankSpacing?: number; /** * The amount of padding around the diagram as a whole so that embedded * diagrams have margins, expressed in pixels. * */ diagramPadding?: number; htmlLabels?: boolean; hideEmptyMembersBox?: boolean; } /** * The object containing configurations specific for entity relationship diagrams * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "StateDiagramConfig". */ export interface StateDiagramConfig extends BaseDiagramConfig { /** * Margin top for the text over the diagram */ titleTopMargin?: number; arrowMarkerAbsolute?: boolean; dividerMargin?: number; sizeUnit?: number; padding?: number; textHeight?: number; titleShift?: number; noteMargin?: number; nodeSpacing?: number; rankSpacing?: number; forkWidth?: number; forkHeight?: number; miniPadding?: number; /** * Font size factor, this is used to guess the width of the edges labels * before rendering by dagre layout. * This might need updating if/when switching font * */ fontSizeFactor?: number; fontSize?: number; labelHeight?: number; edgeLengthFactor?: string; compositTitleSize?: number; radius?: number; /** * Decides which rendering engine that is to be used for the rendering. * */ defaultRenderer?: 'dagre-d3' | 'dagre-wrapper' | 'elk'; } /** * The object containing configurations specific for entity relationship diagrams * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "ErDiagramConfig". */ export interface ErDiagramConfig extends BaseDiagramConfig { /** * Margin top for the text over the diagram */ titleTopMargin?: number; /** * The amount of padding around the diagram as a whole so that embedded * diagrams have margins, expressed in pixels. * */ diagramPadding?: number; /** * Directional bias for layout of entities */ layoutDirection?: 'TB' | 'BT' | 'LR' | 'RL'; /** * The minimum width of an entity box. Expressed in pixels. */ minEntityWidth?: number; /** * The minimum height of an entity box. Expressed in pixels. */ minEntityHeight?: number; /** * The minimum internal padding between text in an entity box and the enclosing box borders. * Expressed in pixels. * */ entityPadding?: number; nodeSpacing?: number; rankSpacing?: number; /** * Stroke color of box edges and lines. */ stroke?: string; /** * Fill color of entity boxes */ fill?: string; /** * Font size (expressed as an integer representing a number of pixels) */ fontSize?: number; } /** * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "PieDiagramConfig". */ export interface PieDiagramConfig extends BaseDiagramConfig { /** * Axial position of slice's label from zero at the center to 1 at the outside edges. * */ textPosition?: number; } /** * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "QuadrantChartConfig". */ export interface QuadrantChartConfig extends BaseDiagramConfig { /** * Width of the chart */ chartWidth?: number; /** * Height of the chart */ chartHeight?: number; /** * Chart title top and bottom padding */ titleFontSize?: number; /** * Padding around the quadrant square */ titlePadding?: number; /** * quadrant title padding from top if the quadrant is rendered on top */ quadrantPadding?: number; /** * Padding around x-axis labels */ xAxisLabelPadding?: number; /** * Padding around y-axis labels */ yAxisLabelPadding?: number; /** * x-axis label font size */ xAxisLabelFontSize?: number; /** * y-axis label font size */ yAxisLabelFontSize?: number; /** * quadrant title font size */ quadrantLabelFontSize?: number; /** * quadrant title padding from top if the quadrant is rendered on top */ quadrantTextTopPadding?: number; /** * padding between point and point label */ pointTextPadding?: number; /** * point title font size */ pointLabelFontSize?: number; /** * radius of the point to be drawn */ pointRadius?: number; /** * position of x-axis labels */ xAxisPosition?: 'top' | 'bottom'; /** * position of y-axis labels */ yAxisPosition?: 'left' | 'right'; /** * stroke width of edges of the box that are inside the quadrant */ quadrantInternalBorderStrokeWidth?: number; /** * stroke width of edges of the box that are outside the quadrant */ quadrantExternalBorderStrokeWidth?: number; } /** * This object contains configuration specific to XYCharts * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "XYChartConfig". */ export interface XYChartConfig extends BaseDiagramConfig { /** * width of the chart */ width?: number; /** * height of the chart */ height?: number; /** * Font size of the chart title */ titleFontSize?: number; /** * Top and bottom space from the chart title */ titlePadding?: number; /** * Should show the value corresponding to the bar within the bar */ showDataLabel?: boolean; /** * Should show the chart title */ showTitle?: boolean; xAxis?: XYChartAxisConfig; yAxis?: XYChartAxisConfig; /** * How to plot will be drawn horizontal or vertical */ chartOrientation?: 'vertical' | 'horizontal'; /** * Minimum percent of space plots of the chart will take */ plotReservedSpacePercent?: number; } /** * This object contains configuration for XYChart axis config * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "XYChartAxisConfig". */ export interface XYChartAxisConfig { /** * Should show the axis labels (tick text) */ showLabel?: boolean; /** * font size of the axis labels (tick text) */ labelFontSize?: number; /** * top and bottom space from axis label (tick text) */ labelPadding?: number; /** * Should show the axis title */ showTitle?: boolean; /** * font size of the axis title */ titleFontSize?: number; /** * top and bottom space from axis title */ titlePadding?: number; /** * Should show the axis tick lines */ showTick?: boolean; /** * length of the axis tick lines */ tickLength?: number; /** * width of the axis tick lines */ tickWidth?: number; /** * Show line across the axis */ showAxisLine?: boolean; /** * Width of the axis line */ axisLineWidth?: number; } /** * The object containing configurations specific for req diagrams * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "RequirementDiagramConfig". */ export interface RequirementDiagramConfig extends BaseDiagramConfig { rect_fill?: string; text_color?: string; rect_border_size?: string; rect_border_color?: string; rect_min_width?: number; rect_min_height?: number; fontSize?: number; rect_padding?: number; line_height?: number; } /** * The object containing configurations specific for architecture diagrams * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "ArchitectureDiagramConfig". */ export interface ArchitectureDiagramConfig extends BaseDiagramConfig { padding?: number; iconSize?: number; fontSize?: number; } /** * The object containing configurations specific for mindmap diagrams * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "MindmapDiagramConfig". */ export interface MindmapDiagramConfig extends BaseDiagramConfig { padding?: number; maxNodeWidth?: number; } /** * The object containing configurations specific for kanban diagrams * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "KanbanDiagramConfig". */ export interface KanbanDiagramConfig extends BaseDiagramConfig { padding?: number; sectionWidth?: number; ticketBaseUrl?: string; } /** * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "GitGraphDiagramConfig". */ export interface GitGraphDiagramConfig extends BaseDiagramConfig { /** * Margin top for the text over the diagram */ titleTopMargin?: number; diagramPadding?: number; nodeLabel?: NodeLabel; mainBranchName?: string; mainBranchOrder?: number; showCommitLabel?: boolean; showBranches?: boolean; rotateCommitLabel?: boolean; parallelCommits?: boolean; /** * Controls whether or arrow markers in html code are absolute paths or anchors. * This matters if you are using base tag settings. * */ arrowMarkerAbsolute?: boolean; } /** * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "NodeLabel". */ export interface NodeLabel { width?: number; height?: number; x?: number; y?: number; } /** * The object containing configurations specific for c4 diagrams * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "C4DiagramConfig". */ export interface C4DiagramConfig extends BaseDiagramConfig { /** * Margin to the right and left of the c4 diagram, must be a positive value. * */ diagramMarginX?: number; /** * Margin to the over and under the c4 diagram, must be a positive value. * */ diagramMarginY?: number; /** * Margin between shapes */ c4ShapeMargin?: number; /** * Padding between shapes */ c4ShapePadding?: number; /** * Width of person boxes */ width?: number; /** * Height of person boxes */ height?: number; /** * Margin around boxes */ boxMargin?: number; /** * How many shapes to place in each row. */ c4ShapeInRow?: number; nextLinePaddingX?: number; /** * How many boundaries to place in each row. */ c4BoundaryInRow?: number; /** * This sets the font size of Person shape for the diagram */ personFontSize?: string | number; /** * This sets the font weight of Person shape for the diagram */ personFontFamily?: string; /** * This sets the font weight of Person shape for the diagram */ personFontWeight?: string | number; /** * This sets the font size of External Person shape for the diagram */ external_personFontSize?: string | number; /** * This sets the font family of External Person shape for the diagram */ external_personFontFamily?: string; /** * This sets the font weight of External Person shape for the diagram */ external_personFontWeight?: string | number; /** * This sets the font size of System shape for the diagram */ systemFontSize?: string | number; /** * This sets the font family of System shape for the diagram */ systemFontFamily?: string; /** * This sets the font weight of System shape for the diagram */ systemFontWeight?: string | number; /** * This sets the font size of External System shape for the diagram */ external_systemFontSize?: string | number; /** * This sets the font family of External System shape for the diagram */ external_systemFontFamily?: string; /** * This sets the font weight of External System shape for the diagram */ external_systemFontWeight?: string | number; /** * This sets the font size of System DB shape for the diagram */ system_dbFontSize?: string | number; /** * This sets the font family of System DB shape for the diagram */ system_dbFontFamily?: string; /** * This sets the font weight of System DB shape for the diagram */ system_dbFontWeight?: string | number; /** * This sets the font size of External System DB shape for the diagram */ external_system_dbFontSize?: string | number; /** * This sets the font family of External System DB shape for the diagram */ external_system_dbFontFamily?: string; /** * This sets the font weight of External System DB shape for the diagram */ external_system_dbFontWeight?: string | number; /** * This sets the font size of System Queue shape for the diagram */ system_queueFontSize?: string | number; /** * This sets the font family of System Queue shape for the diagram */ system_queueFontFamily?: string; /** * This sets the font weight of System Queue shape for the diagram */ system_queueFontWeight?: string | number; /** * This sets the font size of External System Queue shape for the diagram */ external_system_queueFontSize?: string | number; /** * This sets the font family of External System Queue shape for the diagram */ external_system_queueFontFamily?: string; /** * This sets the font weight of External System Queue shape for the diagram */ external_system_queueFontWeight?: string | number; /** * This sets the font size of Boundary shape for the diagram */ boundaryFontSize?: string | number; /** * This sets the font family of Boundary shape for the diagram */ boundaryFontFamily?: string; /** * This sets the font weight of Boundary shape for the diagram */ boundaryFontWeight?: string | number; /** * This sets the font size of Message shape for the diagram */ messageFontSize?: string | number; /** * This sets the font family of Message shape for the diagram */ messageFontFamily?: string; /** * This sets the font weight of Message shape for the diagram */ messageFontWeight?: string | number; /** * This sets the font size of Container shape for the diagram */ containerFontSize?: string | number; /** * This sets the font family of Container shape for the diagram */ containerFontFamily?: string; /** * This sets the font weight of Container shape for the diagram */ containerFontWeight?: string | number; /** * This sets the font size of External Container shape for the diagram */ external_containerFontSize?: string | number; /** * This sets the font family of External Container shape for the diagram */ external_containerFontFamily?: string; /** * This sets the font weight of External Container shape for the diagram */ external_containerFontWeight?: string | number; /** * This sets the font size of Container DB shape for the diagram */ container_dbFontSize?: string | number; /** * This sets the font family of Container DB shape for the diagram */ container_dbFontFamily?: string; /** * This sets the font weight of Container DB shape for the diagram */ container_dbFontWeight?: string | number; /** * This sets the font size of External Container DB shape for the diagram */ external_container_dbFontSize?: string | number; /** * This sets the font family of External Container DB shape for the diagram */ external_container_dbFontFamily?: string; /** * This sets the font weight of External Container DB shape for the diagram */ external_container_dbFontWeight?: string | number; /** * This sets the font size of Container Queue shape for the diagram */ container_queueFontSize?: string | number; /** * This sets the font family of Container Queue shape for the diagram */ container_queueFontFamily?: string; /** * This sets the font weight of Container Queue shape for the diagram */ container_queueFontWeight?: string | number; /** * This sets the font size of External Container Queue shape for the diagram */ external_container_queueFontSize?: string | number; /** * This sets the font family of External Container Queue shape for the diagram */ external_container_queueFontFamily?: string; /** * This sets the font weight of External Container Queue shape for the diagram */ external_container_queueFontWeight?: string | number; /** * This sets the font size of Component shape for the diagram */ componentFontSize?: string | number; /** * This sets the font family of Component shape for the diagram */ componentFontFamily?: string; /** * This sets the font weight of Component shape for the diagram */ componentFontWeight?: string | number; /** * This sets the font size of External Component shape for the diagram */ external_componentFontSize?: string | number; /** * This sets the font family of External Component shape for the diagram */ external_componentFontFamily?: string; /** * This sets the font weight of External Component shape for the diagram */ external_componentFontWeight?: string | number; /** * This sets the font size of Component DB shape for the diagram */ component_dbFontSize?: string | number; /** * This sets the font family of Component DB shape for the diagram */ component_dbFontFamily?: string; /** * This sets the font weight of Component DB shape for the diagram */ component_dbFontWeight?: string | number; /** * This sets the font size of External Component DB shape for the diagram */ external_component_dbFontSize?: string | number; /** * This sets the font family of External Component DB shape for the diagram */ external_component_dbFontFamily?: string; /** * This sets the font weight of External Component DB shape for the diagram */ external_component_dbFontWeight?: string | number; /** * This sets the font size of Component Queue shape for the diagram */ component_queueFontSize?: string | number; /** * This sets the font family of Component Queue shape for the diagram */ component_queueFontFamily?: string; /** * This sets the font weight of Component Queue shape for the diagram */ component_queueFontWeight?: string | number; /** * This sets the font size of External Component Queue shape for the diagram */ external_component_queueFontSize?: string | number; /** * This sets the font family of External Component Queue shape for the diagram */ external_component_queueFontFamily?: string; /** * This sets the font weight of External Component Queue shape for the diagram */ external_component_queueFontWeight?: string | number; /** * This sets the auto-wrap state for the diagram */ wrap?: boolean; /** * This sets the auto-wrap padding for the diagram (sides only) */ wrapPadding?: number; person_bg_color?: string; person_border_color?: string; external_person_bg_color?: string; external_person_border_color?: string; system_bg_color?: string; system_border_color?: string; system_db_bg_color?: string; system_db_border_color?: string; system_queue_bg_color?: string; system_queue_border_color?: string; external_system_bg_color?: string; external_system_border_color?: string; external_system_db_bg_color?: string; external_system_db_border_color?: string; external_system_queue_bg_color?: string; external_system_queue_border_color?: string; container_bg_color?: string; container_border_color?: string; container_db_bg_color?: string; container_db_border_color?: string; container_queue_bg_color?: string; container_queue_border_color?: string; external_container_bg_color?: string; external_container_border_color?: string; external_container_db_bg_color?: string; external_container_db_border_color?: string; external_container_queue_bg_color?: string; external_container_queue_border_color?: string; component_bg_color?: string; component_border_color?: string; component_db_bg_color?: string; component_db_border_color?: string; component_queue_bg_color?: string; component_queue_border_color?: string; external_component_bg_color?: string; external_component_border_color?: string; external_component_db_bg_color?: string; external_component_db_border_color?: string; external_component_queue_bg_color?: string; external_component_queue_border_color?: string; personFont?: FontCalculator; external_personFont?: FontCalculator; systemFont?: FontCalculator; external_systemFont?: FontCalculator; system_dbFont?: FontCalculator; external_system_dbFont?: FontCalculator; system_queueFont?: FontCalculator; external_system_queueFont?: FontCalculator; containerFont?: FontCalculator; external_containerFont?: FontCalculator; container_dbFont?: FontCalculator; external_container_dbFont?: FontCalculator; container_queueFont?: FontCalculator; external_container_queueFont?: FontCalculator; componentFont?: FontCalculator; external_componentFont?: FontCalculator; component_dbFont?: FontCalculator; external_component_dbFont?: FontCalculator; component_queueFont?: FontCalculator; external_component_queueFont?: FontCalculator; boundaryFont?: FontCalculator; messageFont?: FontCalculator; } /** * The object containing configurations specific for sankey diagrams. * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "SankeyDiagramConfig". */ export interface SankeyDiagramConfig extends BaseDiagramConfig { width?: number; height?: number; /** * The color of the links in the sankey diagram. * */ linkColor?: SankeyLinkColor | string; nodeAlignment?: SankeyNodeAlignment; useMaxWidth?: boolean; /** * Toggle to display or hide values along with title. * */ showValues?: boolean; /** * The prefix to use for values * */ prefix?: string; /** * The suffix to use for values * */ suffix?: string; } /** * The object containing configurations specific for packet diagrams. * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "PacketDiagramConfig". */ export interface PacketDiagramConfig extends BaseDiagramConfig { /** * The height of each row in the packet diagram. */ rowHeight?: number; /** * The width of each bit in the packet diagram. */ bitWidth?: number; /** * The number of bits to display per row. */ bitsPerRow?: number; /** * Toggle to display or hide bit numbers. */ showBits?: boolean; /** * The horizontal padding between the blocks in a row. */ paddingX?: number; /** * The vertical padding between the rows. */ paddingY?: number; } /** * The object containing configurations specific for block diagrams. * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "BlockDiagramConfig". */ export interface BlockDiagramConfig extends BaseDiagramConfig { padding?: number; } /** * The object containing configurations specific for radar diagrams. * * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "RadarDiagramConfig". */ export interface RadarDiagramConfig extends BaseDiagramConfig { /** * The size of the radar diagram. */ width?: number; /** * The size of the radar diagram. */ height?: number; /** * The margin from the top of the radar diagram. */ marginTop?: number; /** * The margin from the right of the radar diagram. */ marginRight?: number; /** * The margin from the bottom of the radar diagram. */ marginBottom?: number; /** * The margin from the left of the radar diagram. */ marginLeft?: number; /** * The scale factor of the axis. */ axisScaleFactor?: number; /** * The scale factor of the axis label. */ axisLabelFactor?: number; /** * The tension factor for the Catmull-Rom spline conversion to cubic Bézier curves. */ curveTension?: number; } /** * This interface was referenced by `MermaidConfig`'s JSON-Schema * via the `definition` "FontConfig". */ export interface FontConfig { fontSize?: CSSFontSize; /** * The CSS [`font-family`](https://developer.mozilla.org/en-US/docs/Web/CSS/font-family) to use. */ fontFamily?: string; /** * The font weight to use. */ fontWeight?: string | number; }