import {Fragment, useEffect} from 'react';
import styled from '@emotion/styled';
import {Button} from 'sentry/components/button';
import {SectionHeading} from 'sentry/components/charts/styles';
import EmptyStateWarning from 'sentry/components/emptyStateWarning';
import GroupList from 'sentry/components/issues/groupList';
import LoadingError from 'sentry/components/loadingError';
import Panel from 'sentry/components/panels/panel';
import PanelBody from 'sentry/components/panels/panelBody';
import {t} from 'sentry/locale';
import {space} from 'sentry/styles/space';
import type {Organization} from 'sentry/types/organization';
import type {Project} from 'sentry/types/project';
import useRouter from 'sentry/utils/useRouter';
import {
RELATED_ISSUES_BOOLEAN_QUERY_ERROR,
RelatedIssuesNotAvailable,
} from 'sentry/views/alerts/rules/metric/details/relatedIssuesNotAvailable';
import {makeDefaultCta} from 'sentry/views/alerts/rules/metric/metricRulePresets';
import type {MetricRule} from 'sentry/views/alerts/rules/metric/types';
import {isSessionAggregate} from 'sentry/views/alerts/utils';
import type {TimePeriodType} from './constants';
interface Props {
organization: Organization;
projects: Project[];
rule: MetricRule;
timePeriod: TimePeriodType;
query?: string;
}
function RelatedIssues({rule, organization, projects, query, timePeriod}: Props) {
const router = useRouter();
// Add environment to the query parameters to be picked up by GlobalSelectionLink
// GlobalSelectionLink uses the current query parameters to build links to issue details
useEffect(() => {
const env = rule.environment ?? '';
if (env !== (router.location.query.environment ?? '')) {
router.replace({
pathname: router.location.pathname,
query: {...router.location.query, environment: env},
});
}
}, [rule.environment, router]);
function renderErrorMessage({detail}: {detail: string}, retry: () => void) {
if (
detail === RELATED_ISSUES_BOOLEAN_QUERY_ERROR &&
!isSessionAggregate(rule.aggregate)
) {
const {buttonText, to} = makeDefaultCta({
organization,
projects,
rule,
query,
timePeriod,
});
return ;
}
return ;
}
function renderEmptyMessage() {
return (
{t('No issues for this alert rule')}
);
}
const {start, end} = timePeriod;
const path = `/organizations/${organization.slug}/issues/`;
const queryParams = {
start,
end,
groupStatsPeriod: 'auto',
limit: 5,
...(rule.environment ? {environment: rule.environment} : {}),
sort: rule.aggregate === 'count_unique(user)' ? 'user' : 'freq',
query,
project: projects.map(project => project.id),
};
const issueSearch = {
pathname: `/organizations/${organization.slug}/issues/`,
query: queryParams,
};
return (
{t('Related Issues')}
);
}
const StyledSectionHeading = styled(SectionHeading)`
display: flex;
align-items: center;
`;
const ControlsWrapper = styled('div')`
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: ${space(1)};
`;
const TableWrapper = styled('div')`
margin-bottom: ${space(4)};
${Panel} {
/* smaller space between table and pagination */
margin-bottom: -${space(1)};
}
`;
export default RelatedIssues;