import type { GraphLabel } from 'dagre'; import type { EdgeData, Expr, Size } from '../../types'; import type { EdgeLabelPos } from '../../types/edge-label'; import type { BaseLayoutOptions } from '../types'; /** * 边标签位置:'l' 左侧,'c' 中心,'r' 右侧 * * Edge label position: 'l' for left, 'c' for center, 'r' for right */ /** * Dagre 层次布局配置项,用于有向图的分层排列 * * Dagre hierarchical layout options for layered arrangement of directed graphs */ export interface DagreLayoutOptions extends BaseLayoutOptions, GraphLabel { /** * 控制边的方向性,true 表示边有方向(箭头),影响布局的层次关系 * * Controls edge directionality; true means edges have direction (arrows), affecting hierarchical relationships in layout * @defaultValue true */ directed?: boolean; /** * 支持嵌套结构,允许节点包含子图,用于复杂的层级关系 * * Supports nested structures where nodes can contain subgraphs for complex hierarchical relationships * @defaultValue true */ compound?: boolean; /** * 允许两节点间存在多条边,用于表示多重关系 * * Allows multiple edges between two nodes to represent multiple relationships * @defaultValue true */ multigraph?: boolean; /** * 设置边跨越的最小层数,值越大节点间距越远,用于控制布局紧凑度 * * Sets minimum number of layers an edge spans; larger values create more distance between nodes, controlling layout compactness * @defaultValue 1 */ edgeMinLen?: number | Expr | ((edge: EdgeData) => number); /** * 边的权重,影响边的长度优化优先级,权重大的边倾向于更短 * * Edge weight affecting length optimization priority; higher weight edges tend to be shorter */ edgeWeight?: number | Expr | ((edge: EdgeData) => number); /** * 边标签的尺寸,用于为标签预留空间,避免与节点重叠 * * Size of edge labels for reserving space to prevent overlap with nodes */ edgeLabelSize?: Size | Expr | ((edge: EdgeData) => Size); /** * 标签在边上的位置,控制标签相对于边的对齐方式 * * Label position on edge, controlling label alignment relative to the edge */ edgeLabelPos?: EdgeLabelPos | Expr | ((edge: EdgeData) => EdgeLabelPos); /** * 标签与边的偏移距离,用于微调标签位置避免视觉重叠 * * Offset distance between label and edge for fine-tuning label position to avoid visual overlap */ edgeLabelOffset?: number | Expr | ((edge: EdgeData) => number); }