import {Component} from 'react'; import styled from '@emotion/styled'; import ErrorPanel from 'sentry/components/charts/errorPanel'; import IdBadge from 'sentry/components/idBadge'; import ExternalLink from 'sentry/components/links/externalLink'; import Link from 'sentry/components/links/link'; import {SettingsIconLink} from 'sentry/components/organizations/headerItem'; import {Panel} from 'sentry/components/panels'; import PanelTable from 'sentry/components/panels/panelTable'; import {IconSettings, IconWarning} from 'sentry/icons'; import {t, tct} from 'sentry/locale'; import {DataCategory, Project} from 'sentry/types'; import theme from 'sentry/utils/theme'; import EmptyMessage from 'sentry/views/settings/components/emptyMessage'; import {formatUsageWithUnits} from '../utils'; const DOCS_URL = 'https://docs.sentry.io/product/accounts/membership/#restricting-access'; type Props = { dataCategory: DataCategory; headers: React.ReactNode[]; usageStats: TableStat[]; errors?: Record; isEmpty?: boolean; isError?: boolean; isLoading?: boolean; }; export type TableStat = { accepted: number; dropped: number; filtered: number; project: Project; projectLink: string; projectSettingsLink: string; total: number; }; class UsageTable extends Component { get formatUsageOptions() { const {dataCategory} = this.props; return { isAbbreviated: dataCategory !== DataCategory.ATTACHMENTS, useUnitScaling: dataCategory === DataCategory.ATTACHMENTS, }; } getErrorMessage = errorMessage => { if (errorMessage.projectStats.responseJSON.detail === 'No projects available') { return ( } title={t( "You don't have access to any projects, or your organization has no projects." )} description={tct('Learn more about [link:Project Access]', { link: , })} /> ); } return ; }; renderTableRow(stat: TableStat & {project: Project}) { const {dataCategory} = this.props; const {project, total, accepted, filtered, dropped} = stat; return [ , {formatUsageWithUnits(total, dataCategory, this.formatUsageOptions)} , {formatUsageWithUnits(accepted, dataCategory, this.formatUsageOptions)} , {formatUsageWithUnits(filtered, dataCategory, this.formatUsageOptions)} , {formatUsageWithUnits(dropped, dataCategory, this.formatUsageOptions)} , ]; } render() { const {isEmpty, isLoading, isError, errors, headers, usageStats} = this.props; if (isError) { return ( {this.getErrorMessage(errors)} ); } return ( {usageStats.map(s => this.renderTableRow(s))} ); } } export default UsageTable; const StyledPanelTable = styled(PanelTable)` grid-template-columns: repeat(5, auto); @media (min-width: ${p => p.theme.breakpoints.small}) { grid-template-columns: 1fr repeat(4, minmax(0, auto)); } `; export const CellStat = styled('div')` flex-shrink: 1; text-align: right; font-variant-numeric: tabular-nums; `; export const CellProject = styled(CellStat)` display: flex; align-items: center; text-align: left; `; const StyledIdBadge = styled(IdBadge)` overflow: hidden; white-space: nowrap; flex-shrink: 1; `;