2022-01-04 12:16:09 +00:00
|
|
|
import { react2angular } from '@/react-tools/react2angular';
|
|
|
|
import { EnvironmentProvider } from '@/portainer/environments/useEnvironment';
|
|
|
|
import { TableSettingsProvider } from '@/portainer/components/datatables/components/useTableSettings';
|
|
|
|
import type { Environment } from '@/portainer/environments/types';
|
|
|
|
|
|
|
|
import {
|
|
|
|
ContainersDatatable,
|
|
|
|
ContainerTableProps,
|
|
|
|
} from './ContainersDatatable';
|
|
|
|
|
|
|
|
interface Props extends ContainerTableProps {
|
|
|
|
endpoint: Environment;
|
|
|
|
}
|
|
|
|
|
2022-01-13 05:28:49 +00:00
|
|
|
export function ContainersDatatableContainer({
|
|
|
|
endpoint,
|
|
|
|
tableKey = 'containers',
|
|
|
|
...props
|
|
|
|
}: Props) {
|
2022-01-04 12:16:09 +00:00
|
|
|
const defaultSettings = {
|
|
|
|
autoRefreshRate: 0,
|
|
|
|
truncateContainerName: 32,
|
|
|
|
hiddenQuickActions: [],
|
|
|
|
hiddenColumns: [],
|
|
|
|
pageSize: 10,
|
|
|
|
sortBy: { id: 'state', desc: false },
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<EnvironmentProvider environment={endpoint}>
|
2022-01-13 05:28:49 +00:00
|
|
|
<TableSettingsProvider defaults={defaultSettings} storageKey={tableKey}>
|
2022-03-08 12:14:23 +00:00
|
|
|
{/* eslint-disable-next-line react/jsx-props-no-spreading */}
|
|
|
|
<ContainersDatatable {...props} />
|
2022-01-04 12:16:09 +00:00
|
|
|
</TableSettingsProvider>
|
|
|
|
</EnvironmentProvider>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export const ContainersDatatableAngular = react2angular(
|
|
|
|
ContainersDatatableContainer,
|
|
|
|
[
|
|
|
|
'endpoint',
|
|
|
|
'isAddActionVisible',
|
|
|
|
'dataset',
|
|
|
|
'onRefresh',
|
|
|
|
'isHostColumnVisible',
|
2022-01-13 05:28:49 +00:00
|
|
|
'tableKey',
|
2022-01-04 12:16:09 +00:00
|
|
|
]
|
|
|
|
);
|