123456789101112131415161718192021222324252627282930313233343536373839404142 |
- import styled from '@emotion/styled';
- import replaysDeadRageBackground from 'sentry-images/spot/replay-dead-rage-changelog.svg';
- import PageBanner from 'sentry/components/alerts/pageBanner';
- import {LinkButton} from 'sentry/components/button';
- import {IconBroadcast} from 'sentry/icons';
- import {t, tct} from 'sentry/locale';
- import useDismissAlert from 'sentry/utils/useDismissAlert';
- const LOCAL_STORAGE_KEY = 'release-v1-feedback-dismissed';
- /**
- * Copied from static/app/components/feedback/feedbackSetupBanner.tsx
- */
- export default function ReleaseFeedbackBanner() {
- const {dismiss, isDismissed} = useDismissAlert({key: LOCAL_STORAGE_KEY});
- const ctaButton = (
- <LinkButton external href="mailto:feedback-releases@sentry.io" priority="primary">
- {t('Email Us')}
- </LinkButton>
- );
- return isDismissed ? null : (
- <PageBanner
- style={{marginBottom: '16px'}}
- button={ctaButton}
- description={t('Send us an email to get early access.')}
- heading={t('Want to automatically rollback bad releases?')}
- icon={<IconBroadcast size="sm" />}
- image={replaysDeadRageBackground}
- title={tct("[blue:What's New]", {blue: <Blue />})}
- onDismiss={dismiss}
- />
- );
- }
- const Blue = styled('span')`
- color: ${p => p.theme.blue400};
- font-weight: bold;
- `;
|