mirror of https://github.com/portainer/portainer
60 lines
1.7 KiB
TypeScript
60 lines
1.7 KiB
TypeScript
import { useRouter } from '@uirouter/react';
|
|
|
|
import { useEnvironmentList } from '@/portainer/environments/queries/useEnvironmentList';
|
|
import { EdgeTypes } from '@/portainer/environments/types';
|
|
|
|
import { InformationPanel } from '@@/InformationPanel';
|
|
import { TextTip } from '@@/Tip/TextTip';
|
|
import { TableSettingsProvider } from '@@/datatables/useTableSettings';
|
|
import { PageHeader } from '@@/PageHeader';
|
|
|
|
import { DataTable } from './Datatable/Datatable';
|
|
import { TableSettings } from './Datatable/types';
|
|
|
|
export function WaitingRoomView() {
|
|
const storageKey = 'edge-devices-waiting-room';
|
|
const router = useRouter();
|
|
const { environments, isLoading, totalCount } = useEnvironmentList({
|
|
edgeDevice: true,
|
|
edgeDeviceUntrusted: true,
|
|
types: EdgeTypes,
|
|
});
|
|
|
|
if (process.env.PORTAINER_EDITION !== 'BE') {
|
|
router.stateService.go('edge.devices');
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<PageHeader
|
|
title="Waiting Room"
|
|
breadcrumbs={[
|
|
{ label: 'Edge Devices', link: 'edge.devices' },
|
|
{ label: 'Waiting Room' },
|
|
]}
|
|
/>
|
|
|
|
<InformationPanel>
|
|
<TextTip color="blue">
|
|
Only environments generated from the AEEC script will appear here,
|
|
manually added environments and edge devices will bypass the waiting
|
|
room.
|
|
</TextTip>
|
|
</InformationPanel>
|
|
|
|
<TableSettingsProvider<TableSettings>
|
|
defaults={{ pageSize: 10, sortBy: { desc: false, id: 'name' } }}
|
|
storageKey={storageKey}
|
|
>
|
|
<DataTable
|
|
devices={environments}
|
|
totalCount={totalCount}
|
|
isLoading={isLoading}
|
|
storageKey={storageKey}
|
|
/>
|
|
</TableSettingsProvider>
|
|
</>
|
|
);
|
|
}
|