@unovis/angular 1.3.4-beta.2 → 1.4.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,26 @@
1
+ import { AfterViewInit, SimpleChanges } from '@angular/core';
2
+ import { Annotations, AnnotationsConfigInterface, ContainerCore, AnnotationItem } from '@unovis/ts';
3
+ import * as i0 from "@angular/core";
4
+ export declare class VisAnnotationsComponent implements AnnotationsConfigInterface, AfterViewInit {
5
+ /** Legend items. Array of `AnnotationItem`:
6
+ * ```
7
+ * {
8
+ * content: string | UnovisText | UnovisText[];
9
+ * subject?: AnnotationSubject;
10
+ * x?: LengthUnit;
11
+ * y?: LengthUnit;
12
+ * width?: LengthUnit;
13
+ * height?: LengthUnit;
14
+ * }
15
+ * ```
16
+ * To learn more, see our docs https://unovis.dev/docs/auxiliary/Annotations/
17
+ * Default: `[]` */
18
+ items: AnnotationItem[] | undefined;
19
+ component: Annotations | undefined;
20
+ componentContainer: ContainerCore | undefined;
21
+ ngAfterViewInit(): void;
22
+ ngOnChanges(changes: SimpleChanges): void;
23
+ private getConfig;
24
+ static ɵfac: i0.ɵɵFactoryDeclaration<VisAnnotationsComponent, never>;
25
+ static ɵcmp: i0.ɵɵComponentDeclaration<VisAnnotationsComponent, "vis-annotations", never, { "items": "items"; }, {}, never, never>;
26
+ }
@@ -71,7 +71,7 @@ export declare class VisAreaComponent<Datum> implements AreaConfigInterface<Datu
71
71
  * Default: `false` */
72
72
  excludeFromDomainCalculation?: boolean;
73
73
  /** Curve type from the CurveType enum. Default: `CurveType.MonotoneX` */
74
- curveType?: CurveType;
74
+ curveType?: CurveType | string;
75
75
  /** Baseline value or accessor function. Default: `undefined` */
76
76
  baseline?: NumericAccessor<Datum>;
77
77
  /** Opacity value or accessor function. Default: `1` */
@@ -2,11 +2,13 @@ import { ElementRef, AfterViewInit, OnDestroy, SimpleChanges } from '@angular/co
2
2
  import { ComponentCore, SingleContainer, SingleContainerConfigInterface, Spacing } from '@unovis/ts';
3
3
  import { VisCoreComponent } from '../../core';
4
4
  import { VisTooltipComponent } from '../../components/tooltip/tooltip.component';
5
+ import { VisAnnotationsComponent } from '../../components/annotations/annotations.component';
5
6
  import * as i0 from "@angular/core";
6
7
  export declare class VisSingleContainerComponent<Data = unknown, C extends ComponentCore<Data> = ComponentCore<Data>> implements AfterViewInit, OnDestroy {
7
8
  containerRef: ElementRef;
8
9
  visComponent: VisCoreComponent;
9
10
  tooltipComponent: VisTooltipComponent;
11
+ annotationsComponent: VisAnnotationsComponent;
10
12
  /** Width in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */
11
13
  width?: number;
12
14
  /** Height in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */
@@ -27,5 +29,5 @@ export declare class VisSingleContainerComponent<Data = unknown, C extends Compo
27
29
  getConfig(): SingleContainerConfigInterface<Data>;
28
30
  ngOnDestroy(): void;
29
31
  static ɵfac: i0.ɵɵFactoryDeclaration<VisSingleContainerComponent<any, any>, never>;
30
- static ɵcmp: i0.ɵɵComponentDeclaration<VisSingleContainerComponent<any, any>, "vis-single-container", never, { "width": "width"; "height": "height"; "margin": "margin"; "duration": "duration"; "ariaLabel": "ariaLabel"; "data": "data"; }, {}, ["visComponent", "tooltipComponent"], ["*"]>;
32
+ static ɵcmp: i0.ɵɵComponentDeclaration<VisSingleContainerComponent<any, any>, "vis-single-container", never, { "width": "width"; "height": "height"; "margin": "margin"; "duration": "duration"; "ariaLabel": "ariaLabel"; "data": "data"; }, {}, ["visComponent", "tooltipComponent", "annotationsComponent"], ["*"]>;
31
33
  }
