import {Button} from 'sentry/components/button'; import DeprecatedAsyncComponent from 'sentry/components/deprecatedAsyncComponent'; import {Tooltip} from 'sentry/components/tooltip'; import {t} from 'sentry/locale'; import PluginIcon from 'sentry/plugins/components/pluginIcon'; import ConfigStore from 'sentry/stores/configStore'; import type {Organization, Project} from 'sentry/types'; type Props = DeprecatedAsyncComponent['props'] & { organization: Organization; projectSlug: string; }; type State = DeprecatedAsyncComponent['state'] & { detailedProject?: Project & { hasAlertIntegrationInstalled: boolean; }; }; /** * This component renders a button to Set up an alert integration (just Slack for now) * if the project has no alerting integrations setup already. */ export default class SetupAlertIntegrationButton extends DeprecatedAsyncComponent< Props, State > { getEndpoints(): ReturnType { const {projectSlug, organization} = this.props; return [ [ 'detailedProject', `/projects/${organization.slug}/${projectSlug}/?expand=hasAlertIntegration`, ], ]; } renderLoading() { return null; } // if there is an error, just show nothing renderError() { return null; } renderBody(): React.ReactNode { const {organization} = this.props; const {detailedProject} = this.state; // don't render anything if we don't have the project yet or if an alert integration // is installed if (!detailedProject || detailedProject.hasAlertIntegrationInstalled) { return null; } const {isSelfHosted} = ConfigStore.getState(); // link to docs to set up Slack for self-hosted folks const referrerQuery = '?referrer=issue-alert-builder'; const buttonProps = isSelfHosted ? { href: `https://develop.sentry.dev/integrations/slack/${referrerQuery}`, } : { to: `/settings/${organization.slug}/integrations/slack/${referrerQuery}`, }; // TOOD(Steve): need to use the Tooltip component because adding a title to the button // puts the tooltip in the upper left hand corner of the page instead of the button return ( ); } }