2024-08-23 08:59:56 -04:00
|
|
|
import Component from "@glimmer/component";
|
2023-10-10 14:38:59 -04:00
|
|
|
import { number } from "discourse/lib/formatter";
|
2019-11-01 13:06:50 -04:00
|
|
|
import { makeArray } from "discourse-common/lib/helpers";
|
2023-10-10 14:38:59 -04:00
|
|
|
import Report from "admin/models/report";
|
2024-08-23 08:59:56 -04:00
|
|
|
import Chart from "./chart";
|
2018-07-19 14:33:11 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
export default class AdminReportChart extends Component {
|
2024-08-23 08:59:56 -04:00
|
|
|
get chartConfig() {
|
|
|
|
const { model, options } = this.args;
|
2018-07-19 14:33:11 -04:00
|
|
|
|
2024-08-23 08:59:56 -04:00
|
|
|
const chartData = Report.collapse(
|
2020-07-28 10:14:41 -04:00
|
|
|
model,
|
2024-08-23 08:59:56 -04:00
|
|
|
makeArray(model.chartData || model.data, "weekly"),
|
|
|
|
options.chartGrouping
|
2018-12-12 05:11:56 -05:00
|
|
|
);
|
2024-08-23 08:59:56 -04:00
|
|
|
const prevChartData = makeArray(model.prevChartData || model.prev_data);
|
2018-12-12 05:11:56 -05:00
|
|
|
const labels = chartData.map((d) => d.x);
|
|
|
|
|
|
|
|
const data = {
|
|
|
|
labels,
|
|
|
|
datasets: [
|
|
|
|
{
|
|
|
|
data: chartData.map((d) => Math.round(parseFloat(d.y))),
|
|
|
|
backgroundColor: prevChartData.length
|
|
|
|
? "transparent"
|
|
|
|
: model.secondary_color,
|
2019-01-22 04:22:41 -05:00
|
|
|
borderColor: model.primary_color,
|
|
|
|
pointRadius: 3,
|
|
|
|
borderWidth: 1,
|
|
|
|
pointBackgroundColor: model.primary_color,
|
|
|
|
pointBorderColor: model.primary_color,
|
2018-12-12 05:11:56 -05:00
|
|
|
},
|
|
|
|
],
|
|
|
|
};
|
|
|
|
|
|
|
|
if (prevChartData.length) {
|
|
|
|
data.datasets.push({
|
|
|
|
data: prevChartData.map((d) => Math.round(parseFloat(d.y))),
|
|
|
|
borderColor: model.primary_color,
|
|
|
|
borderDash: [5, 5],
|
|
|
|
backgroundColor: "transparent",
|
|
|
|
borderWidth: 1,
|
|
|
|
pointRadius: 0,
|
2018-07-19 14:33:11 -04:00
|
|
|
});
|
2018-12-12 05:11:56 -05:00
|
|
|
}
|
|
|
|
|
2018-07-19 14:33:11 -04:00
|
|
|
return {
|
|
|
|
type: "line",
|
|
|
|
data,
|
|
|
|
options: {
|
2021-08-23 07:49:49 -04:00
|
|
|
plugins: {
|
|
|
|
tooltip: {
|
|
|
|
callbacks: {
|
|
|
|
title: (tooltipItem) =>
|
|
|
|
moment(tooltipItem[0].label, "YYYY-MM-DD").format("LL"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
legend: {
|
|
|
|
display: false,
|
2018-07-19 14:33:11 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
responsive: true,
|
|
|
|
maintainAspectRatio: false,
|
2019-12-11 09:49:17 -05:00
|
|
|
responsiveAnimationDuration: 0,
|
|
|
|
animation: {
|
|
|
|
duration: 0,
|
|
|
|
},
|
2018-07-19 14:33:11 -04:00
|
|
|
layout: {
|
|
|
|
padding: {
|
|
|
|
left: 0,
|
|
|
|
top: 0,
|
|
|
|
right: 0,
|
|
|
|
bottom: 0,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
scales: {
|
2021-08-23 07:49:49 -04:00
|
|
|
y: [
|
2018-07-19 14:33:11 -04:00
|
|
|
{
|
|
|
|
display: true,
|
2018-10-30 04:58:03 -04:00
|
|
|
ticks: {
|
2019-12-11 09:49:17 -05:00
|
|
|
callback: (label) => number(label),
|
|
|
|
sampleSize: 5,
|
|
|
|
maxRotation: 25,
|
|
|
|
minRotation: 25,
|
2018-10-30 04:58:03 -04:00
|
|
|
},
|
2018-07-19 14:33:11 -04:00
|
|
|
},
|
|
|
|
],
|
2021-08-23 07:49:49 -04:00
|
|
|
x: [
|
2018-07-19 14:33:11 -04:00
|
|
|
{
|
|
|
|
display: true,
|
|
|
|
gridLines: { display: false },
|
|
|
|
type: "time",
|
|
|
|
time: {
|
2021-06-17 03:15:20 -04:00
|
|
|
unit: Report.unitForGrouping(options.chartGrouping),
|
2019-12-11 09:49:17 -05:00
|
|
|
},
|
|
|
|
ticks: {
|
|
|
|
sampleSize: 5,
|
|
|
|
maxRotation: 50,
|
|
|
|
minRotation: 50,
|
2018-07-19 14:33:11 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
2023-02-23 10:32:53 -05:00
|
|
|
}
|
2018-07-19 14:33:11 -04:00
|
|
|
|
2024-08-23 08:59:56 -04:00
|
|
|
<template>
|
|
|
|
<Chart @chartConfig={{this.chartConfig}} class="admin-report-chart" />
|
|
|
|
</template>
|
2023-02-23 10:32:53 -05:00
|
|
|
}
|