@flightctl/ui-components 0.0.1
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/__mocks__/fileMock.js +3 -0
- package/dist/__mocks__/fileMock.js.map +1 -0
- package/dist/__mocks__/styleMock.js +3 -0
- package/dist/__mocks__/styleMock.js.map +1 -0
- package/dist/jest.config.js +24 -0
- package/dist/jest.config.js.map +1 -0
- package/dist/src/components/DetailsPage/DetailsNotFound.js +69 -0
- package/dist/src/components/DetailsPage/DetailsNotFound.js.map +1 -0
- package/dist/src/components/DetailsPage/DetailsPage.css +3 -0
- package/dist/src/components/DetailsPage/DetailsPage.js +42 -0
- package/dist/src/components/DetailsPage/DetailsPage.js.map +1 -0
- package/dist/src/components/DetailsPage/DetailsPage.spec.js +81 -0
- package/dist/src/components/DetailsPage/DetailsPage.spec.js.map +1 -0
- package/dist/src/components/DetailsPage/DetailsPageActions.js +30 -0
- package/dist/src/components/DetailsPage/DetailsPageActions.js.map +1 -0
- package/dist/src/components/DetailsPage/DetailsPageCard.css +8 -0
- package/dist/src/components/DetailsPage/DetailsPageCard.js +12 -0
- package/dist/src/components/DetailsPage/DetailsPageCard.js.map +1 -0
- package/dist/src/components/DetailsPage/Tables/ApplicationsTable.js +27 -0
- package/dist/src/components/DetailsPage/Tables/ApplicationsTable.js.map +1 -0
- package/dist/src/components/DetailsPage/Tables/ConditionsTable.js +24 -0
- package/dist/src/components/DetailsPage/Tables/ConditionsTable.js.map +1 -0
- package/dist/src/components/DetailsPage/Tables/IntegrityDetails.js +22 -0
- package/dist/src/components/DetailsPage/Tables/IntegrityDetails.js.map +1 -0
- package/dist/src/components/DetailsPage/Tables/SystemdDetailsTable.js +40 -0
- package/dist/src/components/DetailsPage/Tables/SystemdDetailsTable.js.map +1 -0
- package/dist/src/components/Device/AddDeviceModal/AddDeviceModal.js +63 -0
- package/dist/src/components/Device/AddDeviceModal/AddDeviceModal.js.map +1 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.js +57 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.js.map +1 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.css +4 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.js +114 -0
- package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.js.map +1 -0
- package/dist/src/components/Device/DeviceDetails/DeviceFleet.css +3 -0
- package/dist/src/components/Device/DeviceDetails/DeviceFleet.js +50 -0
- package/dist/src/components/Device/DeviceDetails/DeviceFleet.js.map +1 -0
- package/dist/src/components/Device/DeviceDetails/DeviceStatusDebugModal.css +3 -0
- package/dist/src/components/Device/DeviceDetails/DeviceStatusDebugModal.js +34 -0
- package/dist/src/components/Device/DeviceDetails/DeviceStatusDebugModal.js.map +1 -0
- package/dist/src/components/Device/DeviceDetails/SystemdTable.js +38 -0
- package/dist/src/components/Device/DeviceDetails/SystemdTable.js.map +1 -0
- package/dist/src/components/Device/DeviceDetails/TerminalTab.js +31 -0
- package/dist/src/components/Device/DeviceDetails/TerminalTab.js.map +1 -0
- package/dist/src/components/Device/DeviceList/DeviceFilterSelect.js +87 -0
- package/dist/src/components/Device/DeviceList/DeviceFilterSelect.js.map +1 -0
- package/dist/src/components/Device/DeviceList/DeviceList.js +157 -0
- package/dist/src/components/Device/DeviceList/DeviceList.js.map +1 -0
- package/dist/src/components/Device/DeviceList/DeviceTableRow.js +62 -0
- package/dist/src/components/Device/DeviceList/DeviceTableRow.js.map +1 -0
- package/dist/src/components/Device/DeviceList/DeviceTableToolbar.js +80 -0
- package/dist/src/components/Device/DeviceList/DeviceTableToolbar.js.map +1 -0
- package/dist/src/components/Device/DeviceList/types.js +4 -0
- package/dist/src/components/Device/DeviceList/types.js.map +1 -0
- package/dist/src/components/Device/DeviceList/useDeviceBackendFilters.js +94 -0
- package/dist/src/components/Device/DeviceList/useDeviceBackendFilters.js.map +1 -0
- package/dist/src/components/Device/DeviceList/useDeviceFilters.js +16 -0
- package/dist/src/components/Device/DeviceList/useDeviceFilters.js.map +1 -0
- package/dist/src/components/Device/DeviceList/useDeviceLikeResources.js +98 -0
- package/dist/src/components/Device/DeviceList/useDeviceLikeResources.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.css +4 -0
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.js +92 -0
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizardFooter.js +32 -0
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizardFooter.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizardNav.js +36 -0
- package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizardNav.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/deviceSpecUtils.js +171 -0
- package/dist/src/components/Device/EditDeviceWizard/deviceSpecUtils.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.js +15 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigK8sSecretTemplateForm.js +22 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigK8sSecretTemplateForm.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigTemplateForm.css +3 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigTemplateForm.js +96 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigTemplateForm.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.js +94 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.js +45 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/GeneralInfoStep.js +48 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/GeneralInfoStep.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.js +45 -0
- package/dist/src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/types.js +3 -0
- package/dist/src/components/Device/EditDeviceWizard/types.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/useEditDevice.js +35 -0
- package/dist/src/components/Device/EditDeviceWizard/useEditDevice.js.map +1 -0
- package/dist/src/components/Device/EditDeviceWizard/utils.js +65 -0
- package/dist/src/components/Device/EditDeviceWizard/utils.js.map +1 -0
- package/dist/src/components/Device/MatchPatternsModal/MatchPatternsForm.js +39 -0
- package/dist/src/components/Device/MatchPatternsModal/MatchPatternsForm.js.map +1 -0
- package/dist/src/components/Device/MatchPatternsModal/MatchPatternsModal.js +46 -0
- package/dist/src/components/Device/MatchPatternsModal/MatchPatternsModal.js.map +1 -0
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.css +3 -0
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.js +103 -0
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.js.map +1 -0
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableRow.js +42 -0
- package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableRow.js.map +1 -0
- package/dist/src/components/ErrorAlert/ErrorAlert.js +13 -0
- package/dist/src/components/ErrorAlert/ErrorAlert.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.css +3 -0
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.js +82 -0
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.js +32 -0
- package/dist/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.js +85 -0
- package/dist/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/GeneralInfoStep.js +30 -0
- package/dist/src/components/Fleet/CreateFleet/steps/GeneralInfoStep.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.js +46 -0
- package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/types.js +3 -0
- package/dist/src/components/Fleet/CreateFleet/types.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/useEditFleet.js +35 -0
- package/dist/src/components/Fleet/CreateFleet/useEditFleet.js.map +1 -0
- package/dist/src/components/Fleet/CreateFleet/utils.js +143 -0
- package/dist/src/components/Fleet/CreateFleet/utils.js.map +1 -0
- package/dist/src/components/Fleet/DeleteFleetModal/DeleteFleetModal.js +55 -0
- package/dist/src/components/Fleet/DeleteFleetModal/DeleteFleetModal.js.map +1 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDetails.js +49 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDetails.js.map +1 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDetailsContent.js +69 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDetailsContent.js.map +1 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDevices.js +40 -0
- package/dist/src/components/Fleet/FleetDetails/FleetDevices.js.map +1 -0
- package/dist/src/components/Fleet/FleetDetails/FleetOwnerLink.js +37 -0
- package/dist/src/components/Fleet/FleetDetails/FleetOwnerLink.js.map +1 -0
- package/dist/src/components/Fleet/FleetDetails/chartUtils.js +29 -0
- package/dist/src/components/Fleet/FleetDetails/chartUtils.js.map +1 -0
- package/dist/src/components/Fleet/FleetList.js +130 -0
- package/dist/src/components/Fleet/FleetList.js.map +1 -0
- package/dist/src/components/Fleet/FleetRow.js +64 -0
- package/dist/src/components/Fleet/FleetRow.js.map +1 -0
- package/dist/src/components/Fleet/FleetStatus.js +34 -0
- package/dist/src/components/Fleet/FleetStatus.js.map +1 -0
- package/dist/src/components/Fleet/ImportFleetWizard/ImportFleetWizard.css +3 -0
- package/dist/src/components/Fleet/ImportFleetWizard/ImportFleetWizard.js +106 -0
- package/dist/src/components/Fleet/ImportFleetWizard/ImportFleetWizard.js.map +1 -0
- package/dist/src/components/Fleet/ImportFleetWizard/steps/RepositoryStep.js +69 -0
- package/dist/src/components/Fleet/ImportFleetWizard/steps/RepositoryStep.js.map +1 -0
- package/dist/src/components/Fleet/ImportFleetWizard/steps/ResourceSyncStep.js +31 -0
- package/dist/src/components/Fleet/ImportFleetWizard/steps/ResourceSyncStep.js.map +1 -0
- package/dist/src/components/Fleet/ImportFleetWizard/steps/ReviewStep.js +37 -0
- package/dist/src/components/Fleet/ImportFleetWizard/steps/ReviewStep.js.map +1 -0
- package/dist/src/components/Fleet/ImportFleetWizard/types.js +3 -0
- package/dist/src/components/Fleet/ImportFleetWizard/types.js.map +1 -0
- package/dist/src/components/Fleet/ResourceSyncRow.js +36 -0
- package/dist/src/components/Fleet/ResourceSyncRow.js.map +1 -0
- package/dist/src/components/ListPage/ListPage.js +12 -0
- package/dist/src/components/ListPage/ListPage.js.map +1 -0
- package/dist/src/components/ListPage/ListPageActions.js +30 -0
- package/dist/src/components/ListPage/ListPageActions.js.map +1 -0
- package/dist/src/components/ListPage/ListPageBody.js +21 -0
- package/dist/src/components/ListPage/ListPageBody.js.map +1 -0
- package/dist/src/components/ListPage/types.js +3 -0
- package/dist/src/components/ListPage/types.js.map +1 -0
- package/dist/src/components/NavItem/NavItem.js +20 -0
- package/dist/src/components/NavItem/NavItem.js.map +1 -0
- package/dist/src/components/OverviewPage/Cards/Status/ApplicationStatusChart.js +30 -0
- package/dist/src/components/OverviewPage/Cards/Status/ApplicationStatusChart.js.map +1 -0
- package/dist/src/components/OverviewPage/Cards/Status/DeviceStatusChart.js +32 -0
- package/dist/src/components/OverviewPage/Cards/Status/DeviceStatusChart.js.map +1 -0
- package/dist/src/components/OverviewPage/Cards/Status/StatusCard.js +61 -0
- package/dist/src/components/OverviewPage/Cards/Status/StatusCard.js.map +1 -0
- package/dist/src/components/OverviewPage/Cards/Status/StatusCardFilters.js +64 -0
- package/dist/src/components/OverviewPage/Cards/Status/StatusCardFilters.js.map +1 -0
- package/dist/src/components/OverviewPage/Cards/Status/SystemUpdateStatusChart.js +30 -0
- package/dist/src/components/OverviewPage/Cards/Status/SystemUpdateStatusChart.js.map +1 -0
- package/dist/src/components/OverviewPage/Cards/Status/utils.js +31 -0
- package/dist/src/components/OverviewPage/Cards/Status/utils.js.map +1 -0
- package/dist/src/components/OverviewPage/Cards/ToDo/ToDoCard.js +46 -0
- package/dist/src/components/OverviewPage/Cards/ToDo/ToDoCard.js.map +1 -0
- package/dist/src/components/OverviewPage/Overview.js +16 -0
- package/dist/src/components/OverviewPage/Overview.js.map +1 -0
- package/dist/src/components/OverviewPage/OverviewPage.js +17 -0
- package/dist/src/components/OverviewPage/OverviewPage.js.map +1 -0
- package/dist/src/components/Repository/CreateRepository/CreateRepository.js +102 -0
- package/dist/src/components/Repository/CreateRepository/CreateRepository.js.map +1 -0
- package/dist/src/components/Repository/CreateRepository/CreateRepositoryForm.css +7 -0
- package/dist/src/components/Repository/CreateRepository/CreateRepositoryForm.js +215 -0
- package/dist/src/components/Repository/CreateRepository/CreateRepositoryForm.js.map +1 -0
- package/dist/src/components/Repository/CreateRepository/CreateResourceSyncsForm.js +31 -0
- package/dist/src/components/Repository/CreateRepository/CreateResourceSyncsForm.js.map +1 -0
- package/dist/src/components/Repository/CreateRepository/types.js +3 -0
- package/dist/src/components/Repository/CreateRepository/types.js.map +1 -0
- package/dist/src/components/Repository/CreateRepository/utils.js +454 -0
- package/dist/src/components/Repository/CreateRepository/utils.js.map +1 -0
- package/dist/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.js +93 -0
- package/dist/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.js.map +1 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositoryDetails.js +39 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositoryDetails.js.map +1 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositoryGeneralDetailsCard.js +64 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositoryGeneralDetailsCard.js.map +1 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositoryResourceSyncsCard.js +18 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositoryResourceSyncsCard.js.map +1 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositorySource.js +24 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositorySource.js.map +1 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositorySourceList.js +64 -0
- package/dist/src/components/Repository/RepositoryDetails/RepositorySourceList.js.map +1 -0
- package/dist/src/components/Repository/RepositoryList.js +133 -0
- package/dist/src/components/Repository/RepositoryList.js.map +1 -0
- package/dist/src/components/ResourceSync/RepositoryResourceSyncList.css +7 -0
- package/dist/src/components/ResourceSync/RepositoryResourceSyncList.js +140 -0
- package/dist/src/components/ResourceSync/RepositoryResourceSyncList.js.map +1 -0
- package/dist/src/components/ResourceSync/ResourceSyncStatus.js +65 -0
- package/dist/src/components/ResourceSync/ResourceSyncStatus.js.map +1 -0
- package/dist/src/components/ResourceSync/ResourceSyncToRepository.js +49 -0
- package/dist/src/components/ResourceSync/ResourceSyncToRepository.js.map +1 -0
- package/dist/src/components/Status/ApplicationStatus.js +23 -0
- package/dist/src/components/Status/ApplicationStatus.js.map +1 -0
- package/dist/src/components/Status/ApplicationSummaryStatus.js +23 -0
- package/dist/src/components/Status/ApplicationSummaryStatus.js.map +1 -0
- package/dist/src/components/Status/DeviceResourceStatus.js +84 -0
- package/dist/src/components/Status/DeviceResourceStatus.js.map +1 -0
- package/dist/src/components/Status/DeviceStatus.js +18 -0
- package/dist/src/components/Status/DeviceStatus.js.map +1 -0
- package/dist/src/components/Status/EnrollmentRequestStatus.js +18 -0
- package/dist/src/components/Status/EnrollmentRequestStatus.js.map +1 -0
- package/dist/src/components/Status/IntegrityStatus.js +17 -0
- package/dist/src/components/Status/IntegrityStatus.js.map +1 -0
- package/dist/src/components/Status/RepositoryStatus.js +37 -0
- package/dist/src/components/Status/RepositoryStatus.js.map +1 -0
- package/dist/src/components/Status/StatusDisplay.css +9 -0
- package/dist/src/components/Status/StatusDisplay.js +33 -0
- package/dist/src/components/Status/StatusDisplay.js.map +1 -0
- package/dist/src/components/Status/SystemUpdateStatus.js +24 -0
- package/dist/src/components/Status/SystemUpdateStatus.js.map +1 -0
- package/dist/src/components/Status/SystemdStatus.js +21 -0
- package/dist/src/components/Status/SystemdStatus.js.map +1 -0
- package/dist/src/components/Status/utils.js +10 -0
- package/dist/src/components/Status/utils.js.map +1 -0
- package/dist/src/components/Table/Table.js +28 -0
- package/dist/src/components/Table/Table.js.map +1 -0
- package/dist/src/components/Table/TableActions.js +16 -0
- package/dist/src/components/Table/TableActions.js.map +1 -0
- package/dist/src/components/Table/TableTextSearch.js +13 -0
- package/dist/src/components/Table/TableTextSearch.js.map +1 -0
- package/dist/src/components/Terminal/Terminal.css +1 -0
- package/dist/src/components/Terminal/Terminal.js +79 -0
- package/dist/src/components/Terminal/Terminal.js.map +1 -0
- package/dist/src/components/UserPreferences/UserPreferencesModal.js +34 -0
- package/dist/src/components/UserPreferences/UserPreferencesModal.js.map +1 -0
- package/dist/src/components/UserPreferences/UserPreferencesProvider.js +19 -0
- package/dist/src/components/UserPreferences/UserPreferencesProvider.js.map +1 -0
- package/dist/src/components/charts/DonutChart.css +10 -0
- package/dist/src/components/charts/DonutChart.js +47 -0
- package/dist/src/components/charts/DonutChart.js.map +1 -0
- package/dist/src/components/common/CopyButton.js +18 -0
- package/dist/src/components/common/CopyButton.js.map +1 -0
- package/dist/src/components/common/EditableLabelControl.js +39 -0
- package/dist/src/components/common/EditableLabelControl.js.map +1 -0
- package/dist/src/components/common/ErrorBoundary.js +36 -0
- package/dist/src/components/common/ErrorBoundary.js.map +1 -0
- package/dist/src/components/common/HelperTextItems.js +25 -0
- package/dist/src/components/common/HelperTextItems.js.map +1 -0
- package/dist/src/components/common/LabelsView.css +9 -0
- package/dist/src/components/common/LabelsView.js +18 -0
- package/dist/src/components/common/LabelsView.js.map +1 -0
- package/dist/src/components/common/LeaveFormConfirmation.js +51 -0
- package/dist/src/components/common/LeaveFormConfirmation.js.map +1 -0
- package/dist/src/components/common/ResourceLink.css +29 -0
- package/dist/src/components/common/ResourceLink.js +30 -0
- package/dist/src/components/common/ResourceLink.js.map +1 -0
- package/dist/src/components/common/ResourceListEmptyState.js +10 -0
- package/dist/src/components/common/ResourceListEmptyState.js.map +1 -0
- package/dist/src/components/common/WithHelperText.css +3 -0
- package/dist/src/components/common/WithHelperText.js +16 -0
- package/dist/src/components/common/WithHelperText.js.map +1 -0
- package/dist/src/components/common/WithTooltip.js +8 -0
- package/dist/src/components/common/WithTooltip.js.map +1 -0
- package/dist/src/components/form/CheckboxField.js +29 -0
- package/dist/src/components/form/CheckboxField.js.map +1 -0
- package/dist/src/components/form/FieldHelperText.js +27 -0
- package/dist/src/components/form/FieldHelperText.js.map +1 -0
- package/dist/src/components/form/FilterSelect.css +8 -0
- package/dist/src/components/form/FilterSelect.js +30 -0
- package/dist/src/components/form/FilterSelect.js.map +1 -0
- package/dist/src/components/form/FlightCtlActionGroup.css +9 -0
- package/dist/src/components/form/FlightCtlActionGroup.js +10 -0
- package/dist/src/components/form/FlightCtlActionGroup.js.map +1 -0
- package/dist/src/components/form/FlightCtlForm.js +13 -0
- package/dist/src/components/form/FlightCtlForm.js.map +1 -0
- package/dist/src/components/form/FormSelect.css +8 -0
- package/dist/src/components/form/FormSelect.js +50 -0
- package/dist/src/components/form/FormSelect.js.map +1 -0
- package/dist/src/components/form/LabelsField.js +61 -0
- package/dist/src/components/form/LabelsField.js.map +1 -0
- package/dist/src/components/form/NameField.js +63 -0
- package/dist/src/components/form/NameField.js.map +1 -0
- package/dist/src/components/form/RadioField.js +32 -0
- package/dist/src/components/form/RadioField.js.map +1 -0
- package/dist/src/components/form/RichValidationTextField.js +66 -0
- package/dist/src/components/form/RichValidationTextField.js.map +1 -0
- package/dist/src/components/form/TextAreaField.js +28 -0
- package/dist/src/components/form/TextAreaField.js.map +1 -0
- package/dist/src/components/form/TextField.js +29 -0
- package/dist/src/components/form/TextField.js.map +1 -0
- package/dist/src/components/form/validations.js +286 -0
- package/dist/src/components/form/validations.js.map +1 -0
- package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceForm.js +36 -0
- package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceForm.js.map +1 -0
- package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.js +43 -0
- package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.js.map +1 -0
- package/dist/src/components/modals/ApproveDeviceModal/DeviceLabelMatch.css +24 -0
- package/dist/src/components/modals/ApproveDeviceModal/DeviceLabelMatch.js +62 -0
- package/dist/src/components/modals/ApproveDeviceModal/DeviceLabelMatch.js.map +1 -0
- package/dist/src/components/modals/CreateRepositoryModal/CreateRepositoryModal.js +14 -0
- package/dist/src/components/modals/CreateRepositoryModal/CreateRepositoryModal.js.map +1 -0
- package/dist/src/components/modals/DeleteModal/DeleteModal.js +41 -0
- package/dist/src/components/modals/DeleteModal/DeleteModal.js.map +1 -0
- package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.js +63 -0
- package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.js.map +1 -0
- package/dist/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.css +4 -0
- package/dist/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.js +126 -0
- package/dist/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.js.map +1 -0
- package/dist/src/components/modals/massModals/MassDeleteDeviceModal/MassDeleteDeviceModal.js +64 -0
- package/dist/src/components/modals/massModals/MassDeleteDeviceModal/MassDeleteDeviceModal.js.map +1 -0
- package/dist/src/components/modals/massModals/MassDeleteFleetModal/MassDeleteFleetModal.js +84 -0
- package/dist/src/components/modals/massModals/MassDeleteFleetModal/MassDeleteFleetModal.js.map +1 -0
- package/dist/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.js +94 -0
- package/dist/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.js.map +1 -0
- package/dist/src/components/modals/massModals/MassDeleteResourceSyncModal/MassDeleteResourceSyncModal.js +62 -0
- package/dist/src/components/modals/massModals/MassDeleteResourceSyncModal/MassDeleteResourceSyncModal.js.map +1 -0
- package/dist/src/constants.js +8 -0
- package/dist/src/constants.js.map +1 -0
- package/dist/src/hooks/useAppContext.js +61 -0
- package/dist/src/hooks/useAppContext.js.map +1 -0
- package/dist/src/hooks/useDeviceLabelMatch.js +78 -0
- package/dist/src/hooks/useDeviceLabelMatch.js.map +1 -0
- package/dist/src/hooks/useDocumentTitle.js +17 -0
- package/dist/src/hooks/useDocumentTitle.js.map +1 -0
- package/dist/src/hooks/useFetch.js +10 -0
- package/dist/src/hooks/useFetch.js.map +1 -0
- package/dist/src/hooks/useFetchPeriodically.js +75 -0
- package/dist/src/hooks/useFetchPeriodically.js.map +1 -0
- package/dist/src/hooks/useNavigate.js +65 -0
- package/dist/src/hooks/useNavigate.js.map +1 -0
- package/dist/src/hooks/useTableSelect.js +45 -0
- package/dist/src/hooks/useTableSelect.js.map +1 -0
- package/dist/src/hooks/useTableSort.js +38 -0
- package/dist/src/hooks/useTableSort.js.map +1 -0
- package/dist/src/hooks/useTableTextSearch.js +23 -0
- package/dist/src/hooks/useTableTextSearch.js.map +1 -0
- package/dist/src/hooks/useTemplateVersion.js +22 -0
- package/dist/src/hooks/useTemplateVersion.js.map +1 -0
- package/dist/src/hooks/useThemePreferences.js +61 -0
- package/dist/src/hooks/useThemePreferences.js.map +1 -0
- package/dist/src/hooks/useTranslation.js +12 -0
- package/dist/src/hooks/useTranslation.js.map +1 -0
- package/dist/src/hooks/useUserPreferences.js +16 -0
- package/dist/src/hooks/useUserPreferences.js.map +1 -0
- package/dist/src/hooks/useWebSocket.js +69 -0
- package/dist/src/hooks/useWebSocket.js.map +1 -0
- package/dist/src/setupTests.js +24 -0
- package/dist/src/setupTests.js.map +1 -0
- package/dist/src/tests/test-utils.js +21 -0
- package/dist/src/tests/test-utils.js.map +1 -0
- package/dist/src/types/deviceSpec.js +20 -0
- package/dist/src/types/deviceSpec.js.map +1 -0
- package/dist/src/types/extraTypes.js +20 -0
- package/dist/src/types/extraTypes.js.map +1 -0
- package/dist/src/types/typeUtils.js +12 -0
- package/dist/src/types/typeUtils.js.map +1 -0
- package/dist/src/utils/api.js +68 -0
- package/dist/src/utils/api.js.map +1 -0
- package/dist/src/utils/dates.js +53 -0
- package/dist/src/utils/dates.js.map +1 -0
- package/dist/src/utils/devices.js +37 -0
- package/dist/src/utils/devices.js.map +1 -0
- package/dist/src/utils/error.js +25 -0
- package/dist/src/utils/error.js.map +1 -0
- package/dist/src/utils/labels.js +44 -0
- package/dist/src/utils/labels.js.map +1 -0
- package/dist/src/utils/metrics.js +48 -0
- package/dist/src/utils/metrics.js.map +1 -0
- package/dist/src/utils/patch.js +108 -0
- package/dist/src/utils/patch.js.map +1 -0
- package/dist/src/utils/resource.js +6 -0
- package/dist/src/utils/resource.js.map +1 -0
- package/dist/src/utils/search.js +14 -0
- package/dist/src/utils/search.js.map +1 -0
- package/dist/src/utils/sort/device.js +89 -0
- package/dist/src/utils/sort/device.js.map +1 -0
- package/dist/src/utils/sort/fleet.js +20 -0
- package/dist/src/utils/sort/fleet.js.map +1 -0
- package/dist/src/utils/sort/generic.js +34 -0
- package/dist/src/utils/sort/generic.js.map +1 -0
- package/dist/src/utils/sort/repository.js +28 -0
- package/dist/src/utils/sort/repository.js.map +1 -0
- package/dist/src/utils/sort/resourceSync.js +29 -0
- package/dist/src/utils/sort/resourceSync.js.map +1 -0
- package/dist/src/utils/status/applications.js +56 -0
- package/dist/src/utils/status/applications.js.map +1 -0
- package/dist/src/utils/status/common.js +63 -0
- package/dist/src/utils/status/common.js.map +1 -0
- package/dist/src/utils/status/devices.js +65 -0
- package/dist/src/utils/status/devices.js.map +1 -0
- package/dist/src/utils/status/enrollmentRequest.js +49 -0
- package/dist/src/utils/status/enrollmentRequest.js.map +1 -0
- package/dist/src/utils/status/fleet.js +38 -0
- package/dist/src/utils/status/fleet.js.map +1 -0
- package/dist/src/utils/status/integrity.js +28 -0
- package/dist/src/utils/status/integrity.js.map +1 -0
- package/dist/src/utils/status/repository.js +88 -0
- package/dist/src/utils/status/repository.js.map +1 -0
- package/dist/src/utils/status/system.js +29 -0
- package/dist/src/utils/status/system.js.map +1 -0
- package/package.json +48 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const React = tslib_1.__importStar(require("react"));
|
|
5
|
+
const formik_1 = require("formik");
|
|
6
|
+
const react_core_1 = require("@patternfly/react-core");
|
|
7
|
+
const plus_circle_icon_1 = require("@patternfly/react-icons/dist/js/icons/plus-circle-icon");
|
|
8
|
+
const exclamation_circle_icon_1 = require("@patternfly/react-icons/dist/js/icons/exclamation-circle-icon");
|
|
9
|
+
const react_i18next_1 = require("react-i18next");
|
|
10
|
+
const types_1 = require("@flightctl/types");
|
|
11
|
+
const useTranslation_1 = require("../../../../hooks/useTranslation");
|
|
12
|
+
const TextField_1 = tslib_1.__importDefault(require("../../../form/TextField"));
|
|
13
|
+
const FormSelect_1 = tslib_1.__importDefault(require("../../../form/FormSelect"));
|
|
14
|
+
const CreateRepositoryModal_1 = tslib_1.__importDefault(require("../../../modals/CreateRepositoryModal/CreateRepositoryModal"));
|
|
15
|
+
const WithHelperText_1 = tslib_1.__importDefault(require("../../../common/WithHelperText"));
|
|
16
|
+
const getRepositoryItems = (t, repositories, repoType, forcedRepoName) => {
|
|
17
|
+
const repositoryItems = repositories.reduce((acc, curr) => {
|
|
18
|
+
if (curr.spec.type === repoType) {
|
|
19
|
+
acc[curr.metadata.name || ''] = {
|
|
20
|
+
label: curr.metadata.name,
|
|
21
|
+
description: curr.spec.url,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
return acc;
|
|
25
|
+
}, {});
|
|
26
|
+
// If there's a broken reference to a repository, we must add an item so the name shows in the dropdown
|
|
27
|
+
if (forcedRepoName && !repositoryItems[forcedRepoName]) {
|
|
28
|
+
repositoryItems[forcedRepoName] = {
|
|
29
|
+
label: forcedRepoName,
|
|
30
|
+
description: (React.createElement(React.Fragment, null,
|
|
31
|
+
React.createElement(react_core_1.Icon, { size: "sm", status: "danger" },
|
|
32
|
+
React.createElement(exclamation_circle_icon_1.ExclamationCircleIcon, null)),
|
|
33
|
+
' ',
|
|
34
|
+
t('Missing repository'))),
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
return repositoryItems;
|
|
38
|
+
};
|
|
39
|
+
const GitConfigForm = ({ template, index }) => {
|
|
40
|
+
const { t } = (0, useTranslation_1.useTranslation)();
|
|
41
|
+
return (React.createElement(React.Fragment, null,
|
|
42
|
+
React.createElement(react_core_1.FormGroup, { label: t('Branch/tag/commit'), isRequired: true },
|
|
43
|
+
React.createElement(TextField_1.default, { "aria-label": t('Branch/tag/commit'), name: `configTemplates[${index}].targetRevision`, value: template.targetRevision })),
|
|
44
|
+
React.createElement(react_core_1.FormGroup, { label: React.createElement(WithHelperText_1.default, { ariaLabel: t('Path'), content: t('Path in the repository where the configuration file(s) are located'), showLabel: true }), isRequired: true },
|
|
45
|
+
React.createElement(TextField_1.default, { "aria-label": t('Path'), name: `configTemplates[${index}].path`, value: template.path, placeholder: t('/absolute/path') })),
|
|
46
|
+
React.createElement(react_core_1.FormGroup, { isRequired: true, label: React.createElement(WithHelperText_1.default, { ariaLabel: t('Mount path'), content: t('Path in the device where the configurations will be stored'), showLabel: true }) },
|
|
47
|
+
React.createElement(TextField_1.default, { "aria-label": t('Mount path'), name: `configTemplates[${index}].mountPath`, value: template.mountPath, placeholder: t('/absolute/path') }))));
|
|
48
|
+
};
|
|
49
|
+
const HttpConfigForm = ({ template, baseURL, index, }) => {
|
|
50
|
+
const { t } = (0, useTranslation_1.useTranslation)();
|
|
51
|
+
let suffixHelperText;
|
|
52
|
+
if (baseURL) {
|
|
53
|
+
const fullURL = `${baseURL}${template.suffix || ''}`;
|
|
54
|
+
suffixHelperText = (React.createElement(react_i18next_1.Trans, { t: t },
|
|
55
|
+
"Full HTTP service URL: ",
|
|
56
|
+
React.createElement("strong", null, fullURL)));
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
suffixHelperText = t('Select a repository to generate the full URL');
|
|
60
|
+
}
|
|
61
|
+
return (React.createElement(React.Fragment, null,
|
|
62
|
+
React.createElement(react_core_1.FormGroup, { label: t('Suffix'), labelIcon: React.createElement(WithHelperText_1.default, { ariaLabel: t('Suffix'), content: t("Suffix that will be combined with the repository's base URL to invoke the HTTP service. Can include query parameters.") }) },
|
|
63
|
+
React.createElement(TextField_1.default, { "aria-label": t('Suffix'), name: `configTemplates[${index}].suffix`, value: template.suffix || '', helperText: suffixHelperText })),
|
|
64
|
+
React.createElement(react_core_1.FormGroup, { label: t('File path'), labelIcon: React.createElement(WithHelperText_1.default, { ariaLabel: t('File path'), content: t('Path of the file where the response will be stored in the device filesystem.') }), isRequired: true },
|
|
65
|
+
React.createElement(TextField_1.default, { "aria-label": t('File path'), name: `configTemplates[${index}].filePath`, value: template.filePath || '', placeholder: t('/absolute/path') }))));
|
|
66
|
+
};
|
|
67
|
+
const ConfigWithRepositoryTemplateForm = ({ repoType, index, repositories, repoRefetch, }) => {
|
|
68
|
+
const { t } = (0, useTranslation_1.useTranslation)();
|
|
69
|
+
const { values, setFieldValue } = (0, formik_1.useFormikContext)();
|
|
70
|
+
const [createRepoModalOpen, setCreateRepoModalOpen] = React.useState(false);
|
|
71
|
+
const ct = values.configTemplates[index];
|
|
72
|
+
const selectedRepoName = ct === null || ct === void 0 ? void 0 : ct.repository;
|
|
73
|
+
const repositoryItems = getRepositoryItems(t, repositories, repoType, selectedRepoName);
|
|
74
|
+
const selectedRepo = repositories.find((repo) => repo.metadata.name === selectedRepoName);
|
|
75
|
+
return (React.createElement(React.Fragment, null,
|
|
76
|
+
React.createElement(react_core_1.FormGroup, { label: t('Repository'), isRequired: true },
|
|
77
|
+
React.createElement(FormSelect_1.default, { name: `configTemplates[${index}].repository`, items: repositoryItems, placeholderText: t('Select a repository') },
|
|
78
|
+
React.createElement(react_core_1.MenuFooter, null,
|
|
79
|
+
React.createElement(react_core_1.Button, { variant: "link", isInline: true, icon: React.createElement(plus_circle_icon_1.PlusCircleIcon, null), onClick: () => {
|
|
80
|
+
setCreateRepoModalOpen(true);
|
|
81
|
+
} }, t('Create repository'))))),
|
|
82
|
+
repoType === types_1.RepoSpecType.GIT && React.createElement(GitConfigForm, { template: ct, index: index }),
|
|
83
|
+
repoType === types_1.RepoSpecType.HTTP && (React.createElement(HttpConfigForm, { template: ct, index: index, baseURL: selectedRepo === null || selectedRepo === void 0 ? void 0 : selectedRepo.spec.url })),
|
|
84
|
+
createRepoModalOpen && (React.createElement(CreateRepositoryModal_1.default, { onClose: () => setCreateRepoModalOpen(false), onSuccess: (repo) => {
|
|
85
|
+
setCreateRepoModalOpen(false);
|
|
86
|
+
repoRefetch();
|
|
87
|
+
void setFieldValue(`configTemplates[${index}].repository`, repo.metadata.name, true);
|
|
88
|
+
}, options: {
|
|
89
|
+
canUseResourceSyncs: false,
|
|
90
|
+
allowedRepoTypes: [repoType],
|
|
91
|
+
} }))));
|
|
92
|
+
};
|
|
93
|
+
exports.default = ConfigWithRepositoryTemplateForm;
|
|
94
|
+
//# sourceMappingURL=ConfigWithRepositoryTemplateForm.js.map
|
package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConfigWithRepositoryTemplateForm.js","sourceRoot":"","sources":["../../../../../../src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isDeviceTemplateStepValid = exports.deviceTemplateStepId = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const React = tslib_1.__importStar(require("react"));
|
|
6
|
+
const react_core_1 = require("@patternfly/react-core");
|
|
7
|
+
const formik_1 = require("formik");
|
|
8
|
+
const react_i18next_1 = require("react-i18next");
|
|
9
|
+
const useTranslation_1 = require("../../../../hooks/useTranslation");
|
|
10
|
+
const WithHelperText_1 = tslib_1.__importDefault(require("../../../common/WithHelperText"));
|
|
11
|
+
const TextField_1 = tslib_1.__importDefault(require("../../../form/TextField"));
|
|
12
|
+
const FlightCtlForm_1 = tslib_1.__importDefault(require("../../../form/FlightCtlForm"));
|
|
13
|
+
const ConfigTemplateForm_1 = tslib_1.__importDefault(require("./ConfigTemplateForm"));
|
|
14
|
+
exports.deviceTemplateStepId = 'device-template';
|
|
15
|
+
const isDeviceTemplateStepValid = (errors) => {
|
|
16
|
+
return !errors.osImage && !errors.configTemplates;
|
|
17
|
+
};
|
|
18
|
+
exports.isDeviceTemplateStepValid = isDeviceTemplateStepValid;
|
|
19
|
+
const templateOption1 = '{{ device.metadata.labels[key] }}';
|
|
20
|
+
const templateOption2 = '{{ device.metadata.name }}';
|
|
21
|
+
const exampleCode = `/device-configs/factory-floors/floor-{{ device.metadata.labels[factory-floor] }}`;
|
|
22
|
+
const DeviceTemplateStep = ({ isFleet }) => {
|
|
23
|
+
const { t } = (0, useTranslation_1.useTranslation)();
|
|
24
|
+
const { values } = (0, formik_1.useFormikContext)();
|
|
25
|
+
return (React.createElement(react_core_1.Grid, { span: 8 },
|
|
26
|
+
React.createElement(FlightCtlForm_1.default, null,
|
|
27
|
+
isFleet && (React.createElement(react_core_1.Alert, { isInline: true, variant: "info", title: t('Using template variables') },
|
|
28
|
+
React.createElement(react_core_1.ExpandableSection, { toggleTextCollapsed: t('Show more'), toggleTextExpanded: t('Show less') },
|
|
29
|
+
React.createElement(react_i18next_1.Trans, { t: t },
|
|
30
|
+
"Add a variable by using ",
|
|
31
|
+
React.createElement("strong", null, templateOption1),
|
|
32
|
+
" or ",
|
|
33
|
+
React.createElement("strong", null, templateOption2),
|
|
34
|
+
" and it will be applied based each device\u2019s details. For example, you could set the following value to apply different files in a Git configuration:"),
|
|
35
|
+
React.createElement(react_core_1.CodeBlock, { className: "pf-v5-u-mt-md" },
|
|
36
|
+
React.createElement(react_core_1.CodeBlockCode, null, exampleCode))))),
|
|
37
|
+
React.createElement(react_core_1.FormGroup, { label: React.createElement(WithHelperText_1.default, { ariaLabel: t('System image'), content: isFleet
|
|
38
|
+
? t("The target system image for this fleet's devices.")
|
|
39
|
+
: t('The target system image for this device.'), showLabel: true }) },
|
|
40
|
+
React.createElement(TextField_1.default, { name: "osImage", "aria-label": t('System image'), value: values.osImage, helperText: t('Must be either an OCI image ref (e.g. "quay.io/redhat/rhde:9.3") or ostree ref (e.g. "https://ostree.fedoraproject.org/iot?ref=fedora/stable/x86_64/iot"). Keep this empty if you do not want to manage your OS from Flight Control.') })),
|
|
41
|
+
React.createElement(react_core_1.FormGroup, null,
|
|
42
|
+
React.createElement(ConfigTemplateForm_1.default, null)))));
|
|
43
|
+
};
|
|
44
|
+
exports.default = DeviceTemplateStep;
|
|
45
|
+
//# sourceMappingURL=DeviceTemplateStep.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DeviceTemplateStep.js","sourceRoot":"","sources":["../../../../../../src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.tsx"],"names":[],"mappings":";;;;AAAA,qDAA+B;AAC/B,uDAA6G;AAC7G,mCAAwD;AACxD,iDAAsC;AAEtC,qEAAkE;AAClE,4FAA4D;AAC5D,gFAAgD;AAChD,wFAAwD;AAExD,sFAAsD;AAEzC,QAAA,oBAAoB,GAAG,iBAAiB,CAAC;AAE/C,MAAM,yBAAyB,GAAG,CAAC,MAAgD,EAAE,EAAE;IAC5F,OAAO,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC;AACpD,CAAC,CAAC;AAFW,QAAA,yBAAyB,6BAEpC;AAEF,MAAM,eAAe,GAAG,mCAAmC,CAAC;AAC5D,MAAM,eAAe,GAAG,4BAA4B,CAAC;AACrD,MAAM,WAAW,GAAG,kFAAkF,CAAC;AAEvG,MAAM,kBAAkB,GAAG,CAAC,EAAE,OAAO,EAAwB,EAAE,EAAE;IAC/D,MAAM,EAAE,CAAC,EAAE,GAAG,IAAA,+BAAc,GAAE,CAAC;IAC/B,MAAM,EAAE,MAAM,EAAE,GAAG,IAAA,yBAAgB,GAA8B,CAAC;IAElE,OAAO,CACL,oBAAC,iBAAI,IAAC,IAAI,EAAE,CAAC;QACX,oBAAC,uBAAa;YACX,OAAO,IAAI,CACV,oBAAC,kBAAK,IAAC,QAAQ,QAAC,OAAO,EAAC,MAAM,EAAC,KAAK,EAAE,CAAC,CAAC,0BAA0B,CAAC;gBACjE,oBAAC,8BAAiB,IAAC,mBAAmB,EAAE,CAAC,CAAC,WAAW,CAAC,EAAE,kBAAkB,EAAE,CAAC,CAAC,WAAW,CAAC;oBACxF,oBAAC,qBAAK,IAAC,CAAC,EAAE,CAAC;;wBACe,oCAAS,eAAe,CAAU;;wBAAI,oCAAS,eAAe,CAAU;oLAG1F;oBACR,oBAAC,sBAAS,IAAC,SAAS,EAAC,eAAe;wBAClC,oBAAC,0BAAa,QAAE,WAAW,CAAiB,CAClC,CACM,CACd,CACT;YACD,oBAAC,sBAAS,IACR,KAAK,EACH,oBAAC,wBAAc,IACb,SAAS,EAAE,CAAC,CAAC,cAAc,CAAC,EAC5B,OAAO,EACL,OAAO;wBACL,CAAC,CAAC,CAAC,CAAC,mDAAmD,CAAC;wBACxD,CAAC,CAAC,CAAC,CAAC,0CAA0C,CAAC,EAEnD,SAAS,SACT;gBAGJ,oBAAC,mBAAS,IACR,IAAI,EAAC,SAAS,gBACF,CAAC,CAAC,cAAc,CAAC,EAC7B,KAAK,EAAE,MAAM,CAAC,OAAO,EACrB,UAAU,EAAE,CAAC,CACX,sOAAsO,CACvO,GACD,CACQ;YACZ,oBAAC,sBAAS;gBACR,oBAAC,4BAAkB,OAAG,CACZ,CACE,CACX,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isGeneralInfoStepValid = exports.generalInfoStepId = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const React = tslib_1.__importStar(require("react"));
|
|
6
|
+
const react_core_1 = require("@patternfly/react-core");
|
|
7
|
+
const formik_1 = require("formik");
|
|
8
|
+
const useTranslation_1 = require("../../../../hooks/useTranslation");
|
|
9
|
+
const useDeviceLabelMatch_1 = tslib_1.__importDefault(require("../../../../hooks/useDeviceLabelMatch"));
|
|
10
|
+
const FlightCtlForm_1 = tslib_1.__importDefault(require("../../../form/FlightCtlForm"));
|
|
11
|
+
const LabelsField_1 = tslib_1.__importDefault(require("../../../form/LabelsField"));
|
|
12
|
+
const RichValidationTextField_1 = tslib_1.__importDefault(require("../../../form/RichValidationTextField"));
|
|
13
|
+
const validations_1 = require("../../../form/validations");
|
|
14
|
+
const DeviceLabelMatch_1 = tslib_1.__importDefault(require("../../../modals/ApproveDeviceModal/DeviceLabelMatch"));
|
|
15
|
+
exports.generalInfoStepId = 'general-info';
|
|
16
|
+
const isGeneralInfoStepValid = (errors) => {
|
|
17
|
+
return !errors.deviceAlias && !errors.labels;
|
|
18
|
+
};
|
|
19
|
+
exports.isGeneralInfoStepValid = isGeneralInfoStepValid;
|
|
20
|
+
const GeneralInfoStep = () => {
|
|
21
|
+
const { t } = (0, useTranslation_1.useTranslation)();
|
|
22
|
+
const [matchLabelsOnChange, matchStatus] = (0, useDeviceLabelMatch_1.default)();
|
|
23
|
+
const { values, setFieldValue } = (0, formik_1.useFormikContext)();
|
|
24
|
+
React.useEffect(() => {
|
|
25
|
+
if (matchStatus.status === 'checked--unique') {
|
|
26
|
+
setFieldValue('fleetMatch', matchStatus.detail); // set the name of the matched fleet
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
setFieldValue('fleetMatch', '');
|
|
30
|
+
}
|
|
31
|
+
}, [matchStatus, setFieldValue]);
|
|
32
|
+
// When users go back to the General info step, we trigger the fleet match check
|
|
33
|
+
React.useEffect(() => {
|
|
34
|
+
if (values.labels) {
|
|
35
|
+
matchLabelsOnChange(values.labels, false);
|
|
36
|
+
}
|
|
37
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
38
|
+
}, [matchLabelsOnChange]);
|
|
39
|
+
return (React.createElement(react_core_1.Grid, { lg: 5, span: 8 },
|
|
40
|
+
React.createElement(FlightCtlForm_1.default, null,
|
|
41
|
+
React.createElement(RichValidationTextField_1.default, { fieldName: "deviceAlias", "aria-label": t('Alias'), validations: (0, validations_1.getLabelValueValidations)(t) }),
|
|
42
|
+
React.createElement(react_core_1.FormGroup, { label: t('Device labels') },
|
|
43
|
+
React.createElement(LabelsField_1.default, { name: "labels", onChangeCallback: matchLabelsOnChange })),
|
|
44
|
+
React.createElement(react_core_1.FormGroup, { label: t('Fleet name') },
|
|
45
|
+
React.createElement(DeviceLabelMatch_1.default, { matchStatus: matchStatus })))));
|
|
46
|
+
};
|
|
47
|
+
exports.default = GeneralInfoStep;
|
|
48
|
+
//# sourceMappingURL=GeneralInfoStep.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GeneralInfoStep.js","sourceRoot":"","sources":["../../../../../../src/components/Device/EditDeviceWizard/steps/GeneralInfoStep.tsx"],"names":[],"mappings":";;;;AAAA,qDAA+B;AAC/B,uDAAyD;AACzD,mCAAwD;AAExD,qEAAkE;AAClE,wGAAwE;AACxE,wFAAwD;AACxD,oFAAoD;AACpD,4GAA4E;AAC5E,2DAAqE;AACrE,mHAAmF;AAGtE,QAAA,iBAAiB,GAAG,cAAc,CAAC;AAEzC,MAAM,sBAAsB,GAAG,CAAC,MAA0C,EAAE,EAAE;IACnF,OAAO,CAAC,MAAM,CAAC,WAAW,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;AAC/C,CAAC,CAAC;AAFW,QAAA,sBAAsB,0BAEjC;AAEF,MAAM,eAAe,GAAG,GAAG,EAAE;IAC3B,MAAM,EAAE,CAAC,EAAE,GAAG,IAAA,+BAAc,GAAE,CAAC;IAC/B,MAAM,CAAC,mBAAmB,EAAE,WAAW,CAAC,GAAG,IAAA,6BAAmB,GAAE,CAAC;IAEjE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,GAAG,IAAA,yBAAgB,GAAwB,CAAC;IAE3E,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,IAAI,WAAW,CAAC,MAAM,KAAK,iBAAiB,EAAE,CAAC;YAC7C,aAAa,CAAC,YAAY,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,oCAAoC;QACvF,CAAC;aAAM,CAAC;YACN,aAAa,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;QAClC,CAAC;IACH,CAAC,EAAE,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC,CAAC;IAEjC,gFAAgF;IAChF,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;YAClB,mBAAmB,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC5C,CAAC;QACD,uDAAuD;IACzD,CAAC,EAAE,CAAC,mBAAmB,CAAC,CAAC,CAAC;IAE1B,OAAO,CACL,oBAAC,iBAAI,IAAC,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC;QAClB,oBAAC,uBAAa;YACZ,oBAAC,iCAAuB,IACtB,SAAS,EAAC,aAAa,gBACX,CAAC,CAAC,OAAO,CAAC,EACtB,WAAW,EAAE,IAAA,sCAAwB,EAAC,CAAC,CAAC,GACxC;YACF,oBAAC,sBAAS,IAAC,KAAK,EAAE,CAAC,CAAC,eAAe,CAAC;gBAClC,oBAAC,qBAAW,IAAC,IAAI,EAAC,QAAQ,EAAC,gBAAgB,EAAE,mBAAmB,GAAI,CAC1D;YACZ,oBAAC,sBAAS,IAAC,KAAK,EAAE,CAAC,CAAC,YAAY,CAAC;gBAC/B,oBAAC,0BAAgB,IAAC,WAAW,EAAE,WAAW,GAAI,CACpC,CACE,CACX,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,eAAe,CAAC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.reviewDeviceStepId = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const React = tslib_1.__importStar(require("react"));
|
|
6
|
+
const formik_1 = require("formik");
|
|
7
|
+
const react_core_1 = require("@patternfly/react-core");
|
|
8
|
+
const useTranslation_1 = require("../../../../hooks/useTranslation");
|
|
9
|
+
const LabelsView_1 = tslib_1.__importDefault(require("../../../common/LabelsView"));
|
|
10
|
+
const labels_1 = require("../../../../utils/labels");
|
|
11
|
+
const devices_1 = require("../../../../utils/devices");
|
|
12
|
+
const error_1 = require("../../../../utils/error");
|
|
13
|
+
const RepositorySourceList_1 = tslib_1.__importDefault(require("../../../Repository/RepositoryDetails/RepositorySourceList"));
|
|
14
|
+
const deviceSpecUtils_1 = require("../deviceSpecUtils");
|
|
15
|
+
exports.reviewDeviceStepId = 'review-device';
|
|
16
|
+
const ReviewStep = ({ error }) => {
|
|
17
|
+
const { t } = (0, useTranslation_1.useTranslation)();
|
|
18
|
+
const { values } = (0, formik_1.useFormikContext)();
|
|
19
|
+
return (React.createElement(react_core_1.Stack, { hasGutter: true },
|
|
20
|
+
React.createElement(react_core_1.StackItem, { isFilled: true },
|
|
21
|
+
React.createElement(react_core_1.DescriptionList, { isHorizontal: true, horizontalTermWidthModifier: {
|
|
22
|
+
default: '25ch',
|
|
23
|
+
} },
|
|
24
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
25
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('Alias')),
|
|
26
|
+
React.createElement(react_core_1.DescriptionListDescription, null, values.deviceAlias || t('Untitled'))),
|
|
27
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
28
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('Device labels')),
|
|
29
|
+
React.createElement(react_core_1.DescriptionListDescription, null,
|
|
30
|
+
React.createElement(LabelsView_1.default, { prefix: "device", labels: (0, labels_1.toAPILabel)(values.labels) }))),
|
|
31
|
+
values.fleetMatch && (React.createElement(react_core_1.DescriptionListGroup, null,
|
|
32
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('Device fleet')),
|
|
33
|
+
React.createElement(react_core_1.DescriptionListDescription, null, values.fleetMatch))),
|
|
34
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
35
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('System image')),
|
|
36
|
+
React.createElement(react_core_1.DescriptionListDescription, null, values.osImage || t(`Device management service will not manage system image`))),
|
|
37
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
38
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('Configurations/applications')),
|
|
39
|
+
React.createElement(react_core_1.DescriptionListDescription, null,
|
|
40
|
+
React.createElement(RepositorySourceList_1.default, { sourceItems: (0, devices_1.getSourceItems)(values.configTemplates.map(deviceSpecUtils_1.getAPIConfig)) }))))),
|
|
41
|
+
!!error && (React.createElement(react_core_1.StackItem, null,
|
|
42
|
+
React.createElement(react_core_1.Alert, { isInline: true, variant: "danger", title: t('An error occurred') }, (0, error_1.getErrorMessage)(error))))));
|
|
43
|
+
};
|
|
44
|
+
exports.default = ReviewStep;
|
|
45
|
+
//# sourceMappingURL=ReviewDeviceStep.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReviewDeviceStep.js","sourceRoot":"","sources":["../../../../../../src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.tsx"],"names":[],"mappings":";;;;AAAA,qDAA+B;AAC/B,mCAA0C;AAC1C,uDAQgC;AAGhC,qEAAkE;AAClE,oFAAoD;AACpD,qDAAsD;AACtD,uDAA2D;AAC3D,mDAA0D;AAC1D,8HAA8F;AAC9F,wDAAkD;AAErC,QAAA,kBAAkB,GAAG,eAAe,CAAC;AAElD,MAAM,UAAU,GAAG,CAAC,EAAE,KAAK,EAAsB,EAAE,EAAE;IACnD,MAAM,EAAE,CAAC,EAAE,GAAG,IAAA,+BAAc,GAAE,CAAC;IAC/B,MAAM,EAAE,MAAM,EAAE,GAAG,IAAA,yBAAgB,GAAwB,CAAC;IAC5D,OAAO,CACL,oBAAC,kBAAK,IAAC,SAAS;QACd,oBAAC,sBAAS,IAAC,QAAQ;YACjB,oBAAC,4BAAe,IACd,YAAY,QACZ,2BAA2B,EAAE;oBAC3B,OAAO,EAAE,MAAM;iBAChB;gBAED,oBAAC,iCAAoB;oBACnB,oBAAC,gCAAmB,QAAE,CAAC,CAAC,OAAO,CAAC,CAAuB;oBACvD,oBAAC,uCAA0B,QAAE,MAAM,CAAC,WAAW,IAAI,CAAC,CAAC,UAAU,CAAC,CAA8B,CACzE;gBACvB,oBAAC,iCAAoB;oBACnB,oBAAC,gCAAmB,QAAE,CAAC,CAAC,eAAe,CAAC,CAAuB;oBAC/D,oBAAC,uCAA0B;wBACzB,oBAAC,oBAAU,IAAC,MAAM,EAAC,QAAQ,EAAC,MAAM,EAAE,IAAA,mBAAU,EAAC,MAAM,CAAC,MAAM,CAAC,GAAI,CACtC,CACR;gBACtB,MAAM,CAAC,UAAU,IAAI,CACpB,oBAAC,iCAAoB;oBACnB,oBAAC,gCAAmB,QAAE,CAAC,CAAC,cAAc,CAAC,CAAuB;oBAC9D,oBAAC,uCAA0B,QAAE,MAAM,CAAC,UAAU,CAA8B,CACvD,CACxB;gBACD,oBAAC,iCAAoB;oBACnB,oBAAC,gCAAmB,QAAE,CAAC,CAAC,cAAc,CAAC,CAAuB;oBAC9D,oBAAC,uCAA0B,QACxB,MAAM,CAAC,OAAO,IAAI,CAAC,CAAC,wDAAwD,CAAC,CACnD,CACR;gBACvB,oBAAC,iCAAoB;oBACnB,oBAAC,gCAAmB,QAAE,CAAC,CAAC,6BAA6B,CAAC,CAAuB;oBAC7E,oBAAC,uCAA0B;wBACzB,oBAAC,8BAAoB,IAAC,WAAW,EAAE,IAAA,wBAAc,EAAC,MAAM,CAAC,eAAe,CAAC,GAAG,CAAC,8BAAY,CAAC,CAAC,GAAI,CACpE,CACR,CACP,CACR;QACX,CAAC,CAAC,KAAK,IAAI,CACV,oBAAC,sBAAS;YACR,oBAAC,kBAAK,IAAC,QAAQ,QAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAE,CAAC,CAAC,mBAAmB,CAAC,IAC3D,IAAA,uBAAe,EAAC,KAAK,CAAC,CACjB,CACE,CACb,CACK,CACT,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,UAAU,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/components/Device/EditDeviceWizard/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useEditDevice = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const React = tslib_1.__importStar(require("react"));
|
|
6
|
+
const useAppContext_1 = require("../../../hooks/useAppContext");
|
|
7
|
+
const useFetch_1 = require("../../../hooks/useFetch");
|
|
8
|
+
const useEditDevice = () => {
|
|
9
|
+
const { router: { useParams }, } = (0, useAppContext_1.useAppContext)();
|
|
10
|
+
const { deviceId } = useParams();
|
|
11
|
+
const { get } = (0, useFetch_1.useFetch)();
|
|
12
|
+
const [device, setDevice] = React.useState();
|
|
13
|
+
const [isLoading, setIsLoading] = React.useState(!!deviceId);
|
|
14
|
+
const [error, setError] = React.useState();
|
|
15
|
+
React.useEffect(() => {
|
|
16
|
+
const fetch = () => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
|
|
17
|
+
try {
|
|
18
|
+
const result = yield get(`devices/${deviceId}`);
|
|
19
|
+
setDevice(result);
|
|
20
|
+
}
|
|
21
|
+
catch (err) {
|
|
22
|
+
setError(err);
|
|
23
|
+
}
|
|
24
|
+
finally {
|
|
25
|
+
setIsLoading(false);
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
if (deviceId && !device) {
|
|
29
|
+
fetch();
|
|
30
|
+
}
|
|
31
|
+
}, [deviceId, get, device]);
|
|
32
|
+
return [deviceId, device, isLoading, error];
|
|
33
|
+
};
|
|
34
|
+
exports.useEditDevice = useEditDevice;
|
|
35
|
+
//# sourceMappingURL=useEditDevice.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useEditDevice.js","sourceRoot":"","sources":["../../../../../src/components/Device/EditDeviceWizard/useEditDevice.ts"],"names":[],"mappings":";;;;AAAA,qDAA+B;AAE/B,gEAA6D;AAC7D,sDAAmD;AAE5C,MAAM,aAAa,GAAG,GAA+D,EAAE;IAC5F,MAAM,EACJ,MAAM,EAAE,EAAE,SAAS,EAAE,GACtB,GAAG,IAAA,6BAAa,GAAE,CAAC;IACpB,MAAM,EAAE,QAAQ,EAAE,GAAG,SAAS,EAAwB,CAAC;IAEvD,MAAM,EAAE,GAAG,EAAE,GAAG,IAAA,mBAAQ,GAAE,CAAC;IAC3B,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;IACrD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAU,CAAC,CAAC,QAAQ,CAAC,CAAC;IACtE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAW,CAAC;IAEpD,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,MAAM,KAAK,GAAG,GAAS,EAAE;YACvB,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,GAAG,CAAS,WAAW,QAAQ,EAAE,CAAC,CAAC;gBAExD,SAAS,CAAC,MAAM,CAAC,CAAC;YACpB,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,QAAQ,CAAC,GAAG,CAAC,CAAC;YAChB,CAAC;oBAAS,CAAC;gBACT,YAAY,CAAC,KAAK,CAAC,CAAC;YACtB,CAAC;QACH,CAAC,CAAA,CAAC;QAEF,IAAI,QAAQ,IAAI,CAAC,MAAM,EAAE,CAAC;YACxB,KAAK,EAAE,CAAC;QACV,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC;IAE5B,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC,CAAC;AA9BW,QAAA,aAAa,iBA8BxB"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getDevicePatches = exports.getValidationSchema = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const Yup = tslib_1.__importStar(require("yup"));
|
|
6
|
+
const validations_1 = require("../../form/validations");
|
|
7
|
+
const patch_1 = require("../../../utils/patch");
|
|
8
|
+
const deviceSpecUtils_1 = require("./deviceSpecUtils");
|
|
9
|
+
const getValidationSchema = (t) => Yup.lazy(() => Yup.object({
|
|
10
|
+
deviceAlias: (0, validations_1.validKubernetesLabelValue)(t, { isRequired: false, fieldName: t('Alias') }),
|
|
11
|
+
osImage: (0, validations_1.maxLengthString)(t, { fieldName: t('System image'), maxLength: 2048 }),
|
|
12
|
+
labels: (0, validations_1.validLabelsSchema)(t),
|
|
13
|
+
configTemplates: (0, validations_1.validConfigTemplatesSchema)(t),
|
|
14
|
+
}));
|
|
15
|
+
exports.getValidationSchema = getValidationSchema;
|
|
16
|
+
const getDevicePatches = (currentDevice, updatedDevice) => {
|
|
17
|
+
var _a, _b, _c;
|
|
18
|
+
let allPatches = [];
|
|
19
|
+
// Device labels
|
|
20
|
+
const currentLabels = currentDevice.metadata.labels || {};
|
|
21
|
+
const updatedLabels = updatedDevice.labels || [];
|
|
22
|
+
if (updatedDevice.deviceAlias) {
|
|
23
|
+
updatedLabels.push({ key: 'alias', value: updatedDevice.deviceAlias });
|
|
24
|
+
}
|
|
25
|
+
const deviceLabelPatches = (0, patch_1.getLabelPatches)('/metadata/labels', currentLabels, updatedLabels);
|
|
26
|
+
allPatches = allPatches.concat(deviceLabelPatches);
|
|
27
|
+
if (updatedDevice.fleetMatch) {
|
|
28
|
+
// The change in device labels makes the device bound to a fleet. Only the labels can be updated.
|
|
29
|
+
return allPatches;
|
|
30
|
+
}
|
|
31
|
+
// OS image
|
|
32
|
+
const currentOsImage = (_b = (_a = currentDevice.spec) === null || _a === void 0 ? void 0 : _a.os) === null || _b === void 0 ? void 0 : _b.image;
|
|
33
|
+
const newOsImage = updatedDevice.osImage;
|
|
34
|
+
if (!currentOsImage && newOsImage) {
|
|
35
|
+
allPatches.push({
|
|
36
|
+
path: '/spec/os',
|
|
37
|
+
op: 'add',
|
|
38
|
+
value: { image: newOsImage },
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
else if (!newOsImage && currentOsImage) {
|
|
42
|
+
allPatches.push({
|
|
43
|
+
path: '/spec/os',
|
|
44
|
+
op: 'remove',
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
else if (newOsImage && currentOsImage !== newOsImage) {
|
|
48
|
+
(0, patch_1.appendJSONPatch)({
|
|
49
|
+
path: '/spec/os/image',
|
|
50
|
+
patches: allPatches,
|
|
51
|
+
newValue: newOsImage,
|
|
52
|
+
originalValue: currentOsImage,
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
// Configurations
|
|
56
|
+
const currentConfigs = ((_c = currentDevice.spec) === null || _c === void 0 ? void 0 : _c.config) || [];
|
|
57
|
+
const newConfigs = updatedDevice.configTemplates.map(deviceSpecUtils_1.getAPIConfig);
|
|
58
|
+
const configPatches = (0, deviceSpecUtils_1.getDeviceSpecConfigPatches)(currentConfigs, newConfigs, '/spec/config');
|
|
59
|
+
if (configPatches.length > 0) {
|
|
60
|
+
return allPatches.concat(configPatches);
|
|
61
|
+
}
|
|
62
|
+
return allPatches;
|
|
63
|
+
};
|
|
64
|
+
exports.getDevicePatches = getDevicePatches;
|
|
65
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../src/components/Device/EditDeviceWizard/utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const React = tslib_1.__importStar(require("react"));
|
|
5
|
+
const react_core_1 = require("@patternfly/react-core");
|
|
6
|
+
const formik_1 = require("formik");
|
|
7
|
+
const FieldHelperText_1 = tslib_1.__importDefault(require("../../form/FieldHelperText"));
|
|
8
|
+
const FlightCtlActionGroup_1 = tslib_1.__importDefault(require("../../form/FlightCtlActionGroup"));
|
|
9
|
+
const FlightCtlForm_1 = tslib_1.__importDefault(require("../../form/FlightCtlForm"));
|
|
10
|
+
const useTranslation_1 = require("../../../hooks/useTranslation");
|
|
11
|
+
const EditableLabelControl_1 = tslib_1.__importDefault(require("../../common/EditableLabelControl"));
|
|
12
|
+
const MatchPatternsForm = ({ onClose, error }) => {
|
|
13
|
+
const { t } = (0, useTranslation_1.useTranslation)();
|
|
14
|
+
const { values, setFieldValue, submitForm, isSubmitting, errors: formErrors, } = (0, formik_1.useFormikContext)();
|
|
15
|
+
const onPatternClose = (e, index) => {
|
|
16
|
+
const newMatchPatterns = [...values.matchPatterns];
|
|
17
|
+
newMatchPatterns.splice(index, 1);
|
|
18
|
+
void setFieldValue('matchPatterns', newMatchPatterns);
|
|
19
|
+
};
|
|
20
|
+
const onAdd = (text) => {
|
|
21
|
+
const newMatchPatterns = [...values.matchPatterns, text];
|
|
22
|
+
void setFieldValue('matchPatterns', newMatchPatterns);
|
|
23
|
+
};
|
|
24
|
+
const onEdit = (index, nextText) => {
|
|
25
|
+
const newMatchPatterns = [...values.matchPatterns];
|
|
26
|
+
newMatchPatterns.splice(index, 1, nextText);
|
|
27
|
+
void setFieldValue('matchPatterns', newMatchPatterns);
|
|
28
|
+
};
|
|
29
|
+
const hasFormErrors = !!formErrors.matchPatterns;
|
|
30
|
+
return (React.createElement(FlightCtlForm_1.default, null,
|
|
31
|
+
React.createElement(react_core_1.LabelGroup, { isEditable: true, addLabelControl: React.createElement(EditableLabelControl_1.default, { defaultLabel: "name.service", addButtonText: t('Add match pattern'), onAddLabel: onAdd }), numLabels: 20, defaultIsOpen: true }, values.matchPatterns.map((pattern, index) => (React.createElement(react_core_1.Label, { key: index, id: `${index}`, onClose: (e) => onPatternClose(e, index), onEditCancel: (_, prevText) => onEdit(index, prevText), onEditComplete: (_, newText) => onEdit(index, newText), isEditable: true }, pattern)))),
|
|
32
|
+
React.createElement(FieldHelperText_1.default, { error: formErrors.matchPatterns }),
|
|
33
|
+
error && React.createElement(react_core_1.Alert, { isInline: true, title: error, variant: "danger" }),
|
|
34
|
+
React.createElement(FlightCtlActionGroup_1.default, null,
|
|
35
|
+
React.createElement(react_core_1.Button, { key: "confirm", variant: "primary", onClick: submitForm, isDisabled: isSubmitting || hasFormErrors, isLoading: isSubmitting }, t('Update match patterns')),
|
|
36
|
+
React.createElement(react_core_1.Button, { key: "cancel", variant: "link", onClick: () => onClose(), isDisabled: isSubmitting }, t('Cancel')))));
|
|
37
|
+
};
|
|
38
|
+
exports.default = MatchPatternsForm;
|
|
39
|
+
//# sourceMappingURL=MatchPatternsForm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MatchPatternsForm.js","sourceRoot":"","sources":["../../../../../src/components/Device/MatchPatternsModal/MatchPatternsForm.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const react_core_1 = require("@patternfly/react-core");
|
|
5
|
+
const formik_1 = require("formik");
|
|
6
|
+
const React = tslib_1.__importStar(require("react"));
|
|
7
|
+
const MatchPatternsForm_1 = tslib_1.__importDefault(require("./MatchPatternsForm"));
|
|
8
|
+
const useFetch_1 = require("../../../hooks/useFetch");
|
|
9
|
+
const error_1 = require("../../../utils/error");
|
|
10
|
+
const patch_1 = require("../../../utils/patch");
|
|
11
|
+
const useTranslation_1 = require("../../../hooks/useTranslation");
|
|
12
|
+
const validations_1 = require("../../form/validations");
|
|
13
|
+
/**
|
|
14
|
+
* Modal for editing the Systemd units matchPatterns of a Device.
|
|
15
|
+
* This operation is only supported for devices that are NOT bound to fleets, in which case
|
|
16
|
+
* the systemd units definition are defined in the `device.spec` itself, not via a templateVersion.
|
|
17
|
+
|
|
18
|
+
* @param device FlightCtl device
|
|
19
|
+
* @param onClose on close callback
|
|
20
|
+
*/
|
|
21
|
+
const MatchPatternsModal = ({ onClose, device }) => {
|
|
22
|
+
var _a, _b;
|
|
23
|
+
const { t } = (0, useTranslation_1.useTranslation)();
|
|
24
|
+
const { patch } = (0, useFetch_1.useFetch)();
|
|
25
|
+
const [error, setError] = React.useState();
|
|
26
|
+
const currentPatterns = ((_b = (_a = device.spec) === null || _a === void 0 ? void 0 : _a.systemd) === null || _b === void 0 ? void 0 : _b.matchPatterns) || [];
|
|
27
|
+
return (React.createElement(react_core_1.Modal, { title: t('Edit match patterns'), isOpen: true, onClose: () => onClose(), variant: "small" },
|
|
28
|
+
React.createElement(formik_1.Formik, { validationSchema: (0, validations_1.deviceSystemdUnitsValidationSchema)(t), initialValues: { matchPatterns: currentPatterns }, onSubmit: ({ matchPatterns: updatedPatterns }) => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
|
|
29
|
+
try {
|
|
30
|
+
const patternPatchBuilder = (value) => ({
|
|
31
|
+
matchPatterns: value,
|
|
32
|
+
});
|
|
33
|
+
const patches = (0, patch_1.getStringListPatches)('/spec/systemd', currentPatterns, updatedPatterns, patternPatchBuilder);
|
|
34
|
+
if (patches.length > 0) {
|
|
35
|
+
yield patch(`devices/${device.metadata.name}`, patches);
|
|
36
|
+
}
|
|
37
|
+
onClose(true);
|
|
38
|
+
}
|
|
39
|
+
catch (err) {
|
|
40
|
+
setError((0, error_1.getErrorMessage)(err));
|
|
41
|
+
}
|
|
42
|
+
}) },
|
|
43
|
+
React.createElement(MatchPatternsForm_1.default, { onClose: onClose, error: error }))));
|
|
44
|
+
};
|
|
45
|
+
exports.default = MatchPatternsModal;
|
|
46
|
+
//# sourceMappingURL=MatchPatternsModal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MatchPatternsModal.js","sourceRoot":"","sources":["../../../../../src/components/Device/MatchPatternsModal/MatchPatternsModal.tsx"],"names":[],"mappings":";;;AAAA,uDAA+C;AAE/C,mCAAgC;AAChC,qDAA+B;AAC/B,oFAAiF;AACjF,sDAAmD;AACnD,gDAAuD;AACvD,gDAA4D;AAC5D,kEAA+D;AAC/D,wDAA4E;AAO5E;;;;;;;GAOG;AACH,MAAM,kBAAkB,GAAsC,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE;;IACpF,MAAM,EAAE,CAAC,EAAE,GAAG,IAAA,+BAAc,GAAE,CAAC;IAC/B,MAAM,EAAE,KAAK,EAAE,GAAG,IAAA,mBAAQ,GAAE,CAAC;IAC7B,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;IAEnD,MAAM,eAAe,GAAG,CAAA,MAAA,MAAA,MAAM,CAAC,IAAI,0CAAE,OAAO,0CAAE,aAAa,KAAI,EAAE,CAAC;IAClE,OAAO,CACL,oBAAC,kBAAK,IAAC,KAAK,EAAE,CAAC,CAAC,qBAAqB,CAAC,EAAE,MAAM,QAAC,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,EAAE,OAAO,EAAC,OAAO;QACtF,oBAAC,eAAM,IACL,gBAAgB,EAAE,IAAA,gDAAkC,EAAC,CAAC,CAAC,EACvD,aAAa,EAAE,EAAE,aAAa,EAAE,eAAe,EAAE,EACjD,QAAQ,EAAE,CAAO,EAAE,aAAa,EAAE,eAAe,EAAE,EAAE,EAAE;gBACrD,IAAI,CAAC;oBACH,MAAM,mBAAmB,GAAG,CAAC,KAAe,EAAE,EAAE,CAAC,CAAC;wBAChD,aAAa,EAAE,KAAK;qBACrB,CAAC,CAAC;oBACH,MAAM,OAAO,GAAG,IAAA,4BAAoB,EAClC,eAAe,EACf,eAAe,EACf,eAAe,EACf,mBAAmB,CACpB,CAAC;oBACF,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;wBACvB,MAAM,KAAK,CAAC,WAAW,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,OAAO,CAAC,CAAC;oBAC1D,CAAC;oBACD,OAAO,CAAC,IAAI,CAAC,CAAC;gBAChB,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,QAAQ,CAAC,IAAA,uBAAe,EAAC,GAAG,CAAC,CAAC,CAAC;gBACjC,CAAC;YACH,CAAC,CAAA;YAED,oBAAC,2BAAiB,IAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,GAAI,CAC9C,CACH,CACT,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,kBAAkB,CAAC"}
|
package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.js
ADDED
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const ConditionsTable_1 = tslib_1.__importDefault(require("../../DetailsPage/Tables/ConditionsTable"));
|
|
5
|
+
const DetailsPage_1 = tslib_1.__importDefault(require("../../DetailsPage/DetailsPage"));
|
|
6
|
+
const IntegrityDetails_1 = tslib_1.__importDefault(require("../../DetailsPage/Tables/IntegrityDetails"));
|
|
7
|
+
const LabelsView_1 = tslib_1.__importDefault(require("../../common/LabelsView"));
|
|
8
|
+
const useFetchPeriodically_1 = require("../../../hooks/useFetchPeriodically");
|
|
9
|
+
const dates_1 = require("../../../utils/dates");
|
|
10
|
+
const enrollmentRequest_1 = require("../../../utils/status/enrollmentRequest");
|
|
11
|
+
const react_core_1 = require("@patternfly/react-core");
|
|
12
|
+
const React = tslib_1.__importStar(require("react"));
|
|
13
|
+
const useFetch_1 = require("../../../hooks/useFetch");
|
|
14
|
+
const ApproveDeviceModal_1 = tslib_1.__importDefault(require("../../modals/ApproveDeviceModal/ApproveDeviceModal"));
|
|
15
|
+
const DetailsPageCard_1 = tslib_1.__importStar(require("../../DetailsPage/DetailsPageCard"));
|
|
16
|
+
const DetailsPageActions_1 = tslib_1.__importStar(require("../../DetailsPage/DetailsPageActions"));
|
|
17
|
+
const EnrollmentRequestStatus_1 = tslib_1.__importDefault(require("../../Status/EnrollmentRequestStatus"));
|
|
18
|
+
const WithHelperText_1 = tslib_1.__importDefault(require("../../common/WithHelperText"));
|
|
19
|
+
const useTranslation_1 = require("../../../hooks/useTranslation");
|
|
20
|
+
const useNavigate_1 = require("../../../hooks/useNavigate");
|
|
21
|
+
const useAppContext_1 = require("../../../hooks/useAppContext");
|
|
22
|
+
require("./EnrollmentRequestDetails.css");
|
|
23
|
+
const EnrollmentRequestDetails = () => {
|
|
24
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
25
|
+
const { t } = (0, useTranslation_1.useTranslation)();
|
|
26
|
+
const { router: { useParams }, } = (0, useAppContext_1.useAppContext)();
|
|
27
|
+
const { enrollmentRequestId } = useParams();
|
|
28
|
+
const [er, loading, error, refetch] = (0, useFetchPeriodically_1.useFetchPeriodically)({
|
|
29
|
+
endpoint: `enrollmentrequests/${enrollmentRequestId}`,
|
|
30
|
+
});
|
|
31
|
+
const { remove } = (0, useFetch_1.useFetch)();
|
|
32
|
+
const navigate = (0, useNavigate_1.useNavigate)();
|
|
33
|
+
const [isApprovalModalOpen, setIsApprovalModalOpen] = React.useState(false);
|
|
34
|
+
const { deleteAction, deleteModal } = (0, DetailsPageActions_1.useDeleteAction)({
|
|
35
|
+
resourceName: enrollmentRequestId,
|
|
36
|
+
resourceType: 'Enrollment request',
|
|
37
|
+
onDelete: () => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
|
|
38
|
+
yield remove(`enrollmentrequests/${enrollmentRequestId}`);
|
|
39
|
+
navigate(useNavigate_1.ROUTE.DEVICES);
|
|
40
|
+
}),
|
|
41
|
+
});
|
|
42
|
+
const approvalStatus = er ? (0, enrollmentRequest_1.getApprovalStatus)(er) : '-';
|
|
43
|
+
const isPendingApproval = approvalStatus === enrollmentRequest_1.EnrollmentRequestStatus.Pending;
|
|
44
|
+
return (React.createElement(DetailsPage_1.default, { loading: loading, error: error, id: er === null || er === void 0 ? void 0 : er.metadata.name, resourceLink: useNavigate_1.ROUTE.DEVICES, resourceType: "Devices", resourceTypeLabel: t('Devices'), actions: React.createElement(DetailsPageActions_1.default, null,
|
|
45
|
+
React.createElement(react_core_1.DropdownList, null,
|
|
46
|
+
React.createElement(react_core_1.DropdownItem, { onClick: () => setIsApprovalModalOpen(true), isDisabled: !isPendingApproval }, t('Approve')),
|
|
47
|
+
deleteAction)) },
|
|
48
|
+
React.createElement(react_core_1.Grid, { hasGutter: true },
|
|
49
|
+
React.createElement(react_core_1.GridItem, { md: 12 },
|
|
50
|
+
React.createElement(react_core_1.Card, null,
|
|
51
|
+
React.createElement(react_core_1.CardTitle, null, t('Details')),
|
|
52
|
+
React.createElement(react_core_1.CardBody, null,
|
|
53
|
+
React.createElement(react_core_1.DescriptionList, { columnModifier: { lg: '3Col' } },
|
|
54
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
55
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('Name')),
|
|
56
|
+
React.createElement(react_core_1.DescriptionListDescription, null, (er === null || er === void 0 ? void 0 : er.metadata.name) || '-')),
|
|
57
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
58
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('Last seen')),
|
|
59
|
+
React.createElement(react_core_1.DescriptionListDescription, null, (0, dates_1.timeSinceText)(t, er === null || er === void 0 ? void 0 : er.metadata.creationTimestamp))),
|
|
60
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
61
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('OS')),
|
|
62
|
+
React.createElement(react_core_1.DescriptionListDescription, null, ((_c = (_b = (_a = er === null || er === void 0 ? void 0 : er.spec) === null || _a === void 0 ? void 0 : _a.deviceStatus) === null || _b === void 0 ? void 0 : _b.systemInfo) === null || _c === void 0 ? void 0 : _c.operatingSystem) || '-')),
|
|
63
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
64
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('Architecture')),
|
|
65
|
+
React.createElement(react_core_1.DescriptionListDescription, null, ((_f = (_e = (_d = er === null || er === void 0 ? void 0 : er.spec) === null || _d === void 0 ? void 0 : _d.deviceStatus) === null || _e === void 0 ? void 0 : _e.systemInfo) === null || _f === void 0 ? void 0 : _f.architecture) || '-')),
|
|
66
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
67
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('Labels')),
|
|
68
|
+
React.createElement(react_core_1.DescriptionListDescription, null,
|
|
69
|
+
React.createElement(LabelsView_1.default, { prefix: "er", labels: er === null || er === void 0 ? void 0 : er.metadata.labels }))),
|
|
70
|
+
React.createElement(react_core_1.DescriptionListGroup, null,
|
|
71
|
+
React.createElement(react_core_1.DescriptionListTerm, null, t('Status')),
|
|
72
|
+
React.createElement(react_core_1.DescriptionListDescription, null,
|
|
73
|
+
React.createElement(EnrollmentRequestStatus_1.default, { er: er }))))))),
|
|
74
|
+
React.createElement(react_core_1.GridItem, { md: 6 },
|
|
75
|
+
React.createElement(DetailsPageCard_1.default, null,
|
|
76
|
+
React.createElement(react_core_1.CardTitle, null,
|
|
77
|
+
React.createElement(WithHelperText_1.default, { showLabel: true, ariaLabel: t('Certificate signing request'), content: t('A PEM-encoded PKCS#10 certificate signing request.') })),
|
|
78
|
+
React.createElement(DetailsPageCard_1.DetailsPageCardBody, null, (er === null || er === void 0 ? void 0 : er.spec.csr) ? (React.createElement(react_core_1.TextArea, { "aria-label": t('Certificate Signing Request'), value: er.spec.csr, readOnlyVariant: "plain", autoResize: true, className: "fctl-enrollment-details__text-area" })) : (React.createElement(react_core_1.Bullseye, null, t('Not available')))))),
|
|
79
|
+
React.createElement(react_core_1.GridItem, { md: 6 },
|
|
80
|
+
React.createElement(DetailsPageCard_1.default, null,
|
|
81
|
+
React.createElement(react_core_1.CardTitle, null,
|
|
82
|
+
React.createElement(WithHelperText_1.default, { showLabel: true, ariaLabel: t('Certificate'), content: t('A PEM-encoded signed certificate.') })),
|
|
83
|
+
React.createElement(DetailsPageCard_1.DetailsPageCardBody, null, ((_g = er === null || er === void 0 ? void 0 : er.status) === null || _g === void 0 ? void 0 : _g.certificate) ? (React.createElement(react_core_1.TextArea, { "aria-label": t('Certificate'), value: er.status.certificate, readOnlyVariant: "plain", autoResize: true, className: "fctl-enrollment-details__text-area" })) : (React.createElement(react_core_1.Bullseye, null, t('Not available')))))),
|
|
84
|
+
React.createElement(react_core_1.GridItem, { md: 6 },
|
|
85
|
+
React.createElement(DetailsPageCard_1.default, null,
|
|
86
|
+
React.createElement(react_core_1.CardTitle, null, t('Conditions')),
|
|
87
|
+
React.createElement(DetailsPageCard_1.DetailsPageCardBody, null, er && (React.createElement(ConditionsTable_1.default, { ariaLabel: t('Enrollment request conditions table'), conditions: (_h = er.status) === null || _h === void 0 ? void 0 : _h.conditions }))))),
|
|
88
|
+
!isPendingApproval && (React.createElement(react_core_1.GridItem, { md: 6 },
|
|
89
|
+
React.createElement(DetailsPageCard_1.default, null,
|
|
90
|
+
React.createElement(react_core_1.CardTitle, null, t('Device conditions')),
|
|
91
|
+
React.createElement(DetailsPageCard_1.DetailsPageCardBody, null, er && (React.createElement(ConditionsTable_1.default, { ariaLabel: t('Device conditions table'), conditions: (_j = er.spec.deviceStatus) === null || _j === void 0 ? void 0 : _j.conditions })))))),
|
|
92
|
+
!isPendingApproval && (React.createElement(react_core_1.GridItem, { md: 6 },
|
|
93
|
+
React.createElement(DetailsPageCard_1.default, null,
|
|
94
|
+
React.createElement(react_core_1.CardTitle, null, t('System integrity details')),
|
|
95
|
+
React.createElement(DetailsPageCard_1.DetailsPageCardBody, null, er && React.createElement(IntegrityDetails_1.default, { integrity: (_k = er.spec.deviceStatus) === null || _k === void 0 ? void 0 : _k.integrity })))))),
|
|
96
|
+
er && isApprovalModalOpen && (React.createElement(ApproveDeviceModal_1.default, { enrollmentRequest: er, onClose: (updateList) => {
|
|
97
|
+
setIsApprovalModalOpen(false);
|
|
98
|
+
updateList && refetch();
|
|
99
|
+
} })),
|
|
100
|
+
deleteModal));
|
|
101
|
+
};
|
|
102
|
+
exports.default = EnrollmentRequestDetails;
|
|
103
|
+
//# sourceMappingURL=EnrollmentRequestDetails.js.map
|