Config
Config API
Assume you are using the UMD bundle in the browser, here is an easy example of setting default renderer to CanvasRenderer by using setConfig
method.
pintora.default.setConfig({
core: {
defalutRenderer: 'canvas',
defaultFontFamily: 'Menlo',
},
sequence: {
messageFontSize: 16,
},
})
Or get current config by getConfig
:
pintora.default.getConfig()
Apply config to just one render
When using @pintora/standalone
in the browser, you can apply config to just one render. This will not change the globalConfig.
pintora.default.renderTo(code, {
container,
config: {
themeConfig: {
theme: 'dark',
}
}
})
Available configs
export type PintoraConfig = {
core: {
/** by default it's 'svg' */
defaultRenderer: string
defaultFontFamily: string
useMaxWidth: boolean
}
themeConfig: {
theme: string
darkTheme?: string
themeVariables: ITheme
}
component: ComponentConf
er: ErConf
sequence: SequenceConf
activity: ActivityConf
mindmap: MindmapConf
gantt: GanttConf
dot: DOTConf
class: ClassConf
}
Config for diagrams
Common Configs
There are some common diagram config keys those - if they appears in the *Conf
below - share common meaning and possible values.
name | value type | description |
---|---|---|
layoutDirection | 'TB' or 'LR' | A config for dagre-layout, stands for (top-bottom) or (left-right) |
diagramPadding | number | Padding of the diagram, distance from visual content to the border |
useMaxWidth | boolean | Whether the diagram should be resized to fit container width |
edgeType | EdgeType | Edge splines type |
EdgeType
polyline
, this is the default valueortho
, stands for orthogonal, edges are axis-aligned and bendings are right-angledcurved
, similar to 'polyline' control points, but draws curved line instead of straight one
Common Font Configs
/**
* Base font configuration that should be used by all diagrams
*/
export interface BaseFontConfig {
/** Font family, defaults to DEFAULT_FONT_FAMILY */
fontFamily: string
/** Font size in pixels, defaults to 14 */
fontSize: number
/** Font weight, defaults to 'normal' */
fontWeight: MarkAttrs['fontWeight']
/** Font style (normal, italic, oblique), defaults to 'normal' */
fontStyle: any
}
sequence
Config for sequence diagram. For more detail, check the latest code.
export type SequenceConf = BaseFontConfig & {
noteWidth: number
noteHeight: number
noteMargin: number
boxMargin: number
activationWidth: number
diagramMarginX: number
diagramMarginY: number
boxTextMargin: number
messageFontFamily: string
messageFontSize: number
messageFontWeight: MarkAttrs['fontWeight']
messageTextColor: string
/**
* font weight of box - such as loop and box
*/
boxFontWeight: MarkAttrs['fontWeight']
wrapPadding: number
labelBoxWidth: number
labelBoxHeight: number
/** color of loop box's border */
loopLineColor: string
/** if the actor should also appear in the bottom of the diagram, default is true */
mirrorActors: boolean
actorWidth: number
actorHeight: number
actorMargin: number
actorBackground: string
actorBorderColor: string
actorTextColor: string
actorLineColor: string
// for participant boxes
participantBoxPadding: number
participantBackground: string
participantBorderColor: string
noteTextColor: string
activationBackground: string
dividerFontWeight: MarkAttrs['fontWeight']
dividerTextColor: string
dividerMargin: number
showSequenceNumbers: boolean
useMaxWidth: boolean
}
er
Config for entity relationship diagram. For more detail, check the latest code.
export type ErConf = BaseFontConfig & {
diagramPadding: number
layoutDirection: string
ranksep: number
edgesep: number
edgeType: EdgeType
useMaxWidth: boolean
minEntityWidth: number
minEntityHeight: number
entityPaddingX: number
entityPaddingY: number
borderRadius: number
stroke: string
fill: string
edgeColor: string
attributeFill: string
textColor: string
labelBackground: string
}
component
Config for component diagram. For more detail, check the latest code.
export type ComponentConf = BaseFontConfig & {
diagramPadding: number
edgeType: EdgeType
edgesep: number
ranksep: number
componentPadding: number
componentBackground: string
componentBorderColor: string
groupBackground: string
groupBorderColor: string
groupBorderWidth: number
relationLineColor: string
textColor: string
lineWidth: number
labelBackground: string
interfaceSize: number
useMaxWidth: boolean
/**
* By default there is a label in bottom-left of group to show its type, set this to true make the label disappear
*/
hideGroupType: boolean
}
activity
export type ActivityConf = BaseFontConfig & {
diagramPadding: number
edgesep: number
edgeType: EdgeType
useMaxWidth: boolean
actionPaddingX: number
actionPaddingY: number
actionBackground: string
actionBorderColor: string
groupBackground: string
groupBorderColor: string
textColor: string
edgeColor: string
keywordBackground: string
noteTextColor: string
noteMargin: number
labelTextColor: string
labelBackground: string
}
mindmap
export type MindmapConf = BaseFontConfig & {
diagramPadding: number
layoutDirection: 'LR' | 'TB'
useMaxWidth: boolean
borderRadius: number
/** default node color */
nodeBgColor: string
nodePadding: number
/** font weight of node label */
nodeFontWeight: MarkAttrs['fontWeight']
textColor: string
edgeColor: string
maxFontSize: number
minFontSize: number
fontFamily: string
levelDistance: number
// node config for different levels
l1NodeBgColor: string
l1NodeTextColor: string
l2NodeBgColor: string
l2NodeTextColor: string
}
gantt
Config for gantt diagram. For more detail, check the latest code.
export type GanttConf = BaseFontConfig & {
barHeight: number
barGap: number
topPadding: number
sidePadding: number
gridLineStartPadding: number
numberSectionStyles: number
axisFormat: DateFormat
axisLabelFontSize: number
axisLabelColor: string
gridLineWidth: number
gridLineColor: string
markLineColor: string
barBackground: string
barBorderColor: string
barBorderRadius: number
sectionBackgrounds: Array<string | undefined>
sectionLabelColor: string
fontColor: string
}
dot
Config for DOT diagram. For more detail, check the latest code.
export type DOTConf = BaseFontConfig & {
diagramPadding: number
layoutDirection: string
ranksep: number
nodesep: number
edgesep: number
edgeType: EdgeType
nodePadding: number
nodeBorderRadius: number
backgroundColor: string
labelTextColor: string
nodeBorderColor: string
edgeColor: string
}
class
Config for class diagram. For more detail, check the latest code.
export type ClassConf = BaseFontConfig & {
diagramPadding: number
layoutDirection: string
ranksep: number
nodesep: number
edgesep: number
edgeType: EdgeType
entityBackground: string
entityBorderColor: string
entityBodyBackground: string
entityTextColor: string
labelBackground: string
relationLineColor: string
relationTextColor: string
entityRadius: number
}
Override config by directive
If you don't have the access to add JS script into the page or in the Node.js module, it's also possible to override some configs of the builtin diagrams through the @param
or @config
directive.
This is the recommended way to override configs inside the text DSL for all pintora's builtin diagrams. But it may be slightly different or not implemented at all in some third-party diagrams, due to syntax confilict or other diagram-parser implementation details.
The @param
directive
This directive overrides local config in current diagram.
Syntax:
@param prop value
%% --- or ---
@param {
prop value
}
For example:
sequenceDiagram @param loopLineColor #79caf1 @param actorBackground #61afef @param actorTextColor #ffffff @param { messageFontFamily Consolas dividerTextColor #61afef } User->>Pintora: render this activate Pintora loop Check input Pintora-->>Pintora: Has input changed? end
The @config
directive
Unlike the @param
directive, this directive:
- Overrides global config in this render.
- Config needs to be valid JSON string.
Syntax:
@config(...configJSON)
For example:
mindmap @config({ "core": { "defaultFontFamily": "serif", "useMaxWidth": true }, "themeConfig": { "theme": "larkDark" }, "mindmap": { "layoutDirection": "TB", "l1NodeBgColor": "#2B7A5D", "l1NodeTextColor": "#fff", "l2NodeBgColor": "#26946C", "l2NodeTextColor": "#fff", "nodeBgColor": "#67B599", "textColor": "#fff" } }) + UML Diagrams ++ Behavior Diagrams +++ Sequence Diagram +++ State Diagram +++ Activity Diagram ++ Structural Diagrams +++ Class Diagram +++ Component Diagram