2021-12-30 15:46:12 +00:00
|
|
|
import { useRouter } from '@uirouter/react';
|
2023-11-20 02:08:19 +00:00
|
|
|
import { PropsWithChildren } from 'react';
|
2023-11-22 01:21:07 +00:00
|
|
|
import { RefreshCw } from 'lucide-react';
|
|
|
|
|
|
|
|
import { dispatchCacheRefreshEvent } from '@/portainer/services/http-request.helper';
|
2021-12-30 15:46:12 +00:00
|
|
|
|
2022-06-17 16:18:42 +00:00
|
|
|
import { Button } from '../buttons';
|
2021-12-30 15:46:12 +00:00
|
|
|
|
|
|
|
import { Breadcrumbs } from './Breadcrumbs';
|
|
|
|
import { Crumb } from './Breadcrumbs/Breadcrumbs';
|
|
|
|
import { HeaderContainer } from './HeaderContainer';
|
|
|
|
import { HeaderTitle } from './HeaderTitle';
|
|
|
|
|
|
|
|
interface Props {
|
2022-08-19 12:31:17 +00:00
|
|
|
id?: string;
|
2021-12-30 15:46:12 +00:00
|
|
|
reload?: boolean;
|
2022-06-23 06:32:18 +00:00
|
|
|
loading?: boolean;
|
|
|
|
onReload?(): Promise<void> | void;
|
2022-07-26 19:44:08 +00:00
|
|
|
breadcrumbs?: (Crumb | string)[] | string;
|
2021-12-30 15:46:12 +00:00
|
|
|
title: string;
|
|
|
|
}
|
|
|
|
|
2022-06-23 06:32:18 +00:00
|
|
|
export function PageHeader({
|
2022-08-19 12:31:17 +00:00
|
|
|
id,
|
2022-06-23 06:32:18 +00:00
|
|
|
title,
|
|
|
|
breadcrumbs = [],
|
|
|
|
reload,
|
|
|
|
loading,
|
|
|
|
onReload,
|
2023-10-11 07:38:57 +00:00
|
|
|
children,
|
|
|
|
}: PropsWithChildren<Props>) {
|
2021-12-30 15:46:12 +00:00
|
|
|
const router = useRouter();
|
2022-06-23 06:32:18 +00:00
|
|
|
|
2021-12-30 15:46:12 +00:00
|
|
|
return (
|
2022-08-19 12:31:17 +00:00
|
|
|
<HeaderContainer id={id}>
|
2022-08-12 03:47:56 +00:00
|
|
|
<Breadcrumbs breadcrumbs={breadcrumbs} />
|
|
|
|
|
2021-12-30 15:46:12 +00:00
|
|
|
<HeaderTitle title={title}>
|
|
|
|
{reload && (
|
2022-03-08 12:14:23 +00:00
|
|
|
<Button
|
2022-07-27 21:53:19 +00:00
|
|
|
color="none"
|
|
|
|
size="large"
|
2022-06-23 06:32:18 +00:00
|
|
|
onClick={onClickedRefresh}
|
2023-03-07 22:22:08 +00:00
|
|
|
className="m-0 p-0 focus:text-inherit"
|
2022-06-23 06:32:18 +00:00
|
|
|
disabled={loading}
|
2022-03-08 12:14:23 +00:00
|
|
|
>
|
2022-07-27 21:53:19 +00:00
|
|
|
<RefreshCw className="icon" />
|
2021-12-30 15:46:12 +00:00
|
|
|
</Button>
|
|
|
|
)}
|
2023-10-11 07:38:57 +00:00
|
|
|
{children}
|
2021-12-30 15:46:12 +00:00
|
|
|
</HeaderTitle>
|
|
|
|
</HeaderContainer>
|
|
|
|
);
|
2023-10-11 07:38:57 +00:00
|
|
|
|
|
|
|
function onClickedRefresh() {
|
2023-11-22 01:21:07 +00:00
|
|
|
dispatchCacheRefreshEvent();
|
2023-10-11 07:38:57 +00:00
|
|
|
return onReload ? onReload() : router.stateService.reload();
|
|
|
|
}
|
2021-12-30 15:46:12 +00:00
|
|
|
}
|