2024-08-23 08:59:56 -04:00
|
|
|
import Component from "@glimmer/component";
|
|
|
|
import { modifier } from "ember-modifier";
|
|
|
|
import loadScript from "discourse/lib/load-script";
|
|
|
|
|
|
|
|
// args:
|
|
|
|
// chartConfig - object
|
|
|
|
export default class Chart extends Component {
|
|
|
|
renderChart = modifier((element) => {
|
2024-11-27 22:37:59 -05:00
|
|
|
const { chartConfig } = this.args;
|
|
|
|
|
2024-08-23 08:59:56 -04:00
|
|
|
loadScript("/javascripts/Chart.min.js").then(() => {
|
2024-11-27 22:37:59 -05:00
|
|
|
this.chart = new window.Chart(element.getContext("2d"), chartConfig);
|
2024-08-23 08:59:56 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
return () => this.chart?.destroy();
|
|
|
|
});
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<div ...attributes>
|
|
|
|
<div class="chart-canvas-container">
|
|
|
|
<canvas {{this.renderChart}} class="chart-canvas"></canvas>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
}
|