import { useState, type VFC } from 'react'; import { Box, styled } from '@mui/material'; import { ArrayParam, withDefault } from 'use-query-params'; import { usePersistentTableState } from 'hooks/usePersistentTableState'; import { allOption, ProjectSelect, } from 'component/common/ProjectSelect/ProjectSelect'; import { useInsights } from 'hooks/api/getters/useInsights/useInsights'; import { InsightsHeader } from './components/InsightsHeader/InsightsHeader'; import { useInsightsData } from './hooks/useInsightsData'; import { InsightsCharts } from './InsightsCharts'; const StickyWrapper = styled(Box, { shouldForwardProp: (prop) => prop !== 'scrolled', })<{ scrolled?: boolean }>(({ theme, scrolled }) => ({ position: 'sticky', top: 0, zIndex: 1000, padding: scrolled ? theme.spacing(2, 0) : theme.spacing(0, 0, 2), background: theme.palette.background.application, transition: 'padding 0.3s ease', })); export const Insights: VFC = () => { const [scrolled, setScrolled] = useState(false); const { insights, loading, error } = useInsights(); const stateConfig = { projects: withDefault(ArrayParam, [allOption.id]), }; const [state, setState] = usePersistentTableState('insights', stateConfig); const setProjects = (projects: string[]) => { setState({ projects }); }; const projects = state.projects ? (state.projects.filter(Boolean) as string[]) : []; const insightsData = useInsightsData(insights, projects); const handleScroll = () => { if (!scrolled && window.scrollY > 0) { setScrolled(true); } else if (scrolled && window.scrollY === 0) { setScrolled(false); } }; if (typeof window !== 'undefined') { window.addEventListener('scroll', handleScroll); } return ( <> } /> ); };