import { type FC, useEffect, useState } from 'react'; import { Box, styled } from '@mui/material'; import ProjectInfo from './ProjectInfo/ProjectInfo'; import { useRequiredPathParam } from 'hooks/useRequiredPathParam'; import { ProjectStats } from './ProjectStats/ProjectStats'; import { ProjectFeatureToggles } from './PaginatedProjectFeatureToggles/ProjectFeatureToggles'; import useProjectOverview, { useProjectOverviewNameOrId, } from 'hooks/api/getters/useProjectOverview/useProjectOverview'; import { usePageTitle } from 'hooks/usePageTitle'; import { useLastViewedProject } from 'hooks/useLastViewedProject'; import { useUiFlag } from 'hooks/useUiFlag'; import { ProjectOverviewChangeRequests } from './ProjectOverviewChangeRequests'; import { useFeedback } from '../../feedbackNew/useFeedback'; import { OldProjectFeatureToggles } from './PaginatedProjectFeatureToggles/OldProjectFeatureToggles'; const refreshInterval = 15 * 1000; const StyledContainer = styled('div')(({ theme }) => ({ display: 'flex', gap: theme.spacing(2), [theme.breakpoints.down('md')]: { flexDirection: 'column', }, })); const StyledProjectToggles = styled('div')(() => ({ width: '100%', minWidth: 0, })); const StyledContentContainer = styled(Box)(({ theme }) => ({ display: 'flex', flexDirection: 'column', gap: theme.spacing(2), width: '100%', minWidth: 0, })); const ProjectOverview: FC<{ storageKey?: string; }> = ({ storageKey = 'project-overview-v2' }) => { const projectOverviewRefactor = useUiFlag('projectOverviewRefactor'); if (projectOverviewRefactor) { return ; } else { return ; } }; const OldProjectOverview: FC<{ storageKey?: string; }> = ({ storageKey = 'project-overview-v2' }) => { const projectId = useRequiredPathParam('projectId'); const projectName = useProjectOverviewNameOrId(projectId); const { project } = useProjectOverview(projectId, { refreshInterval, }); usePageTitle(`Project overview – ${projectName}`); const { setLastViewed } = useLastViewedProject(); useEffect(() => { setLastViewed(projectId); }, [projectId, setLastViewed]); const { members, featureTypeCounts, health, description, environments, stats, } = project; return ( environment.environment, )} refreshInterval={refreshInterval} storageKey={storageKey} /> ); }; const useDelayedFeedbackPrompt = () => { const { openFeedback, hasSubmittedFeedback } = useFeedback( 'newProjectOverview', 'manual', ); const [seenFeedback, setSeenFeedback] = useState(false); useEffect(() => { const timer = setTimeout(() => { if (!seenFeedback && !hasSubmittedFeedback) { openFeedback({ title: 'How easy was it to work with the project overview in Unleash?', positiveLabel: 'What do you like most about the updated project overview?', areasForImprovementsLabel: 'What improvements are needed in the project overview?', }); setSeenFeedback(true); } }, 30000); return () => clearTimeout(timer); }, [hasSubmittedFeedback, openFeedback, seenFeedback]); }; const NewProjectOverview: FC<{ storageKey?: string; }> = ({ storageKey = 'project-overview-v2' }) => { const projectId = useRequiredPathParam('projectId'); const projectName = useProjectOverviewNameOrId(projectId); const { project } = useProjectOverview(projectId, { refreshInterval, }); useDelayedFeedbackPrompt(); usePageTitle(`Project overview – ${projectName}`); const { setLastViewed } = useLastViewedProject(); useEffect(() => { setLastViewed(projectId); }, [projectId, setLastViewed]); return ( environment.environment, )} refreshInterval={refreshInterval} storageKey={storageKey} /> ); }; export default ProjectOverview;