2024-04-18 11:20:01 +02:00
|
|
|
import {
|
|
|
|
StyledProjectCard,
|
2024-04-29 11:51:44 +02:00
|
|
|
StyledCardTitle,
|
2024-04-18 11:20:01 +02:00
|
|
|
StyledProjectCardBody,
|
2024-04-29 11:51:44 +02:00
|
|
|
StyledIconBox,
|
2024-08-27 14:11:07 +02:00
|
|
|
} from './ProjectCard.styles';
|
2024-04-18 11:20:01 +02:00
|
|
|
import { ProjectCardFooter } from './ProjectCardFooter/ProjectCardFooter';
|
2024-04-29 11:51:44 +02:00
|
|
|
import { ProjectModeBadge } from './ProjectModeBadge/ProjectModeBadge';
|
2024-07-26 10:26:16 +02:00
|
|
|
import { ProjectIcon } from 'component/common/ProjectIcon/ProjectIcon';
|
2024-08-28 18:26:41 +02:00
|
|
|
import { FavoriteAction } from './FavoriteAction/FavoriteAction';
|
|
|
|
import { Box, styled } from '@mui/material';
|
|
|
|
import { flexColumn } from 'themes/themeStyles';
|
|
|
|
import { TimeAgo } from 'component/common/TimeAgo/TimeAgo';
|
|
|
|
import { ProjectLastSeen } from './ProjectLastSeen/ProjectLastSeen';
|
|
|
|
import type { IProjectCard } from 'interfaces/project';
|
2024-08-29 15:43:16 +02:00
|
|
|
import { Highlighter } from 'component/common/Highlighter/Highlighter';
|
|
|
|
import { useSearchHighlightContext } from 'component/common/Table/SearchHighlightContext/SearchHighlightContext';
|
2024-04-18 11:20:01 +02:00
|
|
|
|
2024-08-28 18:26:41 +02:00
|
|
|
const StyledUpdated = styled('span')(({ theme }) => ({
|
|
|
|
color: theme.palette.text.secondary,
|
|
|
|
fontSize: theme.fontSizes.smallerBody,
|
|
|
|
}));
|
|
|
|
|
|
|
|
const StyledCount = styled('strong')(({ theme }) => ({
|
|
|
|
fontWeight: theme.typography.fontWeightMedium,
|
|
|
|
}));
|
|
|
|
|
|
|
|
const StyledInfo = styled('div')(({ theme }) => ({
|
2024-08-29 16:39:44 +02:00
|
|
|
display: 'grid',
|
|
|
|
gridTemplate: '1rem 1rem / 1fr 1fr',
|
|
|
|
gridAutoFlow: 'column',
|
|
|
|
alignItems: 'center',
|
2024-08-28 18:26:41 +02:00
|
|
|
justifyContent: 'space-between',
|
|
|
|
marginTop: theme.spacing(1),
|
|
|
|
fontSize: theme.fontSizes.smallerBody,
|
2024-08-29 16:39:44 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
const StyledHeader = styled('div')(({ theme }) => ({
|
|
|
|
gap: theme.spacing(1),
|
|
|
|
display: 'flex',
|
|
|
|
width: '100%',
|
2024-08-28 18:26:41 +02:00
|
|
|
}));
|
2024-04-18 11:20:01 +02:00
|
|
|
|
|
|
|
export const ProjectCard = ({
|
|
|
|
name,
|
|
|
|
featureCount,
|
|
|
|
health,
|
2024-08-13 14:33:11 +02:00
|
|
|
memberCount = 0,
|
2024-04-18 11:20:01 +02:00
|
|
|
onHover,
|
|
|
|
id,
|
|
|
|
mode,
|
2024-08-13 15:19:13 +02:00
|
|
|
favorite = false,
|
2024-04-29 11:51:44 +02:00
|
|
|
owners,
|
2024-08-29 16:39:44 +02:00
|
|
|
createdAt,
|
2024-08-28 18:26:41 +02:00
|
|
|
lastUpdatedAt,
|
|
|
|
lastReportedFlagUsage,
|
2024-08-29 15:43:16 +02:00
|
|
|
}: IProjectCard) => {
|
|
|
|
const { searchQuery } = useSearchHighlightContext();
|
|
|
|
|
|
|
|
return (
|
|
|
|
<StyledProjectCard onMouseEnter={onHover}>
|
|
|
|
<StyledProjectCardBody>
|
2024-08-29 16:39:44 +02:00
|
|
|
<StyledHeader>
|
2024-08-29 15:43:16 +02:00
|
|
|
<StyledIconBox>
|
|
|
|
<ProjectIcon />
|
|
|
|
</StyledIconBox>
|
|
|
|
<Box
|
|
|
|
data-loading
|
|
|
|
sx={(theme) => ({
|
|
|
|
...flexColumn,
|
|
|
|
margin: theme.spacing(1, 'auto', 1, 0),
|
|
|
|
})}
|
|
|
|
>
|
|
|
|
<StyledCardTitle lines={1} sx={{ margin: 0 }}>
|
|
|
|
<Highlighter search={searchQuery}>
|
|
|
|
{name}
|
|
|
|
</Highlighter>
|
|
|
|
</StyledCardTitle>
|
2024-08-29 16:39:44 +02:00
|
|
|
<StyledUpdated>
|
|
|
|
Updated{' '}
|
|
|
|
<TimeAgo date={lastUpdatedAt || createdAt} />
|
|
|
|
</StyledUpdated>
|
2024-08-29 15:43:16 +02:00
|
|
|
</Box>
|
|
|
|
<ProjectModeBadge mode={mode} />
|
|
|
|
<FavoriteAction id={id} isFavorite={favorite} />
|
2024-08-29 16:39:44 +02:00
|
|
|
</StyledHeader>
|
2024-08-29 15:43:16 +02:00
|
|
|
<StyledInfo>
|
2024-08-29 16:39:44 +02:00
|
|
|
<div data-loading>
|
|
|
|
<StyledCount>{featureCount}</StyledCount> flag
|
|
|
|
{featureCount === 1 ? '' : 's'}
|
|
|
|
</div>
|
|
|
|
<div data-loading>
|
|
|
|
<StyledCount>{health}%</StyledCount> health
|
|
|
|
</div>
|
|
|
|
<div />
|
|
|
|
<div data-loading>
|
|
|
|
<ProjectLastSeen date={lastReportedFlagUsage} />
|
2024-08-28 18:26:41 +02:00
|
|
|
</div>
|
2024-08-29 15:43:16 +02:00
|
|
|
</StyledInfo>
|
|
|
|
</StyledProjectCardBody>
|
|
|
|
<ProjectCardFooter
|
|
|
|
id={id}
|
|
|
|
owners={owners}
|
|
|
|
memberCount={memberCount}
|
|
|
|
/>
|
|
|
|
</StyledProjectCard>
|
|
|
|
);
|
|
|
|
};
|