The communications platform that puts data protection first.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Rocket.Chat/apps/meteor/client/components/message/MessageHeader.tsx

85 lines
2.9 KiB

import type { IMessage } from '@rocket.chat/core-typings';
import {
MessageHeader as FuselageMessageHeader,
MessageName,
MessageTimestamp,
MessageUsername,
MessageStatusPrivateIndicator,
MessageNameContainer,
} from '@rocket.chat/fuselage';
import { useButtonPattern } from '@rocket.chat/fuselage-hooks';
import { useUserDisplayName } from '@rocket.chat/ui-client';
import { useUserPresence, useUserCard } from '@rocket.chat/ui-contexts';
import type { ReactElement } from 'react';
import { memo } from 'react';
import { useTranslation } from 'react-i18next';
import StatusIndicators from './StatusIndicators';
import MessageRoles from './header/MessageRoles';
import { useMessageRoles } from './header/hooks/useMessageRoles';
import {
useMessageListShowUsername,
useMessageListShowRealName,
useMessageListShowRoles,
useMessageListFormatDateAndTime,
useMessageListFormatTime,
} from './list/MessageListContext';
type MessageHeaderProps = {
message: IMessage;
};
const MessageHeader = ({ message }: MessageHeaderProps): ReactElement => {
const { t } = useTranslation();
const formatTime = useMessageListFormatTime();
const formatDateAndTime = useMessageListFormatDateAndTime();
const { triggerProps, openUserCard } = useUserCard();
const buttonProps = useButtonPattern((e) => openUserCard(e, message.u.username));
const showRealName = useMessageListShowRealName();
const user = { ...message.u, roles: [], ...useUserPresence(message.u._id) };
const usernameAndRealNameAreSame = !user.name || user.username === user.name;
const showUsername = useMessageListShowUsername() && showRealName && !usernameAndRealNameAreSame;
const displayName = useUserDisplayName(user);
const showRoles = useMessageListShowRoles();
const roles = useMessageRoles(message.u._id, message.rid, showRoles);
const shouldShowRolesList = roles.length > 0;
return (
<FuselageMessageHeader>
<MessageNameContainer
id={`${message._id}-displayName`}
aria-label={displayName}
style={{ cursor: 'pointer' }}
{...buttonProps}
{...triggerProps}
>
<MessageName
{...(!showUsername && { 'data-qa-type': 'username' })}
title={!showUsername && !usernameAndRealNameAreSame ? `@${user.username}` : undefined}
data-username={user.username}
>
{message.alias || displayName}
</MessageName>
{showUsername && (
<>
{' '}
<MessageUsername data-username={user.username} data-qa-type='username'>
@{user.username}
</MessageUsername>
</>
)}
</MessageNameContainer>
{shouldShowRolesList && <MessageRoles roles={roles} isBot={!!message.bot} />}
<MessageTimestamp id={`${message._id}-time`} title={formatDateAndTime(message.ts)}>
{formatTime(message.ts)}
</MessageTimestamp>
{message.private && <MessageStatusPrivateIndicator>{t('Only_you_can_see_this_message')}</MessageStatusPrivateIndicator>}
<StatusIndicators message={message} />
</FuselageMessageHeader>
);
};
export default memo(MessageHeader);