mirror of https://github.com/portainer/portainer
47 lines
1.1 KiB
TypeScript
47 lines
1.1 KiB
TypeScript
import { ReactNode } from 'react';
|
|
|
|
import { IconProps } from '@@/Icon';
|
|
|
|
import { SearchBar } from './SearchBar';
|
|
import { Table } from './Table';
|
|
|
|
type Props = {
|
|
title?: string;
|
|
titleIcon?: IconProps['icon'];
|
|
searchValue: string;
|
|
onSearchChange(value: string): void;
|
|
renderTableSettings?(): ReactNode;
|
|
renderTableActions?(): ReactNode;
|
|
description?: ReactNode;
|
|
};
|
|
|
|
export function DatatableHeader({
|
|
onSearchChange,
|
|
renderTableActions,
|
|
renderTableSettings,
|
|
searchValue,
|
|
title,
|
|
titleIcon,
|
|
description,
|
|
}: Props) {
|
|
if (!title) {
|
|
return null;
|
|
}
|
|
|
|
const searchBar = <SearchBar value={searchValue} onChange={onSearchChange} />;
|
|
const tableActions = !!renderTableActions && (
|
|
<Table.Actions>{renderTableActions()}</Table.Actions>
|
|
);
|
|
const tableTitleSettings = !!renderTableSettings && (
|
|
<Table.TitleActions>{renderTableSettings()}</Table.TitleActions>
|
|
);
|
|
|
|
return (
|
|
<Table.Title label={title} icon={titleIcon} description={description}>
|
|
{searchBar}
|
|
{tableActions}
|
|
{tableTitleSettings}
|
|
</Table.Title>
|
|
);
|
|
}
|