ngx-vflow 0.16.0 → 1.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 +8 -1
- package/esm2022/lib/vflow/components/background/background.component.mjs +6 -7
- package/esm2022/lib/vflow/components/connection/connection.component.mjs +66 -53
- package/esm2022/lib/vflow/components/custom-node-base/custom-node-base.component.mjs +32 -25
- package/esm2022/lib/vflow/components/default-node/default-node.component.mjs +9 -11
- package/esm2022/lib/vflow/components/defs/defs.component.mjs +9 -12
- package/esm2022/lib/vflow/components/edge/edge.component.mjs +21 -24
- package/esm2022/lib/vflow/components/edge-label/edge-label.component.mjs +26 -31
- package/esm2022/lib/vflow/components/node/node.component.mjs +54 -50
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +93 -91
- package/esm2022/lib/vflow/decorators/run-in-injection-context.decorator.mjs +1 -1
- package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +41 -125
- package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +16 -16
- package/esm2022/lib/vflow/directives/drag-handle.directive.mjs +7 -6
- package/esm2022/lib/vflow/directives/flow-size-controller.directive.mjs +7 -6
- package/esm2022/lib/vflow/directives/handle-size-controller.directive.mjs +15 -12
- package/esm2022/lib/vflow/directives/map-context.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/pointer.directive.mjs +18 -19
- package/esm2022/lib/vflow/directives/reference.directive.mjs +6 -5
- package/esm2022/lib/vflow/directives/root-pointer.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/root-svg-context.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/selectable.directive.mjs +10 -7
- package/esm2022/lib/vflow/directives/space-point-context.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/template.directive.mjs +43 -25
- package/esm2022/lib/vflow/interfaces/component-node-event.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/node.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/optimization.interface.mjs +1 -1
- package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +1 -1
- package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +1 -1
- package/esm2022/lib/vflow/models/connection.model.mjs +1 -1
- package/esm2022/lib/vflow/models/edge.model.mjs +1 -1
- package/esm2022/lib/vflow/models/handle.model.mjs +2 -2
- package/esm2022/lib/vflow/models/node.model.mjs +4 -10
- package/esm2022/lib/vflow/models/toolbar.model.mjs +1 -1
- package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs +16 -10
- package/esm2022/lib/vflow/public-components/custom-node/custom-node.component.mjs +15 -10
- package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +52 -0
- package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +35 -44
- package/esm2022/lib/vflow/public-components/node-toolbar/node-toolbar.component.mjs +24 -27
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +60 -45
- package/esm2022/lib/vflow/services/component-event-bus.service.mjs +3 -3
- package/esm2022/lib/vflow/services/draggable.service.mjs +4 -4
- package/esm2022/lib/vflow/services/edge-changes.service.mjs +3 -3
- package/esm2022/lib/vflow/services/flow-entities.service.mjs +4 -4
- package/esm2022/lib/vflow/services/flow-settings.service.mjs +4 -10
- package/esm2022/lib/vflow/services/flow-status.service.mjs +4 -4
- package/esm2022/lib/vflow/services/handle.service.mjs +4 -4
- package/esm2022/lib/vflow/services/keyboard.service.mjs +5 -5
- package/esm2022/lib/vflow/services/node-accessor.service.mjs +3 -3
- package/esm2022/lib/vflow/services/node-changes.service.mjs +3 -3
- package/esm2022/lib/vflow/services/node-rendering.service.mjs +3 -3
- package/esm2022/lib/vflow/services/overlays.service.mjs +3 -3
- package/esm2022/lib/vflow/services/selection.service.mjs +4 -4
- package/esm2022/lib/vflow/services/viewport.service.mjs +3 -3
- package/esm2022/lib/vflow/utils/adjust-direction.mjs +1 -1
- package/esm2022/lib/vflow/utils/get-os.mjs +1 -1
- package/esm2022/lib/vflow/utils/nodes.mjs +1 -1
- package/esm2022/lib/vflow/vflow.mjs +24 -0
- package/esm2022/public-api.mjs +4 -5
- package/fesm2022/ngx-vflow.mjs +914 -1022
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/background/background.component.d.ts +3 -3
- package/lib/vflow/components/connection/connection.component.d.ts +3 -3
- package/lib/vflow/components/custom-node-base/custom-node-base.component.d.ts +4 -9
- package/lib/vflow/components/default-node/default-node.component.d.ts +2 -2
- package/lib/vflow/components/defs/defs.component.d.ts +2 -2
- package/lib/vflow/components/edge/edge.component.d.ts +7 -7
- package/lib/vflow/components/edge-label/edge-label.component.d.ts +9 -8
- package/lib/vflow/components/node/node.component.d.ts +5 -6
- package/lib/vflow/components/vflow/vflow.component.d.ts +19 -29
- package/lib/vflow/directives/changes-controller.directive.d.ts +29 -30
- package/lib/vflow/directives/connection-controller.directive.d.ts +1 -2
- package/lib/vflow/directives/drag-handle.directive.d.ts +1 -1
- package/lib/vflow/directives/flow-size-controller.directive.d.ts +1 -1
- package/lib/vflow/directives/handle-size-controller.directive.d.ts +2 -2
- package/lib/vflow/directives/map-context.directive.d.ts +1 -1
- package/lib/vflow/directives/pointer.directive.d.ts +9 -6
- package/lib/vflow/directives/reference.directive.d.ts +1 -1
- package/lib/vflow/directives/root-pointer.directive.d.ts +1 -1
- package/lib/vflow/directives/root-svg-context.directive.d.ts +1 -1
- package/lib/vflow/directives/selectable.directive.d.ts +1 -1
- package/lib/vflow/directives/space-point-context.directive.d.ts +1 -1
- package/lib/vflow/directives/template.directive.d.ts +6 -6
- package/lib/vflow/interfaces/component-node-event.interface.d.ts +3 -3
- package/lib/vflow/interfaces/node.interface.d.ts +14 -14
- package/lib/vflow/interfaces/optimization.interface.d.ts +0 -7
- package/lib/vflow/models/edge.model.d.ts +1 -17
- package/lib/vflow/models/handle.model.d.ts +4 -4
- package/lib/vflow/models/node.model.d.ts +2 -5
- package/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.d.ts +3 -3
- package/lib/vflow/public-components/custom-node/custom-node.component.d.ts +3 -3
- package/lib/vflow/{components → public-components}/handle/handle.component.d.ts +5 -5
- package/lib/vflow/public-components/minimap/minimap.component.d.ts +8 -10
- package/lib/vflow/public-components/node-toolbar/node-toolbar.component.d.ts +6 -5
- package/lib/vflow/public-components/resizable/resizable.component.d.ts +5 -4
- package/lib/vflow/services/flow-settings.service.d.ts +0 -7
- package/lib/vflow/utils/reference-keeper.d.ts +1 -1
- package/lib/vflow/vflow.d.ts +9 -0
- package/package.json +3 -3
- package/public-api.d.ts +2 -3
- package/esm2022/lib/vflow/components/handle/handle.component.mjs +0 -49
- package/esm2022/lib/vflow/interfaces/handle-positions.interface.mjs +0 -2
- package/esm2022/lib/vflow/vflow.module.mjs +0 -121
- package/lib/vflow/interfaces/handle-positions.interface.d.ts +0 -5
- package/lib/vflow/vflow.module.d.ts +0 -30
package/README.md
CHANGED
|
@@ -10,6 +10,13 @@
|
|
|
10
10
|
npm i ngx-vflow --save
|
|
11
11
|
```
|
|
12
12
|
|
|
13
|
+
## Version Compatibility
|
|
14
|
+
|
|
15
|
+
| ngx-vlow | Angular |
|
|
16
|
+
|----------|-----------|
|
|
17
|
+
| v0.x | v16.2.0+ |
|
|
18
|
+
| v1.x | v17.3.12+ |
|
|
19
|
+
|
|
13
20
|
## Basic Example
|
|
14
21
|
|
|
15
22
|
The following code describes 3 nodes and creates 2 edges between them.
|
|
@@ -19,7 +26,7 @@ The following code describes 3 nodes and creates 2 edges between them.
|
|
|
19
26
|
template: `<vflow [nodes]="nodes" [edges]="edges" />`,
|
|
20
27
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
21
28
|
standalone: true,
|
|
22
|
-
imports: [
|
|
29
|
+
imports: [Vflow]
|
|
23
30
|
})
|
|
24
31
|
export class DefaultEdgesDemoComponent {
|
|
25
32
|
public nodes: Node[] = [
|
|
@@ -6,7 +6,6 @@ import { FlowSettingsService } from '../../services/flow-settings.service';
|
|
|
6
6
|
import { toObservable, toSignal } from '@angular/core/rxjs-interop';
|
|
7
7
|
import { map, switchMap } from 'rxjs';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@angular/common";
|
|
10
9
|
const defaultBg = '#fff';
|
|
11
10
|
const defaultGap = 20;
|
|
12
11
|
const defaultDotSize = 2;
|
|
@@ -108,13 +107,13 @@ export class BackgroundComponent {
|
|
|
108
107
|
}
|
|
109
108
|
});
|
|
110
109
|
}
|
|
111
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
112
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
110
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BackgroundComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
111
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: BackgroundComponent, isStandalone: true, selector: "g[background]", ngImport: i0, template: "@if (backgroundSignal().type === 'dots') {\n <svg:pattern\n [attr.id]=\"patternId\"\n [attr.x]=\"x()\"\n [attr.y]=\"y()\"\n [attr.width]=\"scaledGap()\"\n [attr.height]=\"scaledGap()\"\n patternUnits=\"userSpaceOnUse\"\n >\n <svg:circle\n [attr.cx]=\"patternSize()\"\n [attr.cy]=\"patternSize()\"\n [attr.r]=\"patternSize()\"\n [attr.fill]=\"patternColor()\"\n />\n </svg:pattern>\n\n <svg:rect\n x=\"0\"\n y=\"0\"\n width=\"100%\"\n height=\"100%\"\n [attr.fill]=\"patternUrl\"\n />\n}\n\n@if (backgroundSignal().type === 'image') {\n @if (repeated()) {\n <svg:pattern\n [attr.id]=\"patternId\"\n [attr.x]=\"imageX()\"\n [attr.y]=\"imageY()\"\n [attr.width]=\"scaledImageWidth()\"\n [attr.height]=\"scaledImageHeight()\"\n patternUnits=\"userSpaceOnUse\"\n >\n <svg:image\n [attr.href]=\"bgImageSrc()\"\n [attr.width]=\"scaledImageWidth()\"\n [attr.height]=\"scaledImageHeight()\"\n />\n </svg:pattern>\n\n <svg:rect\n x=\"0\"\n y=\"0\"\n width=\"100%\"\n height=\"100%\"\n [attr.fill]=\"patternUrl\"\n />\n }\n\n @if (!repeated()) {\n <svg:image\n [attr.x]=\"imageX()\"\n [attr.y]=\"imageY()\"\n [attr.width]=\"scaledImageWidth()\"\n [attr.height]=\"scaledImageHeight()\"\n [attr.href]=\"bgImageSrc()\"\n />\n }\n}\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
113
112
|
}
|
|
114
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
113
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BackgroundComponent, decorators: [{
|
|
115
114
|
type: Component,
|
|
116
|
-
args: [{ selector: 'g[background]', changeDetection: ChangeDetectionStrategy.OnPush, template: "
|
|
117
|
-
}], ctorParameters:
|
|
115
|
+
args: [{ standalone: true, selector: 'g[background]', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (backgroundSignal().type === 'dots') {\n <svg:pattern\n [attr.id]=\"patternId\"\n [attr.x]=\"x()\"\n [attr.y]=\"y()\"\n [attr.width]=\"scaledGap()\"\n [attr.height]=\"scaledGap()\"\n patternUnits=\"userSpaceOnUse\"\n >\n <svg:circle\n [attr.cx]=\"patternSize()\"\n [attr.cy]=\"patternSize()\"\n [attr.r]=\"patternSize()\"\n [attr.fill]=\"patternColor()\"\n />\n </svg:pattern>\n\n <svg:rect\n x=\"0\"\n y=\"0\"\n width=\"100%\"\n height=\"100%\"\n [attr.fill]=\"patternUrl\"\n />\n}\n\n@if (backgroundSignal().type === 'image') {\n @if (repeated()) {\n <svg:pattern\n [attr.id]=\"patternId\"\n [attr.x]=\"imageX()\"\n [attr.y]=\"imageY()\"\n [attr.width]=\"scaledImageWidth()\"\n [attr.height]=\"scaledImageHeight()\"\n patternUnits=\"userSpaceOnUse\"\n >\n <svg:image\n [attr.href]=\"bgImageSrc()\"\n [attr.width]=\"scaledImageWidth()\"\n [attr.height]=\"scaledImageHeight()\"\n />\n </svg:pattern>\n\n <svg:rect\n x=\"0\"\n y=\"0\"\n width=\"100%\"\n height=\"100%\"\n [attr.fill]=\"patternUrl\"\n />\n }\n\n @if (!repeated()) {\n <svg:image\n [attr.x]=\"imageX()\"\n [attr.y]=\"imageY()\"\n [attr.width]=\"scaledImageWidth()\"\n [attr.height]=\"scaledImageHeight()\"\n [attr.href]=\"bgImageSrc()\"\n />\n }\n}\n" }]
|
|
116
|
+
}], ctorParameters: () => [] });
|
|
118
117
|
function createImage(url) {
|
|
119
118
|
const image = new Image();
|
|
120
119
|
image.src = url;
|
|
@@ -122,4 +121,4 @@ function createImage(url) {
|
|
|
122
121
|
image.onload = () => resolve(image);
|
|
123
122
|
});
|
|
124
123
|
}
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"background.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/background/background.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/background/background.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, inject } from '@angular/core';\nimport { ViewportService } from '../../services/viewport.service';\nimport { RootSvgReferenceDirective } from '../../directives/reference.directive';\nimport { id } from '../../utils/id';\nimport { FlowSettingsService } from '../../services/flow-settings.service';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { map, switchMap } from 'rxjs';\n\nconst defaultBg = '#fff'\nconst defaultGap = 20\nconst defaultDotSize = 2\nconst defaultDotColor = 'rgb(177, 177, 183)'\nconst defaultImageScale = 0.1\nconst defaultRepeated = true\n\n@Component({\n  selector: 'g[background]',\n  templateUrl: './background.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BackgroundComponent {\n  private viewportService = inject(ViewportService)\n  private rootSvg = inject(RootSvgReferenceDirective).element\n  private settingsService = inject(FlowSettingsService);\n\n  protected backgroundSignal = this.settingsService.background\n\n  // DOTS PATTERN\n  protected scaledGap = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'dots') {\n      const zoom = this.viewportService.readableViewport().zoom\n\n      return zoom * (background.gap ?? defaultGap)\n    }\n\n    return 0\n  })\n\n  protected x = computed(() => this.viewportService.readableViewport().x % this.scaledGap())\n\n  protected y = computed(() => this.viewportService.readableViewport().y % this.scaledGap())\n\n  protected patternColor = computed(() => {\n    const bg = this.backgroundSignal()\n\n    if (bg.type === 'dots') {\n      return bg.color ?? defaultDotColor\n    }\n\n    return defaultDotColor\n  })\n\n  protected patternSize = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'dots') {\n      return (this.viewportService.readableViewport().zoom * (background.size ?? defaultDotSize)) / 2\n    }\n\n    return 0\n  })\n\n  // IMAGE PATTERN\n  protected bgImageSrc = computed(() => {\n    const background = this.backgroundSignal()\n\n    return background.type === 'image' ? background.src : ''\n  })\n\n  protected imageSize = toSignal(\n    toObservable(this.backgroundSignal).pipe(\n      switchMap(() => createImage(this.bgImageSrc())),\n      map((image) => ({ width: image.naturalWidth, height: image.naturalHeight })),\n    ),\n    { initialValue: { width: 0, height: 0 } }\n  )\n\n  protected scaledImageWidth = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'image') {\n      const zoom = background.fixed ? 1 : this.viewportService.readableViewport().zoom\n\n      return this.imageSize().width * zoom * (background.scale ?? defaultImageScale)\n    }\n\n    return 0\n  })\n\n  protected scaledImageHeight = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'image') {\n      const zoom = background.fixed ? 1 : this.viewportService.readableViewport().zoom\n\n      return this.imageSize().height * zoom * (background.scale ?? defaultImageScale)\n    }\n\n    return 0\n  });\n\n  protected imageX = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'image') {\n      if (!background.repeat) {\n        return background.fixed ? 0 : this.viewportService.readableViewport().x\n      }\n\n      return background.fixed\n        ? 0\n        : this.viewportService.readableViewport().x % this.scaledImageWidth()\n    }\n\n    return 0\n  });\n\n  protected imageY = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'image') {\n      if (!background.repeat) {\n        return background.fixed ? 0 : this.viewportService.readableViewport().y\n      }\n\n      return background.fixed\n        ? 0\n        : this.viewportService.readableViewport().y % this.scaledImageHeight()\n    }\n\n    return 0\n  });\n\n  protected repeated = computed(() => {\n    const background = this.backgroundSignal()\n\n    return background.type === 'image' && (background.repeat ?? defaultRepeated)\n  })\n\n  // Without ID there will be pattern collision for several flows on the page\n  // Later pattern ID may be exposed to API\n  protected patternId = id();\n  protected patternUrl = `url(#${this.patternId})`\n\n  constructor() {\n    effect(() => {\n      const background = this.backgroundSignal()\n\n      if (background.type === 'dots') {\n        this.rootSvg.style.backgroundColor = background.backgroundColor ?? defaultBg\n      }\n\n      if (background.type === 'solid') {\n        this.rootSvg.style.backgroundColor = background.color\n      }\n    })\n  }\n}\n\nfunction createImage(url: string) {\n  const image = new Image()\n\n  image.src = url\n\n  return new Promise<HTMLImageElement>(resolve => {\n    image.onload = () => resolve(image)\n  })\n}\n","<ng-container *ngIf=\"backgroundSignal().type === 'dots'\">\n  <svg:pattern\n    [attr.id]=\"patternId\"\n    [attr.x]=\"x()\"\n    [attr.y]=\"y()\"\n    [attr.width]=\"scaledGap()\"\n    [attr.height]=\"scaledGap()\"\n    patternUnits=\"userSpaceOnUse\"\n  >\n    <svg:circle\n      [attr.cx]=\"patternSize()\"\n      [attr.cy]=\"patternSize()\"\n      [attr.r]=\"patternSize()\"\n      [attr.fill]=\"patternColor()\"\n    />\n  </svg:pattern>\n\n  <svg:rect\n    x=\"0\"\n    y=\"0\"\n    width=\"100%\"\n    height=\"100%\"\n    [attr.fill]=\"patternUrl\"\n  />\n</ng-container>\n\n<ng-container *ngIf=\"backgroundSignal().type === 'image'\">\n  <ng-container *ngIf=\"repeated()\">\n    <svg:pattern\n      [attr.id]=\"patternId\"\n      [attr.x]=\"imageX()\"\n      [attr.y]=\"imageY()\"\n      [attr.width]=\"scaledImageWidth()\"\n      [attr.height]=\"scaledImageHeight()\"\n      patternUnits=\"userSpaceOnUse\"\n    >\n      <svg:image\n        [attr.href]=\"bgImageSrc()\"\n        [attr.width]=\"scaledImageWidth()\"\n        [attr.height]=\"scaledImageHeight()\"\n      />\n    </svg:pattern>\n\n    <svg:rect\n      x=\"0\"\n      y=\"0\"\n      width=\"100%\"\n      height=\"100%\"\n      [attr.fill]=\"patternUrl\"\n    />\n  </ng-container>\n\n  <ng-container *ngIf=\"!repeated()\">\n    <svg:image\n      [attr.x]=\"imageX()\"\n      [attr.y]=\"imageY()\"\n      [attr.width]=\"scaledImageWidth()\"\n      [attr.height]=\"scaledImageHeight()\"\n      [attr.href]=\"bgImageSrc()\"\n    />\n  </ng-container>\n</ng-container>\n"]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"background.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/background/background.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/background/background.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC7F,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,yBAAyB,EAAE,MAAM,sCAAsC,CAAC;AACjF,OAAO,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAC;AACpC,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;AAEtC,MAAM,SAAS,GAAG,MAAM,CAAA;AACxB,MAAM,UAAU,GAAG,EAAE,CAAA;AACrB,MAAM,cAAc,GAAG,CAAC,CAAA;AACxB,MAAM,eAAe,GAAG,oBAAoB,CAAA;AAC5C,MAAM,iBAAiB,GAAG,GAAG,CAAA;AAC7B,MAAM,eAAe,GAAG,IAAI,CAAA;AAQ5B,MAAM,OAAO,mBAAmB;IA8H9B;QA7HQ,oBAAe,GAAG,MAAM,CAAC,eAAe,CAAC,CAAA;QACzC,YAAO,GAAG,MAAM,CAAC,yBAAyB,CAAC,CAAC,OAAO,CAAA;QACnD,oBAAe,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAE5C,qBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAA;QAE5D,eAAe;QACL,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YAClC,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAE1C,IAAI,UAAU,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;gBAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,IAAI,CAAA;gBAEzD,OAAO,IAAI,GAAG,CAAC,UAAU,CAAC,GAAG,IAAI,UAAU,CAAC,CAAA;YAC9C,CAAC;YAED,OAAO,CAAC,CAAA;QACV,CAAC,CAAC,CAAA;QAEQ,MAAC,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAEhF,MAAC,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAEhF,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE;YACrC,MAAM,EAAE,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAElC,IAAI,EAAE,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;gBACvB,OAAO,EAAE,CAAC,KAAK,IAAI,eAAe,CAAA;YACpC,CAAC;YAED,OAAO,eAAe,CAAA;QACxB,CAAC,CAAC,CAAA;QAEQ,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE;YACpC,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAE1C,IAAI,UAAU,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;gBAC/B,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,IAAI,cAAc,CAAC,CAAC,GAAG,CAAC,CAAA;YACjG,CAAC;YAED,OAAO,CAAC,CAAA;QACV,CAAC,CAAC,CAAA;QAEF,gBAAgB;QACN,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE;YACnC,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAE1C,OAAO,UAAU,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAA;QAC1D,CAAC,CAAC,CAAA;QAEQ,cAAS,GAAG,QAAQ,CAC5B,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,IAAI,CACtC,SAAS,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,EAC/C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC,CAC7E,EACD,EAAE,YAAY,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,CAC1C,CAAA;QAES,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE;YACzC,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAE1C,IAAI,UAAU,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;gBAChC,MAAM,IAAI,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,IAAI,CAAA;gBAEhF,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,GAAG,IAAI,GAAG,CAAC,UAAU,CAAC,KAAK,IAAI,iBAAiB,CAAC,CAAA;YAChF,CAAC;YAED,OAAO,CAAC,CAAA;QACV,CAAC,CAAC,CAAA;QAEQ,sBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC1C,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAE1C,IAAI,UAAU,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;gBAChC,MAAM,IAAI,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,IAAI,CAAA;gBAEhF,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,MAAM,GAAG,IAAI,GAAG,CAAC,UAAU,CAAC,KAAK,IAAI,iBAAiB,CAAC,CAAA;YACjF,CAAC;YAED,OAAO,CAAC,CAAA;QACV,CAAC,CAAC,CAAC;QAEO,WAAM,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC/B,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAE1C,IAAI,UAAU,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;gBAChC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;oBACvB,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAA;gBACzE,CAAC;gBAED,OAAO,UAAU,CAAC,KAAK;oBACrB,CAAC,CAAC,CAAC;oBACH,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YACzE,CAAC;YAED,OAAO,CAAC,CAAA;QACV,CAAC,CAAC,CAAC;QAEO,WAAM,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC/B,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAE1C,IAAI,UAAU,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;gBAChC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;oBACvB,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAA;gBACzE,CAAC;gBAED,OAAO,UAAU,CAAC,KAAK;oBACrB,CAAC,CAAC,CAAC;oBACH,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAA;YAC1E,CAAC;YAED,OAAO,CAAC,CAAA;QACV,CAAC,CAAC,CAAC;QAEO,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE;YACjC,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAE1C,OAAO,UAAU,CAAC,IAAI,KAAK,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,IAAI,eAAe,CAAC,CAAA;QAC9E,CAAC,CAAC,CAAA;QAEF,2EAA2E;QAC3E,yCAAyC;QAC/B,cAAS,GAAG,EAAE,EAAE,CAAC;QACjB,eAAU,GAAG,QAAQ,IAAI,CAAC,SAAS,GAAG,CAAA;QAG9C,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAE1C,IAAI,UAAU,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;gBAC/B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,UAAU,CAAC,eAAe,IAAI,SAAS,CAAA;YAC9E,CAAC;YAED,IAAI,UAAU,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;gBAChC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,eAAe,GAAG,UAAU,CAAC,KAAK,CAAA;YACvD,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;+GA1IU,mBAAmB;mGAAnB,mBAAmB,yECrBhC,05CA8DA;;4FDzCa,mBAAmB;kBAN/B,SAAS;iCACI,IAAI,YACN,eAAe,mBAER,uBAAuB,CAAC,MAAM;;AA+IjD,SAAS,WAAW,CAAC,GAAW;IAC9B,MAAM,KAAK,GAAG,IAAI,KAAK,EAAE,CAAA;IAEzB,KAAK,CAAC,GAAG,GAAG,GAAG,CAAA;IAEf,OAAO,IAAI,OAAO,CAAmB,OAAO,CAAC,EAAE;QAC7C,KAAK,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IACrC,CAAC,CAAC,CAAA;AACJ,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, inject } from '@angular/core';\nimport { ViewportService } from '../../services/viewport.service';\nimport { RootSvgReferenceDirective } from '../../directives/reference.directive';\nimport { id } from '../../utils/id';\nimport { FlowSettingsService } from '../../services/flow-settings.service';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { map, switchMap } from 'rxjs';\n\nconst defaultBg = '#fff'\nconst defaultGap = 20\nconst defaultDotSize = 2\nconst defaultDotColor = 'rgb(177, 177, 183)'\nconst defaultImageScale = 0.1\nconst defaultRepeated = true\n\n@Component({\n  standalone: true,\n  selector: 'g[background]',\n  templateUrl: './background.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BackgroundComponent {\n  private viewportService = inject(ViewportService)\n  private rootSvg = inject(RootSvgReferenceDirective).element\n  private settingsService = inject(FlowSettingsService);\n\n  protected backgroundSignal = this.settingsService.background\n\n  // DOTS PATTERN\n  protected scaledGap = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'dots') {\n      const zoom = this.viewportService.readableViewport().zoom\n\n      return zoom * (background.gap ?? defaultGap)\n    }\n\n    return 0\n  })\n\n  protected x = computed(() => this.viewportService.readableViewport().x % this.scaledGap())\n\n  protected y = computed(() => this.viewportService.readableViewport().y % this.scaledGap())\n\n  protected patternColor = computed(() => {\n    const bg = this.backgroundSignal()\n\n    if (bg.type === 'dots') {\n      return bg.color ?? defaultDotColor\n    }\n\n    return defaultDotColor\n  })\n\n  protected patternSize = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'dots') {\n      return (this.viewportService.readableViewport().zoom * (background.size ?? defaultDotSize)) / 2\n    }\n\n    return 0\n  })\n\n  // IMAGE PATTERN\n  protected bgImageSrc = computed(() => {\n    const background = this.backgroundSignal()\n\n    return background.type === 'image' ? background.src : ''\n  })\n\n  protected imageSize = toSignal(\n    toObservable(this.backgroundSignal).pipe(\n      switchMap(() => createImage(this.bgImageSrc())),\n      map((image) => ({ width: image.naturalWidth, height: image.naturalHeight })),\n    ),\n    { initialValue: { width: 0, height: 0 } }\n  )\n\n  protected scaledImageWidth = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'image') {\n      const zoom = background.fixed ? 1 : this.viewportService.readableViewport().zoom\n\n      return this.imageSize().width * zoom * (background.scale ?? defaultImageScale)\n    }\n\n    return 0\n  })\n\n  protected scaledImageHeight = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'image') {\n      const zoom = background.fixed ? 1 : this.viewportService.readableViewport().zoom\n\n      return this.imageSize().height * zoom * (background.scale ?? defaultImageScale)\n    }\n\n    return 0\n  });\n\n  protected imageX = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'image') {\n      if (!background.repeat) {\n        return background.fixed ? 0 : this.viewportService.readableViewport().x\n      }\n\n      return background.fixed\n        ? 0\n        : this.viewportService.readableViewport().x % this.scaledImageWidth()\n    }\n\n    return 0\n  });\n\n  protected imageY = computed(() => {\n    const background = this.backgroundSignal()\n\n    if (background.type === 'image') {\n      if (!background.repeat) {\n        return background.fixed ? 0 : this.viewportService.readableViewport().y\n      }\n\n      return background.fixed\n        ? 0\n        : this.viewportService.readableViewport().y % this.scaledImageHeight()\n    }\n\n    return 0\n  });\n\n  protected repeated = computed(() => {\n    const background = this.backgroundSignal()\n\n    return background.type === 'image' && (background.repeat ?? defaultRepeated)\n  })\n\n  // Without ID there will be pattern collision for several flows on the page\n  // Later pattern ID may be exposed to API\n  protected patternId = id();\n  protected patternUrl = `url(#${this.patternId})`\n\n  constructor() {\n    effect(() => {\n      const background = this.backgroundSignal()\n\n      if (background.type === 'dots') {\n        this.rootSvg.style.backgroundColor = background.backgroundColor ?? defaultBg\n      }\n\n      if (background.type === 'solid') {\n        this.rootSvg.style.backgroundColor = background.color\n      }\n    })\n  }\n}\n\nfunction createImage(url: string) {\n  const image = new Image()\n\n  image.src = url\n\n  return new Promise<HTMLImageElement>(resolve => {\n    image.onload = () => resolve(image)\n  })\n}\n","@if (backgroundSignal().type === 'dots') {\n  <svg:pattern\n    [attr.id]=\"patternId\"\n    [attr.x]=\"x()\"\n    [attr.y]=\"y()\"\n    [attr.width]=\"scaledGap()\"\n    [attr.height]=\"scaledGap()\"\n    patternUnits=\"userSpaceOnUse\"\n    >\n    <svg:circle\n      [attr.cx]=\"patternSize()\"\n      [attr.cy]=\"patternSize()\"\n      [attr.r]=\"patternSize()\"\n      [attr.fill]=\"patternColor()\"\n      />\n  </svg:pattern>\n\n  <svg:rect\n    x=\"0\"\n    y=\"0\"\n    width=\"100%\"\n    height=\"100%\"\n    [attr.fill]=\"patternUrl\"\n    />\n}\n\n@if (backgroundSignal().type === 'image') {\n  @if (repeated()) {\n    <svg:pattern\n      [attr.id]=\"patternId\"\n      [attr.x]=\"imageX()\"\n      [attr.y]=\"imageY()\"\n      [attr.width]=\"scaledImageWidth()\"\n      [attr.height]=\"scaledImageHeight()\"\n      patternUnits=\"userSpaceOnUse\"\n      >\n      <svg:image\n        [attr.href]=\"bgImageSrc()\"\n        [attr.width]=\"scaledImageWidth()\"\n        [attr.height]=\"scaledImageHeight()\"\n        />\n    </svg:pattern>\n\n    <svg:rect\n      x=\"0\"\n      y=\"0\"\n      width=\"100%\"\n      height=\"100%\"\n      [attr.fill]=\"patternUrl\"\n      />\n  }\n\n  @if (!repeated()) {\n    <svg:image\n      [attr.x]=\"imageX()\"\n      [attr.y]=\"imageY()\"\n      [attr.width]=\"scaledImageWidth()\"\n      [attr.height]=\"scaledImageHeight()\"\n      [attr.href]=\"bgImageSrc()\"\n      />\n  }\n}\n"]}
|
|
@@ -1,14 +1,16 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, inject, input, } from '@angular/core';
|
|
2
2
|
import { FlowStatusService } from '../../services/flow-status.service';
|
|
3
3
|
import { straightPath } from '../../math/edge-path/straigh-path';
|
|
4
4
|
import { SpacePointContextDirective } from '../../directives/space-point-context.directive';
|
|
5
5
|
import { bezierPath } from '../../math/edge-path/bezier-path';
|
|
6
6
|
import { hashCode } from '../../utils/hash';
|
|
7
7
|
import { smoothStepPath } from '../../math/edge-path/smooth-step-path';
|
|
8
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@angular/common";
|
|
10
10
|
export class ConnectionComponent {
|
|
11
11
|
constructor() {
|
|
12
|
+
this.model = input.required();
|
|
13
|
+
this.template = input();
|
|
12
14
|
this.flowStatusService = inject(FlowStatusService);
|
|
13
15
|
this.spacePointContext = inject(SpacePointContextDirective);
|
|
14
16
|
this.path = computed(() => {
|
|
@@ -19,11 +21,15 @@ export class ConnectionComponent {
|
|
|
19
21
|
const sourcePosition = sourceHandle.rawHandle.position;
|
|
20
22
|
const targetPoint = this.spacePointContext.svgCurrentSpacePoint();
|
|
21
23
|
const targetPosition = getOppositePostion(sourceHandle.rawHandle.position);
|
|
22
|
-
switch (this.model.curve) {
|
|
23
|
-
case 'straight':
|
|
24
|
-
|
|
25
|
-
case '
|
|
26
|
-
|
|
24
|
+
switch (this.model().curve) {
|
|
25
|
+
case 'straight':
|
|
26
|
+
return straightPath(sourcePoint, targetPoint).path;
|
|
27
|
+
case 'bezier':
|
|
28
|
+
return bezierPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;
|
|
29
|
+
case 'smooth-step':
|
|
30
|
+
return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;
|
|
31
|
+
case 'step':
|
|
32
|
+
return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition, 0).path;
|
|
27
33
|
}
|
|
28
34
|
}
|
|
29
35
|
if (status.state === 'connection-validation') {
|
|
@@ -38,17 +44,21 @@ export class ConnectionComponent {
|
|
|
38
44
|
const targetPosition = status.payload.valid
|
|
39
45
|
? targetHandle.rawHandle.position
|
|
40
46
|
: getOppositePostion(sourceHandle.rawHandle.position);
|
|
41
|
-
switch (this.model.curve) {
|
|
42
|
-
case 'straight':
|
|
43
|
-
|
|
44
|
-
case '
|
|
45
|
-
|
|
47
|
+
switch (this.model().curve) {
|
|
48
|
+
case 'straight':
|
|
49
|
+
return straightPath(sourcePoint, targetPoint).path;
|
|
50
|
+
case 'bezier':
|
|
51
|
+
return bezierPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;
|
|
52
|
+
case 'smooth-step':
|
|
53
|
+
return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;
|
|
54
|
+
case 'step':
|
|
55
|
+
return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition, 0).path;
|
|
46
56
|
}
|
|
47
57
|
}
|
|
48
58
|
return null;
|
|
49
59
|
});
|
|
50
60
|
this.markerUrl = computed(() => {
|
|
51
|
-
const marker = this.model.settings.marker;
|
|
61
|
+
const marker = this.model().settings.marker;
|
|
52
62
|
if (marker) {
|
|
53
63
|
return `url(#${hashCode(JSON.stringify(marker))})`;
|
|
54
64
|
}
|
|
@@ -60,56 +70,59 @@ export class ConnectionComponent {
|
|
|
60
70
|
return {
|
|
61
71
|
$implicit: {
|
|
62
72
|
path: this.path,
|
|
63
|
-
marker: this.markerUrl
|
|
64
|
-
}
|
|
73
|
+
marker: this.markerUrl,
|
|
74
|
+
},
|
|
65
75
|
};
|
|
66
76
|
}
|
|
67
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
68
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
77
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ConnectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
78
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ConnectionComponent, isStandalone: true, selector: "g[connection]", inputs: { model: { classPropertyName: "model", publicName: "model", isSignal: true, isRequired: true, transformFunction: null }, template: { classPropertyName: "template", publicName: "template", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
|
79
|
+
@if (model().type === 'default') {
|
|
80
|
+
@if (path(); as path) {
|
|
81
|
+
<svg:path
|
|
82
|
+
[attr.d]="path"
|
|
83
|
+
[attr.marker-end]="markerUrl()"
|
|
84
|
+
[attr.stroke]="defaultColor"
|
|
85
|
+
fill="none"
|
|
86
|
+
stroke-width="2"
|
|
87
|
+
/>
|
|
88
|
+
}
|
|
89
|
+
}
|
|
79
90
|
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
91
|
+
@if (model().type === 'template') {
|
|
92
|
+
@if (template(); as template) {
|
|
93
|
+
<ng-container *ngTemplateOutlet="template; context: getContext()" />
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
84
97
|
}
|
|
85
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ConnectionComponent, decorators: [{
|
|
86
99
|
type: Component,
|
|
87
100
|
args: [{
|
|
101
|
+
standalone: true,
|
|
88
102
|
selector: 'g[connection]',
|
|
89
103
|
template: `
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
104
|
+
@if (model().type === 'default') {
|
|
105
|
+
@if (path(); as path) {
|
|
106
|
+
<svg:path
|
|
107
|
+
[attr.d]="path"
|
|
108
|
+
[attr.marker-end]="markerUrl()"
|
|
109
|
+
[attr.stroke]="defaultColor"
|
|
110
|
+
fill="none"
|
|
111
|
+
stroke-width="2"
|
|
112
|
+
/>
|
|
113
|
+
}
|
|
114
|
+
}
|
|
100
115
|
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
116
|
+
@if (model().type === 'template') {
|
|
117
|
+
@if (template(); as template) {
|
|
118
|
+
<ng-container *ngTemplateOutlet="template; context: getContext()" />
|
|
119
|
+
}
|
|
120
|
+
}
|
|
104
121
|
`,
|
|
105
|
-
changeDetection: ChangeDetectionStrategy.OnPush
|
|
122
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
123
|
+
imports: [NgTemplateOutlet],
|
|
106
124
|
}]
|
|
107
|
-
}]
|
|
108
|
-
type: Input,
|
|
109
|
-
args: [{ required: true }]
|
|
110
|
-
}], template: [{
|
|
111
|
-
type: Input
|
|
112
|
-
}] } });
|
|
125
|
+
}] });
|
|
113
126
|
function getOppositePostion(position) {
|
|
114
127
|
switch (position) {
|
|
115
128
|
case 'top':
|
|
@@ -122,4 +135,4 @@ function getOppositePostion(position) {
|
|
|
122
135
|
return 'left';
|
|
123
136
|
}
|
|
124
137
|
}
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connection.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/connection/connection.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, TemplateRef, computed, inject } from '@angular/core';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { straightPath } from '../../math/edge-path/straigh-path';\nimport { SpacePointContextDirective } from '../../directives/space-point-context.directive';\nimport { ConnectionModel } from '../../models/connection.model';\nimport { bezierPath } from '../../math/edge-path/bezier-path';\nimport { hashCode } from '../../utils/hash';\nimport { Position } from '../../types/position.type';\nimport { smoothStepPath } from '../../math/edge-path/smooth-step-path';\n\n@Component({\n  selector: 'g[connection]',\n  template: `\n    <ng-container *ngIf=\"model.type === 'default'\">\n      <svg:path\n        *ngIf=\"path() as path\"\n        [attr.d]=\"path\"\n        [attr.marker-end]=\"markerUrl()\"\n        [attr.stroke]=\"defaultColor\"\n        fill=\"none\"\n        stroke-width=\"2\"\n      />\n    </ng-container>\n\n    <ng-container *ngIf=\"model.type === 'template' && template\">\n      <ng-container *ngTemplateOutlet=\"template; context: getContext()\" />\n    </ng-container>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ConnectionComponent {\n  @Input({ required: true })\n  public model!: ConnectionModel\n\n  @Input()\n  public template?: TemplateRef<any>\n\n  private flowStatusService = inject(FlowStatusService)\n  private spacePointContext = inject(SpacePointContextDirective)\n\n  protected path = computed(() => {\n    const status = this.flowStatusService.status()\n\n    if (status.state === 'connection-start') {\n      const sourceHandle = status.payload.sourceHandle\n      const sourcePoint = sourceHandle.pointAbsolute()\n      const sourcePosition = sourceHandle.rawHandle.position\n\n      const targetPoint = this.spacePointContext.svgCurrentSpacePoint()\n      const targetPosition = getOppositePostion(sourceHandle.rawHandle.position)\n\n      switch (this.model.curve) {\n        case 'straight': return straightPath(sourcePoint, targetPoint).path\n        case 'bezier': return bezierPath(\n          sourcePoint, targetPoint,\n          sourcePosition, targetPosition\n        ).path\n        case 'smooth-step': return smoothStepPath(\n          sourcePoint, targetPoint,\n          sourcePosition, targetPosition,\n        ).path\n        case 'step': return smoothStepPath(\n          sourcePoint, targetPoint,\n          sourcePosition, targetPosition,\n          0\n        ).path\n      }\n    }\n\n    if (status.state === 'connection-validation') {\n      const sourceHandle = status.payload.sourceHandle\n      const sourcePoint = sourceHandle.pointAbsolute()\n      const sourcePosition = sourceHandle.rawHandle.position\n\n      const targetHandle = status.payload.targetHandle\n      // ignore magnet if validation failed\n      const targetPoint = status.payload.valid\n        ? targetHandle.pointAbsolute()\n        : this.spacePointContext.svgCurrentSpacePoint()\n      const targetPosition = status.payload.valid\n        ? targetHandle.rawHandle.position\n        : getOppositePostion(sourceHandle.rawHandle.position)\n\n      switch (this.model.curve) {\n        case 'straight': return straightPath(sourcePoint, targetPoint).path\n        case 'bezier': return bezierPath(\n          sourcePoint, targetPoint,\n          sourcePosition, targetPosition\n        ).path\n        case 'smooth-step': return smoothStepPath(\n          sourcePoint, targetPoint,\n          sourcePosition, targetPosition,\n        ).path\n        case 'step': return smoothStepPath(\n          sourcePoint, targetPoint,\n          sourcePosition, targetPosition,\n          0\n        ).path\n      }\n    }\n\n    return null\n  })\n\n  protected markerUrl = computed(() => {\n    const marker = this.model.settings.marker\n\n    if (marker) {\n      return `url(#${hashCode(JSON.stringify(marker))})`\n    }\n\n    return ''\n  })\n\n  protected readonly defaultColor = 'rgb(177, 177, 183)'\n\n  protected getContext() {\n    return {\n      $implicit: {\n        path: this.path,\n        marker: this.markerUrl\n      }\n    }\n  }\n}\n\nfunction getOppositePostion(position: Position): Position {\n  switch (position) {\n    case 'top':\n      return 'bottom'\n    case 'bottom':\n      return 'top'\n    case 'left':\n      return 'right'\n    case 'right':\n      return 'left'\n  }\n}\n"]}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connection.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/connection/connection.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  TemplateRef,\n  computed,\n  inject,\n  input,\n} from '@angular/core';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { straightPath } from '../../math/edge-path/straigh-path';\nimport { SpacePointContextDirective } from '../../directives/space-point-context.directive';\nimport { ConnectionModel } from '../../models/connection.model';\nimport { bezierPath } from '../../math/edge-path/bezier-path';\nimport { hashCode } from '../../utils/hash';\nimport { Position } from '../../types/position.type';\nimport { smoothStepPath } from '../../math/edge-path/smooth-step-path';\nimport { NgTemplateOutlet } from '@angular/common';\n\n@Component({\n  standalone: true,\n  selector: 'g[connection]',\n  template: `\n    @if (model().type === 'default') {\n      @if (path(); as path) {\n        <svg:path\n          [attr.d]=\"path\"\n          [attr.marker-end]=\"markerUrl()\"\n          [attr.stroke]=\"defaultColor\"\n          fill=\"none\"\n          stroke-width=\"2\"\n        />\n      }\n    }\n\n    @if (model().type === 'template') {\n      @if (template(); as template) {\n        <ng-container *ngTemplateOutlet=\"template; context: getContext()\" />\n      }\n    }\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [NgTemplateOutlet],\n})\nexport class ConnectionComponent {\n  public model = input.required<ConnectionModel>();\n\n  public template = input<TemplateRef<any>>();\n\n  private flowStatusService = inject(FlowStatusService);\n  private spacePointContext = inject(SpacePointContextDirective);\n\n  protected path = computed(() => {\n    const status = this.flowStatusService.status();\n\n    if (status.state === 'connection-start') {\n      const sourceHandle = status.payload.sourceHandle;\n      const sourcePoint = sourceHandle.pointAbsolute();\n      const sourcePosition = sourceHandle.rawHandle.position;\n\n      const targetPoint = this.spacePointContext.svgCurrentSpacePoint();\n      const targetPosition = getOppositePostion(\n        sourceHandle.rawHandle.position,\n      );\n\n      switch (this.model().curve) {\n        case 'straight':\n          return straightPath(sourcePoint, targetPoint).path;\n        case 'bezier':\n          return bezierPath(\n            sourcePoint,\n            targetPoint,\n            sourcePosition,\n            targetPosition,\n          ).path;\n        case 'smooth-step':\n          return smoothStepPath(\n            sourcePoint,\n            targetPoint,\n            sourcePosition,\n            targetPosition,\n          ).path;\n        case 'step':\n          return smoothStepPath(\n            sourcePoint,\n            targetPoint,\n            sourcePosition,\n            targetPosition,\n            0,\n          ).path;\n      }\n    }\n\n    if (status.state === 'connection-validation') {\n      const sourceHandle = status.payload.sourceHandle;\n      const sourcePoint = sourceHandle.pointAbsolute();\n      const sourcePosition = sourceHandle.rawHandle.position;\n\n      const targetHandle = status.payload.targetHandle;\n      // ignore magnet if validation failed\n      const targetPoint = status.payload.valid\n        ? targetHandle.pointAbsolute()\n        : this.spacePointContext.svgCurrentSpacePoint();\n      const targetPosition = status.payload.valid\n        ? targetHandle.rawHandle.position\n        : getOppositePostion(sourceHandle.rawHandle.position);\n\n      switch (this.model().curve) {\n        case 'straight':\n          return straightPath(sourcePoint, targetPoint).path;\n        case 'bezier':\n          return bezierPath(\n            sourcePoint,\n            targetPoint,\n            sourcePosition,\n            targetPosition,\n          ).path;\n        case 'smooth-step':\n          return smoothStepPath(\n            sourcePoint,\n            targetPoint,\n            sourcePosition,\n            targetPosition,\n          ).path;\n        case 'step':\n          return smoothStepPath(\n            sourcePoint,\n            targetPoint,\n            sourcePosition,\n            targetPosition,\n            0,\n          ).path;\n      }\n    }\n\n    return null;\n  });\n\n  protected markerUrl = computed(() => {\n    const marker = this.model().settings.marker;\n\n    if (marker) {\n      return `url(#${hashCode(JSON.stringify(marker))})`;\n    }\n\n    return '';\n  });\n\n  protected readonly defaultColor = 'rgb(177, 177, 183)';\n\n  protected getContext() {\n    return {\n      $implicit: {\n        path: this.path,\n        marker: this.markerUrl,\n      },\n    };\n  }\n}\n\nfunction getOppositePostion(position: Position): Position {\n  switch (position) {\n    case 'top':\n      return 'bottom';\n    case 'bottom':\n      return 'top';\n    case 'left':\n      return 'right';\n    case 'right':\n      return 'left';\n  }\n}\n"]}
|
|
@@ -1,50 +1,57 @@
|
|
|
1
|
-
import { DestroyRef, Directive, EventEmitter,
|
|
2
|
-
import { merge, tap } from
|
|
3
|
-
import { takeUntilDestroyed } from
|
|
4
|
-
import { ComponentEventBusService } from
|
|
1
|
+
import { DestroyRef, Directive, EventEmitter, inject, signal, OutputEmitterRef, } from '@angular/core';
|
|
2
|
+
import { merge, Observable, tap } from 'rxjs';
|
|
3
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
|
+
import { ComponentEventBusService } from '../../services/component-event-bus.service';
|
|
5
|
+
import { NodeAccessorService } from '../../services/node-accessor.service';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
export class CustomNodeBaseComponent {
|
|
7
8
|
constructor() {
|
|
8
9
|
this.eventBus = inject(ComponentEventBusService);
|
|
10
|
+
this.nodeService = inject(NodeAccessorService);
|
|
9
11
|
this.destroyRef = inject(DestroyRef);
|
|
10
12
|
/**
|
|
11
13
|
* Signal with selected state of node
|
|
12
14
|
*/
|
|
13
|
-
this.selected =
|
|
15
|
+
this.selected = this.nodeService.model().selected;
|
|
14
16
|
this.data = signal(undefined);
|
|
15
17
|
}
|
|
16
|
-
set _selected(value) {
|
|
17
|
-
this.selected.set(value);
|
|
18
|
-
}
|
|
19
18
|
ngOnInit() {
|
|
20
|
-
this.trackEvents()
|
|
21
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
22
|
-
.subscribe();
|
|
19
|
+
this.trackEvents().pipe(takeUntilDestroyed(this.destroyRef)).subscribe();
|
|
23
20
|
}
|
|
24
21
|
trackEvents() {
|
|
25
22
|
const props = Object.getOwnPropertyNames(this);
|
|
26
|
-
const
|
|
23
|
+
const emittersOrRefs = new Map();
|
|
27
24
|
for (const prop of props) {
|
|
28
25
|
const field = this[prop];
|
|
29
26
|
if (field instanceof EventEmitter) {
|
|
30
|
-
|
|
27
|
+
emittersOrRefs.set(field, prop);
|
|
28
|
+
}
|
|
29
|
+
if (field instanceof OutputEmitterRef) {
|
|
30
|
+
emittersOrRefs.set(outputRefToObservable(field), prop);
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
|
-
return merge(...Array.from(
|
|
33
|
+
return merge(...Array.from(emittersOrRefs.keys()).map((emitter) => emitter.pipe(tap((event) => {
|
|
34
34
|
this.eventBus.pushEvent({
|
|
35
|
-
nodeId: this.node.id,
|
|
36
|
-
eventName:
|
|
37
|
-
eventPayload: event
|
|
35
|
+
nodeId: this.nodeService.model()?.node.id ?? '',
|
|
36
|
+
eventName: emittersOrRefs.get(emitter),
|
|
37
|
+
eventPayload: event,
|
|
38
38
|
});
|
|
39
39
|
}))));
|
|
40
40
|
}
|
|
41
|
-
;
|
|
42
|
-
static { this.ɵ
|
|
43
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CustomNodeBaseComponent, inputs: { _selected: "_selected" }, ngImport: i0 }); }
|
|
41
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomNodeBaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
42
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: CustomNodeBaseComponent, ngImport: i0 }); }
|
|
44
43
|
}
|
|
45
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomNodeBaseComponent, decorators: [{
|
|
46
45
|
type: Directive
|
|
47
|
-
}]
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
46
|
+
}] });
|
|
47
|
+
function outputRefToObservable(ref) {
|
|
48
|
+
return new Observable((subscriber) => {
|
|
49
|
+
const subscription = ref.subscribe((value) => {
|
|
50
|
+
subscriber.next(value);
|
|
51
|
+
});
|
|
52
|
+
return () => {
|
|
53
|
+
subscription.unsubscribe();
|
|
54
|
+
};
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLW5vZGUtYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvY29tcG9uZW50cy9jdXN0b20tbm9kZS1iYXNlL2N1c3RvbS1ub2RlLWJhc2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxVQUFVLEVBQ1YsU0FBUyxFQUNULFlBQVksRUFHWixNQUFNLEVBQ04sTUFBTSxFQUVOLGdCQUFnQixHQUNqQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDOUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDaEUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDdEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7O0FBRzNFLE1BQU0sT0FBZ0IsdUJBQXVCO0lBRDdDO1FBRVUsYUFBUSxHQUFHLE1BQU0sQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1FBQzVDLGdCQUFXLEdBQUcsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUE7UUFFdkMsZUFBVSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUUxQzs7V0FFRztRQUNJLGFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRyxDQUFDLFFBQVEsQ0FBQztRQUU5QyxTQUFJLEdBQUcsTUFBTSxDQUFnQixTQUFTLENBQUMsQ0FBQztLQW9DaEQ7SUFsQ1EsUUFBUTtRQUNiLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDM0UsQ0FBQztJQUVPLFdBQVc7UUFDakIsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDO1FBRS9DLE1BQU0sY0FBYyxHQUFHLElBQUksR0FBRyxFQUErQixDQUFDO1FBQzlELEtBQUssTUFBTSxJQUFJLElBQUksS0FBSyxFQUFFLENBQUM7WUFDekIsTUFBTSxLQUFLLEdBQUksSUFBZ0MsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUV0RCxJQUFJLEtBQUssWUFBWSxZQUFZLEVBQUUsQ0FBQztnQkFDbEMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDbEMsQ0FBQztZQUVELElBQUksS0FBSyxZQUFZLGdCQUFnQixFQUFFLENBQUM7Z0JBQ3RDLGNBQWMsQ0FBQyxHQUFHLENBQUMscUJBQXFCLENBQUMsS0FBSyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDekQsQ0FBQztRQUNILENBQUM7UUFFRCxPQUFPLEtBQUssQ0FDVixHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FDbkQsT0FBTyxDQUFDLElBQUksQ0FDVixHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUNaLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDO2dCQUN0QixNQUFNLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsRUFBRSxJQUFJLENBQUMsRUFBRSxJQUFJLEVBQUU7Z0JBQy9DLFNBQVMsRUFBRSxjQUFjLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBRTtnQkFDdkMsWUFBWSxFQUFFLEtBQUs7YUFDcEIsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQ0gsQ0FDRixDQUNGLENBQUM7SUFDSixDQUFDOytHQTlDbUIsdUJBQXVCO21HQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBRDVDLFNBQVM7O0FBa0RWLFNBQVMscUJBQXFCLENBQUMsR0FBOEI7SUFDM0QsT0FBTyxJQUFJLFVBQVUsQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFO1FBQ25DLE1BQU0sWUFBWSxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUMzQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3pCLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxHQUFHLEVBQUU7WUFDVixZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDN0IsQ0FBQyxDQUFDO0lBQ0osQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGVzdHJveVJlZixcbiAgRGlyZWN0aXZlLFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPbkluaXQsXG4gIGluamVjdCxcbiAgc2lnbmFsLFxuICBpbnB1dCxcbiAgT3V0cHV0RW1pdHRlclJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBtZXJnZSwgT2JzZXJ2YWJsZSwgdGFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlVW50aWxEZXN0cm95ZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyBDb21wb25lbnRFdmVudEJ1c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9jb21wb25lbnQtZXZlbnQtYnVzLnNlcnZpY2UnO1xuaW1wb3J0IHsgTm9kZUFjY2Vzc29yU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL25vZGUtYWNjZXNzb3Iuc2VydmljZSc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEN1c3RvbU5vZGVCYXNlQ29tcG9uZW50PFQgPSBhbnk+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgcHJpdmF0ZSBldmVudEJ1cyA9IGluamVjdChDb21wb25lbnRFdmVudEJ1c1NlcnZpY2UpO1xuICBwcml2YXRlIG5vZGVTZXJ2aWNlID0gaW5qZWN0KE5vZGVBY2Nlc3NvclNlcnZpY2UpXG5cbiAgcHJvdGVjdGVkIGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZik7XG5cbiAgLyoqXG4gICAqIFNpZ25hbCB3aXRoIHNlbGVjdGVkIHN0YXRlIG9mIG5vZGVcbiAgICovXG4gIHB1YmxpYyBzZWxlY3RlZCA9IHRoaXMubm9kZVNlcnZpY2UubW9kZWwoKSEuc2VsZWN0ZWQ7XG5cbiAgcHVibGljIGRhdGEgPSBzaWduYWw8VCB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy50cmFja0V2ZW50cygpLnBpcGUodGFrZVVudGlsRGVzdHJveWVkKHRoaXMuZGVzdHJveVJlZikpLnN1YnNjcmliZSgpO1xuICB9XG5cbiAgcHJpdmF0ZSB0cmFja0V2ZW50cygpIHtcbiAgICBjb25zdCBwcm9wcyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eU5hbWVzKHRoaXMpO1xuXG4gICAgY29uc3QgZW1pdHRlcnNPclJlZnMgPSBuZXcgTWFwPE9ic2VydmFibGU8dW5rbm93bj4sIHN0cmluZz4oKTtcbiAgICBmb3IgKGNvbnN0IHByb3Agb2YgcHJvcHMpIHtcbiAgICAgIGNvbnN0IGZpZWxkID0gKHRoaXMgYXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj4pW3Byb3BdO1xuXG4gICAgICBpZiAoZmllbGQgaW5zdGFuY2VvZiBFdmVudEVtaXR0ZXIpIHtcbiAgICAgICAgZW1pdHRlcnNPclJlZnMuc2V0KGZpZWxkLCBwcm9wKTtcbiAgICAgIH1cblxuICAgICAgaWYgKGZpZWxkIGluc3RhbmNlb2YgT3V0cHV0RW1pdHRlclJlZikge1xuICAgICAgICBlbWl0dGVyc09yUmVmcy5zZXQob3V0cHV0UmVmVG9PYnNlcnZhYmxlKGZpZWxkKSwgcHJvcCk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIG1lcmdlKFxuICAgICAgLi4uQXJyYXkuZnJvbShlbWl0dGVyc09yUmVmcy5rZXlzKCkpLm1hcCgoZW1pdHRlcikgPT5cbiAgICAgICAgZW1pdHRlci5waXBlKFxuICAgICAgICAgIHRhcCgoZXZlbnQpID0+IHtcbiAgICAgICAgICAgIHRoaXMuZXZlbnRCdXMucHVzaEV2ZW50KHtcbiAgICAgICAgICAgICAgbm9kZUlkOiB0aGlzLm5vZGVTZXJ2aWNlLm1vZGVsKCk/Lm5vZGUuaWQgPz8gJycsXG4gICAgICAgICAgICAgIGV2ZW50TmFtZTogZW1pdHRlcnNPclJlZnMuZ2V0KGVtaXR0ZXIpISxcbiAgICAgICAgICAgICAgZXZlbnRQYXlsb2FkOiBldmVudCxcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH0pLFxuICAgICAgICApLFxuICAgICAgKSxcbiAgICApO1xuICB9XG59XG5cbmZ1bmN0aW9uIG91dHB1dFJlZlRvT2JzZXJ2YWJsZShyZWY6IE91dHB1dEVtaXR0ZXJSZWY8dW5rbm93bj4pIHtcbiAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlKChzdWJzY3JpYmVyKSA9PiB7XG4gICAgY29uc3Qgc3Vic2NyaXB0aW9uID0gcmVmLnN1YnNjcmliZSgodmFsdWUpID0+IHtcbiAgICAgIHN1YnNjcmliZXIubmV4dCh2YWx1ZSk7XG4gICAgfSk7XG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gICAgfTtcbiAgfSk7XG59XG4iXX0=
|
|
@@ -1,18 +1,16 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class DefaultNodeComponent {
|
|
4
4
|
constructor() {
|
|
5
|
-
this.selected = false;
|
|
5
|
+
this.selected = input(false);
|
|
6
6
|
}
|
|
7
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
8
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultNodeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
8
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: DefaultNodeComponent, isStandalone: true, selector: "default-node", inputs: { selected: { classPropertyName: "selected", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.selected": "selected()" } }, ngImport: i0, template: "<ng-content />\n", styles: [":host{border:1.5px solid #1b262c;border-radius:5px;display:flex;align-items:center;justify-content:center;color:#000;background-color:#fff}:host(.selected){border-width:2px}\n"] }); }
|
|
9
9
|
}
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultNodeComponent, decorators: [{
|
|
11
11
|
type: Component,
|
|
12
|
-
args: [{ selector: 'default-node', host: {
|
|
13
|
-
'[class.selected]': 'selected'
|
|
12
|
+
args: [{ standalone: true, selector: 'default-node', host: {
|
|
13
|
+
'[class.selected]': 'selected()',
|
|
14
14
|
}, template: "<ng-content />\n", styles: [":host{border:1.5px solid #1b262c;border-radius:5px;display:flex;align-items:center;justify-content:center;color:#000;background-color:#fff}:host(.selected){border-width:2px}\n"] }]
|
|
15
|
-
}]
|
|
16
|
-
|
|
17
|
-
}] } });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1ub2RlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9jb21wb25lbnRzL2RlZmF1bHQtbm9kZS9kZWZhdWx0LW5vZGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2NvbXBvbmVudHMvZGVmYXVsdC1ub2RlL2RlZmF1bHQtbm9kZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFlLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFVOUQsTUFBTSxPQUFPLG9CQUFvQjtJQVJqQztRQVVTLGFBQVEsR0FBRyxLQUFLLENBQUE7S0FDeEI7K0dBSFksb0JBQW9CO21HQUFwQixvQkFBb0IsOElDVmpDLGtCQUNBOzs0RkRTYSxvQkFBb0I7a0JBUmhDLFNBQVM7K0JBQ0UsY0FBYyxRQUdsQjt3QkFDSixrQkFBa0IsRUFBRSxVQUFVO3FCQUMvQjs4QkFJTSxRQUFRO3NCQURkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkZWZhdWx0LW5vZGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vZGVmYXVsdC1ub2RlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbYC4vZGVmYXVsdC1ub2RlLmNvbXBvbmVudC5zY3NzYF0sXG4gIGhvc3Q6IHtcbiAgICAnW2NsYXNzLnNlbGVjdGVkXSc6ICdzZWxlY3RlZCdcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBEZWZhdWx0Tm9kZUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzZWxlY3RlZCA9IGZhbHNlXG59XG4iLCI8bmctY29udGVudCAvPlxuIl19
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1ub2RlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9jb21wb25lbnRzL2RlZmF1bHQtbm9kZS9kZWZhdWx0LW5vZGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2NvbXBvbmVudHMvZGVmYXVsdC1ub2RlL2RlZmF1bHQtbm9kZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFXakQsTUFBTSxPQUFPLG9CQUFvQjtJQVRqQztRQVVTLGFBQVEsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDaEM7K0dBRlksb0JBQW9CO21HQUFwQixvQkFBb0IsK1FDWGpDLGtCQUNBOzs0RkRVYSxvQkFBb0I7a0JBVGhDLFNBQVM7aUNBQ0ksSUFBSSxZQUNOLGNBQWMsUUFHbEI7d0JBQ0osa0JBQWtCLEVBQUUsWUFBWTtxQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ2RlZmF1bHQtbm9kZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9kZWZhdWx0LW5vZGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFtgLi9kZWZhdWx0LW5vZGUuY29tcG9uZW50LnNjc3NgXSxcbiAgaG9zdDoge1xuICAgICdbY2xhc3Muc2VsZWN0ZWRdJzogJ3NlbGVjdGVkKCknLFxuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBEZWZhdWx0Tm9kZUNvbXBvbmVudCB7XG4gIHB1YmxpYyBzZWxlY3RlZCA9IGlucHV0KGZhbHNlKTtcbn1cbiIsIjxuZy1jb250ZW50IC8+XG4iXX0=
|
|
@@ -1,19 +1,16 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, input } from '@angular/core';
|
|
2
|
+
import { KeyValuePipe } from '@angular/common';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@angular/common";
|
|
4
4
|
export class DefsComponent {
|
|
5
5
|
constructor() {
|
|
6
|
-
this.markers =
|
|
6
|
+
this.markers = input.required();
|
|
7
7
|
this.defaultColor = 'rgb(177, 177, 183)';
|
|
8
8
|
}
|
|
9
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
10
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
10
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DefsComponent, isStandalone: true, selector: "defs[flowDefs]", inputs: { markers: { classPropertyName: "markers", publicName: "markers", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "@for (marker of markers() | keyvalue; track marker) {\n <svg:marker\n [attr.id]=\"marker.key\"\n [attr.markerWidth]=\"marker.value.width ?? 16.5\"\n [attr.markerHeight]=\"marker.value.height ?? 16.5\"\n [attr.orient]=\"marker.value.orient ?? 'auto-start-reverse'\"\n viewBox=\"-10 -10 20 20\"\n [attr.markerUnits]=\"marker.value.markerUnits ?? 'userSpaceOnUse'\"\n refX=\"0\"\n refY=\"0\"\n >\n @if (marker.value.type === \"arrow-closed\" || !marker.value.type) {\n <polyline\n class=\"marker__arrow_closed\"\n [style.stroke]=\"marker.value.color ?? defaultColor\"\n [style.stroke-width]=\"marker.value.strokeWidth ?? 2\"\n [style.fill]=\"marker.value.color ?? defaultColor\"\n points=\"-5,-4 1,0 -5,4 -5,-4\"\n />\n }\n\n @if (marker.value.type === \"arrow\") {\n <polyline\n class=\"marker__arrow_default\"\n [style.stroke]=\"marker.value.color ?? defaultColor\"\n [style.stroke-width]=\"marker.value.strokeWidth ?? 2\"\n points=\"-5,-4 0,0 -5,4\"\n />\n }\n </svg:marker>\n}\n", styles: [".marker__arrow_default{stroke-width:1px;stroke-linecap:round;stroke-linejoin:round;fill:none}.marker__arrow_closed{stroke-linecap:round;stroke-linejoin:round}\n"], dependencies: [{ kind: "pipe", type: KeyValuePipe, name: "keyvalue" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
11
11
|
}
|
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefsComponent, decorators: [{
|
|
13
13
|
type: Component,
|
|
14
|
-
args: [{ selector: 'defs[flowDefs]', changeDetection: ChangeDetectionStrategy.OnPush, template: "
|
|
15
|
-
}]
|
|
16
|
-
|
|
17
|
-
args: [{ required: true }]
|
|
18
|
-
}] } });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvY29tcG9uZW50cy9kZWZzL2RlZnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2NvbXBvbmVudHMvZGVmcy9kZWZzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFTMUUsTUFBTSxPQUFPLGFBQWE7SUFOMUI7UUFRUyxZQUFPLEdBQXdCLElBQUksR0FBRyxFQUFFLENBQUE7UUFFNUIsaUJBQVksR0FBRyxvQkFBb0IsQ0FBQTtLQUN2RDsrR0FMWSxhQUFhO21HQUFiLGFBQWEsc0ZDVDFCLDQrQkE0QkE7OzRGRG5CYSxhQUFhO2tCQU56QixTQUFTOytCQUNFLGdCQUFnQixtQkFHVCx1QkFBdUIsQ0FBQyxNQUFNOzhCQUl4QyxPQUFPO3NCQURiLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hcmtlciB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvbWFya2VyLmludGVyZmFjZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RlZnNbZmxvd0RlZnNdJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RlZnMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kZWZzLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERlZnNDb21wb25lbnQge1xuICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KVxuICBwdWJsaWMgbWFya2VyczogTWFwPG51bWJlciwgTWFya2VyPiA9IG5ldyBNYXAoKVxuXG4gIHByb3RlY3RlZCByZWFkb25seSBkZWZhdWx0Q29sb3IgPSAncmdiKDE3NywgMTc3LCAxODMpJ1xufVxuIiwiPHN2ZzptYXJrZXJcbiAgKm5nRm9yPVwibGV0IG1hcmtlciBvZiBtYXJrZXJzIHwga2V5dmFsdWVcIlxuICBbYXR0ci5pZF09XCJtYXJrZXIua2V5XCJcbiAgW2F0dHIubWFya2VyV2lkdGhdPVwibWFya2VyLnZhbHVlLndpZHRoID8/IDE2LjVcIlxuICBbYXR0ci5tYXJrZXJIZWlnaHRdPVwibWFya2VyLnZhbHVlLmhlaWdodCA/PyAxNi41XCJcbiAgW2F0dHIub3JpZW50XT1cIm1hcmtlci52YWx1ZS5vcmllbnQgPz8gJ2F1dG8tc3RhcnQtcmV2ZXJzZSdcIlxuICB2aWV3Qm94PVwiLTEwIC0xMCAyMCAyMFwiXG4gIFthdHRyLm1hcmtlclVuaXRzXT1cIm1hcmtlci52YWx1ZS5tYXJrZXJVbml0cyA/PyAndXNlclNwYWNlT25Vc2UnXCJcbiAgcmVmWD1cIjBcIlxuICByZWZZPVwiMFwiXG4+XG4gIDxwb2x5bGluZVxuICAgICpuZ0lmPVwibWFya2VyLnZhbHVlLnR5cGUgPT09ICdhcnJvdy1jbG9zZWQnIHx8ICFtYXJrZXIudmFsdWUudHlwZVwiXG4gICAgY2xhc3M9XCJtYXJrZXJfX2Fycm93X2Nsb3NlZFwiXG4gICAgW3N0eWxlLnN0cm9rZV09XCJtYXJrZXIudmFsdWUuY29sb3IgPz8gZGVmYXVsdENvbG9yXCJcbiAgICBbc3R5bGUuc3Ryb2tlLXdpZHRoXT1cIm1hcmtlci52YWx1ZS5zdHJva2VXaWR0aCA/PyAyXCJcbiAgICBbc3R5bGUuZmlsbF09XCJtYXJrZXIudmFsdWUuY29sb3IgPz8gZGVmYXVsdENvbG9yXCJcbiAgICBwb2ludHM9XCItNSwtNCAxLDAgLTUsNCAtNSwtNFwiXG4gIC8+XG5cbiAgPHBvbHlsaW5lXG4gICAgKm5nSWY9XCJtYXJrZXIudmFsdWUudHlwZSA9PT0gJ2Fycm93J1wiXG4gICAgY2xhc3M9XCJtYXJrZXJfX2Fycm93X2RlZmF1bHRcIlxuICAgIFtzdHlsZS5zdHJva2VdPVwibWFya2VyLnZhbHVlLmNvbG9yID8/IGRlZmF1bHRDb2xvclwiXG4gICAgW3N0eWxlLnN0cm9rZS13aWR0aF09XCJtYXJrZXIudmFsdWUuc3Ryb2tlV2lkdGggPz8gMlwiXG4gICAgcG9pbnRzPVwiLTUsLTQgMCwwIC01LDRcIlxuICAvPlxuPC9zdmc6bWFya2VyPlxuIl19
|
|
14
|
+
args: [{ standalone: true, selector: 'defs[flowDefs]', changeDetection: ChangeDetectionStrategy.OnPush, imports: [KeyValuePipe], template: "@for (marker of markers() | keyvalue; track marker) {\n <svg:marker\n [attr.id]=\"marker.key\"\n [attr.markerWidth]=\"marker.value.width ?? 16.5\"\n [attr.markerHeight]=\"marker.value.height ?? 16.5\"\n [attr.orient]=\"marker.value.orient ?? 'auto-start-reverse'\"\n viewBox=\"-10 -10 20 20\"\n [attr.markerUnits]=\"marker.value.markerUnits ?? 'userSpaceOnUse'\"\n refX=\"0\"\n refY=\"0\"\n >\n @if (marker.value.type === \"arrow-closed\" || !marker.value.type) {\n <polyline\n class=\"marker__arrow_closed\"\n [style.stroke]=\"marker.value.color ?? defaultColor\"\n [style.stroke-width]=\"marker.value.strokeWidth ?? 2\"\n [style.fill]=\"marker.value.color ?? defaultColor\"\n points=\"-5,-4 1,0 -5,4 -5,-4\"\n />\n }\n\n @if (marker.value.type === \"arrow\") {\n <polyline\n class=\"marker__arrow_default\"\n [style.stroke]=\"marker.value.color ?? defaultColor\"\n [style.stroke-width]=\"marker.value.strokeWidth ?? 2\"\n points=\"-5,-4 0,0 -5,4\"\n />\n }\n </svg:marker>\n}\n", styles: [".marker__arrow_default{stroke-width:1px;stroke-linecap:round;stroke-linejoin:round;fill:none}.marker__arrow_closed{stroke-linecap:round;stroke-linejoin:round}\n"] }]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvY29tcG9uZW50cy9kZWZzL2RlZnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2NvbXBvbmVudHMvZGVmcy9kZWZzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFVL0MsTUFBTSxPQUFPLGFBQWE7SUFSMUI7UUFTUyxZQUFPLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBdUIsQ0FBQztRQUVwQyxpQkFBWSxHQUFHLG9CQUFvQixDQUFDO0tBQ3hEOytHQUpZLGFBQWE7bUdBQWIsYUFBYSxtTkNaMUIsK2tDQStCQSxxTkRyQlksWUFBWTs7NEZBRVgsYUFBYTtrQkFSekIsU0FBUztpQ0FDSSxJQUFJLFlBQ04sZ0JBQWdCLG1CQUdULHVCQUF1QixDQUFDLE1BQU0sV0FDdEMsQ0FBQyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWFya2VyIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9tYXJrZXIuaW50ZXJmYWNlJztcbmltcG9ydCB7IEtleVZhbHVlUGlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ2RlZnNbZmxvd0RlZnNdJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RlZnMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kZWZzLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBpbXBvcnRzOiBbS2V5VmFsdWVQaXBlXSxcbn0pXG5leHBvcnQgY2xhc3MgRGVmc0NvbXBvbmVudCB7XG4gIHB1YmxpYyBtYXJrZXJzID0gaW5wdXQucmVxdWlyZWQ8TWFwPG51bWJlciwgTWFya2VyPj4oKTtcblxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgZGVmYXVsdENvbG9yID0gJ3JnYigxNzcsIDE3NywgMTgzKSc7XG59XG4iLCJAZm9yIChtYXJrZXIgb2YgbWFya2VycygpIHwga2V5dmFsdWU7IHRyYWNrIG1hcmtlcikge1xuICA8c3ZnOm1hcmtlclxuICAgIFthdHRyLmlkXT1cIm1hcmtlci5rZXlcIlxuICAgIFthdHRyLm1hcmtlcldpZHRoXT1cIm1hcmtlci52YWx1ZS53aWR0aCA/PyAxNi41XCJcbiAgICBbYXR0ci5tYXJrZXJIZWlnaHRdPVwibWFya2VyLnZhbHVlLmhlaWdodCA/PyAxNi41XCJcbiAgICBbYXR0ci5vcmllbnRdPVwibWFya2VyLnZhbHVlLm9yaWVudCA/PyAnYXV0by1zdGFydC1yZXZlcnNlJ1wiXG4gICAgdmlld0JveD1cIi0xMCAtMTAgMjAgMjBcIlxuICAgIFthdHRyLm1hcmtlclVuaXRzXT1cIm1hcmtlci52YWx1ZS5tYXJrZXJVbml0cyA/PyAndXNlclNwYWNlT25Vc2UnXCJcbiAgICByZWZYPVwiMFwiXG4gICAgcmVmWT1cIjBcIlxuICA+XG4gICAgQGlmIChtYXJrZXIudmFsdWUudHlwZSA9PT0gXCJhcnJvdy1jbG9zZWRcIiB8fCAhbWFya2VyLnZhbHVlLnR5cGUpIHtcbiAgICAgIDxwb2x5bGluZVxuICAgICAgICBjbGFzcz1cIm1hcmtlcl9fYXJyb3dfY2xvc2VkXCJcbiAgICAgICAgW3N0eWxlLnN0cm9rZV09XCJtYXJrZXIudmFsdWUuY29sb3IgPz8gZGVmYXVsdENvbG9yXCJcbiAgICAgICAgW3N0eWxlLnN0cm9rZS13aWR0aF09XCJtYXJrZXIudmFsdWUuc3Ryb2tlV2lkdGggPz8gMlwiXG4gICAgICAgIFtzdHlsZS5maWxsXT1cIm1hcmtlci52YWx1ZS5jb2xvciA/PyBkZWZhdWx0Q29sb3JcIlxuICAgICAgICBwb2ludHM9XCItNSwtNCAxLDAgLTUsNCAtNSwtNFwiXG4gICAgICAvPlxuICAgIH1cblxuICAgIEBpZiAobWFya2VyLnZhbHVlLnR5cGUgPT09IFwiYXJyb3dcIikge1xuICAgICAgPHBvbHlsaW5lXG4gICAgICAgIGNsYXNzPVwibWFya2VyX19hcnJvd19kZWZhdWx0XCJcbiAgICAgICAgW3N0eWxlLnN0cm9rZV09XCJtYXJrZXIudmFsdWUuY29sb3IgPz8gZGVmYXVsdENvbG9yXCJcbiAgICAgICAgW3N0eWxlLnN0cm9rZS13aWR0aF09XCJtYXJrZXIudmFsdWUuc3Ryb2tlV2lkdGggPz8gMlwiXG4gICAgICAgIHBvaW50cz1cIi01LC00IDAsMCAtNSw0XCJcbiAgICAgIC8+XG4gICAgfVxuICA8L3N2ZzptYXJrZXI+XG59XG4iXX0=
|