1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- import {RouteComponentProps} from 'react-router';
- import AlertLink from 'sentry/components/alertLink';
- import Button from 'sentry/components/button';
- import ExternalLink from 'sentry/components/links/externalLink';
- import {Panel, PanelBody, PanelHeader} from 'sentry/components/panels';
- import RepositoryRow from 'sentry/components/repositoryRow';
- import {IconCommit} from 'sentry/icons';
- import {t, tct} from 'sentry/locale';
- import {Repository, RepositoryStatus} from 'sentry/types';
- import useApi from 'sentry/utils/useApi';
- import EmptyMessage from 'sentry/views/settings/components/emptyMessage';
- import SettingsPageHeader from 'sentry/views/settings/components/settingsPageHeader';
- import TextBlock from 'sentry/views/settings/components/text/textBlock';
- type Props = RouteComponentProps<{orgId: string}, {}> & {
- itemList: Repository[];
- onRepositoryChange: (data: {id: string; status: RepositoryStatus}) => void;
- };
- function OrganizationRepositories({itemList, onRepositoryChange, params}: Props) {
- const api = useApi();
- const {orgId} = params;
- const hasItemList = itemList && itemList.length > 0;
- return (
- <div>
- <SettingsPageHeader title={t('Repositories')} />
- <AlertLink to={`/settings/${orgId}/integrations/`}>
- {t(
- 'Want to add a repository to start tracking commits? Install or configure your version control integration here.'
- )}
- </AlertLink>
- {!hasItemList && (
- <div className="m-b-2">
- <TextBlock>
- {t(
- 'Connecting a repository allows Sentry to capture commit data via webhooks. ' +
- 'This enables features like suggested assignees and resolving issues via commit message. ' +
- "Once you've connected a repository, you can associate commits with releases via the API."
- )}
-
- {tct('See our [link:documentation] for more details.', {
- link: <ExternalLink href="https://docs.sentry.io/learn/releases/" />,
- })}
- </TextBlock>
- </div>
- )}
- {hasItemList ? (
- <Panel>
- <PanelHeader>{t('Added Repositories')}</PanelHeader>
- <PanelBody>
- <div>
- {itemList.map(repo => (
- <RepositoryRow
- api={api}
- key={repo.id}
- repository={repo}
- showProvider
- orgId={orgId}
- onRepositoryChange={onRepositoryChange}
- />
- ))}
- </div>
- </PanelBody>
- </Panel>
- ) : (
- <Panel>
- <EmptyMessage
- icon={<IconCommit size="xl" />}
- title={t('Sentry is better with commit data')}
- description={t(
- 'Adding one or more repositories will enable enhanced releases and the ability to resolve Sentry Issues via git message.'
- )}
- action={
- <Button external href="https://docs.sentry.io/learn/releases/">
- {t('Learn more')}
- </Button>
- }
- />
- </Panel>
- )}
- </div>
- );
- }
- export default OrganizationRepositories;
|