mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
Added separate BlankAvatar component
refs https://github.com/TryGhost/Team/issues/1858
This commit is contained in:
parent
b701ba9c0d
commit
90e0ced175
3 changed files with 22 additions and 23 deletions
|
@ -3,21 +3,24 @@ import AppContext from '../AppContext';
|
||||||
import {getInitials} from '../utils/helpers';
|
import {getInitials} from '../utils/helpers';
|
||||||
import {ReactComponent as AvatarIcon} from '../images/icons/avatar.svg';
|
import {ReactComponent as AvatarIcon} from '../images/icons/avatar.svg';
|
||||||
|
|
||||||
const Avatar = ({comment, size, isBlank}) => {
|
function getDimensionClasses() {
|
||||||
const {member, avatarSaturation} = useContext(AppContext);
|
return 'w-9 h-9 sm:w-[40px] sm:h-[40px]';
|
||||||
const dimensionClasses = (size === 'small' ? 'w-6 h-6 sm:w-8 sm:h-8' : 'w-9 h-9 sm:w-[40px] sm:h-[40px]');
|
}
|
||||||
|
|
||||||
// When an avatar has been deleted or hidden
|
export const BlankAvatar = () => {
|
||||||
// todo: move to seperate component
|
const dimensionClasses = getDimensionClasses();
|
||||||
if (isBlank) {
|
return (
|
||||||
return (
|
<figure className={`relative ${dimensionClasses}`}>
|
||||||
<figure className={`relative ${dimensionClasses}`}>
|
<div className={`flex items-center justify-center rounded-full bg-[rgba(200,200,200,0.3)] ${dimensionClasses}`}>
|
||||||
<div className={`flex items-center justify-center rounded-full bg-[rgba(200,200,200,0.3)] ${dimensionClasses}`}>
|
<AvatarIcon className="stroke-white dark:opacity-70" />
|
||||||
<AvatarIcon className="stroke-white dark:opacity-70" />
|
</div>
|
||||||
</div>
|
</figure>
|
||||||
</figure>
|
);
|
||||||
);
|
}
|
||||||
}
|
|
||||||
|
export const Avatar = ({comment}) => {
|
||||||
|
const {member, avatarSaturation} = useContext(AppContext);
|
||||||
|
const dimensionClasses = getDimensionClasses();
|
||||||
|
|
||||||
const memberName = member?.name ?? comment?.member?.name;
|
const memberName = member?.name ?? comment?.member?.name;
|
||||||
|
|
||||||
|
@ -72,7 +75,6 @@ const Avatar = ({comment, size, isBlank}) => {
|
||||||
return getInitials(commentMember.name);
|
return getInitials(commentMember.name);
|
||||||
};
|
};
|
||||||
|
|
||||||
let initialsClasses = (size === 'small' ? 'text-sm' : 'text-lg');
|
|
||||||
let commentMember = (comment ? comment.member : member);
|
let commentMember = (comment ? comment.member : member);
|
||||||
|
|
||||||
const bgColor = HSLtoString(generateHSL());
|
const bgColor = HSLtoString(generateHSL());
|
||||||
|
@ -84,7 +86,7 @@ const Avatar = ({comment, size, isBlank}) => {
|
||||||
<>
|
<>
|
||||||
{memberName ?
|
{memberName ?
|
||||||
(<div className={`flex items-center justify-center rounded-full ${dimensionClasses}`} style={avatarStyle}>
|
(<div className={`flex items-center justify-center rounded-full ${dimensionClasses}`} style={avatarStyle}>
|
||||||
<p className={`font-sans font-semibold text-white ${initialsClasses}`}>{ commentGetInitials() }</p>
|
<p className="font-sans font-semibold text-white text-lg">{ commentGetInitials() }</p>
|
||||||
</div>) :
|
</div>) :
|
||||||
(<div className={`flex items-center justify-center rounded-full bg-neutral-900 dark:bg-[rgba(255,255,255,0.7)] ${dimensionClasses}`}>
|
(<div className={`flex items-center justify-center rounded-full bg-neutral-900 dark:bg-[rgba(255,255,255,0.7)] ${dimensionClasses}`}>
|
||||||
<AvatarIcon className="stroke-white dark:stroke-[rgba(0,0,0,0.6)]" />
|
<AvatarIcon className="stroke-white dark:stroke-[rgba(0,0,0,0.6)]" />
|
||||||
|
@ -99,5 +101,3 @@ const Avatar = ({comment, size, isBlank}) => {
|
||||||
</figure>
|
</figure>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
export default Avatar;
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import React, {useContext, useState} from 'react';
|
import React, {useContext, useState} from 'react';
|
||||||
import {Transition} from '@headlessui/react';
|
import {Transition} from '@headlessui/react';
|
||||||
import Avatar from './Avatar';
|
import {BlankAvatar, Avatar} from './Avatar';
|
||||||
import Like from './Like';
|
import Like from './Like';
|
||||||
import Reply from './Reply';
|
import Reply from './Reply';
|
||||||
import More from './More';
|
import More from './More';
|
||||||
|
@ -96,12 +96,11 @@ function UnpublishedComment({comment, openEditMode}) {
|
||||||
notPublishedMessage = 'This comment has been removed.';
|
notPublishedMessage = 'This comment has been removed.';
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: consider swapping this with a seperate avatar component
|
const avatar = (<BlankAvatar />);
|
||||||
const blankAvatar = (<Avatar isBlank={true} />);
|
|
||||||
const hasReplies = comment.replies && comment.replies.length > 0;
|
const hasReplies = comment.replies && comment.replies.length > 0;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<CommentLayout hasReplies={hasReplies} avatar={blankAvatar}>
|
<CommentLayout hasReplies={hasReplies} avatar={avatar}>
|
||||||
<div className="-mt-[3px] mb-2 flex items-start">
|
<div className="-mt-[3px] mb-2 flex items-start">
|
||||||
<div className="flex h-12 flex-row items-center gap-4 pb-[8px] pr-4">
|
<div className="flex h-12 flex-row items-center gap-4 pb-[8px] pr-4">
|
||||||
<p className="mt-[4px] font-sans text-[16px] italic leading-normal text-neutral-300 dark:text-[rgba(255,255,255,0.5)]">{notPublishedMessage}</p>
|
<p className="mt-[4px] font-sans text-[16px] italic leading-normal text-neutral-300 dark:text-[rgba(255,255,255,0.5)]">{notPublishedMessage}</p>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import React, {useCallback, useContext, useEffect, useRef, useState} from 'react';
|
import React, {useCallback, useContext, useEffect, useRef, useState} from 'react';
|
||||||
import {Transition} from '@headlessui/react';
|
import {Transition} from '@headlessui/react';
|
||||||
import AppContext from '../AppContext';
|
import AppContext from '../AppContext';
|
||||||
import Avatar from './Avatar';
|
import {Avatar} from './Avatar';
|
||||||
import {useEditor, EditorContent} from '@tiptap/react';
|
import {useEditor, EditorContent} from '@tiptap/react';
|
||||||
import {getEditorConfig} from '../utils/editor';
|
import {getEditorConfig} from '../utils/editor';
|
||||||
import {isMobile} from '../utils/helpers';
|
import {isMobile} from '../utils/helpers';
|
||||||
|
|
Loading…
Reference in a new issue