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)}; `;