ngx-vflow 0.1.14 → 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.
Files changed (30) hide show
  1. package/esm2022/lib/vflow/components/connection/connection.component.mjs +27 -7
  2. package/esm2022/lib/vflow/components/handle/handle.component.mjs +49 -0
  3. package/esm2022/lib/vflow/components/node/node.component.mjs +26 -60
  4. package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +5 -8
  5. package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +5 -3
  6. package/esm2022/lib/vflow/interfaces/connection.interface.mjs +1 -1
  7. package/esm2022/lib/vflow/models/edge.model.mjs +32 -5
  8. package/esm2022/lib/vflow/models/flow.model.mjs +3 -1
  9. package/esm2022/lib/vflow/models/handle.model.mjs +47 -0
  10. package/esm2022/lib/vflow/models/node.model.mjs +21 -60
  11. package/esm2022/lib/vflow/services/flow-status.service.mjs +7 -7
  12. package/esm2022/lib/vflow/services/handle.service.mjs +19 -0
  13. package/esm2022/lib/vflow/types/handle-type.type.mjs +2 -0
  14. package/esm2022/lib/vflow/vflow.module.mjs +7 -2
  15. package/esm2022/public-api.mjs +2 -1
  16. package/fesm2022/ngx-vflow.mjs +229 -143
  17. package/fesm2022/ngx-vflow.mjs.map +1 -1
  18. package/lib/vflow/components/handle/handle.component.d.ts +23 -0
  19. package/lib/vflow/components/node/node.component.d.ts +8 -25
  20. package/lib/vflow/components/vflow/vflow.component.d.ts +3 -4
  21. package/lib/vflow/interfaces/connection.interface.d.ts +2 -0
  22. package/lib/vflow/models/flow.model.d.ts +2 -0
  23. package/lib/vflow/models/handle.model.d.ts +24 -0
  24. package/lib/vflow/models/node.model.d.ts +4 -40
  25. package/lib/vflow/services/flow-status.service.d.ts +9 -3
  26. package/lib/vflow/services/handle.service.d.ts +22 -0
  27. package/lib/vflow/types/handle-type.type.d.ts +1 -0
  28. package/lib/vflow/vflow.module.d.ts +9 -8
  29. package/package.json +1 -1
  30. 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; }; "handleTemplate": { "alias": "handleTemplate"; "required": false; }; }, {}, never, never, false, never>;
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, HandleTemplateDirective, NodeHtmlTemplateDirective } from '../../directives/template.directive';
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
- * ! Be carefult using this field, it may depricate in future releases !
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", "handleTemplateDirective"], never, false, [{ directive: typeof i1.ConnectionControllerDirective; inputs: {}; outputs: { "onConnect": "onConnect"; }; }, { directive: typeof i2.ChangesControllerDirective; inputs: {}; outputs: { "onNodesChange": "onNodesChange"; "onEdgesChange": "onEdgesChange"; }; }]>;
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
  }
@@ -1,4 +1,6 @@
1
1
  export interface Connection {
2
2
  source: string;
3
3
  target: string;
4
+ sourceHandle?: string;
5
+ targetHandle?: string;
4
6
  }
@@ -3,6 +3,8 @@ import { HandlePositions } from "../interfaces/handle-positions.interface";
3
3
  export declare class FlowModel {
4
4
  /**
5
5
  * Global setting with handle positions. Nodes derive this value
6
+ *
7
+ * @deprecated
6
8
  */
7
9
  handlePositions: WritableSignal<HandlePositions>;
8
10
  /**
@@ -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
- sourceHandleSize: import("@angular/core").WritableSignal<{
37
- width: number;
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, valid: boolean): void;
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/defs/defs.component";
8
- import * as i7 from "./directives/space-point-context.directive";
9
- import * as i8 from "./directives/map-context.directive";
10
- import * as i9 from "./directives/reference.directive";
11
- import * as i10 from "./directives/root-svg-context.directive";
12
- import * as i11 from "./directives/template.directive";
13
- import * as i12 from "@angular/common";
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.DefsComponent, typeof i7.SpacePointContextDirective, typeof i8.MapContextDirective, typeof i9.RootSvgReferenceDirective, typeof i10.RootSvgContextDirective, typeof i11.NodeHtmlTemplateDirective, typeof i11.EdgeLabelHtmlTemplateDirective, typeof i11.EdgeTemplateDirective, typeof i11.ConnectionTemplateDirective, typeof i11.HandleTemplateDirective], [typeof i12.CommonModule], [typeof i1.VflowComponent, typeof i11.NodeHtmlTemplateDirective, typeof i11.EdgeLabelHtmlTemplateDirective, typeof i11.EdgeTemplateDirective, typeof i11.ConnectionTemplateDirective, typeof i11.HandleTemplateDirective]>;
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ngx-vflow",
3
- "version": "0.1.14",
3
+ "version": "0.2.0",
4
4
  "license": "MIT",
5
5
  "homepage": "https://www.ngx-vflow.org/",
6
6
  "author": "Artem Mangilev",
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';