2024-10-08 09:50:28 +02:00
|
|
|
import { Typography, styled } from '@mui/material';
|
2024-09-26 12:47:29 +02:00
|
|
|
import { Badge } from 'component/common/Badge/Badge';
|
2024-09-27 10:41:25 +02:00
|
|
|
import { AvatarGroupFromOwners } from 'component/common/AvatarGroupFromOwners/AvatarGroupFromOwners';
|
2024-09-26 12:47:29 +02:00
|
|
|
import type { ProjectSchemaOwners } from 'openapi';
|
2024-10-08 09:50:28 +02:00
|
|
|
import { HtmlTooltip } from 'component/common/HtmlTooltip/HtmlTooltip';
|
2024-09-26 12:47:29 +02:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
roles: string[];
|
|
|
|
owners: ProjectSchemaOwners;
|
|
|
|
};
|
|
|
|
|
|
|
|
const Wrapper = styled('div')(({ theme }) => ({
|
|
|
|
width: '100%',
|
|
|
|
display: 'flex',
|
|
|
|
flexDirection: 'row',
|
|
|
|
gap: theme.spacing(1),
|
|
|
|
justifyContent: 'space-between',
|
|
|
|
}));
|
|
|
|
|
|
|
|
const InfoSection = styled('div')(({ theme }) => ({
|
|
|
|
display: 'flex',
|
|
|
|
gap: theme.spacing(1),
|
2024-10-03 14:29:49 +02:00
|
|
|
alignItems: 'center',
|
2024-09-26 12:47:29 +02:00
|
|
|
}));
|
|
|
|
|
2024-10-08 09:50:28 +02:00
|
|
|
const Roles = styled('ul')(({ theme }) => ({
|
|
|
|
display: 'flex',
|
|
|
|
gap: theme.spacing(1),
|
|
|
|
flexFlow: 'row wrap',
|
|
|
|
listStyle: 'none',
|
|
|
|
padding: 0,
|
|
|
|
}));
|
|
|
|
|
|
|
|
const TooltipRoles = styled('ul')(({ theme }) => ({
|
|
|
|
gap: theme.spacing(1),
|
|
|
|
flexFlow: 'column',
|
|
|
|
display: 'flex',
|
|
|
|
listStyle: 'none',
|
|
|
|
padding: 0,
|
|
|
|
}));
|
|
|
|
|
|
|
|
const RoleBadge = styled(Badge)({
|
|
|
|
whitespace: 'nowrap',
|
|
|
|
});
|
|
|
|
|
|
|
|
const StyledAvatarGroup = styled(AvatarGroupFromOwners)({
|
|
|
|
width: 'max-content',
|
|
|
|
});
|
|
|
|
|
2024-09-26 12:47:29 +02:00
|
|
|
export const RoleAndOwnerInfo = ({ roles, owners }: Props) => {
|
2024-10-08 09:50:28 +02:00
|
|
|
const firstRoles = roles.slice(0, 3);
|
|
|
|
const extraRoles = roles.slice(3);
|
2024-09-26 12:47:29 +02:00
|
|
|
return (
|
|
|
|
<Wrapper>
|
|
|
|
<InfoSection>
|
2024-10-02 09:37:02 +02:00
|
|
|
{roles.length > 0 ? (
|
|
|
|
<>
|
2024-10-08 09:50:28 +02:00
|
|
|
<Typography
|
|
|
|
sx={{
|
|
|
|
whiteSpace: 'nowrap',
|
|
|
|
}}
|
|
|
|
variant='body1'
|
|
|
|
component='h4'
|
|
|
|
>
|
|
|
|
Your roles in this project:
|
|
|
|
</Typography>
|
|
|
|
<Roles>
|
|
|
|
{firstRoles.map((role) => (
|
2024-10-08 12:28:31 +02:00
|
|
|
<li key={role}>
|
|
|
|
<RoleBadge color='secondary'>
|
2024-10-08 09:50:28 +02:00
|
|
|
{role}
|
|
|
|
</RoleBadge>
|
|
|
|
</li>
|
|
|
|
))}
|
|
|
|
{extraRoles.length ? (
|
|
|
|
<li>
|
|
|
|
<HtmlTooltip
|
|
|
|
arrow
|
|
|
|
title={
|
|
|
|
<TooltipRoles>
|
|
|
|
{extraRoles.map((role) => (
|
2024-10-08 12:28:31 +02:00
|
|
|
<li key={role}>
|
2024-10-08 09:50:28 +02:00
|
|
|
<RoleBadge>
|
|
|
|
{role}
|
|
|
|
</RoleBadge>
|
|
|
|
</li>
|
|
|
|
))}
|
|
|
|
</TooltipRoles>
|
|
|
|
}
|
|
|
|
>
|
|
|
|
<RoleBadge
|
|
|
|
key={'extra-roles'}
|
|
|
|
color='secondary'
|
|
|
|
>
|
|
|
|
{`+ ${extraRoles.length} more`}
|
|
|
|
</RoleBadge>
|
|
|
|
</HtmlTooltip>
|
|
|
|
</li>
|
|
|
|
) : null}
|
|
|
|
</Roles>
|
2024-10-02 09:37:02 +02:00
|
|
|
</>
|
|
|
|
) : (
|
|
|
|
<span>You have no project roles in this project.</span>
|
|
|
|
)}
|
2024-09-26 12:47:29 +02:00
|
|
|
</InfoSection>
|
|
|
|
<InfoSection>
|
2024-10-08 09:50:28 +02:00
|
|
|
<Typography
|
|
|
|
variant='body1'
|
|
|
|
component='h4'
|
|
|
|
sx={{
|
|
|
|
whiteSpace: 'nowrap',
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
Project owner{owners.length > 1 ? 's' : ''}
|
|
|
|
</Typography>
|
|
|
|
<StyledAvatarGroup users={owners} avatarLimit={3} />
|
2024-09-26 12:47:29 +02:00
|
|
|
</InfoSection>
|
|
|
|
</Wrapper>
|
|
|
|
);
|
|
|
|
};
|