0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Extracted <RepliedToSnippet> component from <CommentHeader>

no issue

- keeps logic inside `<CommentHeader>` single-purpose
- allows for cleaner code when adding logic to remove the link when the replied-to comment is removed
- switched `queryByText` to `getByText` in the test to make debugging easier, the latter will print the current DOM if it fails to find an element

# Conflicts:
#	apps/comments-ui/src/components/content/Comment.tsx
This commit is contained in:
Kevin Ansfield 2024-12-04 13:44:49 +00:00
parent f06de99410
commit 0651d7178b
2 changed files with 34 additions and 23 deletions

View file

@ -37,6 +37,6 @@ describe('<CommentComponent>', function () {
contextualRender(<CommentComponent comment={comment} parent={parent} />, {appContext});
expect(screen.queryByText('First reply')).toBeInTheDocument();
expect(screen.getByText('First reply')).toBeInTheDocument();
});
});

View file

@ -279,27 +279,9 @@ const AuthorName: React.FC<{comment: Comment}> = ({comment}) => {
);
};
type CommentHeaderProps = {
comment: Comment;
className?: string;
}
const CommentHeader: React.FC<CommentHeaderProps> = ({comment, className = ''}) => {
const {comments, t, dispatchAction} = useAppContext();
const labs = useLabs();
const createdAtRelative = useRelativeTime(comment.created_at);
const {member} = useAppContext();
const memberExpertise = member && comment.member && comment.member.uuid === member.uuid ? member.expertise : comment?.member?.expertise;
const isReplyToReply = labs.commentImprovements && comment.in_reply_to_id && comment.in_reply_to_snippet;
let inReplyToSnippet = comment.in_reply_to_snippet;
if (isReplyToReply) {
const RepliedToSnippet: React.FC<{comment: Comment}> = ({comment}) => {
const {comments, dispatchAction, t} = useAppContext();
const inReplyToComment = findCommentById(comments, comment.in_reply_to_id);
if (inReplyToComment && inReplyToComment.status !== 'published') {
inReplyToSnippet = `[${t('removed')}]`;
}
}
const scrollRepliedToCommentIntoView = (e: React.MouseEvent<HTMLAnchorElement>) => {
e.preventDefault();
@ -315,6 +297,35 @@ const CommentHeader: React.FC<CommentHeaderProps> = ({comment, className = ''})
}
};
let inReplyToSnippet = comment.in_reply_to_snippet;
if (inReplyToComment && inReplyToComment.status !== 'published') {
inReplyToSnippet = `[${t('removed')}]`;
}
return (
<a
className="font-semibold text-neutral-900/60 transition-colors hover:text-neutral-900/70 dark:text-white/70 dark:hover:text-white/80"
data-testid="comment-in-reply-to"
href={`#${comment.in_reply_to_id}`}
onClick={scrollRepliedToCommentIntoView}
>
{inReplyToSnippet}
</a>
);
};
type CommentHeaderProps = {
comment: Comment;
className?: string;
}
const CommentHeader: React.FC<CommentHeaderProps> = ({comment, className = ''}) => {
const {member, t} = useAppContext();
const labs = useLabs();
const createdAtRelative = useRelativeTime(comment.created_at);
const memberExpertise = member && comment.member && comment.member.uuid === member.uuid ? member.expertise : comment?.member?.expertise;
const isReplyToReply = labs.commentImprovements && comment.in_reply_to_id && comment.in_reply_to_snippet;
return (
<>
<div className={`mt-0.5 flex flex-wrap items-start sm:flex-row ${memberExpertise ? 'flex-col' : 'flex-row'} ${isReplyToReply ? 'mb-0.5' : 'mb-2'} ${className}`}>
@ -329,7 +340,7 @@ const CommentHeader: React.FC<CommentHeaderProps> = ({comment, className = ''})
</div>
{(isReplyToReply &&
<div className="mb-2 line-clamp-1 font-sans text-base leading-snug text-neutral-900/50 sm:text-sm dark:text-white/60">
<span>{t('Replied to')}</span>:&nbsp;<a className="font-semibold text-neutral-900/60 transition-colors hover:text-neutral-900/75 dark:text-white/70 dark:hover:text-white/85" data-testid="comment-in-reply-to" href={`#${comment.in_reply_to_id}`} onClick={scrollRepliedToCommentIntoView}>{inReplyToSnippet}</a>
<span>{t('Replied to')}</span>:&nbsp;<RepliedToSnippet comment={comment} />
</div>
)}
</>