ngx-vflow 0.12.0 → 0.13.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/custom-node-base/custom-node-base.component.mjs +7 -3
- package/esm2022/lib/vflow/components/node/node.component.mjs +3 -3
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +13 -4
- package/esm2022/lib/vflow/directives/flow-size-controller.directive.mjs +17 -16
- 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/interfaces/component-node-event.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/node.interface.mjs +3 -3
- package/esm2022/lib/vflow/models/node.model.mjs +3 -3
- package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs +19 -0
- package/esm2022/lib/vflow/public-components/custom-node/custom-node.component.mjs +19 -0
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +124 -180
- package/esm2022/lib/vflow/services/component-event-bus.service.mjs +1 -1
- package/esm2022/lib/vflow/services/draggable.service.mjs +40 -19
- 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/public-api.mjs +4 -3
- package/fesm2022/ngx-vflow.mjs +279 -231
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/vflow/vflow.component.d.ts +4 -1
- package/lib/vflow/directives/flow-size-controller.directive.d.ts +3 -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/interfaces/component-node-event.interface.d.ts +2 -2
- package/lib/vflow/interfaces/node.interface.d.ts +2 -2
- package/lib/vflow/models/edge.model.d.ts +17 -1
- package/lib/vflow/public-components/{custom-dynamic-node.component.d.ts → custom-dynamic-node/custom-dynamic-node.component.d.ts} +2 -2
- package/lib/vflow/public-components/{custom-node.component.d.ts → custom-node/custom-node.component.d.ts} +2 -2
- 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/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/package.json +1 -1
- package/public-api.d.ts +3 -2
- package/esm2022/lib/vflow/public-components/custom-dynamic-node.component.mjs +0 -19
- package/esm2022/lib/vflow/public-components/custom-node.component.mjs +0 -19
|
@@ -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
|
|
@@ -65,6 +67,7 @@ export declare class VflowComponent implements OnInit {
|
|
|
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
|
*
|
|
@@ -158,6 +161,6 @@ export declare class VflowComponent implements OnInit {
|
|
|
158
161
|
protected trackEdges(idx: number, { edge }: EdgeModel): Edge<unknown>;
|
|
159
162
|
private setInitialNodesOrder;
|
|
160
163
|
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"; }; }]>;
|
|
164
|
+
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
165
|
static ngAcceptInputType_connection: i3.ConnectionSettings;
|
|
163
166
|
}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
+
import { Signal } from '@angular/core';
|
|
1
2
|
import * as i0 from "@angular/core";
|
|
2
3
|
export declare class FlowSizeControllerDirective {
|
|
3
4
|
private host;
|
|
4
5
|
private flowSettingsService;
|
|
5
|
-
flowWidth: string | number
|
|
6
|
-
flowHeight: string | number
|
|
6
|
+
flowWidth: Signal<string | number>;
|
|
7
|
+
flowHeight: Signal<string | number>;
|
|
7
8
|
constructor();
|
|
8
9
|
static ɵfac: i0.ɵɵFactoryDeclaration<FlowSizeControllerDirective, never>;
|
|
9
10
|
static ɵdir: i0.ɵɵDirectiveDeclaration<FlowSizeControllerDirective, "svg[flowSizeController]", never, {}, {}, never, never, false, never>;
|
|
@@ -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>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { EventEmitter } from "@angular/core";
|
|
2
|
-
import { CustomNodeComponent } from "../public-components/custom-node.component";
|
|
3
|
-
import { CustomDynamicNodeComponent } from "../public-components/custom-dynamic-node.component";
|
|
2
|
+
import { CustomNodeComponent } from "../public-components/custom-node/custom-node.component";
|
|
3
|
+
import { CustomDynamicNodeComponent } from "../public-components/custom-dynamic-node/custom-dynamic-node.component";
|
|
4
4
|
type EventInfo<T> = T extends EventEmitter<infer U> ? U : never;
|
|
5
5
|
type EventKeys<T> = {
|
|
6
6
|
[K in keyof T]: T[K] extends EventEmitter<any> ? K : never;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Type, WritableSignal } from "@angular/core";
|
|
2
2
|
import { Point } from "./point.interface";
|
|
3
|
-
import { CustomNodeComponent } from "../public-components/custom-node.component";
|
|
4
|
-
import { CustomDynamicNodeComponent } from "../public-components/custom-dynamic-node.component";
|
|
3
|
+
import { CustomNodeComponent } from "../public-components/custom-node/custom-node.component";
|
|
4
|
+
import { CustomDynamicNodeComponent } from "../public-components/custom-dynamic-node/custom-dynamic-node.component";
|
|
5
5
|
export type Node<T = unknown> = DefaultNode | HtmlTemplateNode<T> | ComponentNode<T> | DefaultGroupNode | TemplateGroupNode<T>;
|
|
6
6
|
export type DynamicNode<T = unknown> = DefaultDynamicNode | HtmlTemplateDynamicNode<T> | ComponentDynamicNode<T> | DefaultDynamicGroupNode | TemplateDynamicGroupNode<T>;
|
|
7
7
|
export interface SharedNode {
|
|
@@ -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
|
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { OnInit } from "@angular/core";
|
|
2
|
-
import { ComponentDynamicNode } from '
|
|
3
|
-
import { CustomNodeBaseComponent } from "
|
|
2
|
+
import { ComponentDynamicNode } from '../../interfaces/node.interface';
|
|
3
|
+
import { CustomNodeBaseComponent } from "../../components/custom-node-base/custom-node-base.component";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare abstract class CustomDynamicNodeComponent<T = unknown> extends CustomNodeBaseComponent<T> implements OnInit {
|
|
6
6
|
/**
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { OnInit } from "@angular/core";
|
|
2
|
-
import { ComponentNode } from '
|
|
3
|
-
import { CustomNodeBaseComponent } from "
|
|
2
|
+
import { ComponentNode } from '../../interfaces/node.interface';
|
|
3
|
+
import { CustomNodeBaseComponent } from "../../components/custom-node-base/custom-node-base.component";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare abstract class CustomNodeComponent<T = unknown> extends CustomNodeBaseComponent<T> implements OnInit {
|
|
6
6
|
/**
|
|
@@ -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
|
}
|
|
@@ -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;
|
package/package.json
CHANGED
package/public-api.d.ts
CHANGED
|
@@ -17,10 +17,11 @@ 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
|
-
export * from './lib/vflow/public-components/custom-node.component';
|
|
23
|
-
export * from './lib/vflow/public-components/custom-dynamic-node.component';
|
|
23
|
+
export * from './lib/vflow/public-components/custom-node/custom-node.component';
|
|
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';
|
|
25
26
|
export * from './lib/vflow/directives/template.directive';
|
|
26
27
|
export * from './lib/vflow/directives/connection-controller.directive';
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { Directive, Input } from "@angular/core";
|
|
2
|
-
import { CustomNodeBaseComponent } from "../components/custom-node-base/custom-node-base.component";
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class CustomDynamicNodeComponent extends CustomNodeBaseComponent {
|
|
5
|
-
ngOnInit() {
|
|
6
|
-
if (this.node.data) {
|
|
7
|
-
this.data = this.node.data;
|
|
8
|
-
}
|
|
9
|
-
super.ngOnInit();
|
|
10
|
-
}
|
|
11
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomDynamicNodeComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
12
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CustomDynamicNodeComponent, inputs: { node: "node" }, usesInheritance: true, ngImport: i0 }); }
|
|
13
|
-
}
|
|
14
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomDynamicNodeComponent, decorators: [{
|
|
15
|
-
type: Directive
|
|
16
|
-
}], propDecorators: { node: [{
|
|
17
|
-
type: Input
|
|
18
|
-
}] } });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWR5bmFtaWMtbm9kZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvcHVibGljLWNvbXBvbmVudHMvY3VzdG9tLWR5bmFtaWMtbm9kZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUE7QUFFeEQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMkRBQTJELENBQUM7O0FBR3BHLE1BQU0sT0FBZ0IsMEJBQXdDLFNBQVEsdUJBQTBCO0lBTzlFLFFBQVE7UUFDdEIsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRTtZQUNsQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFBO1NBQzNCO1FBRUQsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFBO0lBQ2xCLENBQUM7K0dBYm1CLDBCQUEwQjttR0FBMUIsMEJBQTBCOzs0RkFBMUIsMEJBQTBCO2tCQUQvQyxTQUFTOzhCQU1RLElBQUk7c0JBRG5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0LCBPbkluaXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5pbXBvcnQgeyBDb21wb25lbnREeW5hbWljTm9kZSB9IGZyb20gJy4uL2ludGVyZmFjZXMvbm9kZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgQ3VzdG9tTm9kZUJhc2VDb21wb25lbnQgfSBmcm9tIFwiLi4vY29tcG9uZW50cy9jdXN0b20tbm9kZS1iYXNlL2N1c3RvbS1ub2RlLWJhc2UuY29tcG9uZW50XCI7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEN1c3RvbUR5bmFtaWNOb2RlQ29tcG9uZW50PFQgPSB1bmtub3duPiBleHRlbmRzIEN1c3RvbU5vZGVCYXNlQ29tcG9uZW50PFQ+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqXG4gICAqIFJlZmVyZW5jZSB0byBub2RlIGJvdW5kIHRvIHRoaXMgY29tcG9uZW50XG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgb3ZlcnJpZGUgbm9kZSE6IENvbXBvbmVudER5bmFtaWNOb2RlPFQ+XG5cbiAgcHVibGljIG92ZXJyaWRlIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLm5vZGUuZGF0YSkge1xuICAgICAgdGhpcy5kYXRhID0gdGhpcy5ub2RlLmRhdGFcbiAgICB9XG5cbiAgICBzdXBlci5uZ09uSW5pdCgpXG4gIH1cbn1cblxuIl19
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { Directive, Input } from "@angular/core";
|
|
2
|
-
import { CustomNodeBaseComponent } from "../components/custom-node-base/custom-node-base.component";
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class CustomNodeComponent extends CustomNodeBaseComponent {
|
|
5
|
-
ngOnInit() {
|
|
6
|
-
if (this.node.data) {
|
|
7
|
-
this.data.set(this.node.data);
|
|
8
|
-
}
|
|
9
|
-
super.ngOnInit();
|
|
10
|
-
}
|
|
11
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomNodeComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
12
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CustomNodeComponent, inputs: { node: "node" }, usesInheritance: true, ngImport: i0 }); }
|
|
13
|
-
}
|
|
14
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomNodeComponent, decorators: [{
|
|
15
|
-
type: Directive
|
|
16
|
-
}], propDecorators: { node: [{
|
|
17
|
-
type: Input
|
|
18
|
-
}] } });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLW5vZGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L3B1YmxpYy1jb21wb25lbnRzL2N1c3RvbS1ub2RlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQTtBQUV4RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwyREFBMkQsQ0FBQzs7QUFHcEcsTUFBTSxPQUFnQixtQkFBaUMsU0FBUSx1QkFBMEI7SUFPdkUsUUFBUTtRQUN0QixJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ2xCLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7U0FDOUI7UUFFRCxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUE7SUFDbEIsQ0FBQzsrR0FibUIsbUJBQW1CO21HQUFuQixtQkFBbUI7OzRGQUFuQixtQkFBbUI7a0JBRHhDLFNBQVM7OEJBTVEsSUFBSTtzQkFEbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQsIE9uSW5pdCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcbmltcG9ydCB7IENvbXBvbmVudE5vZGUgfSBmcm9tICcuLi9pbnRlcmZhY2VzL25vZGUuaW50ZXJmYWNlJztcbmltcG9ydCB7IEN1c3RvbU5vZGVCYXNlQ29tcG9uZW50IH0gZnJvbSBcIi4uL2NvbXBvbmVudHMvY3VzdG9tLW5vZGUtYmFzZS9jdXN0b20tbm9kZS1iYXNlLmNvbXBvbmVudFwiO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBDdXN0b21Ob2RlQ29tcG9uZW50PFQgPSB1bmtub3duPiBleHRlbmRzIEN1c3RvbU5vZGVCYXNlQ29tcG9uZW50PFQ+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqXG4gICAqIFJlZmVyZW5jZSB0byBub2RlIGJvdW5kIHRvIHRoaXMgY29tcG9uZW50XG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgb3ZlcnJpZGUgbm9kZSE6IENvbXBvbmVudE5vZGU8VD5cblxuICBwdWJsaWMgb3ZlcnJpZGUgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMubm9kZS5kYXRhKSB7XG4gICAgICB0aGlzLmRhdGEuc2V0KHRoaXMubm9kZS5kYXRhKVxuICAgIH1cblxuICAgIHN1cGVyLm5nT25Jbml0KClcbiAgfVxufVxuXG4iXX0=
|