mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2025-07-29 23:00:08 +02:00

Adapt online user and chat user colors based on luminance GitOrigin-RevId: 1b0c843147ee3dc585866bc491a7c7613cb00e70
87 lines
2.7 KiB
TypeScript
87 lines
2.7 KiB
TypeScript
import { MessageProps } from '@/features/chat/components/message'
|
|
import { User } from '../../../../../../types/user'
|
|
import {
|
|
getBackgroundColorForUserId,
|
|
hslStringToLuminance,
|
|
} from '@/shared/utils/colors'
|
|
import MessageContent from '@/features/chat/components/message-content'
|
|
import classNames from 'classnames'
|
|
import MaterialIcon from '@/shared/components/material-icon'
|
|
import { t } from 'i18next'
|
|
|
|
function getAvatarStyle(user?: User) {
|
|
if (!user?.id) {
|
|
// Deleted user
|
|
return {
|
|
backgroundColor: 'var(--bg-light-disabled)',
|
|
borderColor: 'var(--bg-light-disabled)',
|
|
color: 'var(--content-disabled)',
|
|
}
|
|
}
|
|
|
|
const backgroundColor = getBackgroundColorForUserId(user.id)
|
|
|
|
return {
|
|
borderColor: backgroundColor,
|
|
backgroundColor,
|
|
color:
|
|
hslStringToLuminance(backgroundColor) < 0.5
|
|
? 'var(--content-primary-dark)'
|
|
: 'var(--content-primary)',
|
|
}
|
|
}
|
|
|
|
function Message({ message, fromSelf }: MessageProps) {
|
|
return (
|
|
<div className="chat-message-redesign">
|
|
<div className="message-row">
|
|
<div className="message-avatar-placeholder" />
|
|
{!fromSelf && (
|
|
<div className="message-author">
|
|
<span>
|
|
{message.user?.id && message.user.email
|
|
? message.user.first_name || message.user.email
|
|
: t('deleted_user')}
|
|
</span>
|
|
</div>
|
|
)}
|
|
</div>
|
|
{message.contents.map((content, index) => (
|
|
<div key={index} className="message-row">
|
|
<>
|
|
{!fromSelf && index === message.contents.length - 1 ? (
|
|
<div className="message-avatar">
|
|
<div className="avatar" style={getAvatarStyle(message.user)}>
|
|
{message.user?.id && message.user.email ? (
|
|
message.user.first_name?.charAt(0) ||
|
|
message.user.email.charAt(0)
|
|
) : (
|
|
<MaterialIcon
|
|
type="delete"
|
|
className="message-avatar-deleted-user-icon"
|
|
/>
|
|
)}
|
|
</div>
|
|
</div>
|
|
) : (
|
|
<div className="message-avatar-placeholder" />
|
|
)}
|
|
<div
|
|
className={classNames('message-container', {
|
|
'message-from-self': fromSelf,
|
|
'first-row-in-message': index === 0,
|
|
'last-row-in-message': index === message.contents.length - 1,
|
|
})}
|
|
>
|
|
<div className="message-content">
|
|
<MessageContent content={content} />
|
|
</div>
|
|
</div>
|
|
</>
|
|
</div>
|
|
))}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default Message
|