123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- 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 (
- <PanelWithNoPadding className={className}>
- <PanelBody>
- {title && (
- <Header data-test-id="chart-panel-header">
- {title && (
- <ChartLabel>
- {typeof title === 'string' ? (
- <TextTitleContainer>{title}</TextTitleContainer>
- ) : (
- title
- )}
- </ChartLabel>
- )}
- <MenuContainer>
- {button}
- <Button
- aria-label={t('Expand Insight Chart')}
- borderless
- size="xs"
- icon={<IconExpand />}
- onClick={() => {
- openInsightChartModal({title, children});
- }}
- />
- </MenuContainer>
- </Header>
- )}
- {subtitle && (
- <SubtitleContainer>
- <Subtitle>{subtitle}</Subtitle>
- </SubtitleContainer>
- )}
- {children}
- </PanelBody>
- </PanelWithNoPadding>
- );
- }
- 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;
- `;
|