ngx-vflow 0.14.0 → 0.15.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 +5 -7
- package/esm2022/lib/vflow/components/defs/defs.component.mjs +1 -1
- package/esm2022/lib/vflow/components/handle/handle.component.mjs +16 -14
- package/esm2022/lib/vflow/components/node/node.component.mjs +8 -3
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +8 -5
- package/esm2022/lib/vflow/directives/drag-handle.directive.mjs +27 -0
- package/esm2022/lib/vflow/directives/map-context.directive.mjs +24 -17
- package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +14 -17
- package/esm2022/lib/vflow/math/edge-path/straigh-path.mjs +2 -6
- package/esm2022/lib/vflow/models/handle.model.mjs +3 -2
- package/esm2022/lib/vflow/models/node.model.mjs +2 -1
- package/esm2022/lib/vflow/models/toolbar.model.mjs +36 -0
- package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +1 -1
- package/esm2022/lib/vflow/public-components/node-toolbar/node-toolbar.component.mjs +66 -0
- package/esm2022/lib/vflow/services/draggable.service.mjs +13 -15
- package/esm2022/lib/vflow/services/overlays.service.mjs +34 -0
- package/esm2022/lib/vflow/testing-utils/provide-custom-node-mocks.mjs +67 -0
- package/esm2022/lib/vflow/vflow.module.mjs +21 -9
- package/esm2022/public-api.mjs +5 -1
- package/fesm2022/ngx-vflow.mjs +308 -87
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/handle/handle.component.d.ts +3 -3
- package/lib/vflow/components/node/node.component.d.ts +2 -0
- package/lib/vflow/directives/drag-handle.directive.d.ts +8 -0
- package/lib/vflow/directives/map-context.directive.d.ts +3 -2
- package/lib/vflow/models/handle.model.d.ts +1 -0
- package/lib/vflow/models/node.model.d.ts +1 -0
- package/lib/vflow/models/toolbar.model.d.ts +19 -0
- package/lib/vflow/public-components/node-toolbar/node-toolbar.component.d.ts +22 -0
- package/lib/vflow/services/draggable.service.d.ts +0 -5
- package/lib/vflow/services/overlays.service.d.ts +11 -0
- package/lib/vflow/testing-utils/provide-custom-node-mocks.d.ts +2 -0
- package/lib/vflow/vflow.module.d.ts +14 -12
- package/package.json +1 -3
- package/public-api.d.ts +3 -0
|
@@ -15,8 +15,8 @@ export class DraggableService {
|
|
|
15
15
|
* @param model model with data for this element
|
|
16
16
|
*/
|
|
17
17
|
enable(element, model) {
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
select(element)
|
|
19
|
+
.call(this.getDragBehavior(model));
|
|
20
20
|
}
|
|
21
21
|
/**
|
|
22
22
|
* Disable draggable behavior for element.
|
|
@@ -25,8 +25,8 @@ export class DraggableService {
|
|
|
25
25
|
* @param model model with data for this element
|
|
26
26
|
*/
|
|
27
27
|
disable(element) {
|
|
28
|
-
|
|
29
|
-
|
|
28
|
+
select(element)
|
|
29
|
+
.call(drag().on('drag', null));
|
|
30
30
|
}
|
|
31
31
|
/**
|
|
32
32
|
* TODO: not shure if this work, need to check
|
|
@@ -45,7 +45,15 @@ export class DraggableService {
|
|
|
45
45
|
getDragBehavior(model) {
|
|
46
46
|
let dragNodes = [];
|
|
47
47
|
let initialPositions = [];
|
|
48
|
+
const filterCondition = (event) => {
|
|
49
|
+
// if there is at least one drag handle, we should check if we are dragging it
|
|
50
|
+
if (model.dragHandlesCount()) {
|
|
51
|
+
return !!event.target.closest('.vflow-drag-handle');
|
|
52
|
+
}
|
|
53
|
+
return true;
|
|
54
|
+
};
|
|
48
55
|
return drag()
|
|
56
|
+
.filter(filterCondition)
|
|
49
57
|
.on('start', (event) => {
|
|
50
58
|
dragNodes = this.getDragNodes(model);
|
|
51
59
|
initialPositions = dragNodes.map(node => ({
|
|
@@ -63,16 +71,6 @@ export class DraggableService {
|
|
|
63
71
|
});
|
|
64
72
|
});
|
|
65
73
|
}
|
|
66
|
-
/**
|
|
67
|
-
* Specify ignoring drag behavior. It's responsible for not moving the map when user tries to drag node
|
|
68
|
-
* with disabled drag behavior
|
|
69
|
-
*/
|
|
70
|
-
getIgnoreDragBehavior() {
|
|
71
|
-
return drag()
|
|
72
|
-
.on('drag', (event) => {
|
|
73
|
-
event.sourceEvent.stopPropagation();
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
74
|
getDragNodes(model) {
|
|
77
75
|
return model.selected()
|
|
78
76
|
? this.entitiesService
|
|
@@ -99,4 +97,4 @@ function moveNode(model, point) {
|
|
|
99
97
|
}
|
|
100
98
|
model.setPoint(point, true);
|
|
101
99
|
}
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draggable.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/services/draggable.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, effect, inject } from '@angular/core';\nimport { select } from 'd3-selection';\nimport { D3DragEvent, drag } from 'd3-drag';\nimport { NodeModel } from '../models/node.model';\nimport { round } from '../utils/round';\nimport { FlowEntitiesService } from './flow-entities.service';\nimport { Point } from '../interfaces/point.interface';\n\ntype DragEvent = D3DragEvent<Element, unknown, unknown>\n\n@Injectable()\nexport class DraggableService {\n  private entitiesService = inject(FlowEntitiesService);\n\n  /**\n   * Enable draggable behavior for element.\n   *\n   * @param element target element for toggling draggable\n   * @param model model with data for this element\n   */\n  public enable(element: Element, model: NodeModel) {\n    select(element)\n      .call(this.getDragBehavior(model))\n  }\n\n  /**\n   * Disable draggable behavior for element.\n   *\n   * @param element target element for toggling draggable\n   * @param model model with data for this element\n   */\n  public disable(element: Element) {\n    select(element)\n      .call(drag().on('drag', null))\n  }\n\n  /**\n   * TODO: not shure if this work, need to check\n   *\n   * @param element\n   */\n  public destroy(element: Element) {\n    select(element).on('.drag', null)\n  }\n\n  /**\n   * Node drag behavior. Updated node's coordinate according to dragging\n   *\n   * @param model\n   * @returns\n   */\n  private getDragBehavior(model: NodeModel) {\n    let dragNodes: NodeModel[] = []\n    let initialPositions: Point[] = []\n\n    const filterCondition = (event: Event) => {\n      // if there is at least one drag handle, we should check if we are dragging it\n      if (model.dragHandlesCount()) {\n        return !!(event.target as Element).closest('.vflow-drag-handle')\n      }\n\n      return true\n    }\n\n    return drag()\n      .filter(filterCondition)\n      .on('start', (event: DragEvent) => {\n        dragNodes = this.getDragNodes(model)\n\n        initialPositions = dragNodes.map(node => ({\n          x: node.point().x - event.x,\n          y: node.point().y - event.y\n        }))\n      })\n\n      .on('drag', (event: DragEvent) => {\n        dragNodes.forEach((model, index) => {\n          let point = {\n            x: round(event.x + initialPositions[index].x),\n            y: round(event.y + initialPositions[index].y)\n          }\n\n          moveNode(model, point)\n        })\n      })\n  }\n\n  private getDragNodes(model: NodeModel) {\n    return model.selected()\n      ? this.entitiesService\n        .nodes()\n        // selected draggable nodes (with current node)\n        .filter(node => node.selected() && node.draggable())\n      // we only can move current node if it's not selected\n      : [model]\n  }\n\n\n}\n\nfunction moveNode(model: NodeModel, point: Point) {\n  const parent = model.parent()\n  // keep node in bounds of parent\n  if (parent) {\n    point.x = Math.min(parent.size().width - model.size().width, point.x)\n    point.x = Math.max(0, point.x)\n\n    point.y = Math.min(parent.size().height - model.size().height, point.y)\n    point.y = Math.max(0, point.y)\n  }\n\n  model.setPoint(point, true)\n}\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { computed, Injectable, signal } from '@angular/core';
|
|
3
|
+
import { Microtask } from '../decorators/microtask.decorator';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class OverlaysService {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.toolbars = signal([]);
|
|
8
|
+
this.nodeToolbars = computed(() => {
|
|
9
|
+
const map = new Map();
|
|
10
|
+
this.toolbars().forEach((toolbar) => {
|
|
11
|
+
map.set(toolbar.node, toolbar);
|
|
12
|
+
});
|
|
13
|
+
return map;
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
addToolbar(toolbar) {
|
|
17
|
+
this.toolbars.update((toolbars) => [...toolbars, toolbar]);
|
|
18
|
+
}
|
|
19
|
+
removeToolbar(toolbar) {
|
|
20
|
+
this.toolbars.update((toolbars) => toolbars.filter(t => t !== toolbar));
|
|
21
|
+
}
|
|
22
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: OverlaysService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
23
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: OverlaysService }); }
|
|
24
|
+
}
|
|
25
|
+
__decorate([
|
|
26
|
+
Microtask
|
|
27
|
+
], OverlaysService.prototype, "addToolbar", null);
|
|
28
|
+
__decorate([
|
|
29
|
+
Microtask
|
|
30
|
+
], OverlaysService.prototype, "removeToolbar", null);
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: OverlaysService, decorators: [{
|
|
32
|
+
type: Injectable
|
|
33
|
+
}], propDecorators: { addToolbar: [], removeToolbar: [] } });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheXMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9zZXJ2aWNlcy9vdmVybGF5cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHN0QsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDOztBQUc5RCxNQUFNLE9BQU8sZUFBZTtJQUQ1QjtRQUVVLGFBQVEsR0FBRyxNQUFNLENBQWlCLEVBQUUsQ0FBQyxDQUFDO1FBRXZDLGlCQUFZLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNsQyxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsRUFBMkIsQ0FBQTtZQUU5QyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7Z0JBQ2xDLEdBQUcsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQTtZQUNoQyxDQUFDLENBQUMsQ0FBQTtZQUVGLE9BQU8sR0FBRyxDQUFBO1FBQ1osQ0FBQyxDQUFDLENBQUE7S0FXSDtJQVJRLFVBQVUsQ0FBQyxPQUFxQjtRQUNyQyxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLFFBQVEsRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFHTSxhQUFhLENBQUMsT0FBcUI7UUFDeEMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQztJQUMxRSxDQUFDOytHQXJCVSxlQUFlO21IQUFmLGVBQWU7O0FBY25CO0lBRE4sU0FBUztpREFHVDtBQUdNO0lBRE4sU0FBUztvREFHVDs0RkFyQlUsZUFBZTtrQkFEM0IsVUFBVTs4QkFlRixVQUFVLE1BS1YsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvbXB1dGVkLCBJbmplY3RhYmxlLCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRvb2xiYXJNb2RlbCB9IGZyb20gJy4uL21vZGVscy90b29sYmFyLm1vZGVsJztcbmltcG9ydCB7IE5vZGVNb2RlbCB9IGZyb20gJy4uL21vZGVscy9ub2RlLm1vZGVsJztcbmltcG9ydCB7IE1pY3JvdGFzayB9IGZyb20gJy4uL2RlY29yYXRvcnMvbWljcm90YXNrLmRlY29yYXRvcic7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBPdmVybGF5c1NlcnZpY2Uge1xuICBwcml2YXRlIHRvb2xiYXJzID0gc2lnbmFsPFRvb2xiYXJNb2RlbFtdPihbXSk7XG5cbiAgcHVibGljIG5vZGVUb29sYmFycyA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBtYXAgPSBuZXcgTWFwPE5vZGVNb2RlbCwgVG9vbGJhck1vZGVsPigpXG5cbiAgICB0aGlzLnRvb2xiYXJzKCkuZm9yRWFjaCgodG9vbGJhcikgPT4ge1xuICAgICAgbWFwLnNldCh0b29sYmFyLm5vZGUsIHRvb2xiYXIpXG4gICAgfSlcblxuICAgIHJldHVybiBtYXBcbiAgfSlcblxuICBATWljcm90YXNrXG4gIHB1YmxpYyBhZGRUb29sYmFyKHRvb2xiYXI6IFRvb2xiYXJNb2RlbCk6IHZvaWQge1xuICAgIHRoaXMudG9vbGJhcnMudXBkYXRlKCh0b29sYmFycykgPT4gWy4uLnRvb2xiYXJzLCB0b29sYmFyXSk7XG4gIH1cblxuICBATWljcm90YXNrXG4gIHB1YmxpYyByZW1vdmVUb29sYmFyKHRvb2xiYXI6IFRvb2xiYXJNb2RlbCk6IHZvaWQge1xuICAgIHRoaXMudG9vbGJhcnMudXBkYXRlKCh0b29sYmFycykgPT4gdG9vbGJhcnMuZmlsdGVyKHQgPT4gdCAhPT0gdG9vbGJhcikpO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { signal } from "@angular/core";
|
|
2
|
+
import { ComponentEventBusService } from "../services/component-event-bus.service";
|
|
3
|
+
import { HandleService } from "../services/handle.service";
|
|
4
|
+
import { NodeModel } from "../models/node.model";
|
|
5
|
+
import { FlowSettingsService } from "../services/flow-settings.service";
|
|
6
|
+
import { FlowEntitiesService } from "../services/flow-entities.service";
|
|
7
|
+
import { NodeAccessorService } from "../services/node-accessor.service";
|
|
8
|
+
import { RootPointerDirective } from "../directives/root-pointer.directive";
|
|
9
|
+
import { of } from "rxjs";
|
|
10
|
+
import { ViewportService } from "../services/viewport.service";
|
|
11
|
+
import { SpacePointContextDirective } from "../directives/space-point-context.directive";
|
|
12
|
+
import { SelectionService } from "../services/selection.service";
|
|
13
|
+
const mockModel = () => new NodeModel({ id: 'mock', type: 'default', point: { x: 0, y: 0 } });
|
|
14
|
+
export function provideCustomNodeMocks() {
|
|
15
|
+
return [
|
|
16
|
+
{
|
|
17
|
+
provide: ComponentEventBusService,
|
|
18
|
+
useValue: {
|
|
19
|
+
pushEvent: () => { }
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
provide: HandleService,
|
|
24
|
+
useFactory: () => ({
|
|
25
|
+
node: signal(mockModel()),
|
|
26
|
+
createHandle: () => { },
|
|
27
|
+
destroyHandle: () => { },
|
|
28
|
+
})
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
provide: RootPointerDirective,
|
|
32
|
+
useValue: {
|
|
33
|
+
pointerMovement$: of({
|
|
34
|
+
x: 0,
|
|
35
|
+
y: 0,
|
|
36
|
+
movementX: 0,
|
|
37
|
+
movementY: 0,
|
|
38
|
+
target: null,
|
|
39
|
+
originalEvent: null
|
|
40
|
+
}),
|
|
41
|
+
documentPointerEnd$: of(null)
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
provide: SpacePointContextDirective,
|
|
46
|
+
useValue: {
|
|
47
|
+
documentPointToFlowPoint: (point) => point
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
provide: NodeAccessorService,
|
|
52
|
+
useFactory: () => ({
|
|
53
|
+
model: signal(mockModel())
|
|
54
|
+
})
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
provide: SelectionService,
|
|
58
|
+
useValue: {
|
|
59
|
+
select: () => { },
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
FlowSettingsService,
|
|
63
|
+
FlowEntitiesService,
|
|
64
|
+
ViewportService
|
|
65
|
+
];
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1jdXN0b20tbm9kZS1tb2Nrcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy90ZXN0aW5nLXV0aWxzL3Byb3ZpZGUtY3VzdG9tLW5vZGUtbW9ja3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFZLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNuRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDMUIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQy9ELE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBRXpGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBRWpFLE1BQU0sU0FBUyxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksU0FBUyxDQUFDLEVBQUUsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUU3RixNQUFNLFVBQVUsc0JBQXNCO0lBQ3BDLE9BQU87UUFDTDtZQUNFLE9BQU8sRUFBRSx3QkFBd0I7WUFDakMsUUFBUSxFQUFFO2dCQUNSLFNBQVMsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDO2FBQ3JCO1NBQ0Y7UUFDRDtZQUNFLE9BQU8sRUFBRSxhQUFhO1lBQ3RCLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO2dCQUNqQixJQUFJLEVBQUUsTUFBTSxDQUFDLFNBQVMsRUFBRSxDQUFDO2dCQUN6QixZQUFZLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQztnQkFDdkIsYUFBYSxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUM7YUFDekIsQ0FBQztTQUNIO1FBQ0Q7WUFDRSxPQUFPLEVBQUUsb0JBQW9CO1lBQzdCLFFBQVEsRUFBRTtnQkFDUixnQkFBZ0IsRUFBRSxFQUFFLENBQUM7b0JBQ25CLENBQUMsRUFBRSxDQUFDO29CQUNKLENBQUMsRUFBRSxDQUFDO29CQUNKLFNBQVMsRUFBRSxDQUFDO29CQUNaLFNBQVMsRUFBRSxDQUFDO29CQUNaLE1BQU0sRUFBRSxJQUFJO29CQUNaLGFBQWEsRUFBRSxJQUFJO2lCQUNwQixDQUFDO2dCQUNGLG1CQUFtQixFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUM7YUFDOUI7U0FDRjtRQUNEO1lBQ0UsT0FBTyxFQUFFLDBCQUEwQjtZQUNuQyxRQUFRLEVBQUU7Z0JBQ1Isd0JBQXdCLEVBQUUsQ0FBQyxLQUFZLEVBQUUsRUFBRSxDQUFDLEtBQUs7YUFDbEQ7U0FDRjtRQUNEO1lBQ0UsT0FBTyxFQUFFLG1CQUFtQjtZQUM1QixVQUFVLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztnQkFDakIsS0FBSyxFQUFFLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQzthQUMzQixDQUFDO1NBQ0g7UUFDRDtZQUNFLE9BQU8sRUFBRSxnQkFBZ0I7WUFDekIsUUFBUSxFQUFFO2dCQUNSLE1BQU0sRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDO2FBQ2xCO1NBQ0Y7UUFDRCxtQkFBbUI7UUFDbkIsbUJBQW1CO1FBQ25CLGVBQWU7S0FDaEIsQ0FBQTtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm92aWRlciwgc2lnbmFsIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IENvbXBvbmVudEV2ZW50QnVzU2VydmljZSB9IGZyb20gXCIuLi9zZXJ2aWNlcy9jb21wb25lbnQtZXZlbnQtYnVzLnNlcnZpY2VcIjtcbmltcG9ydCB7IEhhbmRsZVNlcnZpY2UgfSBmcm9tIFwiLi4vc2VydmljZXMvaGFuZGxlLnNlcnZpY2VcIjtcbmltcG9ydCB7IE5vZGVNb2RlbCB9IGZyb20gXCIuLi9tb2RlbHMvbm9kZS5tb2RlbFwiO1xuaW1wb3J0IHsgRmxvd1NldHRpbmdzU2VydmljZSB9IGZyb20gXCIuLi9zZXJ2aWNlcy9mbG93LXNldHRpbmdzLnNlcnZpY2VcIjtcbmltcG9ydCB7IEZsb3dFbnRpdGllc1NlcnZpY2UgfSBmcm9tIFwiLi4vc2VydmljZXMvZmxvdy1lbnRpdGllcy5zZXJ2aWNlXCI7XG5pbXBvcnQgeyBOb2RlQWNjZXNzb3JTZXJ2aWNlIH0gZnJvbSBcIi4uL3NlcnZpY2VzL25vZGUtYWNjZXNzb3Iuc2VydmljZVwiO1xuaW1wb3J0IHsgUm9vdFBvaW50ZXJEaXJlY3RpdmUgfSBmcm9tIFwiLi4vZGlyZWN0aXZlcy9yb290LXBvaW50ZXIuZGlyZWN0aXZlXCI7XG5pbXBvcnQgeyBvZiB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyBWaWV3cG9ydFNlcnZpY2UgfSBmcm9tIFwiLi4vc2VydmljZXMvdmlld3BvcnQuc2VydmljZVwiO1xuaW1wb3J0IHsgU3BhY2VQb2ludENvbnRleHREaXJlY3RpdmUgfSBmcm9tIFwiLi4vZGlyZWN0aXZlcy9zcGFjZS1wb2ludC1jb250ZXh0LmRpcmVjdGl2ZVwiO1xuaW1wb3J0IHsgUG9pbnQgfSBmcm9tIFwiLi4vaW50ZXJmYWNlcy9wb2ludC5pbnRlcmZhY2VcIjtcbmltcG9ydCB7IFNlbGVjdGlvblNlcnZpY2UgfSBmcm9tIFwiLi4vc2VydmljZXMvc2VsZWN0aW9uLnNlcnZpY2VcIjtcblxuY29uc3QgbW9ja01vZGVsID0gKCkgPT4gbmV3IE5vZGVNb2RlbCh7IGlkOiAnbW9jaycsIHR5cGU6ICdkZWZhdWx0JywgcG9pbnQ6IHsgeDogMCwgeTogMCB9IH0pXG5cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlQ3VzdG9tTm9kZU1vY2tzKCk6IFByb3ZpZGVyW10ge1xuICByZXR1cm4gW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IENvbXBvbmVudEV2ZW50QnVzU2VydmljZSxcbiAgICAgIHVzZVZhbHVlOiB7XG4gICAgICAgIHB1c2hFdmVudDogKCkgPT4geyB9XG4gICAgICB9XG4gICAgfSxcbiAgICB7XG4gICAgICBwcm92aWRlOiBIYW5kbGVTZXJ2aWNlLFxuICAgICAgdXNlRmFjdG9yeTogKCkgPT4gKHtcbiAgICAgICAgbm9kZTogc2lnbmFsKG1vY2tNb2RlbCgpKSxcbiAgICAgICAgY3JlYXRlSGFuZGxlOiAoKSA9PiB7IH0sXG4gICAgICAgIGRlc3Ryb3lIYW5kbGU6ICgpID0+IHsgfSxcbiAgICAgIH0pXG4gICAgfSxcbiAgICB7XG4gICAgICBwcm92aWRlOiBSb290UG9pbnRlckRpcmVjdGl2ZSxcbiAgICAgIHVzZVZhbHVlOiB7XG4gICAgICAgIHBvaW50ZXJNb3ZlbWVudCQ6IG9mKHtcbiAgICAgICAgICB4OiAwLFxuICAgICAgICAgIHk6IDAsXG4gICAgICAgICAgbW92ZW1lbnRYOiAwLFxuICAgICAgICAgIG1vdmVtZW50WTogMCxcbiAgICAgICAgICB0YXJnZXQ6IG51bGwsXG4gICAgICAgICAgb3JpZ2luYWxFdmVudDogbnVsbFxuICAgICAgICB9KSxcbiAgICAgICAgZG9jdW1lbnRQb2ludGVyRW5kJDogb2YobnVsbClcbiAgICAgIH1cbiAgICB9LFxuICAgIHtcbiAgICAgIHByb3ZpZGU6IFNwYWNlUG9pbnRDb250ZXh0RGlyZWN0aXZlLFxuICAgICAgdXNlVmFsdWU6IHtcbiAgICAgICAgZG9jdW1lbnRQb2ludFRvRmxvd1BvaW50OiAocG9pbnQ6IFBvaW50KSA9PiBwb2ludFxuICAgICAgfVxuICAgIH0sXG4gICAge1xuICAgICAgcHJvdmlkZTogTm9kZUFjY2Vzc29yU2VydmljZSxcbiAgICAgIHVzZUZhY3Rvcnk6ICgpID0+ICh7XG4gICAgICAgIG1vZGVsOiBzaWduYWwobW9ja01vZGVsKCkpXG4gICAgICB9KVxuICAgIH0sXG4gICAge1xuICAgICAgcHJvdmlkZTogU2VsZWN0aW9uU2VydmljZSxcbiAgICAgIHVzZVZhbHVlOiB7XG4gICAgICAgIHNlbGVjdDogKCkgPT4geyB9LFxuICAgICAgfVxuICAgIH0sXG4gICAgRmxvd1NldHRpbmdzU2VydmljZSxcbiAgICBGbG93RW50aXRpZXNTZXJ2aWNlLFxuICAgIFZpZXdwb3J0U2VydmljZVxuICBdXG59XG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { KeyValuePipe, NgComponentOutlet, NgFor, NgIf, NgTemplateOutlet } from '@angular/common';
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
3
|
import { VflowComponent } from './components/vflow/vflow.component';
|
|
4
4
|
import { NodeComponent } from './components/node/node.component';
|
|
@@ -21,6 +21,8 @@ import { FlowSizeControllerDirective } from './directives/flow-size-controller.d
|
|
|
21
21
|
import { ResizableComponent } from './public-components/resizable/resizable.component';
|
|
22
22
|
import { MiniMapComponent } from './public-components/minimap/minimap.component';
|
|
23
23
|
import { DefaultNodeComponent } from './components/default-node/default-node.component';
|
|
24
|
+
import { NodeToolbarComponent, NodeToolbarWrapperDirective } from './public-components/node-toolbar/node-toolbar.component';
|
|
25
|
+
import { DragHandleDirective } from './directives/drag-handle.directive';
|
|
24
26
|
import * as i0 from "@angular/core";
|
|
25
27
|
const components = [
|
|
26
28
|
VflowComponent,
|
|
@@ -33,7 +35,8 @@ const components = [
|
|
|
33
35
|
DefsComponent,
|
|
34
36
|
BackgroundComponent,
|
|
35
37
|
ResizableComponent,
|
|
36
|
-
MiniMapComponent
|
|
38
|
+
MiniMapComponent,
|
|
39
|
+
NodeToolbarComponent
|
|
37
40
|
];
|
|
38
41
|
const directives = [
|
|
39
42
|
SpacePointContextDirective,
|
|
@@ -42,9 +45,11 @@ const directives = [
|
|
|
42
45
|
RootSvgContextDirective,
|
|
43
46
|
HandleSizeControllerDirective,
|
|
44
47
|
SelectableDirective,
|
|
48
|
+
DragHandleDirective,
|
|
45
49
|
PointerDirective,
|
|
46
50
|
RootPointerDirective,
|
|
47
51
|
FlowSizeControllerDirective,
|
|
52
|
+
NodeToolbarWrapperDirective
|
|
48
53
|
];
|
|
49
54
|
const templateDirectives = [
|
|
50
55
|
NodeHtmlTemplateDirective,
|
|
@@ -66,44 +71,51 @@ export class VflowModule {
|
|
|
66
71
|
DefsComponent,
|
|
67
72
|
BackgroundComponent,
|
|
68
73
|
ResizableComponent,
|
|
69
|
-
MiniMapComponent,
|
|
74
|
+
MiniMapComponent,
|
|
75
|
+
NodeToolbarComponent, SpacePointContextDirective,
|
|
70
76
|
MapContextDirective,
|
|
71
77
|
RootSvgReferenceDirective,
|
|
72
78
|
RootSvgContextDirective,
|
|
73
79
|
HandleSizeControllerDirective,
|
|
74
80
|
SelectableDirective,
|
|
81
|
+
DragHandleDirective,
|
|
75
82
|
PointerDirective,
|
|
76
83
|
RootPointerDirective,
|
|
77
|
-
FlowSizeControllerDirective,
|
|
84
|
+
FlowSizeControllerDirective,
|
|
85
|
+
NodeToolbarWrapperDirective, NodeHtmlTemplateDirective,
|
|
78
86
|
GroupNodeTemplateDirective,
|
|
79
87
|
EdgeLabelHtmlTemplateDirective,
|
|
80
88
|
EdgeTemplateDirective,
|
|
81
89
|
ConnectionTemplateDirective,
|
|
82
|
-
HandleTemplateDirective], imports: [
|
|
90
|
+
HandleTemplateDirective], imports: [NgIf, NgFor, NgTemplateOutlet, NgComponentOutlet, KeyValuePipe], exports: [VflowComponent,
|
|
83
91
|
HandleComponent,
|
|
84
92
|
ResizableComponent,
|
|
85
93
|
SelectableDirective,
|
|
86
|
-
MiniMapComponent,
|
|
94
|
+
MiniMapComponent,
|
|
95
|
+
NodeToolbarComponent,
|
|
96
|
+
DragHandleDirective, NodeHtmlTemplateDirective,
|
|
87
97
|
GroupNodeTemplateDirective,
|
|
88
98
|
EdgeLabelHtmlTemplateDirective,
|
|
89
99
|
EdgeTemplateDirective,
|
|
90
100
|
ConnectionTemplateDirective,
|
|
91
101
|
HandleTemplateDirective] }); }
|
|
92
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: VflowModule
|
|
102
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: VflowModule }); }
|
|
93
103
|
}
|
|
94
104
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: VflowModule, decorators: [{
|
|
95
105
|
type: NgModule,
|
|
96
106
|
args: [{
|
|
97
|
-
imports: [
|
|
107
|
+
imports: [NgIf, NgFor, NgTemplateOutlet, NgComponentOutlet, KeyValuePipe],
|
|
98
108
|
exports: [
|
|
99
109
|
VflowComponent,
|
|
100
110
|
HandleComponent,
|
|
101
111
|
ResizableComponent,
|
|
102
112
|
SelectableDirective,
|
|
103
113
|
MiniMapComponent,
|
|
114
|
+
NodeToolbarComponent,
|
|
115
|
+
DragHandleDirective,
|
|
104
116
|
...templateDirectives
|
|
105
117
|
],
|
|
106
118
|
declarations: [...components, ...directives, ...templateDirectives],
|
|
107
119
|
}]
|
|
108
120
|
}] });
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vflow.module.js","sourceRoot":"","sources":["../../../../../projects/ngx-vflow-lib/src/lib/vflow/vflow.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { KeyValuePipe, NgComponentOutlet, NgFor, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { VflowComponent } from './components/vflow/vflow.component';\nimport { NodeComponent } from './components/node/node.component';\nimport { MapContextDirective } from './directives/map-context.directive';\nimport { EdgeComponent } from './components/edge/edge.component';\nimport { EdgeLabelComponent } from './components/edge-label/edge-label.component';\nimport { ConnectionTemplateDirective, EdgeLabelHtmlTemplateDirective, EdgeTemplateDirective, GroupNodeTemplateDirective, HandleTemplateDirective, NodeHtmlTemplateDirective } from './directives/template.directive';\nimport { ConnectionComponent } from './components/connection/connection.component';\nimport { SpacePointContextDirective } from './directives/space-point-context.directive';\nimport { RootSvgReferenceDirective } from './directives/reference.directive';\nimport { RootSvgContextDirective } from './directives/root-svg-context.directive';\nimport { DefsComponent } from './components/defs/defs.component';\nimport { HandleComponent } from './components/handle/handle.component';\nimport { HandleSizeControllerDirective } from './directives/handle-size-controller.directive';\nimport { SelectableDirective } from './directives/selectable.directive';\nimport { PointerDirective } from './directives/pointer.directive';\nimport { RootPointerDirective } from './directives/root-pointer.directive';\nimport { BackgroundComponent } from './components/background/background.component';\nimport { FlowSizeControllerDirective } from './directives/flow-size-controller.directive';\nimport { ResizableComponent } from './public-components/resizable/resizable.component';\nimport { MiniMapComponent } from './public-components/minimap/minimap.component';\nimport { DefaultNodeComponent } from './components/default-node/default-node.component';\nimport { NodeToolbarComponent, NodeToolbarWrapperDirective } from './public-components/node-toolbar/node-toolbar.component';\nimport { DragHandleDirective } from './directives/drag-handle.directive';\n\nconst components = [\n  VflowComponent,\n  NodeComponent,\n  DefaultNodeComponent,\n  EdgeComponent,\n  EdgeLabelComponent,\n  ConnectionComponent,\n  HandleComponent,\n  DefsComponent,\n  BackgroundComponent,\n  ResizableComponent,\n  MiniMapComponent,\n  NodeToolbarComponent\n]\n\nconst directives = [\n  SpacePointContextDirective,\n  MapContextDirective,\n  RootSvgReferenceDirective,\n  RootSvgContextDirective,\n  HandleSizeControllerDirective,\n  SelectableDirective,\n  DragHandleDirective,\n  PointerDirective,\n  RootPointerDirective,\n  FlowSizeControllerDirective,\n  NodeToolbarWrapperDirective\n]\n\nconst templateDirectives = [\n  NodeHtmlTemplateDirective,\n  GroupNodeTemplateDirective,\n  EdgeLabelHtmlTemplateDirective,\n  EdgeTemplateDirective,\n  ConnectionTemplateDirective,\n  HandleTemplateDirective\n]\n\n@NgModule({\n  imports: [NgIf, NgFor, NgTemplateOutlet, NgComponentOutlet, KeyValuePipe],\n  exports: [\n    VflowComponent,\n    HandleComponent,\n    ResizableComponent,\n    SelectableDirective,\n    MiniMapComponent,\n    NodeToolbarComponent,\n    DragHandleDirective,\n    ...templateDirectives\n  ],\n  declarations: [...components, ...directives, ...templateDirectives],\n})\nexport class VflowModule { }\n"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -27,9 +27,13 @@ export * from './lib/vflow/public-components/custom-node/custom-node.component';
|
|
|
27
27
|
export * from './lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component';
|
|
28
28
|
export * from './lib/vflow/public-components/resizable/resizable.component';
|
|
29
29
|
export * from './lib/vflow/public-components/minimap/minimap.component';
|
|
30
|
+
export * from './lib/vflow/public-components/node-toolbar/node-toolbar.component';
|
|
30
31
|
// Directives
|
|
31
32
|
export * from './lib/vflow/directives/template.directive';
|
|
32
33
|
export * from './lib/vflow/directives/connection-controller.directive';
|
|
33
34
|
export * from './lib/vflow/directives/changes-controller.directive';
|
|
34
35
|
export * from './lib/vflow/directives/selectable.directive';
|
|
35
|
-
|
|
36
|
+
export * from './lib/vflow/directives/drag-handle.directive';
|
|
37
|
+
// Testing
|
|
38
|
+
export * from './lib/vflow/testing-utils/provide-custom-node-mocks';
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsVUFBVTtBQUNWLGNBQWMsMEJBQTBCLENBQUM7QUFFekMsYUFBYTtBQUNiLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLHlDQUF5QyxDQUFDO0FBRXhELGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLCtDQUErQyxDQUFDO0FBRTlELFFBQVE7QUFDUixjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyx3Q0FBd0MsQ0FBQztBQUV2RCxhQUFhO0FBQ2IsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsaUVBQWlFLENBQUM7QUFDaEYsY0FBYyxpRkFBaUYsQ0FBQztBQUNoRyxjQUFjLDZEQUE2RCxDQUFDO0FBQzVFLGNBQWMseURBQXlELENBQUE7QUFDdkUsY0FBYyxtRUFBbUUsQ0FBQTtBQUVqRixhQUFhO0FBQ2IsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLDhDQUE4QyxDQUFDO0FBRTdELFVBQVU7QUFDVixjQUFjLHFEQUFxRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gTW9kdWxlc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvdmZsb3cubW9kdWxlJztcblxuLy8gSW50ZXJmYWNlc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvaW50ZXJmYWNlcy9ub2RlLmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy9pbnRlcmZhY2VzL3BvaW50LmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy9pbnRlcmZhY2VzL2VkZ2UuaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L2ludGVyZmFjZXMvZWRnZS1sYWJlbC5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvaW50ZXJmYWNlcy9jb25uZWN0aW9uLmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy9pbnRlcmZhY2VzL2Nvbm5lY3Rpb24uaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L2ludGVyZmFjZXMvY29ubmVjdGlvbi1zZXR0aW5ncy5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvaW50ZXJmYWNlcy9oYW5kbGUtcG9zaXRpb25zLmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy9pbnRlcmZhY2VzL21hcmtlci5pbnRlcmZhY2UnO1xuZXhwb3J0IHsgVmlld3BvcnRTdGF0ZSB9IGZyb20gJy4vbGliL3ZmbG93L2ludGVyZmFjZXMvdmlld3BvcnQuaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L2ludGVyZmFjZXMvY29tcG9uZW50LW5vZGUtZXZlbnQuaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L2ludGVyZmFjZXMvZml0LXZpZXctb3B0aW9ucy5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvaW50ZXJmYWNlcy9vcHRpbWl6YXRpb24uaW50ZXJmYWNlJztcblxuLy8gVHlwZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L3R5cGVzL25vZGUtY2hhbmdlLnR5cGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvdHlwZXMvZWRnZS1jaGFuZ2UudHlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy90eXBlcy9wb3NpdGlvbi50eXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L3R5cGVzL2JhY2tncm91bmQudHlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy90eXBlcy9jb25uZWN0aW9uLW1vZGUudHlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy90eXBlcy9rZXlib2FyZC1hY3Rpb24udHlwZSc7XG5cbi8vIENvbXBvbmVudHNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L2NvbXBvbmVudHMvdmZsb3cvdmZsb3cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L2NvbXBvbmVudHMvaGFuZGxlL2hhbmRsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvcHVibGljLWNvbXBvbmVudHMvY3VzdG9tLW5vZGUvY3VzdG9tLW5vZGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L3B1YmxpYy1jb21wb25lbnRzL2N1c3RvbS1keW5hbWljLW5vZGUvY3VzdG9tLWR5bmFtaWMtbm9kZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvcHVibGljLWNvbXBvbmVudHMvcmVzaXphYmxlL3Jlc2l6YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvcHVibGljLWNvbXBvbmVudHMvbWluaW1hcC9taW5pbWFwLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L3B1YmxpYy1jb21wb25lbnRzL25vZGUtdG9vbGJhci9ub2RlLXRvb2xiYXIuY29tcG9uZW50J1xuXG4vLyBEaXJlY3RpdmVzXG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy9kaXJlY3RpdmVzL3RlbXBsYXRlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy9kaXJlY3RpdmVzL2Nvbm5lY3Rpb24tY29udHJvbGxlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvZGlyZWN0aXZlcy9jaGFuZ2VzLWNvbnRyb2xsZXIuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZmbG93L2RpcmVjdGl2ZXMvc2VsZWN0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmZsb3cvZGlyZWN0aXZlcy9kcmFnLWhhbmRsZS5kaXJlY3RpdmUnO1xuXG4vLyBUZXN0aW5nXG5leHBvcnQgKiBmcm9tICcuL2xpYi92Zmxvdy90ZXN0aW5nLXV0aWxzL3Byb3ZpZGUtY3VzdG9tLW5vZGUtbW9ja3MnO1xuIl19
|