import {Component} from 'react'; import styled from '@emotion/styled'; import {BannerContainer, BannerSummary} from 'sentry/components/events/styles'; import Link from 'sentry/components/links/link'; import {IconCheckmark, IconClose} from 'sentry/icons'; import {t, tct, tn} from 'sentry/locale'; import space from 'sentry/styles/space'; import {GroupActivityReprocess, Organization} from 'sentry/types'; import localStorage from 'sentry/utils/localStorage'; type Props = { groupCount: number; groupId: string; orgSlug: Organization['slug']; reprocessActivity: GroupActivityReprocess; className?: string; }; type State = { isBannerHidden: boolean; }; class ReprocessedBox extends Component { state: State = { isBannerHidden: localStorage.getItem(this.getBannerUniqueId()) === 'true', }; getBannerUniqueId() { const {reprocessActivity} = this.props; const {id} = reprocessActivity; return `reprocessed-activity-${id}-banner-dismissed`; } handleBannerDismiss = () => { localStorage.setItem(this.getBannerUniqueId(), 'true'); this.setState({isBannerHidden: true}); }; renderMessage() { const {orgSlug, reprocessActivity, groupCount, groupId} = this.props; const {data} = reprocessActivity; const {eventCount, oldGroupId, newGroupId} = data; const reprocessedEventsRoute = `/organizations/${orgSlug}/issues/?query=reprocessing.original_issue_id:${oldGroupId}&referrer=reprocessed-activity`; if (groupCount === 0) { return tct('All events in this issue were moved during reprocessing. [link]', { link: ( {tn('See %s new event', 'See %s new events', eventCount)} ), }); } return tct('Events in this issue were successfully reprocessed. [link]', { link: ( {newGroupId === Number(groupId) ? tn('See %s reprocessed event', 'See %s reprocessed events', eventCount) : tn('See %s new event', 'See %s new events', eventCount)} ), }); } render() { const {isBannerHidden} = this.state; if (isBannerHidden) { return null; } const {className} = this.props; return ( {this.renderMessage()} ); } } export default ReprocessedBox; const StyledBannerSummary = styled(BannerSummary)` & > svg:last-child { margin-right: 0; margin-left: ${space(1)}; } `; const StyledIconClose = styled(IconClose)` cursor: pointer; `;