import styled from '@emotion/styled'; import {openInsightChartModal} from 'sentry/actionCreators/modal'; import {Button} from 'sentry/components/button'; import Panel from 'sentry/components/panels/panel'; import {IconExpand} from 'sentry/icons'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import {Subtitle} from 'sentry/views/performance/landing/widgets/widgets/singleFieldAreaWidget'; export type AlertConfig = { aggregate: string; name?: string; query?: string; }; type Props = { children: React.ReactNode; alertConfigs?: AlertConfig[]; button?: JSX.Element; className?: string; subtitle?: React.ReactNode; title?: React.ReactNode; }; export default function ChartPanel({ title, children, button, subtitle, className, }: Props) { return ( {title && (
{title && ( {typeof title === 'string' ? ( {title} ) : ( title )} )} {button}
)} {subtitle && ( {subtitle} )} {children}
); } const PanelWithNoPadding = styled(Panel)` margin-bottom: 0; `; const TextTitleContainer = styled('div')` padding: 1px 0; `; const SubtitleContainer = styled('div')` padding-top: ${space(0.5)}; `; const ChartLabel = styled('div')` ${p => p.theme.text.cardTitle} `; const PanelBody = styled('div')` padding: ${space(2)}; `; const Header = styled('div')` width: 100%; display: flex; align-items: center; justify-content: space-between; `; const MenuContainer = styled('span')` display: flex; `;