@unovis/angular 1.6.0-pre.2 → 1.6.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.
Files changed (30) hide show
  1. package/dist/lib/bundles/unovis-angular.umd.js +301 -16
  2. package/dist/lib/bundles/unovis-angular.umd.js.map +1 -1
  3. package/dist/lib/components/brush/brush.component.d.ts +1 -1
  4. package/dist/lib/components/crosshair/crosshair.component.d.ts +21 -8
  5. package/dist/lib/components/graph/graph.component.d.ts +9 -1
  6. package/dist/lib/components/nested-donut/nested-donut.component.d.ts +1 -1
  7. package/dist/lib/components/plotband/plotband.component.d.ts +81 -0
  8. package/dist/lib/components/plotband/plotband.module.d.ts +7 -0
  9. package/dist/lib/components/plotline/plotline.component.d.ts +87 -0
  10. package/dist/lib/components/plotline/plotline.module.d.ts +7 -0
  11. package/dist/lib/components/timeline/timeline.component.d.ts +60 -15
  12. package/dist/lib/components.d.ts +6 -0
  13. package/dist/lib/esm2015/components/brush/brush.component.js +1 -1
  14. package/dist/lib/esm2015/components/crosshair/crosshair.component.js +8 -4
  15. package/dist/lib/esm2015/components/graph/graph.component.js +8 -4
  16. package/dist/lib/esm2015/components/nested-donut/nested-donut.component.js +1 -1
  17. package/dist/lib/esm2015/components/plotband/plotband.component.js +61 -0
  18. package/dist/lib/esm2015/components/plotband/plotband.module.js +18 -0
  19. package/dist/lib/esm2015/components/plotline/plotline.component.js +63 -0
  20. package/dist/lib/esm2015/components/plotline/plotline.module.js +18 -0
  21. package/dist/lib/esm2015/components/timeline/timeline.component.js +53 -11
  22. package/dist/lib/esm2015/components.js +7 -1
  23. package/dist/lib/esm2015/html-components/rolling-pin-legend/rolling-pin-legend.component.js +48 -0
  24. package/dist/lib/esm2015/html-components/rolling-pin-legend/rolling-pin-legend.module.js +18 -0
  25. package/dist/lib/fesm2015/unovis-angular.js +273 -18
  26. package/dist/lib/fesm2015/unovis-angular.js.map +1 -1
  27. package/dist/lib/html-components/rolling-pin-legend/rolling-pin-legend.component.d.ts +24 -0
  28. package/dist/lib/html-components/rolling-pin-legend/rolling-pin-legend.module.d.ts +7 -0
  29. package/dist/lib/package.json +2 -2
  30. package/package.json +2 -2
@@ -21,8 +21,8 @@ export class VisTimelineComponent {
21
21
  (_c = this.componentContainer) === null || _c === void 0 ? void 0 : _c.render();
22
22
  }
23
23
  getConfig() {
24
- const { duration, events, attributes, x, id, color, xScale, yScale, excludeFromDomainCalculation, lineWidth, lineCap, rowHeight, length, type, cursor, showLabels, labelWidth, maxLabelWidth, alternatingRowColors, onScroll, showEmptySegments } = this;
25
- const config = { duration, events, attributes, x, id, color, xScale, yScale, excludeFromDomainCalculation, lineWidth, lineCap, rowHeight, length, type, cursor, showLabels, labelWidth, maxLabelWidth, alternatingRowColors, onScroll, showEmptySegments };
24
+ const { duration, events, attributes, x, id, color, xScale, yScale, excludeFromDomainCalculation, type, length, cursor, lineRow, lineDuration, lineWidth, lineCap, lineStartIcon, lineStartIconColor, lineStartIconSize, lineStartIconArrangement, lineEndIcon, lineEndIconColor, lineEndIconSize, lineEndIconArrangement, lineCursor, showEmptySegments, rowHeight, alternatingRowColors, showLabels, labelWidth, maxLabelWidth, showRowLabels, rowLabelStyle, rowLabelFormatter, rowIcon, rowLabelWidth, rowMaxLabelWidth, rowLabelTextAlign, arrows, animationLineEnterPosition, animationLineExitPosition, onScroll } = this;
25
+ const config = { duration, events, attributes, x, id, color, xScale, yScale, excludeFromDomainCalculation, type, length, cursor, lineRow, lineDuration, lineWidth, lineCap, lineStartIcon, lineStartIconColor, lineStartIconSize, lineStartIconArrangement, lineEndIcon, lineEndIconColor, lineEndIconSize, lineEndIconArrangement, lineCursor, showEmptySegments, rowHeight, alternatingRowColors, showLabels, labelWidth, maxLabelWidth, showRowLabels, rowLabelStyle, rowLabelFormatter, rowIcon, rowLabelWidth, rowMaxLabelWidth, rowLabelTextAlign, arrows, animationLineEnterPosition, animationLineExitPosition, onScroll };
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 VisTimelineComponent {
30
30
  }
31
31
  }
32
32
  VisTimelineComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisTimelineComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
