ngx-vflow 0.1.13 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/esm2022/lib/vflow/components/connection/connection.component.mjs +27 -7
- package/esm2022/lib/vflow/components/handle/handle.component.mjs +49 -0
- package/esm2022/lib/vflow/components/node/node.component.mjs +26 -60
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +5 -8
- package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +5 -3
- package/esm2022/lib/vflow/interfaces/connection.interface.mjs +1 -1
- package/esm2022/lib/vflow/models/edge.model.mjs +32 -5
- package/esm2022/lib/vflow/models/flow.model.mjs +3 -1
- package/esm2022/lib/vflow/models/handle.model.mjs +47 -0
- package/esm2022/lib/vflow/models/node.model.mjs +21 -60
- package/esm2022/lib/vflow/services/flow-status.service.mjs +7 -7
- package/esm2022/lib/vflow/services/handle.service.mjs +19 -0
- package/esm2022/lib/vflow/types/handle-type.type.mjs +2 -0
- package/esm2022/lib/vflow/vflow.module.mjs +7 -2
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/ngx-vflow.mjs +229 -143
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/handle/handle.component.d.ts +23 -0
- package/lib/vflow/components/node/node.component.d.ts +8 -25
- package/lib/vflow/components/vflow/vflow.component.d.ts +3 -4
- package/lib/vflow/interfaces/connection.interface.d.ts +2 -0
- package/lib/vflow/models/flow.model.d.ts +2 -0
- package/lib/vflow/models/handle.model.d.ts +24 -0
- package/lib/vflow/models/node.model.d.ts +4 -40
- package/lib/vflow/services/flow-status.service.d.ts +9 -3
- package/lib/vflow/services/handle.service.d.ts +22 -0
- package/lib/vflow/types/handle-type.type.d.ts +1 -0
- package/lib/vflow/vflow.module.d.ts +9 -8
- package/package.json +2 -2
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import { Position } from '../../types/position.type';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class HandleComponent implements OnInit {
|
|
5
|
+
private handleService;
|
|
6
|
+
private element;
|
|
7
|
+
/**
|
|
8
|
+
* At what side of node this component should be placed
|
|
9
|
+
*/
|
|
10
|
+
position: Position;
|
|
11
|
+
/**
|
|
12
|
+
* Source or target
|
|
13
|
+
*/
|
|
14
|
+
type: 'source' | 'target';
|
|
15
|
+
/**
|
|
16
|
+
* Should be used if node has more than one source/target
|
|
17
|
+
*/
|
|
18
|
+
id?: string;
|
|
19
|
+
ngOnInit(): void;
|
|
20
|
+
private parentRect;
|
|
21
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<HandleComponent, never>;
|
|
22
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<HandleComponent, "handle", never, { "position": { "alias": "position"; "required": true; }; "type": { "alias": "type"; "required": true; }; "id": { "alias": "id"; "required": false; }; }, {}, never, never, false, never>;
|
|
23
|
+
}
|
|
@@ -1,53 +1,36 @@
|
|
|
1
|
-
import { AfterViewInit, ElementRef, OnDestroy, OnInit, TemplateRef } from '@angular/core';
|
|
1
|
+
import { AfterViewInit, ElementRef, Injector, OnDestroy, OnInit, TemplateRef } from '@angular/core';
|
|
2
2
|
import { NodeModel } from '../../models/node.model';
|
|
3
|
+
import { HandleService } from '../../services/handle.service';
|
|
4
|
+
import { HandleModel } from '../../models/handle.model';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
6
|
export type HandleState = 'valid' | 'invalid' | 'idle';
|
|
5
7
|
export declare class NodeComponent implements OnInit, AfterViewInit, OnDestroy {
|
|
8
|
+
protected handleService: HandleService;
|
|
9
|
+
protected injector: Injector;
|
|
6
10
|
nodeModel: NodeModel;
|
|
7
11
|
nodeHtmlTemplate?: TemplateRef<any>;
|
|
8
|
-
handleTemplate?: TemplateRef<any>;
|
|
9
12
|
nodeContentRef: ElementRef<SVGGraphicsElement>;
|
|
10
13
|
htmlWrapperRef: ElementRef<HTMLDivElement>;
|
|
11
|
-
sourceHandleRef: ElementRef<SVGGElement | SVGCircleElement>;
|
|
12
|
-
targetHandleRef: ElementRef<SVGGElement | SVGCircleElement>;
|
|
13
14
|
private draggableService;
|
|
14
15
|
private flowStatusService;
|
|
15
16
|
private flowEntitiesService;
|
|
16
17
|
private hostRef;
|
|
17
18
|
protected showMagnet: import("@angular/core").Signal<boolean>;
|
|
18
|
-
protected readonly defaultHandleStrokeWidth = 2;
|
|
19
19
|
private sourceHanldeState;
|
|
20
20
|
private targetHandleState;
|
|
21
|
-
private sourceHanldeStateReadonly;
|
|
22
|
-
private targetHanldeStateReadonly;
|
|
23
21
|
ngOnInit(): void;
|
|
24
22
|
ngAfterViewInit(): void;
|
|
25
23
|
ngOnDestroy(): void;
|
|
26
|
-
protected startConnection(event: MouseEvent): void;
|
|
24
|
+
protected startConnection(event: MouseEvent, handle: HandleModel): void;
|
|
27
25
|
protected endConnection(): void;
|
|
28
26
|
/**
|
|
29
27
|
* TODO srp
|
|
30
28
|
*/
|
|
31
|
-
protected validateTargetHandle(): void;
|
|
29
|
+
protected validateTargetHandle(targetHandle: HandleModel): void;
|
|
32
30
|
/**
|
|
33
31
|
* TODO srp
|
|
34
32
|
*/
|
|
35
33
|
protected resetValidateTargetHandle(): void;
|
|
36
|
-
protected getHandleContext(type: 'source' | 'target'): {
|
|
37
|
-
$implicit: {
|
|
38
|
-
point: import("@angular/core").Signal<{
|
|
39
|
-
x: number;
|
|
40
|
-
y: number;
|
|
41
|
-
}>;
|
|
42
|
-
alignedPoint: import("@angular/core").Signal<{
|
|
43
|
-
x: number;
|
|
44
|
-
y: number;
|
|
45
|
-
}>;
|
|
46
|
-
state: import("@angular/core").Signal<HandleState>;
|
|
47
|
-
};
|
|
48
|
-
};
|
|
49
|
-
private setSourceHandleSize;
|
|
50
|
-
private setTargetHandleSize;
|
|
51
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<NodeComponent, never>;
|
|
52
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NodeComponent, "g[node]", never, { "nodeModel": { "alias": "nodeModel"; "required": false; }; "nodeHtmlTemplate": { "alias": "nodeHtmlTemplate"; "required": false; };
|
|
35
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NodeComponent, "g[node]", never, { "nodeModel": { "alias": "nodeModel"; "required": false; }; "nodeHtmlTemplate": { "alias": "nodeHtmlTemplate"; "required": false; }; }, {}, never, never, false, never>;
|
|
53
36
|
}
|
|
@@ -4,7 +4,7 @@ import { MapContextDirective } from '../../directives/map-context.directive';
|
|
|
4
4
|
import { NodeModel } from '../../models/node.model';
|
|
5
5
|
import { Edge } from '../../interfaces/edge.interface';
|
|
6
6
|
import { EdgeModel } from '../../models/edge.model';
|
|
7
|
-
import { ConnectionTemplateDirective, EdgeLabelHtmlTemplateDirective, EdgeTemplateDirective,
|
|
7
|
+
import { ConnectionTemplateDirective, EdgeLabelHtmlTemplateDirective, EdgeTemplateDirective, NodeHtmlTemplateDirective } from '../../directives/template.directive';
|
|
8
8
|
import { HandlePositions } from '../../interfaces/handle-positions.interface';
|
|
9
9
|
import { FlowModel } from '../../models/flow.model';
|
|
10
10
|
import { Point } from '../../interfaces/point.interface';
|
|
@@ -47,7 +47,7 @@ export declare class VflowComponent {
|
|
|
47
47
|
* For example, if you want to archieve right to left direction
|
|
48
48
|
* then you need to pass these positions { source: 'left', target: 'right' }
|
|
49
49
|
*
|
|
50
|
-
*
|
|
50
|
+
* @deprecated
|
|
51
51
|
*/
|
|
52
52
|
set handlePositions(handlePositions: HandlePositions);
|
|
53
53
|
/**
|
|
@@ -75,7 +75,6 @@ export declare class VflowComponent {
|
|
|
75
75
|
protected edgeTemplateDirective?: EdgeTemplateDirective;
|
|
76
76
|
protected edgeLabelHtmlDirective?: EdgeLabelHtmlTemplateDirective;
|
|
77
77
|
protected connectionTemplateDirective?: ConnectionTemplateDirective;
|
|
78
|
-
protected handleTemplateDirective?: HandleTemplateDirective;
|
|
79
78
|
protected mapContext: MapContextDirective;
|
|
80
79
|
/**
|
|
81
80
|
* Signal for reading viewport change
|
|
@@ -130,6 +129,6 @@ export declare class VflowComponent {
|
|
|
130
129
|
protected trackNodes(idx: number, { node }: NodeModel): string;
|
|
131
130
|
protected trackEdges(idx: number, { edge }: EdgeModel): string;
|
|
132
131
|
static ɵfac: i0.ɵɵFactoryDeclaration<VflowComponent, never>;
|
|
133
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<VflowComponent, "vflow", never, { "view": { "alias": "view"; "required": false; }; "minZoom": { "alias": "minZoom"; "required": false; }; "maxZoom": { "alias": "maxZoom"; "required": false; }; "handlePositions": { "alias": "handlePositions"; "required": false; }; "background": { "alias": "background"; "required": false; }; "connection": { "alias": "connection"; "required": false; }; "nodes": { "alias": "nodes"; "required": true; }; "edges": { "alias": "edges"; "required": false; }; }, {}, ["nodeHtmlDirective", "edgeTemplateDirective", "edgeLabelHtmlDirective", "connectionTemplateDirective"
|
|
132
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<VflowComponent, "vflow", never, { "view": { "alias": "view"; "required": false; }; "minZoom": { "alias": "minZoom"; "required": false; }; "maxZoom": { "alias": "maxZoom"; "required": false; }; "handlePositions": { "alias": "handlePositions"; "required": false; }; "background": { "alias": "background"; "required": false; }; "connection": { "alias": "connection"; "required": false; }; "nodes": { "alias": "nodes"; "required": true; }; "edges": { "alias": "edges"; "required": false; }; }, {}, ["nodeHtmlDirective", "edgeTemplateDirective", "edgeLabelHtmlDirective", "connectionTemplateDirective"], never, false, [{ directive: typeof i1.ConnectionControllerDirective; inputs: {}; outputs: { "onConnect": "onConnect"; }; }, { directive: typeof i2.ChangesControllerDirective; inputs: {}; outputs: { "onNodesChange": "onNodesChange"; "onEdgesChange": "onEdgesChange"; }; }]>;
|
|
134
133
|
static ngAcceptInputType_connection: i3.ConnectionSettings;
|
|
135
134
|
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { NodeHandle } from "../services/handle.service";
|
|
2
|
+
import { NodeModel } from "./node.model";
|
|
3
|
+
export declare class HandleModel {
|
|
4
|
+
rawHandle: NodeHandle;
|
|
5
|
+
private parentNode;
|
|
6
|
+
readonly strokeWidth = 2;
|
|
7
|
+
size: import("@angular/core").WritableSignal<{
|
|
8
|
+
width: number;
|
|
9
|
+
height: number;
|
|
10
|
+
}>;
|
|
11
|
+
offset: import("@angular/core").Signal<{
|
|
12
|
+
x: number;
|
|
13
|
+
y: number;
|
|
14
|
+
}>;
|
|
15
|
+
sizeOffset: import("@angular/core").Signal<{
|
|
16
|
+
x: number;
|
|
17
|
+
y: number;
|
|
18
|
+
}>;
|
|
19
|
+
pointAbsolute: import("@angular/core").Signal<{
|
|
20
|
+
x: number;
|
|
21
|
+
y: number;
|
|
22
|
+
}>;
|
|
23
|
+
constructor(rawHandle: NodeHandle, parentNode: NodeModel);
|
|
24
|
+
}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { Node } from '../interfaces/node.interface';
|
|
2
2
|
import { FlowModel } from './flow.model';
|
|
3
|
+
import { NodeHandle } from '../services/handle.service';
|
|
4
|
+
import { HandleModel } from './handle.model';
|
|
3
5
|
export declare class NodeModel<T = unknown> {
|
|
4
6
|
node: Node<T>;
|
|
5
7
|
point: import("@angular/core").WritableSignal<{
|
|
@@ -15,48 +17,10 @@ export declare class NodeModel<T = unknown> {
|
|
|
15
17
|
height: number;
|
|
16
18
|
}>;
|
|
17
19
|
pointTransform: import("@angular/core").Signal<string>;
|
|
18
|
-
sourceOffset: import("@angular/core").Signal<{
|
|
19
|
-
x: number;
|
|
20
|
-
y: number;
|
|
21
|
-
}>;
|
|
22
|
-
targetOffset: import("@angular/core").Signal<{
|
|
23
|
-
x: number;
|
|
24
|
-
y: number;
|
|
25
|
-
}>;
|
|
26
|
-
sourcePointAbsolute: import("@angular/core").Signal<{
|
|
27
|
-
x: number;
|
|
28
|
-
y: number;
|
|
29
|
-
}>;
|
|
30
|
-
targetPointAbsolute: import("@angular/core").Signal<{
|
|
31
|
-
x: number;
|
|
32
|
-
y: number;
|
|
33
|
-
}>;
|
|
34
20
|
sourcePosition: import("@angular/core").Signal<import("ngx-vflow").Position>;
|
|
35
21
|
targetPosition: import("@angular/core").Signal<import("ngx-vflow").Position>;
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
height: number;
|
|
39
|
-
}>;
|
|
40
|
-
targetHandleSize: import("@angular/core").WritableSignal<{
|
|
41
|
-
width: number;
|
|
42
|
-
height: number;
|
|
43
|
-
}>;
|
|
44
|
-
sourceHandleOffset: import("@angular/core").Signal<{
|
|
45
|
-
x: number;
|
|
46
|
-
y: number;
|
|
47
|
-
}>;
|
|
48
|
-
targetHandleOffset: import("@angular/core").Signal<{
|
|
49
|
-
x: number;
|
|
50
|
-
y: number;
|
|
51
|
-
}>;
|
|
52
|
-
sourceOffsetAligned: import("@angular/core").Signal<{
|
|
53
|
-
x: number;
|
|
54
|
-
y: number;
|
|
55
|
-
}>;
|
|
56
|
-
targetOffsetAligned: import("@angular/core").Signal<{
|
|
57
|
-
x: number;
|
|
58
|
-
y: number;
|
|
59
|
-
}>;
|
|
22
|
+
handles: import("@angular/core").Signal<HandleModel[]>;
|
|
23
|
+
rawHandles: import("@angular/core").WritableSignal<NodeHandle[]>;
|
|
60
24
|
draggable: boolean;
|
|
61
25
|
readonly magnetRadius = 20;
|
|
62
26
|
private flow;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { NodeModel } from '../models/node.model';
|
|
2
|
+
import { HandleModel } from '../models/handle.model';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
export interface FlowStatusIdle {
|
|
4
5
|
state: 'idle';
|
|
@@ -8,6 +9,7 @@ export interface FlowStatusConnectionStart {
|
|
|
8
9
|
state: 'connection-start';
|
|
9
10
|
payload: {
|
|
10
11
|
sourceNode: NodeModel;
|
|
12
|
+
sourceHandle: HandleModel;
|
|
11
13
|
};
|
|
12
14
|
}
|
|
13
15
|
export interface FlowStatusConnectionValidation {
|
|
@@ -15,6 +17,8 @@ export interface FlowStatusConnectionValidation {
|
|
|
15
17
|
payload: {
|
|
16
18
|
sourceNode: NodeModel;
|
|
17
19
|
targetNode: NodeModel;
|
|
20
|
+
sourceHandle: HandleModel;
|
|
21
|
+
targetHandle: HandleModel;
|
|
18
22
|
valid: boolean;
|
|
19
23
|
};
|
|
20
24
|
}
|
|
@@ -23,15 +27,17 @@ export interface FlowStatusConnectionEnd {
|
|
|
23
27
|
payload: {
|
|
24
28
|
sourceNode: NodeModel;
|
|
25
29
|
targetNode: NodeModel;
|
|
30
|
+
sourceHandle: HandleModel;
|
|
31
|
+
targetHandle: HandleModel;
|
|
26
32
|
};
|
|
27
33
|
}
|
|
28
34
|
export type FlowStatus = FlowStatusIdle | FlowStatusConnectionStart | FlowStatusConnectionValidation | FlowStatusConnectionEnd;
|
|
29
35
|
export declare class FlowStatusService {
|
|
30
36
|
readonly status: import("@angular/core").WritableSignal<FlowStatus>;
|
|
31
37
|
setIdleStatus(): void;
|
|
32
|
-
setConnectionStartStatus(sourceNode: NodeModel): void;
|
|
33
|
-
setConnectionValidationStatus(sourceNode: NodeModel, targetNode: NodeModel,
|
|
34
|
-
setConnectionEndStatus(sourceNode: NodeModel, targetNode: NodeModel): void;
|
|
38
|
+
setConnectionStartStatus(sourceNode: NodeModel, sourceHandle: HandleModel): void;
|
|
39
|
+
setConnectionValidationStatus(valid: boolean, sourceNode: NodeModel, targetNode: NodeModel, sourceHandle: HandleModel, targetHandle: HandleModel): void;
|
|
40
|
+
setConnectionEndStatus(sourceNode: NodeModel, targetNode: NodeModel, sourceHandle: HandleModel, targetHandle: HandleModel): void;
|
|
35
41
|
static ɵfac: i0.ɵɵFactoryDeclaration<FlowStatusService, never>;
|
|
36
42
|
static ɵprov: i0.ɵɵInjectableDeclaration<FlowStatusService>;
|
|
37
43
|
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Signal } from '@angular/core';
|
|
2
|
+
import { Position } from '../types/position.type';
|
|
3
|
+
import { HandleType } from '../types/handle-type.type';
|
|
4
|
+
import { Point } from '../interfaces/point.interface';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export interface NodeHandle {
|
|
7
|
+
position: Position;
|
|
8
|
+
type: HandleType;
|
|
9
|
+
parentPosition: Signal<Point>;
|
|
10
|
+
parentSize: Signal<{
|
|
11
|
+
width: number;
|
|
12
|
+
height: number;
|
|
13
|
+
}>;
|
|
14
|
+
id?: string;
|
|
15
|
+
}
|
|
16
|
+
export declare class HandleService {
|
|
17
|
+
readonly handles: import("@angular/core").WritableSignal<NodeHandle[]>;
|
|
18
|
+
createHandle(newHandle: NodeHandle): void;
|
|
19
|
+
destroyHandle(handleToDestoy: NodeHandle): void;
|
|
20
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<HandleService, never>;
|
|
21
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<HandleService>;
|
|
22
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type HandleType = 'source' | 'target';
|
|
@@ -4,15 +4,16 @@ import * as i2 from "./components/node/node.component";
|
|
|
4
4
|
import * as i3 from "./components/edge/edge.component";
|
|
5
5
|
import * as i4 from "./components/edge-label/edge-label.component";
|
|
6
6
|
import * as i5 from "./components/connection/connection.component";
|
|
7
|
-
import * as i6 from "./components/
|
|
8
|
-
import * as i7 from "./
|
|
9
|
-
import * as i8 from "./directives/
|
|
10
|
-
import * as i9 from "./directives/
|
|
11
|
-
import * as i10 from "./directives/
|
|
12
|
-
import * as i11 from "./directives/
|
|
13
|
-
import * as i12 from "
|
|
7
|
+
import * as i6 from "./components/handle/handle.component";
|
|
8
|
+
import * as i7 from "./components/defs/defs.component";
|
|
9
|
+
import * as i8 from "./directives/space-point-context.directive";
|
|
10
|
+
import * as i9 from "./directives/map-context.directive";
|
|
11
|
+
import * as i10 from "./directives/reference.directive";
|
|
12
|
+
import * as i11 from "./directives/root-svg-context.directive";
|
|
13
|
+
import * as i12 from "./directives/template.directive";
|
|
14
|
+
import * as i13 from "@angular/common";
|
|
14
15
|
export declare class VflowModule {
|
|
15
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<VflowModule, never>;
|
|
16
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<VflowModule, [typeof i1.VflowComponent, typeof i2.NodeComponent, typeof i3.EdgeComponent, typeof i4.EdgeLabelComponent, typeof i5.ConnectionComponent, typeof i6.
|
|
17
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<VflowModule, [typeof i1.VflowComponent, typeof i2.NodeComponent, typeof i3.EdgeComponent, typeof i4.EdgeLabelComponent, typeof i5.ConnectionComponent, typeof i6.HandleComponent, typeof i7.DefsComponent, typeof i8.SpacePointContextDirective, typeof i9.MapContextDirective, typeof i10.RootSvgReferenceDirective, typeof i11.RootSvgContextDirective, typeof i12.NodeHtmlTemplateDirective, typeof i12.EdgeLabelHtmlTemplateDirective, typeof i12.EdgeTemplateDirective, typeof i12.ConnectionTemplateDirective, typeof i12.HandleTemplateDirective], [typeof i13.CommonModule], [typeof i1.VflowComponent, typeof i6.HandleComponent, typeof i12.NodeHtmlTemplateDirective, typeof i12.EdgeLabelHtmlTemplateDirective, typeof i12.EdgeTemplateDirective, typeof i12.ConnectionTemplateDirective, typeof i12.HandleTemplateDirective]>;
|
|
17
18
|
static ɵinj: i0.ɵɵInjectorDeclaration<VflowModule>;
|
|
18
19
|
}
|
package/package.json
CHANGED
package/public-api.d.ts
CHANGED
|
@@ -13,6 +13,7 @@ export * from './lib/vflow/types/node-change.type';
|
|
|
13
13
|
export * from './lib/vflow/types/edge-change.type';
|
|
14
14
|
export * from './lib/vflow/types/position.type';
|
|
15
15
|
export * from './lib/vflow/components/vflow/vflow.component';
|
|
16
|
+
export * from './lib/vflow/components/handle/handle.component';
|
|
16
17
|
export * from './lib/vflow/directives/template.directive';
|
|
17
18
|
export * from './lib/vflow/directives/connection-controller.directive';
|
|
18
19
|
export * from './lib/vflow/directives/changes-controller.directive';
|