### Description 1. This PR is a continuation of a previous PR: https://github.com/twentyhq/twenty/pull/6201#pullrequestreview-2175601222 2. One test case was removed here: `packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURI.test.ts` because since we are not handling base64 images anymore, the result is the same of the last test case. Would you rather we update the test instead? ### Refs - #3514 - https://github.com/twentyhq/twenty/pull/6201 ### Demo https://www.loom.com/share/4f32b535c77a4d418e319b095d09452c?sid=df34adf8-b013-44ef-b794-d54846f52d2d Fixes #3514 --------- Co-authored-by: gitstart-twenty <gitstart-twenty@users.noreply.github.com>
58 lines
1.6 KiB
TypeScript
58 lines
1.6 KiB
TypeScript
import styled from '@emotion/styled';
|
|
import { Avatar, OverflowingTextWithTooltip } from 'twenty-ui';
|
|
|
|
import { WorkspaceMember } from '@/workspace-member/types/WorkspaceMember';
|
|
|
|
const StyledContainer = styled.div`
|
|
background: ${({ theme }) => theme.background.secondary};
|
|
border: 1px solid ${({ theme }) => theme.border.color.medium};
|
|
border-radius: ${({ theme }) => theme.spacing(2)};
|
|
display: flex;
|
|
flex-direction: row;
|
|
margin-bottom: ${({ theme }) => theme.spacing(0)};
|
|
margin-top: ${({ theme }) => theme.spacing(4)};
|
|
padding: ${({ theme }) => theme.spacing(3)};
|
|
`;
|
|
|
|
const StyledContent = styled.div`
|
|
display: flex;
|
|
flex: 1;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
margin-left: ${({ theme }) => theme.spacing(3)};
|
|
overflow: auto;
|
|
`;
|
|
|
|
const StyledEmailText = styled.span`
|
|
color: ${({ theme }) => theme.font.color.tertiary};
|
|
`;
|
|
|
|
type WorkspaceMemberCardProps = {
|
|
workspaceMember: WorkspaceMember;
|
|
accessory?: React.ReactNode;
|
|
};
|
|
|
|
export const WorkspaceMemberCard = ({
|
|
workspaceMember,
|
|
accessory,
|
|
}: WorkspaceMemberCardProps) => (
|
|
<StyledContainer>
|
|
<Avatar
|
|
avatarUrl={workspaceMember.avatarUrl}
|
|
placeholderColorSeed={workspaceMember.id}
|
|
placeholder={workspaceMember.name.firstName || ''}
|
|
type="squared"
|
|
size="xl"
|
|
/>
|
|
<StyledContent>
|
|
<OverflowingTextWithTooltip
|
|
text={
|
|
workspaceMember.name.firstName + ' ' + workspaceMember.name.lastName
|
|
}
|
|
/>
|
|
<StyledEmailText>{workspaceMember.userEmail}</StyledEmailText>
|
|
</StyledContent>
|
|
{accessory}
|
|
</StyledContainer>
|
|
);
|