@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.
- package/bundles/kirbydesign-designsystem.umd.js +64 -37
- package/bundles/kirbydesign-designsystem.umd.js.map +1 -1
- package/bundles/kirbydesign-designsystem.umd.min.js +1 -1
- package/bundles/kirbydesign-designsystem.umd.min.js.map +1 -1
- package/esm2015/lib/components/chart/chart.component.js +25 -2
- package/esm2015/lib/components/chart/chart.component.metadata.json +1 -1
- package/fesm2015/kirbydesign-designsystem.js +59 -37
- package/fesm2015/kirbydesign-designsystem.js.map +1 -1
- package/kirbydesign-designsystem.metadata.json +1 -1
- package/lib/components/chart/chart.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -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
|
-
|
|
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,
|
|
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":
|
|
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,
|
|
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
|
-
|
|
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";
|