1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-20 00:08:02 +01:00

feat: project health card (#6595)

This commit is contained in:
Mateusz Kwasniewski 2024-03-19 09:01:27 +01:00 committed by GitHub
parent 5db0e9ac6e
commit 52363f176a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 113 additions and 4 deletions

View File

@ -0,0 +1,101 @@
import { ProjectHealthChart } from './ProjectHealthChart';
import { Alert, Box, styled, Typography, useTheme } from '@mui/material';
import { Link } from 'react-router-dom';
import { useRequiredPathParam } from 'hooks/useRequiredPathParam';
const Dot = styled('span', {
shouldForwardProp: (prop) => prop !== 'color',
})<{ color?: string }>(({ theme, color }) => ({
height: '15px',
width: '15px',
borderRadius: '50%',
display: 'inline-block',
backgroundColor: color,
}));
const FlagsCount = styled('p')(({ theme }) => ({
color: theme.palette.text.secondary,
marginLeft: theme.spacing(3),
}));
const FlagCounts = styled(Box)(({ theme }) => ({
display: 'flex',
flexDirection: 'column',
gap: theme.spacing(2),
}));
const Container = styled(Box)(({ theme }) => ({
display: 'flex',
flexDirection: 'column',
gap: theme.spacing(2),
}));
const StatusWithDot = styled(Box)(({ theme }) => ({
display: 'flex',
alignItems: 'center',
gap: theme.spacing(1),
}));
export const ProjectHealth = () => {
const theme = useTheme();
const projectId = useRequiredPathParam('projectId');
const active = 15;
const stale = 10;
const potentiallyStale = 3;
const health = 93;
return (
<Container>
<Typography variant='h3'>Project Health</Typography>
<Alert severity='warning'>
<b>Health alert!</b> Review your flags and delete the stale
flags
</Alert>
<Box
sx={(theme) => ({
display: 'flex',
gap: theme.spacing(4),
marginTop: theme.spacing(3),
})}
>
<ProjectHealthChart
active={active}
stale={stale}
potentiallyStale={potentiallyStale}
health={health}
/>
<FlagCounts>
<Box>
<StatusWithDot>
<Dot color={theme.palette.success.border} />
<Box sx={{ fontWeight: 'bold' }}>Active</Box>
</StatusWithDot>
<FlagsCount>{active} feature flags</FlagsCount>
</Box>
<Box>
<StatusWithDot>
<Dot color={theme.palette.warning.border} />
<Box sx={{ fontWeight: 'bold' }}>
Potentially stale
</Box>
<Link to='/feature-toggle-type'>(configure)</Link>
</StatusWithDot>
<FlagsCount>
{potentiallyStale} feature flags
</FlagsCount>
</Box>
<Box>
<StatusWithDot>
<Dot color={theme.palette.error.border} />
<Box sx={{ fontWeight: 'bold' }}>Stale</Box>
<Link to={`/projects/${projectId}`}>
(view flags)
</Link>
</StatusWithDot>
<FlagsCount>{stale} feature flags</FlagsCount>
</Box>
</FlagCounts>
</Box>
</Container>
);
};

View File

@ -1,7 +1,6 @@
import React from 'react';
import '@testing-library/jest-dom';
import { ProjectHealthChart } from './ProjectHealthChart';
import { render } from 'utils/testRenderer';
import { render } from '../../../../../utils/testRenderer';
import { screen } from '@testing-library/react';
describe('ProjectHealthChart', () => {

View File

@ -1,5 +1,12 @@
import { Box, styled } from '@mui/material';
import { LeadTimeForChanges } from './LeadTimeForChanges/LeadTimeForChanges';
import { ProjectHealth } from './ProjectHealth/ProjectHealth';
const Container = styled(Box)(({ theme }) => ({
backgroundColor: theme.palette.background.paper,
padding: theme.spacing(3),
borderRadius: theme.shape.borderRadiusLarge,
}));
const Grid = styled(Box)(({ theme }) => ({
display: 'grid',
@ -11,7 +18,7 @@ const Overview = styled(Box)(({ theme }) => ({
gridColumn: '1 / -1',
}));
const Health = styled(Box)(({ theme }) => ({
const Health = styled(Container)(({ theme }) => ({
gridColumn: 'span 5',
}));
@ -34,7 +41,9 @@ export const ProjectInsights = () => {
Total changes / avg time to production / feature flags /stale
flags
</Overview>
<Health>Project Health</Health>
<Health>
<ProjectHealth />
</Health>
<LeadTimeForChanges />
<ToggleTypesUsed>Toggle types used</ToggleTypesUsed>
<ProjectMembers>Project members</ProjectMembers>