mirror of https://github.com/portainer/portainer
59 lines
1.7 KiB
TypeScript
59 lines
1.7 KiB
TypeScript
|
import { useState } from 'react';
|
||
|
|
||
|
import { PageHeader } from '@/portainer/components/PageHeader';
|
||
|
import { useSettings } from '@/portainer/settings/queries';
|
||
|
import { useGroups } from '@/portainer/environment-groups/queries';
|
||
|
import { r2a } from '@/react-tools/react2angular';
|
||
|
import { ViewLoading } from '@/portainer/components/ViewLoading';
|
||
|
|
||
|
import { EdgeDevicesDatatableContainer } from './EdgeDevicesDatatable/EdgeDevicesDatatableContainer';
|
||
|
|
||
|
export function EdgeDevicesView() {
|
||
|
const [loadingMessage, setLoadingMessage] = useState('');
|
||
|
|
||
|
const settingsQuery = useSettings();
|
||
|
const groupsQuery = useGroups();
|
||
|
|
||
|
if (!settingsQuery.data || !groupsQuery.data) {
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
const settings = settingsQuery.data;
|
||
|
|
||
|
return (
|
||
|
<>
|
||
|
<PageHeader
|
||
|
title="Edge Devices"
|
||
|
reload
|
||
|
breadcrumbs={[{ label: 'EdgeDevices' }]}
|
||
|
/>
|
||
|
|
||
|
{loadingMessage ? (
|
||
|
<ViewLoading message={loadingMessage} />
|
||
|
) : (
|
||
|
<EdgeDevicesDatatableContainer
|
||
|
setLoadingMessage={setLoadingMessage}
|
||
|
isFdoEnabled={
|
||
|
settings.EnableEdgeComputeFeatures &&
|
||
|
settings.fdoConfiguration.enabled
|
||
|
}
|
||
|
showWaitingRoomLink={
|
||
|
process.env.PORTAINER_EDITION === 'BE' &&
|
||
|
settings.EnableEdgeComputeFeatures &&
|
||
|
!settings.TrustOnFirstConnect
|
||
|
}
|
||
|
isOpenAmtEnabled={
|
||
|
settings.EnableEdgeComputeFeatures &&
|
||
|
settings.openAMTConfiguration.enabled
|
||
|
}
|
||
|
mpsServer={settings.openAMTConfiguration.mpsServer}
|
||
|
groups={groupsQuery.data}
|
||
|
storageKey="edgeDevices"
|
||
|
/>
|
||
|
)}
|
||
|
</>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
export const EdgeDevicesViewAngular = r2a(EdgeDevicesView, []);
|