123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- 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 (
- <StyledRow minSize={200}>
- {new Array(chartCount).fill(0).map((_, index) => (
- <WidgetContainer
- {...props}
- key={index}
- index={index}
- chartHeight={chartHeight}
- chartColor={palette[index]}
- defaultChartSetting={allowedCharts[index]}
- rowChartSettings={chartSettings}
- setRowChartSettings={setChartSettings}
- />
- ))}
- </StyledRow>
- );
- };
- export const TripleChartRow = (props: ChartRowProps) => <ChartRow {...props} />;
- TripleChartRow.defaultProps = {
- chartCount: 3,
- chartHeight: 100,
- };
- export const DoubleChartRow = (props: ChartRowProps) => <ChartRow {...props} />;
- DoubleChartRow.defaultProps = {
- chartCount: 2,
- chartHeight: 180,
- };
- const StyledRow = styled(PerformanceLayoutBodyRow)`
- margin-bottom: ${space(2)};
- `;
|