@@ -2,11 +2,13 @@ import { AfterContentInit, AfterViewInit, ElementRef, OnDestroy, QueryList, Simp
2
2
  import { ContinuousScale, Direction, Spacing, XYContainer, XYContainerConfigInterface } from '@unovis/ts';
3
3
  import { VisXYComponent } from '../../core';
4
4
  import { VisTooltipComponent } from '../../components/tooltip/tooltip.component';
5
+ import { VisAnnotationsComponent } from '../../components/annotations/annotations.component';
5
6
  import * as i0 from "@angular/core";
6
7
  export declare class VisXYContainerComponent<Datum> implements AfterViewInit, AfterContentInit, OnDestroy {
7
8
  containerRef: ElementRef;
8
9
  visComponents: QueryList<VisXYComponent>;
9
10
  tooltipComponent: VisTooltipComponent;
11
+ annotationsComponent: VisAnnotationsComponent;
10
12
  /** Width in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */
11
13
  width?: number;
12
14
  /** Height in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */
@@ -87,5 +89,5 @@ export declare class VisXYContainerComponent<Datum> implements AfterViewInit, Af
87
89
  passContainerReferenceToChildren(): void;
88
90
  ngOnDestroy(): void;
89
91
  static ɵfac: i0.ɵɵFactoryDeclaration<VisXYContainerComponent<any>, never>;
90
- static ɵcmp: i0.ɵɵComponentDeclaration<VisXYContainerComponent<any>, "vis-xy-container", never, { "width": "width"; "height": "height"; "xScale": "xScale"; "xDomain": "xDomain"; "xDomainMinConstraint": "xDomainMinConstraint"; "xDomainMaxConstraint": "xDomainMaxConstraint"; "xRange": "xRange"; "yScale": "yScale"; "yDomain": "yDomain"; "yDomainMinConstraint": "yDomainMinConstraint"; "yDomainMaxConstraint": "yDomainMaxConstraint"; "yRange": "yRange"; "yDirection": "yDirection"; "preventEmptyDomain": "preventEmptyDomain"; "duration": "duration"; "margin": "margin"; "padding": "padding"; "scaleByDomain": "scaleByDomain"; "autoMargin": "autoMargin"; "ariaLabel": "ariaLabel"; "data": "data"; }, {}, ["tooltipComponent", "visComponents"], ["*"]>;
92
+ static ɵcmp: i0.ɵɵComponentDeclaration<VisXYContainerComponent<any>, "vis-xy-container", never, { "width": "width"; "height": "height"; "xScale": "xScale"; "xDomain": "xDomain"; "xDomainMinConstraint": "xDomainMinConstraint"; "xDomainMaxConstraint": "xDomainMaxConstraint"; "xRange": "xRange"; "yScale": "yScale"; "yDomain": "yDomain"; "yDomainMinConstraint": "yDomainMinConstraint"; "yDomainMaxConstraint": "yDomainMaxConstraint"; "yRange": "yRange"; "yDirection": "yDirection"; "preventEmptyDomain": "preventEmptyDomain"; "duration": "duration"; "margin": "margin"; "padding": "padding"; "scaleByDomain": "scaleByDomain"; "autoMargin": "autoMargin"; "ariaLabel": "ariaLabel"; "data": "data"; }, {}, ["tooltipComponent", "annotationsComponent", "visComponents"], ["*"]>;
91
93
  }
@@ -0,0 +1,37 @@
1
+ // !!! This code was automatically generated. You should not change it !!!
2
+ import { Component, Input } from '@angular/core';
3
+ import { Annotations } from '@unovis/ts';
4
+ import { VisGenericComponent } from '../../core';
5
+ import * as i0 from "@angular/core";
6
+ export class VisAnnotationsComponent {
7
+ ngAfterViewInit() {
8
+ this.component = new Annotations(this.getConfig());
9
+ }
10
+ ngOnChanges(changes) {
11
+ var _a, _b;
12
+ (_a = this.component) === null || _a === void 0 ? void 0 : _a.setConfig(this.getConfig());
13
+ (_b = this.componentContainer) === null || _b === void 0 ? void 0 : _b.render();
14
+ }
15
+ getConfig() {
16
+ const { items } = this;
17
+ const config = { items };
18
+ const keys = Object.keys(config);
19
+ keys.forEach(key => { if (config[key] === undefined)
20
+ delete config[key]; });
21
+ return config;
22
+ }
23
+ }
24
+ VisAnnotationsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
25
+ VisAnnotationsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisAnnotationsComponent, selector: "vis-annotations", inputs: { items: "items" }, providers: [{ provide: VisGenericComponent, useExisting: VisAnnotationsComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsComponent, decorators: [{
27
+ type: Component,
28
+ args: [{
29
+ selector: 'vis-annotations',
30
+ template: '',
31
+ // eslint-disable-next-line no-use-before-define
32
+ providers: [{ provide: VisGenericComponent, useExisting: VisAnnotationsComponent }],
33
+ }]
34
+ }], propDecorators: { items: [{
35
+ type: Input
36
+ }] } });
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ub3RhdGlvbnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYW5ub3RhdGlvbnMvYW5ub3RhdGlvbnMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDBFQUEwRTtBQUMxRSxPQUFPLEVBQUUsU0FBUyxFQUFpQixLQUFLLEVBQWlCLE1BQU0sZUFBZSxDQUFBO0FBQzlFLE9BQU8sRUFBRSxXQUFXLEVBQTZELE1BQU0sWUFBWSxDQUFBO0FBQ25HLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLFlBQVksQ0FBQTs7QUFRaEQsTUFBTSxPQUFPLHVCQUF1QjtJQW9CbEMsZUFBZTtRQUNiLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUE7SUFDcEQsQ0FBQztJQUVELFdBQVcsQ0FBRSxPQUFzQjs7UUFDakMsTUFBQSxJQUFJLENBQUMsU0FBUywwQ0FBRSxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUE7UUFDM0MsTUFBQSxJQUFJLENBQUMsa0JBQWtCLDBDQUFFLE1BQU0sRUFBRSxDQUFBO0lBQ25DLENBQUM7SUFFTyxTQUFTO1FBQ2YsTUFBTSxFQUFFLEtBQUssRUFBRSxHQUFHLElBQUksQ0FBQTtRQUN0QixNQUFNLE1BQU0sR0FBRyxFQUFFLEtBQUssRUFBRSxDQUFBO1FBQ3hCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUF5QyxDQUFBO1FBQ3hFLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsR0FBRyxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUMsS0FBSyxTQUFTO1lBQUUsT0FBTyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUEsQ0FBQyxDQUFDLENBQUMsQ0FBQTtRQUUxRSxPQUFPLE1BQU0sQ0FBQTtJQUNmLENBQUM7O3FIQXBDVSx1QkFBdUI7eUdBQXZCLHVCQUF1QixzRUFGdkIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxXQUFXLEVBQUUsdUJBQXVCLEVBQUUsQ0FBQywrQ0FGekUsRUFBRTs0RkFJRCx1QkFBdUI7a0JBTm5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsUUFBUSxFQUFFLEVBQUU7b0JBQ1osZ0RBQWdEO29CQUNoRCxTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxXQUFXLHlCQUF5QixFQUFFLENBQUM7aUJBQ3BGOzhCQWVVLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbIi8vICEhISBUaGlzIGNvZGUgd2FzIGF1dG9tYXRpY2FsbHkgZ2VuZXJhdGVkLiBZb3Ugc2hvdWxkIG5vdCBjaGFuZ2UgaXQgISEhXG5pbXBvcnQgeyBDb21wb25lbnQsIEFmdGVyVmlld0luaXQsIElucHV0LCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IEFubm90YXRpb25zLCBBbm5vdGF0aW9uc0NvbmZpZ0ludGVyZmFjZSwgQ29udGFpbmVyQ29yZSwgQW5ub3RhdGlvbkl0ZW0gfSBmcm9tICdAdW5vdmlzL3RzJ1xuaW1wb3J0IHsgVmlzR2VuZXJpY0NvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvcmUnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3Zpcy1hbm5vdGF0aW9ucycsXG4gIHRlbXBsYXRlOiAnJyxcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXVzZS1iZWZvcmUtZGVmaW5lXG4gIHByb3ZpZGVyczogW3sgcHJvdmlkZTogVmlzR2VuZXJpY0NvbXBvbmVudCwgdXNlRXhpc3Rpbmc6IFZpc0Fubm90YXRpb25zQ29tcG9uZW50IH1dLFxufSlcbmV4cG9ydCBjbGFzcyBWaXNBbm5vdGF0aW9uc0NvbXBvbmVudCBpbXBsZW1lbnRzIEFubm90YXRpb25zQ29uZmlnSW50ZXJmYWNlLCBBZnRlclZpZXdJbml0IHtcbiAgLyoqIExlZ2VuZCBpdGVtcy4gQXJyYXkgb2YgYEFubm90YXRpb25JdGVtYDpcbiAgICogYGBgXG4gICAqIHtcbiAgICogIGNvbnRlbnQ6IHN0cmluZyB8IFVub3Zpc1RleHQgfCBVbm92aXNUZXh0W107XG4gICAqICBzdWJqZWN0PzogQW5ub3RhdGlvblN1YmplY3Q7XG4gICAqICB4PzogTGVuZ3RoVW5pdDtcbiAgICogIHk/OiBMZW5ndGhVbml0O1xuICAgKiAgd2lkdGg/OiBMZW5ndGhVbml0O1xuICAgKiAgaGVpZ2h0PzogTGVuZ3RoVW5pdDtcbiAgICogfVxuICAgKiBgYGBcbiAgICogVG8gbGVhcm4gbW9yZSwgc2VlIG91ciBkb2NzIGh0dHBzOi8vdW5vdmlzLmRldi9kb2NzL2F1eGlsaWFyeS9Bbm5vdGF0aW9ucy9cbiAgICogRGVmYXVsdDogYFtdYCAqL1xuICBASW5wdXQoKSBpdGVtczogQW5ub3RhdGlvbkl0ZW1bXSB8IHVuZGVmaW5lZFxuXG5cbiAgY29tcG9uZW50OiBBbm5vdGF0aW9ucyB8IHVuZGVmaW5lZFxuICBwdWJsaWMgY29tcG9uZW50Q29udGFpbmVyOiBDb250YWluZXJDb3JlIHwgdW5kZWZpbmVkXG5cbiAgbmdBZnRlclZpZXdJbml0ICgpOiB2b2lkIHtcbiAgICB0aGlzLmNvbXBvbmVudCA9IG5ldyBBbm5vdGF0aW9ucyh0aGlzLmdldENvbmZpZygpKVxuICB9XG5cbiAgbmdPbkNoYW5nZXMgKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICB0aGlzLmNvbXBvbmVudD8uc2V0Q29uZmlnKHRoaXMuZ2V0Q29uZmlnKCkpXG4gICAgdGhpcy5jb21wb25lbnRDb250YWluZXI/LnJlbmRlcigpXG4gIH1cblxuICBwcml2YXRlIGdldENvbmZpZyAoKTogQW5ub3RhdGlvbnNDb25maWdJbnRlcmZhY2Uge1xuICAgIGNvbnN0IHsgaXRlbXMgfSA9IHRoaXNcbiAgICBjb25zdCBjb25maWcgPSB7IGl0ZW1zIH1cbiAgICBjb25zdCBrZXlzID0gT2JqZWN0LmtleXMoY29uZmlnKSBhcyAoa2V5b2YgQW5ub3RhdGlvbnNDb25maWdJbnRlcmZhY2UpW11cbiAgICBrZXlzLmZvckVhY2goa2V5ID0+IHsgaWYgKGNvbmZpZ1trZXldID09PSB1bmRlZmluZWQpIGRlbGV0ZSBjb25maWdba2V5XSB9KVxuXG4gICAgcmV0dXJuIGNvbmZpZ1xuICB9XG59XG4iXX0=
@@ -72,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
72
72
  }], data: [{
73
73
  type: Input
74
74
  }] } });
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"area.component.js","sourceRoot":"","sources":["../../../../../src/components/area/area.component.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,OAAO,EAAE,SAAS,EAAiB,KAAK,EAAiB,MAAM,eAAe,CAAA;AAC9E,OAAO,EACL,IAAI,GAUL,MAAM,YAAY,CAAA;AACnB,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;;AAQ3C,MAAM,OAAO,gBAAgB;IAqG3B,eAAe;;QACb,IAAI,CAAC,SAAS,GAAG,IAAI,IAAI,CAAQ,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAElD,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACjC,MAAA,IAAI,CAAC,kBAAkB,0CAAE,MAAM,EAAE,CAAA;SAClC;IACH,CAAC;IAED,WAAW,CAAE,OAAsB;;QACjC,IAAI,OAAO,CAAC,IAAI,EAAE;YAAE,MAAA,IAAI,CAAC,SAAS,0CAAE,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;SAAE;QACxD,MAAA,IAAI,CAAC,SAAS,0CAAE,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAC3C,MAAA,IAAI,CAAC,kBAAkB,0CAAE,MAAM,EAAE,CAAA;IACnC,CAAC;IAEO,SAAS;QACf,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,4BAA4B,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,IAAI,CAAA;QAChK,MAAM,MAAM,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,4BAA4B,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,CAAA;QAClK,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAyC,CAAA;QACxE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,GAAG,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,SAAS;YAAE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAE1E,OAAO,MAAM,CAAA;IACf,CAAC;;8GA3HU,gBAAgB;kGAAhB,gBAAgB,6XAFhB,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC,+CAF7D,EAAE;4FAID,gBAAgB;kBAN5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,UAAU;oBACpB,QAAQ,EAAE,EAAE;oBACZ,gDAAgD;oBAChD,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,WAAW,kBAAkB,EAAE,CAAC;iBACxE;8BAGU,QAAQ;sBAAhB,KAAK;gBAmBG,MAAM;sBAAd,KAAK;gBAwBG,UAAU;sBAAlB,KAAK;gBAOG,CAAC;sBAAT,KAAK;gBAGG,CAAC;sBAAT,KAAK;gBAGG,EAAE;sBAAV,KAAK;gBAGG,KAAK;sBAAb,KAAK;gBAKG,MAAM;sBAAd,KAAK;gBAKG,MAAM;sBAAd,KAAK;gBAMG,4BAA4B;sBAApC,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBAMG,YAAY;sBAApB,KAAK;gBACG,IAAI;sBAAZ,KAAK","sourcesContent":["// !!! This code was automatically generated. You should not change it !!!\nimport { Component, AfterViewInit, Input, SimpleChanges } from '@angular/core'\nimport {\n  Area,\n  AreaConfigInterface,\n  ContainerCore,\n  VisEventType,\n  VisEventCallback,\n  NumericAccessor,\n  ColorAccessor,\n  ContinuousScale,\n  CurveType,\n  StringAccessor,\n} from '@unovis/ts'\nimport { VisXYComponent } from '../../core'\n\n@Component({\n  selector: 'vis-area',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisXYComponent, useExisting: VisAreaComponent }],\n})\nexport class VisAreaComponent<Datum> implements AreaConfigInterface<Datum>, AfterViewInit {\n  /** Animation duration of the data update transitions in milliseconds. Default: `600` */\n  @Input() duration?: number\n\n  /** Events configuration. An object containing properties in the following format:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[eventType]: callbackFunction\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    click: (d) => console.log(\"Clicked Area\", d)\n   *  }\n   * }\n   * ``` */\n  @Input() events?: {\n    [selector: string]: {\n      [eventType in VisEventType]?: VisEventCallback\n    };\n  }\n\n  /** You can set every SVG and HTML visualization object to have a custom DOM attributes, which is useful\n   * when you want to do unit or end-to-end testing. Attributes configuration object has the following structure:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[attributeName]: attribute constant value or accessor function\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    \"test-value\": d => d.value\n   *  }\n   * }\n   * ``` */\n  @Input() attributes?: {\n    [selector: string]: {\n      [attr: string]: string | number | boolean | ((datum: any) => string | number | boolean);\n    };\n  }\n\n  /** Accessor function for getting the values along the X axis. Default: `undefined` */\n  @Input() x: NumericAccessor<Datum>\n\n  /** A single of multiple accessor functions for getting the values along the Y axis. Default: `undefined` */\n  @Input() y: NumericAccessor<Datum> | NumericAccessor<Datum>[]\n\n  /** Accessor function for getting the unique data record id. Used for more persistent data updates. Default: `(d, i) => d.id ?? i` */\n  @Input() id?: ((d: Datum, i: number, ...rest) => string)\n\n  /** Area color accessor function. The whole data array will be passed as the first argument. Default: `undefined` */\n  @Input() color?: ColorAccessor<Datum[]>\n\n  /** Scale for X dimension, e.g. Scale.scaleLinear(). If you set xScale you'll be responsible for setting it's `domain` and `range` as well.\n   * Only continuous scales are supported.\n   * Default: `undefined` */\n  @Input() xScale?: ContinuousScale\n\n  /** Scale for Y dimension, e.g. Scale.scaleLinear(). If you set yScale you'll be responsible for setting it's `domain` and `range` as well.\n   * Only continuous scales are supported.\n   * Default: `undefined` */\n  @Input() yScale?: ContinuousScale\n\n  /** Identifies whether the component should be excluded from overall X and Y domain calculations or not.\n   * This property can be useful when you want pass individual data to a component and you don't want it to affect\n   * the scales of the chart.\n   * Default: `false` */\n  @Input() excludeFromDomainCalculation?: boolean\n\n  /** Curve type from the CurveType enum. Default: `CurveType.MonotoneX` */\n  @Input() curveType?: CurveType\n\n  /** Baseline value or accessor function. Default: `undefined` */\n  @Input() baseline?: NumericAccessor<Datum>\n\n  /** Opacity value or accessor function. Default: `1` */\n  @Input() opacity?: NumericAccessor<Datum[]>\n\n  /** Optional area cursor. String or accessor function. Default: `null` */\n  @Input() cursor?: StringAccessor<Datum[]>\n\n  /** If an area is smaller than 1px, extend it to have 1px height.\n   * This setting is useful when some of the area values are zeros or very small so visually they become\n   * practically invisible, but you want to show that the data behind them exists and they're not just empty segments.\n   * Default: `false` */\n  @Input() minHeight1Px?: boolean\n  @Input() data: Datum[]\n\n  component: Area<Datum> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new Area<Datum>(this.getConfig())\n\n    if (this.data) {\n      this.component.setData(this.data)\n      this.componentContainer?.render()\n    }\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    if (changes.data) { this.component?.setData(this.data) }\n    this.component?.setConfig(this.getConfig())\n    this.componentContainer?.render()\n  }\n\n  private getConfig (): AreaConfigInterface<Datum> {\n    const { duration, events, attributes, x, y, id, color, xScale, yScale, excludeFromDomainCalculation, curveType, baseline, opacity, cursor, minHeight1Px } = this\n    const config = { duration, events, attributes, x, y, id, color, xScale, yScale, excludeFromDomainCalculation, curveType, baseline, opacity, cursor, minHeight1Px }\n    const keys = Object.keys(config) as (keyof AreaConfigInterface<Datum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"area.component.js","sourceRoot":"","sources":["../../../../../src/components/area/area.component.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,OAAO,EAAE,SAAS,EAAiB,KAAK,EAAiB,MAAM,eAAe,CAAA;AAC9E,OAAO,EACL,IAAI,GAUL,MAAM,YAAY,CAAA;AACnB,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;;AAQ3C,MAAM,OAAO,gBAAgB;IAqG3B,eAAe;;QACb,IAAI,CAAC,SAAS,GAAG,IAAI,IAAI,CAAQ,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAElD,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACjC,MAAA,IAAI,CAAC,kBAAkB,0CAAE,MAAM,EAAE,CAAA;SAClC;IACH,CAAC;IAED,WAAW,CAAE,OAAsB;;QACjC,IAAI,OAAO,CAAC,IAAI,EAAE;YAAE,MAAA,IAAI,CAAC,SAAS,0CAAE,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;SAAE;QACxD,MAAA,IAAI,CAAC,SAAS,0CAAE,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAC3C,MAAA,IAAI,CAAC,kBAAkB,0CAAE,MAAM,EAAE,CAAA;IACnC,CAAC;IAEO,SAAS;QACf,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,4BAA4B,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,IAAI,CAAA;QAChK,MAAM,MAAM,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,4BAA4B,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,CAAA;QAClK,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAyC,CAAA;QACxE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,GAAG,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,SAAS;YAAE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAE1E,OAAO,MAAM,CAAA;IACf,CAAC;;8GA3HU,gBAAgB;kGAAhB,gBAAgB,6XAFhB,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC,+CAF7D,EAAE;4FAID,gBAAgB;kBAN5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,UAAU;oBACpB,QAAQ,EAAE,EAAE;oBACZ,gDAAgD;oBAChD,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,WAAW,kBAAkB,EAAE,CAAC;iBACxE;8BAGU,QAAQ;sBAAhB,KAAK;gBAmBG,MAAM;sBAAd,KAAK;gBAwBG,UAAU;sBAAlB,KAAK;gBAOG,CAAC;sBAAT,KAAK;gBAGG,CAAC;sBAAT,KAAK;gBAGG,EAAE;sBAAV,KAAK;gBAGG,KAAK;sBAAb,KAAK;gBAKG,MAAM;sBAAd,KAAK;gBAKG,MAAM;sBAAd,KAAK;gBAMG,4BAA4B;sBAApC,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBAMG,YAAY;sBAApB,KAAK;gBACG,IAAI;sBAAZ,KAAK","sourcesContent":["// !!! This code was automatically generated. You should not change it !!!\nimport { Component, AfterViewInit, Input, SimpleChanges } from '@angular/core'\nimport {\n  Area,\n  AreaConfigInterface,\n  ContainerCore,\n  VisEventType,\n  VisEventCallback,\n  NumericAccessor,\n  ColorAccessor,\n  ContinuousScale,\n  CurveType,\n  StringAccessor,\n} from '@unovis/ts'\nimport { VisXYComponent } from '../../core'\n\n@Component({\n  selector: 'vis-area',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisXYComponent, useExisting: VisAreaComponent }],\n})\nexport class VisAreaComponent<Datum> implements AreaConfigInterface<Datum>, AfterViewInit {\n  /** Animation duration of the data update transitions in milliseconds. Default: `600` */\n  @Input() duration?: number\n\n  /** Events configuration. An object containing properties in the following format:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[eventType]: callbackFunction\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    click: (d) => console.log(\"Clicked Area\", d)\n   *  }\n   * }\n   * ``` */\n  @Input() events?: {\n    [selector: string]: {\n      [eventType in VisEventType]?: VisEventCallback\n    };\n  }\n\n  /** You can set every SVG and HTML visualization object to have a custom DOM attributes, which is useful\n   * when you want to do unit or end-to-end testing. Attributes configuration object has the following structure:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[attributeName]: attribute constant value or accessor function\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    \"test-value\": d => d.value\n   *  }\n   * }\n   * ``` */\n  @Input() attributes?: {\n    [selector: string]: {\n      [attr: string]: string | number | boolean | ((datum: any) => string | number | boolean);\n    };\n  }\n\n  /** Accessor function for getting the values along the X axis. Default: `undefined` */\n  @Input() x: NumericAccessor<Datum>\n\n  /** A single of multiple accessor functions for getting the values along the Y axis. Default: `undefined` */\n  @Input() y: NumericAccessor<Datum> | NumericAccessor<Datum>[]\n\n  /** Accessor function for getting the unique data record id. Used for more persistent data updates. Default: `(d, i) => d.id ?? i` */\n  @Input() id?: ((d: Datum, i: number, ...rest) => string)\n\n  /** Area color accessor function. The whole data array will be passed as the first argument. Default: `undefined` */\n  @Input() color?: ColorAccessor<Datum[]>\n\n  /** Scale for X dimension, e.g. Scale.scaleLinear(). If you set xScale you'll be responsible for setting it's `domain` and `range` as well.\n   * Only continuous scales are supported.\n   * Default: `undefined` */\n  @Input() xScale?: ContinuousScale\n\n  /** Scale for Y dimension, e.g. Scale.scaleLinear(). If you set yScale you'll be responsible for setting it's `domain` and `range` as well.\n   * Only continuous scales are supported.\n   * Default: `undefined` */\n  @Input() yScale?: ContinuousScale\n\n  /** Identifies whether the component should be excluded from overall X and Y domain calculations or not.\n   * This property can be useful when you want pass individual data to a component and you don't want it to affect\n   * the scales of the chart.\n   * Default: `false` */\n  @Input() excludeFromDomainCalculation?: boolean\n\n  /** Curve type from the CurveType enum. Default: `CurveType.MonotoneX` */\n  @Input() curveType?: CurveType | string\n\n  /** Baseline value or accessor function. Default: `undefined` */\n  @Input() baseline?: NumericAccessor<Datum>\n\n  /** Opacity value or accessor function. Default: `1` */\n  @Input() opacity?: NumericAccessor<Datum[]>\n\n  /** Optional area cursor. String or accessor function. Default: `null` */\n  @Input() cursor?: StringAccessor<Datum[]>\n\n  /** If an area is smaller than 1px, extend it to have 1px height.\n   * This setting is useful when some of the area values are zeros or very small so visually they become\n   * practically invisible, but you want to show that the data behind them exists and they're not just empty segments.\n   * Default: `false` */\n  @Input() minHeight1Px?: boolean\n  @Input() data: Datum[]\n\n  component: Area<Datum> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new Area<Datum>(this.getConfig())\n\n    if (this.data) {\n      this.component.setData(this.data)\n      this.componentContainer?.render()\n    }\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    if (changes.data) { this.component?.setData(this.data) }\n    this.component?.setConfig(this.getConfig())\n    this.componentContainer?.render()\n  }\n\n  private getConfig (): AreaConfigInterface<Datum> {\n    const { duration, events, attributes, x, y, id, color, xScale, yScale, excludeFromDomainCalculation, curveType, baseline, opacity, cursor, minHeight1Px } = this\n    const config = { duration, events, attributes, x, y, id, color, xScale, yScale, excludeFromDomainCalculation, curveType, baseline, opacity, cursor, minHeight1Px }\n    const keys = Object.keys(config) as (keyof AreaConfigInterface<Datum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
@@ -3,6 +3,7 @@ import { Component, ViewChild, Input, ContentChild } from '@angular/core';
3
3
  import { SingleContainer } from '@unovis/ts';
4
4
  import { VisCoreComponent } from '../../core';
5
5
  import { VisTooltipComponent } from '../../components/tooltip/tooltip.component';
6
+ import { VisAnnotationsComponent } from '../../components/annotations/annotations.component';
6
7
  import * as i0 from "@angular/core";
7
8
  export class VisSingleContainerComponent {
8
9
  constructor() {
@@ -25,18 +26,19 @@ export class VisSingleContainerComponent {
25
26
  (_b = this.chart) === null || _b === void 0 ? void 0 : _b.updateContainer(this.getConfig());
26
27
  }
27
28
  getConfig() {
28
- var _a, _b;
29
+ var _a, _b, _c;
29
30
  const { width, height, duration, margin, ariaLabel } = this;
30
31
  const component = (_a = this.visComponent) === null || _a === void 0 ? void 0 : _a.component;
31
32
  const tooltip = (_b = this.tooltipComponent) === null || _b === void 0 ? void 0 : _b.component;
32
- return { width, height, duration, margin, component, tooltip, ariaLabel };
33
+ const annotations = (_c = this.annotationsComponent) === null || _c === void 0 ? void 0 : _c.component;
34
+ return { width, height, duration, margin, component, tooltip, ariaLabel, annotations };
33
35
  }
34
36
  ngOnDestroy() {
35
37
  this.chart.destroy();
36
38
  }
37
39
  }
38
40
  VisSingleContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisSingleContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
39
- VisSingleContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisSingleContainerComponent, selector: "vis-single-container", inputs: { width: "width", height: "height", margin: "margin", duration: "duration", ariaLabel: "ariaLabel", data: "data" }, queries: [{ propertyName: "visComponent", first: true, predicate: VisCoreComponent, descendants: true }, { propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-single-container">
41
+ VisSingleContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisSingleContainerComponent, selector: "vis-single-container", inputs: { width: "width", height: "height", margin: "margin", duration: "duration", ariaLabel: "ariaLabel", data: "data" }, queries: [{ propertyName: "visComponent", first: true, predicate: VisCoreComponent, descendants: true }, { propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }, { propertyName: "annotationsComponent", first: true, predicate: VisAnnotationsComponent, descendants: true }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-single-container">
40
42
  <ng-content></ng-content>
41
43
  </div>`, isInline: true, styles: [".unovis-single-container { width: 100%; height: 100%; position: relative; }"] });
42
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisSingleContainerComponent, decorators: [{
@@ -57,6 +59,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
57
59
  }], tooltipComponent: [{
58
60
  type: ContentChild,
59
61
  args: [VisTooltipComponent]
62
+ }], annotationsComponent: [{
63
+ type: ContentChild,
64
+ args: [VisAnnotationsComponent]
60
65
  }], width: [{
61
66
  type: Input
62
67
  }], height: [{
@@ -70,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
70
75
  }], data: [{
71
76
  type: Input
72
77
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xlLWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29udGFpbmVycy9zaW5nbGUtY29udGFpbmVyL3NpbmdsZS1jb250YWluZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUE2QixLQUFLLEVBQTRCLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUU5SCxNQUFNO0FBQ04sT0FBTyxFQUFpQixlQUFlLEVBQW9ELE1BQU0sWUFBWSxDQUFBO0FBQzdHLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQTs7QUFTaEYsTUFBTSxPQUFPLDJCQUEyQjtJQVB4QztRQWlCRSxtRUFBbUU7UUFDMUQsV0FBTSxHQUFhLEVBQUUsR0FBRyxFQUFFLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxDQUFBO0tBeUNyRTtJQTdCQyxlQUFlO1FBQ2IsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLGVBQWUsQ0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3BHLHVGQUF1RjtRQUN2RixJQUFJLENBQUMsWUFBWSxDQUFDLGtCQUFrQixHQUFHLElBQUksQ0FBQyxLQUFLLENBQUE7SUFDbkQsQ0FBQztJQUVELFdBQVcsQ0FBRSxPQUFzQjs7UUFDakMsaUNBQWlDO1FBQ2pDLElBQUksT0FBTyxDQUFDLElBQUksRUFBRTtZQUNoQixNQUFBLElBQUksQ0FBQyxLQUFLLDBDQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFBO1lBQ3BDLE9BQU8sT0FBTyxDQUFDLElBQUksQ0FBQTtTQUNwQjtRQUVELDhCQUE4QjtRQUM5QixNQUFBLElBQUksQ0FBQyxLQUFLLDBDQUFFLGVBQWUsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQTtJQUMvQyxDQUFDO0lBRUQsU0FBUzs7UUFDUCxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxHQUFHLElBQUksQ0FBQTtRQUUzRCxNQUFNLFNBQVMsR0FBRyxNQUFBLElBQUksQ0FBQyxZQUFZLDBDQUFFLFNBQWMsQ0FBQTtRQUNuRCxNQUFNLE9BQU8sR0FBRyxNQUFBLElBQUksQ0FBQyxnQkFBZ0IsMENBQUUsU0FBb0IsQ0FBQTtRQUUzRCxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLENBQUE7SUFDM0UsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFBO0lBQ3RCLENBQUM7O3lIQW5EVSwyQkFBMkI7NkdBQTNCLDJCQUEyQixrT0FFeEIsZ0JBQWdCLG1GQUNoQixtQkFBbUIsZ0xBUnZCOztTQUVIOzRGQUdJLDJCQUEyQjtrQkFQdkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxRQUFRLEVBQUU7O1NBRUg7b0JBQ1AsTUFBTSxFQUFFLENBQUMsNkVBQTZFLENBQUM7aUJBQ3hGOzhCQUU0QyxZQUFZO3NCQUF0RCxTQUFTO3VCQUFDLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUU7Z0JBQ1QsWUFBWTtzQkFBM0MsWUFBWTt1QkFBQyxnQkFBZ0I7Z0JBQ0ssZ0JBQWdCO3NCQUFsRCxZQUFZO3VCQUFDLG1CQUFtQjtnQkFHeEIsS0FBSztzQkFBYixLQUFLO2dCQUVHLE1BQU07c0JBQWQsS0FBSztnQkFHRyxNQUFNO3NCQUFkLEtBQUs7Z0JBRUcsUUFBUTtzQkFBaEIsS0FBSztnQkFJRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgVmlld0NoaWxkLCBFbGVtZW50UmVmLCBBZnRlclZpZXdJbml0LCBJbnB1dCwgT25EZXN0cm95LCBTaW1wbGVDaGFuZ2VzLCBDb250ZW50Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG4vLyBWaXNcbmltcG9ydCB7IENvbXBvbmVudENvcmUsIFNpbmdsZUNvbnRhaW5lciwgU2luZ2xlQ29udGFpbmVyQ29uZmlnSW50ZXJmYWNlLCBUb29sdGlwLCBTcGFjaW5nIH0gZnJvbSAnQHVub3Zpcy90cydcbmltcG9ydCB7IFZpc0NvcmVDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb3JlJ1xuaW1wb3J0IHsgVmlzVG9vbHRpcENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvdG9vbHRpcC90b29sdGlwLmNvbXBvbmVudCdcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmlzLXNpbmdsZS1jb250YWluZXInLFxuICB0ZW1wbGF0ZTogYDxkaXYgI2NvbnRhaW5lciBjbGFzcz1cInVub3Zpcy1zaW5nbGUtY29udGFpbmVyXCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5gLFxuICBzdHlsZXM6IFsnLnVub3Zpcy1zaW5nbGUtY29udGFpbmVyIHsgd2lkdGg6IDEwMCU7IGhlaWdodDogMTAwJTsgcG9zaXRpb246IHJlbGF0aXZlOyB9J10sXG59KVxuZXhwb3J0IGNsYXNzIFZpc1NpbmdsZUNvbnRhaW5lckNvbXBvbmVudDxEYXRhID0gdW5rbm93biwgQyBleHRlbmRzIENvbXBvbmVudENvcmU8RGF0YT4gPSBDb21wb25lbnRDb3JlPERhdGE+PiBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XG4gIEBWaWV3Q2hpbGQoJ2NvbnRhaW5lcicsIHsgc3RhdGljOiBmYWxzZSB9KSBjb250YWluZXJSZWY6IEVsZW1lbnRSZWZcbiAgQENvbnRlbnRDaGlsZChWaXNDb3JlQ29tcG9uZW50KSB2aXNDb21wb25lbnQ6IFZpc0NvcmVDb21wb25lbnRcbiAgQENvbnRlbnRDaGlsZChWaXNUb29sdGlwQ29tcG9uZW50KSB0b29sdGlwQ29tcG9uZW50OiBWaXNUb29sdGlwQ29tcG9uZW50XG5cbiAgLyoqIFdpZHRoIGluIHBpeGVscy4gQnkgZGVmYXVsdCwgQ29udGFpbmVyIGF1dG9tYXRpY2FsbHkgZml0cyB0byB0aGUgc2l6ZSBvZiB0aGUgcGFyZW50IGVsZW1lbnQuIERlZmF1bHQ6IGB1bmRlZmluZWRgLiAqL1xuICBASW5wdXQoKSB3aWR0aD86IG51bWJlclxuICAvKiogSGVpZ2h0IGluIHBpeGVscy4gQnkgZGVmYXVsdCwgQ29udGFpbmVyIGF1dG9tYXRpY2FsbHkgZml0cyB0byB0aGUgc2l6ZSBvZiB0aGUgcGFyZW50IGVsZW1lbnQuIERlZmF1bHQ6IGB1bmRlZmluZWRgLiAqL1xuICBASW5wdXQoKSBoZWlnaHQ/OiBudW1iZXJcblxuICAvKiogTWFyZ2lucy4gRGVmYXVsdDogYHsgdG9wOiAwLCBib3R0b206IDAsIGxlZnQ6IDAsIHJpZ2h0OiAwIH1gICovXG4gIEBJbnB1dCgpIG1hcmdpbj86IFNwYWNpbmcgPSB7IHRvcDogMCwgYm90dG9tOiAwLCBsZWZ0OiAwLCByaWdodDogMCB9XG4gIC8qKiBBbmltYXRpb24gZHVyYXRpb24gb2YgYWxsIHRoZSBjb21wb25lbnRzIHdpdGhpbiB0aGUgY29udGFpbmVyLiBEZWZhdWx0OiBgdW5kZWZpbmVkYCAqL1xuICBASW5wdXQoKSBkdXJhdGlvbj86IG51bWJlclxuICAvKiogQWx0ZXJuYXRpdmUgdGV4dCBkZXNjcmlwdGlvbiBvZiB0aGUgY2hhcnQgZm9yIGFjY2Vzc2liaWxpdHkgcHVycG9zZXMuIEl0IHdpbGwgYmUgYXBwbGllZCBhcyBhblxuICAgKiBgYXJpYS1sYWJlbGAgYXR0cmlidXRlIHRvIHRoZSBkaXYgZWxlbWVudCBjb250YWluaW5nIHlvdXIgY2hhcnQuIERlZmF1bHQ6IGB1bmRlZmluZWRgLlxuICAqL1xuICBASW5wdXQoKSBhcmlhTGFiZWw/OiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkXG4gIC8qKiBEYXRhIHRvIGJlIHBhc3NlZCB0byB0aGUgY29tcG9uZW50LiBEZWZhdWx0OiBgdW5kZWZpbmVkYC4gKi9cbiAgQElucHV0KCkgZGF0YT86IERhdGFcblxuICBjaGFydDogU2luZ2xlQ29udGFpbmVyPERhdGE+XG5cbiAgbmdBZnRlclZpZXdJbml0ICgpOiB2b2lkIHtcbiAgICB0aGlzLmNoYXJ0ID0gbmV3IFNpbmdsZUNvbnRhaW5lcjxEYXRhPih0aGlzLmNvbnRhaW5lclJlZi5uYXRpdmVFbGVtZW50LCB0aGlzLmdldENvbmZpZygpLCB0aGlzLmRhdGEpXG4gICAgLy8gV2UgcGFzcyB0aGUgY29udGFpbmVyIGZvciB0aGUgY29tcG9uZW50IHRvIHRyaWdnZXIgcmUtcmVuZGVyIGlmIHRoZSBkYXRhIGhhcyBjaGFuZ2VkXG4gICAgdGhpcy52aXNDb21wb25lbnQuY29tcG9uZW50Q29udGFpbmVyID0gdGhpcy5jaGFydFxuICB9XG5cbiAgbmdPbkNoYW5nZXMgKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICAvLyBTZXQgbmV3IERhdGEgd2l0aG91dCByZS1yZW5kZXJcbiAgICBpZiAoY2hhbmdlcy5kYXRhKSB7XG4gICAgICB0aGlzLmNoYXJ0Py5zZXREYXRhKHRoaXMuZGF0YSwgdHJ1ZSlcbiAgICAgIGRlbGV0ZSBjaGFuZ2VzLmRhdGFcbiAgICB9XG5cbiAgICAvLyBVcGRhdGUgQ29udGFpbmVyIGFuZCByZW5kZXJcbiAgICB0aGlzLmNoYXJ0Py51cGRhdGVDb250YWluZXIodGhpcy5nZXRDb25maWcoKSlcbiAgfVxuXG4gIGdldENvbmZpZyAoKTogU2luZ2xlQ29udGFpbmVyQ29uZmlnSW50ZXJmYWNlPERhdGE+IHtcbiAgICBjb25zdCB7IHdpZHRoLCBoZWlnaHQsIGR1cmF0aW9uLCBtYXJnaW4sIGFyaWFMYWJlbCB9ID0gdGhpc1xuXG4gICAgY29uc3QgY29tcG9uZW50ID0gdGhpcy52aXNDb21wb25lbnQ/LmNvbXBvbmVudCBhcyBDXG4gICAgY29uc3QgdG9vbHRpcCA9IHRoaXMudG9vbHRpcENvbXBvbmVudD8uY29tcG9uZW50IGFzIFRvb2x0aXBcblxuICAgIHJldHVybiB7IHdpZHRoLCBoZWlnaHQsIGR1cmF0aW9uLCBtYXJnaW4sIGNvbXBvbmVudCwgdG9vbHRpcCwgYXJpYUxhYmVsIH1cbiAgfVxuXG4gIG5nT25EZXN0cm95ICgpOiB2b2lkIHtcbiAgICB0aGlzLmNoYXJ0LmRlc3Ryb3koKVxuICB9XG59XG4iXX0=
78
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xlLWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29udGFpbmVycy9zaW5nbGUtY29udGFpbmVyL3NpbmdsZS1jb250YWluZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUE2QixLQUFLLEVBQTRCLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUU5SCxNQUFNO0FBQ04sT0FBTyxFQUFpQixlQUFlLEVBQWlFLE1BQU0sWUFBWSxDQUFBO0FBQzFILE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQTtBQUNoRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxvREFBb0QsQ0FBQTs7QUFTNUYsTUFBTSxPQUFPLDJCQUEyQjtJQVB4QztRQWtCRSxtRUFBbUU7UUFDMUQsV0FBTSxHQUFhLEVBQUUsR0FBRyxFQUFFLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxDQUFBO0tBMENyRTtJQTlCQyxlQUFlO1FBQ2IsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLGVBQWUsQ0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3BHLHVGQUF1RjtRQUN2RixJQUFJLENBQUMsWUFBWSxDQUFDLGtCQUFrQixHQUFHLElBQUksQ0FBQyxLQUFLLENBQUE7SUFDbkQsQ0FBQztJQUVELFdBQVcsQ0FBRSxPQUFzQjs7UUFDakMsaUNBQWlDO1FBQ2pDLElBQUksT0FBTyxDQUFDLElBQUksRUFBRTtZQUNoQixNQUFBLElBQUksQ0FBQyxLQUFLLDBDQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFBO1lBQ3BDLE9BQU8sT0FBTyxDQUFDLElBQUksQ0FBQTtTQUNwQjtRQUVELDhCQUE4QjtRQUM5QixNQUFBLElBQUksQ0FBQyxLQUFLLDBDQUFFLGVBQWUsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQTtJQUMvQyxDQUFDO0lBRUQsU0FBUzs7UUFDUCxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxHQUFHLElBQUksQ0FBQTtRQUUzRCxNQUFNLFNBQVMsR0FBRyxNQUFBLElBQUksQ0FBQyxZQUFZLDBDQUFFLFNBQWMsQ0FBQTtRQUNuRCxNQUFNLE9BQU8sR0FBRyxNQUFBLElBQUksQ0FBQyxnQkFBZ0IsMENBQUUsU0FBb0IsQ0FBQTtRQUMzRCxNQUFNLFdBQVcsR0FBRyxNQUFBLElBQUksQ0FBQyxvQkFBb0IsMENBQUUsU0FBd0IsQ0FBQTtRQUV2RSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxDQUFBO0lBQ3hGLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQTtJQUN0QixDQUFDOzt5SEFyRFUsMkJBQTJCOzZHQUEzQiwyQkFBMkIsa09BRXhCLGdCQUFnQixtRkFDaEIsbUJBQW1CLHVGQUNuQix1QkFBdUIsZ0xBVDNCOztTQUVIOzRGQUdJLDJCQUEyQjtrQkFQdkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxRQUFRLEVBQUU7O1NBRUg7b0JBQ1AsTUFBTSxFQUFFLENBQUMsNkVBQTZFLENBQUM7aUJBQ3hGOzhCQUU0QyxZQUFZO3NCQUF0RCxTQUFTO3VCQUFDLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUU7Z0JBQ1QsWUFBWTtzQkFBM0MsWUFBWTt1QkFBQyxnQkFBZ0I7Z0JBQ0ssZ0JBQWdCO3NCQUFsRCxZQUFZO3VCQUFDLG1CQUFtQjtnQkFDTSxvQkFBb0I7c0JBQTFELFlBQVk7dUJBQUMsdUJBQXVCO2dCQUc1QixLQUFLO3NCQUFiLEtBQUs7Z0JBRUcsTUFBTTtzQkFBZCxLQUFLO2dCQUdHLE1BQU07c0JBQWQsS0FBSztnQkFFRyxRQUFRO3NCQUFoQixLQUFLO2dCQUlHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRUcsSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBWaWV3Q2hpbGQsIEVsZW1lbnRSZWYsIEFmdGVyVmlld0luaXQsIElucHV0LCBPbkRlc3Ryb3ksIFNpbXBsZUNoYW5nZXMsIENvbnRlbnRDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbi8vIFZpc1xuaW1wb3J0IHsgQ29tcG9uZW50Q29yZSwgU2luZ2xlQ29udGFpbmVyLCBTaW5nbGVDb250YWluZXJDb25maWdJbnRlcmZhY2UsIFRvb2x0aXAsIFNwYWNpbmcsIEFubm90YXRpb25zIH0gZnJvbSAnQHVub3Zpcy90cydcbmltcG9ydCB7IFZpc0NvcmVDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb3JlJ1xuaW1wb3J0IHsgVmlzVG9vbHRpcENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvdG9vbHRpcC90b29sdGlwLmNvbXBvbmVudCdcbmltcG9ydCB7IFZpc0Fubm90YXRpb25zQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9hbm5vdGF0aW9ucy9hbm5vdGF0aW9ucy5jb21wb25lbnQnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3Zpcy1zaW5nbGUtY29udGFpbmVyJyxcbiAgdGVtcGxhdGU6IGA8ZGl2ICNjb250YWluZXIgY2xhc3M9XCJ1bm92aXMtc2luZ2xlLWNvbnRhaW5lclwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+YCxcbiAgc3R5bGVzOiBbJy51bm92aXMtc2luZ2xlLWNvbnRhaW5lciB7IHdpZHRoOiAxMDAlOyBoZWlnaHQ6IDEwMCU7IHBvc2l0aW9uOiByZWxhdGl2ZTsgfSddLFxufSlcbmV4cG9ydCBjbGFzcyBWaXNTaW5nbGVDb250YWluZXJDb21wb25lbnQ8RGF0YSA9IHVua25vd24sIEMgZXh0ZW5kcyBDb21wb25lbnRDb3JlPERhdGE+ID0gQ29tcG9uZW50Q29yZTxEYXRhPj4gaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xuICBAVmlld0NoaWxkKCdjb250YWluZXInLCB7IHN0YXRpYzogZmFsc2UgfSkgY29udGFpbmVyUmVmOiBFbGVtZW50UmVmXG4gIEBDb250ZW50Q2hpbGQoVmlzQ29yZUNvbXBvbmVudCkgdmlzQ29tcG9uZW50OiBWaXNDb3JlQ29tcG9uZW50XG4gIEBDb250ZW50Q2hpbGQoVmlzVG9vbHRpcENvbXBvbmVudCkgdG9vbHRpcENvbXBvbmVudDogVmlzVG9vbHRpcENvbXBvbmVudFxuICBAQ29udGVudENoaWxkKFZpc0Fubm90YXRpb25zQ29tcG9uZW50KSBhbm5vdGF0aW9uc0NvbXBvbmVudDogVmlzQW5ub3RhdGlvbnNDb21wb25lbnRcblxuICAvKiogV2lkdGggaW4gcGl4ZWxzLiBCeSBkZWZhdWx0LCBDb250YWluZXIgYXV0b21hdGljYWxseSBmaXRzIHRvIHRoZSBzaXplIG9mIHRoZSBwYXJlbnQgZWxlbWVudC4gRGVmYXVsdDogYHVuZGVmaW5lZGAuICovXG4gIEBJbnB1dCgpIHdpZHRoPzogbnVtYmVyXG4gIC8qKiBIZWlnaHQgaW4gcGl4ZWxzLiBCeSBkZWZhdWx0LCBDb250YWluZXIgYXV0b21hdGljYWxseSBmaXRzIHRvIHRoZSBzaXplIG9mIHRoZSBwYXJlbnQgZWxlbWVudC4gRGVmYXVsdDogYHVuZGVmaW5lZGAuICovXG4gIEBJbnB1dCgpIGhlaWdodD86IG51bWJlclxuXG4gIC8qKiBNYXJnaW5zLiBEZWZhdWx0OiBgeyB0b3A6IDAsIGJvdHRvbTogMCwgbGVmdDogMCwgcmlnaHQ6IDAgfWAgKi9cbiAgQElucHV0KCkgbWFyZ2luPzogU3BhY2luZyA9IHsgdG9wOiAwLCBib3R0b206IDAsIGxlZnQ6IDAsIHJpZ2h0OiAwIH1cbiAgLyoqIEFuaW1hdGlvbiBkdXJhdGlvbiBvZiBhbGwgdGhlIGNvbXBvbmVudHMgd2l0aGluIHRoZSBjb250YWluZXIuIERlZmF1bHQ6IGB1bmRlZmluZWRgICovXG4gIEBJbnB1dCgpIGR1cmF0aW9uPzogbnVtYmVyXG4gIC8qKiBBbHRlcm5hdGl2ZSB0ZXh0IGRlc2NyaXB0aW9uIG9mIHRoZSBjaGFydCBmb3IgYWNjZXNzaWJpbGl0eSBwdXJwb3Nlcy4gSXQgd2lsbCBiZSBhcHBsaWVkIGFzIGFuXG4gICAqIGBhcmlhLWxhYmVsYCBhdHRyaWJ1dGUgdG8gdGhlIGRpdiBlbGVtZW50IGNvbnRhaW5pbmcgeW91ciBjaGFydC4gRGVmYXVsdDogYHVuZGVmaW5lZGAuXG4gICovXG4gIEBJbnB1dCgpIGFyaWFMYWJlbD86IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWRcbiAgLyoqIERhdGEgdG8gYmUgcGFzc2VkIHRvIHRoZSBjb21wb25lbnQuIERlZmF1bHQ6IGB1bmRlZmluZWRgLiAqL1xuICBASW5wdXQoKSBkYXRhPzogRGF0YVxuXG4gIGNoYXJ0OiBTaW5nbGVDb250YWluZXI8RGF0YT5cblxuICBuZ0FmdGVyVmlld0luaXQgKCk6IHZvaWQge1xuICAgIHRoaXMuY2hhcnQgPSBuZXcgU2luZ2xlQ29udGFpbmVyPERhdGE+KHRoaXMuY29udGFpbmVyUmVmLm5hdGl2ZUVsZW1lbnQsIHRoaXMuZ2V0Q29uZmlnKCksIHRoaXMuZGF0YSlcbiAgICAvLyBXZSBwYXNzIHRoZSBjb250YWluZXIgZm9yIHRoZSBjb21wb25lbnQgdG8gdHJpZ2dlciByZS1yZW5kZXIgaWYgdGhlIGRhdGEgaGFzIGNoYW5nZWRcbiAgICB0aGlzLnZpc0NvbXBvbmVudC5jb21wb25lbnRDb250YWluZXIgPSB0aGlzLmNoYXJ0XG4gIH1cblxuICBuZ09uQ2hhbmdlcyAoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIC8vIFNldCBuZXcgRGF0YSB3aXRob3V0IHJlLXJlbmRlclxuICAgIGlmIChjaGFuZ2VzLmRhdGEpIHtcbiAgICAgIHRoaXMuY2hhcnQ/LnNldERhdGEodGhpcy5kYXRhLCB0cnVlKVxuICAgICAgZGVsZXRlIGNoYW5nZXMuZGF0YVxuICAgIH1cblxuICAgIC8vIFVwZGF0ZSBDb250YWluZXIgYW5kIHJlbmRlclxuICAgIHRoaXMuY2hhcnQ/LnVwZGF0ZUNvbnRhaW5lcih0aGlzLmdldENvbmZpZygpKVxuICB9XG5cbiAgZ2V0Q29uZmlnICgpOiBTaW5nbGVDb250YWluZXJDb25maWdJbnRlcmZhY2U8RGF0YT4ge1xuICAgIGNvbnN0IHsgd2lkdGgsIGhlaWdodCwgZHVyYXRpb24sIG1hcmdpbiwgYXJpYUxhYmVsIH0gPSB0aGlzXG5cbiAgICBjb25zdCBjb21wb25lbnQgPSB0aGlzLnZpc0NvbXBvbmVudD8uY29tcG9uZW50IGFzIENcbiAgICBjb25zdCB0b29sdGlwID0gdGhpcy50b29sdGlwQ29tcG9uZW50Py5jb21wb25lbnQgYXMgVG9vbHRpcFxuICAgIGNvbnN0IGFubm90YXRpb25zID0gdGhpcy5hbm5vdGF0aW9uc0NvbXBvbmVudD8uY29tcG9uZW50IGFzIEFubm90YXRpb25zXG5cbiAgICByZXR1cm4geyB3aWR0aCwgaGVpZ2h0LCBkdXJhdGlvbiwgbWFyZ2luLCBjb21wb25lbnQsIHRvb2x0aXAsIGFyaWFMYWJlbCwgYW5ub3RhdGlvbnMgfVxuICB9XG5cbiAgbmdPbkRlc3Ryb3kgKCk6IHZvaWQge1xuICAgIHRoaXMuY2hhcnQuZGVzdHJveSgpXG4gIH1cbn1cbiJdfQ==
@@ -3,6 +3,7 @@ import { Component, ContentChild, ContentChildren, Input, ViewChild, } from '@an
3
3
  import { Axis, Crosshair, Direction, Tooltip, XYContainer } from '@unovis/ts';
4
4
  import { VisXYComponent } from '../../core';
5
5
  import { VisTooltipComponent } from '../../components/tooltip/tooltip.component';
6
+ import { VisAnnotationsComponent } from '../../components/annotations/annotations.component';
6
7
  import * as i0 from "@angular/core";
7
8
  export class VisXYContainerComponent {
8
9
  constructor() {
@@ -58,13 +59,14 @@ export class VisXYContainerComponent {
58
59
  (_b = this.chart) === null || _b === void 0 ? void 0 : _b.updateContainer(this.getConfig());
59
60
  }
60
61
  getConfig() {
61
- var _a;
62
+ var _a, _b;
62
63
  const { duration, margin, padding, scaleByDomain, autoMargin, width, height, xScale, xDomain, xDomainMinConstraint, xDomainMaxConstraint, xRange, yScale, yDomain, yDomainMinConstraint, yDomainMaxConstraint, yRange, yDirection, ariaLabel, } = this;
63
64
  const visComponents = this.visComponents.toArray().map(d => d.component);
64
65
  const crosshair = visComponents.find(c => c instanceof Crosshair);
65
66
  const tooltip = (_a = this.tooltipComponent) === null || _a === void 0 ? void 0 : _a.component;
66
67
  const xAxis = visComponents.find(c => { var _a; return c instanceof Axis && ((_a = c === null || c === void 0 ? void 0 : c.config) === null || _a === void 0 ? void 0 : _a.type) === 'x'; });
67
68
  const yAxis = visComponents.find(c => { var _a; return c instanceof Axis && ((_a = c === null || c === void 0 ? void 0 : c.config) === null || _a === void 0 ? void 0 : _a.type) === 'y'; });
69
+ const annotations = (_b = this.annotationsComponent) === null || _b === void 0 ? void 0 : _b.component;
68
70
  const components = visComponents.filter(c => !(c instanceof Crosshair) && !(c instanceof Tooltip) && !(c instanceof Axis));
69
71
  return {
70
72
  components,
@@ -77,6 +79,7 @@ export class VisXYContainerComponent {
77
79
  yAxis,
78
80
  tooltip,
79
81
  crosshair,
82
+ annotations,
80
83
  scaleByDomain,
81
84
  autoMargin,
82
85
  xScale,
@@ -104,7 +107,7 @@ export class VisXYContainerComponent {
104
107
  }
105
108
  }
106
109
  VisXYContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisXYContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
107
- VisXYContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisXYContainerComponent, selector: "vis-xy-container", inputs: { width: "width", height: "height", xScale: "xScale", xDomain: "xDomain", xDomainMinConstraint: "xDomainMinConstraint", xDomainMaxConstraint: "xDomainMaxConstraint", xRange: "xRange", yScale: "yScale", yDomain: "yDomain", yDomainMinConstraint: "yDomainMinConstraint", yDomainMaxConstraint: "yDomainMaxConstraint", yRange: "yRange", yDirection: "yDirection", preventEmptyDomain: "preventEmptyDomain", duration: "duration", margin: "margin", padding: "padding", scaleByDomain: "scaleByDomain", autoMargin: "autoMargin", ariaLabel: "ariaLabel", data: "data" }, queries: [{ propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }, { propertyName: "visComponents", predicate: VisXYComponent }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-xy-container">
110
+ VisXYContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisXYContainerComponent, selector: "vis-xy-container", inputs: { width: "width", height: "height", xScale: "xScale", xDomain: "xDomain", xDomainMinConstraint: "xDomainMinConstraint", xDomainMaxConstraint: "xDomainMaxConstraint", xRange: "xRange", yScale: "yScale", yDomain: "yDomain", yDomainMinConstraint: "yDomainMinConstraint", yDomainMaxConstraint: "yDomainMaxConstraint", yRange: "yRange", yDirection: "yDirection", preventEmptyDomain: "preventEmptyDomain", duration: "duration", margin: "margin", padding: "padding", scaleByDomain: "scaleByDomain", autoMargin: "autoMargin", ariaLabel: "ariaLabel", data: "data" }, queries: [{ propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }, { propertyName: "annotationsComponent", first: true, predicate: VisAnnotationsComponent, descendants: true }, { propertyName: "visComponents", predicate: VisXYComponent }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-xy-container">
108
111
  <ng-content></ng-content>
109
112
  </div>`, isInline: true, styles: [".unovis-xy-container { width: 100%; height: 100%; position: relative; }"] });
110
113
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisXYContainerComponent, decorators: [{
@@ -125,6 +128,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
125
128
  }], tooltipComponent: [{
126
129
  type: ContentChild,
127
130
  args: [VisTooltipComponent]
131
+ }], annotationsComponent: [{
132
+ type: ContentChild,
133
+ args: [VisAnnotationsComponent]
128
134
  }], width: [{
129
135
  type: Input
130
136
  }], height: [{
@@ -168,4 +174,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
168
174
  }], data: [{
169
175
  type: Input
170
176
  }] } });
171
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xy-container.component.js","sourceRoot":"","sources":["../../../../../src/containers/xy-container/xy-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core'\n\n// Vis\nimport { Axis, ContinuousScale, Crosshair, Direction, Spacing, Tooltip, XYContainer, XYContainerConfigInterface } from '@unovis/ts'\nimport { VisXYComponent } from '../../core'\nimport { VisTooltipComponent } from '../../components/tooltip/tooltip.component'\n\n@Component({\n  selector: 'vis-xy-container',\n  template: `<div #container class=\"unovis-xy-container\">\n    <ng-content></ng-content>\n  </div>`,\n  styles: ['.unovis-xy-container { width: 100%; height: 100%; position: relative; }'],\n})\nexport class VisXYContainerComponent<Datum> implements AfterViewInit, AfterContentInit, OnDestroy {\n  @ViewChild('container', { static: false }) containerRef: ElementRef\n  @ContentChildren(VisXYComponent) visComponents: QueryList<VisXYComponent>\n  @ContentChild(VisTooltipComponent) tooltipComponent: VisTooltipComponent\n\n  /** Width in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */\n  @Input() width?: number\n  /** Height in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */\n  @Input() height?: number\n\n  /** Scale for X dimension, e.g. Scale.scaleLinear(). Default: `Scale.scaleLinear()` */\n  @Input() xScale?: ContinuousScale\n  /** Scale domain (data extent) for X dimension. By default this value is calculated automatically based on data. */\n  @Input() xDomain?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the X scale domain. Useful when the data is plotted along the X axis.\n   * For example, imagine that you have a chart with dynamic data that has negative values. When values are small\n   * (let's say in the range of [-0.01, 0]), you might still want the chart to display some meaningful value range (e.g. [-1, 0]). That can\n   * be achieved by setting `xDomainMinConstraint` to `[undefined, -1]`. In addition to that, if you want to cut off the\n   * values that are too low (let's say lower than -100), you can set the constraint to `[-100, -1]`\n   * Default: `undefined` */\n  @Input() xDomainMinConstraint?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the X scale domain. Useful when the data is plotted along the X axis.\n   * For example, imagine that you have a chart with dynamic data. When values are small\n   * (let's say < 0.01), you might still want the chart to display some meaningful value range (e.g. [0, 1]). That can\n   * be achieved by setting `xDomainMaxConstraint` to `[1, undefined]`. In addition to that, if you want to cut off the\n   * values that are too high (let's say higher than 100), you can set the constraint to `[1, 100]`\n   * Default: `undefined` */\n  @Input() xDomainMaxConstraint?: [number | undefined, number | undefined]\n  /** Force set the X scale range (in the screen space). By default the range is calculated automatically based on the\n   * chart's set up */\n  @Input() xRange?: [number, number]\n\n  /** Scale for Y dimension, e.g. Scale.ScaleLinear. Default: `Scale.ScaleLinear()` */\n  @Input() yScale?: ContinuousScale\n  /** Scale domain (data extent) for Y dimension. By default this value is calculated automatically based on data. */\n  @Input() yDomain?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the Y scale domain.\n   * For example, imagine that you have a chart with dynamic data that has negative values. When values are small\n   * (let's say in the range of [-0.01, 0]), you might still want the chart to display some meaningful value range (e.g. [-1, 0]). That can\n   * be achieved by setting `yDomainMinConstraint` to `[undefined, -1]`. In addition to that, if you want to cut off the\n   * values that are too low (let's say lower than -100), you can set the constraint to `[-100, -1]`\n   * Default: `undefined` */\n  @Input() yDomainMinConstraint?: [number | undefined, number | undefined] = undefined\n  /** Constraint the minimum value of the Y scale domain.\n   * For example, imagine that you have a chart with dynamic data. When values are small\n   * (let's say < 0.01), you might still want the chart to display some meaningful value range (e.g. [0, 1]). That can\n   * be achieved by setting `yDomainMaxConstraint` to `[1, undefined]`. In addition to that, if you want to cut off the\n   * values that are too high (let's say higher than 100), you can set the constraint to `[1, 100]`\n   * Default: `undefined` */\n  @Input() yDomainMaxConstraint?: [number | undefined, number | undefined]\n  /** Force set the Y scale range (in the screen space). By default the range is calculated automatically based on the\n   * chart's set up */\n  @Input() yRange?: [number, number]\n  /** Y Axis direction. Default: `Direction.North` */\n  @Input() yDirection?: Direction.South | Direction.North | string = Direction.North\n  /** Prevents the chart domain from being empty (when domain's min and max values are equal).\n   *  That usually happens when all the data values are the same or when there's no data.\n   *  Setting to `true` will automatically extend the domain by `+1` when needed.\n   *  Setting to `null` will extend the domain only when there's no data.\n   *  Setting to `false` will keep the domain as is.\n   *  Default: `null` */\n  @Input() preventEmptyDomain?: boolean | null = null\n\n  /** Animation duration of all the components within the container. Default: `undefined` */\n  @Input() duration?: number = undefined\n  /** Margins. Default: `{ top: 0, bottom: 0, left: 0, right: 0 }` */\n  @Input() margin?: Spacing = { top: 0, bottom: 0, left: 0, right: 0 }\n  /** Padding. Default: `{ top: 0, bottom: 0, left: 0, right: 0 }` */\n  @Input() padding?: Spacing = {}\n  /** Sets the Y scale domain based on the current X scale domain (not the whole dataset). Default: `false` */\n  @Input() scaleByDomain?: boolean\n  /** Enables automatic calculation of chart margins based on the size of the axes. Default: `true` */\n  @Input() autoMargin?: boolean = true\n\n  /** Alternative text description of the chart for accessibility purposes. It will be applied as an\n   * `aria-label` attribute to the div element containing your chart. Default: `undefined`.\n  */\n  @Input() ariaLabel?: string | null | undefined\n\n  /** Data to be passed to all child components. But if `data` is `undefined` it'll to be passed allowing components to\n   * have their individual data. Default: `undefined` */\n  @Input() data?: Datum[] | undefined = undefined\n\n  chart: XYContainer<Datum>\n\n  ngAfterViewInit (): void {\n    this.chart = new XYContainer<Datum>(this.containerRef.nativeElement, this.getConfig(), this.data)\n    this.passContainerReferenceToChildren()\n  }\n\n  ngAfterContentInit (): void {\n    // QueryList does unsubscribe automatically when it gets destroyed\n    this.visComponents.changes.subscribe(() => {\n      this.passContainerReferenceToChildren()\n      this.chart?.updateContainer(this.getConfig())\n    })\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    const preventRender = true\n\n    // Set new Data without re-render\n    if (changes.data) {\n      this.chart?.setData(this.data, preventRender)\n      delete changes.data\n    }\n\n    // Update Container and render\n    this.chart?.updateContainer(this.getConfig())\n  }\n\n  getConfig (): XYContainerConfigInterface<Datum> {\n    const {\n      duration, margin, padding, scaleByDomain, autoMargin, width, height,\n      xScale, xDomain, xDomainMinConstraint, xDomainMaxConstraint, xRange,\n      yScale, yDomain, yDomainMinConstraint, yDomainMaxConstraint, yRange,\n      yDirection, ariaLabel,\n    } = this\n    const visComponents = this.visComponents.toArray().map(d => d.component)\n\n    const crosshair = visComponents.find(c => c instanceof Crosshair) as Crosshair<Datum>\n    const tooltip = this.tooltipComponent?.component as Tooltip\n    const xAxis = visComponents.find(c => c instanceof Axis && c?.config?.type === 'x') as Axis<Datum>\n    const yAxis = visComponents.find(c => c instanceof Axis && c?.config?.type === 'y') as Axis<Datum>\n\n    const components = visComponents.filter(c => !(c instanceof Crosshair) && !(c instanceof Tooltip) && !(c instanceof Axis))\n\n    return {\n      components,\n      width,\n      height,\n      duration,\n      margin,\n      padding,\n      xAxis,\n      yAxis,\n      tooltip,\n      crosshair,\n      scaleByDomain,\n      autoMargin,\n      xScale,\n      xDomain,\n      xDomainMinConstraint,\n      xDomainMaxConstraint,\n      xRange,\n      yScale,\n      yDomain,\n      yDomainMinConstraint,\n      yDomainMaxConstraint,\n      yRange,\n      yDirection,\n      ariaLabel,\n    }\n  }\n\n  passContainerReferenceToChildren (): void {\n    // We set the container for each vis component to trigger chart re-render if the data has changed\n    if (this.chart) this.visComponents.toArray().forEach(c => { c.componentContainer = this.chart })\n  }\n\n  ngOnDestroy (): void {\n    this.chart?.destroy()\n  }\n}\n"]}
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xy-container.component.js","sourceRoot":"","sources":["../../../../../src/containers/xy-container/xy-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core'\n\n// Vis\nimport { Annotations, Axis, ContinuousScale, Crosshair, Direction, Spacing, Tooltip, XYContainer, XYContainerConfigInterface } from '@unovis/ts'\nimport { VisXYComponent } from '../../core'\nimport { VisTooltipComponent } from '../../components/tooltip/tooltip.component'\nimport { VisAnnotationsComponent } from '../../components/annotations/annotations.component'\n\n@Component({\n  selector: 'vis-xy-container',\n  template: `<div #container class=\"unovis-xy-container\">\n    <ng-content></ng-content>\n  </div>`,\n  styles: ['.unovis-xy-container { width: 100%; height: 100%; position: relative; }'],\n})\nexport class VisXYContainerComponent<Datum> implements AfterViewInit, AfterContentInit, OnDestroy {\n  @ViewChild('container', { static: false }) containerRef: ElementRef\n  @ContentChildren(VisXYComponent) visComponents: QueryList<VisXYComponent>\n  @ContentChild(VisTooltipComponent) tooltipComponent: VisTooltipComponent\n  @ContentChild(VisAnnotationsComponent) annotationsComponent: VisAnnotationsComponent\n\n  /** Width in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */\n  @Input() width?: number\n  /** Height in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */\n  @Input() height?: number\n\n  /** Scale for X dimension, e.g. Scale.scaleLinear(). Default: `Scale.scaleLinear()` */\n  @Input() xScale?: ContinuousScale\n  /** Scale domain (data extent) for X dimension. By default this value is calculated automatically based on data. */\n  @Input() xDomain?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the X scale domain. Useful when the data is plotted along the X axis.\n   * For example, imagine that you have a chart with dynamic data that has negative values. When values are small\n   * (let's say in the range of [-0.01, 0]), you might still want the chart to display some meaningful value range (e.g. [-1, 0]). That can\n   * be achieved by setting `xDomainMinConstraint` to `[undefined, -1]`. In addition to that, if you want to cut off the\n   * values that are too low (let's say lower than -100), you can set the constraint to `[-100, -1]`\n   * Default: `undefined` */\n  @Input() xDomainMinConstraint?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the X scale domain. Useful when the data is plotted along the X axis.\n   * For example, imagine that you have a chart with dynamic data. When values are small\n   * (let's say < 0.01), you might still want the chart to display some meaningful value range (e.g. [0, 1]). That can\n   * be achieved by setting `xDomainMaxConstraint` to `[1, undefined]`. In addition to that, if you want to cut off the\n   * values that are too high (let's say higher than 100), you can set the constraint to `[1, 100]`\n   * Default: `undefined` */\n  @Input() xDomainMaxConstraint?: [number | undefined, number | undefined]\n  /** Force set the X scale range (in the screen space). By default the range is calculated automatically based on the\n   * chart's set up */\n  @Input() xRange?: [number, number]\n\n  /** Scale for Y dimension, e.g. Scale.ScaleLinear. Default: `Scale.ScaleLinear()` */\n  @Input() yScale?: ContinuousScale\n  /** Scale domain (data extent) for Y dimension. By default this value is calculated automatically based on data. */\n  @Input() yDomain?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the Y scale domain.\n   * For example, imagine that you have a chart with dynamic data that has negative values. When values are small\n   * (let's say in the range of [-0.01, 0]), you might still want the chart to display some meaningful value range (e.g. [-1, 0]). That can\n   * be achieved by setting `yDomainMinConstraint` to `[undefined, -1]`. In addition to that, if you want to cut off the\n   * values that are too low (let's say lower than -100), you can set the constraint to `[-100, -1]`\n   * Default: `undefined` */\n  @Input() yDomainMinConstraint?: [number | undefined, number | undefined] = undefined\n  /** Constraint the minimum value of the Y scale domain.\n   * For example, imagine that you have a chart with dynamic data. When values are small\n   * (let's say < 0.01), you might still want the chart to display some meaningful value range (e.g. [0, 1]). That can\n   * be achieved by setting `yDomainMaxConstraint` to `[1, undefined]`. In addition to that, if you want to cut off the\n   * values that are too high (let's say higher than 100), you can set the constraint to `[1, 100]`\n   * Default: `undefined` */\n  @Input() yDomainMaxConstraint?: [number | undefined, number | undefined]\n  /** Force set the Y scale range (in the screen space). By default the range is calculated automatically based on the\n   * chart's set up */\n  @Input() yRange?: [number, number]\n  /** Y Axis direction. Default: `Direction.North` */\n  @Input() yDirection?: Direction.South | Direction.North | string = Direction.North\n  /** Prevents the chart domain from being empty (when domain's min and max values are equal).\n   *  That usually happens when all the data values are the same or when there's no data.\n   *  Setting to `true` will automatically extend the domain by `+1` when needed.\n   *  Setting to `null` will extend the domain only when there's no data.\n   *  Setting to `false` will keep the domain as is.\n   *  Default: `null` */\n  @Input() preventEmptyDomain?: boolean | null = null\n\n  /** Animation duration of all the components within the container. Default: `undefined` */\n  @Input() duration?: number = undefined\n  /** Margins. Default: `{ top: 0, bottom: 0, left: 0, right: 0 }` */\n  @Input() margin?: Spacing = { top: 0, bottom: 0, left: 0, right: 0 }\n  /** Padding. Default: `{ top: 0, bottom: 0, left: 0, right: 0 }` */\n  @Input() padding?: Spacing = {}\n  /** Sets the Y scale domain based on the current X scale domain (not the whole dataset). Default: `false` */\n  @Input() scaleByDomain?: boolean\n  /** Enables automatic calculation of chart margins based on the size of the axes. Default: `true` */\n  @Input() autoMargin?: boolean = true\n\n  /** Alternative text description of the chart for accessibility purposes. It will be applied as an\n   * `aria-label` attribute to the div element containing your chart. Default: `undefined`.\n  */\n  @Input() ariaLabel?: string | null | undefined\n\n  /** Data to be passed to all child components. But if `data` is `undefined` it'll to be passed allowing components to\n   * have their individual data. Default: `undefined` */\n  @Input() data?: Datum[] | undefined = undefined\n\n  chart: XYContainer<Datum>\n\n  ngAfterViewInit (): void {\n    this.chart = new XYContainer<Datum>(this.containerRef.nativeElement, this.getConfig(), this.data)\n    this.passContainerReferenceToChildren()\n  }\n\n  ngAfterContentInit (): void {\n    // QueryList does unsubscribe automatically when it gets destroyed\n    this.visComponents.changes.subscribe(() => {\n      this.passContainerReferenceToChildren()\n      this.chart?.updateContainer(this.getConfig())\n    })\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    const preventRender = true\n\n    // Set new Data without re-render\n    if (changes.data) {\n      this.chart?.setData(this.data, preventRender)\n      delete changes.data\n    }\n\n    // Update Container and render\n    this.chart?.updateContainer(this.getConfig())\n  }\n\n  getConfig (): XYContainerConfigInterface<Datum> {\n    const {\n      duration, margin, padding, scaleByDomain, autoMargin, width, height,\n      xScale, xDomain, xDomainMinConstraint, xDomainMaxConstraint, xRange,\n      yScale, yDomain, yDomainMinConstraint, yDomainMaxConstraint, yRange,\n      yDirection, ariaLabel,\n    } = this\n    const visComponents = this.visComponents.toArray().map(d => d.component)\n\n    const crosshair = visComponents.find(c => c instanceof Crosshair) as Crosshair<Datum>\n    const tooltip = this.tooltipComponent?.component as Tooltip\n    const xAxis = visComponents.find(c => c instanceof Axis && c?.config?.type === 'x') as Axis<Datum>\n    const yAxis = visComponents.find(c => c instanceof Axis && c?.config?.type === 'y') as Axis<Datum>\n    const annotations = this.annotationsComponent?.component as Annotations\n\n    const components = visComponents.filter(c => !(c instanceof Crosshair) && !(c instanceof Tooltip) && !(c instanceof Axis))\n\n    return {\n      components,\n      width,\n      height,\n      duration,\n      margin,\n      padding,\n      xAxis,\n      yAxis,\n      tooltip,\n      crosshair,\n      annotations,\n      scaleByDomain,\n      autoMargin,\n      xScale,\n      xDomain,\n      xDomainMinConstraint,\n      xDomainMaxConstraint,\n      xRange,\n      yScale,\n      yDomain,\n      yDomainMinConstraint,\n      yDomainMaxConstraint,\n      yRange,\n      yDirection,\n      ariaLabel,\n    }\n  }\n\n  passContainerReferenceToChildren (): void {\n    // We set the container for each vis component to trigger chart re-render if the data has changed\n    if (this.chart) this.visComponents.toArray().forEach(c => { c.componentContainer = this.chart })\n  }\n\n  ngOnDestroy (): void {\n    this.chart?.destroy()\n  }\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { Component, Input, ViewChild, ContentChildren, ContentChild, NgModule } from '@angular/core';
3
- import { Tooltip, Direction, XYContainer, Crosshair, Axis, SingleContainer, Area, Brush, ChordDiagram, Donut, FreeBrush, Graph, GroupedBar, Line, NestedDonut, Sankey, Scatter, StackedBar, Timeline, XYLabels, TopoJSONMap, LeafletMap, LeafletFlowMap, BulletLegend } from '@unovis/ts';
3
+ import { Tooltip, Annotations, Direction, XYContainer, Crosshair, Axis, SingleContainer, Area, Brush, ChordDiagram, Donut, FreeBrush, Graph, GroupedBar, Line, NestedDonut, Sankey, Scatter, StackedBar, Timeline, XYLabels, TopoJSONMap, LeafletMap, LeafletFlowMap, BulletLegend } from '@unovis/ts';
4
4
 
5
5
  class VisGenericComponent {
6
6
  }
@@ -58,6 +58,39 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
58
58
  type: Input
59
59
  }] } });
