import React, { CSSProperties, MouseEvent as ReactMouseEvent, HTMLAttributes, ReactNode } from 'react'; import { Selection as D3Selection, ZoomBehavior } from 'd3'; export type ElementId = string; export type FlowElement = Node | Edge; export type Elements = Array>; export type Transform = [number, number, number]; export declare enum Position { Left = "left", Top = "top", Right = "right", Bottom = "bottom" } export interface XYPosition { x: number; y: number; } export interface Dimensions { width: number; height: number; } export interface Rect extends Dimensions, XYPosition { } export interface Box extends XYPosition { x2: number; y2: number; } export type SnapGrid = [number, number]; export interface Node { id: ElementId; position: XYPosition; type?: string; __rf?: any; data?: T; style?: CSSProperties; className?: string; targetPosition?: Position; sourcePosition?: Position; isHidden?: boolean; draggable?: boolean; selectable?: boolean; connectable?: boolean; dragHandle?: string; } export declare enum ArrowHeadType { Arrow = "arrow", ArrowClosed = "arrowclosed" } export interface Edge { id: ElementId; type?: string; source: ElementId; target: ElementId; sourceHandle?: ElementId | null; targetHandle?: ElementId | null; label?: string | ReactNode; labelStyle?: CSSProperties; labelShowBg?: boolean; labelBgStyle?: CSSProperties; labelBgPadding?: [number, number]; labelBgBorderRadius?: number; style?: CSSProperties; animated?: boolean; arrowHeadType?: ArrowHeadType; isHidden?: boolean; data?: T; className?: string; } export declare enum BackgroundVariant { Lines = "lines", Dots = "dots" } export type HandleType = 'source' | 'target'; export type NodeTypesType = { [key: string]: ReactNode; }; export type EdgeTypesType = NodeTypesType; export interface SelectionRect extends Rect { startX: number; startY: number; draw: boolean; } export interface WrapEdgeProps { id: ElementId; className?: string; type: string; data?: T; onClick?: (event: React.MouseEvent, edge: Edge) => void; onEdgeDoubleClick?: (event: React.MouseEvent, edge: Edge) => void; selected: boolean; animated?: boolean; label?: string | ReactNode; labelStyle?: CSSProperties; labelShowBg?: boolean; labelBgStyle?: CSSProperties; labelBgPadding?: [number, number]; labelBgBorderRadius?: number; style?: CSSProperties; arrowHeadType?: ArrowHeadType; source: ElementId; target: ElementId; sourceHandleId: ElementId | null; targetHandleId: ElementId | null; sourceX: number; sourceY: number; targetX: number; targetY: number; sourcePosition: Position; targetPosition: Position; elementsSelectable?: boolean; markerEndId?: string; isHidden?: boolean; handleEdgeUpdate: boolean; onConnectEdge: OnConnectFunc; onContextMenu?: (event: React.MouseEvent, edge: Edge) => void; onMouseEnter?: (event: React.MouseEvent, edge: Edge) => void; onMouseMove?: (event: React.MouseEvent, edge: Edge) => void; onMouseLeave?: (event: React.MouseEvent, edge: Edge) => void; edgeUpdaterRadius?: number; onEdgeUpdateStart?: (event: React.MouseEvent, edge: Edge) => void; onEdgeUpdateEnd?: (event: MouseEvent, edge: Edge) => void; } export interface EdgeProps { id: ElementId; source: ElementId; target: ElementId; sourceX: number; sourceY: number; targetX: number; targetY: number; selected?: boolean; animated?: boolean; sourcePosition: Position; targetPosition: Position; label?: string | ReactNode; labelStyle?: CSSProperties; labelShowBg?: boolean; labelBgStyle?: CSSProperties; labelBgPadding?: [number, number]; labelBgBorderRadius?: number; style?: CSSProperties; arrowHeadType?: ArrowHeadType; markerEndId?: string; data?: T; sourceHandleId?: ElementId | null; targetHandleId?: ElementId | null; } export interface EdgeSmoothStepProps extends EdgeProps { borderRadius?: number; } export interface EdgeTextProps extends HTMLAttributes { x: number; y: number; label?: string | ReactNode; labelStyle?: CSSProperties; labelShowBg?: boolean; labelBgStyle?: CSSProperties; labelBgPadding?: [number, number]; labelBgBorderRadius?: number; } export interface NodeProps { id: ElementId; type: string; data: T; selected: boolean; isConnectable: boolean; xPos?: number; yPos?: number; targetPosition?: Position; sourcePosition?: Position; isDragging?: boolean; dragHandle?: string; } export interface NodeComponentProps { id: ElementId; type: string; data: T; selected?: boolean; isConnectable: boolean; transform?: Transform; xPos?: number; yPos?: number; targetPosition?: Position; sourcePosition?: Position; onClick?: (node: Node) => void; onNodeDoubleClick?: (node: Node) => void; onMouseEnter?: (node: Node) => void; onMouseMove?: (node: Node) => void; onMouseLeave?: (node: Node) => void; onContextMenu?: (node: Node) => void; onNodeDragStart?: (node: Node) => void; onNodeDrag?: (node: Node) => void; onNodeDragStop?: (node: Node) => void; style?: CSSProperties; isDragging?: boolean; dragHandle?: string; } export interface WrapNodeProps { id: ElementId; type: string; data: T; selected: boolean; scale: number; xPos: number; yPos: number; isSelectable: boolean; isDraggable: boolean; isConnectable: boolean; selectNodesOnDrag: boolean; onClick?: (event: ReactMouseEvent, node: Node) => void; onNodeDoubleClick?: (event: ReactMouseEvent, node: Node) => void; onMouseEnter?: (event: ReactMouseEvent, node: Node) => void; onMouseMove?: (event: ReactMouseEvent, node: Node) => void; onMouseLeave?: (event: ReactMouseEvent, node: Node) => void; onContextMenu?: (event: ReactMouseEvent, node: Node) => void; onNodeDragStart?: (event: ReactMouseEvent, node: Node) => void; onNodeDrag?: (event: ReactMouseEvent, node: Node) => void; onNodeDragStop?: (event: ReactMouseEvent, node: Node) => void; style?: CSSProperties; className?: string; sourcePosition?: Position; targetPosition?: Position; isHidden?: boolean; isInitialized?: boolean; snapToGrid?: boolean; snapGrid?: SnapGrid; isDragging?: boolean; resizeObserver: ResizeObserver | null; dragHandle?: string; } export type FitViewParams = { padding?: number; includeHiddenNodes?: boolean; minZoom?: number; maxZoom?: number; }; export type FlowExportObject = { elements: Elements; position: [number, number]; zoom: number; }; export type FitViewFunc = (fitViewOptions?: FitViewParams) => void; export type ProjectFunc = (position: XYPosition) => XYPosition; export type ToObjectFunc = () => FlowExportObject; export type OnLoadParams = { zoomIn: () => void; zoomOut: () => void; zoomTo: (zoomLevel: number) => void; fitView: FitViewFunc; project: ProjectFunc; getElements: () => Elements; setTransform: (transform: FlowTransform) => void; toObject: ToObjectFunc; }; export type OnLoadFunc = (params: OnLoadParams) => void; export interface Connection { source: ElementId | null; target: ElementId | null; sourceHandle: ElementId | null; targetHandle: ElementId | null; } export declare enum ConnectionMode { Strict = "strict", Loose = "loose" } export declare enum ConnectionLineType { Bezier = "default", Straight = "straight", Step = "step", SmoothStep = "smoothstep" } export type ConnectionLineComponentProps = { sourceX: number; sourceY: number; sourcePosition?: Position; targetX: number; targetY: number; targetPosition?: Position; connectionLineStyle?: CSSProperties; connectionLineType: ConnectionLineType; sourceNode?: Node; sourceHandle?: HandleElement; }; export type ConnectionLineComponent = React.ComponentType; export type OnConnectFunc = (connection: Connection) => void; export type OnConnectStartParams = { nodeId: ElementId | null; handleId: ElementId | null; handleType: HandleType | null; }; export type OnConnectStartFunc = (event: ReactMouseEvent, params: OnConnectStartParams) => void; export type OnConnectStopFunc = (event: MouseEvent) => void; export type OnConnectEndFunc = (event: MouseEvent) => void; export type SetConnectionId = { connectionNodeId: ElementId | null; connectionHandleId: ElementId | null; connectionHandleType: HandleType | null; }; export interface HandleElement extends XYPosition, Dimensions { id?: ElementId | null; position: Position; } export interface HandleProps { type: HandleType; position: Position; isConnectable?: boolean; onConnect?: OnConnectFunc; isValidConnection?: (connection: Connection) => boolean; id?: ElementId; } export type NodePosUpdate = { id: ElementId; pos: XYPosition; }; export type NodeDiffUpdate = { id?: ElementId; diff?: XYPosition; isDragging?: boolean; }; export type FlowTransform = { x: number; y: number; zoom: number; }; export type TranslateExtent = [[number, number], [number, number]]; export type NodeExtent = TranslateExtent; export type KeyCode = number | string; export declare enum PanOnScrollMode { Free = "free", Vertical = "vertical", Horizontal = "horizontal" } export interface ZoomPanHelperFunctions { zoomIn: () => void; zoomOut: () => void; zoomTo: (zoomLevel: number) => void; transform: (transform: FlowTransform) => void; fitView: FitViewFunc; setCenter: (x: number, y: number, zoom?: number) => void; fitBounds: (bounds: Rect, padding?: number) => void; project: (position: XYPosition) => XYPosition; initialized: boolean; } export type OnEdgeUpdateFunc = (oldEdge: Edge, newConnection: Connection) => void; export type NodeDimensionUpdate = { id: ElementId; nodeElement: HTMLDivElement; forceUpdate?: boolean; }; export type InitD3ZoomPayload = { d3Zoom: ZoomBehavior; d3Selection: D3Selection; d3ZoomHandler: ((this: Element, event: any, d: unknown) => void) | undefined; transform: Transform; }; export interface ReactFlowState { width: number; height: number; transform: Transform; nodes: Node[]; edges: Edge[]; selectedElements: Elements | null; selectedNodesBbox: Rect; d3Zoom: ZoomBehavior | null; d3Selection: D3Selection | null; d3ZoomHandler: ((this: Element, event: any, d: unknown) => void) | undefined; minZoom: number; maxZoom: number; translateExtent: TranslateExtent; nodeExtent: NodeExtent; nodesSelectionActive: boolean; selectionActive: boolean; userSelectionRect: SelectionRect; connectionNodeId: ElementId | null; connectionHandleId: ElementId | null; connectionHandleType: HandleType | null; connectionPosition: XYPosition; connectionMode: ConnectionMode; snapToGrid: boolean; snapGrid: SnapGrid; nodesDraggable: boolean; nodesConnectable: boolean; elementsSelectable: boolean; multiSelectionActive: boolean; reactFlowVersion: string; onConnect?: OnConnectFunc; onConnectStart?: OnConnectStartFunc; onConnectStop?: OnConnectStopFunc; onConnectEnd?: OnConnectEndFunc; } export type UpdateNodeInternals = (nodeId: ElementId) => void;