Skip to content

Commit

Permalink
feat(releases): Split release commit from shared component (#78538)
Browse files Browse the repository at this point in the history
  • Loading branch information
scttcper authored and cmanallen committed Oct 23, 2024
1 parent cc04bde commit 8f3e90a
Show file tree
Hide file tree
Showing 2 changed files with 196 additions and 2 deletions.
4 changes: 2 additions & 2 deletions static/app/views/releases/detail/commitsAndFiles/commits.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ import {Fragment} from 'react';
import styled from '@emotion/styled';
import type {Location} from 'history';

import {CommitRow} from 'sentry/components/commitRow';
import * as Layout from 'sentry/components/layouts/thirds';
import LoadingError from 'sentry/components/loadingError';
import LoadingIndicator from 'sentry/components/loadingIndicator';
Expand All @@ -22,6 +21,7 @@ import {useLocation} from 'sentry/utils/useLocation';
import useOrganization from 'sentry/utils/useOrganization';
import {useParams} from 'sentry/utils/useParams';
import {formatVersion} from 'sentry/utils/versions/formatVersion';
import {ReleaseCommit} from 'sentry/views/releases/detail/commitsAndFiles/releaseCommit';

import {getCommitsByRepository, getQuery, getReposToRender} from '../utils';

Expand Down Expand Up @@ -93,7 +93,7 @@ function Commits({activeReleaseRepo, releaseRepos, projectSlug}: CommitsProps) {
<PanelHeader>{activeRepoName}</PanelHeader>
<PanelBody>
{commitsByRepository[activeRepoName]?.map(commit => (
<CommitRow key={commit.id} commit={commit} />
<ReleaseCommit key={commit.id} commit={commit} />
))}
</PanelBody>
</Panel>
Expand Down
194 changes: 194 additions & 0 deletions static/app/views/releases/detail/commitsAndFiles/releaseCommit.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,194 @@
import {useCallback} from 'react';
import styled from '@emotion/styled';
import * as Sentry from '@sentry/react';

import {openInviteMembersModal} from 'sentry/actionCreators/modal';
import UserAvatar from 'sentry/components/avatar/userAvatar';
import {LinkButton} from 'sentry/components/button';
import CommitLink from 'sentry/components/commitLink';
import Link from 'sentry/components/links/link';
import PanelItem from 'sentry/components/panels/panelItem';
import TextOverflow from 'sentry/components/textOverflow';
import TimeSince from 'sentry/components/timeSince';
import {Tooltip} from 'sentry/components/tooltip';
import {IconQuestion} from 'sentry/icons';
import {t, tct} from 'sentry/locale';
import {space} from 'sentry/styles/space';
import type {Commit} from 'sentry/types/integrations';
import {useUser} from 'sentry/utils/useUser';

function formatCommitMessage(message: string | null) {
if (!message) {
return t('No message provided');
}

return message.split(/\n/)[0];
}

export interface ReleaseCommitProps {
commit: Commit;
}

export function ReleaseCommit({commit}: ReleaseCommitProps) {
const user = useUser();

const handleInviteClick = useCallback(
(event: React.MouseEvent<HTMLAnchorElement>) => {
// Prevent link behavior
event?.preventDefault();

if (!commit.author?.email) {
Sentry.captureException(
new Error(`Commit author has no email or id, invite flow is broken.`)
);
return;
}

openInviteMembersModal({
initialData: [
{
emails: new Set([commit.author.email]),
},
],
source: 'suspect_commit',
});
},
[commit.author]
);

const isUser = user?.id === commit.author?.id;

return (
<StyledPanelItem key={commit.id} data-test-id="commit-row">
<CommitContent>
<Message>{formatCommitMessage(commit.message)}</Message>
<MetaWrapper>
<UserAvatar size={16} user={commit.author} />
<Meta>
<Tooltip
title={tct(
'The email [actorEmail] is not a member of your organization. [inviteUser:Invite] them or link additional emails in [accountSettings:account settings].',
{
actorEmail: <BoldEmail>{commit.author?.email}</BoldEmail>,
accountSettings: <StyledLink to="/settings/account/emails/" />,
inviteUser: (
<StyledLink
to=""
onClick={handleInviteClick}
aria-label={t('Invite user')}
/>
),
}
)}
disabled={!commit.author || commit.author.id !== undefined}
overlayStyle={{maxWidth: '350px'}}
skipWrapper
isHoverable
>
<AuthorWrapper>
{isUser ? t('You') : commit.author?.name ?? t('Unknown author')}
{commit.author && commit.author.id === undefined && (
<IconQuestion size="xs" />
)}
</AuthorWrapper>
</Tooltip>
{tct(' committed [commitLink] ', {
commitLink: (
<CommitLink
inline
showIcon={false}
commitId={commit.id}
repository={commit.repository}
/>
),
})}
<TimeSince date={commit.dateCreated} tooltipUnderlineColor="background" />
</Meta>
</MetaWrapper>
</CommitContent>

{commit.pullRequest?.externalUrl && (
<LinkButton external href={commit.pullRequest.externalUrl}>
{t('View Pull Request')}
</LinkButton>
)}
</StyledPanelItem>
);
}

const StyledPanelItem = styled(PanelItem)`
display: flex;
align-items: center;
justify-content: space-between;
gap: ${space(2)};
`;

const BoldEmail = styled('strong')`
font-weight: bold;
word-break: break-all;
`;

const StyledLink = styled(Link)`
color: ${p => p.theme.textColor};
border-bottom: 1px dotted ${p => p.theme.textColor};
&:hover {
color: ${p => p.theme.textColor};
}
`;

const Message = styled(TextOverflow)`
font-size: ${p => p.theme.fontSizeLarge};
line-height: 1.2;
`;

const Meta = styled(TextOverflow)`
line-height: 1.5;
margin: 0;
color: ${p => p.theme.subText};
a {
color: ${p => p.theme.subText};
text-decoration: underline;
text-decoration-style: dotted;
}
a:hover {
color: ${p => p.theme.textColor};
}
`;

const CommitContent = styled('div')`
display: flex;
flex-direction: column;
gap: ${space(0.25)};
${p => p.theme.overflowEllipsis};
`;

const MetaWrapper = styled('div')`
display: flex;
align-items: center;
gap: ${space(0.5)};
color: ${p => p.theme.subText};
font-size: ${p => p.theme.fontSizeMedium};
line-height: 1.2;
`;

const AuthorWrapper = styled('span')`
display: inline-flex;
align-items: center;
gap: ${space(0.25)};
color: ${p => p.theme.subText};
& svg {
transition: 120ms opacity;
opacity: 0.6;
}
&:has(svg):hover {
color: ${p => p.theme.textColor};
& svg {
opacity: 1;
}
}
`;

0 comments on commit 8f3e90a

Please sign in to comment.