@kirbydesign/designsystem 4.0.12 → 4.0.13

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.
@@ -1,4 +1,5 @@
1
1
  import { Component, ElementRef, HostBinding, Input, ViewChild, } from '@angular/core';
2
+ import { ResizeObserverFactory } from '../shared';
2
3
  import { ChartJSService } from './chart-js/chart-js.service';
3
4
  export class ChartComponent {
4
5
  constructor(chartJSService) {
@@ -9,7 +10,29 @@ export class ChartComponent {
9
10
  this._height = typeof value === 'number' ? `${value}px` : value;
10
11
  }
11
12
  ngAfterViewInit() {
12
- this.renderChart();
13
+ /*
14
+ A chart is not rendered until it has both a height and a width.
15
+ If ChartComponent is slotted in an ionic component it will
16
+ not have any height or width on afterViewInit. This will cause
17
+ the animation to not be played on first draw.
18
+ */
19
+ const canvasElement = this.canvasElement.nativeElement;
20
+ this.whenElementHasHeightAndWidth(canvasElement).then(() => this.renderChart());
21
+ }
22
+ whenElementHasHeightAndWidth(element) {
23
+ const rectIs2D = ({ width, height }) => height > 0 && width > 0;
24
+ return new Promise((resolve) => {
25
+ const initialClientRect = element.getBoundingClientRect();
26
+ if (rectIs2D(initialClientRect))
27
+ resolve();
28
+ const resizeObserver = new ResizeObserverFactory().create(([resizeObserverEntry]) => {
29
+ if (rectIs2D(resizeObserverEntry.contentRect)) {
30
+ resizeObserver.unobserve(element);
31
+ resolve();
32
+ }
33
+ });
34
+ resizeObserver.observe(element);
35
+ });
13
36
  }
14
37
  ngOnChanges(simpleChanges) {
15
38
  let shouldRedrawChart = false;
@@ -86,4 +109,4 @@ ChartComponent.propDecorators = {
86
109
  height: [{ type: Input }],
87
110
  canvasElement: [{ type: ViewChild, args: ['chartCanvas',] }]
88
111
  };
89
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ25zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2NoYXJ0L2NoYXJ0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFVBQVUsRUFDVixXQUFXLEVBQ1gsS0FBSyxFQUdMLFNBQVMsR0FDVixNQUFNLGVBQWUsQ0FBQztBQUl2QixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFTN0QsTUFBTSxPQUFPLGNBQWM7SUFpQnpCLFlBQW9CLGNBQThCO1FBQTlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQWhCekMsU0FBSSxHQUFjLFFBQVEsQ0FBQztJQWdCaUIsQ0FBQztJQVB0RCxJQUFhLE1BQU0sQ0FBQyxLQUFzQjtRQUN4QyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sS0FBSyxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQ2xFLENBQUM7SUFPRCxlQUFlO1FBQ2IsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxXQUFXLENBQUMsYUFBNEI7UUFDdEMsSUFBSSxpQkFBaUIsR0FBRyxLQUFLLENBQUM7UUFFOUIsTUFBTSxnQkFBZ0IsR0FBRztZQUN2QixJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUM3QixVQUFVLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFO1lBQ3pDLElBQUksRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQzdCLGFBQWEsRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLEVBQUU7WUFDL0MsV0FBVyxFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtZQUMzQyxtQkFBbUIsRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMseUJBQXlCLEVBQUU7U0FDNUQsQ0FBQztRQUVGLE1BQU0sQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFO1lBQzlDLElBQUksYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFdBQVcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQztnQkFBRSxPQUFPO1lBQ3JFLGlCQUFpQixHQUFHLElBQUksQ0FBQztZQUN6QixnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQzFCLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxpQkFBaUI7WUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDNUMsQ0FBQztJQUVPLFdBQVc7UUFDakIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUM7WUFDOUIsYUFBYSxFQUFFLElBQUksQ0FBQyxhQUFhO1lBQ2pDLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNmLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNmLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUMzQixhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWE7WUFDakMsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO1lBQzdCLG1CQUFtQixFQUFFLElBQUksQ0FBQyxtQkFBbUI7U0FDOUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVPLFVBQVU7UUFDaEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFTyxnQkFBZ0I7UUFDdEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDeEQsQ0FBQztJQUVPLFVBQVU7UUFDaEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDaEUsQ0FBQztJQUVPLG1CQUFtQjtRQUN6QixJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRU8saUJBQWlCO1FBQ3ZCLElBQUksQ0FBQyxjQUFjLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFTyx5QkFBeUI7UUFDL0IsSUFBSSxDQUFDLGNBQWMsQ0FBQyx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQztJQUMxRSxDQUFDO0lBRU8sV0FBVztRQUNqQixJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3BDLENBQUM7OztZQXhGRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGFBQWE7Z0JBQ3ZCLDRSQUFxQztnQkFFckMsU0FBUyxFQUFFLENBQUMsY0FBYyxDQUFDOzthQUM1Qjs7OztZQVJRLGNBQWM7OzttQkFVcEIsS0FBSzttQkFDTCxLQUFLO3lCQUNMLEtBQUs7NEJBQ0wsS0FBSzswQkFDTCxLQUFLO2tDQUNMLEtBQUs7c0JBRUwsV0FBVyxTQUFDLDRCQUE0QjtxQkFFeEMsS0FBSzs0QkFJTCxTQUFTLFNBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgSG9zdEJpbmRpbmcsXG4gIElucHV0LFxuICBPbkNoYW5nZXMsXG4gIFNpbXBsZUNoYW5nZXMsXG4gIFZpZXdDaGlsZCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGFydE9wdGlvbnMgfSBmcm9tICdjaGFydC5qcyc7XG5pbXBvcnQgeyBBbm5vdGF0aW9uT3B0aW9ucyB9IGZyb20gJ2NoYXJ0anMtcGx1Z2luLWFubm90YXRpb24nO1xuXG5pbXBvcnQgeyBDaGFydEpTU2VydmljZSB9IGZyb20gJy4vY2hhcnQtanMvY2hhcnQtanMuc2VydmljZSc7XG5pbXBvcnQgeyBDaGFydERhdGFzZXQsIENoYXJ0SGlnaGxpZ2h0ZWRFbGVtZW50cywgQ2hhcnRUeXBlIH0gZnJvbSAnLi9jaGFydC50eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2tpcmJ5LWNoYXJ0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NoYXJ0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2hhcnQuY29tcG9uZW50LnNjc3MnXSxcbiAgcHJvdmlkZXJzOiBbQ2hhcnRKU1NlcnZpY2VdLFxufSlcbmV4cG9ydCBjbGFzcyBDaGFydENvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpIHR5cGU6IENoYXJ0VHlwZSA9ICdjb2x1bW4nO1xuICBASW5wdXQoKSBkYXRhOiBDaGFydERhdGFzZXRbXSB8IG51bWJlcltdO1xuICBASW5wdXQoKSBkYXRhTGFiZWxzPzogc3RyaW5nW10gfCBzdHJpbmdbXVtdO1xuICBASW5wdXQoKSBjdXN0b21PcHRpb25zPzogQ2hhcnRPcHRpb25zO1xuICBASW5wdXQoKSBhbm5vdGF0aW9ucz86IEFubm90YXRpb25PcHRpb25zW107XG4gIEBJbnB1dCgpIGhpZ2hsaWdodGVkRWxlbWVudHM/OiBDaGFydEhpZ2hsaWdodGVkRWxlbWVudHM7XG5cbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS4tLWtpcmJ5LWNoYXJ0LWhlaWdodCcpXG4gIF9oZWlnaHQ6IHN0cmluZztcbiAgQElucHV0KCkgc2V0IGhlaWdodCh2YWx1ZTogc3RyaW5nIHwgbnVtYmVyKSB7XG4gICAgdGhpcy5faGVpZ2h0ID0gdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJyA/IGAke3ZhbHVlfXB4YCA6IHZhbHVlO1xuICB9XG5cbiAgQFZpZXdDaGlsZCgnY2hhcnRDYW52YXMnKVxuICBjYW52YXNFbGVtZW50OiBFbGVtZW50UmVmPEhUTUxDYW52YXNFbGVtZW50PjtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNoYXJ0SlNTZXJ2aWNlOiBDaGFydEpTU2VydmljZSkge31cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5yZW5kZXJDaGFydCgpO1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoc2ltcGxlQ2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGxldCBzaG91bGRSZWRyYXdDaGFydCA9IGZhbHNlO1xuXG4gICAgY29uc3Qga2V5VXBkYXRlRm5QYWlycyA9IHtcbiAgICAgIGRhdGE6ICgpID0+IHRoaXMudXBkYXRlRGF0YSgpLFxuICAgICAgZGF0YUxhYmVsczogKCkgPT4gdGhpcy51cGRhdGVEYXRhTGFiZWxzKCksXG4gICAgICB0eXBlOiAoKSA9PiB0aGlzLnVwZGF0ZVR5cGUoKSxcbiAgICAgIGN1c3RvbU9wdGlvbnM6ICgpID0+IHRoaXMudXBkYXRlQ3VzdG9tT3B0aW9ucygpLFxuICAgICAgYW5ub3RhdGlvbnM6ICgpID0+IHRoaXMudXBkYXRlQW5ub3RhdGlvbnMoKSxcbiAgICAgIGhpZ2hsaWdodGVkRWxlbWVudHM6ICgpID0+IHRoaXMudXBkYXRlSGlnaGxpZ2h0ZWRFbGVtZW50cygpLFxuICAgIH07XG5cbiAgICBPYmplY3QuZW50cmllcyhzaW1wbGVDaGFuZ2VzKS5mb3JFYWNoKChba2V5XSkgPT4ge1xuICAgICAgaWYgKHNpbXBsZUNoYW5nZXNba2V5XS5maXJzdENoYW5nZSB8fCAha2V5VXBkYXRlRm5QYWlyc1trZXldKSByZXR1cm47XG4gICAgICBzaG91bGRSZWRyYXdDaGFydCA9IHRydWU7XG4gICAgICBrZXlVcGRhdGVGblBhaXJzW2tleV0oKTtcbiAgICB9KTtcblxuICAgIGlmIChzaG91bGRSZWRyYXdDaGFydCkgdGhpcy5yZWRyYXdDaGFydCgpO1xuICB9XG5cbiAgcHJpdmF0ZSByZW5kZXJDaGFydCgpIHtcbiAgICB0aGlzLmNoYXJ0SlNTZXJ2aWNlLnJlbmRlckNoYXJ0KHtcbiAgICAgIHRhcmdldEVsZW1lbnQ6IHRoaXMuY2FudmFzRWxlbWVudCxcbiAgICAgIHR5cGU6IHRoaXMudHlwZSxcbiAgICAgIGRhdGE6IHRoaXMuZGF0YSxcbiAgICAgIGRhdGFMYWJlbHM6IHRoaXMuZGF0YUxhYmVscyxcbiAgICAgIGN1c3RvbU9wdGlvbnM6IHRoaXMuY3VzdG9tT3B0aW9ucyxcbiAgICAgIGFubm90YXRpb25zOiB0aGlzLmFubm90YXRpb25zLFxuICAgICAgaGlnaGxpZ2h0ZWRFbGVtZW50czogdGhpcy5oaWdobGlnaHRlZEVsZW1lbnRzLFxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSB1cGRhdGVEYXRhKCkge1xuICAgIHRoaXMuY2hhcnRKU1NlcnZpY2UudXBkYXRlRGF0YSh0aGlzLmRhdGEpO1xuICB9XG5cbiAgcHJpdmF0ZSB1cGRhdGVEYXRhTGFiZWxzKCkge1xuICAgIHRoaXMuY2hhcnRKU1NlcnZpY2UudXBkYXRlRGF0YUxhYmVscyh0aGlzLmRhdGFMYWJlbHMpO1xuICB9XG5cbiAgcHJpdmF0ZSB1cGRhdGVUeXBlKCkge1xuICAgIHRoaXMuY2hhcnRKU1NlcnZpY2UudXBkYXRlVHlwZSh0aGlzLnR5cGUsIHRoaXMuY3VzdG9tT3B0aW9ucyk7XG4gIH1cblxuICBwcml2YXRlIHVwZGF0ZUN1c3RvbU9wdGlvbnMoKSB7XG4gICAgdGhpcy5jaGFydEpTU2VydmljZS51cGRhdGVPcHRpb25zKHRoaXMuY3VzdG9tT3B0aW9ucywgdGhpcy50eXBlKTtcbiAgfVxuXG4gIHByaXZhdGUgdXBkYXRlQW5ub3RhdGlvbnMoKSB7XG4gICAgdGhpcy5jaGFydEpTU2VydmljZS51cGRhdGVBbm5vdGF0aW9ucyh0aGlzLmFubm90YXRpb25zKTtcbiAgfVxuXG4gIHByaXZhdGUgdXBkYXRlSGlnaGxpZ2h0ZWRFbGVtZW50cygpIHtcbiAgICB0aGlzLmNoYXJ0SlNTZXJ2aWNlLnVwZGF0ZUhpZ2hsaWdodGVkRWxlbWVudHModGhpcy5oaWdobGlnaHRlZEVsZW1lbnRzKTtcbiAgfVxuXG4gIHByaXZhdGUgcmVkcmF3Q2hhcnQoKSB7XG4gICAgdGhpcy5jaGFydEpTU2VydmljZS5yZWRyYXdDaGFydCgpO1xuICB9XG59XG4iXX0=
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.component.js","sourceRoot":"","sources":["../../../../../../../libs/designsystem/src/lib/components/chart/chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { ChartOptions } from 'chart.js';\nimport { AnnotationOptions } from 'chartjs-plugin-annotation';\n\nimport { ResizeObserverFactory, ResizeObserverService } from '../shared';\n\nimport { ChartJSService } from './chart-js/chart-js.service';\nimport { ChartDataset, ChartHighlightedElements, ChartType } from './chart.types';\n\n@Component({\n  selector: 'kirby-chart',\n  templateUrl: './chart.component.html',\n  styleUrls: ['./chart.component.scss'],\n  providers: [ChartJSService],\n})\nexport class ChartComponent implements AfterViewInit, OnChanges {\n  @Input() type: ChartType = 'column';\n  @Input() data: ChartDataset[] | number[];\n  @Input() dataLabels?: string[] | string[][];\n  @Input() customOptions?: ChartOptions;\n  @Input() annotations?: AnnotationOptions[];\n  @Input() highlightedElements?: ChartHighlightedElements;\n\n  @HostBinding('style.--kirby-chart-height')\n  _height: string;\n  @Input() set height(value: string | number) {\n    this._height = typeof value === 'number' ? `${value}px` : value;\n  }\n\n  @ViewChild('chartCanvas')\n  canvasElement: ElementRef<HTMLCanvasElement>;\n\n  constructor(private chartJSService: ChartJSService) {}\n\n  ngAfterViewInit() {\n    /* \n       A chart is not rendered until it has both a height and a width. \n       If ChartComponent is slotted in an ionic component it will\n       not have any height or width on afterViewInit. This will cause \n       the animation to not be played on first draw. \n    */\n    const canvasElement = this.canvasElement.nativeElement;\n    this.whenElementHasHeightAndWidth(canvasElement).then(() => this.renderChart());\n  }\n\n  private whenElementHasHeightAndWidth(element: HTMLElement): Promise<void> {\n    const rectIs2D = ({ width, height }) => height > 0 && width > 0;\n\n    return new Promise((resolve) => {\n      const initialClientRect = element.getBoundingClientRect();\n      if (rectIs2D(initialClientRect)) resolve();\n\n      const resizeObserver = new ResizeObserverFactory().create(([resizeObserverEntry]) => {\n        if (rectIs2D(resizeObserverEntry.contentRect)) {\n          resizeObserver.unobserve(element);\n          resolve();\n        }\n      });\n\n      resizeObserver.observe(element);\n    });\n  }\n\n  ngOnChanges(simpleChanges: SimpleChanges) {\n    let shouldRedrawChart = false;\n\n    const keyUpdateFnPairs = {\n      data: () => this.updateData(),\n      dataLabels: () => this.updateDataLabels(),\n      type: () => this.updateType(),\n      customOptions: () => this.updateCustomOptions(),\n      annotations: () => this.updateAnnotations(),\n      highlightedElements: () => this.updateHighlightedElements(),\n    };\n\n    Object.entries(simpleChanges).forEach(([key]) => {\n      if (simpleChanges[key].firstChange || !keyUpdateFnPairs[key]) return;\n      shouldRedrawChart = true;\n      keyUpdateFnPairs[key]();\n    });\n\n    if (shouldRedrawChart) this.redrawChart();\n  }\n\n  private renderChart() {\n    this.chartJSService.renderChart({\n      targetElement: this.canvasElement,\n      type: this.type,\n      data: this.data,\n      dataLabels: this.dataLabels,\n      customOptions: this.customOptions,\n      annotations: this.annotations,\n      highlightedElements: this.highlightedElements,\n    });\n  }\n\n  private updateData() {\n    this.chartJSService.updateData(this.data);\n  }\n\n  private updateDataLabels() {\n    this.chartJSService.updateDataLabels(this.dataLabels);\n  }\n\n  private updateType() {\n    this.chartJSService.updateType(this.type, this.customOptions);\n  }\n\n  private updateCustomOptions() {\n    this.chartJSService.updateOptions(this.customOptions, this.type);\n  }\n\n  private updateAnnotations() {\n    this.chartJSService.updateAnnotations(this.annotations);\n  }\n\n  private updateHighlightedElements() {\n    this.chartJSService.updateHighlightedElements(this.highlightedElements);\n  }\n\n  private redrawChart() {\n    this.chartJSService.redrawChart();\n  }\n}\n"]}
@@ -1 +1 @@
1
- [{"__symbolic":"module","version":4,"metadata":{"ChartComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":16,"character":1},"arguments":[{"selector":"kirby-chart","providers":[{"__symbolic":"reference","module":"./chart-js/chart-js.service","name":"ChartJSService","line":20,"character":14}],"template":"<div class=\"chart-container\">\n <canvas #chartCanvas>\n <!-- Slotted content makes it possible to insert fallback content for screen readers \n https://www.chartjs.org/docs/latest/general/accessibility.html-->\n <ng-content></ng-content>\n </canvas>\n</div>\n","styles":[":host div{height:var(--kirby-chart-height,300px);position:relative}"]}]}],"members":{"type":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3}}]}],"data":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3}}]}],"dataLabels":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":25,"character":3}}]}],"customOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3}}]}],"annotations":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":3}}]}],"highlightedElements":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}],"_height":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":30,"character":3},"arguments":["style.--kirby-chart-height"]}]}],"height":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3}}]}],"canvasElement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":36,"character":3},"arguments":["chartCanvas"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"./chart-js/chart-js.service","name":"ChartJSService","line":39,"character":38}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"renderChart":[{"__symbolic":"method"}],"updateData":[{"__symbolic":"method"}],"updateDataLabels":[{"__symbolic":"method"}],"updateType":[{"__symbolic":"method"}],"updateCustomOptions":[{"__symbolic":"method"}],"updateAnnotations":[{"__symbolic":"method"}],"updateHighlightedElements":[{"__symbolic":"method"}],"redrawChart":[{"__symbolic":"method"}]}}}}]
1
+ [{"__symbolic":"module","version":4,"metadata":{"ChartComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":18,"character":1},"arguments":[{"selector":"kirby-chart","providers":[{"__symbolic":"reference","module":"./chart-js/chart-js.service","name":"ChartJSService","line":22,"character":14}],"template":"<div class=\"chart-container\">\n <canvas #chartCanvas>\n <!-- Slotted content makes it possible to insert fallback content for screen readers \n https://www.chartjs.org/docs/latest/general/accessibility.html-->\n <ng-content></ng-content>\n </canvas>\n</div>\n","styles":[":host div{height:var(--kirby-chart-height,300px);position:relative}"]}]}],"members":{"type":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":25,"character":3}}]}],"data":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3}}]}],"dataLabels":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":3}}]}],"customOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}],"annotations":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"highlightedElements":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3}}]}],"_height":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":32,"character":3},"arguments":["style.--kirby-chart-height"]}]}],"height":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":34,"character":3}}]}],"canvasElement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":38,"character":3},"arguments":["chartCanvas"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"./chart-js/chart-js.service","name":"ChartJSService","line":41,"character":38}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"whenElementHasHeightAndWidth":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"renderChart":[{"__symbolic":"method"}],"updateData":[{"__symbolic":"method"}],"updateDataLabels":[{"__symbolic":"method"}],"updateType":[{"__symbolic":"method"}],"updateCustomOptions":[{"__symbolic":"method"}],"updateAnnotations":[{"__symbolic":"method"}],"updateHighlightedElements":[{"__symbolic":"method"}],"redrawChart":[{"__symbolic":"method"}]}}}}]
@@ -1,6 +1,6 @@
1
1
  import { DesignTokenHelper, ColorHelper, capitalizeFirstLetter } from '@kirbydesign/core';
