import { useRouter } from '@uirouter/react'; import { PropsWithChildren } from 'react'; import { RefreshCw } from 'lucide-react'; import { dispatchCacheRefreshEvent } from '@/portainer/services/http-request.helper'; import { Button } from '../buttons'; import { Breadcrumbs } from './Breadcrumbs'; import { Crumb } from './Breadcrumbs/Breadcrumbs'; import { HeaderContainer } from './HeaderContainer'; import { HeaderTitle } from './HeaderTitle'; interface Props { id?: string; reload?: boolean; loading?: boolean; onReload?(): Promise | void; breadcrumbs?: (Crumb | string)[] | string; title: string; } export function PageHeader({ id, title, breadcrumbs = [], reload, loading, onReload, children, }: PropsWithChildren) { const router = useRouter(); return ( {reload && ( )} {children} ); function onClickedRefresh() { dispatchCacheRefreshEvent(); return onReload ? onReload() : router.stateService.reload(); } }