firefish/packages/client/src/scripts/init-chart.ts

59 lines
1.1 KiB
TypeScript
Raw Normal View History

2023-11-27 18:17:53 +09:00
import { defaultStore } from "@/store";
2023-07-20 04:17:05 +09:00
import {
ArcElement,
BarController,
2023-09-04 17:47:24 +09:00
BarElement,
2023-07-20 04:17:05 +09:00
CategoryScale,
2023-09-04 17:47:24 +09:00
Chart,
DoughnutController,
Filler,
Legend,
LineController,
LineElement,
2023-07-20 04:17:05 +09:00
LinearScale,
2023-09-04 17:47:24 +09:00
PointElement,
SubTitle,
2023-07-20 04:17:05 +09:00
TimeScale,
Title,
Tooltip,
} from "chart.js";
2023-11-27 18:17:53 +09:00
import "chartjs-adapter-date-fns";
import { MatrixController, MatrixElement } from "chartjs-chart-matrix";
2023-07-20 04:17:05 +09:00
import gradient from "chartjs-plugin-gradient";
import zoomPlugin from "chartjs-plugin-zoom";
export function initChart() {
Chart.register(
ArcElement,
LineElement,
BarElement,
PointElement,
BarController,
LineController,
DoughnutController,
CategoryScale,
LinearScale,
TimeScale,
Legend,
Title,
Tooltip,
SubTitle,
Filler,
MatrixController,
MatrixElement,
zoomPlugin,
gradient,
);
// フォントカラー
Chart.defaults.color = getComputedStyle(
document.documentElement,
).getPropertyValue("--fg");
Chart.defaults.borderColor = defaultStore.state.darkMode
? "rgba(255, 255, 255, 0.1)"
: "rgba(0, 0, 0, 0.1)";
Chart.defaults.animation = false;
}