2
2
  export { ColorHelper, DesignTokenHelper, camelToKebabCase, capitalizeFirstLetter, kebabToCamelCase, kebabToTitleCase } from '@kirbydesign/core';
3
- import { Component, Input, EventEmitter, Output, Injectable, ɵɵdefineInjectable, ElementRef, ViewChild, ɵɵinject, InjectionToken, Injector, HostListener, Optional, Inject, HostBinding, ContentChild, NgZone, RendererStyleFlags2, Renderer2, ComponentFactoryResolver, ViewChildren, NgModule, ChangeDetectionStrategy, LOCALE_ID, Directive, forwardRef, ChangeDetectorRef, TemplateRef, ContentChildren, INJECTOR, Pipe, SkipSelf, ViewContainerRef, APP_INITIALIZER } from '@angular/core';
3
+ import { Component, Input, EventEmitter, Output, Injectable, ɵɵdefineInjectable, ElementRef, ViewChild, ɵɵinject, InjectionToken, Injector, HostListener, Optional, Inject, HostBinding, ContentChild, NgZone, RendererStyleFlags2, Renderer2, ComponentFactoryResolver, ViewChildren, NgModule, ChangeDetectionStrategy, Directive, ViewContainerRef, LOCALE_ID, forwardRef, ChangeDetectorRef, TemplateRef, ContentChildren, INJECTOR, Pipe, SkipSelf, APP_INITIALIZER } from '@angular/core';
4
4
  import { ModalController as ModalController$1, IonContent, IonHeader, IonToolbar, IonTitle, AnimationController, IonApp, IonicModule, IonRadio, IonFabButton, LoadingController, IonItemSliding, IonTabs, IonFooter, ToastController as ToastController$1 } from '@ionic/angular';
