mirror of https://github.com/portainer/portainer
53 lines
1.2 KiB
TypeScript
53 lines
1.2 KiB
TypeScript
import { useRouter } from '@uirouter/react';
|
|
import { RefreshCw } from 'react-feather';
|
|
|
|
import { Button } from '../buttons';
|
|
|
|
import { Breadcrumbs } from './Breadcrumbs';
|
|
import { Crumb } from './Breadcrumbs/Breadcrumbs';
|
|
import { HeaderContainer } from './HeaderContainer';
|
|
import { HeaderTitle } from './HeaderTitle';
|
|
import styles from './PageHeader.module.css';
|
|
|
|
interface Props {
|
|
reload?: boolean;
|
|
loading?: boolean;
|
|
onReload?(): Promise<void> | void;
|
|
breadcrumbs?: (Crumb | string)[] | string;
|
|
title: string;
|
|
}
|
|
|
|
export function PageHeader({
|
|
title,
|
|
breadcrumbs = [],
|
|
reload,
|
|
loading,
|
|
onReload,
|
|
}: Props) {
|
|
const router = useRouter();
|
|
|
|
function onClickedRefresh() {
|
|
return onReload ? onReload() : router.stateService.reload();
|
|
}
|
|
|
|
return (
|
|
<HeaderContainer>
|
|
<Breadcrumbs breadcrumbs={breadcrumbs} />
|
|
|
|
<HeaderTitle title={title}>
|
|
{reload && (
|
|
<Button
|
|
color="none"
|
|
size="large"
|
|
onClick={onClickedRefresh}
|
|
className={styles.reloadButton}
|
|
disabled={loading}
|
|
>
|
|
<RefreshCw className="icon" />
|
|
</Button>
|
|
)}
|
|
</HeaderTitle>
|
|
</HeaderContainer>
|
|
);
|
|
}
|