1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00
unleash.unleash/frontend/src/component/project/ProjectCard/ProjectCard.tsx

116 lines
4.2 KiB
TypeScript
Raw Normal View History

import {
StyledProjectCard,
StyledCardTitle,
StyledProjectCardBody,
StyledIconBox,
} from './ProjectCard.styles';
import { ProjectCardFooter } from './ProjectCardFooter/ProjectCardFooter';
import { ProjectModeBadge } from './ProjectModeBadge/ProjectModeBadge';
fix: project icon sizing and color (#7672) This PR fixes the project icon sizing and color in the create feature form. However, it includes a little more cleanup work. 1. I've switched out the previous project icon with a new one. The difference? The old one had lots of whitespace around it, which made sizing it awkward. 2. I've added a wrapping Icon component to common. The idea was taken from this thread on the MUI GitHub about how to make imported icons behave consistently with MUI icons. 3. Because I've switched the icon and added a new component, I've also gone and updated the other places we used the old icon, so that we're consistent about the usage. In create dialog form: ![image](https://github.com/user-attachments/assets/9b5caed7-cd50-437b-82bb-1d7ccbfaac3f) Updated icon in: Project card component ![image](https://github.com/user-attachments/assets/4ce809f4-4083-4554-ac4c-3597d9bf42df) Project creation form ![image](https://github.com/user-attachments/assets/4227416f-a56d-41ed-96a4-99b71a11dbf7) Sidebar and command bar (it's actually larger here, but maybe that's okay? Previous project was kinda small): ![image](https://github.com/user-attachments/assets/72b8aa2e-6970-4c11-9a4d-250648b44ad9) (Previous sidebar and command bar): ![image](https://github.com/user-attachments/assets/bcef9208-9819-4742-87a1-3a20d50d741c) I'd be willing to leave the sidebar and command bar for now if we think it's better to leave them using the same size as previously, but we can talk about that. I think it's better in the sidebar; undecided about the command bar. Bonus changes: I fixed some typos
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 { Highlighter } from 'component/common/Highlighter/Highlighter';
import { useSearchHighlightContext } from 'component/common/Table/SearchHighlightContext/SearchHighlightContext';
import { ProjectMembers } from './ProjectCardFooter/ProjectMembers/ProjectMembers';
import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender';
import { DEFAULT_PROJECT_ID } from 'hooks/api/getters/useDefaultProject/useDefaultProjectId';
import type { ProjectSchema } from 'openapi';
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-29 16:49:46 +02:00
alignItems: 'center',
2024-08-28 18:26:41 +02:00
}));
type ProjectCardProps = ProjectSchema & { onHover?: () => void };
export const ProjectCard = ({
name,
featureCount,
health,
memberCount = 0,
onHover,
id,
mode,
favorite = false,
owners,
2024-08-29 16:39:44 +02:00
createdAt,
2024-08-28 18:26:41 +02:00
lastUpdatedAt,
lastReportedFlagUsage,
}: ProjectCardProps) => {
const { searchQuery } = useSearchHighlightContext();
return (
<StyledProjectCard onMouseEnter={onHover}>
<StyledProjectCardBody>
2024-08-29 16:39:44 +02:00
<StyledHeader>
<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>
</Box>
<ProjectModeBadge mode={mode} />
<FavoriteAction id={id} isFavorite={favorite} />
2024-08-29 16:39:44 +02:00
</StyledHeader>
<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>
</StyledInfo>
</StyledProjectCardBody>
<ProjectCardFooter id={id} owners={owners}>
<ConditionallyRender
condition={id !== DEFAULT_PROJECT_ID}
show={<ProjectMembers count={memberCount} members={[]} />}
/>
</ProjectCardFooter>
</StyledProjectCard>
);
};