2023-01-02 21:08:52 -08:00
|
|
|
import { Plugin } from 'chart.js';
|
|
|
|
|
2022-12-22 22:21:55 -08:00
|
|
|
export const chartVLine = (vLineColor: string) => ({
|
|
|
|
id: 'vLine',
|
|
|
|
beforeDraw(chart, args, options) {
|
|
|
|
if (chart.tooltip?._active?.length) {
|
|
|
|
const ctx = chart.ctx;
|
2023-01-01 19:01:06 -08:00
|
|
|
const xs = chart.tooltip._active.map(a => a.element.x);
|
|
|
|
const x = xs.reduce((a, b) => a + b, 0) / xs.length;
|
2022-12-22 22:21:55 -08:00
|
|
|
const topY = chart.scales.y.top;
|
|
|
|
const bottomY = chart.scales.y.bottom;
|
|
|
|
|
|
|
|
ctx.save();
|
|
|
|
ctx.beginPath();
|
|
|
|
ctx.moveTo(x, bottomY);
|
|
|
|
ctx.lineTo(x, topY);
|
|
|
|
ctx.lineWidth = 1;
|
|
|
|
ctx.strokeStyle = vLineColor;
|
|
|
|
ctx.stroke();
|
|
|
|
ctx.restore();
|
|
|
|
}
|
|
|
|
},
|
2023-01-02 21:08:52 -08:00
|
|
|
}) as Plugin;
|