60
60
 
61
+ // !!! This code was automatically generated. You should not change it !!!
62
+ class VisAnnotationsComponent {
63
+ ngAfterViewInit() {
64
+ this.component = new Annotations(this.getConfig());
65
+ }
66
+ ngOnChanges(changes) {
67
+ var _a, _b;
68
+ (_a = this.component) === null || _a === void 0 ? void 0 : _a.setConfig(this.getConfig());
69
+ (_b = this.componentContainer) === null || _b === void 0 ? void 0 : _b.render();
70
+ }
71
+ getConfig() {
72
+ const { items } = this;
73
+ const config = { items };
74
+ const keys = Object.keys(config);
75
+ keys.forEach(key => { if (config[key] === undefined)
76
+ delete config[key]; });
77
+ return config;
78
+ }
79
+ }
80
+ VisAnnotationsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
81
+ VisAnnotationsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisAnnotationsComponent, selector: "vis-annotations", inputs: { items: "items" }, providers: [{ provide: VisGenericComponent, useExisting: VisAnnotationsComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
82
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsComponent, decorators: [{
83
+ type: Component,
84
+ args: [{
85
+ selector: 'vis-annotations',
86
+ template: '',
87
+ // eslint-disable-next-line no-use-before-define
88
+ providers: [{ provide: VisGenericComponent, useExisting: VisAnnotationsComponent }],
89
+ }]
90
+ }], propDecorators: { items: [{
91
+ type: Input
92
+ }] } });
93
+
61
94
  class VisXYContainerComponent {
62
95
  constructor() {
63
96
  /** Constraint the minimum value of the Y scale domain.
@@ -112,13 +145,14 @@ class VisXYContainerComponent {
112
145
  (_b = this.chart) === null || _b === void 0 ? void 0 : _b.updateContainer(this.getConfig());
113
146
  }
114
147
  getConfig() {
115
- var _a;
148
+ var _a, _b;
116
149
  const { duration, margin, padding, scaleByDomain, autoMargin, width, height, xScale, xDomain, xDomainMinConstraint, xDomainMaxConstraint, xRange, yScale, yDomain, yDomainMinConstraint, yDomainMaxConstraint, yRange, yDirection, ariaLabel, } = this;
117
150
  const visComponents = this.visComponents.toArray().map(d => d.component);
118
151
  const crosshair = visComponents.find(c => c instanceof Crosshair);
119
152
  const tooltip = (_a = this.tooltipComponent) === null || _a === void 0 ? void 0 : _a.component;
120
153
  const xAxis = visComponents.find(c => { var _a; return c instanceof Axis && ((_a = c === null || c === void 0 ? void 0 : c.config) === null || _a === void 0 ? void 0 : _a.type) === 'x'; });
121
154
  const yAxis = visComponents.find(c => { var _a; return c instanceof Axis && ((_a = c === null || c === void 0 ? void 0 : c.config) === null || _a === void 0 ? void 0 : _a.type) === 'y'; });
155
+ const annotations = (_b = this.annotationsComponent) === null || _b === void 0 ? void 0 : _b.component;
122
156
  const components = visComponents.filter(c => !(c instanceof Crosshair) && !(c instanceof Tooltip) && !(c instanceof Axis));
123
157
  return {
124
158
  components,
@@ -131,6 +165,7 @@ class VisXYContainerComponent {
131
165
  yAxis,
132
166
  tooltip,
133
167
  crosshair,
168
+ annotations,
134
169
  scaleByDomain,
135
170
  autoMargin,
136
171
  xScale,
@@ -158,7 +193,7 @@ class VisXYContainerComponent {
158
193
  }
159
194
  }
160
195
  VisXYContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisXYContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
161
- VisXYContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisXYContainerComponent, selector: "vis-xy-container", inputs: { width: "width", height: "height", xScale: "xScale", xDomain: "xDomain", xDomainMinConstraint: "xDomainMinConstraint", xDomainMaxConstraint: "xDomainMaxConstraint", xRange: "xRange", yScale: "yScale", yDomain: "yDomain", yDomainMinConstraint: "yDomainMinConstraint", yDomainMaxConstraint: "yDomainMaxConstraint", yRange: "yRange", yDirection: "yDirection", preventEmptyDomain: "preventEmptyDomain", duration: "duration", margin: "margin", padding: "padding", scaleByDomain: "scaleByDomain", autoMargin: "autoMargin", ariaLabel: "ariaLabel", data: "data" }, queries: [{ propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }, { propertyName: "visComponents", predicate: VisXYComponent }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-xy-container">
196
+ VisXYContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisXYContainerComponent, selector: "vis-xy-container", inputs: { width: "width", height: "height", xScale: "xScale", xDomain: "xDomain", xDomainMinConstraint: "xDomainMinConstraint", xDomainMaxConstraint: "xDomainMaxConstraint", xRange: "xRange", yScale: "yScale", yDomain: "yDomain", yDomainMinConstraint: "yDomainMinConstraint", yDomainMaxConstraint: "yDomainMaxConstraint", yRange: "yRange", yDirection: "yDirection", preventEmptyDomain: "preventEmptyDomain", duration: "duration", margin: "margin", padding: "padding", scaleByDomain: "scaleByDomain", autoMargin: "autoMargin", ariaLabel: "ariaLabel", data: "data" }, queries: [{ propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }, { propertyName: "annotationsComponent", first: true, predicate: VisAnnotationsComponent, descendants: true }, { propertyName: "visComponents", predicate: VisXYComponent }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-xy-container">
162
197
  <ng-content></ng-content>
163
198
  </div>`, isInline: true, styles: [".unovis-xy-container { width: 100%; height: 100%; position: relative; }"] });
164
199
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisXYContainerComponent, decorators: [{
@@ -179,6 +214,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
179
214
  }], tooltipComponent: [{
180
215
  type: ContentChild,
181
216
  args: [VisTooltipComponent]
217
+ }], annotationsComponent: [{
218
+ type: ContentChild,
219
+ args: [VisAnnotationsComponent]
182
220
  }], width: [{
183
221
  type: Input
184
222
  }], height: [{
@@ -258,18 +296,19 @@ class VisSingleContainerComponent {
258
296
  (_b = this.chart) === null || _b === void 0 ? void 0 : _b.updateContainer(this.getConfig());
259
297
  }
260
298
  getConfig() {
261
- var _a, _b;
299
+ var _a, _b, _c;
262
300
  const { width, height, duration, margin, ariaLabel } = this;
263
301
  const component = (_a = this.visComponent) === null || _a === void 0 ? void 0 : _a.component;
264
302
  const tooltip = (_b = this.tooltipComponent) === null || _b === void 0 ? void 0 : _b.component;
265
- return { width, height, duration, margin, component, tooltip, ariaLabel };
303
+ const annotations = (_c = this.annotationsComponent) === null || _c === void 0 ? void 0 : _c.component;
304
+ return { width, height, duration, margin, component, tooltip, ariaLabel, annotations };
266
305
  }
267
306
  ngOnDestroy() {
268
307
  this.chart.destroy();
269
308
  }
270
309
  }
271
310
  VisSingleContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisSingleContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
272
- VisSingleContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisSingleContainerComponent, selector: "vis-single-container", inputs: { width: "width", height: "height", margin: "margin", duration: "duration", ariaLabel: "ariaLabel", data: "data" }, queries: [{ propertyName: "visComponent", first: true, predicate: VisCoreComponent, descendants: true }, { propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-single-container">
311
+ VisSingleContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisSingleContainerComponent, selector: "vis-single-container", inputs: { width: "width", height: "height", margin: "margin", duration: "duration", ariaLabel: "ariaLabel", data: "data" }, queries: [{ propertyName: "visComponent", first: true, predicate: VisCoreComponent, descendants: true }, { propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }, { propertyName: "annotationsComponent", first: true, predicate: VisAnnotationsComponent, descendants: true }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-single-container">
273
312
  <ng-content></ng-content>
274
313
  </div>`, isInline: true, styles: [".unovis-single-container { width: 100%; height: 100%; position: relative; }"] });
275
314
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisSingleContainerComponent, decorators: [{
@@ -290,6 +329,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
290
329
  }], tooltipComponent: [{
291
330
  type: ContentChild,
292
331
  args: [VisTooltipComponent]
332
+ }], annotationsComponent: [{
333
+ type: ContentChild,
334
+ args: [VisAnnotationsComponent]
293
335
  }], width: [{
294
336
  type: Input
295
337
  }], height: [{