ngx-vflow 0.13.0-0 → 0.14.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/esm2022/lib/vflow/components/background/background.component.mjs +7 -16
- package/esm2022/lib/vflow/components/default-node/default-node.component.mjs +18 -0
- package/esm2022/lib/vflow/components/node/node.component.mjs +8 -7
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +23 -10
- package/esm2022/lib/vflow/directives/root-pointer.directive.mjs +1 -1
- package/esm2022/lib/vflow/directives/selectable.directive.mjs +5 -2
- package/esm2022/lib/vflow/models/minimap.model.mjs +7 -0
- package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +119 -0
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +124 -180
- package/esm2022/lib/vflow/services/draggable.service.mjs +40 -19
- package/esm2022/lib/vflow/services/flow-entities.service.mjs +6 -5
- package/esm2022/lib/vflow/services/flow-settings.service.mjs +2 -1
- package/esm2022/lib/vflow/services/keyboard.service.mjs +45 -0
- package/esm2022/lib/vflow/services/node-changes.service.mjs +6 -7
- package/esm2022/lib/vflow/services/selection.service.mjs +12 -5
- package/esm2022/lib/vflow/types/keyboard-action.type.mjs +2 -0
- package/esm2022/lib/vflow/utils/get-os.mjs +24 -0
- package/esm2022/lib/vflow/utils/transform-background.mjs +6 -0
- package/esm2022/lib/vflow/vflow.module.mjs +11 -3
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/ngx-vflow.mjs +423 -242
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/background/background.component.d.ts +3 -6
- package/lib/vflow/components/default-node/default-node.component.d.ts +6 -0
- package/lib/vflow/components/vflow/vflow.component.d.ts +6 -2
- package/lib/vflow/directives/root-pointer.directive.d.ts +10 -16
- package/lib/vflow/directives/space-point-context.directive.d.ts +1 -15
- package/lib/vflow/models/edge.model.d.ts +17 -1
- package/lib/vflow/models/minimap.model.d.ts +4 -0
- package/lib/vflow/public-components/minimap/minimap.component.d.ts +49 -0
- package/lib/vflow/public-components/resizable/resizable.component.d.ts +6 -11
- package/lib/vflow/services/draggable.service.d.ts +2 -0
- package/lib/vflow/services/flow-entities.service.d.ts +7 -5
- package/lib/vflow/services/flow-settings.service.d.ts +2 -0
- package/lib/vflow/services/keyboard.service.d.ts +11 -0
- package/lib/vflow/services/selection.service.d.ts +1 -0
- package/lib/vflow/types/keyboard-action.type.d.ts +2 -0
- package/lib/vflow/utils/get-os.d.ts +1 -0
- package/lib/vflow/utils/transform-background.d.ts +2 -0
- package/lib/vflow/vflow.module.d.ts +21 -19
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -1,11 +1,9 @@
|
|
|
1
|
-
import { Background } from '../../types/background.type';
|
|
2
1
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "../../types/background.type";
|
|
4
2
|
export declare class BackgroundComponent {
|
|
5
3
|
private viewportService;
|
|
6
4
|
private rootSvg;
|
|
7
|
-
|
|
8
|
-
protected backgroundSignal: import("@angular/core").WritableSignal<Background>;
|
|
5
|
+
private settingsService;
|
|
6
|
+
protected backgroundSignal: import("@angular/core").WritableSignal<import("ngx-vflow").Background>;
|
|
9
7
|
protected scaledGap: import("@angular/core").Signal<number>;
|
|
10
8
|
protected x: import("@angular/core").Signal<number>;
|
|
11
9
|
protected y: import("@angular/core").Signal<number>;
|
|
@@ -15,6 +13,5 @@ export declare class BackgroundComponent {
|
|
|
15
13
|
protected patternUrl: string;
|
|
16
14
|
constructor();
|
|
17
15
|
static ɵfac: i0.ɵɵFactoryDeclaration<BackgroundComponent, never>;
|
|
18
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<BackgroundComponent, "g[background]", never, {
|
|
19
|
-
static ngAcceptInputType_background: i1.Background | string;
|
|
16
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<BackgroundComponent, "g[background]", never, {}, {}, never, never, false, never>;
|
|
20
17
|
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class DefaultNodeComponent {
|
|
3
|
+
selected: boolean;
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DefaultNodeComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DefaultNodeComponent, "default-node", never, { "selected": { "alias": "selected"; "required": false; }; }, {}, never, ["*"], false, never>;
|
|
6
|
+
}
|
|
@@ -15,6 +15,7 @@ import { Background } from '../../types/background.type';
|
|
|
15
15
|
import { SpacePointContextDirective } from '../../directives/space-point-context.directive';
|
|
16
16
|
import { FitViewOptions } from '../../interfaces/fit-view-options.interface';
|
|
17
17
|
import { Optimization } from '../../interfaces/optimization.interface';
|
|
18
|
+
import { KeyboardShortcuts } from '../../types/keyboard-action.type';
|
|
18
19
|
import * as i0 from "@angular/core";
|
|
19
20
|
import * as i1 from "../../directives/connection-controller.directive";
|
|
20
21
|
import * as i2 from "../../directives/changes-controller.directive";
|
|
@@ -27,6 +28,7 @@ export declare class VflowComponent implements OnInit {
|
|
|
27
28
|
private nodeRenderingService;
|
|
28
29
|
private flowSettingsService;
|
|
29
30
|
private componentEventBusService;
|
|
31
|
+
private keyboardService;
|
|
30
32
|
private injector;
|
|
31
33
|
/**
|
|
32
34
|
* Size for flow view
|
|
@@ -59,12 +61,13 @@ export declare class VflowComponent implements OnInit {
|
|
|
59
61
|
/**
|
|
60
62
|
* Background for flow
|
|
61
63
|
*/
|
|
62
|
-
background: Background | string;
|
|
64
|
+
set background(value: Background | string);
|
|
63
65
|
optimization: Optimization;
|
|
64
66
|
/**
|
|
65
67
|
* Global rule if you can or can't select entities
|
|
66
68
|
*/
|
|
67
69
|
set entitiesSelectable(value: boolean);
|
|
70
|
+
set keyboardShortcuts(value: KeyboardShortcuts);
|
|
68
71
|
/**
|
|
69
72
|
* Settings for connection (it renders when user tries to create edge between nodes)
|
|
70
73
|
*
|
|
@@ -120,6 +123,7 @@ export declare class VflowComponent implements OnInit {
|
|
|
120
123
|
*/
|
|
121
124
|
readonly edgesChange$: import("rxjs").Observable<EdgeChange[]>;
|
|
122
125
|
protected markers: Signal<Map<number, import("ngx-vflow").Marker>>;
|
|
126
|
+
protected minimap: import("@angular/core").WritableSignal<import("../../models/minimap.model").MinimapModel | null>;
|
|
123
127
|
ngOnInit(): void;
|
|
124
128
|
/**
|
|
125
129
|
* Change viewport to specified state
|
|
@@ -158,6 +162,6 @@ export declare class VflowComponent implements OnInit {
|
|
|
158
162
|
protected trackEdges(idx: number, { edge }: EdgeModel): Edge<unknown>;
|
|
159
163
|
private setInitialNodesOrder;
|
|
160
164
|
static ɵfac: i0.ɵɵFactoryDeclaration<VflowComponent, never>;
|
|
161
|
-
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; }; "optimization": { "alias": "optimization"; "required": false; }; "entitiesSelectable": { "alias": "entitiesSelectable"; "required": false; }; "connection": { "alias": "connection"; "required": false; }; "nodes": { "alias": "nodes"; "required": true; }; "edges": { "alias": "edges"; "required": false; }; }, { "onComponentNodeEvent": "onComponentNodeEvent"; }, ["nodeTemplateDirective", "groupNodeTemplateDirective", "edgeTemplateDirective", "edgeLabelHtmlDirective", "connectionTemplateDirective"], never, false, [{ directive: typeof i1.ConnectionControllerDirective; inputs: {}; outputs: { "onConnect": "onConnect"; }; }, { directive: typeof i2.ChangesControllerDirective; inputs: {}; outputs: { "onNodesChange": "onNodesChange"; "onNodesChange.position": "onNodesChange.position"; "onNodesChange.position.single": "onNodesChange.position.single"; "onNodesChange.position.many": "onNodesChange.position.many"; "onNodesChange.size": "onNodesChange.size"; "onNodesChange.size.single": "onNodesChange.size.single"; "onNodesChange.size.many": "onNodesChange.size.many"; "onNodesChange.add": "onNodesChange.add"; "onNodesChange.add.single": "onNodesChange.add.single"; "onNodesChange.add.many": "onNodesChange.add.many"; "onNodesChange.remove": "onNodesChange.remove"; "onNodesChange.remove.single": "onNodesChange.remove.single"; "onNodesChange.remove.many": "onNodesChange.remove.many"; "onNodesChange.select": "onNodesChange.select"; "onNodesChange.select.single": "onNodesChange.select.single"; "onNodesChange.select.many": "onNodesChange.select.many"; "onEdgesChange": "onEdgesChange"; "onEdgesChange.detached": "onEdgesChange.detached"; "onEdgesChange.detached.single": "onEdgesChange.detached.single"; "onEdgesChange.detached.many": "onEdgesChange.detached.many"; "onEdgesChange.add": "onEdgesChange.add"; "onEdgesChange.add.single": "onEdgesChange.add.single"; "onEdgesChange.add.many": "onEdgesChange.add.many"; "onEdgesChange.remove": "onEdgesChange.remove"; "onEdgesChange.remove.single": "onEdgesChange.remove.single"; "onEdgesChange.remove.many": "onEdgesChange.remove.many"; "onEdgesChange.select": "onEdgesChange.select"; "onEdgesChange.select.single": "onEdgesChange.select.single"; "onEdgesChange.select.many": "onEdgesChange.select.many"; }; }]>;
|
|
165
|
+
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; }; "optimization": { "alias": "optimization"; "required": false; }; "entitiesSelectable": { "alias": "entitiesSelectable"; "required": false; }; "keyboardShortcuts": { "alias": "keyboardShortcuts"; "required": false; }; "connection": { "alias": "connection"; "required": false; }; "nodes": { "alias": "nodes"; "required": true; }; "edges": { "alias": "edges"; "required": false; }; }, { "onComponentNodeEvent": "onComponentNodeEvent"; }, ["nodeTemplateDirective", "groupNodeTemplateDirective", "edgeTemplateDirective", "edgeLabelHtmlDirective", "connectionTemplateDirective"], never, false, [{ directive: typeof i1.ConnectionControllerDirective; inputs: {}; outputs: { "onConnect": "onConnect"; }; }, { directive: typeof i2.ChangesControllerDirective; inputs: {}; outputs: { "onNodesChange": "onNodesChange"; "onNodesChange.position": "onNodesChange.position"; "onNodesChange.position.single": "onNodesChange.position.single"; "onNodesChange.position.many": "onNodesChange.position.many"; "onNodesChange.size": "onNodesChange.size"; "onNodesChange.size.single": "onNodesChange.size.single"; "onNodesChange.size.many": "onNodesChange.size.many"; "onNodesChange.add": "onNodesChange.add"; "onNodesChange.add.single": "onNodesChange.add.single"; "onNodesChange.add.many": "onNodesChange.add.many"; "onNodesChange.remove": "onNodesChange.remove"; "onNodesChange.remove.single": "onNodesChange.remove.single"; "onNodesChange.remove.many": "onNodesChange.remove.many"; "onNodesChange.select": "onNodesChange.select"; "onNodesChange.select.single": "onNodesChange.select.single"; "onNodesChange.select.many": "onNodesChange.select.many"; "onEdgesChange": "onEdgesChange"; "onEdgesChange.detached": "onEdgesChange.detached"; "onEdgesChange.detached.single": "onEdgesChange.detached.single"; "onEdgesChange.detached.many": "onEdgesChange.detached.many"; "onEdgesChange.add": "onEdgesChange.add"; "onEdgesChange.add.single": "onEdgesChange.add.single"; "onEdgesChange.add.many": "onEdgesChange.add.many"; "onEdgesChange.remove": "onEdgesChange.remove"; "onEdgesChange.remove.single": "onEdgesChange.remove.single"; "onEdgesChange.remove.many": "onEdgesChange.remove.many"; "onEdgesChange.select": "onEdgesChange.select"; "onEdgesChange.select.single": "onEdgesChange.select.single"; "onEdgesChange.select.many": "onEdgesChange.select.many"; }; }]>;
|
|
162
166
|
static ngAcceptInputType_connection: i3.ConnectionSettings;
|
|
163
167
|
}
|
|
@@ -1,5 +1,13 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
export interface PointerEvent {
|
|
4
|
+
x: number;
|
|
5
|
+
y: number;
|
|
6
|
+
movementX: number;
|
|
7
|
+
movementY: number;
|
|
8
|
+
target: Element | null;
|
|
9
|
+
originalEvent: MouseEvent | TouchEvent;
|
|
10
|
+
}
|
|
3
11
|
export declare class RootPointerDirective {
|
|
4
12
|
private host;
|
|
5
13
|
private initialTouch$;
|
|
@@ -9,7 +17,7 @@ export declare class RootPointerDirective {
|
|
|
9
17
|
y: number;
|
|
10
18
|
movementX: number;
|
|
11
19
|
movementY: number;
|
|
12
|
-
target:
|
|
20
|
+
target: Element | null;
|
|
13
21
|
originalEvent: MouseEvent;
|
|
14
22
|
}>;
|
|
15
23
|
touchMovement$: Observable<{
|
|
@@ -20,21 +28,7 @@ export declare class RootPointerDirective {
|
|
|
20
28
|
target: Element | null;
|
|
21
29
|
originalEvent: TouchEvent;
|
|
22
30
|
}>;
|
|
23
|
-
pointerMovement$: Observable<
|
|
24
|
-
x: number;
|
|
25
|
-
y: number;
|
|
26
|
-
movementX: number;
|
|
27
|
-
movementY: number;
|
|
28
|
-
target: EventTarget | null;
|
|
29
|
-
originalEvent: MouseEvent;
|
|
30
|
-
} | {
|
|
31
|
-
x: number;
|
|
32
|
-
y: number;
|
|
33
|
-
movementX: number;
|
|
34
|
-
movementY: number;
|
|
35
|
-
target: Element | null;
|
|
36
|
-
originalEvent: TouchEvent;
|
|
37
|
-
}>;
|
|
31
|
+
pointerMovement$: Observable<PointerEvent>;
|
|
38
32
|
touchEnd$: Observable<{
|
|
39
33
|
x: number;
|
|
40
34
|
y: number;
|
|
@@ -9,21 +9,7 @@ export declare class SpacePointContextDirective {
|
|
|
9
9
|
* Signal with current mouse position in svg space
|
|
10
10
|
*/
|
|
11
11
|
svgCurrentSpacePoint: Signal<Point>;
|
|
12
|
-
pointerMovement: Signal<
|
|
13
|
-
x: number;
|
|
14
|
-
y: number;
|
|
15
|
-
movementX: number;
|
|
16
|
-
movementY: number;
|
|
17
|
-
target: EventTarget | null;
|
|
18
|
-
originalEvent: MouseEvent;
|
|
19
|
-
} | {
|
|
20
|
-
x: number;
|
|
21
|
-
y: number;
|
|
22
|
-
movementX: number;
|
|
23
|
-
movementY: number;
|
|
24
|
-
target: Element | null;
|
|
25
|
-
originalEvent: TouchEvent;
|
|
26
|
-
} | undefined>;
|
|
12
|
+
pointerMovement: Signal<import("./root-pointer.directive").PointerEvent | undefined>;
|
|
27
13
|
documentPointToFlowPoint(documentPoint: Point): DOMPoint;
|
|
28
14
|
static ɵfac: i0.ɵɵFactoryDeclaration<SpacePointContextDirective, never>;
|
|
29
15
|
static ɵdir: i0.ɵɵDirectiveDeclaration<SpacePointContextDirective, "g[spacePointContext]", never, {}, {}, never, never, false, never>;
|
|
@@ -14,7 +14,23 @@ export declare class EdgeModel implements FlowEntity {
|
|
|
14
14
|
selected$: import("rxjs").Observable<boolean>;
|
|
15
15
|
detached: import("@angular/core").Signal<boolean>;
|
|
16
16
|
detached$: import("rxjs").Observable<boolean>;
|
|
17
|
-
path: import("@angular/core").Signal<
|
|
17
|
+
path: import("@angular/core").Signal<{
|
|
18
|
+
path: string;
|
|
19
|
+
points: {
|
|
20
|
+
start: {
|
|
21
|
+
x: number;
|
|
22
|
+
y: number;
|
|
23
|
+
};
|
|
24
|
+
center: {
|
|
25
|
+
x: number;
|
|
26
|
+
y: number;
|
|
27
|
+
};
|
|
28
|
+
end: {
|
|
29
|
+
x: number;
|
|
30
|
+
y: number;
|
|
31
|
+
};
|
|
32
|
+
};
|
|
33
|
+
}>;
|
|
18
34
|
edgeLabels: {
|
|
19
35
|
[position in EdgeLabelPosition]?: EdgeLabelModel;
|
|
20
36
|
};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Injector, OnInit } from '@angular/core';
|
|
2
|
+
import { FlowEntitiesService } from '../../services/flow-entities.service';
|
|
3
|
+
import { NodeModel } from '../../models/node.model';
|
|
4
|
+
import { FlowSettingsService } from '../../services/flow-settings.service';
|
|
5
|
+
import { ViewportService } from '../../services/viewport.service';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export type MiniMapPosition = 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
|
|
8
|
+
export declare class MiniMapComponent implements OnInit {
|
|
9
|
+
protected entitiesService: FlowEntitiesService;
|
|
10
|
+
protected flowSettingsService: FlowSettingsService;
|
|
11
|
+
protected viewportService: ViewportService;
|
|
12
|
+
protected injector: Injector;
|
|
13
|
+
/**
|
|
14
|
+
* The corner of the flow where to render a mini-map
|
|
15
|
+
*/
|
|
16
|
+
set position(value: MiniMapPosition);
|
|
17
|
+
/**
|
|
18
|
+
* The color outside the viewport (invisible area)
|
|
19
|
+
*/
|
|
20
|
+
maskColor: string;
|
|
21
|
+
/**
|
|
22
|
+
* The minimap stroke color
|
|
23
|
+
*/
|
|
24
|
+
strokeColor: string;
|
|
25
|
+
/**
|
|
26
|
+
* Make a minimap bigger on hover
|
|
27
|
+
*/
|
|
28
|
+
set scaleOnHover(value: boolean);
|
|
29
|
+
private minimap;
|
|
30
|
+
private readonly minimapOffset;
|
|
31
|
+
private readonly minimapScale;
|
|
32
|
+
protected viewportColor: import("@angular/core").Signal<string>;
|
|
33
|
+
protected hovered: import("@angular/core").WritableSignal<boolean>;
|
|
34
|
+
protected minimapPoint: import("@angular/core").Signal<{
|
|
35
|
+
x: number;
|
|
36
|
+
y: number;
|
|
37
|
+
}>;
|
|
38
|
+
protected minimapWidth: import("@angular/core").Signal<number>;
|
|
39
|
+
protected minimapHeight: import("@angular/core").Signal<number>;
|
|
40
|
+
protected viewportTransform: import("@angular/core").Signal<string>;
|
|
41
|
+
protected boundsViewport: import("@angular/core").Signal<import("ngx-vflow").ViewportState>;
|
|
42
|
+
protected minimapTransform: import("@angular/core").Signal<string>;
|
|
43
|
+
private minimapPosition;
|
|
44
|
+
private scaleOnHoverSignal;
|
|
45
|
+
ngOnInit(): void;
|
|
46
|
+
protected trackNodes(idx: number, { node }: NodeModel): import("ngx-vflow").Node<unknown> | import("ngx-vflow").DynamicNode<unknown>;
|
|
47
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<MiniMapComponent, never>;
|
|
48
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<MiniMapComponent, "mini-map", never, { "position": { "alias": "position"; "required": false; }; "maskColor": { "alias": "maskColor"; "required": false; }; "strokeColor": { "alias": "strokeColor"; "required": false; }; "scaleOnHover": { "alias": "scaleOnHover"; "required": false; }; }, {}, never, never, false, never>;
|
|
49
|
+
}
|
|
@@ -1,16 +1,19 @@
|
|
|
1
1
|
import { AfterViewInit, OnInit } from '@angular/core';
|
|
2
|
+
import { NodeModel } from '../../models/node.model';
|
|
3
|
+
import { PointerEvent } from '../../directives/root-pointer.directive';
|
|
2
4
|
import * as i0 from "@angular/core";
|
|
3
5
|
type Side = 'top' | 'right' | 'bottom' | 'left' | 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left';
|
|
4
6
|
export declare class ResizableComponent implements OnInit, AfterViewInit {
|
|
5
7
|
private nodeAccessor;
|
|
6
8
|
private rootPointer;
|
|
7
9
|
private viewportService;
|
|
10
|
+
private spacePointContext;
|
|
8
11
|
private hostRef;
|
|
9
12
|
set resizable(value: boolean | '');
|
|
10
13
|
resizerColor: string;
|
|
11
14
|
gap: number;
|
|
12
15
|
private resizer;
|
|
13
|
-
protected get model():
|
|
16
|
+
protected get model(): NodeModel<unknown>;
|
|
14
17
|
protected lineGap: number;
|
|
15
18
|
protected handleSize: number;
|
|
16
19
|
private resizeSide;
|
|
@@ -22,17 +25,9 @@ export declare class ResizableComponent implements OnInit, AfterViewInit {
|
|
|
22
25
|
ngOnInit(): void;
|
|
23
26
|
ngAfterViewInit(): void;
|
|
24
27
|
protected startResize(side: Side, event: Event): void;
|
|
25
|
-
protected resize(
|
|
26
|
-
movementX: number;
|
|
27
|
-
movementY: number;
|
|
28
|
-
}): void;
|
|
28
|
+
protected resize(event: PointerEvent): void;
|
|
29
29
|
protected endResize(): void;
|
|
30
|
-
private
|
|
31
|
-
private getMaxHeight;
|
|
32
|
-
private getMinX;
|
|
33
|
-
private getMinY;
|
|
34
|
-
private getMaxX;
|
|
35
|
-
private getMaxY;
|
|
30
|
+
private isResizeConstrained;
|
|
36
31
|
static ɵfac: i0.ɵɵFactoryDeclaration<ResizableComponent, never>;
|
|
37
32
|
static ɵcmp: i0.ɵɵComponentDeclaration<ResizableComponent, "[resizable]", never, { "resizable": { "alias": "resizable"; "required": false; }; "resizerColor": { "alias": "resizerColor"; "required": false; }; "gap": { "alias": "gap"; "required": false; }; }, {}, never, ["*"], false, never>;
|
|
38
33
|
}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { NodeModel } from '../models/node.model';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class DraggableService {
|
|
4
|
+
private entitiesService;
|
|
4
5
|
/**
|
|
5
6
|
* Enable draggable behavior for element.
|
|
6
7
|
*
|
|
@@ -33,6 +34,7 @@ export declare class DraggableService {
|
|
|
33
34
|
* with disabled drag behavior
|
|
34
35
|
*/
|
|
35
36
|
private getIgnoreDragBehavior;
|
|
37
|
+
private getDragNodes;
|
|
36
38
|
static ɵfac: i0.ɵɵFactoryDeclaration<DraggableService, never>;
|
|
37
39
|
static ɵprov: i0.ɵɵInjectableDeclaration<DraggableService>;
|
|
38
40
|
}
|
|
@@ -1,17 +1,19 @@
|
|
|
1
|
-
import { Signal } from '@angular/core';
|
|
1
|
+
import { Signal, WritableSignal } from '@angular/core';
|
|
2
2
|
import { NodeModel } from '../models/node.model';
|
|
3
3
|
import { EdgeModel } from '../models/edge.model';
|
|
4
4
|
import { ConnectionModel } from '../models/connection.model';
|
|
5
5
|
import { Marker } from '../interfaces/marker.interface';
|
|
6
6
|
import { FlowEntity } from '../interfaces/flow-entity.interface';
|
|
7
|
+
import { MinimapModel } from '../models/minimap.model';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
export declare class FlowEntitiesService {
|
|
9
|
-
readonly nodes:
|
|
10
|
-
readonly edges:
|
|
11
|
-
readonly connection: import("@angular/core").WritableSignal<ConnectionModel>;
|
|
12
|
-
readonly markers: Signal<Map<number, Marker>>;
|
|
10
|
+
readonly nodes: WritableSignal<NodeModel<unknown>[]>;
|
|
11
|
+
readonly edges: WritableSignal<EdgeModel[]>;
|
|
13
12
|
readonly validEdges: Signal<EdgeModel[]>;
|
|
13
|
+
readonly connection: WritableSignal<ConnectionModel>;
|
|
14
|
+
readonly markers: Signal<Map<number, Marker>>;
|
|
14
15
|
entities: Signal<FlowEntity[]>;
|
|
16
|
+
minimap: WritableSignal<MinimapModel | null>;
|
|
15
17
|
getNode<T>(id: string): NodeModel<T> | undefined;
|
|
16
18
|
getDetachedEdges(): EdgeModel[];
|
|
17
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<FlowEntitiesService, never>;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { WritableSignal } from '@angular/core';
|
|
2
2
|
import { HandlePositions } from '../interfaces/handle-positions.interface';
|
|
3
|
+
import { Background } from '../types/background.type';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
export declare class FlowSettingsService {
|
|
5
6
|
entitiesSelectable: WritableSignal<boolean>;
|
|
@@ -23,6 +24,7 @@ export declare class FlowSettingsService {
|
|
|
23
24
|
computedFlowHeight: WritableSignal<number>;
|
|
24
25
|
minZoom: WritableSignal<number>;
|
|
25
26
|
maxZoom: WritableSignal<number>;
|
|
27
|
+
background: WritableSignal<Background>;
|
|
26
28
|
static ɵfac: i0.ɵɵFactoryDeclaration<FlowSettingsService, never>;
|
|
27
29
|
static ɵprov: i0.ɵɵInjectableDeclaration<FlowSettingsService>;
|
|
28
30
|
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { KeyboardAction, KeyboardShortcuts } from '../types/keyboard-action.type';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class KeyboardService {
|
|
4
|
+
private actions;
|
|
5
|
+
private actionsActive;
|
|
6
|
+
constructor();
|
|
7
|
+
setShortcuts(newActions: KeyboardShortcuts): void;
|
|
8
|
+
isActiveAction(action: KeyboardAction): boolean;
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<KeyboardService, never>;
|
|
10
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<KeyboardService>;
|
|
11
|
+
}
|
|
@@ -13,6 +13,7 @@ export interface ViewportForSelection {
|
|
|
13
13
|
export declare class SelectionService {
|
|
14
14
|
private static delta;
|
|
15
15
|
private flowEntitiesService;
|
|
16
|
+
private keyboardService;
|
|
16
17
|
protected viewport$: Subject<ViewportForSelection>;
|
|
17
18
|
protected resetSelection: import("rxjs").Subscription;
|
|
18
19
|
setViewport(viewport: ViewportForSelection): void;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function getOS(): "macos" | "ios" | "windows" | "android" | "linux" | null;
|
|
@@ -1,26 +1,28 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
2
|
import * as i1 from "./components/vflow/vflow.component";
|
|
3
3
|
import * as i2 from "./components/node/node.component";
|
|
4
|
-
import * as i3 from "./components/
|
|
5
|
-
import * as i4 from "./components/edge
|
|
6
|
-
import * as i5 from "./components/
|
|
7
|
-
import * as i6 from "./components/
|
|
8
|
-
import * as i7 from "./components/
|
|
9
|
-
import * as i8 from "./components/
|
|
10
|
-
import * as i9 from "./
|
|
11
|
-
import * as i10 from "./
|
|
12
|
-
import * as i11 from "./
|
|
13
|
-
import * as i12 from "./directives/
|
|
14
|
-
import * as i13 from "./directives/
|
|
15
|
-
import * as i14 from "./directives/
|
|
16
|
-
import * as i15 from "./directives/
|
|
17
|
-
import * as i16 from "./directives/
|
|
18
|
-
import * as i17 from "./directives/
|
|
19
|
-
import * as i18 from "./directives/
|
|
20
|
-
import * as i19 from "./directives/
|
|
21
|
-
import * as i20 from "
|
|
4
|
+
import * as i3 from "./components/default-node/default-node.component";
|
|
5
|
+
import * as i4 from "./components/edge/edge.component";
|
|
6
|
+
import * as i5 from "./components/edge-label/edge-label.component";
|
|
7
|
+
import * as i6 from "./components/connection/connection.component";
|
|
8
|
+
import * as i7 from "./components/handle/handle.component";
|
|
9
|
+
import * as i8 from "./components/defs/defs.component";
|
|
10
|
+
import * as i9 from "./components/background/background.component";
|
|
11
|
+
import * as i10 from "./public-components/resizable/resizable.component";
|
|
12
|
+
import * as i11 from "./public-components/minimap/minimap.component";
|
|
13
|
+
import * as i12 from "./directives/space-point-context.directive";
|
|
14
|
+
import * as i13 from "./directives/map-context.directive";
|
|
15
|
+
import * as i14 from "./directives/reference.directive";
|
|
16
|
+
import * as i15 from "./directives/root-svg-context.directive";
|
|
17
|
+
import * as i16 from "./directives/handle-size-controller.directive";
|
|
18
|
+
import * as i17 from "./directives/selectable.directive";
|
|
19
|
+
import * as i18 from "./directives/pointer.directive";
|
|
20
|
+
import * as i19 from "./directives/root-pointer.directive";
|
|
21
|
+
import * as i20 from "./directives/flow-size-controller.directive";
|
|
22
|
+
import * as i21 from "./directives/template.directive";
|
|
23
|
+
import * as i22 from "@angular/common";
|
|
22
24
|
export declare class VflowModule {
|
|
23
25
|
static ɵfac: i0.ɵɵFactoryDeclaration<VflowModule, never>;
|
|
24
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<VflowModule, [typeof i1.VflowComponent, typeof i2.NodeComponent, typeof i3.
|
|
26
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<VflowModule, [typeof i1.VflowComponent, typeof i2.NodeComponent, typeof i3.DefaultNodeComponent, typeof i4.EdgeComponent, typeof i5.EdgeLabelComponent, typeof i6.ConnectionComponent, typeof i7.HandleComponent, typeof i8.DefsComponent, typeof i9.BackgroundComponent, typeof i10.ResizableComponent, typeof i11.MiniMapComponent, typeof i12.SpacePointContextDirective, typeof i13.MapContextDirective, typeof i14.RootSvgReferenceDirective, typeof i15.RootSvgContextDirective, typeof i16.HandleSizeControllerDirective, typeof i17.SelectableDirective, typeof i18.PointerDirective, typeof i19.RootPointerDirective, typeof i20.FlowSizeControllerDirective, typeof i21.NodeHtmlTemplateDirective, typeof i21.GroupNodeTemplateDirective, typeof i21.EdgeLabelHtmlTemplateDirective, typeof i21.EdgeTemplateDirective, typeof i21.ConnectionTemplateDirective, typeof i21.HandleTemplateDirective], [typeof i22.CommonModule], [typeof i1.VflowComponent, typeof i7.HandleComponent, typeof i10.ResizableComponent, typeof i17.SelectableDirective, typeof i11.MiniMapComponent, typeof i21.NodeHtmlTemplateDirective, typeof i21.GroupNodeTemplateDirective, typeof i21.EdgeLabelHtmlTemplateDirective, typeof i21.EdgeTemplateDirective, typeof i21.ConnectionTemplateDirective, typeof i21.HandleTemplateDirective]>;
|
|
25
27
|
static ɵinj: i0.ɵɵInjectorDeclaration<VflowModule>;
|
|
26
28
|
}
|
package/package.json
CHANGED
package/public-api.d.ts
CHANGED
|
@@ -17,11 +17,13 @@ export * from './lib/vflow/types/edge-change.type';
|
|
|
17
17
|
export * from './lib/vflow/types/position.type';
|
|
18
18
|
export * from './lib/vflow/types/background.type';
|
|
19
19
|
export * from './lib/vflow/types/connection-mode.type';
|
|
20
|
+
export * from './lib/vflow/types/keyboard-action.type';
|
|
20
21
|
export * from './lib/vflow/components/vflow/vflow.component';
|
|
21
22
|
export * from './lib/vflow/components/handle/handle.component';
|
|
22
23
|
export * from './lib/vflow/public-components/custom-node/custom-node.component';
|
|
23
24
|
export * from './lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component';
|
|
24
25
|
export * from './lib/vflow/public-components/resizable/resizable.component';
|
|
26
|
+
export * from './lib/vflow/public-components/minimap/minimap.component';
|
|
25
27
|
export * from './lib/vflow/directives/template.directive';
|
|
26
28
|
export * from './lib/vflow/directives/connection-controller.directive';
|
|
27
29
|
export * from './lib/vflow/directives/changes-controller.directive';
|