@angflow/angular 0.0.1
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 +187 -0
- package/dist/base.css +1204 -0
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +2 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/components/a11y-descriptions/a11y-descriptions.component.d.ts +25 -0
- package/dist/esm/lib/components/a11y-descriptions/a11y-descriptions.component.d.ts.map +1 -0
- package/dist/esm/lib/components/a11y-descriptions/a11y-descriptions.component.js +58 -0
- package/dist/esm/lib/components/a11y-descriptions/a11y-descriptions.component.js.map +1 -0
- package/dist/esm/lib/components/attribution/attribution.component.d.ts +6 -0
- package/dist/esm/lib/components/attribution/attribution.component.d.ts.map +1 -0
- package/dist/esm/lib/components/attribution/attribution.component.js +32 -0
- package/dist/esm/lib/components/attribution/attribution.component.js.map +1 -0
- package/dist/esm/lib/components/background/background.component.d.ts +31 -0
- package/dist/esm/lib/components/background/background.component.d.ts.map +1 -0
- package/dist/esm/lib/components/background/background.component.js +209 -0
- package/dist/esm/lib/components/background/background.component.js.map +1 -0
- package/dist/esm/lib/components/connection-line/connection-line.component.d.ts +36 -0
- package/dist/esm/lib/components/connection-line/connection-line.component.d.ts.map +1 -0
- package/dist/esm/lib/components/connection-line/connection-line.component.js +146 -0
- package/dist/esm/lib/components/connection-line/connection-line.component.js.map +1 -0
- package/dist/esm/lib/components/controls/controls.component.d.ts +25 -0
- package/dist/esm/lib/components/controls/controls.component.d.ts.map +1 -0
- package/dist/esm/lib/components/controls/controls.component.js +174 -0
- package/dist/esm/lib/components/controls/controls.component.js.map +1 -0
- package/dist/esm/lib/components/edge-label-renderer/edge-label-renderer.component.d.ts +6 -0
- package/dist/esm/lib/components/edge-label-renderer/edge-label-renderer.component.d.ts.map +1 -0
- package/dist/esm/lib/components/edge-label-renderer/edge-label-renderer.component.js +24 -0
- package/dist/esm/lib/components/edge-label-renderer/edge-label-renderer.component.js.map +1 -0
- package/dist/esm/lib/components/edge-toolbar/edge-toolbar.component.d.ts +22 -0
- package/dist/esm/lib/components/edge-toolbar/edge-toolbar.component.d.ts.map +1 -0
- package/dist/esm/lib/components/edge-toolbar/edge-toolbar.component.js +64 -0
- package/dist/esm/lib/components/edge-toolbar/edge-toolbar.component.js.map +1 -0
- package/dist/esm/lib/components/edges/base-edge.component.d.ts +11 -0
- package/dist/esm/lib/components/edges/base-edge.component.d.ts.map +1 -0
- package/dist/esm/lib/components/edges/base-edge.component.js +56 -0
- package/dist/esm/lib/components/edges/base-edge.component.js.map +1 -0
- package/dist/esm/lib/components/edges/bezier-edge.component.d.ts +30 -0
- package/dist/esm/lib/components/edges/bezier-edge.component.d.ts.map +1 -0
- package/dist/esm/lib/components/edges/bezier-edge.component.js +68 -0
- package/dist/esm/lib/components/edges/bezier-edge.component.js.map +1 -0
- package/dist/esm/lib/components/edges/edge-text.component.d.ts +11 -0
- package/dist/esm/lib/components/edges/edge-text.component.d.ts.map +1 -0
- package/dist/esm/lib/components/edges/edge-text.component.js +48 -0
- package/dist/esm/lib/components/edges/edge-text.component.js.map +1 -0
- package/dist/esm/lib/components/edges/simple-bezier-edge.component.d.ts +21 -0
- package/dist/esm/lib/components/edges/simple-bezier-edge.component.d.ts.map +1 -0
- package/dist/esm/lib/components/edges/simple-bezier-edge.component.js +57 -0
- package/dist/esm/lib/components/edges/simple-bezier-edge.component.js.map +1 -0
- package/dist/esm/lib/components/edges/smooth-step-edge.component.d.ts +22 -0
- package/dist/esm/lib/components/edges/smooth-step-edge.component.d.ts.map +1 -0
- package/dist/esm/lib/components/edges/smooth-step-edge.component.js +59 -0
- package/dist/esm/lib/components/edges/smooth-step-edge.component.js.map +1 -0
- package/dist/esm/lib/components/edges/step-edge.component.d.ts +22 -0
- package/dist/esm/lib/components/edges/step-edge.component.d.ts.map +1 -0
- package/dist/esm/lib/components/edges/step-edge.component.js +60 -0
- package/dist/esm/lib/components/edges/step-edge.component.js.map +1 -0
- package/dist/esm/lib/components/edges/straight-edge.component.d.ts +18 -0
- package/dist/esm/lib/components/edges/straight-edge.component.d.ts.map +1 -0
- package/dist/esm/lib/components/edges/straight-edge.component.js +53 -0
- package/dist/esm/lib/components/edges/straight-edge.component.js.map +1 -0
- package/dist/esm/lib/components/handle/handle.component.d.ts +28 -0
- package/dist/esm/lib/components/handle/handle.component.d.ts.map +1 -0
- package/dist/esm/lib/components/handle/handle.component.js +162 -0
- package/dist/esm/lib/components/handle/handle.component.js.map +1 -0
- package/dist/esm/lib/components/minimap/minimap.component.d.ts +75 -0
- package/dist/esm/lib/components/minimap/minimap.component.d.ts.map +1 -0
- package/dist/esm/lib/components/minimap/minimap.component.js +319 -0
- package/dist/esm/lib/components/minimap/minimap.component.js.map +1 -0
- package/dist/esm/lib/components/ng-flow-provider/ng-flow-provider.component.d.ts +6 -0
- package/dist/esm/lib/components/ng-flow-provider/ng-flow-provider.component.d.ts.map +1 -0
- package/dist/esm/lib/components/ng-flow-provider/ng-flow-provider.component.js +24 -0
- package/dist/esm/lib/components/ng-flow-provider/ng-flow-provider.component.js.map +1 -0
- package/dist/esm/lib/components/node-resizer/node-resizer.component.d.ts +44 -0
- package/dist/esm/lib/components/node-resizer/node-resizer.component.d.ts.map +1 -0
- package/dist/esm/lib/components/node-resizer/node-resizer.component.js +198 -0
- package/dist/esm/lib/components/node-resizer/node-resizer.component.js.map +1 -0
- package/dist/esm/lib/components/node-toolbar/node-toolbar.component.d.ts +19 -0
- package/dist/esm/lib/components/node-toolbar/node-toolbar.component.d.ts.map +1 -0
- package/dist/esm/lib/components/node-toolbar/node-toolbar.component.js +101 -0
- package/dist/esm/lib/components/node-toolbar/node-toolbar.component.js.map +1 -0
- package/dist/esm/lib/components/nodes/default-node.component.d.ts +20 -0
- package/dist/esm/lib/components/nodes/default-node.component.d.ts.map +1 -0
- package/dist/esm/lib/components/nodes/default-node.component.js +52 -0
- package/dist/esm/lib/components/nodes/default-node.component.js.map +1 -0
- package/dist/esm/lib/components/nodes/group-node.component.d.ts +19 -0
- package/dist/esm/lib/components/nodes/group-node.component.d.ts.map +1 -0
- package/dist/esm/lib/components/nodes/group-node.component.js +34 -0
- package/dist/esm/lib/components/nodes/group-node.component.js.map +1 -0
- package/dist/esm/lib/components/nodes/input-node.component.d.ts +20 -0
- package/dist/esm/lib/components/nodes/input-node.component.d.ts.map +1 -0
- package/dist/esm/lib/components/nodes/input-node.component.js +49 -0
- package/dist/esm/lib/components/nodes/input-node.component.js.map +1 -0
- package/dist/esm/lib/components/nodes/output-node.component.d.ts +20 -0
- package/dist/esm/lib/components/nodes/output-node.component.d.ts.map +1 -0
- package/dist/esm/lib/components/nodes/output-node.component.js +48 -0
- package/dist/esm/lib/components/nodes/output-node.component.js.map +1 -0
- package/dist/esm/lib/components/panel/panel.component.d.ts +13 -0
- package/dist/esm/lib/components/panel/panel.component.d.ts.map +1 -0
- package/dist/esm/lib/components/panel/panel.component.js +39 -0
- package/dist/esm/lib/components/panel/panel.component.js.map +1 -0
- package/dist/esm/lib/components/selection-box/selection-box.component.d.ts +12 -0
- package/dist/esm/lib/components/selection-box/selection-box.component.d.ts.map +1 -0
- package/dist/esm/lib/components/selection-box/selection-box.component.js +56 -0
- package/dist/esm/lib/components/selection-box/selection-box.component.js.map +1 -0
- package/dist/esm/lib/components/viewport-portal/viewport-portal.component.d.ts +8 -0
- package/dist/esm/lib/components/viewport-portal/viewport-portal.component.d.ts.map +1 -0
- package/dist/esm/lib/components/viewport-portal/viewport-portal.component.js +35 -0
- package/dist/esm/lib/components/viewport-portal/viewport-portal.component.js.map +1 -0
- package/dist/esm/lib/container/edge-renderer/edge-renderer.component.d.ts +70 -0
- package/dist/esm/lib/container/edge-renderer/edge-renderer.component.d.ts.map +1 -0
- package/dist/esm/lib/container/edge-renderer/edge-renderer.component.js +503 -0
- package/dist/esm/lib/container/edge-renderer/edge-renderer.component.js.map +1 -0
- package/dist/esm/lib/container/ng-flow/ng-flow.component.d.ts +281 -0
- package/dist/esm/lib/container/ng-flow/ng-flow.component.d.ts.map +1 -0
- package/dist/esm/lib/container/ng-flow/ng-flow.component.js +644 -0
- package/dist/esm/lib/container/ng-flow/ng-flow.component.js.map +1 -0
- package/dist/esm/lib/container/node-renderer/node-renderer.component.d.ts +56 -0
- package/dist/esm/lib/container/node-renderer/node-renderer.component.d.ts.map +1 -0
- package/dist/esm/lib/container/node-renderer/node-renderer.component.js +312 -0
- package/dist/esm/lib/container/node-renderer/node-renderer.component.js.map +1 -0
- package/dist/esm/lib/container/pane/pane.component.d.ts +35 -0
- package/dist/esm/lib/container/pane/pane.component.d.ts.map +1 -0
- package/dist/esm/lib/container/pane/pane.component.js +161 -0
- package/dist/esm/lib/container/pane/pane.component.js.map +1 -0
- package/dist/esm/lib/container/viewport/viewport.component.d.ts +9 -0
- package/dist/esm/lib/container/viewport/viewport.component.d.ts.map +1 -0
- package/dist/esm/lib/container/viewport/viewport.component.js +35 -0
- package/dist/esm/lib/container/viewport/viewport.component.js.map +1 -0
- package/dist/esm/lib/directives/drag.directive.d.ts +21 -0
- package/dist/esm/lib/directives/drag.directive.d.ts.map +1 -0
- package/dist/esm/lib/directives/drag.directive.js +69 -0
- package/dist/esm/lib/directives/drag.directive.js.map +1 -0
- package/dist/esm/lib/directives/drop-zone.directive.d.ts +30 -0
- package/dist/esm/lib/directives/drop-zone.directive.d.ts.map +1 -0
- package/dist/esm/lib/directives/drop-zone.directive.js +58 -0
- package/dist/esm/lib/directives/drop-zone.directive.js.map +1 -0
- package/dist/esm/lib/directives/key-handler.directive.d.ts +29 -0
- package/dist/esm/lib/directives/key-handler.directive.d.ts.map +1 -0
- package/dist/esm/lib/directives/key-handler.directive.js +176 -0
- package/dist/esm/lib/directives/key-handler.directive.js.map +1 -0
- package/dist/esm/lib/directives/node-type.directive.d.ts +21 -0
- package/dist/esm/lib/directives/node-type.directive.d.ts.map +1 -0
- package/dist/esm/lib/directives/node-type.directive.js +32 -0
- package/dist/esm/lib/directives/node-type.directive.js.map +1 -0
- package/dist/esm/lib/public-api.d.ts +40 -0
- package/dist/esm/lib/public-api.d.ts.map +1 -0
- package/dist/esm/lib/public-api.js +67 -0
- package/dist/esm/lib/public-api.js.map +1 -0
- package/dist/esm/lib/services/flow-store.service.d.ts +227 -0
- package/dist/esm/lib/services/flow-store.service.d.ts.map +1 -0
- package/dist/esm/lib/services/flow-store.service.js +542 -0
- package/dist/esm/lib/services/flow-store.service.js.map +1 -0
- package/dist/esm/lib/services/ng-flow.service.d.ts +186 -0
- package/dist/esm/lib/services/ng-flow.service.d.ts.map +1 -0
- package/dist/esm/lib/services/ng-flow.service.js +501 -0
- package/dist/esm/lib/services/ng-flow.service.js.map +1 -0
- package/dist/esm/lib/services/tokens.d.ts +4 -0
- package/dist/esm/lib/services/tokens.d.ts.map +1 -0
- package/dist/esm/lib/services/tokens.js +4 -0
- package/dist/esm/lib/services/tokens.js.map +1 -0
- package/dist/esm/lib/types/edges.d.ts +83 -0
- package/dist/esm/lib/types/edges.d.ts.map +1 -0
- package/dist/esm/lib/types/edges.js +2 -0
- package/dist/esm/lib/types/edges.js.map +1 -0
- package/dist/esm/lib/types/general.d.ts +128 -0
- package/dist/esm/lib/types/general.d.ts.map +1 -0
- package/dist/esm/lib/types/general.js +2 -0
- package/dist/esm/lib/types/general.js.map +1 -0
- package/dist/esm/lib/types/index.d.ts +5 -0
- package/dist/esm/lib/types/index.d.ts.map +1 -0
- package/dist/esm/lib/types/index.js +5 -0
- package/dist/esm/lib/types/index.js.map +1 -0
- package/dist/esm/lib/types/nodes.d.ts +53 -0
- package/dist/esm/lib/types/nodes.d.ts.map +1 -0
- package/dist/esm/lib/types/nodes.js +2 -0
- package/dist/esm/lib/types/nodes.js.map +1 -0
- package/dist/esm/lib/types/store.d.ts +71 -0
- package/dist/esm/lib/types/store.d.ts.map +1 -0
- package/dist/esm/lib/types/store.js +2 -0
- package/dist/esm/lib/types/store.js.map +1 -0
- package/dist/esm/lib/utils/changes.d.ts +12 -0
- package/dist/esm/lib/utils/changes.d.ts.map +1 -0
- package/dist/esm/lib/utils/changes.js +134 -0
- package/dist/esm/lib/utils/changes.js.map +1 -0
- package/dist/esm/lib/utils/index.d.ts +2 -0
- package/dist/esm/lib/utils/index.d.ts.map +1 -0
- package/dist/esm/lib/utils/index.js +2 -0
- package/dist/esm/lib/utils/index.js.map +1 -0
- package/dist/esm/lib/utils/type-guards.d.ts +12 -0
- package/dist/esm/lib/utils/type-guards.d.ts.map +1 -0
- package/dist/esm/lib/utils/type-guards.js +16 -0
- package/dist/esm/lib/utils/type-guards.js.map +1 -0
- package/dist/style.css +1392 -0
- package/package.json +60 -0
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Position } from '@angflow/system';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class InputNodeComponent {
|
|
4
|
+
readonly Position: typeof Position;
|
|
5
|
+
readonly id: import("@angular/core").InputSignal<string>;
|
|
6
|
+
readonly data: import("@angular/core").InputSignal<any>;
|
|
7
|
+
readonly type: import("@angular/core").InputSignal<string | undefined>;
|
|
8
|
+
readonly selected: import("@angular/core").InputSignal<boolean>;
|
|
9
|
+
readonly dragging: import("@angular/core").InputSignal<boolean>;
|
|
10
|
+
readonly zIndex: import("@angular/core").InputSignal<number>;
|
|
11
|
+
readonly isConnectable: import("@angular/core").InputSignal<boolean>;
|
|
12
|
+
readonly positionAbsoluteX: import("@angular/core").InputSignal<number>;
|
|
13
|
+
readonly positionAbsoluteY: import("@angular/core").InputSignal<number>;
|
|
14
|
+
readonly sourcePosition: import("@angular/core").InputSignal<Position | undefined>;
|
|
15
|
+
readonly targetPosition: import("@angular/core").InputSignal<Position | undefined>;
|
|
16
|
+
readonly dragHandle: import("@angular/core").InputSignal<string | undefined>;
|
|
17
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<InputNodeComponent, never>;
|
|
18
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<InputNodeComponent, "ng-flow-input-node", never, { "id": { "alias": "id"; "required": true; "isSignal": true; }; "data": { "alias": "data"; "required": false; "isSignal": true; }; "type": { "alias": "type"; "required": false; "isSignal": true; }; "selected": { "alias": "selected"; "required": false; "isSignal": true; }; "dragging": { "alias": "dragging"; "required": false; "isSignal": true; }; "zIndex": { "alias": "zIndex"; "required": false; "isSignal": true; }; "isConnectable": { "alias": "isConnectable"; "required": false; "isSignal": true; }; "positionAbsoluteX": { "alias": "positionAbsoluteX"; "required": false; "isSignal": true; }; "positionAbsoluteY": { "alias": "positionAbsoluteY"; "required": false; "isSignal": true; }; "sourcePosition": { "alias": "sourcePosition"; "required": false; "isSignal": true; }; "targetPosition": { "alias": "targetPosition"; "required": false; "isSignal": true; }; "dragHandle": { "alias": "dragHandle"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=input-node.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"input-node.component.d.ts","sourceRoot":"","sources":["../../../../../src/lib/components/nodes/input-node.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;AAE3C,qBAUa,kBAAkB;IAC7B,QAAQ,CAAC,QAAQ,kBAAY;IAC7B,QAAQ,CAAC,EAAE,8CAA4B;IACvC,QAAQ,CAAC,IAAI,2CAAgB;IAC7B,QAAQ,CAAC,IAAI,0DAAmB;IAChC,QAAQ,CAAC,QAAQ,+CAAgB;IACjC,QAAQ,CAAC,QAAQ,+CAAgB;IACjC,QAAQ,CAAC,MAAM,8CAAY;IAC3B,QAAQ,CAAC,aAAa,+CAAe;IACrC,QAAQ,CAAC,iBAAiB,8CAAY;IACtC,QAAQ,CAAC,iBAAiB,8CAAY;IACtC,QAAQ,CAAC,cAAc,4DAAqB;IAC5C,QAAQ,CAAC,cAAc,4DAAqB;IAC5C,QAAQ,CAAC,UAAU,0DAAmB;yCAb3B,kBAAkB;2CAAlB,kBAAkB;CAc9B"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, input } from '@angular/core';
|
|
2
|
+
import { HandleComponent } from '../handle/handle.component';
|
|
3
|
+
import { Position } from '@angflow/system';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class InputNodeComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.Position = Position;
|
|
8
|
+
this.id = input.required(...(ngDevMode ? [{ debugName: "id" }] : /* istanbul ignore next */ []));
|
|
9
|
+
this.data = input(...(ngDevMode ? [undefined, { debugName: "data" }] : /* istanbul ignore next */ []));
|
|
10
|
+
this.type = input(...(ngDevMode ? [undefined, { debugName: "type" }] : /* istanbul ignore next */ []));
|
|
11
|
+
this.selected = input(false, ...(ngDevMode ? [{ debugName: "selected" }] : /* istanbul ignore next */ []));
|
|
12
|
+
this.dragging = input(false, ...(ngDevMode ? [{ debugName: "dragging" }] : /* istanbul ignore next */ []));
|
|
13
|
+
this.zIndex = input(0, ...(ngDevMode ? [{ debugName: "zIndex" }] : /* istanbul ignore next */ []));
|
|
14
|
+
this.isConnectable = input(true, ...(ngDevMode ? [{ debugName: "isConnectable" }] : /* istanbul ignore next */ []));
|
|
15
|
+
this.positionAbsoluteX = input(0, ...(ngDevMode ? [{ debugName: "positionAbsoluteX" }] : /* istanbul ignore next */ []));
|
|
16
|
+
this.positionAbsoluteY = input(0, ...(ngDevMode ? [{ debugName: "positionAbsoluteY" }] : /* istanbul ignore next */ []));
|
|
17
|
+
this.sourcePosition = input(...(ngDevMode ? [undefined, { debugName: "sourcePosition" }] : /* istanbul ignore next */ []));
|
|
18
|
+
this.targetPosition = input(...(ngDevMode ? [undefined, { debugName: "targetPosition" }] : /* istanbul ignore next */ []));
|
|
19
|
+
this.dragHandle = input(...(ngDevMode ? [undefined, { debugName: "dragHandle" }] : /* istanbul ignore next */ []));
|
|
20
|
+
}
|
|
21
|
+
static { this.ɵfac = function InputNodeComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || InputNodeComponent)(); }; }
|
|
22
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: InputNodeComponent, selectors: [["ng-flow-input-node"]], inputs: { id: [1, "id"], data: [1, "data"], type: [1, "type"], selected: [1, "selected"], dragging: [1, "dragging"], zIndex: [1, "zIndex"], isConnectable: [1, "isConnectable"], positionAbsoluteX: [1, "positionAbsoluteX"], positionAbsoluteY: [1, "positionAbsoluteY"], sourcePosition: [1, "sourcePosition"], targetPosition: [1, "targetPosition"], dragHandle: [1, "dragHandle"] }, decls: 3, vars: 2, consts: [["type", "source", 3, "position"]], template: function InputNodeComponent_Template(rf, ctx) { if (rf & 1) {
|
|
23
|
+
i0.ɵɵelementStart(0, "div");
|
|
24
|
+
i0.ɵɵtext(1);
|
|
25
|
+
i0.ɵɵelementEnd();
|
|
26
|
+
i0.ɵɵelement(2, "ng-flow-handle", 0);
|
|
27
|
+
} if (rf & 2) {
|
|
28
|
+
let tmp_0_0;
|
|
29
|
+
i0.ɵɵadvance();
|
|
30
|
+
i0.ɵɵtextInterpolate((tmp_0_0 = ctx.data()) == null ? null : tmp_0_0.label);
|
|
31
|
+
i0.ɵɵadvance();
|
|
32
|
+
i0.ɵɵproperty("position", ctx.Position.Bottom);
|
|
33
|
+
} }, dependencies: [HandleComponent], encapsulation: 2, changeDetection: 0 }); }
|
|
34
|
+
}
|
|
35
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InputNodeComponent, [{
|
|
36
|
+
type: Component,
|
|
37
|
+
args: [{
|
|
38
|
+
selector: 'ng-flow-input-node',
|
|
39
|
+
standalone: true,
|
|
40
|
+
imports: [HandleComponent],
|
|
41
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
42
|
+
template: `
|
|
43
|
+
<div>{{ data()?.label }}</div>
|
|
44
|
+
<ng-flow-handle type="source" [position]="Position.Bottom" />
|
|
45
|
+
`,
|
|
46
|
+
}]
|
|
47
|
+
}], null, { id: [{ type: i0.Input, args: [{ isSignal: true, alias: "id", required: true }] }], data: [{ type: i0.Input, args: [{ isSignal: true, alias: "data", required: false }] }], type: [{ type: i0.Input, args: [{ isSignal: true, alias: "type", required: false }] }], selected: [{ type: i0.Input, args: [{ isSignal: true, alias: "selected", required: false }] }], dragging: [{ type: i0.Input, args: [{ isSignal: true, alias: "dragging", required: false }] }], zIndex: [{ type: i0.Input, args: [{ isSignal: true, alias: "zIndex", required: false }] }], isConnectable: [{ type: i0.Input, args: [{ isSignal: true, alias: "isConnectable", required: false }] }], positionAbsoluteX: [{ type: i0.Input, args: [{ isSignal: true, alias: "positionAbsoluteX", required: false }] }], positionAbsoluteY: [{ type: i0.Input, args: [{ isSignal: true, alias: "positionAbsoluteY", required: false }] }], sourcePosition: [{ type: i0.Input, args: [{ isSignal: true, alias: "sourcePosition", required: false }] }], targetPosition: [{ type: i0.Input, args: [{ isSignal: true, alias: "targetPosition", required: false }] }], dragHandle: [{ type: i0.Input, args: [{ isSignal: true, alias: "dragHandle", required: false }] }] }); })();
|
|
48
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(InputNodeComponent, { className: "InputNodeComponent", filePath: "lib/components/nodes/input-node.component.ts", lineNumber: 15 }); })();
|
|
49
|
+
//# sourceMappingURL=input-node.component.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"input-node.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/nodes/input-node.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;AAY3C,MAAM,OAAO,kBAAkB;IAV/B;QAWW,aAAQ,GAAG,QAAQ,CAAC;QACpB,OAAE,GAAG,KAAK,CAAC,QAAQ,wEAAU,CAAC;QAC9B,SAAI,GAAG,KAAK,qFAAO,CAAC;QACpB,SAAI,GAAG,KAAK,qFAAU,CAAC;QACvB,aAAQ,GAAG,KAAK,CAAC,KAAK,+EAAC,CAAC;QACxB,aAAQ,GAAG,KAAK,CAAC,KAAK,+EAAC,CAAC;QACxB,WAAM,GAAG,KAAK,CAAC,CAAC,6EAAC,CAAC;QAClB,kBAAa,GAAG,KAAK,CAAC,IAAI,oFAAC,CAAC;QAC5B,sBAAiB,GAAG,KAAK,CAAC,CAAC,wFAAC,CAAC;QAC7B,sBAAiB,GAAG,KAAK,CAAC,CAAC,wFAAC,CAAC;QAC7B,mBAAc,GAAG,KAAK,+FAAY,CAAC;QACnC,mBAAc,GAAG,KAAK,+FAAY,CAAC;QACnC,eAAU,GAAG,KAAK,2FAAU,CAAC;KACvC;mHAdY,kBAAkB;oEAAlB,kBAAkB;YAJ3B,2BAAK;YAAA,YAAmB;YAAA,iBAAM;YAC9B,oCAA6D;;;YADxD,cAAmB;YAAnB,2EAAmB;YACM,cAA4B;YAA5B,8CAA4B;4BAJlD,eAAe;;iFAOd,kBAAkB;cAV9B,SAAS;eAAC;gBACT,QAAQ,EAAE,oBAAoB;gBAC9B,UAAU,EAAE,IAAI;gBAChB,OAAO,EAAE,CAAC,eAAe,CAAC;gBAC1B,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,QAAQ,EAAE;;;GAGT;aACF;;kFACY,kBAAkB"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Position } from '@angflow/system';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class OutputNodeComponent {
|
|
4
|
+
readonly Position: typeof Position;
|
|
5
|
+
readonly id: import("@angular/core").InputSignal<string>;
|
|
6
|
+
readonly data: import("@angular/core").InputSignal<any>;
|
|
7
|
+
readonly type: import("@angular/core").InputSignal<string | undefined>;
|
|
8
|
+
readonly selected: import("@angular/core").InputSignal<boolean>;
|
|
9
|
+
readonly dragging: import("@angular/core").InputSignal<boolean>;
|
|
10
|
+
readonly zIndex: import("@angular/core").InputSignal<number>;
|
|
11
|
+
readonly isConnectable: import("@angular/core").InputSignal<boolean>;
|
|
12
|
+
readonly positionAbsoluteX: import("@angular/core").InputSignal<number>;
|
|
13
|
+
readonly positionAbsoluteY: import("@angular/core").InputSignal<number>;
|
|
14
|
+
readonly sourcePosition: import("@angular/core").InputSignal<Position | undefined>;
|
|
15
|
+
readonly targetPosition: import("@angular/core").InputSignal<Position | undefined>;
|
|
16
|
+
readonly dragHandle: import("@angular/core").InputSignal<string | undefined>;
|
|
17
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<OutputNodeComponent, never>;
|
|
18
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<OutputNodeComponent, "ng-flow-output-node", never, { "id": { "alias": "id"; "required": true; "isSignal": true; }; "data": { "alias": "data"; "required": false; "isSignal": true; }; "type": { "alias": "type"; "required": false; "isSignal": true; }; "selected": { "alias": "selected"; "required": false; "isSignal": true; }; "dragging": { "alias": "dragging"; "required": false; "isSignal": true; }; "zIndex": { "alias": "zIndex"; "required": false; "isSignal": true; }; "isConnectable": { "alias": "isConnectable"; "required": false; "isSignal": true; }; "positionAbsoluteX": { "alias": "positionAbsoluteX"; "required": false; "isSignal": true; }; "positionAbsoluteY": { "alias": "positionAbsoluteY"; "required": false; "isSignal": true; }; "sourcePosition": { "alias": "sourcePosition"; "required": false; "isSignal": true; }; "targetPosition": { "alias": "targetPosition"; "required": false; "isSignal": true; }; "dragHandle": { "alias": "dragHandle"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=output-node.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"output-node.component.d.ts","sourceRoot":"","sources":["../../../../../src/lib/components/nodes/output-node.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;AAE3C,qBAUa,mBAAmB;IAC9B,QAAQ,CAAC,QAAQ,kBAAY;IAC7B,QAAQ,CAAC,EAAE,8CAA4B;IACvC,QAAQ,CAAC,IAAI,2CAAgB;IAC7B,QAAQ,CAAC,IAAI,0DAAmB;IAChC,QAAQ,CAAC,QAAQ,+CAAgB;IACjC,QAAQ,CAAC,QAAQ,+CAAgB;IACjC,QAAQ,CAAC,MAAM,8CAAY;IAC3B,QAAQ,CAAC,aAAa,+CAAe;IACrC,QAAQ,CAAC,iBAAiB,8CAAY;IACtC,QAAQ,CAAC,iBAAiB,8CAAY;IACtC,QAAQ,CAAC,cAAc,4DAAqB;IAC5C,QAAQ,CAAC,cAAc,4DAAqB;IAC5C,QAAQ,CAAC,UAAU,0DAAmB;yCAb3B,mBAAmB;2CAAnB,mBAAmB;CAc/B"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, input } from '@angular/core';
|
|
2
|
+
import { HandleComponent } from '../handle/handle.component';
|
|
3
|
+
import { Position } from '@angflow/system';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class OutputNodeComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.Position = Position;
|
|
8
|
+
this.id = input.required(...(ngDevMode ? [{ debugName: "id" }] : /* istanbul ignore next */ []));
|
|
9
|
+
this.data = input(...(ngDevMode ? [undefined, { debugName: "data" }] : /* istanbul ignore next */ []));
|
|
10
|
+
this.type = input(...(ngDevMode ? [undefined, { debugName: "type" }] : /* istanbul ignore next */ []));
|
|
11
|
+
this.selected = input(false, ...(ngDevMode ? [{ debugName: "selected" }] : /* istanbul ignore next */ []));
|
|
12
|
+
this.dragging = input(false, ...(ngDevMode ? [{ debugName: "dragging" }] : /* istanbul ignore next */ []));
|
|
13
|
+
this.zIndex = input(0, ...(ngDevMode ? [{ debugName: "zIndex" }] : /* istanbul ignore next */ []));
|
|
14
|
+
this.isConnectable = input(true, ...(ngDevMode ? [{ debugName: "isConnectable" }] : /* istanbul ignore next */ []));
|
|
15
|
+
this.positionAbsoluteX = input(0, ...(ngDevMode ? [{ debugName: "positionAbsoluteX" }] : /* istanbul ignore next */ []));
|
|
16
|
+
this.positionAbsoluteY = input(0, ...(ngDevMode ? [{ debugName: "positionAbsoluteY" }] : /* istanbul ignore next */ []));
|
|
17
|
+
this.sourcePosition = input(...(ngDevMode ? [undefined, { debugName: "sourcePosition" }] : /* istanbul ignore next */ []));
|
|
18
|
+
this.targetPosition = input(...(ngDevMode ? [undefined, { debugName: "targetPosition" }] : /* istanbul ignore next */ []));
|
|
19
|
+
this.dragHandle = input(...(ngDevMode ? [undefined, { debugName: "dragHandle" }] : /* istanbul ignore next */ []));
|
|
20
|
+
}
|
|
21
|
+
static { this.ɵfac = function OutputNodeComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || OutputNodeComponent)(); }; }
|
|
22
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: OutputNodeComponent, selectors: [["ng-flow-output-node"]], inputs: { id: [1, "id"], data: [1, "data"], type: [1, "type"], selected: [1, "selected"], dragging: [1, "dragging"], zIndex: [1, "zIndex"], isConnectable: [1, "isConnectable"], positionAbsoluteX: [1, "positionAbsoluteX"], positionAbsoluteY: [1, "positionAbsoluteY"], sourcePosition: [1, "sourcePosition"], targetPosition: [1, "targetPosition"], dragHandle: [1, "dragHandle"] }, decls: 3, vars: 2, consts: [["type", "target", 3, "position"]], template: function OutputNodeComponent_Template(rf, ctx) { if (rf & 1) {
|
|
23
|
+
i0.ɵɵelement(0, "ng-flow-handle", 0);
|
|
24
|
+
i0.ɵɵelementStart(1, "div");
|
|
25
|
+
i0.ɵɵtext(2);
|
|
26
|
+
i0.ɵɵelementEnd();
|
|
27
|
+
} if (rf & 2) {
|
|
28
|
+
let tmp_1_0;
|
|
29
|
+
i0.ɵɵproperty("position", ctx.Position.Top);
|
|
30
|
+
i0.ɵɵadvance(2);
|
|
31
|
+
i0.ɵɵtextInterpolate((tmp_1_0 = ctx.data()) == null ? null : tmp_1_0.label);
|
|
32
|
+
} }, dependencies: [HandleComponent], encapsulation: 2, changeDetection: 0 }); }
|
|
33
|
+
}
|
|
34
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(OutputNodeComponent, [{
|
|
35
|
+
type: Component,
|
|
36
|
+
args: [{
|
|
37
|
+
selector: 'ng-flow-output-node',
|
|
38
|
+
standalone: true,
|
|
39
|
+
imports: [HandleComponent],
|
|
40
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
41
|
+
template: `
|
|
42
|
+
<ng-flow-handle type="target" [position]="Position.Top" />
|
|
43
|
+
<div>{{ data()?.label }}</div>
|
|
44
|
+
`,
|
|
45
|
+
}]
|
|
46
|
+
}], null, { id: [{ type: i0.Input, args: [{ isSignal: true, alias: "id", required: true }] }], data: [{ type: i0.Input, args: [{ isSignal: true, alias: "data", required: false }] }], type: [{ type: i0.Input, args: [{ isSignal: true, alias: "type", required: false }] }], selected: [{ type: i0.Input, args: [{ isSignal: true, alias: "selected", required: false }] }], dragging: [{ type: i0.Input, args: [{ isSignal: true, alias: "dragging", required: false }] }], zIndex: [{ type: i0.Input, args: [{ isSignal: true, alias: "zIndex", required: false }] }], isConnectable: [{ type: i0.Input, args: [{ isSignal: true, alias: "isConnectable", required: false }] }], positionAbsoluteX: [{ type: i0.Input, args: [{ isSignal: true, alias: "positionAbsoluteX", required: false }] }], positionAbsoluteY: [{ type: i0.Input, args: [{ isSignal: true, alias: "positionAbsoluteY", required: false }] }], sourcePosition: [{ type: i0.Input, args: [{ isSignal: true, alias: "sourcePosition", required: false }] }], targetPosition: [{ type: i0.Input, args: [{ isSignal: true, alias: "targetPosition", required: false }] }], dragHandle: [{ type: i0.Input, args: [{ isSignal: true, alias: "dragHandle", required: false }] }] }); })();
|
|
47
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(OutputNodeComponent, { className: "OutputNodeComponent", filePath: "lib/components/nodes/output-node.component.ts", lineNumber: 15 }); })();
|
|
48
|
+
//# sourceMappingURL=output-node.component.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"output-node.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/nodes/output-node.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;AAY3C,MAAM,OAAO,mBAAmB;IAVhC;QAWW,aAAQ,GAAG,QAAQ,CAAC;QACpB,OAAE,GAAG,KAAK,CAAC,QAAQ,wEAAU,CAAC;QAC9B,SAAI,GAAG,KAAK,qFAAO,CAAC;QACpB,SAAI,GAAG,KAAK,qFAAU,CAAC;QACvB,aAAQ,GAAG,KAAK,CAAC,KAAK,+EAAC,CAAC;QACxB,aAAQ,GAAG,KAAK,CAAC,KAAK,+EAAC,CAAC;QACxB,WAAM,GAAG,KAAK,CAAC,CAAC,6EAAC,CAAC;QAClB,kBAAa,GAAG,KAAK,CAAC,IAAI,oFAAC,CAAC;QAC5B,sBAAiB,GAAG,KAAK,CAAC,CAAC,wFAAC,CAAC;QAC7B,sBAAiB,GAAG,KAAK,CAAC,CAAC,wFAAC,CAAC;QAC7B,mBAAc,GAAG,KAAK,+FAAY,CAAC;QACnC,mBAAc,GAAG,KAAK,+FAAY,CAAC;QACnC,eAAU,GAAG,KAAK,2FAAU,CAAC;KACvC;oHAdY,mBAAmB;oEAAnB,mBAAmB;YAJ5B,oCAA0D;YAC1D,2BAAK;YAAA,YAAmB;YAAA,iBAAM;;;YADA,2CAAyB;YAClD,eAAmB;YAAnB,2EAAmB;4BAJhB,eAAe;;iFAOd,mBAAmB;cAV/B,SAAS;eAAC;gBACT,QAAQ,EAAE,qBAAqB;gBAC/B,UAAU,EAAE,IAAI;gBAChB,OAAO,EAAE,CAAC,eAAe,CAAC;gBAC1B,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,QAAQ,EAAE;;;GAGT;aACF;;kFACY,mBAAmB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { PanelPosition } from '@angflow/system';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class PanelComponent {
|
|
4
|
+
readonly position: import("@angular/core").InputSignal<PanelPosition>;
|
|
5
|
+
readonly isTop: import("@angular/core").Signal<boolean>;
|
|
6
|
+
readonly isBottom: import("@angular/core").Signal<boolean>;
|
|
7
|
+
readonly isLeft: import("@angular/core").Signal<boolean>;
|
|
8
|
+
readonly isRight: import("@angular/core").Signal<boolean>;
|
|
9
|
+
readonly isCenter: import("@angular/core").Signal<boolean>;
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<PanelComponent, never>;
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<PanelComponent, "ng-flow-panel", never, { "position": { "alias": "position"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true, never>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=panel.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"panel.component.d.ts","sourceRoot":"","sources":["../../../../../src/lib/components/panel/panel.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;;AAErD,qBAca,cAAc;IACzB,QAAQ,CAAC,QAAQ,qDAAoC;IAErD,QAAQ,CAAC,KAAK,0CAAmD;IACjE,QAAQ,CAAC,QAAQ,0CAAsD;IACvE,QAAQ,CAAC,MAAM,0CAAoD;IACnE,QAAQ,CAAC,OAAO,0CAAqD;IACrE,QAAQ,CAAC,QAAQ,0CAAsD;yCAP5D,cAAc;2CAAd,cAAc;CAQ1B"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, input, computed } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
const _c0 = ["*"];
|
|
4
|
+
export class PanelComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.position = input('top-left', ...(ngDevMode ? [{ debugName: "position" }] : /* istanbul ignore next */ []));
|
|
7
|
+
this.isTop = computed(() => this.position().includes('top'), ...(ngDevMode ? [{ debugName: "isTop" }] : /* istanbul ignore next */ []));
|
|
8
|
+
this.isBottom = computed(() => this.position().includes('bottom'), ...(ngDevMode ? [{ debugName: "isBottom" }] : /* istanbul ignore next */ []));
|
|
9
|
+
this.isLeft = computed(() => this.position().includes('left'), ...(ngDevMode ? [{ debugName: "isLeft" }] : /* istanbul ignore next */ []));
|
|
10
|
+
this.isRight = computed(() => this.position().includes('right'), ...(ngDevMode ? [{ debugName: "isRight" }] : /* istanbul ignore next */ []));
|
|
11
|
+
this.isCenter = computed(() => this.position().includes('center'), ...(ngDevMode ? [{ debugName: "isCenter" }] : /* istanbul ignore next */ []));
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = function PanelComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || PanelComponent)(); }; }
|
|
14
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PanelComponent, selectors: [["ng-flow-panel"]], hostAttrs: [1, "ng-flow__panel", "xy-flow__panel"], hostVars: 10, hostBindings: function PanelComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
15
|
+
i0.ɵɵclassProp("top", ctx.isTop())("bottom", ctx.isBottom())("left", ctx.isLeft())("right", ctx.isRight())("center", ctx.isCenter());
|
|
16
|
+
} }, inputs: { position: [1, "position"] }, ngContentSelectors: _c0, decls: 1, vars: 0, template: function PanelComponent_Template(rf, ctx) { if (rf & 1) {
|
|
17
|
+
i0.ɵɵprojectionDef();
|
|
18
|
+
i0.ɵɵprojection(0);
|
|
19
|
+
} }, encapsulation: 2, changeDetection: 0 }); }
|
|
20
|
+
}
|
|
21
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PanelComponent, [{
|
|
22
|
+
type: Component,
|
|
23
|
+
args: [{
|
|
24
|
+
selector: 'ng-flow-panel',
|
|
25
|
+
standalone: true,
|
|
26
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
27
|
+
host: {
|
|
28
|
+
'class': 'ng-flow__panel xy-flow__panel',
|
|
29
|
+
'[class.top]': 'isTop()',
|
|
30
|
+
'[class.bottom]': 'isBottom()',
|
|
31
|
+
'[class.left]': 'isLeft()',
|
|
32
|
+
'[class.right]': 'isRight()',
|
|
33
|
+
'[class.center]': 'isCenter()',
|
|
34
|
+
},
|
|
35
|
+
template: `<ng-content />`,
|
|
36
|
+
}]
|
|
37
|
+
}], null, { position: [{ type: i0.Input, args: [{ isSignal: true, alias: "position", required: false }] }] }); })();
|
|
38
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PanelComponent, { className: "PanelComponent", filePath: "lib/components/panel/panel.component.ts", lineNumber: 18 }); })();
|
|
39
|
+
//# sourceMappingURL=panel.component.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"panel.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/panel/panel.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;;;AAiBpF,MAAM,OAAO,cAAc;IAd3B;QAeW,aAAQ,GAAG,KAAK,CAAgB,UAAU,+EAAC,CAAC;QAE5C,UAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,4EAAC,CAAC;QACxD,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,+EAAC,CAAC;QAC9D,WAAM,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,6EAAC,CAAC;QAC1D,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,8EAAC,CAAC;QAC5D,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,+EAAC,CAAC;KACxE;+GARY,cAAc;oEAAd,cAAc;YAAd,sBAAA,WAAO,CAAO,WAAd,cAAU,CAAI,SAAd,YAAQ,CAAM,UAAd,aAAS,CAAK,WAAd,cAAU,CAAI;;;YAFd,kBAAc;;;iFAEd,cAAc;cAd1B,SAAS;eAAC;gBACT,QAAQ,EAAE,eAAe;gBACzB,UAAU,EAAE,IAAI;gBAChB,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,IAAI,EAAE;oBACJ,OAAO,EAAE,+BAA+B;oBACxC,aAAa,EAAE,SAAS;oBACxB,gBAAgB,EAAE,YAAY;oBAC9B,cAAc,EAAE,UAAU;oBAC1B,eAAe,EAAE,WAAW;oBAC5B,gBAAgB,EAAE,YAAY;iBAC/B;gBACD,QAAQ,EAAE,gBAAgB;aAC3B;;kFACY,cAAc"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { FlowStore } from '../../services/flow-store.service';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class SelectionBoxComponent {
|
|
4
|
+
readonly store: FlowStore<import("../../types").Node, import("../../types").Edge>;
|
|
5
|
+
readonly contextMenu: import("@angular/core").OutputEmitterRef<MouseEvent>;
|
|
6
|
+
readonly isVisible: import("@angular/core").Signal<boolean>;
|
|
7
|
+
readonly rect: import("@angular/core").Signal<import("@angflow/system").SelectionRect | null>;
|
|
8
|
+
onContextMenu(event: MouseEvent): void;
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SelectionBoxComponent, never>;
|
|
10
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SelectionBoxComponent, "ng-flow-selection-box", never, {}, { "contextMenu": "contextMenu"; }, never, never, true, never>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=selection-box.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"selection-box.component.d.ts","sourceRoot":"","sources":["../../../../../src/lib/components/selection-box/selection-box.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;;AAE9D,qBAqBa,qBAAqB;IAChC,QAAQ,CAAC,KAAK,oEAAqB;IAEnC,QAAQ,CAAC,WAAW,uDAAwB;IAE5C,QAAQ,CAAC,SAAS,0CAA+F;IACjH,QAAQ,CAAC,IAAI,iFAAkD;IAE/D,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;yCAR3B,qBAAqB;2CAArB,qBAAqB;CAYjC"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, inject, computed, output } from '@angular/core';
|
|
2
|
+
import { FlowStore } from '../../services/flow-store.service';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
function SelectionBoxComponent_Conditional_0_Template(rf, ctx) { if (rf & 1) {
|
|
5
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
|
6
|
+
i0.ɵɵdomElementStart(0, "div", 1);
|
|
7
|
+
i0.ɵɵdomListener("contextmenu", function SelectionBoxComponent_Conditional_0_Template_div_contextmenu_0_listener($event) { i0.ɵɵrestoreView(_r1); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.onContextMenu($event)); });
|
|
8
|
+
i0.ɵɵdomElementEnd();
|
|
9
|
+
} if (rf & 2) {
|
|
10
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
11
|
+
i0.ɵɵstyleProp("left", ctx_r1.rect().x, "px")("top", ctx_r1.rect().y, "px")("width", ctx_r1.rect().width, "px")("height", ctx_r1.rect().height, "px");
|
|
12
|
+
} }
|
|
13
|
+
export class SelectionBoxComponent {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.store = inject(FlowStore);
|
|
16
|
+
this.contextMenu = output();
|
|
17
|
+
this.isVisible = computed(() => this.store.userSelectionActive() && this.store.userSelectionRect() !== null, ...(ngDevMode ? [{ debugName: "isVisible" }] : /* istanbul ignore next */ []));
|
|
18
|
+
this.rect = computed(() => this.store.userSelectionRect(), ...(ngDevMode ? [{ debugName: "rect" }] : /* istanbul ignore next */ []));
|
|
19
|
+
}
|
|
20
|
+
onContextMenu(event) {
|
|
21
|
+
event.preventDefault();
|
|
22
|
+
this.contextMenu.emit(event);
|
|
23
|
+
}
|
|
24
|
+
static { this.ɵfac = function SelectionBoxComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SelectionBoxComponent)(); }; }
|
|
25
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SelectionBoxComponent, selectors: [["ng-flow-selection-box"]], hostAttrs: [2, "display", "contents"], outputs: { contextMenu: "contextMenu" }, decls: 1, vars: 1, consts: [[1, "ng-flow__selection", "xy-flow__selection", 2, "position", "absolute", "pointer-events", "all", "z-index", "10", 3, "left", "top", "width", "height"], [1, "ng-flow__selection", "xy-flow__selection", 2, "position", "absolute", "pointer-events", "all", "z-index", "10", 3, "contextmenu"]], template: function SelectionBoxComponent_Template(rf, ctx) { if (rf & 1) {
|
|
26
|
+
i0.ɵɵconditionalCreate(0, SelectionBoxComponent_Conditional_0_Template, 1, 8, "div", 0);
|
|
27
|
+
} if (rf & 2) {
|
|
28
|
+
i0.ɵɵconditional(ctx.isVisible() ? 0 : -1);
|
|
29
|
+
} }, encapsulation: 2, changeDetection: 0 }); }
|
|
30
|
+
}
|
|
31
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectionBoxComponent, [{
|
|
32
|
+
type: Component,
|
|
33
|
+
args: [{
|
|
34
|
+
selector: 'ng-flow-selection-box',
|
|
35
|
+
standalone: true,
|
|
36
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
37
|
+
host: {
|
|
38
|
+
'style': 'display: contents;',
|
|
39
|
+
},
|
|
40
|
+
template: `
|
|
41
|
+
@if (isVisible()) {
|
|
42
|
+
<div
|
|
43
|
+
class="ng-flow__selection xy-flow__selection"
|
|
44
|
+
style="position: absolute; pointer-events: all; z-index: 10;"
|
|
45
|
+
[style.left.px]="rect()!.x"
|
|
46
|
+
[style.top.px]="rect()!.y"
|
|
47
|
+
[style.width.px]="rect()!.width"
|
|
48
|
+
[style.height.px]="rect()!.height"
|
|
49
|
+
(contextmenu)="onContextMenu($event)"
|
|
50
|
+
></div>
|
|
51
|
+
}
|
|
52
|
+
`,
|
|
53
|
+
}]
|
|
54
|
+
}], null, { contextMenu: [{ type: i0.Output, args: ["contextMenu"] }] }); })();
|
|
55
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectionBoxComponent, { className: "SelectionBoxComponent", filePath: "lib/components/selection-box/selection-box.component.ts", lineNumber: 25 }); })();
|
|
56
|
+
//# sourceMappingURL=selection-box.component.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"selection-box.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/selection-box/selection-box.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC7F,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;;;;IAWxD,iCAQC;IADC,2MAAe,4BAAqB,KAAC;IACtC,oBAAM;;;IAFL,AADA,AADA,AADA,6CAA2B,8BACD,oCACM,sCACE;;AAM1C,MAAM,OAAO,qBAAqB;IArBlC;QAsBW,UAAK,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAE1B,gBAAW,GAAG,MAAM,EAAc,CAAC;QAEnC,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,mBAAmB,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,KAAK,IAAI,gFAAC,CAAC;QACxG,SAAI,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,2EAAC,CAAC;KAMhE;IAJC,aAAa,CAAC,KAAiB;QAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;sHAXU,qBAAqB;oEAArB,qBAAqB;YAb9B,uFAAmB;;YAAnB,0CAUC;;;iFAGQ,qBAAqB;cArBjC,SAAS;eAAC;gBACT,QAAQ,EAAE,uBAAuB;gBACjC,UAAU,EAAE,IAAI;gBAChB,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,IAAI,EAAE;oBACJ,OAAO,EAAE,oBAAoB;iBAC9B;gBACD,QAAQ,EAAE;;;;;;;;;;;;GAYT;aACF;;kFACY,qBAAqB"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class ViewportPortalComponent {
|
|
3
|
+
private store;
|
|
4
|
+
readonly cssTransform: import("@angular/core").Signal<string>;
|
|
5
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ViewportPortalComponent, never>;
|
|
6
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ViewportPortalComponent, "ng-flow-viewport-portal", never, {}, {}, never, ["*"], true, never>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=viewport-portal.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"viewport-portal.component.d.ts","sourceRoot":"","sources":["../../../../../src/lib/components/viewport-portal/viewport-portal.component.ts"],"names":[],"mappings":";AAGA,qBAUa,uBAAuB;IAClC,OAAO,CAAC,KAAK,CAAqB;IAElC,QAAQ,CAAC,YAAY,yCAGlB;yCANQ,uBAAuB;2CAAvB,uBAAuB;CAOnC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, inject, computed } from '@angular/core';
|
|
2
|
+
import { FlowStore } from '../../services/flow-store.service';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
const _c0 = ["*"];
|
|
5
|
+
export class ViewportPortalComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.store = inject(FlowStore);
|
|
8
|
+
this.cssTransform = computed(() => {
|
|
9
|
+
const t = this.store.transform();
|
|
10
|
+
return `translate(${t[0]}px, ${t[1]}px) scale(${t[2]})`;
|
|
11
|
+
}, ...(ngDevMode ? [{ debugName: "cssTransform" }] : /* istanbul ignore next */ []));
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = function ViewportPortalComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ViewportPortalComponent)(); }; }
|
|
14
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ViewportPortalComponent, selectors: [["ng-flow-viewport-portal"]], hostAttrs: [1, "ng-flow__viewport-portal", "xy-flow__viewport-portal"], hostVars: 2, hostBindings: function ViewportPortalComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
15
|
+
i0.ɵɵstyleProp("transform", ctx.cssTransform());
|
|
16
|
+
} }, ngContentSelectors: _c0, decls: 1, vars: 0, template: function ViewportPortalComponent_Template(rf, ctx) { if (rf & 1) {
|
|
17
|
+
i0.ɵɵprojectionDef();
|
|
18
|
+
i0.ɵɵprojection(0);
|
|
19
|
+
} }, encapsulation: 2, changeDetection: 0 }); }
|
|
20
|
+
}
|
|
21
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ViewportPortalComponent, [{
|
|
22
|
+
type: Component,
|
|
23
|
+
args: [{
|
|
24
|
+
selector: 'ng-flow-viewport-portal',
|
|
25
|
+
standalone: true,
|
|
26
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
27
|
+
host: {
|
|
28
|
+
'class': 'ng-flow__viewport-portal xy-flow__viewport-portal',
|
|
29
|
+
'[style.transform]': 'cssTransform()',
|
|
30
|
+
},
|
|
31
|
+
template: `<ng-content />`,
|
|
32
|
+
}]
|
|
33
|
+
}], null, null); })();
|
|
34
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ViewportPortalComponent, { className: "ViewportPortalComponent", filePath: "lib/components/viewport-portal/viewport-portal.component.ts", lineNumber: 14 }); })();
|
|
35
|
+
//# sourceMappingURL=viewport-portal.component.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"viewport-portal.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/viewport-portal/viewport-portal.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACrF,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;;;AAY9D,MAAM,OAAO,uBAAuB;IAVpC;QAWU,UAAK,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAEzB,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE;YACpC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;YACjC,OAAO,aAAa,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QAC1D,CAAC,mFAAC,CAAC;KACJ;wHAPY,uBAAuB;oEAAvB,uBAAuB;YAAvB,4BAAA,kBAAc,CAAS;;;YAFvB,kBAAc;;;iFAEd,uBAAuB;cAVnC,SAAS;eAAC;gBACT,QAAQ,EAAE,yBAAyB;gBACnC,UAAU,EAAE,IAAI;gBAChB,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,IAAI,EAAE;oBACJ,OAAO,EAAE,mDAAmD;oBAC5D,mBAAmB,EAAE,gBAAgB;iBACtC;gBACD,QAAQ,EAAE,gBAAgB;aAC3B;;kFACY,uBAAuB"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { Type } from '@angular/core';
|
|
2
|
+
import { type HandleType, type Connection, type FinalConnectionState } from '@angflow/system';
|
|
3
|
+
import { FlowStore } from '../../services/flow-store.service';
|
|
4
|
+
import type { Edge, EdgeTypes } from '../../types';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export declare class EdgeRendererComponent {
|
|
7
|
+
readonly store: FlowStore<import("../../types").Node, Edge>;
|
|
8
|
+
readonly reconnectRadius: import("@angular/core").InputSignal<number>;
|
|
9
|
+
readonly edgeClick: import("@angular/core").OutputEmitterRef<{
|
|
10
|
+
event: MouseEvent;
|
|
11
|
+
edge: Edge;
|
|
12
|
+
}>;
|
|
13
|
+
readonly edgeDoubleClick: import("@angular/core").OutputEmitterRef<{
|
|
14
|
+
event: MouseEvent;
|
|
15
|
+
edge: Edge;
|
|
16
|
+
}>;
|
|
17
|
+
readonly edgeContextMenu: import("@angular/core").OutputEmitterRef<{
|
|
18
|
+
event: MouseEvent;
|
|
19
|
+
edge: Edge;
|
|
20
|
+
}>;
|
|
21
|
+
readonly edgeMouseEnter: import("@angular/core").OutputEmitterRef<{
|
|
22
|
+
event: MouseEvent;
|
|
23
|
+
edge: Edge;
|
|
24
|
+
}>;
|
|
25
|
+
readonly edgeMouseMove: import("@angular/core").OutputEmitterRef<{
|
|
26
|
+
event: MouseEvent;
|
|
27
|
+
edge: Edge;
|
|
28
|
+
}>;
|
|
29
|
+
readonly edgeMouseLeave: import("@angular/core").OutputEmitterRef<{
|
|
30
|
+
event: MouseEvent;
|
|
31
|
+
edge: Edge;
|
|
32
|
+
}>;
|
|
33
|
+
readonly customEdgeTypes: import("@angular/core").InputSignal<EdgeTypes>;
|
|
34
|
+
readonly reconnect: import("@angular/core").OutputEmitterRef<{
|
|
35
|
+
edge: Edge;
|
|
36
|
+
connection: Connection;
|
|
37
|
+
}>;
|
|
38
|
+
readonly reconnectStart: import("@angular/core").OutputEmitterRef<{
|
|
39
|
+
event: MouseEvent;
|
|
40
|
+
edge: Edge;
|
|
41
|
+
handleType: HandleType;
|
|
42
|
+
}>;
|
|
43
|
+
readonly reconnectEnd: import("@angular/core").OutputEmitterRef<{
|
|
44
|
+
event: MouseEvent | TouchEvent;
|
|
45
|
+
edge: Edge;
|
|
46
|
+
handleType: HandleType;
|
|
47
|
+
connectionState: FinalConnectionState;
|
|
48
|
+
}>;
|
|
49
|
+
readonly visibleEdges: import("@angular/core").Signal<Edge[]>;
|
|
50
|
+
readonly markers: import("@angular/core").Signal<Record<string, unknown>[]>;
|
|
51
|
+
isCustomEdge(type?: string): boolean;
|
|
52
|
+
getEdgePath(ei: Record<string, unknown>): string;
|
|
53
|
+
getEdgeComponent(type?: string): Type<unknown>;
|
|
54
|
+
getEdgeInputs(edge: Edge): Record<string, any>;
|
|
55
|
+
onEdgeEvent(event: MouseEvent, edge: Edge, eventType: string): void;
|
|
56
|
+
getEdgeCenterX(ei: Record<string, unknown>): number;
|
|
57
|
+
getEdgeCenterY(ei: Record<string, unknown>): number;
|
|
58
|
+
getEdgeAriaLabel(edge: Edge): string;
|
|
59
|
+
isEdgeReconnectable(edge: Edge): boolean;
|
|
60
|
+
shiftX(x: number, shift: number, position: string): number;
|
|
61
|
+
shiftY(y: number, shift: number, position: string): number;
|
|
62
|
+
onReconnectSourceMouseDown(event: MouseEvent, edge: Edge): void;
|
|
63
|
+
onReconnectTargetMouseDown(event: MouseEvent, edge: Edge): void;
|
|
64
|
+
private handleEdgeReconnect;
|
|
65
|
+
private addMarker;
|
|
66
|
+
private getMarkerUrl;
|
|
67
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<EdgeRendererComponent, never>;
|
|
68
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<EdgeRendererComponent, "ng-flow-edge-renderer", never, { "reconnectRadius": { "alias": "reconnectRadius"; "required": false; "isSignal": true; }; "customEdgeTypes": { "alias": "customEdgeTypes"; "required": false; "isSignal": true; }; }, { "edgeClick": "edgeClick"; "edgeDoubleClick": "edgeDoubleClick"; "edgeContextMenu": "edgeContextMenu"; "edgeMouseEnter": "edgeMouseEnter"; "edgeMouseMove": "edgeMouseMove"; "edgeMouseLeave": "edgeMouseLeave"; "reconnect": "reconnect"; "reconnectStart": "reconnectStart"; "reconnectEnd": "reconnectEnd"; }, never, never, true, never>;
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=edge-renderer.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"edge-renderer.component.d.ts","sourceRoot":"","sources":["../../../../../src/lib/container/edge-renderer/edge-renderer.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAOL,IAAI,EAEL,MAAM,eAAe,CAAC;AAEvB,OAAO,EASL,KAAK,UAAU,EACf,KAAK,UAAU,EAEf,KAAK,oBAAoB,EAC1B,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAM9D,OAAO,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;;AAanD,qBAwHa,qBAAqB;IAChC,QAAQ,CAAC,KAAK,8CAAqB;IAEnC,QAAQ,CAAC,eAAe,8CAAa;IAErC,QAAQ,CAAC,SAAS;eAAmB,UAAU;cAAQ,IAAI;OAAM;IACjE,QAAQ,CAAC,eAAe;eAAmB,UAAU;cAAQ,IAAI;OAAM;IACvE,QAAQ,CAAC,eAAe;eAAmB,UAAU;cAAQ,IAAI;OAAM;IACvE,QAAQ,CAAC,cAAc;eAAmB,UAAU;cAAQ,IAAI;OAAM;IACtE,QAAQ,CAAC,aAAa;eAAmB,UAAU;cAAQ,IAAI;OAAM;IACrE,QAAQ,CAAC,cAAc;eAAmB,UAAU;cAAQ,IAAI;OAAM;IACtE,QAAQ,CAAC,eAAe,iDAAwB;IAEhD,QAAQ,CAAC,SAAS;cAAkB,IAAI;oBAAc,UAAU;OAAM;IACtE,QAAQ,CAAC,cAAc;eAAmB,UAAU;cAAQ,IAAI;oBAAc,UAAU;OAAM;IAC9F,QAAQ,CAAC,YAAY;eAAmB,UAAU,GAAG,UAAU;cAAQ,IAAI;oBAAc,UAAU;yBAAmB,oBAAoB;OAAM;IAEhJ,QAAQ,CAAC,YAAY,yCAGlB;IAEH,QAAQ,CAAC,OAAO,4DAUb;IAEH,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO;IAQpC,WAAW,CAAC,EAAE,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM;IAyBhD,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;IAK9C,aAAa,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAkE9C,WAAW,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IA0BnE,cAAc,CAAC,EAAE,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM;IAInD,cAAc,CAAC,EAAE,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM;IAInD,gBAAgB,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM;IAKpC,mBAAmB,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO;IAKxC,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM;IAM1D,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM;IAM1D,0BAA0B,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,IAAI,GAAG,IAAI;IAS/D,0BAA0B,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,IAAI,GAAG,IAAI;IAS/D,OAAO,CAAC,mBAAmB;IA2C3B,OAAO,CAAC,SAAS;IAQjB,OAAO,CAAC,YAAY;yCAvQT,qBAAqB;2CAArB,qBAAqB;CA4QjC"}
|