Skip to content

Commit

Permalink
[frontend] refacto how we get apex chart context (#9299)
Browse files Browse the repository at this point in the history
  • Loading branch information
lndrtrbn authored Jan 17, 2025
1 parent 7d5bb14 commit 78afddd
Showing 1 changed file with 40 additions and 24 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import React, { RefObject, useRef, useState } from 'react';
import ApexChart, { Props } from 'react-apexcharts';
import type ReactApexChart from 'react-apexcharts';
import React, { useState } from 'react';
import ApexChart, { Props as ApexProps } from 'react-apexcharts';
import ApexCharts, { ApexOptions } from 'apexcharts';
import makeStyles from '@mui/styles/makeStyles';
import IconButton from '@mui/material/IconButton';
Expand All @@ -27,49 +26,51 @@ const useStyles = makeStyles<Theme>(() => ({
},
}));

interface ChartType extends ReactApexChart {
chart: { ctx: ApexCharts, opts: ApexOptions }
}

interface ExportPopoverProps {
chartRef: RefObject<ChartType>;
chart?: ApexCharts;
series?: ApexOptions['series'];
isReadOnly?: boolean;
}

const ExportPopover = ({
chart,
isReadOnly,
chartRef,
series,
}: ExportPopoverProps) => {
const classes = useStyles();
const { t_i18n } = useFormatter();
const [anchorEl, setAnchorEl] = useState<HTMLButtonElement | null>(null);

const handleExportToSVG = () => {
setAnchorEl(null);
if (chartRef.current) {
chartRef.current.chart.ctx.exports.exportToSVG();
if (chart) {
chart.exports.exportToSVG();
}
};

const handleExportToPng = () => {
setAnchorEl(null);
if (chartRef.current) {
chartRef.current.chart.ctx.exports.exportToPng();
if (chart) {
chart.exports.exportToPng();
}
};

const handleExportToCSV = () => {
setAnchorEl(null);
if (chartRef.current) {
const currentFormatter = chartRef.current.chart.opts.xaxis?.labels?.formatter;
if (chart) {
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
const currentFormatter = chart.opts.xaxis?.labels?.formatter;
if (currentFormatter) {
chartRef.current.chart.ctx.updateOptions({ xaxis: { labels: { formatter: (value: string) => value } } }, false, false, false);
chartRef.current.chart.ctx.exports.exportToCSV({ series });
chartRef.current.chart.ctx.updateOptions({ xaxis: { labels: { formatter: currentFormatter } } }, false);
chart.updateOptions({ xaxis: { labels: { formatter: (value: string) => value } } }, false, false, false);
chart.exports.exportToCSV({ series });
chart.updateOptions({ xaxis: { labels: { formatter: currentFormatter } } }, false);
} else {
chartRef.current.chart.ctx.exports.exportToCSV({ series });
chart.exports.exportToCSV({ series });
}
}
};

return (
<div className={isReadOnly ? classes.containerReadOnly : classes.container}>
<IconButton
Expand Down Expand Up @@ -100,7 +101,7 @@ const ExportPopover = ({
);
};

interface OpenCTIChartProps extends Props {
interface OpenCTIChartProps extends ApexProps {
withExportPopover?: boolean;
isReadOnly?: boolean;
}
Expand All @@ -114,20 +115,35 @@ const Chart = ({
withExportPopover,
isReadOnly,
}: OpenCTIChartProps) => {
const chartRef = useRef<ChartType>(null);
const [chart, setChart] = useState<ApexCharts>();

// Add in config a callback on 'mounted event' to retrieve chart context.
// This context is used to export in different format.
const apexOptions: ApexProps['options'] = {
...options,
chart: {
...options?.chart,
events: {
...options?.chart?.events,
mounted(c) {
setChart(c);
},
},
},
};

return (
<>
<ApexChart
ref={chartRef}
options={options}
options={apexOptions}
series={series}
type={type}
width={width}
height={height}
/>
{withExportPopover === true && (
<ExportPopover
chartRef={chartRef}
chart={chart}
series={series}
isReadOnly={isReadOnly}
/>
Expand Down

0 comments on commit 78afddd

Please sign in to comment.