Selector: [fNode]
The FNodeDirective is a directive that represents a node within a flow of elements. It is capable of interacting with other nodes and connectors, and can be dynamically positioned and styled.
fNodeId: string;
The unique identifier for the directive instance. Automatically generated. Default: f-node-${uniqueId++}
fNodePosition: IPoint;
Sets the position of the node. Redraws the node when the position changes.
fNodeSize: IRect;
Sets the size of the node. Redraws the node when the size changes. Use the fResizeHandle directive to resize the node.
fNodeDraggingDisabled: boolean;
Indicates whether the node cannot be dragged. Default: false
fNodeSelectionDisabled: boolean;
Indicates whether the node cannot be selected. Default: false
fNodePositionChange: EventEmitter<IPoint>;
Emits an event when the position of the node changes.
fNodeSizeChange: EventEmitter<IRect>;
Emits an event when the size of the node changes using the fResizeHandle directive.
refresh(): void;
Refreshes the state of the node, typically triggering a re-render or update..f-component
A general class applied to all F components for shared styling.
.f-node
Class specific to the node directive, providing styles for node representation.
.f-node-dragging-disabled
Class applied to the node when fNodeDraggingDisabled=true
.
.f-node-selection-disabled
Class applied to the node when fNodeSelectionDisabled=true
.
.f-selected
Class applied to the node when it is selected.
This code snippet shows a basic example of a node with a specified position.
<f-flow>
<f-canvas>
|:|<div fNode [fNodePosition]="{ x: 100, y: 200 }"></div>|:|
</f-canvas>
</f-flow>
Let's add the fDraggable directive to the f-flow to enable dragging functionality. Also, we need to add the fDragHandle directive inside fNode to specify the handle for dragging. This can be any element inside the node that will act as the drag handle.
<f-flow |:|fDraggable|:|>
<f-canvas>
<div |:|fDragHandle|:| fNode [fNodePosition]="{ x: 100, y: 200 }"></div>
</f-canvas>
</f-flow>
This code snippet shows how to disable dragging for a node.
<f-flow fDraggable>
<f-canvas>
<div fDragHandle |:|[fNodeDraggingDisabled]="true"|:| fNode [fNodePosition]="{ x: 100, y: 200 }"></div>
</f-canvas>
</f-flow>
This code snippet shows how to disable selection for a node.
<f-flow fDraggable>
<f-canvas>
<div fDragHandle |:|[fNodeSelectionDisabled]="true"|:| fNode [fNodePosition]="{ x: 100, y: 200 }"></div>
</f-canvas>
</f-flow>
This example demonstrates a node with a specified position.
This example demonstrates a node with dragging functionality.