5
5
  export { IonRouterOutlet, NavController } from '@ionic/angular';
6
6
  import { NavigationEnd, Router, ActivatedRoute, RouterOutlet, ROUTES, NavigationStart, RouterModule } from '@angular/router';
@@ -3037,6 +3037,41 @@ function isNumberArray(value) {
3037
3037
  return Array.isArray(value) && value.every((item) => typeof item === 'number');
3038
3038
  }
3039
3039
 
3040
+ class ComponentLoaderDirective {
3041
+ constructor(componentFactoryResolver, viewContainerRef, renderer) {
3042
+ this.componentFactoryResolver = componentFactoryResolver;
3043
+ this.viewContainerRef = viewContainerRef;
3044
+ this.renderer = renderer;
3045
+ }
3046
+ ngOnInit() {
3047
+ this.loadCard();
3048
+ }
3049
+ loadCard() {
3050
+ const componentFactory = this.componentFactoryResolver.resolveComponentFactory(this.configuration.component);
3051
+ this.viewContainerRef.clear();
3052
+ const componentRef = this.viewContainerRef.createComponent(componentFactory);
3053
+ if (componentRef && componentRef.location && componentRef.location.nativeElement) {
3054
+ this.renderer.addClass(componentRef.location.nativeElement, this.cssClass);
3055
+ }
3056
+ componentRef.instance.data = this.configuration.data;
3057
+ }
3058
+ }
3059
+ ComponentLoaderDirective.decorators = [
3060
+ { type: Directive, args: [{
3061
+ selector: '[kirbyLoadComponent]',
3062
+ },] }
3063
+ ];
3064
+ /** @nocollapse */
3065
+ ComponentLoaderDirective.ctorParameters = () => [
3066
+ { type: ComponentFactoryResolver },
3067
+ { type: ViewContainerRef },
3068
+ { type: Renderer2 }
3069
+ ];
3070
+ ComponentLoaderDirective.propDecorators = {
3071
+ configuration: [{ type: Input, args: ['kirbyLoadComponent',] }],
3072
+ cssClass: [{ type: Input }]
3073
+ };
3074
+
3040
3075
  function deepCopy(obj) {
3041
3076
  return JSON.parse(JSON.stringify(obj));
3042
3077
  }
