@flightctl/ui-components 0.4.0 → 0.5.0-rc2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/components/DetailsPage/DetailsPageActions.d.ts +11 -4
- package/dist/src/components/DetailsPage/DetailsPageActions.d.ts.map +1 -1
- package/dist/src/components/DetailsPage/DetailsPageActions.js +15 -4
- package/dist/src/components/DetailsPage/DetailsPageActions.js.map +1 -1
- package/dist/src/components/DetailsPage/Tables/ApplicationsTable.js +1 -1
- package/dist/src/components/DetailsPage/Tables/ApplicationsTable.js.map +1 -1
- package/dist/src/components/Device/DeviceDetails/DeviceApplications.d.ts +1 -1
- package/dist/src/components/Device/DeviceDetails/DeviceApplications.d.ts.map +1 -1
- package/dist/src/components/Device/DeviceDetails/DeviceApplications.js +2 -2
- package/dist/src/components/Device/DeviceDetails/DeviceApplications.js.map +1 -1
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.d.ts.map +1 -1
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.js +22 -15
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.js.map +1 -1
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.d.ts.map +1 -1
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.js +42 -39
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.js.map +1 -1
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTabContent/StatusContent.d.ts +7 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTabContent/StatusContent.d.ts.map +1 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTabContent/StatusContent.js +41 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTabContent/StatusContent.js.map +1 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTabContent/SystemResourcesContent.d.ts +7 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTabContent/SystemResourcesContent.d.ts.map +1 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTabContent/SystemResourcesContent.js +30 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTabContent/SystemResourcesContent.js.map +1 -0
- package/dist/src/components/Device/DeviceDetails/TerminalTab.d.ts.map +1 -1
- package/dist/src/components/Device/DeviceDetails/TerminalTab.js +1 -1
- package/dist/src/components/Device/DeviceDetails/TerminalTab.js.map +1 -1
- package/dist/src/components/Device/DevicesPage/DecommissionedDeviceTableRow.d.ts +16 -0
- package/dist/src/components/Device/DevicesPage/DecommissionedDeviceTableRow.d.ts.map +1 -0
- package/dist/src/components/Device/DevicesPage/DecommissionedDeviceTableRow.js +57 -0
- package/dist/src/components/Device/DevicesPage/DecommissionedDeviceTableRow.js.map +1 -0
- package/dist/src/components/Device/DevicesPage/DecommissionedDevicesTable.d.ts +16 -0
- package/dist/src/components/Device/DevicesPage/DecommissionedDevicesTable.d.ts.map +1 -0
- package/dist/src/components/Device/DevicesPage/DecommissionedDevicesTable.js +73 -0
- package/dist/src/components/Device/DevicesPage/DecommissionedDevicesTable.js.map +1 -0
- package/dist/src/components/Device/DevicesPage/DeviceNameOnlyToolbarFilter.d.ts +10 -0
- package/dist/src/components/Device/DevicesPage/DeviceNameOnlyToolbarFilter.d.ts.map +1 -0
- package/dist/src/components/Device/DevicesPage/DeviceNameOnlyToolbarFilter.js +19 -0
- package/dist/src/components/Device/DevicesPage/DeviceNameOnlyToolbarFilter.js.map +1 -0
- package/dist/src/components/Device/DevicesPage/DevicesEmptyStates.d.ts +8 -0
- package/dist/src/components/Device/DevicesPage/DevicesEmptyStates.d.ts.map +1 -0
- package/dist/src/components/Device/DevicesPage/DevicesEmptyStates.js +34 -0
- package/dist/src/components/Device/DevicesPage/DevicesEmptyStates.js.map +1 -0
- package/dist/src/components/Device/DevicesPage/DevicesPage.d.ts +0 -22
- package/dist/src/components/Device/DevicesPage/DevicesPage.d.ts.map +1 -1
- package/dist/src/components/Device/DevicesPage/DevicesPage.js +9 -92
- package/dist/src/components/Device/DevicesPage/DevicesPage.js.map +1 -1
- package/dist/src/components/Device/DevicesPage/EnrolledDeviceTableRow.d.ts +16 -0
- package/dist/src/components/Device/DevicesPage/EnrolledDeviceTableRow.d.ts.map +1 -0
- package/dist/src/components/Device/DevicesPage/{DeviceTableRow.js → EnrolledDeviceTableRow.js} +9 -13
- package/dist/src/components/Device/DevicesPage/EnrolledDeviceTableRow.js.map +1 -0
- package/dist/src/components/Device/DevicesPage/EnrolledDevicesTable.d.ts +23 -0
- package/dist/src/components/Device/DevicesPage/EnrolledDevicesTable.d.ts.map +1 -0
- package/dist/src/components/Device/DevicesPage/EnrolledDevicesTable.js +99 -0
- package/dist/src/components/Device/DevicesPage/EnrolledDevicesTable.js.map +1 -0
- package/dist/src/components/Device/DevicesPage/useDevices.d.ts +2 -0
- package/dist/src/components/Device/DevicesPage/useDevices.d.ts.map +1 -1
- package/dist/src/components/Device/DevicesPage/useDevices.js +16 -1
- package/dist/src/components/Device/DevicesPage/useDevices.js.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.d.ts.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.js +5 -3
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.js.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizardNav.js +1 -1
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizardNav.js.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.d.ts.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.js +2 -2
- package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.js.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.d.ts.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.js +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.js.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.d.ts.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.js +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.js.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.d.ts.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.js +7 -7
- package/dist/src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.js.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/ReviewUpdatePolicy.d.ts +9 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ReviewUpdatePolicy.d.ts.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ReviewUpdatePolicy.js +37 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ReviewUpdatePolicy.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.d.ts.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.js +6 -4
- package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.js.map +1 -1
- package/dist/src/components/Device/EditDeviceWizard/utils.d.ts +1 -1
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.d.ts.map +1 -1
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.js +4 -13
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.js.map +1 -1
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestList.js +2 -2
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestList.js.map +1 -1
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableRow.d.ts +2 -2
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableRow.d.ts.map +1 -1
- package/dist/src/components/EnrollmentRequest/useEnrollmentRequests.d.ts +2 -2
- package/dist/src/components/EnrollmentRequest/useEnrollmentRequests.d.ts.map +1 -1
- package/dist/src/components/EnrollmentRequest/useEnrollmentRequests.js.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.d.ts.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.js +32 -3
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.js.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.d.ts.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.js +4 -0
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.js.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/fleetSpecUtils.d.ts +26 -0
- package/dist/src/components/Fleet/CreateFleet/fleetSpecUtils.d.ts.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/fleetSpecUtils.js +63 -0
- package/dist/src/components/Fleet/CreateFleet/fleetSpecUtils.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.d.ts.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.js +19 -10
- package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.js.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.d.ts +9 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.d.ts.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.js +52 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.d.ts +8 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.d.ts.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.js +95 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.d.ts +4 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.d.ts.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.js +31 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.d.ts +4 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.d.ts.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.js +78 -0
- package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/types.d.ts +21 -0
- package/dist/src/components/Fleet/CreateFleet/types.d.ts.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/types.js +6 -0
- package/dist/src/components/Fleet/CreateFleet/types.js.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/utils.d.ts.map +1 -1
- package/dist/src/components/Fleet/CreateFleet/utils.js +15 -1
- package/dist/src/components/Fleet/CreateFleet/utils.js.map +1 -1
- package/dist/src/components/Fleet/FleetDetails/FleetDetailsContent.d.ts.map +1 -1
- package/dist/src/components/Fleet/FleetDetails/FleetDetailsContent.js +9 -7
- package/dist/src/components/Fleet/FleetDetails/FleetDetailsContent.js.map +1 -1
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesCharts.d.ts +9 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesCharts.d.ts.map +1 -0
- package/dist/src/components/Fleet/FleetDetails/{FleetDevices.js → FleetDevicesCharts.js} +4 -4
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesCharts.js.map +1 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesCount.d.ts +10 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesCount.d.ts.map +1 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesCount.js +30 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesCount.js.map +1 -0
- package/dist/src/components/Fleet/FleetResourceSyncs.js +2 -2
- package/dist/src/components/Fleet/FleetResourceSyncs.js.map +1 -1
- package/dist/src/components/Fleet/FleetRow.d.ts.map +1 -1
- package/dist/src/components/Fleet/FleetRow.js +7 -5
- package/dist/src/components/Fleet/FleetRow.js.map +1 -1
- package/dist/src/components/Fleet/FleetsPage.js +2 -2
- package/dist/src/components/Fleet/FleetsPage.js.map +1 -1
- package/dist/src/components/Fleet/useFleets.d.ts +3 -3
- package/dist/src/components/Fleet/useFleets.d.ts.map +1 -1
- package/dist/src/components/Fleet/useFleets.js +3 -3
- package/dist/src/components/Fleet/useFleets.js.map +1 -1
- package/dist/src/components/ListPage/ListPage.d.ts.map +1 -1
- package/dist/src/components/ListPage/ListPage.js +6 -1
- package/dist/src/components/ListPage/ListPage.js.map +1 -1
- package/dist/src/components/ListPage/ListPageActions.d.ts +8 -15
- package/dist/src/components/ListPage/ListPageActions.d.ts.map +1 -1
- package/dist/src/components/ListPage/ListPageActions.js +25 -5
- package/dist/src/components/ListPage/ListPageActions.js.map +1 -1
- package/dist/src/components/ListPage/types.d.ts +11 -11
- package/dist/src/components/ListPage/types.d.ts.map +1 -1
- package/dist/src/components/OverviewPage/Cards/Status/DeviceStatusChart.d.ts.map +1 -1
- package/dist/src/components/OverviewPage/Cards/Status/DeviceStatusChart.js +0 -1
- package/dist/src/components/OverviewPage/Cards/Status/DeviceStatusChart.js.map +1 -1
- package/dist/src/components/OverviewPage/OverviewPage.d.ts.map +1 -1
- package/dist/src/components/OverviewPage/OverviewPage.js +6 -1
- package/dist/src/components/OverviewPage/OverviewPage.js.map +1 -1
- package/dist/src/components/Repository/RepositoryDetails/RepositoryResourceSyncsCard.js +1 -1
- package/dist/src/components/Repository/RepositoryDetails/RepositoryResourceSyncsCard.js.map +1 -1
- package/dist/src/components/Repository/useRepositories.d.ts +2 -2
- package/dist/src/components/Repository/useRepositories.d.ts.map +1 -1
- package/dist/src/components/Repository/useRepositories.js.map +1 -1
- package/dist/src/components/ResourceSync/RepositoryResourceSyncList.js +2 -2
- package/dist/src/components/ResourceSync/RepositoryResourceSyncList.js.map +1 -1
- package/dist/src/components/Status/DeviceLifecycleStatus.d.ts +7 -0
- package/dist/src/components/Status/DeviceLifecycleStatus.d.ts.map +1 -0
- package/dist/src/components/Status/DeviceLifecycleStatus.js +25 -0
- package/dist/src/components/Status/DeviceLifecycleStatus.js.map +1 -0
- package/dist/src/components/Status/StatusDisplay.d.ts +1 -1
- package/dist/src/components/Status/StatusDisplay.d.ts.map +1 -1
- package/dist/src/components/Status/StatusDisplay.js +3 -3
- package/dist/src/components/Status/StatusDisplay.js.map +1 -1
- package/dist/src/components/Table/Table.d.ts.map +1 -1
- package/dist/src/components/Table/Table.js +2 -2
- package/dist/src/components/Table/Table.js.map +1 -1
- package/dist/src/components/Table/TablePagination.d.ts +4 -3
- package/dist/src/components/Table/TablePagination.d.ts.map +1 -1
- package/dist/src/components/Table/TablePagination.js +6 -5
- package/dist/src/components/Table/TablePagination.js.map +1 -1
- package/dist/src/components/common/EditableLabelControl.d.ts.map +1 -1
- package/dist/src/components/common/EditableLabelControl.js +5 -7
- package/dist/src/components/common/EditableLabelControl.js.map +1 -1
- package/dist/src/components/common/TechPreviewBadge.d.ts +4 -0
- package/dist/src/components/common/TechPreviewBadge.d.ts.map +1 -0
- package/dist/src/components/common/TechPreviewBadge.js +23 -0
- package/dist/src/components/common/TechPreviewBadge.js.map +1 -0
- package/dist/src/components/form/LabelsField.d.ts.map +1 -1
- package/dist/src/components/form/LabelsField.js +4 -1
- package/dist/src/components/form/LabelsField.js.map +1 -1
- package/dist/src/components/form/NumberField.d.ts +10 -0
- package/dist/src/components/form/NumberField.d.ts.map +1 -0
- package/dist/src/components/form/NumberField.js +51 -0
- package/dist/src/components/form/NumberField.js.map +1 -0
- package/dist/src/components/form/TextListField.d.ts +12 -0
- package/dist/src/components/form/TextListField.d.ts.map +1 -0
- package/dist/src/components/form/TextListField.js +46 -0
- package/dist/src/components/form/TextListField.js.map +1 -0
- package/dist/src/components/form/validations.d.ts +34 -6
- package/dist/src/components/form/validations.d.ts.map +1 -1
- package/dist/src/components/form/validations.js +78 -4
- package/dist/src/components/form/validations.js.map +1 -1
- package/dist/src/components/modals/DecommissionModal/DecommissionModal.d.ts +9 -0
- package/dist/src/components/modals/DecommissionModal/DecommissionModal.d.ts.map +1 -0
- package/dist/src/components/modals/DecommissionModal/DecommissionModal.js +51 -0
- package/dist/src/components/modals/DecommissionModal/DecommissionModal.js.map +1 -0
- package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.d.ts +4 -2
- package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.d.ts.map +1 -1
- package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.js +11 -4
- package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.js.map +1 -1
- package/dist/src/components/modals/massModals/MassDecommissionDeviceModal/MassDecommissionDeviceModal.d.ts +10 -0
- package/dist/src/components/modals/massModals/MassDecommissionDeviceModal/MassDecommissionDeviceModal.d.ts.map +1 -0
- package/dist/src/components/modals/massModals/MassDecommissionDeviceModal/MassDecommissionDeviceModal.js +67 -0
- package/dist/src/components/modals/massModals/MassDecommissionDeviceModal/MassDecommissionDeviceModal.js.map +1 -0
- package/dist/src/constants.d.ts +1 -1
- package/dist/src/constants.d.ts.map +1 -1
- package/dist/src/constants.js +1 -1
- package/dist/src/constants.js.map +1 -1
- package/dist/src/hooks/useAppContext.d.ts +1 -1
- package/dist/src/hooks/useAppContext.d.ts.map +1 -1
- package/dist/src/hooks/useFetch.d.ts +1 -1
- package/dist/src/hooks/useFetchPeriodically.js +10 -10
- package/dist/src/hooks/useFetchPeriodically.js.map +1 -1
- package/dist/src/hooks/useTablePagination.d.ts +5 -3
- package/dist/src/hooks/useTablePagination.d.ts.map +1 -1
- package/dist/src/hooks/useTablePagination.js +9 -5
- package/dist/src/hooks/useTablePagination.js.map +1 -1
- package/dist/src/hooks/useWebSocket.d.ts +1 -1
- package/dist/src/hooks/useWebSocket.js +4 -4
- package/dist/src/hooks/useWebSocket.js.map +1 -1
- package/dist/src/links.d.ts +1 -0
- package/dist/src/links.d.ts.map +1 -1
- package/dist/src/links.js +2 -1
- package/dist/src/links.js.map +1 -1
- package/dist/src/types/rbac.d.ts +3 -1
- package/dist/src/types/rbac.d.ts.map +1 -1
- package/dist/src/types/rbac.js +2 -0
- package/dist/src/types/rbac.js.map +1 -1
- package/dist/src/utils/api.d.ts +3 -6
- package/dist/src/utils/api.d.ts.map +1 -1
- package/dist/src/utils/api.js.map +1 -1
- package/dist/src/utils/apiCalls.d.ts +2 -0
- package/dist/src/utils/apiCalls.d.ts.map +1 -0
- package/dist/src/utils/apiCalls.js +23 -0
- package/dist/src/utils/apiCalls.js.map +1 -0
- package/dist/src/utils/devices.d.ts +6 -3
- package/dist/src/utils/devices.d.ts.map +1 -1
- package/dist/src/utils/devices.js +20 -1
- package/dist/src/utils/devices.js.map +1 -1
- package/dist/src/utils/patch.d.ts +4 -1
- package/dist/src/utils/patch.d.ts.map +1 -1
- package/dist/src/utils/patch.js +166 -9
- package/dist/src/utils/patch.js.map +1 -1
- package/dist/src/utils/status/common.js +13 -12
- package/dist/src/utils/status/common.js.map +1 -1
- package/dist/src/utils/status/devices.d.ts +3 -3
- package/dist/src/utils/status/devices.d.ts.map +1 -1
- package/dist/src/utils/status/devices.js +40 -5
- package/dist/src/utils/status/devices.js.map +1 -1
- package/dist/src/utils/status/fleet.d.ts +4 -4
- package/dist/src/utils/status/fleet.d.ts.map +1 -1
- package/dist/src/utils/status/fleet.js +15 -2
- package/dist/src/utils/status/fleet.js.map +1 -1
- package/dist/src/utils/tooltip.d.ts +7 -0
- package/dist/src/utils/tooltip.d.ts.map +1 -0
- package/dist/src/utils/tooltip.js +6 -0
- package/dist/src/utils/tooltip.js.map +1 -0
- package/package.json +1 -1
- package/src/components/DetailsPage/DetailsPageActions.tsx +34 -6
- package/src/components/DetailsPage/Tables/ApplicationsTable.tsx +1 -1
- package/src/components/Device/DeviceDetails/DeviceApplications.tsx +3 -3
- package/src/components/Device/DeviceDetails/DeviceDetailsPage.tsx +53 -34
- package/src/components/Device/DeviceDetails/DeviceDetailsTab.tsx +71 -54
- package/src/components/Device/DeviceDetails/DeviceDetailsTabContent/StatusContent.tsx +75 -0
- package/src/components/Device/DeviceDetails/DeviceDetailsTabContent/SystemResourcesContent.tsx +47 -0
- package/src/components/Device/DeviceDetails/TerminalTab.tsx +1 -4
- package/src/components/Device/DevicesPage/DecommissionedDeviceTableRow.tsx +89 -0
- package/src/components/Device/DevicesPage/DecommissionedDevicesTable.tsx +156 -0
- package/src/components/Device/DevicesPage/DeviceNameOnlyToolbarFilter.tsx +30 -0
- package/src/components/Device/DevicesPage/DevicesEmptyStates.tsx +46 -0
- package/src/components/Device/DevicesPage/DevicesPage.tsx +45 -215
- package/src/components/Device/DevicesPage/{DeviceTableRow.tsx → EnrolledDeviceTableRow.tsx} +16 -20
- package/src/components/Device/DevicesPage/EnrolledDevicesTable.tsx +208 -0
- package/src/components/Device/DevicesPage/useDevices.ts +21 -1
- package/src/components/Device/EditDeviceWizard/EditDeviceWizard.tsx +6 -3
- package/src/components/Device/EditDeviceWizard/EditDeviceWizardNav.tsx +1 -1
- package/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.tsx +2 -0
- package/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.tsx +1 -0
- package/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.tsx +1 -0
- package/src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.tsx +27 -19
- package/src/components/Device/EditDeviceWizard/steps/ReviewUpdatePolicy.tsx +55 -0
- package/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.tsx +9 -7
- package/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.tsx +10 -36
- package/src/components/EnrollmentRequest/EnrollmentRequestList.tsx +2 -2
- package/src/components/EnrollmentRequest/EnrollmentRequestTableRow.tsx +2 -2
- package/src/components/EnrollmentRequest/useEnrollmentRequests.ts +3 -2
- package/src/components/Fleet/CreateFleet/CreateFleetWizard.tsx +46 -5
- package/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.tsx +4 -0
- package/src/components/Fleet/CreateFleet/fleetSpecUtils.ts +62 -0
- package/src/components/Fleet/CreateFleet/steps/ReviewStep.tsx +65 -30
- package/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.tsx +87 -0
- package/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.tsx +155 -0
- package/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.tsx +87 -0
- package/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.tsx +190 -0
- package/src/components/Fleet/CreateFleet/types.ts +25 -0
- package/src/components/Fleet/CreateFleet/utils.ts +20 -1
- package/src/components/Fleet/FleetDetails/FleetDetailsContent.tsx +10 -7
- package/src/components/Fleet/FleetDetails/{FleetDevices.tsx → FleetDevicesCharts.tsx} +4 -4
- package/src/components/Fleet/FleetDetails/FleetDevicesCount.tsx +53 -0
- package/src/components/Fleet/FleetResourceSyncs.tsx +2 -2
- package/src/components/Fleet/FleetRow.tsx +12 -4
- package/src/components/Fleet/FleetsPage.tsx +2 -2
- package/src/components/Fleet/useFleets.ts +7 -7
- package/src/components/ListPage/ListPage.tsx +12 -4
- package/src/components/ListPage/ListPageActions.tsx +50 -16
- package/src/components/ListPage/types.ts +8 -8
- package/src/components/OverviewPage/Cards/Status/DeviceStatusChart.tsx +0 -1
- package/src/components/OverviewPage/OverviewPage.tsx +12 -4
- package/src/components/Repository/RepositoryDetails/RepositoryResourceSyncsCard.tsx +1 -1
- package/src/components/Repository/useRepositories.ts +2 -2
- package/src/components/ResourceSync/RepositoryResourceSyncList.tsx +2 -2
- package/src/components/Status/DeviceLifecycleStatus.tsx +33 -0
- package/src/components/Status/StatusDisplay.tsx +4 -4
- package/src/components/Table/Table.tsx +2 -1
- package/src/components/Table/TablePagination.tsx +9 -7
- package/src/components/common/EditableLabelControl.tsx +7 -6
- package/src/components/common/TechPreviewBadge.tsx +43 -0
- package/src/components/form/LabelsField.tsx +4 -1
- package/src/components/form/NumberField.tsx +78 -0
- package/src/components/form/TextListField.tsx +82 -0
- package/src/components/form/validations.ts +103 -10
- package/src/components/modals/DecommissionModal/DecommissionModal.tsx +95 -0
- package/src/components/modals/EditLabelsModal/EditLabelsForm.tsx +9 -8
- package/src/components/modals/massModals/MassDecommissionDeviceModal/MassDecommissionDeviceModal.tsx +130 -0
- package/src/constants.ts +1 -1
- package/src/hooks/useAppContext.tsx +1 -1
- package/src/hooks/useFetchPeriodically.ts +11 -11
- package/src/hooks/{useTablePagination.tsx → useTablePagination.ts} +13 -7
- package/src/hooks/useWebSocket.ts +4 -4
- package/src/links.ts +2 -0
- package/src/types/rbac.ts +2 -0
- package/src/utils/api.ts +13 -6
- package/src/utils/apiCalls.ts +15 -0
- package/src/utils/devices.ts +21 -3
- package/src/utils/patch.ts +182 -8
- package/src/utils/status/common.ts +8 -8
- package/src/utils/status/devices.ts +39 -8
- package/src/utils/status/fleet.ts +21 -6
- package/src/utils/tooltip.ts +2 -0
- package/dist/src/components/DetailsPage/Tables/IntegrityDetails.d.ts +0 -8
- package/dist/src/components/DetailsPage/Tables/IntegrityDetails.d.ts.map +0 -1
- package/dist/src/components/DetailsPage/Tables/IntegrityDetails.js +0 -23
- package/dist/src/components/DetailsPage/Tables/IntegrityDetails.js.map +0 -1
- package/dist/src/components/Device/DevicesPage/DeviceTableRow.d.ts +0 -16
- package/dist/src/components/Device/DevicesPage/DeviceTableRow.d.ts.map +0 -1
- package/dist/src/components/Device/DevicesPage/DeviceTableRow.js.map +0 -1
- package/dist/src/components/Fleet/FleetDetails/FleetDevices.d.ts +0 -9
- package/dist/src/components/Fleet/FleetDetails/FleetDevices.d.ts.map +0 -1
- package/dist/src/components/Fleet/FleetDetails/FleetDevices.js.map +0 -1
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesLink.d.ts +0 -7
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesLink.d.ts.map +0 -1
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesLink.js +0 -13
- package/dist/src/components/Fleet/FleetDetails/FleetDevicesLink.js.map +0 -1
- package/dist/src/components/Status/IntegrityStatus.d.ts +0 -7
- package/dist/src/components/Status/IntegrityStatus.d.ts.map +0 -1
- package/dist/src/components/Status/IntegrityStatus.js +0 -17
- package/dist/src/components/Status/IntegrityStatus.js.map +0 -1
- package/dist/src/utils/status/integrity.d.ts +0 -5
- package/dist/src/utils/status/integrity.d.ts.map +0 -1
- package/dist/src/utils/status/integrity.js +0 -28
- package/dist/src/utils/status/integrity.js.map +0 -1
- package/src/components/DetailsPage/Tables/IntegrityDetails.tsx +0 -44
- package/src/components/Fleet/FleetDetails/FleetDevicesLink.tsx +0 -16
- package/src/components/Status/IntegrityStatus.tsx +0 -19
- package/src/utils/status/integrity.ts +0 -26
|
@@ -1,17 +1,18 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getDefaultStatusColor = exports.getDefaultStatusIcon = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
4
5
|
const in_progress_icon_1 = require("@patternfly/react-icons/dist/js/icons/in-progress-icon");
|
|
5
6
|
const exclamation_circle_icon_1 = require("@patternfly/react-icons/dist/js/icons/exclamation-circle-icon");
|
|
6
7
|
const exclamation_triangle_icon_1 = require("@patternfly/react-icons/dist/js/icons/exclamation-triangle-icon");
|
|
7
8
|
const check_circle_icon_1 = require("@patternfly/react-icons/dist/js/icons/check-circle-icon");
|
|
8
9
|
const outlined_question_circle_icon_1 = require("@patternfly/react-icons/dist/js/icons/outlined-question-circle-icon");
|
|
9
|
-
const global_warning_color_100_1 = require("@patternfly/react-tokens/dist/js/global_warning_color_100");
|
|
10
|
-
const global_danger_color_100_1 = require("@patternfly/react-tokens/dist/js/global_danger_color_100");
|
|
11
|
-
const global_success_color_100_1 = require("@patternfly/react-tokens/dist/js/global_success_color_100");
|
|
12
|
-
const global_disabled_color_100_1 = require("@patternfly/react-tokens/dist/js/global_disabled_color_100");
|
|
13
|
-
const global_active_color_100_1 = require("@patternfly/react-tokens/dist/js/global_active_color_100");
|
|
14
|
-
const global_palette_black_1000_1 = require("@patternfly/react-tokens/dist/js/global_palette_black_1000");
|
|
10
|
+
const global_warning_color_100_1 = tslib_1.__importDefault(require("@patternfly/react-tokens/dist/js/global_warning_color_100"));
|
|
11
|
+
const global_danger_color_100_1 = tslib_1.__importDefault(require("@patternfly/react-tokens/dist/js/global_danger_color_100"));
|
|
12
|
+
const global_success_color_100_1 = tslib_1.__importDefault(require("@patternfly/react-tokens/dist/js/global_success_color_100"));
|
|
13
|
+
const global_disabled_color_100_1 = tslib_1.__importDefault(require("@patternfly/react-tokens/dist/js/global_disabled_color_100"));
|
|
14
|
+
const global_active_color_100_1 = tslib_1.__importDefault(require("@patternfly/react-tokens/dist/js/global_active_color_100"));
|
|
15
|
+
const global_palette_black_1000_1 = tslib_1.__importDefault(require("@patternfly/react-tokens/dist/js/global_palette_black_1000"));
|
|
15
16
|
const getDefaultStatusIcon = (level) => {
|
|
16
17
|
let iconClass;
|
|
17
18
|
switch (level) {
|
|
@@ -39,22 +40,22 @@ const getDefaultStatusColor = (level) => {
|
|
|
39
40
|
let color;
|
|
40
41
|
switch (level) {
|
|
41
42
|
case 'info':
|
|
42
|
-
color = global_active_color_100_1.
|
|
43
|
+
color = global_active_color_100_1.default.value;
|
|
43
44
|
break;
|
|
44
45
|
case 'danger':
|
|
45
|
-
color = global_danger_color_100_1.
|
|
46
|
+
color = global_danger_color_100_1.default.value;
|
|
46
47
|
break;
|
|
47
48
|
case 'warning':
|
|
48
|
-
color = global_warning_color_100_1.
|
|
49
|
+
color = global_warning_color_100_1.default.value;
|
|
49
50
|
break;
|
|
50
51
|
case 'success':
|
|
51
|
-
color = global_success_color_100_1.
|
|
52
|
+
color = global_success_color_100_1.default.value;
|
|
52
53
|
break;
|
|
53
54
|
case 'custom':
|
|
54
|
-
color = global_palette_black_1000_1.
|
|
55
|
+
color = global_palette_black_1000_1.default.value;
|
|
55
56
|
break;
|
|
56
57
|
default:
|
|
57
|
-
color = global_disabled_color_100_1.
|
|
58
|
+
color = global_disabled_color_100_1.default.value;
|
|
58
59
|
break;
|
|
59
60
|
}
|
|
60
61
|
return color;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../src/utils/status/common.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../src/utils/status/common.ts"],"names":[],"mappings":";;;;AAEA,6FAAwF;AACxF,2GAAsG;AACtG,+GAA0G;AAC1G,+FAA0F;AAC1F,uHAAiH;AAEjH,iIAAqF;AACrF,+HAAmF;AACnF,iIAAqF;AACrF,mIAAuF;AACvF,+HAAmF;AACnF,mIAAsF;AAW/E,MAAM,oBAAoB,GAAG,CAAC,KAAkB,EAAE,EAAE;IACzD,IAAI,SAA6C,CAAC;IAClD,QAAQ,KAAK,EAAE,CAAC;QACd,KAAK,MAAM;YACT,SAAS,GAAG,iCAAc,CAAC;YAC3B,MAAM;QACR,KAAK,QAAQ;YACX,SAAS,GAAG,+CAAqB,CAAC;YAClC,MAAM;QACR,KAAK,SAAS,CAAC;QACf,KAAK,SAAS;YACZ,SAAS,GAAG,mDAAuB,CAAC;YACpC,MAAM;QACR,KAAK,SAAS;YACZ,SAAS,GAAG,mCAAe,CAAC;YAC5B,MAAM;QACR;YACE,SAAS,GAAG,0DAA0B,CAAC;YACvC,MAAM;IACV,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AArBW,QAAA,oBAAoB,wBAqB/B;AAEK,MAAM,qBAAqB,GAAG,CAAC,KAAkB,EAAE,EAAE;IAC1D,IAAI,KAAa,CAAC;IAClB,QAAQ,KAAK,EAAE,CAAC;QACd,KAAK,MAAM;YACT,KAAK,GAAG,iCAAW,CAAC,KAAK,CAAC;YAC1B,MAAM;QACR,KAAK,QAAQ;YACX,KAAK,GAAG,iCAAW,CAAC,KAAK,CAAC;YAC1B,MAAM;QACR,KAAK,SAAS;YACZ,KAAK,GAAG,kCAAY,CAAC,KAAK,CAAC;YAC3B,MAAM;QACR,KAAK,SAAS;YACZ,KAAK,GAAG,kCAAY,CAAC,KAAK,CAAC;YAC3B,MAAM;QACR,KAAK,QAAQ;YACX,KAAK,GAAG,mCAAY,CAAC,KAAK,CAAC;YAC3B,MAAM;QACR;YACE,KAAK,GAAG,mCAAa,CAAC,KAAK,CAAC;YAC5B,MAAM;IACV,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAvBW,QAAA,qBAAqB,yBAuBhC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { TFunction } from 'react-i18next';
|
|
2
|
-
import { ApplicationsSummaryStatusType, DeviceSummaryStatus as BEDeviceSummaryStatus,
|
|
2
|
+
import { ApplicationsSummaryStatusType, DeviceSummaryStatus as BEDeviceSummaryStatus, Device, DeviceIntegrityStatusSummaryType, DeviceLifecycleStatusType, DeviceSummaryStatusType, DeviceUpdatedStatusType } from '@flightctl/types';
|
|
3
3
|
import { StatusItem } from './common';
|
|
4
4
|
export declare enum FilterSearchParams {
|
|
5
5
|
Fleet = "fleetId",
|
|
@@ -11,8 +11,8 @@ export declare enum FilterSearchParams {
|
|
|
11
11
|
}
|
|
12
12
|
export type DeviceSummaryStatus = ApplicationsSummaryStatusType | DeviceUpdatedStatusType | DeviceSummaryStatusType | DeviceIntegrityStatusSummaryType;
|
|
13
13
|
export declare const getDeviceSummaryStatus: (deviceStatus?: BEDeviceSummaryStatus) => DeviceSummaryStatusType;
|
|
14
|
-
export declare const
|
|
15
|
-
export declare const getSystemUpdateStatus: (updatedStatus?: DeviceUpdatedStatus) => DeviceUpdatedStatusType;
|
|
14
|
+
export declare const getDeviceLifecycleStatus: (device: Device) => DeviceLifecycleStatusType;
|
|
16
15
|
export declare const getDeviceStatusItems: (t: TFunction) => StatusItem<DeviceSummaryStatusType>[];
|
|
16
|
+
export declare const getDeviceLifecycleStatusItems: (t: TFunction) => StatusItem<DeviceLifecycleStatusType>[];
|
|
17
17
|
export declare const deviceStatusOrder: DeviceSummaryStatusType[];
|
|
18
18
|
//# sourceMappingURL=devices.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"devices.d.ts","sourceRoot":"","sources":["../../../../src/utils/status/devices.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"devices.d.ts","sourceRoot":"","sources":["../../../../src/utils/status/devices.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAI1C,OAAO,EACL,6BAA6B,EAC7B,mBAAmB,IAAI,qBAAqB,EAC5C,MAAM,EACN,gCAAgC,EAChC,yBAAyB,EACzB,uBAAuB,EACvB,uBAAuB,EACxB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAEtC,oBAAY,kBAAkB;IAC5B,KAAK,YAAY;IACjB,YAAY,UAAU;IACtB,SAAS,UAAU;IACnB,aAAa,UAAU;IACvB,KAAK,UAAU;IACf,WAAW,gBAAgB;CAC5B;AAED,MAAM,MAAM,mBAAmB,GAC3B,6BAA6B,GAC7B,uBAAuB,GACvB,uBAAuB,GACvB,gCAAgC,CAAC;AAErC,eAAO,MAAM,sBAAsB,kBAAmB,qBAAqB,KAAG,uBACF,CAAC;AAE7E,eAAO,MAAM,wBAAwB,WAAY,MAAM,KAAG,yBAYzD,CAAC;AAEF,eAAO,MAAM,oBAAoB,MAAO,SAAS,KAAG,WAAW,uBAAuB,CAAC,EAgCtF,CAAC;AAEF,eAAO,MAAM,6BAA6B,MAAO,SAAS,KAAG,WAAW,yBAAyB,CAAC,EAsBjG,CAAC;AAEF,eAAO,MAAM,iBAAiB,2BAAgE,CAAC"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.deviceStatusOrder = exports.
|
|
3
|
+
exports.deviceStatusOrder = exports.getDeviceLifecycleStatusItems = exports.getDeviceStatusItems = exports.getDeviceLifecycleStatus = exports.getDeviceSummaryStatus = exports.FilterSearchParams = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
4
5
|
const icons_1 = require("@patternfly/react-icons/dist/js/icons");
|
|
6
|
+
const ban_icon_1 = tslib_1.__importDefault(require("@patternfly/react-icons/dist/js/icons/ban-icon"));
|
|
5
7
|
const types_1 = require("@flightctl/types");
|
|
6
8
|
var FilterSearchParams;
|
|
7
9
|
(function (FilterSearchParams) {
|
|
@@ -14,10 +16,19 @@ var FilterSearchParams;
|
|
|
14
16
|
})(FilterSearchParams || (exports.FilterSearchParams = FilterSearchParams = {}));
|
|
15
17
|
const getDeviceSummaryStatus = (deviceStatus) => (deviceStatus === null || deviceStatus === void 0 ? void 0 : deviceStatus.status) || types_1.DeviceSummaryStatusType.DeviceSummaryStatusUnknown;
|
|
16
18
|
exports.getDeviceSummaryStatus = getDeviceSummaryStatus;
|
|
17
|
-
const
|
|
18
|
-
|
|
19
|
-
const
|
|
20
|
-
|
|
19
|
+
const getDeviceLifecycleStatus = (device) => {
|
|
20
|
+
var _a, _b, _c, _d;
|
|
21
|
+
const lifecycleStatus = ((_b = (_a = device.status) === null || _a === void 0 ? void 0 : _a.lifecycle) === null || _b === void 0 ? void 0 : _b.status) || types_1.DeviceLifecycleStatusType.DeviceLifecycleStatusEnrolled;
|
|
22
|
+
const isDecomStatus = [
|
|
23
|
+
types_1.DeviceLifecycleStatusType.DeviceLifecycleStatusDecommissioning,
|
|
24
|
+
types_1.DeviceLifecycleStatusType.DeviceLifecycleStatusDecommissioned,
|
|
25
|
+
].includes(lifecycleStatus);
|
|
26
|
+
if (!isDecomStatus && ((_d = (_c = device.spec) === null || _c === void 0 ? void 0 : _c.decommissioning) === null || _d === void 0 ? void 0 : _d.target)) {
|
|
27
|
+
return types_1.DeviceLifecycleStatusType.DeviceLifecycleStatusDecommissioning;
|
|
28
|
+
}
|
|
29
|
+
return lifecycleStatus;
|
|
30
|
+
};
|
|
31
|
+
exports.getDeviceLifecycleStatus = getDeviceLifecycleStatus;
|
|
21
32
|
const getDeviceStatusItems = (t) => [
|
|
22
33
|
{
|
|
23
34
|
id: types_1.DeviceSummaryStatusType.DeviceSummaryStatusError,
|
|
@@ -52,5 +63,29 @@ const getDeviceStatusItems = (t) => [
|
|
|
52
63
|
},
|
|
53
64
|
];
|
|
54
65
|
exports.getDeviceStatusItems = getDeviceStatusItems;
|
|
66
|
+
const getDeviceLifecycleStatusItems = (t) => [
|
|
67
|
+
{
|
|
68
|
+
id: types_1.DeviceLifecycleStatusType.DeviceLifecycleStatusDecommissioned,
|
|
69
|
+
label: t('Decommissioned'),
|
|
70
|
+
level: 'unknown',
|
|
71
|
+
customIcon: ban_icon_1.default,
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
id: types_1.DeviceLifecycleStatusType.DeviceLifecycleStatusDecommissioning,
|
|
75
|
+
label: t('Decommissioning'),
|
|
76
|
+
level: 'warning',
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
id: types_1.DeviceLifecycleStatusType.DeviceLifecycleStatusUnknown,
|
|
80
|
+
label: t('Unknown'),
|
|
81
|
+
level: 'unknown',
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
id: types_1.DeviceLifecycleStatusType.DeviceLifecycleStatusEnrolled,
|
|
85
|
+
label: t('Enrolled'),
|
|
86
|
+
level: 'success',
|
|
87
|
+
},
|
|
88
|
+
];
|
|
89
|
+
exports.getDeviceLifecycleStatusItems = getDeviceLifecycleStatusItems;
|
|
55
90
|
exports.deviceStatusOrder = (0, exports.getDeviceStatusItems)((s) => s).map((item) => item.id);
|
|
56
91
|
//# sourceMappingURL=devices.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"devices.js","sourceRoot":"","sources":["../../../../src/utils/status/devices.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"devices.js","sourceRoot":"","sources":["../../../../src/utils/status/devices.ts"],"names":[],"mappings":";;;;AACA,iEAAqE;AACrE,sGAAqE;AAErE,4CAQ0B;AAG1B,IAAY,kBAOX;AAPD,WAAY,kBAAkB;IAC5B,uCAAiB,CAAA;IACjB,4CAAsB,CAAA;IACtB,yCAAmB,CAAA;IACnB,6CAAuB,CAAA;IACvB,qCAAe,CAAA;IACf,iDAA2B,CAAA;AAC7B,CAAC,EAPW,kBAAkB,kCAAlB,kBAAkB,QAO7B;AAQM,MAAM,sBAAsB,GAAG,CAAC,YAAoC,EAA2B,EAAE,CACtG,CAAA,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,MAAM,KAAI,+BAAuB,CAAC,0BAA0B,CAAC;AADhE,QAAA,sBAAsB,0BAC0C;AAEtE,MAAM,wBAAwB,GAAG,CAAC,MAAc,EAA6B,EAAE;;IACpF,MAAM,eAAe,GAAG,CAAA,MAAA,MAAA,MAAM,CAAC,MAAM,0CAAE,SAAS,0CAAE,MAAM,KAAI,iCAAyB,CAAC,6BAA6B,CAAC;IACpH,MAAM,aAAa,GAAG;QACpB,iCAAyB,CAAC,oCAAoC;QAC9D,iCAAyB,CAAC,mCAAmC;KAC9D,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;IAE5B,IAAI,CAAC,aAAa,KAAI,MAAA,MAAA,MAAM,CAAC,IAAI,0CAAE,eAAe,0CAAE,MAAM,CAAA,EAAE,CAAC;QAC3D,OAAO,iCAAyB,CAAC,oCAAoC,CAAC;IACxE,CAAC;IAED,OAAO,eAAe,CAAC;AACzB,CAAC,CAAC;AAZW,QAAA,wBAAwB,4BAYnC;AAEK,MAAM,oBAAoB,GAAG,CAAC,CAAY,EAAyC,EAAE,CAAC;IAC3F;QACE,EAAE,EAAE,+BAAuB,CAAC,wBAAwB;QACpD,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC;QACjB,KAAK,EAAE,QAAQ;KAChB;IACD;QACE,EAAE,EAAE,+BAAuB,CAAC,2BAA2B;QACvD,KAAK,EAAE,CAAC,CAAC,UAAU,CAAC;QACpB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,+BAAuB,CAAC,0BAA0B;QACtD,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC;QACnB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,+BAAuB,CAAC,4BAA4B;QACxD,KAAK,EAAE,CAAC,CAAC,WAAW,CAAC;QACrB,KAAK,EAAE,MAAM;KACd;IACD;QACE,EAAE,EAAE,+BAAuB,CAAC,6BAA6B;QACzD,KAAK,EAAE,CAAC,CAAC,aAAa,CAAC;QACvB,KAAK,EAAE,QAAQ;QACf,UAAU,EAAE,oBAAY;KACzB;IACD;QACE,EAAE,EAAE,+BAAuB,CAAC,yBAAyB;QACrD,KAAK,EAAE,CAAC,CAAC,QAAQ,CAAC;QAClB,KAAK,EAAE,SAAS;KACjB;CACF,CAAC;AAhCW,QAAA,oBAAoB,wBAgC/B;AAEK,MAAM,6BAA6B,GAAG,CAAC,CAAY,EAA2C,EAAE,CAAC;IACtG;QACE,EAAE,EAAE,iCAAyB,CAAC,mCAAmC;QACjE,KAAK,EAAE,CAAC,CAAC,gBAAgB,CAAC;QAC1B,KAAK,EAAE,SAAS;QAChB,UAAU,EAAE,kBAAO;KACpB;IACD;QACE,EAAE,EAAE,iCAAyB,CAAC,oCAAoC;QAClE,KAAK,EAAE,CAAC,CAAC,iBAAiB,CAAC;QAC3B,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,iCAAyB,CAAC,4BAA4B;QAC1D,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC;QACnB,KAAK,EAAE,SAAS;KACjB;IACD;QACE,EAAE,EAAE,iCAAyB,CAAC,6BAA6B;QAC3D,KAAK,EAAE,CAAC,CAAC,UAAU,CAAC;QACpB,KAAK,EAAE,SAAS;KACjB;CACF,CAAC;AAtBW,QAAA,6BAA6B,iCAsBxC;AAEW,QAAA,iBAAiB,GAAG,IAAA,4BAAoB,EAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC"}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
+
import { TFunction } from 'i18next';
|
|
1
2
|
import { Fleet } from '@flightctl/types';
|
|
2
3
|
import { FleetConditionType } from '../../types/extraTypes';
|
|
3
|
-
|
|
4
|
-
declare const fleetStatusLabels: (t: TFunction) => {
|
|
4
|
+
export declare const fleetStatusLabels: (t: TFunction) => {
|
|
5
5
|
OverlappingSelectors: string;
|
|
6
6
|
Valid: string;
|
|
7
7
|
Invalid: string;
|
|
8
8
|
SyncPending: string;
|
|
9
9
|
};
|
|
10
|
-
declare const getFleetSyncStatus: (fleet: Fleet, t
|
|
10
|
+
export declare const getFleetSyncStatus: (fleet: Fleet, t: TFunction) => {
|
|
11
11
|
status: FleetConditionType;
|
|
12
12
|
message: string | undefined;
|
|
13
13
|
};
|
|
14
|
-
export
|
|
14
|
+
export declare const getFleetRolloutStatusWarning: (fleet: Fleet, t: TFunction) => string | undefined;
|
|
15
15
|
//# sourceMappingURL=fleet.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fleet.d.ts","sourceRoot":"","sources":["../../../../src/utils/status/fleet.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"fleet.d.ts","sourceRoot":"","sources":["../../../../src/utils/status/fleet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEpC,OAAO,EAA6C,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACpF,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAK5D,eAAO,MAAM,iBAAiB,MAAO,SAAS;;;;;CAK5C,CAAC;AAEH,eAAO,MAAM,kBAAkB,UACtB,KAAK,KACT,SAAS,KACX;IACD,QAAQ,kBAAkB,CAAC;IAC3B,OAAO,EAAE,MAAM,GAAG,SAAS,CAAC;CA2B7B,CAAC;AAOF,eAAO,MAAM,4BAA4B,UAAW,KAAK,KAAK,SAAS,uBAOtE,CAAC"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.getFleetRolloutStatusWarning = exports.getFleetSyncStatus = exports.fleetStatusLabels = void 0;
|
|
4
4
|
const types_1 = require("@flightctl/types");
|
|
5
5
|
const error_1 = require("../error");
|
|
6
|
+
const FLEET_ROLLOUT_FAILED_REASON = 'Suspended';
|
|
6
7
|
const fleetStatusLabels = (t) => ({
|
|
7
8
|
[types_1.ConditionType.FleetOverlappingSelectors]: t('Selectors overlap'),
|
|
8
9
|
[types_1.ConditionType.FleetValid]: t('Valid'),
|
|
@@ -10,7 +11,7 @@ const fleetStatusLabels = (t) => ({
|
|
|
10
11
|
SyncPending: t('Sync pending'),
|
|
11
12
|
});
|
|
12
13
|
exports.fleetStatusLabels = fleetStatusLabels;
|
|
13
|
-
const getFleetSyncStatus = (fleet, t
|
|
14
|
+
const getFleetSyncStatus = (fleet, t) => {
|
|
14
15
|
var _a, _b, _c;
|
|
15
16
|
const selectorOverlap = (_b = (_a = fleet.status) === null || _a === void 0 ? void 0 : _a.conditions) === null || _b === void 0 ? void 0 : _b.find((c) => c.type === types_1.ConditionType.FleetOverlappingSelectors && c.status === types_1.ConditionStatus.ConditionStatusTrue);
|
|
16
17
|
if (selectorOverlap) {
|
|
@@ -35,4 +36,16 @@ const getFleetSyncStatus = (fleet, t = (s) => s) => {
|
|
|
35
36
|
};
|
|
36
37
|
};
|
|
37
38
|
exports.getFleetSyncStatus = getFleetSyncStatus;
|
|
39
|
+
const isFleetRolloutFailedCondition = (condition) => condition.type === types_1.ConditionType.FleetRolloutInProgress &&
|
|
40
|
+
condition.status === types_1.ConditionStatus.ConditionStatusFalse &&
|
|
41
|
+
condition.reason === FLEET_ROLLOUT_FAILED_REASON;
|
|
42
|
+
const getFleetRolloutStatusWarning = (fleet, t) => {
|
|
43
|
+
var _a, _b;
|
|
44
|
+
const failedRolloutCondition = (_b = (_a = fleet.status) === null || _a === void 0 ? void 0 : _a.conditions) === null || _b === void 0 ? void 0 : _b.find(isFleetRolloutFailedCondition);
|
|
45
|
+
if (failedRolloutCondition) {
|
|
46
|
+
return (0, error_1.getConditionMessage)(failedRolloutCondition) || t('Last rollout did not complete successfully');
|
|
47
|
+
}
|
|
48
|
+
return undefined;
|
|
49
|
+
};
|
|
50
|
+
exports.getFleetRolloutStatusWarning = getFleetRolloutStatusWarning;
|
|
38
51
|
//# sourceMappingURL=fleet.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fleet.js","sourceRoot":"","sources":["../../../../src/utils/status/fleet.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"fleet.js","sourceRoot":"","sources":["../../../../src/utils/status/fleet.ts"],"names":[],"mappings":";;;AAEA,4CAAoF;AAEpF,oCAA+C;AAE/C,MAAM,2BAA2B,GAAG,WAAW,CAAC;AAEzC,MAAM,iBAAiB,GAAG,CAAC,CAAY,EAAE,EAAE,CAAC,CAAC;IAClD,CAAC,qBAAa,CAAC,yBAAyB,CAAC,EAAE,CAAC,CAAC,mBAAmB,CAAC;IACjE,CAAC,qBAAa,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC;IACtC,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC;IACrB,WAAW,EAAE,CAAC,CAAC,cAAc,CAAC;CAC/B,CAAC,CAAC;AALU,QAAA,iBAAiB,qBAK3B;AAEI,MAAM,kBAAkB,GAAG,CAChC,KAAY,EACZ,CAAY,EAIZ,EAAE;;IACF,MAAM,eAAe,GAAG,MAAA,MAAA,KAAK,CAAC,MAAM,0CAAE,UAAU,0CAAE,IAAI,CACpD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,qBAAa,CAAC,yBAAyB,IAAI,CAAC,CAAC,MAAM,KAAK,uBAAe,CAAC,mBAAmB,CAC9G,CAAC;IACF,IAAI,eAAe,EAAE,CAAC;QACpB,OAAO;YACL,OAAO,EACL,eAAe,CAAC,OAAO;gBACvB,CAAC,CAAC,8FAA8F,CAAC;YACnG,MAAM,EAAE,qBAAa,CAAC,yBAAyB;SAChD,CAAC;IACJ,CAAC;IAED,MAAM,cAAc,GAAG,CAAC,CAAA,MAAA,KAAK,CAAC,MAAM,0CAAE,UAAU,KAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,qBAAa,CAAC,UAAU,CAAC,CAAC;IACzG,IAAI,cAAc,EAAE,CAAC;QACnB,MAAM,IAAI,GAAG,cAAc,CAAC,MAAM,KAAK,uBAAe,CAAC,mBAAmB,CAAC;QAC3E,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAA,2BAAmB,EAAC,cAAc,CAAC,CAAC;QAChE,OAAO;YACL,OAAO;YACP,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,qBAAa,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;SACpD,CAAC;IACJ,CAAC;IACD,OAAO;QACL,MAAM,EAAE,aAAa;QACrB,OAAO,EAAE,CAAC,CAAC,wBAAwB,CAAC;KACrC,CAAC;AACJ,CAAC,CAAC;AAhCW,QAAA,kBAAkB,sBAgC7B;AAEF,MAAM,6BAA6B,GAAG,CAAC,SAAoB,EAAE,EAAE,CAC7D,SAAS,CAAC,IAAI,KAAK,qBAAa,CAAC,sBAAsB;IACvD,SAAS,CAAC,MAAM,KAAK,uBAAe,CAAC,oBAAoB;IACzD,SAAS,CAAC,MAAM,KAAK,2BAA2B,CAAC;AAE5C,MAAM,4BAA4B,GAAG,CAAC,KAAY,EAAE,CAAY,EAAE,EAAE;;IACzE,MAAM,sBAAsB,GAAG,MAAA,MAAA,KAAK,CAAC,MAAM,0CAAE,UAAU,0CAAE,IAAI,CAAC,6BAA6B,CAAC,CAAC;IAE7F,IAAI,sBAAsB,EAAE,CAAC;QAC3B,OAAO,IAAA,2BAAmB,EAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC,4CAA4C,CAAC,CAAC;IACxG,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAPW,QAAA,4BAA4B,gCAOvC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tooltip.d.ts","sourceRoot":"","sources":["../../../src/utils/tooltip.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,uBAAuB,mBAAoB,MAAM,GAAG,SAAS;;;;;aACwB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getDisabledTooltipProps = void 0;
|
|
4
|
+
const getDisabledTooltipProps = (disabledReason) => disabledReason ? { isAriaDisabled: true, tooltipProps: { content: disabledReason } } : undefined;
|
|
5
|
+
exports.getDisabledTooltipProps = getDisabledTooltipProps;
|
|
6
|
+
//# sourceMappingURL=tooltip.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tooltip.js","sourceRoot":"","sources":["../../../src/utils/tooltip.ts"],"names":[],"mappings":";;;AAAO,MAAM,uBAAuB,GAAG,CAAC,cAAkC,EAAE,EAAE,CAC5E,cAAc,CAAC,CAAC,CAAC,EAAE,cAAc,EAAE,IAAI,EAAE,YAAY,EAAE,EAAE,OAAO,EAAE,cAAc,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;AADtF,QAAA,uBAAuB,2BAC+D"}
|
package/package.json
CHANGED
|
@@ -1,17 +1,33 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import { Dropdown, DropdownItem, MenuToggle } from '@patternfly/react-core';
|
|
3
3
|
|
|
4
|
-
import
|
|
4
|
+
import { DeviceDecommissionTargetType } from '@flightctl/types';
|
|
5
|
+
|
|
5
6
|
import { useTranslation } from '../../hooks/useTranslation';
|
|
7
|
+
import { getDisabledTooltipProps } from '../../utils/tooltip';
|
|
8
|
+
import DeleteModal from '../modals/DeleteModal/DeleteModal';
|
|
9
|
+
import DecommissionModal from '../modals/DecommissionModal/DecommissionModal';
|
|
6
10
|
|
|
7
11
|
type DeleteActionProps = {
|
|
8
12
|
onDelete: () => Promise<unknown>;
|
|
9
13
|
resourceType: string;
|
|
10
14
|
resourceName: string;
|
|
15
|
+
buttonLabel?: string;
|
|
11
16
|
disabledReason?: string | boolean;
|
|
12
17
|
};
|
|
13
18
|
|
|
14
|
-
|
|
19
|
+
type DecommissionActionProps = {
|
|
20
|
+
onDecommission: (target: DeviceDecommissionTargetType) => Promise<unknown>;
|
|
21
|
+
disabledReason?: string;
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export const useDeleteAction = ({
|
|
25
|
+
resourceType,
|
|
26
|
+
resourceName,
|
|
27
|
+
buttonLabel,
|
|
28
|
+
onDelete,
|
|
29
|
+
disabledReason,
|
|
30
|
+
}: DeleteActionProps) => {
|
|
15
31
|
const { t } = useTranslation();
|
|
16
32
|
const [isDeleteModalOpen, setIsDeleteModalOpen] = React.useState(false);
|
|
17
33
|
const deleteAction = (
|
|
@@ -26,7 +42,7 @@ export const useDeleteAction = ({ resourceType, resourceName, onDelete, disabled
|
|
|
26
42
|
}
|
|
27
43
|
: undefined)}
|
|
28
44
|
>
|
|
29
|
-
{t('Delete {{ resourceType }}', { resourceType })}
|
|
45
|
+
{buttonLabel || t('Delete {{ resourceType }}', { resourceType })}
|
|
30
46
|
</DropdownItem>
|
|
31
47
|
);
|
|
32
48
|
const deleteModal = isDeleteModalOpen && (
|
|
@@ -41,11 +57,23 @@ export const useDeleteAction = ({ resourceType, resourceName, onDelete, disabled
|
|
|
41
57
|
return { deleteAction, deleteModal };
|
|
42
58
|
};
|
|
43
59
|
|
|
44
|
-
|
|
45
|
-
|
|
60
|
+
export const useDecommissionAction = ({ onDecommission, disabledReason }: DecommissionActionProps) => {
|
|
61
|
+
const { t } = useTranslation();
|
|
62
|
+
const [isDecommissionModalOpen, setIsDecommissionModalOpen] = React.useState(false);
|
|
63
|
+
const decommissionProps = getDisabledTooltipProps(disabledReason);
|
|
64
|
+
const decommissionAction = (
|
|
65
|
+
<DropdownItem onClick={() => setIsDecommissionModalOpen(true)} {...decommissionProps}>
|
|
66
|
+
{t('Decommission device')}
|
|
67
|
+
</DropdownItem>
|
|
68
|
+
);
|
|
69
|
+
const decommissionModal = isDecommissionModalOpen && (
|
|
70
|
+
<DecommissionModal onClose={() => setIsDecommissionModalOpen(false)} onDecommission={onDecommission} />
|
|
71
|
+
);
|
|
72
|
+
|
|
73
|
+
return { decommissionAction, decommissionModal };
|
|
46
74
|
};
|
|
47
75
|
|
|
48
|
-
const DetailsPageActions
|
|
76
|
+
const DetailsPageActions = ({ children }: React.PropsWithChildren<unknown>) => {
|
|
49
77
|
const { t } = useTranslation();
|
|
50
78
|
const [actionsOpen, setActionsOpen] = React.useState(false);
|
|
51
79
|
return (
|
|
@@ -90,7 +90,7 @@ const ApplicationsTable = ({
|
|
|
90
90
|
|
|
91
91
|
const deleteSystemdUnit = canEdit && !isDeletedSystemdUnit && onSystemdDelete && (
|
|
92
92
|
<Button
|
|
93
|
-
aria-label={t('Delete')}
|
|
93
|
+
aria-label={t('Delete system service')}
|
|
94
94
|
isDisabled={isUpdating}
|
|
95
95
|
variant="plain"
|
|
96
96
|
icon={<MinusCircleIcon />}
|
|
@@ -12,8 +12,8 @@ import DetailsPageCard, { DetailsPageCardBody } from '../../DetailsPage/DetailsP
|
|
|
12
12
|
|
|
13
13
|
type DeviceDetailsTabProps = {
|
|
14
14
|
device: Required<Device>;
|
|
15
|
-
refetch: VoidFunction;
|
|
16
15
|
canEdit: boolean;
|
|
16
|
+
refetch?: VoidFunction;
|
|
17
17
|
};
|
|
18
18
|
|
|
19
19
|
const DeviceApplications = ({ device, refetch, canEdit }: React.PropsWithChildren<DeviceDetailsTabProps>) => {
|
|
@@ -25,7 +25,7 @@ const DeviceApplications = ({ device, refetch, canEdit }: React.PropsWithChildre
|
|
|
25
25
|
|
|
26
26
|
const onClose = (hasChanges?: boolean, addedUnits?: string[]) => {
|
|
27
27
|
if (hasChanges) {
|
|
28
|
-
refetch();
|
|
28
|
+
refetch?.();
|
|
29
29
|
}
|
|
30
30
|
if (addedUnits?.length) {
|
|
31
31
|
const allAddedUnitDates = { ...addedSystemdDates };
|
|
@@ -56,7 +56,7 @@ const DeviceApplications = ({ device, refetch, canEdit }: React.PropsWithChildre
|
|
|
56
56
|
if (patches.length > 0) {
|
|
57
57
|
setIsUpdating(true);
|
|
58
58
|
await patch(`devices/${device.metadata.name}`, patches);
|
|
59
|
-
refetch();
|
|
59
|
+
refetch?.();
|
|
60
60
|
setIsUpdating(false);
|
|
61
61
|
}
|
|
62
62
|
};
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
|
-
import { DropdownItem, DropdownList, Nav, NavList } from '@patternfly/react-core';
|
|
2
|
+
import { Button, DropdownItem, DropdownList, Nav, NavList } from '@patternfly/react-core';
|
|
3
3
|
|
|
4
|
-
import { Device } from '@flightctl/types';
|
|
4
|
+
import { Device, DeviceDecommission, DeviceDecommissionTargetType } from '@flightctl/types';
|
|
5
5
|
import { useFetchPeriodically } from '../../../hooks/useFetchPeriodically';
|
|
6
6
|
import { useFetch } from '../../../hooks/useFetch';
|
|
7
|
+
import { getDisabledTooltipProps } from '../../../utils/tooltip';
|
|
7
8
|
import DetailsPage from '../../DetailsPage/DetailsPage';
|
|
8
|
-
import DetailsPageActions, { useDeleteAction } from '../../DetailsPage/DetailsPageActions';
|
|
9
|
+
import DetailsPageActions, { useDecommissionAction, useDeleteAction } from '../../DetailsPage/DetailsPageActions';
|
|
9
10
|
import { useTranslation } from '../../../hooks/useTranslation';
|
|
10
11
|
import { ROUTE, useNavigate } from '../../../hooks/useNavigate';
|
|
11
12
|
import { useAppContext } from '../../../hooks/useAppContext';
|
|
@@ -13,7 +14,7 @@ import DeviceDetailsTab from './DeviceDetailsTab';
|
|
|
13
14
|
import TerminalTab from './TerminalTab';
|
|
14
15
|
import NavItem from '../../NavItem/NavItem';
|
|
15
16
|
import DeviceStatusDebugModal from './DeviceStatusDebugModal';
|
|
16
|
-
import {
|
|
17
|
+
import { getEditDisabledReason, isDeviceEnrolled } from '../../../utils/devices';
|
|
17
18
|
import { RESOURCE, VERB } from '../../../types/rbac';
|
|
18
19
|
import { useAccessReview } from '../../../hooks/useAccessReview';
|
|
19
20
|
import PageWithPermissions from '../../common/PageWithPermissions';
|
|
@@ -26,17 +27,21 @@ const DeviceDetailsPage = ({ children, hideTerminal }: DeviceDetailsPageProps) =
|
|
|
26
27
|
router: { useParams, Routes, Route, Navigate },
|
|
27
28
|
} = useAppContext();
|
|
28
29
|
const { deviceId } = useParams() as { deviceId: string };
|
|
30
|
+
const navigate = useNavigate();
|
|
31
|
+
const { put, remove } = useFetch();
|
|
29
32
|
const [device, loading, error, refetch] = useFetchPeriodically<Required<Device>>({ endpoint: `devices/${deviceId}` });
|
|
30
|
-
const [showDebugInfo, setShowDebugInfo] = React.useState<boolean>(false);
|
|
31
33
|
|
|
32
|
-
const
|
|
33
|
-
const { remove } = useFetch();
|
|
34
|
+
const [showDebugInfo, setShowDebugInfo] = React.useState<boolean>(false);
|
|
34
35
|
|
|
35
36
|
const deviceAlias = device?.metadata.labels?.alias || deviceId;
|
|
37
|
+
const isEnrolled = device && isDeviceEnrolled(device);
|
|
36
38
|
|
|
39
|
+
const [hasTerminalAccess] = useAccessReview(RESOURCE.DEVICE_CONSOLE, VERB.GET);
|
|
37
40
|
const [canDelete] = useAccessReview(RESOURCE.DEVICE, VERB.DELETE);
|
|
38
41
|
const [canEdit] = useAccessReview(RESOURCE.DEVICE, VERB.PATCH);
|
|
39
|
-
const [
|
|
42
|
+
const [canDecommission] = useAccessReview(RESOURCE.DEVICE_DECOMMISSION, VERB.UPDATE);
|
|
43
|
+
|
|
44
|
+
const canOpenTerminal = hasTerminalAccess && isEnrolled;
|
|
40
45
|
|
|
41
46
|
const { deleteAction, deleteModal } = useDeleteAction({
|
|
42
47
|
onDelete: async () => {
|
|
@@ -45,15 +50,20 @@ const DeviceDetailsPage = ({ children, hideTerminal }: DeviceDetailsPageProps) =
|
|
|
45
50
|
},
|
|
46
51
|
resourceName: deviceAlias,
|
|
47
52
|
resourceType: 'device',
|
|
53
|
+
buttonLabel: isEnrolled ? undefined : t('Delete forever'),
|
|
48
54
|
});
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
55
|
+
|
|
56
|
+
const { decommissionAction, decommissionModal } = useDecommissionAction({
|
|
57
|
+
onDecommission: async (target: DeviceDecommissionTargetType) => {
|
|
58
|
+
await put<DeviceDecommission>(`devices/${deviceId}/decommission`, {
|
|
59
|
+
target,
|
|
60
|
+
});
|
|
61
|
+
refetch();
|
|
62
|
+
navigate(ROUTE.DEVICES);
|
|
63
|
+
},
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
const editActionProps = device ? getDisabledTooltipProps(getEditDisabledReason(device, t)) : undefined;
|
|
57
67
|
|
|
58
68
|
return (
|
|
59
69
|
<DetailsPage
|
|
@@ -73,26 +83,34 @@ const DeviceDetailsPage = ({ children, hideTerminal }: DeviceDetailsPageProps) =
|
|
|
73
83
|
</Nav>
|
|
74
84
|
}
|
|
75
85
|
actions={
|
|
76
|
-
|
|
77
|
-
<
|
|
78
|
-
|
|
86
|
+
isEnrolled ? (
|
|
87
|
+
<DetailsPageActions>
|
|
88
|
+
<DropdownList>
|
|
89
|
+
{canEdit && (
|
|
90
|
+
<DropdownItem
|
|
91
|
+
onClick={() => navigate({ route: ROUTE.DEVICE_EDIT, postfix: deviceId })}
|
|
92
|
+
{...editActionProps}
|
|
93
|
+
>
|
|
94
|
+
{t('Edit device configurations')}
|
|
95
|
+
</DropdownItem>
|
|
96
|
+
)}
|
|
79
97
|
<DropdownItem
|
|
80
|
-
onClick={() =>
|
|
81
|
-
|
|
98
|
+
onClick={() => {
|
|
99
|
+
setShowDebugInfo(!showDebugInfo);
|
|
100
|
+
}}
|
|
82
101
|
>
|
|
83
|
-
{t('
|
|
102
|
+
{t('View status debug information')}
|
|
84
103
|
</DropdownItem>
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
</DetailsPageActions>
|
|
104
|
+
{canDecommission && decommissionAction}
|
|
105
|
+
</DropdownList>
|
|
106
|
+
</DetailsPageActions>
|
|
107
|
+
) : (
|
|
108
|
+
canDelete && (
|
|
109
|
+
<Button aria-label={t('Delete device forever')} variant="danger">
|
|
110
|
+
{deleteAction}
|
|
111
|
+
</Button>
|
|
112
|
+
)
|
|
113
|
+
)
|
|
96
114
|
}
|
|
97
115
|
>
|
|
98
116
|
{device && (
|
|
@@ -109,7 +127,8 @@ const DeviceDetailsPage = ({ children, hideTerminal }: DeviceDetailsPageProps) =
|
|
|
109
127
|
{!hideTerminal && canOpenTerminal && <Route path="terminal" element={<TerminalTab device={device} />} />}
|
|
110
128
|
</Routes>
|
|
111
129
|
)}
|
|
112
|
-
|
|
130
|
+
|
|
131
|
+
{deleteModal || decommissionModal}
|
|
113
132
|
{device && showDebugInfo && (
|
|
114
133
|
<DeviceStatusDebugModal
|
|
115
134
|
status={device.status}
|