ngx-vflow 1.16.3 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +35 -69
- package/fesm2022/ngx-vflow-testing.mjs +77 -67
- package/fesm2022/ngx-vflow-testing.mjs.map +1 -1
- package/fesm2022/ngx-vflow.mjs +926 -559
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/custom-node-base/custom-node-base.component.d.ts +1 -1
- package/lib/vflow/components/vflow/vflow.component.d.ts +18 -9
- package/lib/vflow/directives/auto-pan.directive.d.ts +16 -0
- package/lib/vflow/directives/changes-controller.directive.d.ts +13 -87
- package/lib/vflow/directives/connection-controller.directive.d.ts +8 -10
- package/lib/vflow/directives/space-point-context.directive.d.ts +2 -1
- package/lib/vflow/interfaces/component-node-event.interface.d.ts +1 -2
- package/lib/vflow/interfaces/connection-events.interface.d.ts +66 -0
- package/lib/vflow/interfaces/connection-settings.interface.d.ts +7 -1
- package/lib/vflow/interfaces/connection.interface.d.ts +0 -5
- package/lib/vflow/interfaces/curve-factory.interface.d.ts +2 -2
- package/lib/vflow/interfaces/edge-label.interface.d.ts +0 -4
- package/lib/vflow/interfaces/edge.interface.d.ts +36 -8
- package/lib/vflow/interfaces/node.interface.d.ts +44 -63
- package/lib/vflow/interfaces/selection-strategy.interface.d.ts +16 -0
- package/lib/vflow/interfaces/template-context.interface.d.ts +8 -3
- package/lib/vflow/models/connection.model.d.ts +1 -1
- package/lib/vflow/models/edge.model.d.ts +20 -23
- package/lib/vflow/models/handle.model.d.ts +1 -1
- package/lib/vflow/models/node.model.d.ts +4 -7
- package/lib/vflow/public-components/custom-node/custom-node.component.d.ts +1 -1
- package/lib/vflow/public-components/custom-template-edge/custom-template-edge.component.d.ts +2 -1
- package/lib/vflow/public-components/minimap/minimap.component.d.ts +1 -1
- package/lib/vflow/services/draggable.service.d.ts +3 -0
- package/lib/vflow/services/flow-entities.service.d.ts +2 -2
- package/lib/vflow/services/flow-settings.service.d.ts +3 -0
- package/lib/vflow/services/flow-status.service.d.ts +35 -7
- package/lib/vflow/services/selection.service.d.ts +4 -1
- package/lib/vflow/strategies/default-selection.strategy.d.ts +6 -0
- package/lib/vflow/strategies/manual-selection.strategy.d.ts +5 -0
- package/lib/vflow/types/selection-mode.type.d.ts +1 -0
- package/lib/vflow/types/unwrap-signal.type.d.ts +4 -0
- package/lib/vflow/utils/adjust-direction.d.ts +2 -6
- package/lib/vflow/utils/identity-checker/reference-identity-checker.d.ts +2 -2
- package/lib/vflow/utils/is-vflow-component.d.ts +0 -2
- package/lib/vflow/utils/signals/to-lazy-signal.d.ts +4 -4
- package/package.json +3 -7
- package/public-api.d.ts +3 -2
- package/testing/component-mocks/vflow-mock.component.d.ts +8 -6
- package/testing/directive-mocks/connection-controller-mock.directive.d.ts +8 -6
- package/esm2022/lib/vflow/components/alignment-helper/alignment-helper.component.mjs +0 -103
- package/esm2022/lib/vflow/components/background/background.component.mjs +0 -121
- package/esm2022/lib/vflow/components/connection/connection.component.mjs +0 -157
- package/esm2022/lib/vflow/components/custom-node-base/custom-node-base.component.mjs +0 -57
- package/esm2022/lib/vflow/components/default-node/default-node.component.mjs +0 -16
- package/esm2022/lib/vflow/components/defs/defs.component.mjs +0 -16
- package/esm2022/lib/vflow/components/edge/edge.component.mjs +0 -54
- package/esm2022/lib/vflow/components/edge-label/edge-label.component.mjs +0 -76
- package/esm2022/lib/vflow/components/node/node.component.mjs +0 -107
- package/esm2022/lib/vflow/components/preview-flow/draw-node.mjs +0 -100
- package/esm2022/lib/vflow/components/preview-flow/preview-flow.component.mjs +0 -62
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +0 -437
- package/esm2022/lib/vflow/constants/magic-number-to-fix-glitch-in-chrome.constant.mjs +0 -4
- package/esm2022/lib/vflow/decorators/microtask.decorator.mjs +0 -11
- package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +0 -165
- package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +0 -145
- package/esm2022/lib/vflow/directives/drag-handle.directive.mjs +0 -28
- package/esm2022/lib/vflow/directives/flow-size-controller.directive.mjs +0 -40
- package/esm2022/lib/vflow/directives/handle-size-controller.directive.mjs +0 -41
- package/esm2022/lib/vflow/directives/map-context.directive.mjs +0 -116
- package/esm2022/lib/vflow/directives/node-handles-controller.directive.mjs +0 -33
- package/esm2022/lib/vflow/directives/node-resize-controller.directive.mjs +0 -37
- package/esm2022/lib/vflow/directives/pointer.directive.mjs +0 -84
- package/esm2022/lib/vflow/directives/reference.directive.mjs +0 -17
- package/esm2022/lib/vflow/directives/root-pointer.directive.mjs +0 -58
- package/esm2022/lib/vflow/directives/root-svg-context.directive.mjs +0 -35
- package/esm2022/lib/vflow/directives/selectable.directive.mjs +0 -48
- package/esm2022/lib/vflow/directives/space-point-context.directive.mjs +0 -42
- package/esm2022/lib/vflow/directives/template.directive.mjs +0 -119
- package/esm2022/lib/vflow/interfaces/alignment-helper-settings.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/box.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/component-node-event.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/connection-settings.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/connection.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/connection.internal.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/contextable.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/curve-factory.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/edge-label.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/edge.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/fit-view-options.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/flow-entity.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/intersecting-nodes-options.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/marker.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/node-preview.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/node.interface.mjs +0 -53
- package/esm2022/lib/vflow/interfaces/optimization.interface.mjs +0 -7
- package/esm2022/lib/vflow/interfaces/point.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/rect.mjs +0 -10
- package/esm2022/lib/vflow/interfaces/template-context.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/viewport.interface.mjs +0 -2
- package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +0 -66
- package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +0 -226
- package/esm2022/lib/vflow/math/edge-path/straigh-path.mjs +0 -12
- package/esm2022/lib/vflow/math/point-on-line-by-ratio.mjs +0 -12
- package/esm2022/lib/vflow/models/connection.model.mjs +0 -31
- package/esm2022/lib/vflow/models/edge-label.model.mjs +0 -8
- package/esm2022/lib/vflow/models/edge.model.mjs +0 -208
- package/esm2022/lib/vflow/models/handle.model.mjs +0 -98
- package/esm2022/lib/vflow/models/minimap.model.mjs +0 -7
- package/esm2022/lib/vflow/models/node.model.mjs +0 -181
- package/esm2022/lib/vflow/models/toolbar.model.mjs +0 -36
- package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs +0 -25
- package/esm2022/lib/vflow/public-components/custom-node/custom-node.component.mjs +0 -24
- package/esm2022/lib/vflow/public-components/custom-template-edge/custom-template-edge.component.mjs +0 -29
- package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +0 -53
- package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +0 -108
- package/esm2022/lib/vflow/public-components/node-toolbar/node-toolbar.component.mjs +0 -73
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +0 -272
- package/esm2022/lib/vflow/services/component-event-bus.service.mjs +0 -18
- package/esm2022/lib/vflow/services/draggable.service.mjs +0 -124
- package/esm2022/lib/vflow/services/edge-changes.service.mjs +0 -43
- package/esm2022/lib/vflow/services/edge-rendering.service.mjs +0 -40
- package/esm2022/lib/vflow/services/flow-entities.service.mjs +0 -56
- package/esm2022/lib/vflow/services/flow-rendering.service.mjs +0 -41
- package/esm2022/lib/vflow/services/flow-settings.service.mjs +0 -33
- package/esm2022/lib/vflow/services/flow-status.service.mjs +0 -49
- package/esm2022/lib/vflow/services/handle.service.mjs +0 -30
- package/esm2022/lib/vflow/services/keyboard.service.mjs +0 -47
- package/esm2022/lib/vflow/services/node-accessor.service.mjs +0 -16
- package/esm2022/lib/vflow/services/node-changes.service.mjs +0 -41
- package/esm2022/lib/vflow/services/node-rendering.service.mjs +0 -66
- package/esm2022/lib/vflow/services/overlays.service.mjs +0 -35
- package/esm2022/lib/vflow/services/preview-flow-render-strategy.service.mjs +0 -21
- package/esm2022/lib/vflow/services/selection.service.mjs +0 -54
- package/esm2022/lib/vflow/services/viewport.service.mjs +0 -64
- package/esm2022/lib/vflow/types/background.type.mjs +0 -2
- package/esm2022/lib/vflow/types/connection-mode.type.mjs +0 -2
- package/esm2022/lib/vflow/types/edge-change.type.mjs +0 -2
- package/esm2022/lib/vflow/types/handle-type.type.mjs +0 -2
- package/esm2022/lib/vflow/types/keyboard-action.type.mjs +0 -2
- package/esm2022/lib/vflow/types/node-change.type.mjs +0 -2
- package/esm2022/lib/vflow/types/position.type.mjs +0 -2
- package/esm2022/lib/vflow/types/viewport-change-type.type.mjs +0 -2
- package/esm2022/lib/vflow/utils/add-nodes-to-edges.mjs +0 -11
- package/esm2022/lib/vflow/utils/adjust-direction.mjs +0 -30
- package/esm2022/lib/vflow/utils/align-number.mjs +0 -4
- package/esm2022/lib/vflow/utils/assert-injector.mjs +0 -27
- package/esm2022/lib/vflow/utils/event.mjs +0 -4
- package/esm2022/lib/vflow/utils/get-os.mjs +0 -24
- package/esm2022/lib/vflow/utils/get-overlapping-area.mjs +0 -6
- package/esm2022/lib/vflow/utils/get-space-points.mjs +0 -25
- package/esm2022/lib/vflow/utils/hash.mjs +0 -7
- package/esm2022/lib/vflow/utils/id.mjs +0 -5
- package/esm2022/lib/vflow/utils/identity-checker/reference-identity-checker.mjs +0 -28
- package/esm2022/lib/vflow/utils/is-callable.mjs +0 -10
- package/esm2022/lib/vflow/utils/is-defined.mjs +0 -4
- package/esm2022/lib/vflow/utils/is-group-node.mjs +0 -4
- package/esm2022/lib/vflow/utils/is-vflow-component.mjs +0 -9
- package/esm2022/lib/vflow/utils/nodes.mjs +0 -60
- package/esm2022/lib/vflow/utils/resizable.mjs +0 -11
- package/esm2022/lib/vflow/utils/round.mjs +0 -2
- package/esm2022/lib/vflow/utils/signals/extended-computed.mjs +0 -15
- package/esm2022/lib/vflow/utils/signals/to-lazy-signal.mjs +0 -35
- package/esm2022/lib/vflow/utils/to-unified-node.mjs +0 -24
- package/esm2022/lib/vflow/utils/transform-background.mjs +0 -4
- package/esm2022/lib/vflow/utils/viewport.mjs +0 -51
- package/esm2022/lib/vflow/vflow.mjs +0 -29
- package/esm2022/ngx-vflow.mjs +0 -5
- package/esm2022/public-api.mjs +0 -55
- package/esm2022/testing/component-mocks/custom-template-edge-mock.component.mjs +0 -16
- package/esm2022/testing/component-mocks/handle-mock.component.mjs +0 -26
- package/esm2022/testing/component-mocks/minimap-mock.component.mjs +0 -24
- package/esm2022/testing/component-mocks/node-toolbar-mock.component.mjs +0 -23
- package/esm2022/testing/component-mocks/resizable-mock.component.mjs +0 -27
- package/esm2022/testing/component-mocks/vflow-mock.component.mjs +0 -299
- package/esm2022/testing/directive-mocks/connection-controller-mock.directive.mjs +0 -29
- package/esm2022/testing/directive-mocks/drag-handle-mock.directive.mjs +0 -11
- package/esm2022/testing/directive-mocks/selectable-mock.directive.mjs +0 -14
- package/esm2022/testing/directive-mocks/template-mock.directive.mjs +0 -101
- package/esm2022/testing/ngx-vflow-testing.mjs +0 -5
- package/esm2022/testing/provide-custom-node-mocks.mjs +0 -60
- package/esm2022/testing/public-api.mjs +0 -13
- package/esm2022/testing/types.mjs +0 -2
- package/esm2022/testing/vflow-mocks.mjs +0 -28
- package/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.d.ts +0 -13
- package/lib/vflow/utils/to-unified-node.d.ts +0 -2
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export function Microtask(target, key, descriptor) {
|
|
2
|
-
const originalMethod = descriptor.value;
|
|
3
|
-
descriptor.value = function (...args) {
|
|
4
|
-
queueMicrotask(() => {
|
|
5
|
-
originalMethod?.apply(this, args);
|
|
6
|
-
});
|
|
7
|
-
};
|
|
8
|
-
// Return the modified descriptor
|
|
9
|
-
return descriptor;
|
|
10
|
-
}
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWljcm90YXNrLmRlY29yYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9kZWNvcmF0b3JzL21pY3JvdGFzay5kZWNvcmF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxVQUFVLFNBQVMsQ0FBQyxNQUFXLEVBQUUsR0FBVyxFQUFFLFVBQTZEO0lBQy9HLE1BQU0sY0FBYyxHQUFHLFVBQVUsQ0FBQyxLQUFLLENBQUM7SUFFeEMsVUFBVSxDQUFDLEtBQUssR0FBRyxVQUFVLEdBQUcsSUFBVztRQUN6QyxjQUFjLENBQUMsR0FBRyxFQUFFO1lBQ2xCLGNBQWMsRUFBRSxLQUFLLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDO0lBRUYsaUNBQWlDO0lBQ2pDLE9BQU8sVUFBVSxDQUFDO0FBQ3BCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gTWljcm90YXNrKHRhcmdldDogYW55LCBrZXk6IHN0cmluZywgZGVzY3JpcHRvcjogVHlwZWRQcm9wZXJ0eURlc2NyaXB0b3I8KC4uLmFyZ3M6IGFueVtdKSA9PiB2b2lkPikge1xuICBjb25zdCBvcmlnaW5hbE1ldGhvZCA9IGRlc2NyaXB0b3IudmFsdWU7XG5cbiAgZGVzY3JpcHRvci52YWx1ZSA9IGZ1bmN0aW9uICguLi5hcmdzOiBhbnlbXSkge1xuICAgIHF1ZXVlTWljcm90YXNrKCgpID0+IHtcbiAgICAgIG9yaWdpbmFsTWV0aG9kPy5hcHBseSh0aGlzLCBhcmdzKTtcbiAgICB9KTtcbiAgfTtcblxuICAvLyBSZXR1cm4gdGhlIG1vZGlmaWVkIGRlc2NyaXB0b3JcbiAgcmV0dXJuIGRlc2NyaXB0b3I7XG59XG4iXX0=
|
|
@@ -1,165 +0,0 @@
|
|
|
1
|
-
import { Directive, inject } from '@angular/core';
|
|
2
|
-
import { EdgeChangesService } from '../services/edge-changes.service';
|
|
3
|
-
import { NodesChangeService } from '../services/node-changes.service';
|
|
4
|
-
import { filter, map } from 'rxjs';
|
|
5
|
-
import { outputFromObservable } from '@angular/core/rxjs-interop';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export class ChangesControllerDirective {
|
|
8
|
-
constructor() {
|
|
9
|
-
this.nodesChangeService = inject(NodesChangeService);
|
|
10
|
-
this.edgesChangeService = inject(EdgeChangesService);
|
|
11
|
-
/**
|
|
12
|
-
* Watch nodes change
|
|
13
|
-
*/
|
|
14
|
-
this.onNodesChange = outputFromObservable(this.nodesChangeService.changes$);
|
|
15
|
-
this.onNodesChangePosition = outputFromObservable(this.nodeChangesOfType('position'), {
|
|
16
|
-
alias: 'onNodesChange.position',
|
|
17
|
-
});
|
|
18
|
-
/**
|
|
19
|
-
* @deprecated use `onNodesChange.position` instead
|
|
20
|
-
*/
|
|
21
|
-
this.onNodesChangePositionSignle = outputFromObservable(this.singleChange(this.nodeChangesOfType('position')), { alias: 'onNodesChange.position.single' });
|
|
22
|
-
/**
|
|
23
|
-
* @deprecated use `onNodesChange.position` instead
|
|
24
|
-
*/
|
|
25
|
-
this.onNodesChangePositionMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('position')), { alias: 'onNodesChange.position.many' });
|
|
26
|
-
this.onNodesChangeSize = outputFromObservable(this.nodeChangesOfType('size'), {
|
|
27
|
-
alias: 'onNodesChange.size',
|
|
28
|
-
});
|
|
29
|
-
/**
|
|
30
|
-
* @deprecated use `onNodesChange.size` instead
|
|
31
|
-
*/
|
|
32
|
-
this.onNodesChangeSizeSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('size')), {
|
|
33
|
-
alias: 'onNodesChange.size.single',
|
|
34
|
-
});
|
|
35
|
-
/**
|
|
36
|
-
* @deprecated use `onNodesChange.size` instead
|
|
37
|
-
*/
|
|
38
|
-
this.onNodesChangeSizeMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('size')), {
|
|
39
|
-
alias: 'onNodesChange.size.many',
|
|
40
|
-
});
|
|
41
|
-
this.onNodesChangeAdd = outputFromObservable(this.nodeChangesOfType('add'), {
|
|
42
|
-
alias: 'onNodesChange.add',
|
|
43
|
-
});
|
|
44
|
-
/**
|
|
45
|
-
* @deprecated use `onNodesChange.add` instead
|
|
46
|
-
*/
|
|
47
|
-
this.onNodesChangeAddSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('add')), {
|
|
48
|
-
alias: 'onNodesChange.add.single',
|
|
49
|
-
});
|
|
50
|
-
/**
|
|
51
|
-
* @deprecated use `onNodesChange.add` instead
|
|
52
|
-
*/
|
|
53
|
-
this.onNodesChangeAddMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('add')), {
|
|
54
|
-
alias: 'onNodesChange.add.many',
|
|
55
|
-
});
|
|
56
|
-
this.onNodesChangeRemove = outputFromObservable(this.nodeChangesOfType('remove'), {
|
|
57
|
-
alias: 'onNodesChange.remove',
|
|
58
|
-
});
|
|
59
|
-
/**
|
|
60
|
-
* @deprecated use `onNodesChange.remove` instead
|
|
61
|
-
*/
|
|
62
|
-
this.onNodesChangeRemoveSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('remove')), { alias: 'onNodesChange.remove.single' });
|
|
63
|
-
/**
|
|
64
|
-
* @deprecated use `onNodesChange.remove` instead
|
|
65
|
-
*/
|
|
66
|
-
this.onNodesChangeRemoveMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('remove')), {
|
|
67
|
-
alias: 'onNodesChange.remove.many',
|
|
68
|
-
});
|
|
69
|
-
this.onNodesChangeSelect = outputFromObservable(this.nodeChangesOfType('select'), {
|
|
70
|
-
alias: 'onNodesChange.select',
|
|
71
|
-
});
|
|
72
|
-
/**
|
|
73
|
-
* @deprecated use `onNodesChange.select` instead
|
|
74
|
-
*/
|
|
75
|
-
this.onNodesChangeSelectSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('select')), { alias: 'onNodesChange.select.single' });
|
|
76
|
-
/**
|
|
77
|
-
* @deprecated use `onNodesChange.select` instead
|
|
78
|
-
*/
|
|
79
|
-
this.onNodesChangeSelectMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('select')), {
|
|
80
|
-
alias: 'onNodesChange.select.many',
|
|
81
|
-
});
|
|
82
|
-
/**
|
|
83
|
-
* Watch edges change
|
|
84
|
-
*/
|
|
85
|
-
this.onEdgesChange = outputFromObservable(this.edgesChangeService.changes$);
|
|
86
|
-
this.onNodesChangeDetached = outputFromObservable(this.edgeChangesOfType('detached'), {
|
|
87
|
-
alias: 'onEdgesChange.detached',
|
|
88
|
-
});
|
|
89
|
-
/**
|
|
90
|
-
* @deprecated use `onEdgesChange.detached` instead
|
|
91
|
-
*/
|
|
92
|
-
this.onNodesChangeDetachedSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('detached')), { alias: 'onEdgesChange.detached.single' });
|
|
93
|
-
/**
|
|
94
|
-
* @deprecated use `onEdgesChange.detached` instead
|
|
95
|
-
*/
|
|
96
|
-
this.onNodesChangeDetachedMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('detached')), { alias: 'onEdgesChange.detached.many' });
|
|
97
|
-
this.onEdgesChangeAdd = outputFromObservable(this.edgeChangesOfType('add'), {
|
|
98
|
-
alias: 'onEdgesChange.add',
|
|
99
|
-
});
|
|
100
|
-
/**
|
|
101
|
-
* @deprecated use `onEdgesChange.add` instead
|
|
102
|
-
*/
|
|
103
|
-
this.onEdgeChangeAddSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('add')), {
|
|
104
|
-
alias: 'onEdgesChange.add.single',
|
|
105
|
-
});
|
|
106
|
-
/**
|
|
107
|
-
* @deprecated use `onEdgesChange.add` instead
|
|
108
|
-
*/
|
|
109
|
-
this.onEdgeChangeAddMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('add')), {
|
|
110
|
-
alias: 'onEdgesChange.add.many',
|
|
111
|
-
});
|
|
112
|
-
this.onEdgeChangeRemove = outputFromObservable(this.edgeChangesOfType('remove'), {
|
|
113
|
-
alias: 'onEdgesChange.remove',
|
|
114
|
-
});
|
|
115
|
-
/**
|
|
116
|
-
* @deprecated use `onEdgesChange.remove` instead
|
|
117
|
-
*/
|
|
118
|
-
this.onEdgeChangeRemoveSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('remove')), {
|
|
119
|
-
alias: 'onEdgesChange.remove.single',
|
|
120
|
-
});
|
|
121
|
-
/**
|
|
122
|
-
* @deprecated use `onEdgesChange.remove` instead
|
|
123
|
-
*/
|
|
124
|
-
this.onEdgeChangeRemoveMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('remove')), {
|
|
125
|
-
alias: 'onEdgesChange.remove.many',
|
|
126
|
-
});
|
|
127
|
-
this.onEdgeChangeSelect = outputFromObservable(this.edgeChangesOfType('select'), {
|
|
128
|
-
alias: 'onEdgesChange.select',
|
|
129
|
-
});
|
|
130
|
-
/**
|
|
131
|
-
* @deprecated use `onEdgesChange.select` instead
|
|
132
|
-
*/
|
|
133
|
-
this.onEdgeChangeSelectSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('select')), {
|
|
134
|
-
alias: 'onEdgesChange.select.single',
|
|
135
|
-
});
|
|
136
|
-
/**
|
|
137
|
-
* @deprecated use `onEdgesChange.select` instead
|
|
138
|
-
*/
|
|
139
|
-
this.onEdgeChangeSelectMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('select')), {
|
|
140
|
-
alias: 'onEdgesChange.select.many',
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
nodeChangesOfType(type) {
|
|
144
|
-
return this.nodesChangeService.changes$.pipe(map((changes) => changes.filter((c) => c.type === type)), filter((changes) => !!changes.length));
|
|
145
|
-
}
|
|
146
|
-
edgeChangesOfType(type) {
|
|
147
|
-
return this.edgesChangeService.changes$.pipe(map((changes) => changes.filter((c) => c.type === type)), filter((changes) => !!changes.length));
|
|
148
|
-
}
|
|
149
|
-
singleChange(changes$) {
|
|
150
|
-
return changes$.pipe(filter((changes) => changes.length === 1), map(([first]) => first));
|
|
151
|
-
}
|
|
152
|
-
manyChanges(changes$) {
|
|
153
|
-
return changes$.pipe(filter((changes) => changes.length > 1));
|
|
154
|
-
}
|
|
155
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChangesControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
156
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: ChangesControllerDirective, isStandalone: true, selector: "[changesController]", outputs: { onNodesChange: "onNodesChange", onNodesChangePosition: "onNodesChange.position", onNodesChangePositionSignle: "onNodesChange.position.single", onNodesChangePositionMany: "onNodesChange.position.many", onNodesChangeSize: "onNodesChange.size", onNodesChangeSizeSingle: "onNodesChange.size.single", onNodesChangeSizeMany: "onNodesChange.size.many", onNodesChangeAdd: "onNodesChange.add", onNodesChangeAddSingle: "onNodesChange.add.single", onNodesChangeAddMany: "onNodesChange.add.many", onNodesChangeRemove: "onNodesChange.remove", onNodesChangeRemoveSingle: "onNodesChange.remove.single", onNodesChangeRemoveMany: "onNodesChange.remove.many", onNodesChangeSelect: "onNodesChange.select", onNodesChangeSelectSingle: "onNodesChange.select.single", onNodesChangeSelectMany: "onNodesChange.select.many", onEdgesChange: "onEdgesChange", onNodesChangeDetached: "onEdgesChange.detached", onNodesChangeDetachedSingle: "onEdgesChange.detached.single", onNodesChangeDetachedMany: "onEdgesChange.detached.many", onEdgesChangeAdd: "onEdgesChange.add", onEdgeChangeAddSingle: "onEdgesChange.add.single", onEdgeChangeAddMany: "onEdgesChange.add.many", onEdgeChangeRemove: "onEdgesChange.remove", onEdgeChangeRemoveSingle: "onEdgesChange.remove.single", onEdgeChangeRemoveMany: "onEdgesChange.remove.many", onEdgeChangeSelect: "onEdgesChange.select", onEdgeChangeSelectSingle: "onEdgesChange.select.single", onEdgeChangeSelectMany: "onEdgesChange.select.many" }, ngImport: i0 }); }
|
|
157
|
-
}
|
|
158
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChangesControllerDirective, decorators: [{
|
|
159
|
-
type: Directive,
|
|
160
|
-
args: [{
|
|
161
|
-
selector: '[changesController]',
|
|
162
|
-
standalone: true,
|
|
163
|
-
}]
|
|
164
|
-
}] });
|
|
165
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"changes-controller.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/changes-controller.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, inject } from '@angular/core';\nimport {\n  NodeAddChange,\n  NodeChange,\n  NodePositionChange,\n  NodeRemoveChange,\n  NodeSelectedChange,\n  NodeSizeChange,\n} from '../types/node-change.type';\nimport { EdgeChangesService } from '../services/edge-changes.service';\nimport { NodesChangeService } from '../services/node-changes.service';\nimport { Observable, filter, map } from 'rxjs';\nimport {\n  EdgeAddChange,\n  EdgeChange,\n  EdgeDetachedChange,\n  EdgeRemoveChange,\n  EdgeSelectChange,\n} from '../types/edge-change.type';\nimport { outputFromObservable } from '@angular/core/rxjs-interop';\n\n@Directive({\n  selector: '[changesController]',\n  standalone: true,\n})\nexport class ChangesControllerDirective {\n  protected nodesChangeService = inject(NodesChangeService);\n  protected edgesChangeService = inject(EdgeChangesService);\n\n  /**\n   * Watch nodes change\n   */\n  public readonly onNodesChange = outputFromObservable(this.nodesChangeService.changes$);\n\n  public readonly onNodesChangePosition = outputFromObservable(this.nodeChangesOfType('position'), {\n    alias: 'onNodesChange.position',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.position` instead\n   */\n  public readonly onNodesChangePositionSignle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.single' },\n  );\n\n  /**\n   * @deprecated use `onNodesChange.position` instead\n   */\n  public readonly onNodesChangePositionMany = outputFromObservable(\n    this.manyChanges(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.many' },\n  );\n\n  public readonly onNodesChangeSize = outputFromObservable(this.nodeChangesOfType('size'), {\n    alias: 'onNodesChange.size',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.size` instead\n   */\n  public readonly onNodesChangeSizeSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('size')), {\n    alias: 'onNodesChange.size.single',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.size` instead\n   */\n  public readonly onNodesChangeSizeMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('size')), {\n    alias: 'onNodesChange.size.many',\n  });\n\n  public readonly onNodesChangeAdd = outputFromObservable(this.nodeChangesOfType('add'), {\n    alias: 'onNodesChange.add',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.add` instead\n   */\n  public readonly onNodesChangeAddSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('add')), {\n    alias: 'onNodesChange.add.single',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.add` instead\n   */\n  public readonly onNodesChangeAddMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('add')), {\n    alias: 'onNodesChange.add.many',\n  });\n\n  public readonly onNodesChangeRemove = outputFromObservable(this.nodeChangesOfType('remove'), {\n    alias: 'onNodesChange.remove',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.remove` instead\n   */\n  public readonly onNodesChangeRemoveSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('remove')),\n    { alias: 'onNodesChange.remove.single' },\n  );\n\n  /**\n   * @deprecated use `onNodesChange.remove` instead\n   */\n  public readonly onNodesChangeRemoveMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('remove')), {\n    alias: 'onNodesChange.remove.many',\n  });\n\n  public readonly onNodesChangeSelect = outputFromObservable(this.nodeChangesOfType('select'), {\n    alias: 'onNodesChange.select',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.select` instead\n   */\n  public readonly onNodesChangeSelectSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('select')),\n    { alias: 'onNodesChange.select.single' },\n  );\n\n  /**\n   * @deprecated use `onNodesChange.select` instead\n   */\n  public readonly onNodesChangeSelectMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('select')), {\n    alias: 'onNodesChange.select.many',\n  });\n\n  /**\n   * Watch edges change\n   */\n  public readonly onEdgesChange = outputFromObservable(this.edgesChangeService.changes$);\n\n  public readonly onNodesChangeDetached = outputFromObservable(this.edgeChangesOfType('detached'), {\n    alias: 'onEdgesChange.detached',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.detached` instead\n   */\n  public readonly onNodesChangeDetachedSingle = outputFromObservable(\n    this.singleChange(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.single' },\n  );\n\n  /**\n   * @deprecated use `onEdgesChange.detached` instead\n   */\n  public readonly onNodesChangeDetachedMany = outputFromObservable(\n    this.manyChanges(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.many' },\n  );\n\n  public readonly onEdgesChangeAdd = outputFromObservable(this.edgeChangesOfType('add'), {\n    alias: 'onEdgesChange.add',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.add` instead\n   */\n  public readonly onEdgeChangeAddSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('add')), {\n    alias: 'onEdgesChange.add.single',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.add` instead\n   */\n  public readonly onEdgeChangeAddMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('add')), {\n    alias: 'onEdgesChange.add.many',\n  });\n\n  public readonly onEdgeChangeRemove = outputFromObservable(this.edgeChangesOfType('remove'), {\n    alias: 'onEdgesChange.remove',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.remove` instead\n   */\n  public readonly onEdgeChangeRemoveSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('remove')), {\n    alias: 'onEdgesChange.remove.single',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.remove` instead\n   */\n  public readonly onEdgeChangeRemoveMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('remove')), {\n    alias: 'onEdgesChange.remove.many',\n  });\n\n  public readonly onEdgeChangeSelect = outputFromObservable(this.edgeChangesOfType('select'), {\n    alias: 'onEdgesChange.select',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.select` instead\n   */\n  public readonly onEdgeChangeSelectSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('select')), {\n    alias: 'onEdgesChange.select.single',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.select` instead\n   */\n  public readonly onEdgeChangeSelectMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('select')), {\n    alias: 'onEdgesChange.select.many',\n  });\n\n  private nodeChangesOfType<T extends NodeChange['type']>(type: T) {\n    return this.nodesChangeService.changes$.pipe(\n      map((changes) => changes.filter((c): c is NodeChangeMap[T] => c.type === type)),\n      filter((changes) => !!changes.length),\n    );\n  }\n\n  private edgeChangesOfType<T extends EdgeChange['type']>(type: T) {\n    return this.edgesChangeService.changes$.pipe(\n      map((changes) => changes.filter((c): c is EdgeChangeMap[T] => c.type === type)),\n      filter((changes) => !!changes.length),\n    );\n  }\n\n  private singleChange<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(\n      filter((changes) => changes.length === 1),\n      map(([first]) => first),\n    );\n  }\n\n  private manyChanges<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(filter((changes) => changes.length > 1));\n  }\n}\n\n// TODO: do not write this types manually\ntype NodeChangeMap = {\n  position: NodePositionChange;\n  size: NodeSizeChange;\n  add: NodeAddChange;\n  remove: NodeRemoveChange;\n  select: NodeSelectedChange;\n};\n\ntype EdgeChangeMap = {\n  detached: EdgeDetachedChange;\n  add: EdgeAddChange;\n  remove: EdgeRemoveChange;\n  select: EdgeSelectChange;\n};\n"]}
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
import { Directive, computed, inject } from '@angular/core';
|
|
2
|
-
import { FlowStatusService } from '../services/flow-status.service';
|
|
3
|
-
import { FlowEntitiesService } from '../services/flow-entities.service';
|
|
4
|
-
import { adjustDirection } from '../utils/adjust-direction';
|
|
5
|
-
import { outputFromObservable, toObservable } from '@angular/core/rxjs-interop';
|
|
6
|
-
import { filter, map, tap } from 'rxjs';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export class ConnectionControllerDirective {
|
|
9
|
-
constructor() {
|
|
10
|
-
this.statusService = inject(FlowStatusService);
|
|
11
|
-
this.flowEntitiesService = inject(FlowEntitiesService);
|
|
12
|
-
/**
|
|
13
|
-
* This event fires when user tries to create new Edge.
|
|
14
|
-
*
|
|
15
|
-
* `Connection` is an entity that contains data about source and target nodes.
|
|
16
|
-
*
|
|
17
|
-
* Also it's important to note, that this event only fires when connection is valid by validator function in `ConnectionSettings`,
|
|
18
|
-
* by default without passing the validator every connection concidered valid.
|
|
19
|
-
*
|
|
20
|
-
* @deprecated use `connect` output instead
|
|
21
|
-
*/
|
|
22
|
-
// eslint-disable-next-line @angular-eslint/no-output-on-prefix
|
|
23
|
-
this.onConnect = outputFromObservable(toObservable(this.statusService.status).pipe(filter((status) => status.state === 'connection-end'), map((status) => statusToConnection(status, this.isStrictMode())), tap(() => this.statusService.setIdleStatus()), filter((connection) => this.flowEntitiesService.connection().validator(connection))));
|
|
24
|
-
this.connect = outputFromObservable(toObservable(this.statusService.status).pipe(filter((status) => status.state === 'connection-end'), map((status) => statusToConnection(status, this.isStrictMode())), tap(() => this.statusService.setIdleStatus()), filter((connection) => this.flowEntitiesService.connection().validator(connection))));
|
|
25
|
-
/**
|
|
26
|
-
* @deprecated use `reconnect` output instead
|
|
27
|
-
*/
|
|
28
|
-
this.onReconnect = outputFromObservable(toObservable(this.statusService.status).pipe(filter((status) => status.state === 'reconnection-end'), map((status) => {
|
|
29
|
-
const connection = statusToConnection(status, this.isStrictMode());
|
|
30
|
-
const oldEdge = status.payload.oldEdge.edge;
|
|
31
|
-
return { connection, oldEdge };
|
|
32
|
-
}), tap(() => this.statusService.setIdleStatus()), filter(({ connection }) => this.flowEntitiesService.connection().validator(connection))));
|
|
33
|
-
this.reconnect = outputFromObservable(toObservable(this.statusService.status).pipe(filter((status) => status.state === 'reconnection-end'), map((status) => {
|
|
34
|
-
const connection = statusToConnection(status, this.isStrictMode());
|
|
35
|
-
const oldEdge = status.payload.oldEdge.edge;
|
|
36
|
-
return { connection, oldEdge };
|
|
37
|
-
}), tap(() => this.statusService.setIdleStatus()), filter(({ connection }) => this.flowEntitiesService.connection().validator(connection))));
|
|
38
|
-
this.isStrictMode = computed(() => this.flowEntitiesService.connection().mode === 'strict');
|
|
39
|
-
}
|
|
40
|
-
startConnection(handle) {
|
|
41
|
-
this.statusService.setConnectionStartStatus(handle.parentNode, handle);
|
|
42
|
-
}
|
|
43
|
-
startReconnection(handle, oldEdge) {
|
|
44
|
-
this.statusService.setReconnectionStartStatus(handle.parentNode, handle, oldEdge);
|
|
45
|
-
}
|
|
46
|
-
validateConnection(handle) {
|
|
47
|
-
const status = this.statusService.status();
|
|
48
|
-
if (status.state === 'connection-start' || status.state === 'reconnection-start') {
|
|
49
|
-
const isReconnection = status.state === 'reconnection-start';
|
|
50
|
-
let source = status.payload.source;
|
|
51
|
-
let target = handle.parentNode;
|
|
52
|
-
let sourceHandle = status.payload.sourceHandle;
|
|
53
|
-
let targetHandle = handle;
|
|
54
|
-
if (this.isStrictMode()) {
|
|
55
|
-
// swap direction (if needed) according to actual source and target of strict mode
|
|
56
|
-
const adjusted = adjustDirection({
|
|
57
|
-
source: status.payload.source,
|
|
58
|
-
sourceHandle: status.payload.sourceHandle,
|
|
59
|
-
target: handle.parentNode,
|
|
60
|
-
targetHandle: handle,
|
|
61
|
-
});
|
|
62
|
-
source = adjusted.source;
|
|
63
|
-
target = adjusted.target;
|
|
64
|
-
sourceHandle = adjusted.sourceHandle;
|
|
65
|
-
targetHandle = adjusted.targetHandle;
|
|
66
|
-
}
|
|
67
|
-
const valid = this.flowEntitiesService.connection().validator({
|
|
68
|
-
source: source.rawNode.id,
|
|
69
|
-
target: target.rawNode.id,
|
|
70
|
-
sourceHandle: sourceHandle.rawHandle.id,
|
|
71
|
-
targetHandle: targetHandle.rawHandle.id,
|
|
72
|
-
});
|
|
73
|
-
// TODO: check how react flow handles highlight of handle
|
|
74
|
-
// if direction changes
|
|
75
|
-
handle.state.set(valid ? 'valid' : 'invalid');
|
|
76
|
-
// status is about how we draw connection, so we don't need
|
|
77
|
-
// swapped diretion here
|
|
78
|
-
isReconnection
|
|
79
|
-
? this.statusService.setReconnectionValidationStatus(valid, status.payload.source, handle.parentNode, status.payload.sourceHandle, handle, status.payload.oldEdge)
|
|
80
|
-
: this.statusService.setConnectionValidationStatus(valid, status.payload.source, handle.parentNode, status.payload.sourceHandle, handle);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
resetValidateConnection(targetHandle) {
|
|
84
|
-
targetHandle.state.set('idle');
|
|
85
|
-
// drop back to start status
|
|
86
|
-
const status = this.statusService.status();
|
|
87
|
-
if (status.state === 'connection-validation' || status.state === 'reconnection-validation') {
|
|
88
|
-
const isReconnection = status.state === 'reconnection-validation';
|
|
89
|
-
isReconnection
|
|
90
|
-
? this.statusService.setReconnectionStartStatus(status.payload.source, status.payload.sourceHandle, status.payload.oldEdge)
|
|
91
|
-
: this.statusService.setConnectionStartStatus(status.payload.source, status.payload.sourceHandle);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
endConnection() {
|
|
95
|
-
const status = this.statusService.status();
|
|
96
|
-
if (status.state === 'connection-validation' || status.state === 'reconnection-validation') {
|
|
97
|
-
const isReconnection = status.state === 'reconnection-validation';
|
|
98
|
-
const source = status.payload.source;
|
|
99
|
-
const sourceHandle = status.payload.sourceHandle;
|
|
100
|
-
const target = status.payload.target;
|
|
101
|
-
const targetHandle = status.payload.targetHandle;
|
|
102
|
-
isReconnection
|
|
103
|
-
? this.statusService.setReconnectionEndStatus(source, target, sourceHandle, targetHandle, status.payload.oldEdge)
|
|
104
|
-
: this.statusService.setConnectionEndStatus(source, target, sourceHandle, targetHandle);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ConnectionControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
108
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: ConnectionControllerDirective, isStandalone: true, selector: "[onConnect], [onReconnect], [connect], [reconnect]", outputs: { onConnect: "onConnect", connect: "connect", onReconnect: "onReconnect", reconnect: "reconnect" }, ngImport: i0 }); }
|
|
109
|
-
}
|
|
110
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ConnectionControllerDirective, decorators: [{
|
|
111
|
-
type: Directive,
|
|
112
|
-
args: [{
|
|
113
|
-
selector: '[onConnect], [onReconnect], [connect], [reconnect]',
|
|
114
|
-
standalone: true,
|
|
115
|
-
}]
|
|
116
|
-
}] });
|
|
117
|
-
function statusToConnection(status, isStrictMode) {
|
|
118
|
-
let source = status.payload.source;
|
|
119
|
-
let target = status.payload.target;
|
|
120
|
-
let sourceHandle = status.payload.sourceHandle;
|
|
121
|
-
let targetHandle = status.payload.targetHandle;
|
|
122
|
-
if (isStrictMode) {
|
|
123
|
-
const adjusted = adjustDirection({
|
|
124
|
-
source: status.payload.source,
|
|
125
|
-
sourceHandle: status.payload.sourceHandle,
|
|
126
|
-
target: status.payload.target,
|
|
127
|
-
targetHandle: status.payload.targetHandle,
|
|
128
|
-
});
|
|
129
|
-
source = adjusted.source;
|
|
130
|
-
target = adjusted.target;
|
|
131
|
-
sourceHandle = adjusted.sourceHandle;
|
|
132
|
-
targetHandle = adjusted.targetHandle;
|
|
133
|
-
}
|
|
134
|
-
const sourceId = source.rawNode.id;
|
|
135
|
-
const targetId = target.rawNode.id;
|
|
136
|
-
const sourceHandleId = sourceHandle.rawHandle.id;
|
|
137
|
-
const targetHandleId = targetHandle.rawHandle.id;
|
|
138
|
-
return {
|
|
139
|
-
source: sourceId,
|
|
140
|
-
target: targetId,
|
|
141
|
-
sourceHandle: sourceHandleId,
|
|
142
|
-
targetHandle: targetHandleId,
|
|
143
|
-
};
|
|
144
|
-
}
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connection-controller.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/connection-controller.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, computed, inject } from '@angular/core';\nimport { Connection, ReconnectionEvent } from '../interfaces/connection.interface';\nimport { FlowStatusConnectionEnd, FlowStatusReconnectionEnd, FlowStatusService } from '../services/flow-status.service';\n\nimport { FlowEntitiesService } from '../services/flow-entities.service';\nimport { HandleModel } from '../models/handle.model';\nimport { adjustDirection } from '../utils/adjust-direction';\nimport { outputFromObservable, toObservable } from '@angular/core/rxjs-interop';\nimport { filter, map, tap } from 'rxjs';\nimport { EdgeModel } from '../models/edge.model';\n\n@Directive({\n  selector: '[onConnect], [onReconnect], [connect], [reconnect]',\n  standalone: true,\n})\nexport class ConnectionControllerDirective {\n  private statusService = inject(FlowStatusService);\n  private flowEntitiesService = inject(FlowEntitiesService);\n\n  /**\n   * This event fires when user tries to create new Edge.\n   *\n   * `Connection` is an entity that contains data about source and target nodes.\n   *\n   * Also it's important to note, that this event only fires when connection is valid by validator function in `ConnectionSettings`,\n   * by default without passing the validator every connection concidered valid.\n   *\n   * @deprecated use `connect` output instead\n   */\n  // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n  public readonly onConnect = outputFromObservable<Connection>(\n    toObservable(this.statusService.status).pipe(\n      filter((status): status is FlowStatusConnectionEnd => status.state === 'connection-end'),\n      map((status) => statusToConnection(status, this.isStrictMode())),\n      tap(() => this.statusService.setIdleStatus()),\n      filter((connection) => this.flowEntitiesService.connection().validator(connection)),\n    ),\n  );\n\n  public readonly connect = outputFromObservable<Connection>(\n    toObservable(this.statusService.status).pipe(\n      filter((status): status is FlowStatusConnectionEnd => status.state === 'connection-end'),\n      map((status) => statusToConnection(status, this.isStrictMode())),\n      tap(() => this.statusService.setIdleStatus()),\n      filter((connection) => this.flowEntitiesService.connection().validator(connection)),\n    ),\n  );\n\n  /**\n   * @deprecated use `reconnect` output instead\n   */\n  public readonly onReconnect = outputFromObservable<ReconnectionEvent>(\n    toObservable(this.statusService.status).pipe(\n      filter((status): status is FlowStatusReconnectionEnd => status.state === 'reconnection-end'),\n      map((status) => {\n        const connection = statusToConnection(status, this.isStrictMode());\n        const oldEdge = status.payload.oldEdge.edge;\n\n        return { connection, oldEdge };\n      }),\n      tap(() => this.statusService.setIdleStatus()),\n      filter(({ connection }) => this.flowEntitiesService.connection().validator(connection)),\n    ),\n  );\n\n  public readonly reconnect = outputFromObservable<ReconnectionEvent>(\n    toObservable(this.statusService.status).pipe(\n      filter((status): status is FlowStatusReconnectionEnd => status.state === 'reconnection-end'),\n      map((status) => {\n        const connection = statusToConnection(status, this.isStrictMode());\n        const oldEdge = status.payload.oldEdge.edge;\n\n        return { connection, oldEdge };\n      }),\n      tap(() => this.statusService.setIdleStatus()),\n      filter(({ connection }) => this.flowEntitiesService.connection().validator(connection)),\n    ),\n  );\n\n  protected isStrictMode = computed(() => this.flowEntitiesService.connection().mode === 'strict');\n\n  public startConnection(handle: HandleModel) {\n    this.statusService.setConnectionStartStatus(handle.parentNode, handle);\n  }\n\n  public startReconnection(handle: HandleModel, oldEdge: EdgeModel) {\n    this.statusService.setReconnectionStartStatus(handle.parentNode, handle, oldEdge);\n  }\n\n  public validateConnection(handle: HandleModel) {\n    const status = this.statusService.status();\n\n    if (status.state === 'connection-start' || status.state === 'reconnection-start') {\n      const isReconnection = status.state === 'reconnection-start';\n\n      let source = status.payload.source;\n      let target = handle.parentNode;\n      let sourceHandle = status.payload.sourceHandle;\n      let targetHandle = handle;\n\n      if (this.isStrictMode()) {\n        // swap direction (if needed) according to actual source and target of strict mode\n        const adjusted = adjustDirection({\n          source: status.payload.source,\n          sourceHandle: status.payload.sourceHandle,\n          target: handle.parentNode,\n          targetHandle: handle,\n        });\n\n        source = adjusted.source;\n        target = adjusted.target;\n        sourceHandle = adjusted.sourceHandle;\n        targetHandle = adjusted.targetHandle;\n      }\n\n      const valid = this.flowEntitiesService.connection().validator({\n        source: source.rawNode.id,\n        target: target.rawNode.id,\n        sourceHandle: sourceHandle.rawHandle.id,\n        targetHandle: targetHandle.rawHandle.id,\n      });\n\n      // TODO: check how react flow handles highlight of handle\n      // if direction changes\n      handle.state.set(valid ? 'valid' : 'invalid');\n\n      // status is about how we draw connection, so we don't need\n      // swapped diretion here\n      isReconnection\n        ? this.statusService.setReconnectionValidationStatus(\n            valid,\n            status.payload.source,\n            handle.parentNode,\n            status.payload.sourceHandle,\n            handle,\n            status.payload.oldEdge,\n          )\n        : this.statusService.setConnectionValidationStatus(\n            valid,\n            status.payload.source,\n            handle.parentNode,\n            status.payload.sourceHandle,\n            handle,\n          );\n    }\n  }\n\n  public resetValidateConnection(targetHandle: HandleModel) {\n    targetHandle.state.set('idle');\n\n    // drop back to start status\n    const status = this.statusService.status();\n    if (status.state === 'connection-validation' || status.state === 'reconnection-validation') {\n      const isReconnection = status.state === 'reconnection-validation';\n\n      isReconnection\n        ? this.statusService.setReconnectionStartStatus(\n            status.payload.source,\n            status.payload.sourceHandle,\n            status.payload.oldEdge,\n          )\n        : this.statusService.setConnectionStartStatus(status.payload.source, status.payload.sourceHandle);\n    }\n  }\n\n  public endConnection() {\n    const status = this.statusService.status();\n\n    if (status.state === 'connection-validation' || status.state === 'reconnection-validation') {\n      const isReconnection = status.state === 'reconnection-validation';\n\n      const source = status.payload.source;\n      const sourceHandle = status.payload.sourceHandle;\n      const target = status.payload.target;\n      const targetHandle = status.payload.targetHandle;\n\n      isReconnection\n        ? this.statusService.setReconnectionEndStatus(\n            source,\n            target,\n            sourceHandle,\n            targetHandle,\n            status.payload.oldEdge,\n          )\n        : this.statusService.setConnectionEndStatus(source, target, sourceHandle, targetHandle);\n    }\n  }\n}\n\nfunction statusToConnection(\n  status: FlowStatusConnectionEnd | FlowStatusReconnectionEnd,\n  isStrictMode: boolean,\n): Connection {\n  let source = status.payload.source;\n  let target = status.payload.target;\n  let sourceHandle = status.payload.sourceHandle;\n  let targetHandle = status.payload.targetHandle;\n\n  if (isStrictMode) {\n    const adjusted = adjustDirection({\n      source: status.payload.source,\n      sourceHandle: status.payload.sourceHandle,\n      target: status.payload.target,\n      targetHandle: status.payload.targetHandle,\n    });\n\n    source = adjusted.source;\n    target = adjusted.target;\n    sourceHandle = adjusted.sourceHandle;\n    targetHandle = adjusted.targetHandle;\n  }\n\n  const sourceId = source.rawNode.id;\n  const targetId = target.rawNode.id;\n\n  const sourceHandleId = sourceHandle.rawHandle.id;\n  const targetHandleId = targetHandle.rawHandle.id;\n\n  return {\n    source: sourceId,\n    target: targetId,\n    sourceHandle: sourceHandleId,\n    targetHandle: targetHandleId,\n  };\n}\n"]}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { DestroyRef, Directive, inject } from '@angular/core';
|
|
2
|
-
import { NodeAccessorService } from '../services/node-accessor.service';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class DragHandleDirective {
|
|
5
|
-
get model() {
|
|
6
|
-
return this.nodeAccessor.model();
|
|
7
|
-
}
|
|
8
|
-
constructor() {
|
|
9
|
-
this.nodeAccessor = inject(NodeAccessorService);
|
|
10
|
-
this.model.dragHandlesCount.update((count) => count + 1);
|
|
11
|
-
inject(DestroyRef).onDestroy(() => {
|
|
12
|
-
this.model.dragHandlesCount.update((count) => count - 1);
|
|
13
|
-
});
|
|
14
|
-
}
|
|
15
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DragHandleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
16
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: DragHandleDirective, isStandalone: true, selector: "[dragHandle]", host: { classAttribute: "vflow-drag-handle" }, ngImport: i0 }); }
|
|
17
|
-
}
|
|
18
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DragHandleDirective, decorators: [{
|
|
19
|
-
type: Directive,
|
|
20
|
-
args: [{
|
|
21
|
-
standalone: true,
|
|
22
|
-
selector: '[dragHandle]',
|
|
23
|
-
host: {
|
|
24
|
-
class: 'vflow-drag-handle',
|
|
25
|
-
},
|
|
26
|
-
}]
|
|
27
|
-
}], ctorParameters: () => [] });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1oYW5kbGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2RpcmVjdGl2ZXMvZHJhZy1oYW5kbGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFTeEUsTUFBTSxPQUFPLG1CQUFtQjtJQUc5QixJQUFZLEtBQUs7UUFDZixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFHLENBQUM7SUFDcEMsQ0FBQztJQUVEO1FBTlEsaUJBQVksR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQU9qRCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBRXpELE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDM0QsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOytHQWJVLG1CQUFtQjttR0FBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQVAvQixTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsY0FBYztvQkFDeEIsSUFBSSxFQUFFO3dCQUNKLEtBQUssRUFBRSxtQkFBbUI7cUJBQzNCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgRGlyZWN0aXZlLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5vZGVBY2Nlc3NvclNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9ub2RlLWFjY2Vzc29yLnNlcnZpY2UnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdbZHJhZ0hhbmRsZV0nLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICd2Zmxvdy1kcmFnLWhhbmRsZScsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIERyYWdIYW5kbGVEaXJlY3RpdmUge1xuICBwcml2YXRlIG5vZGVBY2Nlc3NvciA9IGluamVjdChOb2RlQWNjZXNzb3JTZXJ2aWNlKTtcblxuICBwcml2YXRlIGdldCBtb2RlbCgpIHtcbiAgICByZXR1cm4gdGhpcy5ub2RlQWNjZXNzb3IubW9kZWwoKSE7XG4gIH1cblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLm1vZGVsLmRyYWdIYW5kbGVzQ291bnQudXBkYXRlKChjb3VudCkgPT4gY291bnQgKyAxKTtcblxuICAgIGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT4ge1xuICAgICAgdGhpcy5tb2RlbC5kcmFnSGFuZGxlc0NvdW50LnVwZGF0ZSgoY291bnQpID0+IGNvdW50IC0gMSk7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { Directive, ElementRef, NgZone, computed, inject } from '@angular/core';
|
|
2
|
-
import { resizable } from '../utils/resizable';
|
|
3
|
-
import { tap } from 'rxjs';
|
|
4
|
-
import { FlowSettingsService } from '../services/flow-settings.service';
|
|
5
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export class FlowSizeControllerDirective {
|
|
8
|
-
constructor() {
|
|
9
|
-
this.host = inject(ElementRef);
|
|
10
|
-
this.flowSettingsService = inject(FlowSettingsService);
|
|
11
|
-
this.flowWidth = computed(() => {
|
|
12
|
-
const view = this.flowSettingsService.view();
|
|
13
|
-
return view === 'auto' ? '100%' : view[0];
|
|
14
|
-
});
|
|
15
|
-
this.flowHeight = computed(() => {
|
|
16
|
-
const view = this.flowSettingsService.view();
|
|
17
|
-
return view === 'auto' ? '100%' : view[1];
|
|
18
|
-
});
|
|
19
|
-
resizable([this.host.nativeElement], inject(NgZone))
|
|
20
|
-
.pipe(tap(([entry]) => {
|
|
21
|
-
this.flowSettingsService.computedFlowWidth.set(entry.contentRect.width);
|
|
22
|
-
this.flowSettingsService.computedFlowHeight.set(entry.contentRect.height);
|
|
23
|
-
}), takeUntilDestroyed())
|
|
24
|
-
.subscribe();
|
|
25
|
-
}
|
|
26
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowSizeControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
27
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: FlowSizeControllerDirective, isStandalone: true, selector: "svg[flowSizeController]", host: { properties: { "attr.width": "flowWidth()", "attr.height": "flowHeight()" } }, ngImport: i0 }); }
|
|
28
|
-
}
|
|
29
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowSizeControllerDirective, decorators: [{
|
|
30
|
-
type: Directive,
|
|
31
|
-
args: [{
|
|
32
|
-
standalone: true,
|
|
33
|
-
selector: 'svg[flowSizeController]',
|
|
34
|
-
host: {
|
|
35
|
-
'[attr.width]': 'flowWidth()',
|
|
36
|
-
'[attr.height]': 'flowHeight()',
|
|
37
|
-
},
|
|
38
|
-
}]
|
|
39
|
-
}], ctorParameters: () => [] });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvdy1zaXplLWNvbnRyb2xsZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2RpcmVjdGl2ZXMvZmxvdy1zaXplLWNvbnRyb2xsZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBVSxRQUFRLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hGLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNCLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQVVoRSxNQUFNLE9BQU8sMkJBQTJCO0lBZ0J0QztRQWZRLFNBQUksR0FBRyxNQUFNLENBQTRCLFVBQVUsQ0FBQyxDQUFDO1FBQ3JELHdCQUFtQixHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBRW5ELGNBQVMsR0FBNEIsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUN4RCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxFQUFFLENBQUM7WUFFN0MsT0FBTyxJQUFJLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM1QyxDQUFDLENBQUMsQ0FBQztRQUVJLGVBQVUsR0FBNEIsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUN6RCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxFQUFFLENBQUM7WUFFN0MsT0FBTyxJQUFJLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM1QyxDQUFDLENBQUMsQ0FBQztRQUdELFNBQVMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO2FBQ2pELElBQUksQ0FDSCxHQUFHLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUFFLEVBQUU7WUFDZCxJQUFJLENBQUMsbUJBQW1CLENBQUMsaUJBQWlCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDeEUsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzVFLENBQUMsQ0FBQyxFQUNGLGtCQUFrQixFQUFFLENBQ3JCO2FBQ0EsU0FBUyxFQUFFLENBQUM7SUFDakIsQ0FBQzsrR0ExQlUsMkJBQTJCO21HQUEzQiwyQkFBMkI7OzRGQUEzQiwyQkFBMkI7a0JBUnZDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSx5QkFBeUI7b0JBQ25DLElBQUksRUFBRTt3QkFDSixjQUFjLEVBQUUsYUFBYTt3QkFDN0IsZUFBZSxFQUFFLGNBQWM7cUJBQ2hDO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBOZ1pvbmUsIFNpZ25hbCwgY29tcHV0ZWQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgcmVzaXphYmxlIH0gZnJvbSAnLi4vdXRpbHMvcmVzaXphYmxlJztcbmltcG9ydCB7IHRhcCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRmxvd1NldHRpbmdzU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2Zsb3ctc2V0dGluZ3Muc2VydmljZSc7XG5pbXBvcnQgeyB0YWtlVW50aWxEZXN0cm95ZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ3N2Z1tmbG93U2l6ZUNvbnRyb2xsZXJdJyxcbiAgaG9zdDoge1xuICAgICdbYXR0ci53aWR0aF0nOiAnZmxvd1dpZHRoKCknLFxuICAgICdbYXR0ci5oZWlnaHRdJzogJ2Zsb3dIZWlnaHQoKScsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIEZsb3dTaXplQ29udHJvbGxlckRpcmVjdGl2ZSB7XG4gIHByaXZhdGUgaG9zdCA9IGluamVjdDxFbGVtZW50UmVmPFNWR1NWR0VsZW1lbnQ+PihFbGVtZW50UmVmKTtcbiAgcHJpdmF0ZSBmbG93U2V0dGluZ3NTZXJ2aWNlID0gaW5qZWN0KEZsb3dTZXR0aW5nc1NlcnZpY2UpO1xuXG4gIHB1YmxpYyBmbG93V2lkdGg6IFNpZ25hbDxzdHJpbmcgfCBudW1iZXI+ID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGNvbnN0IHZpZXcgPSB0aGlzLmZsb3dTZXR0aW5nc1NlcnZpY2UudmlldygpO1xuXG4gICAgcmV0dXJuIHZpZXcgPT09ICdhdXRvJyA/ICcxMDAlJyA6IHZpZXdbMF07XG4gIH0pO1xuXG4gIHB1YmxpYyBmbG93SGVpZ2h0OiBTaWduYWw8c3RyaW5nIHwgbnVtYmVyPiA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCB2aWV3ID0gdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLnZpZXcoKTtcblxuICAgIHJldHVybiB2aWV3ID09PSAnYXV0bycgPyAnMTAwJScgOiB2aWV3WzFdO1xuICB9KTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICByZXNpemFibGUoW3RoaXMuaG9zdC5uYXRpdmVFbGVtZW50XSwgaW5qZWN0KE5nWm9uZSkpXG4gICAgICAucGlwZShcbiAgICAgICAgdGFwKChbZW50cnldKSA9PiB7XG4gICAgICAgICAgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLmNvbXB1dGVkRmxvd1dpZHRoLnNldChlbnRyeS5jb250ZW50UmVjdC53aWR0aCk7XG4gICAgICAgICAgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLmNvbXB1dGVkRmxvd0hlaWdodC5zZXQoZW50cnkuY29udGVudFJlY3QuaGVpZ2h0KTtcbiAgICAgICAgfSksXG4gICAgICAgIHRha2VVbnRpbERlc3Ryb3llZCgpLFxuICAgICAgKVxuICAgICAgLnN1YnNjcmliZSgpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { Directive, ElementRef, inject, input } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class HandleSizeControllerDirective {
|
|
4
|
-
constructor() {
|
|
5
|
-
this.handleModel = input.required({
|
|
6
|
-
alias: 'handleSizeController',
|
|
7
|
-
});
|
|
8
|
-
this.handleWrapper = inject(ElementRef);
|
|
9
|
-
}
|
|
10
|
-
ngAfterViewInit() {
|
|
11
|
-
const element = this.handleWrapper.nativeElement;
|
|
12
|
-
const rect = element.getBBox();
|
|
13
|
-
const stroke = getChildStrokeWidth(element);
|
|
14
|
-
this.handleModel().size.set({
|
|
15
|
-
width: rect.width + stroke,
|
|
16
|
-
height: rect.height + stroke,
|
|
17
|
-
});
|
|
18
|
-
}
|
|
19
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HandleSizeControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
20
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.12", type: HandleSizeControllerDirective, isStandalone: true, selector: "[handleSizeController]", inputs: { handleModel: { classPropertyName: "handleModel", publicName: "handleSizeController", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0 }); }
|
|
21
|
-
}
|
|
22
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HandleSizeControllerDirective, decorators: [{
|
|
23
|
-
type: Directive,
|
|
24
|
-
args: [{
|
|
25
|
-
standalone: true,
|
|
26
|
-
selector: '[handleSizeController]',
|
|
27
|
-
}]
|
|
28
|
-
}] });
|
|
29
|
-
function getChildStrokeWidth(element) {
|
|
30
|
-
const child = element.firstElementChild;
|
|
31
|
-
if (child) {
|
|
32
|
-
const stroke = getComputedStyle(child).strokeWidth;
|
|
33
|
-
const strokeAsNumber = Number(stroke.replace('px', ''));
|
|
34
|
-
if (isNaN(strokeAsNumber)) {
|
|
35
|
-
return 0;
|
|
36
|
-
}
|
|
37
|
-
return strokeAsNumber;
|
|
38
|
-
}
|
|
39
|
-
return 0;
|
|
40
|
-
}
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFuZGxlLXNpemUtY29udHJvbGxlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvZGlyZWN0aXZlcy9oYW5kbGUtc2l6ZS1jb250cm9sbGVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlCLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPcEYsTUFBTSxPQUFPLDZCQUE2QjtJQUoxQztRQUtTLGdCQUFXLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBYztZQUMvQyxLQUFLLEVBQUUsc0JBQXNCO1NBQzlCLENBQUMsQ0FBQztRQUVLLGtCQUFhLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBNEIsQ0FBQztLQVl2RTtJQVZRLGVBQWU7UUFDcEIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUM7UUFDakQsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBRS9CLE1BQU0sTUFBTSxHQUFHLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzVDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1lBQzFCLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxHQUFHLE1BQU07WUFDMUIsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTTtTQUM3QixDQUFDLENBQUM7SUFDTCxDQUFDOytHQWhCVSw2QkFBNkI7bUdBQTdCLDZCQUE2Qjs7NEZBQTdCLDZCQUE2QjtrQkFKekMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLHdCQUF3QjtpQkFDbkM7O0FBb0JELFNBQVMsbUJBQW1CLENBQUMsT0FBb0I7SUFDL0MsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLGlCQUFpQixDQUFDO0lBRXhDLElBQUksS0FBSyxFQUFFLENBQUM7UUFDVixNQUFNLE1BQU0sR0FBRyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxXQUFXLENBQUM7UUFDbkQsTUFBTSxjQUFjLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFeEQsSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLEVBQUUsQ0FBQztZQUMxQixPQUFPLENBQUMsQ0FBQztRQUNYLENBQUM7UUFFRCxPQUFPLGNBQWMsQ0FBQztJQUN4QixDQUFDO0lBRUQsT0FBTyxDQUFDLENBQUM7QUFDWCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBIYW5kbGVNb2RlbCB9IGZyb20gJy4uL21vZGVscy9oYW5kbGUubW9kZWwnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdbaGFuZGxlU2l6ZUNvbnRyb2xsZXJdJyxcbn0pXG5leHBvcnQgY2xhc3MgSGFuZGxlU2l6ZUNvbnRyb2xsZXJEaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcbiAgcHVibGljIGhhbmRsZU1vZGVsID0gaW5wdXQucmVxdWlyZWQ8SGFuZGxlTW9kZWw+KHtcbiAgICBhbGlhczogJ2hhbmRsZVNpemVDb250cm9sbGVyJyxcbiAgfSk7XG5cbiAgcHJpdmF0ZSBoYW5kbGVXcmFwcGVyID0gaW5qZWN0KEVsZW1lbnRSZWYpIGFzIEVsZW1lbnRSZWY8U1ZHR0VsZW1lbnQ+O1xuXG4gIHB1YmxpYyBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgY29uc3QgZWxlbWVudCA9IHRoaXMuaGFuZGxlV3JhcHBlci5uYXRpdmVFbGVtZW50O1xuICAgIGNvbnN0IHJlY3QgPSBlbGVtZW50LmdldEJCb3goKTtcblxuICAgIGNvbnN0IHN0cm9rZSA9IGdldENoaWxkU3Ryb2tlV2lkdGgoZWxlbWVudCk7XG4gICAgdGhpcy5oYW5kbGVNb2RlbCgpLnNpemUuc2V0KHtcbiAgICAgIHdpZHRoOiByZWN0LndpZHRoICsgc3Ryb2tlLFxuICAgICAgaGVpZ2h0OiByZWN0LmhlaWdodCArIHN0cm9rZSxcbiAgICB9KTtcbiAgfVxufVxuXG5mdW5jdGlvbiBnZXRDaGlsZFN0cm9rZVdpZHRoKGVsZW1lbnQ6IFNWR0dFbGVtZW50KSB7XG4gIGNvbnN0IGNoaWxkID0gZWxlbWVudC5maXJzdEVsZW1lbnRDaGlsZDtcblxuICBpZiAoY2hpbGQpIHtcbiAgICBjb25zdCBzdHJva2UgPSBnZXRDb21wdXRlZFN0eWxlKGNoaWxkKS5zdHJva2VXaWR0aDtcbiAgICBjb25zdCBzdHJva2VBc051bWJlciA9IE51bWJlcihzdHJva2UucmVwbGFjZSgncHgnLCAnJykpO1xuXG4gICAgaWYgKGlzTmFOKHN0cm9rZUFzTnVtYmVyKSkge1xuICAgICAgcmV0dXJuIDA7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0cm9rZUFzTnVtYmVyO1xuICB9XG5cbiAgcmV0dXJuIDA7XG59XG4iXX0=
|