123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- import AsyncComponent from 'sentry/components/asyncComponent';
- import {Button} from 'sentry/components/button';
- 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 {Organization, Project} from 'sentry/types';
- type Props = AsyncComponent['props'] & {
- organization: Organization;
- projectSlug: string;
- };
- type State = AsyncComponent['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 AsyncComponent<Props, State> {
- getEndpoints(): ReturnType<AsyncComponent['getEndpoints']> {
- 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 (
- <Tooltip title={t('Send Alerts to Slack. Install the integration now.')}>
- <Button
- size="sm"
- icon={<PluginIcon pluginId="slack" size={16} />}
- {...buttonProps}
- >
- {t('Set Up Slack Now')}
- </Button>
- </Tooltip>
- );
- }
- }
|