@@ -3462,7 +3497,29 @@ class ChartComponent {
3462
3497
  this._height = typeof value === 'number' ? `${value}px` : value;
3463
3498
  }
3464
3499
  ngAfterViewInit() {
3465
- this.renderChart();
3500
+ /*
3501
+ A chart is not rendered until it has both a height and a width.
3502
+ If ChartComponent is slotted in an ionic component it will
3503
+ not have any height or width on afterViewInit. This will cause
3504
+ the animation to not be played on first draw.
3505
+ */
3506
+ const canvasElement = this.canvasElement.nativeElement;
3507
+ this.whenElementHasHeightAndWidth(canvasElement).then(() => this.renderChart());
3508
+ }
3509
+ whenElementHasHeightAndWidth(element) {
3510
+ const rectIs2D = ({ width, height }) => height > 0 && width > 0;
3511
+ return new Promise((resolve) => {
3512
+ const initialClientRect = element.getBoundingClientRect();
3513
+ if (rectIs2D(initialClientRect))
3514
+ resolve();
3515
+ const resizeObserver = new ResizeObserverFactory().create(([resizeObserverEntry]) => {
3516
+ if (rectIs2D(resizeObserverEntry.contentRect)) {
3517
+ resizeObserver.unobserve(element);
3518
+ resolve();
3519
+ }
3520
+ });
3521
+ resizeObserver.observe(element);
3522
+ });
3466
3523
  }
