2022-07-20 12:04:14 +02:00
|
|
|
import BaseUIElement from "../BaseUIElement";
|
|
|
|
import {Chart, ChartConfiguration, ChartType, DefaultDataPoint, registerables} from 'chart.js';
|
2022-08-18 16:39:48 +02:00
|
|
|
Chart?.register(...(registerables ?? []));
|
2022-07-20 12:04:14 +02:00
|
|
|
|
|
|
|
|
|
|
|
export default class ChartJs<
|
|
|
|
TType extends ChartType = ChartType,
|
|
|
|
TData = DefaultDataPoint<TType>,
|
|
|
|
TLabel = unknown
|
|
|
|
> extends BaseUIElement{
|
|
|
|
private readonly _config: ChartConfiguration<TType, TData, TLabel>;
|
|
|
|
|
|
|
|
constructor(config: ChartConfiguration<TType, TData, TLabel>) {
|
|
|
|
super();
|
|
|
|
this._config = config;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected InnerConstructElement(): HTMLElement {
|
|
|
|
const canvas = document.createElement("canvas");
|
|
|
|
new Chart(canvas, this._config);
|
|
|
|
return canvas;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|