import {useState} from 'react';
import {useTheme} from '@emotion/react';
import styled from '@emotion/styled';
import {Location} from 'history';
import {PerformanceLayoutBodyRow} from 'sentry/components/performance/layouts';
import {space} from 'sentry/styles/space';
import EventView from 'sentry/utils/discover/eventView';
import {usePerformanceDisplayType} from 'sentry/utils/performance/contexts/performanceDisplayContext';
import {PROJECT_PERFORMANCE_TYPE} from 'sentry/views/performance/utils';
import {getChartSetting} from '../utils';
import {PerformanceWidgetSetting} from '../widgetDefinitions';
import WidgetContainer from './widgetContainer';
export type ChartRowProps = {
allowedCharts: PerformanceWidgetSetting[];
chartCount: number;
chartHeight: number;
eventView: EventView;
location: Location;
withStaticFilters: boolean;
};
function getInitialChartSettings(
chartCount: number,
chartHeight: number,
performanceType: PROJECT_PERFORMANCE_TYPE,
allowedCharts: PerformanceWidgetSetting[]
) {
return new Array(chartCount)
.fill(0)
.map((_, index) =>
getChartSetting(index, chartHeight, performanceType, allowedCharts[index])
);
}
const ChartRow = (props: ChartRowProps) => {
const {chartCount, chartHeight, allowedCharts} = props;
const theme = useTheme();
const performanceType = usePerformanceDisplayType();
const palette = theme.charts.getColorPalette(chartCount);
const [chartSettings, setChartSettings] = useState(
getInitialChartSettings(chartCount, chartHeight, performanceType, allowedCharts)
);
if (props.allowedCharts.length < chartCount) {
throw new Error('Not enough allowed chart types to show row.');
}
return (
{new Array(chartCount).fill(0).map((_, index) => (
))}
);
};
export const TripleChartRow = (props: ChartRowProps) => ;
TripleChartRow.defaultProps = {
chartCount: 3,
chartHeight: 100,
};
export const DoubleChartRow = (props: ChartRowProps) => ;
DoubleChartRow.defaultProps = {
chartCount: 2,
chartHeight: 180,
};
const StyledRow = styled(PerformanceLayoutBodyRow)`
margin-bottom: ${space(2)};
`;