import styled from '@emotion/styled';
import {Panel} from 'sentry/components/panels';
import QuestionTooltip from 'sentry/components/questionTooltip';
import TextOverflow from 'sentry/components/textOverflow';
import space from 'sentry/styles/space';
import {defined} from 'sentry/utils';
import {Theme} from 'sentry/utils/theme';
type Props = {
title: React.ReactNode;
className?: string;
help?: React.ReactNode;
score?: React.ReactNode;
trend?: React.ReactNode;
trendStatus?: 'good' | 'bad';
};
function ScoreCard({title, score, help, trend, trendStatus, className}: Props) {
return (
{title}
{help && }
{score ?? '\u2014'}
{defined(trend) && (
{trend}
)}
);
}
function getTrendColor(p: TrendProps & {theme: Theme}) {
switch (p.trendStatus) {
case 'good':
return p.theme.green300;
case 'bad':
return p.theme.red300;
default:
return p.theme.gray300;
}
}
export const ScorePanel = styled(Panel)`
display: flex;
flex-direction: column;
justify-content: space-between;
padding: ${space(2)} ${space(3)};
min-height: 96px;
`;
export const HeaderTitle = styled('div')`
display: inline-grid;
grid-auto-flow: column;
gap: ${space(1)};
align-items: center;
width: fit-content;
`;
export const Title = styled('div')`
font-size: ${p => p.theme.fontSizeLarge};
color: ${p => p.theme.headingColor};
${p => p.theme.overflowEllipsis};
font-weight: 600;
`;
export const ScoreWrapper = styled('div')`
display: flex;
flex-direction: row;
align-items: flex-end;
max-width: 100%;
`;
export const Score = styled('span')`
flex-shrink: 1;
font-size: 32px;
line-height: 1;
color: ${p => p.theme.headingColor};
white-space: nowrap;
`;
type TrendProps = {trendStatus: Props['trendStatus']};
export const Trend = styled('div')`
color: ${getTrendColor};
margin-left: ${space(1)};
line-height: 1;
overflow: hidden;
`;
export default ScoreCard;