@unovis/angular 1.4.0-beta.3 → 1.4.0-beta.5
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/dist/lib/bundles/unovis-angular.umd.js +39 -13
- package/dist/lib/bundles/unovis-angular.umd.js.map +1 -1
- package/dist/lib/components/annotations/annotations.component.d.ts +49 -2
- package/dist/lib/components/annotations/annotations.module.d.ts +7 -0
- package/dist/lib/components/chord-diagram/chord-diagram.component.d.ts +6 -6
- package/dist/lib/components.d.ts +2 -0
- package/dist/lib/esm2015/components/annotations/annotations.component.js +11 -5
- package/dist/lib/esm2015/components/annotations/annotations.module.js +18 -0
- package/dist/lib/esm2015/components/chord-diagram/chord-diagram.component.js +8 -8
- package/dist/lib/esm2015/components/nested-donut/nested-donut.component.js +3 -3
- package/dist/lib/esm2015/components.js +3 -1
- package/dist/lib/fesm2015/unovis-angular.js +35 -14
- package/dist/lib/fesm2015/unovis-angular.js.map +1 -1
- package/dist/lib/package.json +2 -2
- package/package.json +2 -2
|
@@ -1,7 +1,54 @@
|
|
|
1
1
|
import { AfterViewInit, SimpleChanges } from '@angular/core';
|
|
2
|
-
import { Annotations, AnnotationsConfigInterface, ContainerCore, AnnotationItem } from '@unovis/ts';
|
|
2
|
+
import { Annotations, AnnotationsConfigInterface, ContainerCore, VisEventType, VisEventCallback, AnnotationItem } from '@unovis/ts';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class VisAnnotationsComponent implements AnnotationsConfigInterface, AfterViewInit {
|
|
5
|
+
/** Animation duration of the data update transitions in milliseconds. Default: `600` */
|
|
6
|
+
duration?: number;
|
|
7
|
+
/** Events configuration. An object containing properties in the following format:
|
|
8
|
+
*
|
|
9
|
+
* ```
|
|
10
|
+
* {
|
|
11
|
+
* \[selectorString]: {
|
|
12
|
+
* \[eventType]: callbackFunction
|
|
13
|
+
* }
|
|
14
|
+
* }
|
|
15
|
+
* ```
|
|
16
|
+
* e.g.:
|
|
17
|
+
* ```
|
|
18
|
+
* {
|
|
19
|
+
* \[Area.selectors.area]: {
|
|
20
|
+
* click: (d) => console.log("Clicked Area", d)
|
|
21
|
+
* }
|
|
22
|
+
* }
|
|
23
|
+
* ``` */
|
|
24
|
+
events?: {
|
|
25
|
+
[selector: string]: {
|
|
26
|
+
[eventType in VisEventType]?: VisEventCallback;
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
/** You can set every SVG and HTML visualization object to have a custom DOM attributes, which is useful
|
|
30
|
+
* when you want to do unit or end-to-end testing. Attributes configuration object has the following structure:
|
|
31
|
+
*
|
|
32
|
+
* ```
|
|
33
|
+
* {
|
|
34
|
+
* \[selectorString]: {
|
|
35
|
+
* \[attributeName]: attribute constant value or accessor function
|
|
36
|
+
* }
|
|
37
|
+
* }
|
|
38
|
+
* ```
|
|
39
|
+
* e.g.:
|
|
40
|
+
* ```
|
|
41
|
+
* {
|
|
42
|
+
* \[Area.selectors.area]: {
|
|
43
|
+
* "test-value": d => d.value
|
|
44
|
+
* }
|
|
45
|
+
* }
|
|
46
|
+
* ``` */
|
|
47
|
+
attributes?: {
|
|
48
|
+
[selector: string]: {
|
|
49
|
+
[attr: string]: string | number | boolean | ((datum: any) => string | number | boolean);
|
|
50
|
+
};
|
|
51
|
+
};
|
|
5
52
|
/** Legend items. Array of `AnnotationItem`:
|
|
6
53
|
* ```
|
|
7
54
|
* {
|
|
@@ -22,5 +69,5 @@ export declare class VisAnnotationsComponent implements AnnotationsConfigInterfa
|
|
|
22
69
|
ngOnChanges(changes: SimpleChanges): void;
|
|
23
70
|
private getConfig;
|
|
24
71
|
static ɵfac: i0.ɵɵFactoryDeclaration<VisAnnotationsComponent, never>;
|
|
25
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<VisAnnotationsComponent, "vis-annotations", never, { "items": "items"; }, {}, never, never>;
|
|
72
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<VisAnnotationsComponent, "vis-annotations", never, { "duration": "duration"; "events": "events"; "attributes": "attributes"; "items": "items"; }, {}, never, never>;
|
|
26
73
|
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./annotations.component";
|
|
3
|
+
export declare class VisAnnotationsModule {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<VisAnnotationsModule, never>;
|
|
5
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<VisAnnotationsModule, [typeof i1.VisAnnotationsComponent], never, [typeof i1.VisAnnotationsComponent]>;
|
|
6
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<VisAnnotationsModule>;
|
|
7
|
+
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { AfterViewInit, SimpleChanges } from '@angular/core';
|
|
2
|
-
import { ChordDiagram, ChordDiagramConfigInterface, ContainerCore, ChordInputNode, ChordInputLink, VisEventType, VisEventCallback,
|
|
2
|
+
import { ChordDiagram, ChordDiagramConfigInterface, ContainerCore, ChordInputNode, ChordInputLink, VisEventType, VisEventCallback, NumericAccessor, ChordNodeDatum, ColorAccessor, ChordLinkDatum, StringAccessor, GenericAccessor, ChordLabelAlignment } from '@unovis/ts';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class VisChordDiagramComponent<N extends ChordInputNode, L extends ChordInputLink> implements ChordDiagramConfigInterface<N, L>, AfterViewInit {
|
|
5
5
|
/** Animation duration of the data update transitions in milliseconds. Default: `600` */
|
|
@@ -49,6 +49,10 @@ export declare class VisChordDiagramComponent<N extends ChordInputNode, L extend
|
|
|
49
49
|
[attr: string]: string | number | boolean | ((datum: any) => string | number | boolean);
|
|
50
50
|
};
|
|
51
51
|
};
|
|
52
|
+
/** Angular range of the diagram. Default: `[0, 2 * Math.PI]` */
|
|
53
|
+
angleRange?: [number, number];
|
|
54
|
+
/** Corner radius constant value or accessor function. Default: `2` */
|
|
55
|
+
cornerRadius?: NumericAccessor<ChordNodeDatum<N>>;
|
|
52
56
|
/** Node id or index to highlight. Overrides default hover behavior if supplied. Default: `undefined` */
|
|
53
57
|
highlightedNodeId?: number | string;
|
|
54
58
|
/** Link ids or index values to highlight. Overrides default hover behavior if supplied. Default: [] */
|
|
@@ -71,10 +75,6 @@ export declare class VisChordDiagramComponent<N extends ChordInputNode, L extend
|
|
|
71
75
|
nodeLabelAlignment?: GenericAccessor<ChordLabelAlignment | string, ChordNodeDatum<N>>;
|
|
72
76
|
/** Pad angle in radians. Default: `0.02` */
|
|
73
77
|
padAngle?: number;
|
|
74
|
-
/** Corner radius constant value or accessor function. Default: `2` */
|
|
75
|
-
cornerRadius?: NumericAccessor<ChordNodeDatum<N>>;
|
|
76
|
-
/** Angular range of the diagram. Default: `[0, 2 * Math.PI]` */
|
|
77
|
-
angleRange?: [number, number];
|
|
78
78
|
/** The exponent property of the radius scale. Default: `2` */
|
|
79
79
|
radiusScaleExponent?: number;
|
|
80
80
|
data: {
|
|
@@ -87,5 +87,5 @@ export declare class VisChordDiagramComponent<N extends ChordInputNode, L extend
|
|
|
87
87
|
ngOnChanges(changes: SimpleChanges): void;
|
|
88
88
|
private getConfig;
|
|
89
89
|
static ɵfac: i0.ɵɵFactoryDeclaration<VisChordDiagramComponent<any, any>, never>;
|
|
90
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<VisChordDiagramComponent<any, any>, "vis-chord-diagram", never, { "duration": "duration"; "events": "events"; "attributes": "attributes"; "highlightedNodeId": "highlightedNodeId"; "highlightedLinkIds": "highlightedLinkIds"; "linkColor": "linkColor"; "linkValue": "linkValue"; "nodeLevels": "nodeLevels"; "nodeWidth": "nodeWidth"; "nodeColor": "nodeColor"; "nodeLabel": "nodeLabel"; "nodeLabelColor": "nodeLabelColor"; "nodeLabelAlignment": "nodeLabelAlignment"; "padAngle": "padAngle"; "
|
|
90
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<VisChordDiagramComponent<any, any>, "vis-chord-diagram", never, { "duration": "duration"; "events": "events"; "attributes": "attributes"; "angleRange": "angleRange"; "cornerRadius": "cornerRadius"; "highlightedNodeId": "highlightedNodeId"; "highlightedLinkIds": "highlightedLinkIds"; "linkColor": "linkColor"; "linkValue": "linkValue"; "nodeLevels": "nodeLevels"; "nodeWidth": "nodeWidth"; "nodeColor": "nodeColor"; "nodeLabel": "nodeLabel"; "nodeLabelColor": "nodeLabelColor"; "nodeLabelAlignment": "nodeLabelAlignment"; "padAngle": "padAngle"; "radiusScaleExponent": "radiusScaleExponent"; "data": "data"; }, {}, never, never>;
|
|
91
91
|
}
|
package/dist/lib/components.d.ts
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
export * from './core';
|
|
2
2
|
export { VisAreaComponent } from './components/area/area.component';
|
|
3
3
|
export { VisAreaModule } from './components/area/area.module';
|
|
4
|
+
export { VisAnnotationsComponent } from './components/annotations/annotations.component';
|
|
5
|
+
export { VisAnnotationsModule } from './components/annotations/annotations.module';
|
|
4
6
|
export { VisAxisComponent } from './components/axis/axis.component';
|
|
5
7
|
export { VisAxisModule } from './components/axis/axis.module';
|
|
6
8
|
export { VisBrushComponent } from './components/brush/brush.component';
|
|
@@ -13,8 +13,8 @@ export class VisAnnotationsComponent {
|
|
|
13
13
|
(_b = this.componentContainer) === null || _b === void 0 ? void 0 : _b.render();
|
|
14
14
|
}
|
|
15
15
|
getConfig() {
|
|
16
|
-
const { items } = this;
|
|
17
|
-
const config = { items };
|
|
16
|
+
const { duration, events, attributes, items } = this;
|
|
17
|
+
const config = { duration, events, attributes, items };
|
|
18
18
|
const keys = Object.keys(config);
|
|
19
19
|
keys.forEach(key => { if (config[key] === undefined)
|
|
20
20
|
delete config[key]; });
|
|
@@ -22,7 +22,7 @@ export class VisAnnotationsComponent {
|
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
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 });
|
|
25
|
+
VisAnnotationsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisAnnotationsComponent, selector: "vis-annotations", inputs: { duration: "duration", events: "events", attributes: "attributes", items: "items" }, providers: [{ provide: VisGenericComponent, useExisting: VisAnnotationsComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
|
|
26
26
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsComponent, decorators: [{
|
|
27
27
|
type: Component,
|
|
28
28
|
args: [{
|
|
@@ -31,7 +31,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
31
31
|
// eslint-disable-next-line no-use-before-define
|
|
32
32
|
providers: [{ provide: VisGenericComponent, useExisting: VisAnnotationsComponent }],
|
|
33
33
|
}]
|
|
34
|
-
}], propDecorators: {
|
|
34
|
+
}], propDecorators: { duration: [{
|
|
35
|
+
type: Input
|
|
36
|
+
}], events: [{
|
|
37
|
+
type: Input
|
|
38
|
+
}], attributes: [{
|
|
39
|
+
type: Input
|
|
40
|
+
}], items: [{
|
|
35
41
|
type: Input
|
|
36
42
|
}] } });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ub3RhdGlvbnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYW5ub3RhdGlvbnMvYW5ub3RhdGlvbnMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDBFQUEwRTtBQUMxRSxPQUFPLEVBQUUsU0FBUyxFQUFpQixLQUFLLEVBQWlCLE1BQU0sZUFBZSxDQUFBO0FBQzlFLE9BQU8sRUFBRSxXQUFXLEVBQTZGLE1BQU0sWUFBWSxDQUFBO0FBQ25JLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLFlBQVksQ0FBQTs7QUFRaEQsTUFBTSxPQUFPLHVCQUF1QjtJQXNFbEMsZUFBZTtRQUNiLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUE7SUFDcEQsQ0FBQztJQUVELFdBQVcsQ0FBRSxPQUFzQjs7UUFDakMsTUFBQSxJQUFJLENBQUMsU0FBUywwQ0FBRSxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUE7UUFDM0MsTUFBQSxJQUFJLENBQUMsa0JBQWtCLDBDQUFFLE1BQU0sRUFBRSxDQUFBO0lBQ25DLENBQUM7SUFFTyxTQUFTO1FBQ2YsTUFBTSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxHQUFHLElBQUksQ0FBQTtRQUNwRCxNQUFNLE1BQU0sR0FBRyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxDQUFBO1FBQ3RELE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUF5QyxDQUFBO1FBQ3hFLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsR0FBRyxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUMsS0FBSyxTQUFTO1lBQUUsT0FBTyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUEsQ0FBQyxDQUFDLENBQUMsQ0FBQTtRQUUxRSxPQUFPLE1BQU0sQ0FBQTtJQUNmLENBQUM7O3FIQXRGVSx1QkFBdUI7eUdBQXZCLHVCQUF1Qix3SUFGdkIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxXQUFXLEVBQUUsdUJBQXVCLEVBQUUsQ0FBQywrQ0FGekUsRUFBRTs0RkFJRCx1QkFBdUI7a0JBTm5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsUUFBUSxFQUFFLEVBQUU7b0JBQ1osZ0RBQWdEO29CQUNoRCxTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxXQUFXLHlCQUF5QixFQUFFLENBQUM7aUJBQ3BGOzhCQUdVLFFBQVE7c0JBQWhCLEtBQUs7Z0JBbUJHLE1BQU07c0JBQWQsS0FBSztnQkF3QkcsVUFBVTtzQkFBbEIsS0FBSztnQkFtQkcsS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gISEhIFRoaXMgY29kZSB3YXMgYXV0b21hdGljYWxseSBnZW5lcmF0ZWQuIFlvdSBzaG91bGQgbm90IGNoYW5nZSBpdCAhISFcbmltcG9ydCB7IENvbXBvbmVudCwgQWZ0ZXJWaWV3SW5pdCwgSW5wdXQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgQW5ub3RhdGlvbnMsIEFubm90YXRpb25zQ29uZmlnSW50ZXJmYWNlLCBDb250YWluZXJDb3JlLCBWaXNFdmVudFR5cGUsIFZpc0V2ZW50Q2FsbGJhY2ssIEFubm90YXRpb25JdGVtIH0gZnJvbSAnQHVub3Zpcy90cydcbmltcG9ydCB7IFZpc0dlbmVyaWNDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb3JlJ1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2aXMtYW5ub3RhdGlvbnMnLFxuICB0ZW1wbGF0ZTogJycsXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby11c2UtYmVmb3JlLWRlZmluZVxuICBwcm92aWRlcnM6IFt7IHByb3ZpZGU6IFZpc0dlbmVyaWNDb21wb25lbnQsIHVzZUV4aXN0aW5nOiBWaXNBbm5vdGF0aW9uc0NvbXBvbmVudCB9XSxcbn0pXG5leHBvcnQgY2xhc3MgVmlzQW5ub3RhdGlvbnNDb21wb25lbnQgaW1wbGVtZW50cyBBbm5vdGF0aW9uc0NvbmZpZ0ludGVyZmFjZSwgQWZ0ZXJWaWV3SW5pdCB7XG4gIC8qKiBBbmltYXRpb24gZHVyYXRpb24gb2YgdGhlIGRhdGEgdXBkYXRlIHRyYW5zaXRpb25zIGluIG1pbGxpc2Vjb25kcy4gRGVmYXVsdDogYDYwMGAgKi9cbiAgQElucHV0KCkgZHVyYXRpb24/OiBudW1iZXJcblxuICAvKiogRXZlbnRzIGNvbmZpZ3VyYXRpb24uIEFuIG9iamVjdCBjb250YWluaW5nIHByb3BlcnRpZXMgaW4gdGhlIGZvbGxvd2luZyBmb3JtYXQ6XG4gICAqXG4gICAqIGBgYFxuICAgKiB7XG4gICAqIFxcW3NlbGVjdG9yU3RyaW5nXToge1xuICAgKiAgICAgXFxbZXZlbnRUeXBlXTogY2FsbGJhY2tGdW5jdGlvblxuICAgKiAgfVxuICAgKiB9XG4gICAqIGBgYFxuICAgKiBlLmcuOlxuICAgKiBgYGBcbiAgICoge1xuICAgKiBcXFtBcmVhLnNlbGVjdG9ycy5hcmVhXToge1xuICAgKiAgICBjbGljazogKGQpID0+IGNvbnNvbGUubG9nKFwiQ2xpY2tlZCBBcmVhXCIsIGQpXG4gICAqICB9XG4gICAqIH1cbiAgICogYGBgICovXG4gIEBJbnB1dCgpIGV2ZW50cz86IHtcbiAgICBbc2VsZWN0b3I6IHN0cmluZ106IHtcbiAgICAgIFtldmVudFR5cGUgaW4gVmlzRXZlbnRUeXBlXT86IFZpc0V2ZW50Q2FsbGJhY2tcbiAgICB9O1xuICB9XG5cbiAgLyoqIFlvdSBjYW4gc2V0IGV2ZXJ5IFNWRyBhbmQgSFRNTCB2aXN1YWxpemF0aW9uIG9iamVjdCB0byBoYXZlIGEgY3VzdG9tIERPTSBhdHRyaWJ1dGVzLCB3aGljaCBpcyB1c2VmdWxcbiAgICogd2hlbiB5b3Ugd2FudCB0byBkbyB1bml0IG9yIGVuZC10by1lbmQgdGVzdGluZy4gQXR0cmlidXRlcyBjb25maWd1cmF0aW9uIG9iamVjdCBoYXMgdGhlIGZvbGxvd2luZyBzdHJ1Y3R1cmU6XG4gICAqXG4gICAqIGBgYFxuICAgKiB7XG4gICAqIFxcW3NlbGVjdG9yU3RyaW5nXToge1xuICAgKiAgICAgXFxbYXR0cmlidXRlTmFtZV06IGF0dHJpYnV0ZSBjb25zdGFudCB2YWx1ZSBvciBhY2Nlc3NvciBmdW5jdGlvblxuICAgKiAgfVxuICAgKiB9XG4gICAqIGBgYFxuICAgKiBlLmcuOlxuICAgKiBgYGBcbiAgICoge1xuICAgKiBcXFtBcmVhLnNlbGVjdG9ycy5hcmVhXToge1xuICAgKiAgICBcInRlc3QtdmFsdWVcIjogZCA9PiBkLnZhbHVlXG4gICAqICB9XG4gICAqIH1cbiAgICogYGBgICovXG4gIEBJbnB1dCgpIGF0dHJpYnV0ZXM/OiB7XG4gICAgW3NlbGVjdG9yOiBzdHJpbmddOiB7XG4gICAgICBbYXR0cjogc3RyaW5nXTogc3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbiB8ICgoZGF0dW06IGFueSkgPT4gc3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbik7XG4gICAgfTtcbiAgfVxuXG4gIC8qKiBMZWdlbmQgaXRlbXMuIEFycmF5IG9mIGBBbm5vdGF0aW9uSXRlbWA6XG4gICAqIGBgYFxuICAgKiB7XG4gICAqICBjb250ZW50OiBzdHJpbmcgfCBVbm92aXNUZXh0IHwgVW5vdmlzVGV4dFtdO1xuICAgKiAgc3ViamVjdD86IEFubm90YXRpb25TdWJqZWN0O1xuICAgKiAgeD86IExlbmd0aFVuaXQ7XG4gICAqICB5PzogTGVuZ3RoVW5pdDtcbiAgICogIHdpZHRoPzogTGVuZ3RoVW5pdDtcbiAgICogIGhlaWdodD86IExlbmd0aFVuaXQ7XG4gICAqIH1cbiAgICogYGBgXG4gICAqIFRvIGxlYXJuIG1vcmUsIHNlZSBvdXIgZG9jcyBodHRwczovL3Vub3Zpcy5kZXYvZG9jcy9hdXhpbGlhcnkvQW5ub3RhdGlvbnMvXG4gICAqIERlZmF1bHQ6IGBbXWAgKi9cbiAgQElucHV0KCkgaXRlbXM6IEFubm90YXRpb25JdGVtW10gfCB1bmRlZmluZWRcblxuXG4gIGNvbXBvbmVudDogQW5ub3RhdGlvbnMgfCB1bmRlZmluZWRcbiAgcHVibGljIGNvbXBvbmVudENvbnRhaW5lcjogQ29udGFpbmVyQ29yZSB8IHVuZGVmaW5lZFxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCAoKTogdm9pZCB7XG4gICAgdGhpcy5jb21wb25lbnQgPSBuZXcgQW5ub3RhdGlvbnModGhpcy5nZXRDb25maWcoKSlcbiAgfVxuXG4gIG5nT25DaGFuZ2VzIChjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgdGhpcy5jb21wb25lbnQ/LnNldENvbmZpZyh0aGlzLmdldENvbmZpZygpKVxuICAgIHRoaXMuY29tcG9uZW50Q29udGFpbmVyPy5yZW5kZXIoKVxuICB9XG5cbiAgcHJpdmF0ZSBnZXRDb25maWcgKCk6IEFubm90YXRpb25zQ29uZmlnSW50ZXJmYWNlIHtcbiAgICBjb25zdCB7IGR1cmF0aW9uLCBldmVudHMsIGF0dHJpYnV0ZXMsIGl0ZW1zIH0gPSB0aGlzXG4gICAgY29uc3QgY29uZmlnID0geyBkdXJhdGlvbiwgZXZlbnRzLCBhdHRyaWJ1dGVzLCBpdGVtcyB9XG4gICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKGNvbmZpZykgYXMgKGtleW9mIEFubm90YXRpb25zQ29uZmlnSW50ZXJmYWNlKVtdXG4gICAga2V5cy5mb3JFYWNoKGtleSA9PiB7IGlmIChjb25maWdba2V5XSA9PT0gdW5kZWZpbmVkKSBkZWxldGUgY29uZmlnW2tleV0gfSlcblxuICAgIHJldHVybiBjb25maWdcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// !!! This code was automatically generated. You should not change it !!!
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { VisAnnotationsComponent } from './annotations.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class VisAnnotationsModule {
|
|
6
|
+
}
|
|
7
|
+
VisAnnotationsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
+
VisAnnotationsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsModule, declarations: [VisAnnotationsComponent], exports: [VisAnnotationsComponent] });
|
|
9
|
+
VisAnnotationsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsModule, imports: [[]] });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
imports: [],
|
|
14
|
+
declarations: [VisAnnotationsComponent],
|
|
15
|
+
exports: [VisAnnotationsComponent],
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ub3RhdGlvbnMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYW5ub3RhdGlvbnMvYW5ub3RhdGlvbnMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDBFQUEwRTtBQUMxRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3hDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHlCQUF5QixDQUFBOztBQU9qRSxNQUFNLE9BQU8sb0JBQW9COztrSEFBcEIsb0JBQW9CO21IQUFwQixvQkFBb0IsaUJBSGhCLHVCQUF1QixhQUM1Qix1QkFBdUI7bUhBRXRCLG9CQUFvQixZQUp0QixFQUFFOzRGQUlBLG9CQUFvQjtrQkFMaEMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsRUFBRTtvQkFDWCxZQUFZLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztvQkFDdkMsT0FBTyxFQUFFLENBQUMsdUJBQXVCLENBQUM7aUJBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiLy8gISEhIFRoaXMgY29kZSB3YXMgYXV0b21hdGljYWxseSBnZW5lcmF0ZWQuIFlvdSBzaG91bGQgbm90IGNoYW5nZSBpdCAhISFcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IFZpc0Fubm90YXRpb25zQ29tcG9uZW50IH0gZnJvbSAnLi9hbm5vdGF0aW9ucy5jb21wb25lbnQnXG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtdLFxuICBkZWNsYXJhdGlvbnM6IFtWaXNBbm5vdGF0aW9uc0NvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtWaXNBbm5vdGF0aW9uc0NvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFZpc0Fubm90YXRpb25zTW9kdWxlIHt9XG4iXX0=
|
|
@@ -21,8 +21,8 @@ export class VisChordDiagramComponent {
|
|
|
21
21
|
(_c = this.componentContainer) === null || _c === void 0 ? void 0 : _c.render();
|
|
22
22
|
}
|
|
23
23
|
getConfig() {
|
|
24
|
-
const { duration, events, attributes, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle,
|
|
25
|
-
const config = { duration, events, attributes, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle,
|
|
24
|
+
const { duration, events, attributes, angleRange, cornerRadius, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle, radiusScaleExponent } = this;
|
|
25
|
+
const config = { duration, events, attributes, angleRange, cornerRadius, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle, radiusScaleExponent };
|
|
26
26
|
const keys = Object.keys(config);
|
|
27
27
|
keys.forEach(key => { if (config[key] === undefined)
|
|
28
28
|
delete config[key]; });
|
|
@@ -30,7 +30,7 @@ export class VisChordDiagramComponent {
|
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
32
|
VisChordDiagramComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisChordDiagramComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
-
VisChordDiagramComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisChordDiagramComponent, selector: "vis-chord-diagram", inputs: { duration: "duration", events: "events", attributes: "attributes", highlightedNodeId: "highlightedNodeId", highlightedLinkIds: "highlightedLinkIds", linkColor: "linkColor", linkValue: "linkValue", nodeLevels: "nodeLevels", nodeWidth: "nodeWidth", nodeColor: "nodeColor", nodeLabel: "nodeLabel", nodeLabelColor: "nodeLabelColor", nodeLabelAlignment: "nodeLabelAlignment", padAngle: "padAngle",
|
|
33
|
+
VisChordDiagramComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisChordDiagramComponent, selector: "vis-chord-diagram", inputs: { duration: "duration", events: "events", attributes: "attributes", angleRange: "angleRange", cornerRadius: "cornerRadius", highlightedNodeId: "highlightedNodeId", highlightedLinkIds: "highlightedLinkIds", linkColor: "linkColor", linkValue: "linkValue", nodeLevels: "nodeLevels", nodeWidth: "nodeWidth", nodeColor: "nodeColor", nodeLabel: "nodeLabel", nodeLabelColor: "nodeLabelColor", nodeLabelAlignment: "nodeLabelAlignment", padAngle: "padAngle", radiusScaleExponent: "radiusScaleExponent", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisChordDiagramComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
|
|
34
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisChordDiagramComponent, decorators: [{
|
|
35
35
|
type: Component,
|
|
36
36
|
args: [{
|
|
@@ -45,6 +45,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
45
45
|
type: Input
|
|
46
46
|
}], attributes: [{
|
|
47
47
|
type: Input
|
|
48
|
+
}], angleRange: [{
|
|
49
|
+
type: Input
|
|
50
|
+
}], cornerRadius: [{
|
|
51
|
+
type: Input
|
|
48
52
|
}], highlightedNodeId: [{
|
|
49
53
|
type: Input
|
|
50
54
|
}], highlightedLinkIds: [{
|
|
@@ -67,13 +71,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
67
71
|
type: Input
|
|
68
72
|
}], padAngle: [{
|
|
69
73
|
type: Input
|
|
70
|
-
}], cornerRadius: [{
|
|
71
|
-
type: Input
|
|
72
|
-
}], angleRange: [{
|
|
73
|
-
type: Input
|
|
74
74
|
}], radiusScaleExponent: [{
|
|
75
75
|
type: Input
|
|
76
76
|
}], data: [{
|
|
77
77
|
type: Input
|
|
78
78
|
}] } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chord-diagram.component.js","sourceRoot":"","sources":["../../../../../src/components/chord-diagram/chord-diagram.component.ts"],"names":[],"mappings":"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","sourcesContent":["// !!! This code was automatically generated. You should not change it !!!\nimport { Component, AfterViewInit, Input, SimpleChanges } from '@angular/core'\nimport {\n  ChordDiagram,\n  ChordDiagramConfigInterface,\n  ContainerCore,\n  ChordInputNode,\n  ChordInputLink,\n  VisEventType,\n  VisEventCallback,\n  ColorAccessor,\n  ChordLinkDatum,\n  NumericAccessor,\n  ChordNodeDatum,\n  StringAccessor,\n  GenericAccessor,\n  ChordLabelAlignment,\n} from '@unovis/ts'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-chord-diagram',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisChordDiagramComponent }],\n})\nexport class VisChordDiagramComponent<N extends ChordInputNode, L extends ChordInputLink> implements ChordDiagramConfigInterface<N, L>, 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  /** Node id or index to highlight. Overrides default hover behavior if supplied. Default: `undefined` */\n  @Input() highlightedNodeId?: number | string\n\n  /** Link ids or index values to highlight. Overrides default hover behavior if supplied. Default: [] */\n  @Input() highlightedLinkIds?: (number | string)[]\n\n  /** Link color accessor function. Default: `var(--vis-chord-diagram-link-fill-color)` */\n  @Input() linkColor?: ColorAccessor<ChordLinkDatum<N, L>>\n\n  /** Link value accessor function. Default: `l => l.value` */\n  @Input() linkValue?: NumericAccessor<ChordLinkDatum<N, L>>\n\n  /** Array of node hierarchy levels. Data records are supposed to have corresponding properties, e.g. ['level1', 'level2']. Default: `[]` */\n  @Input() nodeLevels?: string[]\n\n  /** Node width in pixels. Default: `15` */\n  @Input() nodeWidth?: number\n\n  /** Node color accessor function ot constant value. Default: `d => d.color` */\n  @Input() nodeColor?: ColorAccessor<ChordNodeDatum<N>>\n\n  /** Node label accessor function. Default: `d => d.label ?? d.key` */\n  @Input() nodeLabel?: StringAccessor<ChordNodeDatum<N>>\n\n  /** Node label color accessor function. Default: `undefined` */\n  @Input() nodeLabelColor?: StringAccessor<ChordNodeDatum<N>>\n\n  /** Node label alignment. Default: `ChordLabelAlignment.Along` */\n  @Input() nodeLabelAlignment?: GenericAccessor<ChordLabelAlignment | string, ChordNodeDatum<N>>\n\n  /** Pad angle in radians. Default: `0.02` */\n  @Input() padAngle?: number\n\n  /** Corner radius constant value or accessor function. Default: `2` */\n  @Input() cornerRadius?: NumericAccessor<ChordNodeDatum<N>>\n\n  /** Angular range of the diagram. Default: `[0, 2 * Math.PI]` */\n  @Input() angleRange?: [number, number]\n\n  /** The exponent property of the radius scale. Default: `2` */\n  @Input() radiusScaleExponent?: number\n  @Input() data: { nodes: N[]; links?: L[] }\n\n  component: ChordDiagram<N, L> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new ChordDiagram<N, L>(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 (): ChordDiagramConfigInterface<N, L> {\n    const { duration, events, attributes, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle, cornerRadius, angleRange, radiusScaleExponent } = this\n    const config = { duration, events, attributes, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle, cornerRadius, angleRange, radiusScaleExponent }\n    const keys = Object.keys(config) as (keyof ChordDiagramConfigInterface<N, L>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chord-diagram.component.js","sourceRoot":"","sources":["../../../../../src/components/chord-diagram/chord-diagram.component.ts"],"names":[],"mappings":"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","sourcesContent":["// !!! This code was automatically generated. You should not change it !!!\nimport { Component, AfterViewInit, Input, SimpleChanges } from '@angular/core'\nimport {\n  ChordDiagram,\n  ChordDiagramConfigInterface,\n  ContainerCore,\n  ChordInputNode,\n  ChordInputLink,\n  VisEventType,\n  VisEventCallback,\n  NumericAccessor,\n  ChordNodeDatum,\n  ColorAccessor,\n  ChordLinkDatum,\n  StringAccessor,\n  GenericAccessor,\n  ChordLabelAlignment,\n} from '@unovis/ts'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-chord-diagram',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisChordDiagramComponent }],\n})\nexport class VisChordDiagramComponent<N extends ChordInputNode, L extends ChordInputLink> implements ChordDiagramConfigInterface<N, L>, 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  /** Angular range of the diagram. Default: `[0, 2 * Math.PI]` */\n  @Input() angleRange?: [number, number]\n\n  /** Corner radius constant value or accessor function. Default: `2` */\n  @Input() cornerRadius?: NumericAccessor<ChordNodeDatum<N>>\n\n  /** Node id or index to highlight. Overrides default hover behavior if supplied. Default: `undefined` */\n  @Input() highlightedNodeId?: number | string\n\n  /** Link ids or index values to highlight. Overrides default hover behavior if supplied. Default: [] */\n  @Input() highlightedLinkIds?: (number | string)[]\n\n  /** Link color accessor function. Default: `var(--vis-chord-diagram-link-fill-color)` */\n  @Input() linkColor?: ColorAccessor<ChordLinkDatum<N, L>>\n\n  /** Link value accessor function. Default: `l => l.value` */\n  @Input() linkValue?: NumericAccessor<ChordLinkDatum<N, L>>\n\n  /** Array of node hierarchy levels. Data records are supposed to have corresponding properties, e.g. ['level1', 'level2']. Default: `[]` */\n  @Input() nodeLevels?: string[]\n\n  /** Node width in pixels. Default: `15` */\n  @Input() nodeWidth?: number\n\n  /** Node color accessor function ot constant value. Default: `d => d.color` */\n  @Input() nodeColor?: ColorAccessor<ChordNodeDatum<N>>\n\n  /** Node label accessor function. Default: `d => d.label ?? d.key` */\n  @Input() nodeLabel?: StringAccessor<ChordNodeDatum<N>>\n\n  /** Node label color accessor function. Default: `undefined` */\n  @Input() nodeLabelColor?: StringAccessor<ChordNodeDatum<N>>\n\n  /** Node label alignment. Default: `ChordLabelAlignment.Along` */\n  @Input() nodeLabelAlignment?: GenericAccessor<ChordLabelAlignment | string, ChordNodeDatum<N>>\n\n  /** Pad angle in radians. Default: `0.02` */\n  @Input() padAngle?: number\n\n  /** The exponent property of the radius scale. Default: `2` */\n  @Input() radiusScaleExponent?: number\n  @Input() data: { nodes: N[]; links?: L[] }\n\n  component: ChordDiagram<N, L> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new ChordDiagram<N, L>(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 (): ChordDiagramConfigInterface<N, L> {\n    const { duration, events, attributes, angleRange, cornerRadius, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle, radiusScaleExponent } = this\n    const config = { duration, events, attributes, angleRange, cornerRadius, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle, radiusScaleExponent }\n    const keys = Object.keys(config) as (keyof ChordDiagramConfigInterface<N, L>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
|
|
@@ -21,8 +21,8 @@ export class VisNestedDonutComponent {
|
|
|
21
21
|
(_c = this.componentContainer) === null || _c === void 0 ? void 0 : _c.render();
|
|
22
22
|
}
|
|
23
23
|
getConfig() {
|
|
24
|
-
const { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments } = this;
|
|
25
|
-
const config = { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments };
|
|
24
|
+
const { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments, showSegmentLabels } = this;
|
|
25
|
+
const config = { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments, showSegmentLabels };
|
|
26
26
|
const keys = Object.keys(config);
|
|
27
27
|
keys.forEach(key => { if (config[key] === undefined)
|
|
28
28
|
delete config[key]; });
|
|
@@ -86,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
86
86
|
}], data: [{
|
|
87
87
|
type: Input
|
|
88
88
|
}] } });
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-donut.component.js","sourceRoot":"","sources":["../../../../../src/components/nested-donut/nested-donut.component.ts"],"names":[],"mappings":"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","sourcesContent":["// !!! This code was automatically generated. You should not change it !!!\nimport { Component, AfterViewInit, Input, SimpleChanges } from '@angular/core'\nimport {\n  NestedDonut,\n  NestedDonutConfigInterface,\n  ContainerCore,\n  VisEventType,\n  VisEventCallback,\n  NestedDonutDirection,\n  NumericAccessor,\n  NestedDonutSegment,\n  StringAccessor,\n  GenericAccessor,\n  NestedDonutLayerSettings,\n  ColorAccessor,\n} from '@unovis/ts'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-nested-donut',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisNestedDonutComponent }],\n})\nexport class VisNestedDonutComponent<Datum> implements NestedDonutConfigInterface<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  /** Diagram angle range. Default: `[0, 2 * Math.PI]` */\n  @Input() angleRange?: [number, number]\n\n  /** Direction of hierarchy flow from root to leaf.\n   * `NestedDonutDirection.Inwards` starts from the outer most radius and works towards center\n   * `NestedDonutDirection.Outwards` starts from the inner most radius the consecutive layers outward.\n   * Default: `NestedDonutDirection.Inwards` */\n  @Input() direction?: NestedDonutDirection | string\n\n\n  @Input() value?: NumericAccessor<Datum>\n\n  /** Central label text. Default: `undefined` */\n  @Input() centralLabel?: string\n\n  /** Central sub-label accessor function or text. Default: `undefined` */\n  @Input() centralSubLabel?: string\n\n  /** Enables wrapping for the sub-label. Default: `true` */\n  @Input() centralSubLabelWrap?: boolean\n\n  /** Show donut background. The color is configurable via\n   * the `--vis-nested-donut-background-color` and `--vis-dark-nested-donut-background-color` CSS variables.\n   * Default: `false` */\n  @Input() showBackground?: boolean\n\n  /** Sort function for segments. Default `undefined` */\n  @Input() sort?: (a: NestedDonutSegment<Datum>, b: NestedDonutSegment<Datum>) => number\n\n  /** Array of accessor functions to defined the nested groups */\n  @Input() layers: StringAccessor<Datum>[]\n\n\n  @Input() layerSettings?: GenericAccessor<NestedDonutLayerSettings, number>\n\n\n  @Input() layerPadding?: number\n\n  /** Corner Radius. Default: `0` */\n  @Input() cornerRadius?: number\n\n  /** Angular size for empty segments in radians. Default: `Math.PI / 180` */\n  @Input() emptySegmentAngle?: number\n\n  /** Hide segment labels when they don't fit. Default: `true` */\n  @Input() hideOverflowingSegmentLabels?: boolean\n\n  /** Color accessor function for segments. Default: `undefined` */\n  @Input() segmentColor?: ColorAccessor<NestedDonutSegment<Datum>>\n\n  /** Segment label accessor function. Default `undefined` */\n  @Input() segmentLabel?: StringAccessor<NestedDonutSegment<Datum>>\n\n  /** Color accessor function for segment labels */\n  @Input() segmentLabelColor?: ColorAccessor<NestedDonutSegment<Datum>>\n\n  /** When true, the component will display empty segments (the ones that have `0` values) as tiny slices.\n   * Default: `false` */\n  @Input() showEmptySegments?: boolean\n\n  /** Show labels for individual segments. Default: `true` */\n  @Input() showSegmentLabels?: boolean\n\n  @Input() data: Datum[]\n\n  component: NestedDonut<Datum> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new NestedDonut<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 (): NestedDonutConfigInterface<Datum> {\n    const { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments } = this\n    const config = { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments }\n    const keys = Object.keys(config) as (keyof NestedDonutConfigInterface<Datum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-donut.component.js","sourceRoot":"","sources":["../../../../../src/components/nested-donut/nested-donut.component.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,OAAO,EAAE,SAAS,EAAiB,KAAK,EAAiB,MAAM,eAAe,CAAA;AAC9E,OAAO,EACL,WAAW,GAYZ,MAAM,YAAY,CAAA;AACnB,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;;AAQ7C,MAAM,OAAO,uBAAuB;IAsHlC,eAAe;;QACb,IAAI,CAAC,SAAS,GAAG,IAAI,WAAW,CAAQ,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAEzD,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,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,mBAAmB,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,YAAY,EAAE,iBAAiB,EAAE,4BAA4B,EAAE,YAAY,EAAE,YAAY,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,GAAG,IAAI,CAAA;QAC9U,MAAM,MAAM,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,mBAAmB,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,YAAY,EAAE,iBAAiB,EAAE,4BAA4B,EAAE,YAAY,EAAE,YAAY,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,CAAA;QAChV,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAgD,CAAA;QAC/E,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;;qHA5IU,uBAAuB;yGAAvB,uBAAuB,+uBAFvB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,uBAAuB,EAAE,CAAC,+CAFtE,EAAE;4FAID,uBAAuB;kBANnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,kBAAkB;oBAC5B,QAAQ,EAAE,EAAE;oBACZ,gDAAgD;oBAChD,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,yBAAyB,EAAE,CAAC;iBACjF;8BAGU,QAAQ;sBAAhB,KAAK;gBAmBG,MAAM;sBAAd,KAAK;gBAwBG,UAAU;sBAAlB,KAAK;gBAOG,UAAU;sBAAlB,KAAK;gBAMG,SAAS;sBAAjB,KAAK;gBAGG,KAAK;sBAAb,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBAGG,mBAAmB;sBAA3B,KAAK;gBAKG,cAAc;sBAAtB,KAAK;gBAGG,IAAI;sBAAZ,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,iBAAiB;sBAAzB,KAAK;gBAGG,4BAA4B;sBAApC,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,iBAAiB;sBAAzB,KAAK;gBAIG,iBAAiB;sBAAzB,KAAK;gBAGG,iBAAiB;sBAAzB,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  NestedDonut,\n  NestedDonutConfigInterface,\n  ContainerCore,\n  VisEventType,\n  VisEventCallback,\n  NestedDonutDirection,\n  NumericAccessor,\n  NestedDonutSegment,\n  StringAccessor,\n  GenericAccessor,\n  NestedDonutLayerSettings,\n  ColorAccessor,\n} from '@unovis/ts'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-nested-donut',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisNestedDonutComponent }],\n})\nexport class VisNestedDonutComponent<Datum> implements NestedDonutConfigInterface<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  /** Diagram angle range. Default: `[0, 2 * Math.PI]` */\n  @Input() angleRange?: [number, number]\n\n  /** Direction of hierarchy flow from root to leaf.\n   * `NestedDonutDirection.Inwards` starts from the outer most radius and works towards center\n   * `NestedDonutDirection.Outwards` starts from the inner most radius the consecutive layers outward.\n   * Default: `NestedDonutDirection.Inwards` */\n  @Input() direction?: NestedDonutDirection | string\n\n\n  @Input() value?: NumericAccessor<Datum>\n\n  /** Central label text. Default: `undefined` */\n  @Input() centralLabel?: string\n\n  /** Central sub-label accessor function or text. Default: `undefined` */\n  @Input() centralSubLabel?: string\n\n  /** Enables wrapping for the sub-label. Default: `true` */\n  @Input() centralSubLabelWrap?: boolean\n\n  /** Show donut background. The color is configurable via\n   * the `--vis-nested-donut-background-color` and `--vis-dark-nested-donut-background-color` CSS variables.\n   * Default: `false` */\n  @Input() showBackground?: boolean\n\n  /** Sort function for segments. Default `undefined` */\n  @Input() sort?: (a: NestedDonutSegment<Datum>, b: NestedDonutSegment<Datum>) => number\n\n  /** Array of accessor functions to defined the nested groups */\n  @Input() layers: StringAccessor<Datum>[]\n\n\n  @Input() layerSettings?: GenericAccessor<NestedDonutLayerSettings, number>\n\n\n  @Input() layerPadding?: number\n\n  /** Corner Radius. Default: `0` */\n  @Input() cornerRadius?: number\n\n  /** Angular size for empty segments in radians. Default: `Math.PI / 180` */\n  @Input() emptySegmentAngle?: number\n\n  /** Hide segment labels when they don't fit. Default: `true` */\n  @Input() hideOverflowingSegmentLabels?: boolean\n\n  /** Color accessor function for segments. Default: `undefined` */\n  @Input() segmentColor?: ColorAccessor<NestedDonutSegment<Datum>>\n\n  /** Segment label accessor function. Default `undefined` */\n  @Input() segmentLabel?: StringAccessor<NestedDonutSegment<Datum>>\n\n  /** Color accessor function for segment labels */\n  @Input() segmentLabelColor?: ColorAccessor<NestedDonutSegment<Datum>>\n\n  /** When true, the component will display empty segments (the ones that have `0` values) as tiny slices.\n   * Default: `false` */\n  @Input() showEmptySegments?: boolean\n\n  /** Show labels for individual segments. Default: `true` */\n  @Input() showSegmentLabels?: boolean\n  @Input() data: Datum[]\n\n  component: NestedDonut<Datum> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new NestedDonut<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 (): NestedDonutConfigInterface<Datum> {\n    const { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments, showSegmentLabels } = this\n    const config = { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments, showSegmentLabels }\n    const keys = Object.keys(config) as (keyof NestedDonutConfigInterface<Datum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
|
|
@@ -3,6 +3,8 @@ export * from './core';
|
|
|
3
3
|
// SVG Components
|
|
4
4
|
export { VisAreaComponent } from './components/area/area.component';
|
|
5
5
|
export { VisAreaModule } from './components/area/area.module';
|
|
6
|
+
export { VisAnnotationsComponent } from './components/annotations/annotations.component';
|
|
7
|
+
export { VisAnnotationsModule } from './components/annotations/annotations.module';
|
|
6
8
|
export { VisAxisComponent } from './components/axis/axis.component';
|
|
7
9
|
export { VisAxisModule } from './components/axis/axis.module';
|
|
8
10
|
export { VisBrushComponent } from './components/brush/brush.component';
|
|
@@ -44,4 +46,4 @@ export { VisBulletLegendComponent } from './html-components/bullet-legend/bullet
|
|
|
44
46
|
export { VisBulletLegendModule } from './html-components/bullet-legend/bullet-legend.module';
|
|
45
47
|
export { VisTooltipComponent } from './components/tooltip/tooltip.component';
|
|
46
48
|
export { VisTooltipModule } from './components/tooltip/tooltip.module';
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU87QUFDUCxjQUFjLFFBQVEsQ0FBQTtBQUV0QixpQkFBaUI7QUFDakIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0NBQWtDLENBQUE7QUFDbkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLCtCQUErQixDQUFBO0FBRTdELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGdEQUFnRCxDQUFBO0FBQ3hGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDZDQUE2QyxDQUFBO0FBRWxGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBQ25FLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQTtBQUU3RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQTtBQUN0RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0saUNBQWlDLENBQUE7QUFFaEUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sb0RBQW9ELENBQUE7QUFDN0YsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saURBQWlELENBQUE7QUFFdkYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sNENBQTRDLENBQUE7QUFDbEYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUNBQXlDLENBQUE7QUFFNUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0NBQW9DLENBQUE7QUFDdEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGlDQUFpQyxDQUFBO0FBRWhFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDhDQUE4QyxDQUFBO0FBQ3BGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFBO0FBRTlFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFBO0FBQ3RFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQTtBQUVoRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQTtBQUN2RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQTtBQUVqRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQTtBQUNuRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sK0JBQStCLENBQUE7QUFFN0QsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sa0RBQWtELENBQUE7QUFDMUYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sK0NBQStDLENBQUE7QUFFcEYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sc0NBQXNDLENBQUE7QUFDekUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1DQUFtQyxDQUFBO0FBRW5FLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFBO0FBQzVFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFBO0FBRXRFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFBO0FBQ3ZGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFBO0FBRWpGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFBO0FBQy9FLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFBO0FBRXpFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFBO0FBQ2pGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFBO0FBRTNFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGtEQUFrRCxDQUFBO0FBQzFGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLCtDQUErQyxDQUFBO0FBRXBGLGtCQUFrQjtBQUNsQixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxxREFBcUQsQ0FBQTtBQUM1RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxrREFBa0QsQ0FBQTtBQUV0RixPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSwrREFBK0QsQ0FBQTtBQUMxRyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQTtBQUVwRyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx5REFBeUQsQ0FBQTtBQUNsRyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQTtBQUU1RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQTtBQUM1RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcmVcbmV4cG9ydCAqIGZyb20gJy4vY29yZSdcblxuLy8gU1ZHIENvbXBvbmVudHNcbmV4cG9ydCB7IFZpc0FyZWFDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYXJlYS9hcmVhLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc0FyZWFNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvYXJlYS9hcmVhLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzQW5ub3RhdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYW5ub3RhdGlvbnMvYW5ub3RhdGlvbnMuY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzQW5ub3RhdGlvbnNNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvYW5ub3RhdGlvbnMvYW5ub3RhdGlvbnMubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNBeGlzQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2F4aXMvYXhpcy5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNBeGlzTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2F4aXMvYXhpcy5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc0JydXNoQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2JydXNoL2JydXNoLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc0JydXNoTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2JydXNoL2JydXNoLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzQ2hvcmREaWFncmFtQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2Nob3JkLWRpYWdyYW0vY2hvcmQtZGlhZ3JhbS5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNDaG9yZERpYWdyYW1Nb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvY2hvcmQtZGlhZ3JhbS9jaG9yZC1kaWFncmFtLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzQ3Jvc3NoYWlyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2Nyb3NzaGFpci9jcm9zc2hhaXIuY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzQ3Jvc3NoYWlyTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2Nyb3NzaGFpci9jcm9zc2hhaXIubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNEb251dENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9kb251dC9kb251dC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNEb251dE1vZHVsZSB9IGZyb20gJy4vY29tcG9uZW50cy9kb251dC9kb251dC5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc0ZyZWVCcnVzaENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9mcmVlLWJydXNoL2ZyZWUtYnJ1c2guY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzRnJlZUJydXNoTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2ZyZWUtYnJ1c2gvZnJlZS1icnVzaC5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc0dyYXBoQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2dyYXBoL2dyYXBoLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc0dyYXBoTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2dyYXBoL2dyYXBoLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzR3JvdXBlZEJhckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9ncm91cGVkLWJhci9ncm91cGVkLWJhci5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNHcm91cGVkQmFyTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2dyb3VwZWQtYmFyL2dyb3VwZWQtYmFyLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzTGluZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9saW5lL2xpbmUuY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzTGluZU1vZHVsZSB9IGZyb20gJy4vY29tcG9uZW50cy9saW5lL2xpbmUubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNOZXN0ZWREb251dENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9uZXN0ZWQtZG9udXQvbmVzdGVkLWRvbnV0LmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc05lc3RlZERvbnV0TW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL25lc3RlZC1kb251dC9uZXN0ZWQtZG9udXQubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNTYW5rZXlDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvc2Fua2V5L3NhbmtleS5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNTYW5rZXlNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvc2Fua2V5L3NhbmtleS5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc1NjYXR0ZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvc2NhdHRlci9zY2F0dGVyLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc1NjYXR0ZXJNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvc2NhdHRlci9zY2F0dGVyLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzU3RhY2tlZEJhckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9zdGFja2VkLWJhci9zdGFja2VkLWJhci5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNTdGFja2VkQmFyTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL3N0YWNrZWQtYmFyL3N0YWNrZWQtYmFyLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzVGltZWxpbmVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdGltZWxpbmUvdGltZWxpbmUuY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzVGltZWxpbmVNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvdGltZWxpbmUvdGltZWxpbmUubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNYWUxhYmVsc0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy94eS1sYWJlbHMveHktbGFiZWxzLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc1hZTGFiZWxzTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL3h5LWxhYmVscy94eS1sYWJlbHMubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNUb3BvSlNPTk1hcENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90b3BvanNvbi1tYXAvdG9wb2pzb24tbWFwLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc1RvcG9KU09OTWFwTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL3RvcG9qc29uLW1hcC90b3BvanNvbi1tYXAubW9kdWxlJ1xuXG4vLyBIVE1MIENvbXBvbmVudHNcbmV4cG9ydCB7IFZpc0xlYWZsZXRNYXBDb21wb25lbnQgfSBmcm9tICcuL2h0bWwtY29tcG9uZW50cy9sZWFmbGV0LW1hcC9sZWFmbGV0LW1hcC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNMZWFmbGV0TWFwTW9kdWxlIH0gZnJvbSAnLi9odG1sLWNvbXBvbmVudHMvbGVhZmxldC1tYXAvbGVhZmxldC1tYXAubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNMZWFmbGV0Rmxvd01hcENvbXBvbmVudCB9IGZyb20gJy4vaHRtbC1jb21wb25lbnRzL2xlYWZsZXQtZmxvdy1tYXAvbGVhZmxldC1mbG93LW1hcC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNMZWFmbGV0Rmxvd01hcE1vZHVsZSB9IGZyb20gJy4vaHRtbC1jb21wb25lbnRzL2xlYWZsZXQtZmxvdy1tYXAvbGVhZmxldC1mbG93LW1hcC5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc0J1bGxldExlZ2VuZENvbXBvbmVudCB9IGZyb20gJy4vaHRtbC1jb21wb25lbnRzL2J1bGxldC1sZWdlbmQvYnVsbGV0LWxlZ2VuZC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNCdWxsZXRMZWdlbmRNb2R1bGUgfSBmcm9tICcuL2h0bWwtY29tcG9uZW50cy9idWxsZXQtbGVnZW5kL2J1bGxldC1sZWdlbmQubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNUb29sdGlwQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNUb29sdGlwTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL3Rvb2x0aXAvdG9vbHRpcC5tb2R1bGUnXG4iXX0=
|
|
@@ -69,8 +69,8 @@ class VisAnnotationsComponent {
|
|
|
69
69
|
(_b = this.componentContainer) === null || _b === void 0 ? void 0 : _b.render();
|
|
70
70
|
}
|
|
71
71
|
getConfig() {
|
|
72
|
-
const { items } = this;
|
|
73
|
-
const config = { items };
|
|
72
|
+
const { duration, events, attributes, items } = this;
|
|
73
|
+
const config = { duration, events, attributes, items };
|
|
74
74
|
const keys = Object.keys(config);
|
|
75
75
|
keys.forEach(key => { if (config[key] === undefined)
|
|
76
76
|
delete config[key]; });
|
|
@@ -78,7 +78,7 @@ class VisAnnotationsComponent {
|
|
|
78
78
|
}
|
|
79
79
|
}
|
|
80
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 });
|
|
81
|
+
VisAnnotationsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisAnnotationsComponent, selector: "vis-annotations", inputs: { duration: "duration", events: "events", attributes: "attributes", items: "items" }, providers: [{ provide: VisGenericComponent, useExisting: VisAnnotationsComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
|
|
82
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsComponent, decorators: [{
|
|
83
83
|
type: Component,
|
|
84
84
|
args: [{
|
|
@@ -87,7 +87,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
87
87
|
// eslint-disable-next-line no-use-before-define
|
|
88
88
|
providers: [{ provide: VisGenericComponent, useExisting: VisAnnotationsComponent }],
|
|
89
89
|
}]
|
|
90
|
-
}], propDecorators: {
|
|
90
|
+
}], propDecorators: { duration: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], events: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], attributes: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], items: [{
|
|
91
97
|
type: Input
|
|
92
98
|
}] } });
|
|
93
99
|
|
|
@@ -446,6 +452,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
446
452
|
}]
|
|
447
453
|
}] });
|
|
448
454
|
|
|
455
|
+
// !!! This code was automatically generated. You should not change it !!!
|
|
456
|
+
class VisAnnotationsModule {
|
|
457
|
+
}
|
|
458
|
+
VisAnnotationsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
459
|
+
VisAnnotationsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsModule, declarations: [VisAnnotationsComponent], exports: [VisAnnotationsComponent] });
|
|
460
|
+
VisAnnotationsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsModule, imports: [[]] });
|
|
461
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisAnnotationsModule, decorators: [{
|
|
462
|
+
type: NgModule,
|
|
463
|
+
args: [{
|
|
464
|
+
imports: [],
|
|
465
|
+
declarations: [VisAnnotationsComponent],
|
|
466
|
+
exports: [VisAnnotationsComponent],
|
|
467
|
+
}]
|
|
468
|
+
}] });
|
|
469
|
+
|
|
449
470
|
// !!! This code was automatically generated. You should not change it !!!
|
|
450
471
|
class VisAxisComponent {
|
|
451
472
|
ngAfterViewInit() {
|
|
@@ -653,8 +674,8 @@ class VisChordDiagramComponent {
|
|
|
653
674
|
(_c = this.componentContainer) === null || _c === void 0 ? void 0 : _c.render();
|
|
654
675
|
}
|
|
655
676
|
getConfig() {
|
|
656
|
-
const { duration, events, attributes, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle,
|
|
657
|
-
const config = { duration, events, attributes, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle,
|
|
677
|
+
const { duration, events, attributes, angleRange, cornerRadius, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle, radiusScaleExponent } = this;
|
|
678
|
+
const config = { duration, events, attributes, angleRange, cornerRadius, highlightedNodeId, highlightedLinkIds, linkColor, linkValue, nodeLevels, nodeWidth, nodeColor, nodeLabel, nodeLabelColor, nodeLabelAlignment, padAngle, radiusScaleExponent };
|
|
658
679
|
const keys = Object.keys(config);
|
|
659
680
|
keys.forEach(key => { if (config[key] === undefined)
|
|
660
681
|
delete config[key]; });
|
|
@@ -662,7 +683,7 @@ class VisChordDiagramComponent {
|
|
|
662
683
|
}
|
|
663
684
|
}
|
|
664
685
|
VisChordDiagramComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisChordDiagramComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
665
|
-
VisChordDiagramComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisChordDiagramComponent, selector: "vis-chord-diagram", inputs: { duration: "duration", events: "events", attributes: "attributes", highlightedNodeId: "highlightedNodeId", highlightedLinkIds: "highlightedLinkIds", linkColor: "linkColor", linkValue: "linkValue", nodeLevels: "nodeLevels", nodeWidth: "nodeWidth", nodeColor: "nodeColor", nodeLabel: "nodeLabel", nodeLabelColor: "nodeLabelColor", nodeLabelAlignment: "nodeLabelAlignment", padAngle: "padAngle",
|
|
686
|
+
VisChordDiagramComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisChordDiagramComponent, selector: "vis-chord-diagram", inputs: { duration: "duration", events: "events", attributes: "attributes", angleRange: "angleRange", cornerRadius: "cornerRadius", highlightedNodeId: "highlightedNodeId", highlightedLinkIds: "highlightedLinkIds", linkColor: "linkColor", linkValue: "linkValue", nodeLevels: "nodeLevels", nodeWidth: "nodeWidth", nodeColor: "nodeColor", nodeLabel: "nodeLabel", nodeLabelColor: "nodeLabelColor", nodeLabelAlignment: "nodeLabelAlignment", padAngle: "padAngle", radiusScaleExponent: "radiusScaleExponent", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisChordDiagramComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
|
|
666
687
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisChordDiagramComponent, decorators: [{
|
|
667
688
|
type: Component,
|
|
668
689
|
args: [{
|
|
@@ -677,6 +698,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
677
698
|
type: Input
|
|
678
699
|
}], attributes: [{
|
|
679
700
|
type: Input
|
|
701
|
+
}], angleRange: [{
|
|
702
|
+
type: Input
|
|
703
|
+
}], cornerRadius: [{
|
|
704
|
+
type: Input
|
|
680
705
|
}], highlightedNodeId: [{
|
|
681
706
|
type: Input
|
|
682
707
|
}], highlightedLinkIds: [{
|
|
@@ -699,10 +724,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
699
724
|
type: Input
|
|
700
725
|
}], padAngle: [{
|
|
701
726
|
type: Input
|
|
702
|
-
}], cornerRadius: [{
|
|
703
|
-
type: Input
|
|
704
|
-
}], angleRange: [{
|
|
705
|
-
type: Input
|
|
706
727
|
}], radiusScaleExponent: [{
|
|
707
728
|
type: Input
|
|
708
729
|
}], data: [{
|
|
@@ -1375,8 +1396,8 @@ class VisNestedDonutComponent {
|
|
|
1375
1396
|
(_c = this.componentContainer) === null || _c === void 0 ? void 0 : _c.render();
|
|
1376
1397
|
}
|
|
1377
1398
|
getConfig() {
|
|
1378
|
-
const { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments } = this;
|
|
1379
|
-
const config = { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments };
|
|
1399
|
+
const { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments, showSegmentLabels } = this;
|
|
1400
|
+
const config = { duration, events, attributes, angleRange, direction, value, centralLabel, centralSubLabel, centralSubLabelWrap, showBackground, sort, layers, layerSettings, layerPadding, cornerRadius, emptySegmentAngle, hideOverflowingSegmentLabels, segmentColor, segmentLabel, segmentLabelColor, showEmptySegments, showSegmentLabels };
|
|
1380
1401
|
const keys = Object.keys(config);
|
|
1381
1402
|
keys.forEach(key => { if (config[key] === undefined)
|
|
1382
1403
|
delete config[key]; });
|
|
@@ -2526,5 +2547,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
2526
2547
|
* Generated bundle index. Do not edit.
|
|
2527
2548
|
*/
|
|
2528
2549
|
|
|
2529
|
-
export { VisAreaComponent, VisAreaModule, VisAxisComponent, VisAxisModule, VisBrushComponent, VisBrushModule, VisBulletLegendComponent, VisBulletLegendModule, VisChordDiagramComponent, VisChordDiagramModule, VisCoreComponent, VisCrosshairComponent, VisCrosshairModule, VisDonutComponent, VisDonutModule, VisFreeBrushComponent, VisFreeBrushModule, VisGenericComponent, VisGraphComponent, VisGraphModule, VisGroupedBarComponent, VisGroupedBarModule, VisLeafletFlowMapComponent, VisLeafletFlowMapModule, VisLeafletMapComponent, VisLeafletMapModule, VisLineComponent, VisLineModule, VisNestedDonutComponent, VisNestedDonutModule, VisSankeyComponent, VisSankeyModule, VisScatterComponent, VisScatterModule, VisSingleContainerComponent, VisSingleContainerModule, VisStackedBarComponent, VisStackedBarModule, VisTimelineComponent, VisTimelineModule, VisTooltipComponent, VisTooltipModule, VisTopoJSONMapComponent, VisTopoJSONMapModule, VisXYComponent, VisXYContainerComponent, VisXYContainerModule, VisXYLabelsComponent, VisXYLabelsModule };
|
|
2550
|
+
export { VisAnnotationsComponent, VisAnnotationsModule, VisAreaComponent, VisAreaModule, VisAxisComponent, VisAxisModule, VisBrushComponent, VisBrushModule, VisBulletLegendComponent, VisBulletLegendModule, VisChordDiagramComponent, VisChordDiagramModule, VisCoreComponent, VisCrosshairComponent, VisCrosshairModule, VisDonutComponent, VisDonutModule, VisFreeBrushComponent, VisFreeBrushModule, VisGenericComponent, VisGraphComponent, VisGraphModule, VisGroupedBarComponent, VisGroupedBarModule, VisLeafletFlowMapComponent, VisLeafletFlowMapModule, VisLeafletMapComponent, VisLeafletMapModule, VisLineComponent, VisLineModule, VisNestedDonutComponent, VisNestedDonutModule, VisSankeyComponent, VisSankeyModule, VisScatterComponent, VisScatterModule, VisSingleContainerComponent, VisSingleContainerModule, VisStackedBarComponent, VisStackedBarModule, VisTimelineComponent, VisTimelineModule, VisTooltipComponent, VisTooltipModule, VisTopoJSONMapComponent, VisTopoJSONMapModule, VisXYComponent, VisXYContainerComponent, VisXYContainerModule, VisXYLabelsComponent, VisXYLabelsModule };
|
|
2530
2551
|
//# sourceMappingURL=unovis-angular.js.map
|