33
- VisTimelineComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisTimelineComponent, selector: "vis-timeline", inputs: { duration: "duration", events: "events", attributes: "attributes", x: "x", id: "id", color: "color", xScale: "xScale", yScale: "yScale", excludeFromDomainCalculation: "excludeFromDomainCalculation", lineWidth: "lineWidth", lineCap: "lineCap", rowHeight: "rowHeight", length: "length", type: "type", cursor: "cursor", showLabels: "showLabels", labelWidth: "labelWidth", maxLabelWidth: "maxLabelWidth", alternatingRowColors: "alternatingRowColors", onScroll: "onScroll", showEmptySegments: "showEmptySegments", data: "data" }, providers: [{ provide: VisXYComponent, useExisting: VisTimelineComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
33
+ VisTimelineComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisTimelineComponent, selector: "vis-timeline", inputs: { duration: "duration", events: "events", attributes: "attributes", x: "x", id: "id", color: "color", xScale: "xScale", yScale: "yScale", excludeFromDomainCalculation: "excludeFromDomainCalculation", type: "type", length: "length", cursor: "cursor", lineRow: "lineRow", lineDuration: "lineDuration", lineWidth: "lineWidth", lineCap: "lineCap", lineStartIcon: "lineStartIcon", lineStartIconColor: "lineStartIconColor", lineStartIconSize: "lineStartIconSize", lineStartIconArrangement: "lineStartIconArrangement", lineEndIcon: "lineEndIcon", lineEndIconColor: "lineEndIconColor", lineEndIconSize: "lineEndIconSize", lineEndIconArrangement: "lineEndIconArrangement", lineCursor: "lineCursor", showEmptySegments: "showEmptySegments", rowHeight: "rowHeight", alternatingRowColors: "alternatingRowColors", showLabels: "showLabels", labelWidth: "labelWidth", maxLabelWidth: "maxLabelWidth", showRowLabels: "showRowLabels", rowLabelStyle: "rowLabelStyle", rowLabelFormatter: "rowLabelFormatter", rowIcon: "rowIcon", rowLabelWidth: "rowLabelWidth", rowMaxLabelWidth: "rowMaxLabelWidth", rowLabelTextAlign: "rowLabelTextAlign", arrows: "arrows", animationLineEnterPosition: "animationLineEnterPosition", animationLineExitPosition: "animationLineExitPosition", onScroll: "onScroll", data: "data" }, providers: [{ provide: VisXYComponent, useExisting: VisTimelineComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
34
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisTimelineComponent, decorators: [{
35
35
  type: Component,
36
36
  args: [{
@@ -57,17 +57,43 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
57
57
  type: Input
58
58
  }], excludeFromDomainCalculation: [{
59
59
  type: Input
60
+ }], type: [{
61
+ type: Input
62
+ }], length: [{
63
+ type: Input
64
+ }], cursor: [{
65
+ type: Input
66
+ }], lineRow: [{
67
+ type: Input
68
+ }], lineDuration: [{
69
+ type: Input
60
70
  }], lineWidth: [{
61
71
  type: Input
62
72
  }], lineCap: [{
63
73
  type: Input
64
- }], rowHeight: [{
74
+ }], lineStartIcon: [{
65
75
  type: Input
66
- }], length: [{
76
+ }], lineStartIconColor: [{
67
77
  type: Input
68
- }], type: [{
78
+ }], lineStartIconSize: [{
69
79
  type: Input
70
- }], cursor: [{
80
+ }], lineStartIconArrangement: [{
81
+ type: Input
82
+ }], lineEndIcon: [{
83
+ type: Input
84
+ }], lineEndIconColor: [{
85
+ type: Input
86
+ }], lineEndIconSize: [{
87
+ type: Input
88
+ }], lineEndIconArrangement: [{
89
+ type: Input
90
+ }], lineCursor: [{
91
+ type: Input
92
+ }], showEmptySegments: [{
93
+ type: Input
94
+ }], rowHeight: [{
95
+ type: Input
96
+ }], alternatingRowColors: [{
71
97
  type: Input
72
98
  }], showLabels: [{
73
99
  type: Input
@@ -75,13 +101,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
75
101
  type: Input
76
102
  }], maxLabelWidth: [{
77
103
  type: Input
78
- }], alternatingRowColors: [{
104
+ }], showRowLabels: [{
79
105
  type: Input
80
- }], onScroll: [{
106
+ }], rowLabelStyle: [{
81
107
  type: Input
82
- }], showEmptySegments: [{
108
+ }], rowLabelFormatter: [{
109
+ type: Input
110
+ }], rowIcon: [{
111
+ type: Input
112
+ }], rowLabelWidth: [{
113
+ type: Input
114
+ }], rowMaxLabelWidth: [{
115
+ type: Input
116
+ }], rowLabelTextAlign: [{
117
+ type: Input
118
+ }], arrows: [{
119
+ type: Input
120
+ }], animationLineEnterPosition: [{
121
+ type: Input
122
+ }], animationLineExitPosition: [{
123
+ type: Input
124
+ }], onScroll: [{
83
125
  type: Input
84
126
  }], data: [{
85
127
  type: Input
86
128
  }] } });
87
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timeline.component.js","sourceRoot":"","sources":["../../../../../src/components/timeline/timeline.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  Timeline,\n  TimelineConfigInterface,\n  ContainerCore,\n  VisEventType,\n  VisEventCallback,\n  NumericAccessor,\n  ColorAccessor,\n  ContinuousScale,\n  StringAccessor,\n} from '@unovis/ts'\nimport { VisXYComponent } from '../../core'\n\n@Component({\n  selector: 'vis-timeline',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisXYComponent, useExisting: VisTimelineComponent }],\n})\nexport class VisTimelineComponent<Datum> implements TimelineConfigInterface<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  /** 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  /** Timeline item color accessor function. Default: `d => d.color` */\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  /** Width of the timeline items. Default: `8` */\n  @Input() lineWidth?: NumericAccessor<Datum>\n\n  /** Display rounded ends for timeline items. Default: `true` */\n  @Input() lineCap?: boolean\n\n  /** Timeline row height. Default: `22` */\n  @Input() rowHeight?: number\n\n  /** Timeline item length accessor function. Default: `d => d.length` */\n  @Input() length?: NumericAccessor<Datum>\n\n  /** Timeline item type accessor function. Records of one type will be plotted in one row. Default: `d => d.type` */\n  @Input() type?: StringAccessor<Datum>\n\n  /** Configurable Timeline item cursor when hovering over. Default: `null` */\n  @Input() cursor?: StringAccessor<Datum>\n\n  /** Show item type labels when set to `true`. Default: `false` */\n  @Input() showLabels?: boolean\n\n  /** Fixed label width in pixels. Labels longer than the specified value will be trimmed. Default: `undefined` */\n  @Input() labelWidth?: number\n\n  /** Maximum label width in pixels. Labels longer than the specified value will be trimmed. Default: `120` */\n  @Input() maxLabelWidth?: number\n\n  /** Alternating row colors. Default: `true` */\n  @Input() alternatingRowColors?: boolean\n\n  /** Scrolling callback function: `(scrollTop: number) => void`. Default: `undefined` */\n  @Input() onScroll?: (scrollTop: number) => void\n\n  /** Sets the minimum line length to 1 pixel for better visibility of small values. Default: `false` */\n  @Input() showEmptySegments?: boolean\n  @Input() data: Datum[]\n\n  component: Timeline<Datum> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new Timeline<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 (): TimelineConfigInterface<Datum> {\n    const { duration, events, attributes, x, id, color, xScale, yScale, excludeFromDomainCalculation, lineWidth, lineCap, rowHeight, length, type, cursor, showLabels, labelWidth, maxLabelWidth, alternatingRowColors, onScroll, showEmptySegments } = this\n    const config = { duration, events, attributes, x, id, color, xScale, yScale, excludeFromDomainCalculation, lineWidth, lineCap, rowHeight, length, type, cursor, showLabels, labelWidth, maxLabelWidth, alternatingRowColors, onScroll, showEmptySegments }\n    const keys = Object.keys(config) as (keyof TimelineConfigInterface<Datum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timeline.component.js","sourceRoot":"","sources":["../../../../../src/components/timeline/timeline.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  Timeline,\n  TimelineConfigInterface,\n  ContainerCore,\n  VisEventType,\n  VisEventCallback,\n  NumericAccessor,\n  ColorAccessor,\n  ContinuousScale,\n  StringAccessor,\n  GenericAccessor,\n  Arrangement,\n  TimelineRowLabel,\n  TimelineRowIcon,\n  TextAlign,\n  TimelineArrow,\n  TimelineLineRenderState,\n} from '@unovis/ts'\nimport { VisXYComponent } from '../../core'\n\n@Component({\n  selector: 'vis-timeline',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisXYComponent, useExisting: VisTimelineComponent }],\n})\nexport class VisTimelineComponent<Datum> implements TimelineConfigInterface<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  /** 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  /** Timeline item color accessor function. Default: `d => d.color` */\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  /**  */\n  @Input() type?: StringAccessor<Datum>\n\n  /**  */\n  @Input() length?: NumericAccessor<Datum>\n\n  /**  */\n  @Input() cursor?: StringAccessor<Datum>\n\n  /** Timeline item row accessor function. Records with the `lineRow` will be plotted in one row. Default: `undefined` */\n  @Input() lineRow?: StringAccessor<Datum>\n\n  /** Timeline item duration accessor function. Default: `undefined`. Falls back to the deprecated `length` property */\n  @Input() lineDuration?: NumericAccessor<Datum>\n\n  /** Width of the timeline items. Default: `8` */\n  @Input() lineWidth?: NumericAccessor<Datum>\n\n  /** Display rounded ends for timeline items. Default: `true` */\n  @Input() lineCap?: boolean\n\n  /** Provide a href to an SVG defined in container's `svgDefs` to display an icon at the start of the line. Default: undefined */\n  @Input() lineStartIcon?: StringAccessor<Datum>\n\n  /** Line start icon color accessor function. Default: `undefined` */\n  @Input() lineStartIconColor?: StringAccessor<Datum>\n\n  /** Line start icon size accessor function. Default: `undefined` */\n  @Input() lineStartIconSize?: NumericAccessor<Datum>\n\n  /** Line start icon arrangement configuration. Controls how the icon is positioned relative to the line.\n   * Accepts values from the Arrangement enum: `Arrangement.Start`, `Arrangement.Middle`, `Arrangement.End` or a string equivalent.\n   * Default: `Arrangement.Inside` */\n  @Input() lineStartIconArrangement?: GenericAccessor<Arrangement | any, Datum>\n\n  /** Provide a href to an SVG defined in container's `svgDefs` to display an icon at the end of the line. Default: undefined */\n  @Input() lineEndIcon?: StringAccessor<Datum>\n\n  /** Line end icon color accessor function. Default: `undefined` */\n  @Input() lineEndIconColor?: StringAccessor<Datum>\n\n  /** Line end icon size accessor function. Default: `undefined` */\n  @Input() lineEndIconSize?: NumericAccessor<Datum>\n\n  /** Line end icon arrangement configuration. Controls how the icon is positioned relative to the line.\n   * Accepts values from the Arrangement enum: `Arrangement.Start`, `Arrangement.Middle`, `Arrangement.End` or a string equivalent.\n   * Default: `Arrangement.Inside` */\n  @Input() lineEndIconArrangement?: GenericAccessor<Arrangement | any, Datum>\n\n  /** Configurable Timeline item cursor when hovering over. Default: `undefined` */\n  @Input() lineCursor?: StringAccessor<Datum>\n\n  /** Sets the minimum line length to 1 pixel for better visibility of small values. Default: `false` */\n  @Input() showEmptySegments?: boolean\n\n  /** Timeline row height. Default: `22` */\n  @Input() rowHeight?: number\n\n  /** Alternating row colors. Default: `true` */\n  @Input() alternatingRowColors?: boolean\n\n  /**  */\n  @Input() showLabels?: boolean\n\n  /**  */\n  @Input() labelWidth?: number\n\n  /**  */\n  @Input() maxLabelWidth?: number\n\n  /** Show row labels when set to `true`. Default: `false`. Falls back to deprecated `showLabels` */\n  @Input() showRowLabels?: boolean\n\n  /** Row label style as an object with the `{ [property-name]: value }` format. Default: `undefined` */\n  @Input() rowLabelStyle?: GenericAccessor<Record<string, string>, TimelineRowLabel<Datum>>\n\n  /** Row label formatter function. Default: `undefined` */\n  @Input() rowLabelFormatter?: (key: string, items: Datum[], i: number) => string\n\n  /** Provide an icon href to be displayed before the row label. Default: `undefined` */\n  @Input() rowIcon?: (key: string, items: Datum[], i: number) => TimelineRowIcon | undefined\n\n  /** Fixed label width in pixels. Labels longer than the specified value will be trimmed. Default: `undefined`. Falls back to deprecated `labelWidth`. */\n  @Input() rowLabelWidth?: number\n\n  /** Maximum label width in pixels. Labels longer than the specified value will be trimmed. Default: `undefined`. Falls back to deprecated `maxLabelWidth`. */\n  @Input() rowMaxLabelWidth?: number\n\n  /** Text alignment for labels: `TextAlign.Left`, `TextAlign.Center` or `TextAlign.Right`. Default: `TextAlign.Right` */\n  @Input() rowLabelTextAlign?: TextAlign | any\n\n\n  @Input() arrows?: TimelineArrow[]\n\n  /** Control the animation by specify the initial position for new lines as [x, y]. Default: `undefined` */\n  @Input() animationLineEnterPosition?: [number | undefined | null, number | undefined | null] | ((d: Datum & TimelineLineRenderState, i: number, data: (Datum & TimelineLineRenderState)[]) => [number | undefined, number | undefined]) | undefined\n\n  /** Control the animation by specify the destination position for exiting lines as [x, y]. Default: `undefined` */\n  @Input() animationLineExitPosition?: [number | undefined | null, number | undefined | null] | ((d: Datum & TimelineLineRenderState, i: number, data: (Datum & TimelineLineRenderState)[]) => [number | undefined, number | undefined]) | undefined\n\n  /** Scrolling callback function: `(scrollTop: number) => void`. Default: `undefined` */\n  @Input() onScroll?: (scrollTop: number) => void\n  @Input() data: Datum[]\n\n  component: Timeline<Datum> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new Timeline<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 (): TimelineConfigInterface<Datum> {\n    const { duration, events, attributes, x, id, color, xScale, yScale, excludeFromDomainCalculation, type, length, cursor, lineRow, lineDuration, lineWidth, lineCap, lineStartIcon, lineStartIconColor, lineStartIconSize, lineStartIconArrangement, lineEndIcon, lineEndIconColor, lineEndIconSize, lineEndIconArrangement, lineCursor, showEmptySegments, rowHeight, alternatingRowColors, showLabels, labelWidth, maxLabelWidth, showRowLabels, rowLabelStyle, rowLabelFormatter, rowIcon, rowLabelWidth, rowMaxLabelWidth, rowLabelTextAlign, arrows, animationLineEnterPosition, animationLineExitPosition, onScroll } = this\n    const config = { duration, events, attributes, x, id, color, xScale, yScale, excludeFromDomainCalculation, type, length, cursor, lineRow, lineDuration, lineWidth, lineCap, lineStartIcon, lineStartIconColor, lineStartIconSize, lineStartIconArrangement, lineEndIcon, lineEndIconColor, lineEndIconSize, lineEndIconArrangement, lineCursor, showEmptySegments, rowHeight, alternatingRowColors, showLabels, labelWidth, maxLabelWidth, showRowLabels, rowLabelStyle, rowLabelFormatter, rowIcon, rowLabelWidth, rowMaxLabelWidth, rowLabelTextAlign, arrows, animationLineEnterPosition, animationLineExitPosition, onScroll }\n    const keys = Object.keys(config) as (keyof TimelineConfigInterface<Datum>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
@@ -25,6 +25,8 @@ export { VisLineComponent } from './components/line/line.component';
25
25
  export { VisLineModule } from './components/line/line.module';
26
26
  export { VisNestedDonutComponent } from './components/nested-donut/nested-donut.component';
27
27
  export { VisNestedDonutModule } from './components/nested-donut/nested-donut.module';
28
+ export { VisPlotlineComponent } from './components/plotline/plotline.component';
29
+ export { VisPlotlineModule } from './components/plotline/plotline.module';
28
30
  export { VisSankeyComponent } from './components/sankey/sankey.component';
29
31
  export { VisSankeyModule } from './components/sankey/sankey.module';
30
32
  export { VisScatterComponent } from './components/scatter/scatter.component';
@@ -37,6 +39,8 @@ export { VisXYLabelsComponent } from './components/xy-labels/xy-labels.component
37
39
  export { VisXYLabelsModule } from './components/xy-labels/xy-labels.module';
38
40
  export { VisTopoJSONMapComponent } from './components/topojson-map/topojson-map.component';
39
41
  export { VisTopoJSONMapModule } from './components/topojson-map/topojson-map.module';
42
+ export { VisPlotbandComponent } from './components/plotband/plotband.component';
43
+ export { VisPlotbandModule } from './components/plotband/plotband.module';
40
44
  // HTML Components
41
45
  export { VisLeafletMapComponent } from './html-components/leaflet-map/leaflet-map.component';
42
46
  export { VisLeafletMapModule } from './html-components/leaflet-map/leaflet-map.module';
@@ -44,6 +48,8 @@ export { VisLeafletFlowMapComponent } from './html-components/leaflet-flow-map/l
44
48
  export { VisLeafletFlowMapModule } from './html-components/leaflet-flow-map/leaflet-flow-map.module';
45
49
  export { VisBulletLegendComponent } from './html-components/bullet-legend/bullet-legend.component';
46
50
  export { VisBulletLegendModule } from './html-components/bullet-legend/bullet-legend.module';
51
+ export { VisRollingPinLegendComponent } from './html-components/rolling-pin-legend/rolling-pin-legend.component';
52
+ export { VisRollingPinLegendModule } from './html-components/rolling-pin-legend/rolling-pin-legend.module';
47
53
  export { VisTooltipComponent } from './components/tooltip/tooltip.component';
48
54
  export { VisTooltipModule } from './components/tooltip/tooltip.module';
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU87QUFDUCxjQUFjLFFBQVEsQ0FBQTtBQUV0QixpQkFBaUI7QUFDakIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0NBQWtDLENBQUE7QUFDbkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLCtCQUErQixDQUFBO0FBRTdELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGdEQUFnRCxDQUFBO0FBQ3hGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDZDQUE2QyxDQUFBO0FBRWxGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBQ25FLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQTtBQUU3RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQTtBQUN0RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0saUNBQWlDLENBQUE7QUFFaEUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sb0RBQW9ELENBQUE7QUFDN0YsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saURBQWlELENBQUE7QUFFdkYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sNENBQTRDLENBQUE7QUFDbEYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUNBQXlDLENBQUE7QUFFNUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0NBQW9DLENBQUE7QUFDdEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGlDQUFpQyxDQUFBO0FBRWhFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDhDQUE4QyxDQUFBO0FBQ3BGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFBO0FBRTlFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFBO0FBQ3RFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQTtBQUVoRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQTtBQUN2RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQTtBQUVqRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQTtBQUNuRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sK0JBQStCLENBQUE7QUFFN0QsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sa0RBQWtELENBQUE7QUFDMUYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sK0NBQStDLENBQUE7QUFFcEYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sc0NBQXNDLENBQUE7QUFDekUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1DQUFtQyxDQUFBO0FBRW5FLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFBO0FBQzVFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFBO0FBRXRFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFBO0FBQ3ZGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFBO0FBRWpGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFBO0FBQy9FLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFBO0FBRXpFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFBO0FBQ2pGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFBO0FBRTNFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGtEQUFrRCxDQUFBO0FBQzFGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLCtDQUErQyxDQUFBO0FBRXBGLGtCQUFrQjtBQUNsQixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxxREFBcUQsQ0FBQTtBQUM1RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxrREFBa0QsQ0FBQTtBQUV0RixPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSwrREFBK0QsQ0FBQTtBQUMxRyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQTtBQUVwRyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx5REFBeUQsQ0FBQTtBQUNsRyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQTtBQUU1RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQTtBQUM1RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcmVcbmV4cG9ydCAqIGZyb20gJy4vY29yZSdcblxuLy8gU1ZHIENvbXBvbmVudHNcbmV4cG9ydCB7IFZpc0FyZWFDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYXJlYS9hcmVhLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc0FyZWFNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvYXJlYS9hcmVhLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzQW5ub3RhdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYW5ub3RhdGlvbnMvYW5ub3RhdGlvbnMuY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzQW5ub3RhdGlvbnNNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvYW5ub3RhdGlvbnMvYW5ub3RhdGlvbnMubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNBeGlzQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2F4aXMvYXhpcy5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNBeGlzTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2F4aXMvYXhpcy5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc0JydXNoQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2JydXNoL2JydXNoLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc0JydXNoTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2JydXNoL2JydXNoLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzQ2hvcmREaWFncmFtQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2Nob3JkLWRpYWdyYW0vY2hvcmQtZGlhZ3JhbS5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNDaG9yZERpYWdyYW1Nb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvY2hvcmQtZGlhZ3JhbS9jaG9yZC1kaWFncmFtLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzQ3Jvc3NoYWlyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2Nyb3NzaGFpci9jcm9zc2hhaXIuY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzQ3Jvc3NoYWlyTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2Nyb3NzaGFpci9jcm9zc2hhaXIubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNEb251dENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9kb251dC9kb251dC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNEb251dE1vZHVsZSB9IGZyb20gJy4vY29tcG9uZW50cy9kb251dC9kb251dC5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc0ZyZWVCcnVzaENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9mcmVlLWJydXNoL2ZyZWUtYnJ1c2guY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzRnJlZUJydXNoTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2ZyZWUtYnJ1c2gvZnJlZS1icnVzaC5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc0dyYXBoQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2dyYXBoL2dyYXBoLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc0dyYXBoTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2dyYXBoL2dyYXBoLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzR3JvdXBlZEJhckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9ncm91cGVkLWJhci9ncm91cGVkLWJhci5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNHcm91cGVkQmFyTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2dyb3VwZWQtYmFyL2dyb3VwZWQtYmFyLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzTGluZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9saW5lL2xpbmUuY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzTGluZU1vZHVsZSB9IGZyb20gJy4vY29tcG9uZW50cy9saW5lL2xpbmUubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNOZXN0ZWREb251dENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9uZXN0ZWQtZG9udXQvbmVzdGVkLWRvbnV0LmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc05lc3RlZERvbnV0TW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL25lc3RlZC1kb251dC9uZXN0ZWQtZG9udXQubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNTYW5rZXlDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvc2Fua2V5L3NhbmtleS5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNTYW5rZXlNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvc2Fua2V5L3NhbmtleS5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc1NjYXR0ZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvc2NhdHRlci9zY2F0dGVyLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc1NjYXR0ZXJNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvc2NhdHRlci9zY2F0dGVyLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzU3RhY2tlZEJhckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9zdGFja2VkLWJhci9zdGFja2VkLWJhci5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNTdGFja2VkQmFyTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL3N0YWNrZWQtYmFyL3N0YWNrZWQtYmFyLm1vZHVsZSdcblxuZXhwb3J0IHsgVmlzVGltZWxpbmVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdGltZWxpbmUvdGltZWxpbmUuY29tcG9uZW50J1xuZXhwb3J0IHsgVmlzVGltZWxpbmVNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvdGltZWxpbmUvdGltZWxpbmUubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNYWUxhYmVsc0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy94eS1sYWJlbHMveHktbGFiZWxzLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc1hZTGFiZWxzTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL3h5LWxhYmVscy94eS1sYWJlbHMubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNUb3BvSlNPTk1hcENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90b3BvanNvbi1tYXAvdG9wb2pzb24tbWFwLmNvbXBvbmVudCdcbmV4cG9ydCB7IFZpc1RvcG9KU09OTWFwTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL3RvcG9qc29uLW1hcC90b3BvanNvbi1tYXAubW9kdWxlJ1xuXG4vLyBIVE1MIENvbXBvbmVudHNcbmV4cG9ydCB7IFZpc0xlYWZsZXRNYXBDb21wb25lbnQgfSBmcm9tICcuL2h0bWwtY29tcG9uZW50cy9sZWFmbGV0LW1hcC9sZWFmbGV0LW1hcC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNMZWFmbGV0TWFwTW9kdWxlIH0gZnJvbSAnLi9odG1sLWNvbXBvbmVudHMvbGVhZmxldC1tYXAvbGVhZmxldC1tYXAubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNMZWFmbGV0Rmxvd01hcENvbXBvbmVudCB9IGZyb20gJy4vaHRtbC1jb21wb25lbnRzL2xlYWZsZXQtZmxvdy1tYXAvbGVhZmxldC1mbG93LW1hcC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNMZWFmbGV0Rmxvd01hcE1vZHVsZSB9IGZyb20gJy4vaHRtbC1jb21wb25lbnRzL2xlYWZsZXQtZmxvdy1tYXAvbGVhZmxldC1mbG93LW1hcC5tb2R1bGUnXG5cbmV4cG9ydCB7IFZpc0J1bGxldExlZ2VuZENvbXBvbmVudCB9IGZyb20gJy4vaHRtbC1jb21wb25lbnRzL2J1bGxldC1sZWdlbmQvYnVsbGV0LWxlZ2VuZC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNCdWxsZXRMZWdlbmRNb2R1bGUgfSBmcm9tICcuL2h0bWwtY29tcG9uZW50cy9idWxsZXQtbGVnZW5kL2J1bGxldC1sZWdlbmQubW9kdWxlJ1xuXG5leHBvcnQgeyBWaXNUb29sdGlwQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQnXG5leHBvcnQgeyBWaXNUb29sdGlwTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL3Rvb2x0aXAvdG9vbHRpcC5tb2R1bGUnXG4iXX0=
55
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.js","sourceRoot":"","sources":["../../../src/components.ts"],"names":[],"mappings":"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","sourcesContent":["// Core\nexport * from './core'\n\n// SVG Components\nexport { VisAreaComponent } from './components/area/area.component'\nexport { VisAreaModule } from './components/area/area.module'\n\nexport { VisAnnotationsComponent } from './components/annotations/annotations.component'\nexport { VisAnnotationsModule } from './components/annotations/annotations.module'\n\nexport { VisAxisComponent } from './components/axis/axis.component'\nexport { VisAxisModule } from './components/axis/axis.module'\n\nexport { VisBrushComponent } from './components/brush/brush.component'\nexport { VisBrushModule } from './components/brush/brush.module'\n\nexport { VisChordDiagramComponent } from './components/chord-diagram/chord-diagram.component'\nexport { VisChordDiagramModule } from './components/chord-diagram/chord-diagram.module'\n\nexport { VisCrosshairComponent } from './components/crosshair/crosshair.component'\nexport { VisCrosshairModule } from './components/crosshair/crosshair.module'\n\nexport { VisDonutComponent } from './components/donut/donut.component'\nexport { VisDonutModule } from './components/donut/donut.module'\n\nexport { VisFreeBrushComponent } from './components/free-brush/free-brush.component'\nexport { VisFreeBrushModule } from './components/free-brush/free-brush.module'\n\nexport { VisGraphComponent } from './components/graph/graph.component'\nexport { VisGraphModule } from './components/graph/graph.module'\n\nexport { VisGroupedBarComponent } from './components/grouped-bar/grouped-bar.component'\nexport { VisGroupedBarModule } from './components/grouped-bar/grouped-bar.module'\n\nexport { VisLineComponent } from './components/line/line.component'\nexport { VisLineModule } from './components/line/line.module'\n\nexport { VisNestedDonutComponent } from './components/nested-donut/nested-donut.component'\nexport { VisNestedDonutModule } from './components/nested-donut/nested-donut.module'\n\nexport { VisPlotlineComponent } from './components/plotline/plotline.component'\nexport { VisPlotlineModule } from './components/plotline/plotline.module'\n\nexport { VisSankeyComponent } from './components/sankey/sankey.component'\nexport { VisSankeyModule } from './components/sankey/sankey.module'\n\nexport { VisScatterComponent } from './components/scatter/scatter.component'\nexport { VisScatterModule } from './components/scatter/scatter.module'\n\nexport { VisStackedBarComponent } from './components/stacked-bar/stacked-bar.component'\nexport { VisStackedBarModule } from './components/stacked-bar/stacked-bar.module'\n\nexport { VisTimelineComponent } from './components/timeline/timeline.component'\nexport { VisTimelineModule } from './components/timeline/timeline.module'\n\nexport { VisXYLabelsComponent } from './components/xy-labels/xy-labels.component'\nexport { VisXYLabelsModule } from './components/xy-labels/xy-labels.module'\n\nexport { VisTopoJSONMapComponent } from './components/topojson-map/topojson-map.component'\nexport { VisTopoJSONMapModule } from './components/topojson-map/topojson-map.module'\n\nexport { VisPlotbandComponent } from './components/plotband/plotband.component'\nexport { VisPlotbandModule } from './components/plotband/plotband.module'\n\n// HTML Components\nexport { VisLeafletMapComponent } from './html-components/leaflet-map/leaflet-map.component'\nexport { VisLeafletMapModule } from './html-components/leaflet-map/leaflet-map.module'\n\nexport { VisLeafletFlowMapComponent } from './html-components/leaflet-flow-map/leaflet-flow-map.component'\nexport { VisLeafletFlowMapModule } from './html-components/leaflet-flow-map/leaflet-flow-map.module'\n\nexport { VisBulletLegendComponent } from './html-components/bullet-legend/bullet-legend.component'\nexport { VisBulletLegendModule } from './html-components/bullet-legend/bullet-legend.module'\n\nexport { VisRollingPinLegendComponent } from './html-components/rolling-pin-legend/rolling-pin-legend.component'\nexport { VisRollingPinLegendModule } from './html-components/rolling-pin-legend/rolling-pin-legend.module'\n\nexport { VisTooltipComponent } from './components/tooltip/tooltip.component'\nexport { VisTooltipModule } from './components/tooltip/tooltip.module'\n"]}
@@ -0,0 +1,48 @@
1
+ // !!! This code was automatically generated. You should not change it !!!
2
+ import { Component, Input, ViewChild } from '@angular/core';
3
+ import { RollingPinLegend } from '@unovis/ts';
4
+ import { VisGenericComponent } from '../../core';
5
+ import * as i0 from "@angular/core";
6
+ export class VisRollingPinLegendComponent {
7
+ ngAfterViewInit() {
8
+ this.component = new RollingPinLegend(this.containerRef.nativeElement, this.getConfig());
9
+ }
10
+ ngOnChanges(changes) {
11
+ var _a;
12
+ (_a = this.component) === null || _a === void 0 ? void 0 : _a.setConfig(this.getConfig());
13
+ }
14
+ getConfig() {
15
+ const { rects, leftLabelText, rightLabelText, labelClassName, labelFontSize } = this;
16
+ const config = { rects, leftLabelText, rightLabelText, labelClassName, labelFontSize };
17
+ const keys = Object.keys(config);
18
+ keys.forEach(key => { if (config[key] === undefined)
19
+ delete config[key]; });
20
+ return config;
21
+ }
22
+ }
23
+ VisRollingPinLegendComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisRollingPinLegendComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
24
+ VisRollingPinLegendComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisRollingPinLegendComponent, selector: "vis-rolling-pin-legend", inputs: { rects: "rects", leftLabelText: "leftLabelText", rightLabelText: "rightLabelText", labelClassName: "labelClassName", labelFontSize: "labelFontSize" }, providers: [{ provide: VisGenericComponent, useExisting: VisRollingPinLegendComponent }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: '<div #container class="rolling-pin-legend-container"></div>', isInline: true, styles: [".rolling-pin-legend-container { }"] });
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisRollingPinLegendComponent, decorators: [{
26
+ type: Component,
27
+ args: [{
28
+ selector: 'vis-rolling-pin-legend',
29
+ template: '<div #container class="rolling-pin-legend-container"></div>',
30
+ styles: ['.rolling-pin-legend-container { }'],
31
+ // eslint-disable-next-line no-use-before-define
32
+ providers: [{ provide: VisGenericComponent, useExisting: VisRollingPinLegendComponent }],
33
+ }]
34
+ }], propDecorators: { containerRef: [{
35
+ type: ViewChild,
36
+ args: ['container', { static: false }]
37
+ }], rects: [{
38
+ type: Input
39
+ }], leftLabelText: [{
40
+ type: Input
41
+ }], rightLabelText: [{
42
+ type: Input
43
+ }], labelClassName: [{
44
+ type: Input
45
+ }], labelFontSize: [{
46
+ type: Input
47
+ }] } });
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9sbGluZy1waW4tbGVnZW5kLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9odG1sLWNvbXBvbmVudHMvcm9sbGluZy1waW4tbGVnZW5kL3JvbGxpbmctcGluLWxlZ2VuZC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMEVBQTBFO0FBQzFFLE9BQU8sRUFBRSxTQUFTLEVBQWlCLEtBQUssRUFBaUIsU0FBUyxFQUFjLE1BQU0sZUFBZSxDQUFBO0FBQ3JHLE9BQU8sRUFBRSxnQkFBZ0IsRUFBeUQsTUFBTSxZQUFZLENBQUE7QUFDcEcsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sWUFBWSxDQUFBOztBQVNoRCxNQUFNLE9BQU8sNEJBQTRCO0lBc0J2QyxlQUFlO1FBQ2IsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLGdCQUFnQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFBO0lBQzFGLENBQUM7SUFFRCxXQUFXLENBQUUsT0FBc0I7O1FBQ2pDLE1BQUEsSUFBSSxDQUFDLFNBQVMsMENBQUUsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFBO0lBQzdDLENBQUM7SUFFTyxTQUFTO1FBQ2YsTUFBTSxFQUFFLEtBQUssRUFBRSxhQUFhLEVBQUUsY0FBYyxFQUFFLGNBQWMsRUFBRSxhQUFhLEVBQUUsR0FBRyxJQUFJLENBQUE7UUFDcEYsTUFBTSxNQUFNLEdBQUcsRUFBRSxLQUFLLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxjQUFjLEVBQUUsYUFBYSxFQUFFLENBQUE7UUFDdEYsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQThDLENBQUE7UUFDN0UsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxHQUFHLElBQUksTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLFNBQVM7WUFBRSxPQUFPLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQSxDQUFDLENBQUMsQ0FBQyxDQUFBO1FBRTFFLE9BQU8sTUFBTSxDQUFBO0lBQ2YsQ0FBQzs7MEhBckNVLDRCQUE0Qjs4R0FBNUIsNEJBQTRCLGlOQUY1QixDQUFDLEVBQUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFdBQVcsRUFBRSw0QkFBNEIsRUFBRSxDQUFDLDBKQUg5RSw2REFBNkQ7NEZBSzVELDRCQUE0QjtrQkFQeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsd0JBQXdCO29CQUNsQyxRQUFRLEVBQUUsNkRBQTZEO29CQUN2RSxNQUFNLEVBQUUsQ0FBQyxvQ0FBb0MsQ0FBQztvQkFDOUMsZ0RBQWdEO29CQUNoRCxTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxXQUFXLDhCQUE4QixFQUFFLENBQUM7aUJBQ3pGOzhCQUU0QyxZQUFZO3NCQUF0RCxTQUFTO3VCQUFDLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUU7Z0JBS2hDLEtBQUs7c0JBQWIsS0FBSztnQkFHRyxhQUFhO3NCQUFyQixLQUFLO2dCQUdHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBR0csY0FBYztzQkFBdEIsS0FBSztnQkFHRyxhQUFhO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gISEhIFRoaXMgY29kZSB3YXMgYXV0b21hdGljYWxseSBnZW5lcmF0ZWQuIFlvdSBzaG91bGQgbm90IGNoYW5nZSBpdCAhISFcbmltcG9ydCB7IENvbXBvbmVudCwgQWZ0ZXJWaWV3SW5pdCwgSW5wdXQsIFNpbXBsZUNoYW5nZXMsIFZpZXdDaGlsZCwgRWxlbWVudFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBSb2xsaW5nUGluTGVnZW5kLCBSb2xsaW5nUGluTGVnZW5kQ29uZmlnSW50ZXJmYWNlLCBSb2xsaW5nUGluTGVnZW5kSXRlbSB9IGZyb20gJ0B1bm92aXMvdHMnXG5pbXBvcnQgeyBWaXNHZW5lcmljQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29yZSdcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmlzLXJvbGxpbmctcGluLWxlZ2VuZCcsXG4gIHRlbXBsYXRlOiAnPGRpdiAjY29udGFpbmVyIGNsYXNzPVwicm9sbGluZy1waW4tbGVnZW5kLWNvbnRhaW5lclwiPjwvZGl2PicsXG4gIHN0eWxlczogWycucm9sbGluZy1waW4tbGVnZW5kLWNvbnRhaW5lciB7ICB9J10sXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby11c2UtYmVmb3JlLWRlZmluZVxuICBwcm92aWRlcnM6IFt7IHByb3ZpZGU6IFZpc0dlbmVyaWNDb21wb25lbnQsIHVzZUV4aXN0aW5nOiBWaXNSb2xsaW5nUGluTGVnZW5kQ29tcG9uZW50IH1dLFxufSlcbmV4cG9ydCBjbGFzcyBWaXNSb2xsaW5nUGluTGVnZW5kQ29tcG9uZW50IGltcGxlbWVudHMgUm9sbGluZ1BpbkxlZ2VuZENvbmZpZ0ludGVyZmFjZSwgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBWaWV3Q2hpbGQoJ2NvbnRhaW5lcicsIHsgc3RhdGljOiBmYWxzZSB9KSBjb250YWluZXJSZWY6IEVsZW1lbnRSZWZcblxuICAvKiogUmVjdHMgZm9ybWluZyBhIGxlZ2VuZC4gQXJyYXkgb2YgYHN0cmluZ2AsIHJlcHJlc2VudGluZyBjb2xvcnMuXG4gICAqXG4gICAqIERlZmF1bHQ6IGBbXWAgKi9cbiAgQElucHV0KCkgcmVjdHM6IFJvbGxpbmdQaW5MZWdlbmRJdGVtW11cblxuICAvKiogTGFiZWwgb24gdGhlIGxlZnQgc2lkZSBvZiB0aGUgbGVnZW5kLiBEZWZhdWx0OiBgdW5kZWZpbmVkYCAqL1xuICBASW5wdXQoKSBsZWZ0TGFiZWxUZXh0Pzogc3RyaW5nXG5cbiAgLyoqIExhYmVsIG9uIHRoZSByaWdodCBzaWRlIG9mIHRoZSBsZWdlbmQuIERlZmF1bHQ6IGB1bmRlZmluZWRgICovXG4gIEBJbnB1dCgpIHJpZ2h0TGFiZWxUZXh0Pzogc3RyaW5nXG5cbiAgLyoqIEFwcGx5IGEgc3BlY2lmaWMgY2xhc3MgdG8gdGhlIGxhYmVscy4gRGVmYXVsdDogYCcnYCAqL1xuICBASW5wdXQoKSBsYWJlbENsYXNzTmFtZT86IHN0cmluZ1xuXG4gIC8qKiBMYWJlbCB0ZXh0ICg8c3Bhbj4gZWxlbWVudCkgZm9udC1zaXplIENTUy4gRGVmYXVsdDogYG51bGxgICovXG4gIEBJbnB1dCgpIGxhYmVsRm9udFNpemU/OiBzdHJpbmcgfCBudWxsXG5cbiAgY29tcG9uZW50OiBSb2xsaW5nUGluTGVnZW5kIHwgdW5kZWZpbmVkXG5cbiAgbmdBZnRlclZpZXdJbml0ICgpOiB2b2lkIHtcbiAgICB0aGlzLmNvbXBvbmVudCA9IG5ldyBSb2xsaW5nUGluTGVnZW5kKHRoaXMuY29udGFpbmVyUmVmLm5hdGl2ZUVsZW1lbnQsIHRoaXMuZ2V0Q29uZmlnKCkpXG4gIH1cblxuICBuZ09uQ2hhbmdlcyAoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIHRoaXMuY29tcG9uZW50Py5zZXRDb25maWcodGhpcy5nZXRDb25maWcoKSlcbiAgfVxuXG4gIHByaXZhdGUgZ2V0Q29uZmlnICgpOiBSb2xsaW5nUGluTGVnZW5kQ29uZmlnSW50ZXJmYWNlIHtcbiAgICBjb25zdCB7IHJlY3RzLCBsZWZ0TGFiZWxUZXh0LCByaWdodExhYmVsVGV4dCwgbGFiZWxDbGFzc05hbWUsIGxhYmVsRm9udFNpemUgfSA9IHRoaXNcbiAgICBjb25zdCBjb25maWcgPSB7IHJlY3RzLCBsZWZ0TGFiZWxUZXh0LCByaWdodExhYmVsVGV4dCwgbGFiZWxDbGFzc05hbWUsIGxhYmVsRm9udFNpemUgfVxuICAgIGNvbnN0IGtleXMgPSBPYmplY3Qua2V5cyhjb25maWcpIGFzIChrZXlvZiBSb2xsaW5nUGluTGVnZW5kQ29uZmlnSW50ZXJmYWNlKVtdXG4gICAga2V5cy5mb3JFYWNoKGtleSA9PiB7IGlmIChjb25maWdba2V5XSA9PT0gdW5kZWZpbmVkKSBkZWxldGUgY29uZmlnW2tleV0gfSlcblxuICAgIHJldHVybiBjb25maWdcbiAgfVxufVxuIl19
@@ -0,0 +1,18 @@
1
+ // !!! This code was automatically generated. You should not change it !!!
2
+ import { NgModule } from '@angular/core';
3
+ import { VisRollingPinLegendComponent } from './rolling-pin-legend.component';
4
+ import * as i0 from "@angular/core";
5
+ export class VisRollingPinLegendModule {
6
+ }
7
+ VisRollingPinLegendModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisRollingPinLegendModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
+ VisRollingPinLegendModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisRollingPinLegendModule, declarations: [VisRollingPinLegendComponent], exports: [VisRollingPinLegendComponent] });
9
+ VisRollingPinLegendModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisRollingPinLegendModule, imports: [[]] });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisRollingPinLegendModule, decorators: [{
11
+ type: NgModule,
12
+ args: [{
13
+ imports: [],
14
+ declarations: [VisRollingPinLegendComponent],
15
+ exports: [VisRollingPinLegendComponent],
16
+ }]
17
+ }] });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9sbGluZy1waW4tbGVnZW5kLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9odG1sLWNvbXBvbmVudHMvcm9sbGluZy1waW4tbGVnZW5kL3JvbGxpbmctcGluLWxlZ2VuZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMEVBQTBFO0FBQzFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDeEMsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sZ0NBQWdDLENBQUE7O0FBTzdFLE1BQU0sT0FBTyx5QkFBeUI7O3VIQUF6Qix5QkFBeUI7d0hBQXpCLHlCQUF5QixpQkFIckIsNEJBQTRCLGFBQ2pDLDRCQUE0Qjt3SEFFM0IseUJBQXlCLFlBSjNCLEVBQUU7NEZBSUEseUJBQXlCO2tCQUxyQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxFQUFFO29CQUNYLFlBQVksRUFBRSxDQUFDLDRCQUE0QixDQUFDO29CQUM1QyxPQUFPLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQztpQkFDeEMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyAhISEgVGhpcyBjb2RlIHdhcyBhdXRvbWF0aWNhbGx5IGdlbmVyYXRlZC4gWW91IHNob3VsZCBub3QgY2hhbmdlIGl0ICEhIVxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgVmlzUm9sbGluZ1BpbkxlZ2VuZENvbXBvbmVudCB9IGZyb20gJy4vcm9sbGluZy1waW4tbGVnZW5kLmNvbXBvbmVudCdcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW10sXG4gIGRlY2xhcmF0aW9uczogW1Zpc1JvbGxpbmdQaW5MZWdlbmRDb21wb25lbnRdLFxuICBleHBvcnRzOiBbVmlzUm9sbGluZ1BpbkxlZ2VuZENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFZpc1JvbGxpbmdQaW5MZWdlbmRNb2R1bGUge31cbiJdfQ==