mirror of
https://github.com/grafana/grafana.git
synced 2025-02-16 18:34:52 -06:00
63 lines
1.9 KiB
TypeScript
Executable File
63 lines
1.9 KiB
TypeScript
Executable File
import React, { useMemo } from 'react';
|
|
import { TooltipDisplayMode, StackingMode } from '@grafana/schema';
|
|
import { PanelProps, TimeRange, VizOrientation } from '@grafana/data';
|
|
import { TooltipPlugin, useTheme2 } from '@grafana/ui';
|
|
import { BarChartOptions } from './types';
|
|
import { BarChart } from './BarChart';
|
|
import { prepareGraphableFrames } from './utils';
|
|
|
|
interface Props extends PanelProps<BarChartOptions> {}
|
|
|
|
/**
|
|
* @alpha
|
|
*/
|
|
export const BarChartPanel: React.FunctionComponent<Props> = ({ data, options, width, height, timeZone }) => {
|
|
const theme = useTheme2();
|
|
|
|
const { frames, warn } = useMemo(() => prepareGraphableFrames(data?.series, theme, options.stacking), [
|
|
data,
|
|
theme,
|
|
options.stacking,
|
|
]);
|
|
const orientation = useMemo(() => {
|
|
if (!options.orientation || options.orientation === VizOrientation.Auto) {
|
|
return width < height ? VizOrientation.Horizontal : VizOrientation.Vertical;
|
|
}
|
|
|
|
return options.orientation;
|
|
}, [width, height, options.orientation]);
|
|
|
|
// Force 'multi' tooltip setting or stacking mode
|
|
const tooltip = useMemo(() => {
|
|
if (options.stacking === StackingMode.Normal || options.stacking === StackingMode.Percent) {
|
|
return { ...options.tooltip, mode: TooltipDisplayMode.Multi };
|
|
}
|
|
return options.tooltip;
|
|
}, [options.tooltip, options.stacking]);
|
|
|
|
if (!frames || warn) {
|
|
return (
|
|
<div className="panel-empty">
|
|
<p>{warn ?? 'No data found in response'}</p>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<BarChart
|
|
frames={frames}
|
|
timeZone={timeZone}
|
|
timeRange={({ from: 1, to: 1 } as unknown) as TimeRange} // HACK
|
|
structureRev={data.structureRev}
|
|
width={width}
|
|
height={height}
|
|
{...options}
|
|
orientation={orientation}
|
|
>
|
|
{(config, alignedFrame) => {
|
|
return <TooltipPlugin data={alignedFrame} config={config} mode={tooltip.mode} timeZone={timeZone} />;
|
|
}}
|
|
</BarChart>
|
|
);
|
|
};
|