Closes #4810 - Introduces a new component `ExpandableList` which uses intersection observers to display the maximum number of elements possible
37 lines
1.0 KiB
TypeScript
37 lines
1.0 KiB
TypeScript
import styled from '@emotion/styled';
|
|
|
|
import { ParticipantChip } from '@/activities/components/ParticipantChip';
|
|
import { EmailThreadMessageParticipant } from '@/activities/emails/types/EmailThreadMessageParticipant';
|
|
import { beautifyPastDateRelativeToNow } from '~/utils/date-utils';
|
|
|
|
const StyledEmailThreadMessageSender = styled.div`
|
|
display: flex;
|
|
justify-content: space-between;
|
|
`;
|
|
|
|
const StyledThreadMessageSentAt = styled.div`
|
|
align-items: flex-end;
|
|
display: flex;
|
|
color: ${({ theme }) => theme.font.color.tertiary};
|
|
font-size: ${({ theme }) => theme.font.size.sm};
|
|
`;
|
|
|
|
type EmailThreadMessageSenderProps = {
|
|
sender: EmailThreadMessageParticipant;
|
|
sentAt: string;
|
|
};
|
|
|
|
export const EmailThreadMessageSender = ({
|
|
sender,
|
|
sentAt,
|
|
}: EmailThreadMessageSenderProps) => {
|
|
return (
|
|
<StyledEmailThreadMessageSender>
|
|
<ParticipantChip participant={sender} variant="bold" />
|
|
<StyledThreadMessageSentAt>
|
|
{beautifyPastDateRelativeToNow(sentAt)}
|
|
</StyledThreadMessageSentAt>
|
|
</StyledEmailThreadMessageSender>
|
|
);
|
|
};
|