3467
3524
  ngOnChanges(simpleChanges) {
3468
3525
  let shouldRedrawChart = false;
@@ -7350,41 +7407,6 @@ RouterOutletModule.decorators = [
7350
7407
  },] }
7351
7408
  ];
7352
7409
 
7353
- class ComponentLoaderDirective {
7354
- constructor(componentFactoryResolver, viewContainerRef, renderer) {
7355
- this.componentFactoryResolver = componentFactoryResolver;
7356
- this.viewContainerRef = viewContainerRef;
7357
- this.renderer = renderer;
7358
- }
7359
- ngOnInit() {
7360
- this.loadCard();
7361
- }
7362
- loadCard() {
7363
- const componentFactory = this.componentFactoryResolver.resolveComponentFactory(this.configuration.component);
7364
- this.viewContainerRef.clear();
7365
- const componentRef = this.viewContainerRef.createComponent(componentFactory);
7366
- if (componentRef && componentRef.location && componentRef.location.nativeElement) {
7367
- this.renderer.addClass(componentRef.location.nativeElement, this.cssClass);
7368
- }
7369
- componentRef.instance.data = this.configuration.data;
7370
- }
7371
- }
7372
- ComponentLoaderDirective.decorators = [
7373
- { type: Directive, args: [{
7374
- selector: '[kirbyLoadComponent]',
7375
- },] }
7376
- ];
7377
- /** @nocollapse */
7378
- ComponentLoaderDirective.ctorParameters = () => [
7379
- { type: ComponentFactoryResolver },
7380
- { type: ViewContainerRef },
7381
- { type: Renderer2 }
7382
- ];
7383
- ComponentLoaderDirective.propDecorators = {
7384
- configuration: [{ type: Input, args: ['kirbyLoadComponent',] }],
7385
- cssClass: [{ type: Input }]
7386
- };
7387
-
7388
7410
  var SegmentedControlMode;
7389
7411
  (function (SegmentedControlMode) {
7390
7412
  SegmentedControlMode["chip"] = "chip";