@flightctl/ui-components 0.0.10 → 0.4.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.
Files changed (452) hide show
  1. package/dist/src/components/DetailsPage/Tables/ApplicationsTable.css +7 -0
  2. package/dist/src/components/DetailsPage/Tables/ApplicationsTable.d.ts +8 -1
  3. package/dist/src/components/DetailsPage/Tables/ApplicationsTable.d.ts.map +1 -1
  4. package/dist/src/components/DetailsPage/Tables/ApplicationsTable.js +91 -9
  5. package/dist/src/components/DetailsPage/Tables/ApplicationsTable.js.map +1 -1
  6. package/dist/src/components/Device/AddDeviceModal/AddDeviceModal.d.ts.map +1 -1
  7. package/dist/src/components/Device/AddDeviceModal/AddDeviceModal.js +15 -51
  8. package/dist/src/components/Device/AddDeviceModal/AddDeviceModal.js.map +1 -1
  9. package/dist/src/components/Device/DeviceDetails/DeviceApplications.d.ts +10 -0
  10. package/dist/src/components/Device/DeviceDetails/DeviceApplications.d.ts.map +1 -0
  11. package/dist/src/components/Device/DeviceDetails/DeviceApplications.js +65 -0
  12. package/dist/src/components/Device/DeviceDetails/DeviceApplications.js.map +1 -0
  13. package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.d.ts +5 -4
  14. package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.d.ts.map +1 -1
  15. package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.js +18 -9
  16. package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.js.map +1 -1
  17. package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.d.ts +3 -4
  18. package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.d.ts.map +1 -1
  19. package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.js +6 -18
  20. package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.js.map +1 -1
  21. package/dist/src/components/Device/DeviceDetails/TerminalTab.d.ts +4 -3
  22. package/dist/src/components/Device/DeviceDetails/TerminalTab.d.ts.map +1 -1
  23. package/dist/src/components/Device/DeviceDetails/TerminalTab.js +13 -4
  24. package/dist/src/components/Device/DeviceDetails/TerminalTab.js.map +1 -1
  25. package/dist/src/components/Device/DevicesPage/DeviceFilterSelect.d.ts.map +1 -1
  26. package/dist/src/components/Device/DevicesPage/DeviceFilterSelect.js +4 -14
  27. package/dist/src/components/Device/DevicesPage/DeviceFilterSelect.js.map +1 -1
  28. package/dist/src/components/Device/DevicesPage/DeviceTableRow.d.ts +2 -0
  29. package/dist/src/components/Device/DevicesPage/DeviceTableRow.d.ts.map +1 -1
  30. package/dist/src/components/Device/DevicesPage/DeviceTableRow.js +14 -6
  31. package/dist/src/components/Device/DevicesPage/DeviceTableRow.js.map +1 -1
  32. package/dist/src/components/Device/DevicesPage/DeviceTableToolbar.d.ts +0 -3
  33. package/dist/src/components/Device/DevicesPage/DeviceTableToolbar.d.ts.map +1 -1
  34. package/dist/src/components/Device/DevicesPage/DeviceTableToolbar.js +2 -2
  35. package/dist/src/components/Device/DevicesPage/DeviceTableToolbar.js.map +1 -1
  36. package/dist/src/components/Device/DevicesPage/DeviceToolbarFilters.d.ts +1 -4
  37. package/dist/src/components/Device/DevicesPage/DeviceToolbarFilters.d.ts.map +1 -1
  38. package/dist/src/components/Device/DevicesPage/DeviceToolbarFilters.js +70 -16
  39. package/dist/src/components/Device/DevicesPage/DeviceToolbarFilters.js.map +1 -1
  40. package/dist/src/components/Device/DevicesPage/DevicesPage.d.ts +6 -8
  41. package/dist/src/components/Device/DevicesPage/DevicesPage.d.ts.map +1 -1
  42. package/dist/src/components/Device/DevicesPage/DevicesPage.js +41 -37
  43. package/dist/src/components/Device/DevicesPage/DevicesPage.js.map +1 -1
  44. package/dist/src/components/Device/DevicesPage/types.d.ts +1 -10
  45. package/dist/src/components/Device/DevicesPage/types.d.ts.map +1 -1
  46. package/dist/src/components/Device/DevicesPage/types.js.map +1 -1
  47. package/dist/src/components/Device/DevicesPage/useDevices.d.ts +9 -10
  48. package/dist/src/components/Device/DevicesPage/useDevices.d.ts.map +1 -1
  49. package/dist/src/components/Device/DevicesPage/useDevices.js +9 -29
  50. package/dist/src/components/Device/DevicesPage/useDevices.js.map +1 -1
  51. package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.d.ts +2 -2
  52. package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.d.ts.map +1 -1
  53. package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.js +19 -4
  54. package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.js.map +1 -1
  55. package/dist/src/components/Device/EditDeviceWizard/deviceSpecUtils.d.ts +7 -2
  56. package/dist/src/components/Device/EditDeviceWizard/deviceSpecUtils.d.ts.map +1 -1
  57. package/dist/src/components/Device/EditDeviceWizard/deviceSpecUtils.js +99 -7
  58. package/dist/src/components/Device/EditDeviceWizard/deviceSpecUtils.js.map +1 -1
  59. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.d.ts +5 -0
  60. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.d.ts.map +1 -0
  61. package/dist/src/components/Device/EditDeviceWizard/steps/{ApplicationsForm.js → ApplicationTemplates.js} +31 -24
  62. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.js.map +1 -0
  63. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.d.ts.map +1 -1
  64. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.js +9 -10
  65. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.js.map +1 -1
  66. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.d.ts +2 -1
  67. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.d.ts.map +1 -1
  68. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.js +5 -6
  69. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.js.map +1 -1
  70. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.d.ts +4 -0
  71. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.d.ts.map +1 -0
  72. package/dist/src/components/Device/EditDeviceWizard/steps/{ConfigTemplateForm.js → ConfigurationTemplates.js} +42 -28
  73. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.js.map +1 -0
  74. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.d.ts.map +1 -1
  75. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.js +53 -12
  76. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.js.map +1 -1
  77. package/dist/src/components/Device/EditDeviceWizard/steps/ReviewTrackedSystemdServices.d.ts +7 -0
  78. package/dist/src/components/Device/EditDeviceWizard/steps/ReviewTrackedSystemdServices.d.ts.map +1 -0
  79. package/dist/src/components/Device/EditDeviceWizard/steps/ReviewTrackedSystemdServices.js +13 -0
  80. package/dist/src/components/Device/EditDeviceWizard/steps/ReviewTrackedSystemdServices.js.map +1 -0
  81. package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.d.ts +4 -0
  82. package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.d.ts.map +1 -0
  83. package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.js +38 -0
  84. package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.js.map +1 -0
  85. package/dist/src/components/Device/EditDeviceWizard/types.d.ts +3 -0
  86. package/dist/src/components/Device/EditDeviceWizard/types.d.ts.map +1 -1
  87. package/dist/src/components/Device/EditDeviceWizard/utils.d.ts +1 -0
  88. package/dist/src/components/Device/EditDeviceWizard/utils.d.ts.map +1 -1
  89. package/dist/src/components/Device/EditDeviceWizard/utils.js +5 -2
  90. package/dist/src/components/Device/EditDeviceWizard/utils.js.map +1 -1
  91. package/dist/src/components/Device/{MatchPatternsModal/MatchPatternsModal.d.ts → SystemdUnitsModal/SystemdUnitsModal.d.ts} +6 -6
  92. package/dist/src/components/Device/SystemdUnitsModal/SystemdUnitsModal.d.ts.map +1 -0
  93. package/dist/src/components/Device/{MatchPatternsModal/MatchPatternsModal.js → SystemdUnitsModal/SystemdUnitsModal.js} +28 -15
  94. package/dist/src/components/Device/SystemdUnitsModal/SystemdUnitsModal.js.map +1 -0
  95. package/dist/src/components/Device/SystemdUnitsModal/TrackSystemdUnitsForm.d.ts +15 -0
  96. package/dist/src/components/Device/SystemdUnitsModal/TrackSystemdUnitsForm.d.ts.map +1 -0
  97. package/dist/src/components/Device/SystemdUnitsModal/TrackSystemdUnitsForm.js +57 -0
  98. package/dist/src/components/Device/SystemdUnitsModal/TrackSystemdUnitsForm.js.map +1 -0
  99. package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.d.ts +2 -2
  100. package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.d.ts.map +1 -1
  101. package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.js +14 -4
  102. package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.js.map +1 -1
  103. package/dist/src/components/EnrollmentRequest/EnrollmentRequestList.d.ts +9 -0
  104. package/dist/src/components/EnrollmentRequest/EnrollmentRequestList.d.ts.map +1 -0
  105. package/dist/src/components/{Device/DevicesPage → EnrollmentRequest}/EnrollmentRequestList.js +40 -38
  106. package/dist/src/components/EnrollmentRequest/EnrollmentRequestList.js.map +1 -0
  107. package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableRow.d.ts +2 -0
  108. package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableRow.d.ts.map +1 -1
  109. package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableRow.js +15 -11
  110. package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableRow.js.map +1 -1
  111. package/dist/src/components/{Device/DevicesPage → EnrollmentRequest}/EnrollmentRequestTableToolbar.d.ts +1 -1
  112. package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableToolbar.d.ts.map +1 -0
  113. package/dist/src/components/{Device/DevicesPage → EnrollmentRequest}/EnrollmentRequestTableToolbar.js +2 -2
  114. package/dist/src/components/EnrollmentRequest/EnrollmentRequestTableToolbar.js.map +1 -0
  115. package/dist/src/components/EnrollmentRequest/useEnrollmentRequests.d.ts +9 -0
  116. package/dist/src/components/EnrollmentRequest/useEnrollmentRequests.d.ts.map +1 -0
  117. package/dist/src/components/EnrollmentRequest/useEnrollmentRequests.js +42 -0
  118. package/dist/src/components/EnrollmentRequest/useEnrollmentRequests.js.map +1 -0
  119. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.d.ts +2 -2
  120. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.d.ts.map +1 -1
  121. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.js +19 -2
  122. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.js.map +1 -1
  123. package/dist/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.d.ts.map +1 -1
  124. package/dist/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.js +2 -4
  125. package/dist/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.js.map +1 -1
  126. package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.d.ts.map +1 -1
  127. package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.js +6 -1
  128. package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.js.map +1 -1
  129. package/dist/src/components/Fleet/CreateFleet/utils.d.ts.map +1 -1
  130. package/dist/src/components/Fleet/CreateFleet/utils.js +61 -35
  131. package/dist/src/components/Fleet/CreateFleet/utils.js.map +1 -1
  132. package/dist/src/components/Fleet/FleetDetails/FleetDetails.d.ts +2 -2
  133. package/dist/src/components/Fleet/FleetDetails/FleetDetails.d.ts.map +1 -1
  134. package/dist/src/components/Fleet/FleetDetails/FleetDetails.js +16 -6
  135. package/dist/src/components/Fleet/FleetDetails/FleetDetails.js.map +1 -1
  136. package/dist/src/components/Fleet/FleetResourceSyncs.d.ts +2 -5
  137. package/dist/src/components/Fleet/FleetResourceSyncs.d.ts.map +1 -1
  138. package/dist/src/components/Fleet/FleetResourceSyncs.js +38 -24
  139. package/dist/src/components/Fleet/FleetResourceSyncs.js.map +1 -1
  140. package/dist/src/components/Fleet/FleetRow.d.ts +2 -0
  141. package/dist/src/components/Fleet/FleetRow.d.ts.map +1 -1
  142. package/dist/src/components/Fleet/FleetRow.js +16 -14
  143. package/dist/src/components/Fleet/FleetRow.js.map +1 -1
  144. package/dist/src/components/Fleet/FleetsPage.d.ts +2 -2
  145. package/dist/src/components/Fleet/FleetsPage.d.ts.map +1 -1
  146. package/dist/src/components/Fleet/FleetsPage.js +34 -24
  147. package/dist/src/components/Fleet/FleetsPage.js.map +1 -1
  148. package/dist/src/components/Fleet/ImportFleetWizard/ImportFleetWizard.d.ts +2 -2
  149. package/dist/src/components/Fleet/ImportFleetWizard/ImportFleetWizard.d.ts.map +1 -1
  150. package/dist/src/components/Fleet/ImportFleetWizard/ImportFleetWizard.js +11 -2
  151. package/dist/src/components/Fleet/ImportFleetWizard/ImportFleetWizard.js.map +1 -1
  152. package/dist/src/components/Fleet/ImportFleetWizard/steps/RepositoryStep.d.ts.map +1 -1
  153. package/dist/src/components/Fleet/ImportFleetWizard/steps/RepositoryStep.js +5 -2
  154. package/dist/src/components/Fleet/ImportFleetWizard/steps/RepositoryStep.js.map +1 -1
  155. package/dist/src/components/Fleet/useFleets.d.ts +11 -3
  156. package/dist/src/components/Fleet/useFleets.d.ts.map +1 -1
  157. package/dist/src/components/Fleet/useFleets.js +22 -12
  158. package/dist/src/components/Fleet/useFleets.js.map +1 -1
  159. package/dist/src/components/OverviewPage/Cards/Status/StatusCard.d.ts.map +1 -1
  160. package/dist/src/components/OverviewPage/Cards/Status/StatusCard.js +5 -14
  161. package/dist/src/components/OverviewPage/Cards/Status/StatusCard.js.map +1 -1
  162. package/dist/src/components/OverviewPage/Cards/Status/StatusCardFilters.d.ts +0 -3
  163. package/dist/src/components/OverviewPage/Cards/Status/StatusCardFilters.d.ts.map +1 -1
  164. package/dist/src/components/OverviewPage/Cards/Status/StatusCardFilters.js +2 -2
  165. package/dist/src/components/OverviewPage/Cards/Status/StatusCardFilters.js.map +1 -1
  166. package/dist/src/components/OverviewPage/Overview.d.ts.map +1 -1
  167. package/dist/src/components/OverviewPage/Overview.js +11 -5
  168. package/dist/src/components/OverviewPage/Overview.js.map +1 -1
  169. package/dist/src/components/Repository/CreateRepository/CreateRepository.d.ts +2 -2
  170. package/dist/src/components/Repository/CreateRepository/CreateRepository.d.ts.map +1 -1
  171. package/dist/src/components/Repository/CreateRepository/CreateRepository.js +15 -6
  172. package/dist/src/components/Repository/CreateRepository/CreateRepository.js.map +1 -1
  173. package/dist/src/components/Repository/CreateRepository/CreateRepositoryForm.d.ts.map +1 -1
  174. package/dist/src/components/Repository/CreateRepository/CreateRepositoryForm.js +4 -1
  175. package/dist/src/components/Repository/CreateRepository/CreateRepositoryForm.js.map +1 -1
  176. package/dist/src/components/Repository/CreateRepository/utils.d.ts.map +1 -1
  177. package/dist/src/components/Repository/CreateRepository/utils.js +22 -6
  178. package/dist/src/components/Repository/CreateRepository/utils.js.map +1 -1
  179. package/dist/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.d.ts.map +1 -1
  180. package/dist/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.js +3 -2
  181. package/dist/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.js.map +1 -1
  182. package/dist/src/components/Repository/RepositoryDetails/RepositoryDetails.d.ts +2 -2
  183. package/dist/src/components/Repository/RepositoryDetails/RepositoryDetails.d.ts.map +1 -1
  184. package/dist/src/components/Repository/RepositoryDetails/RepositoryDetails.js +16 -5
  185. package/dist/src/components/Repository/RepositoryDetails/RepositoryDetails.js.map +1 -1
  186. package/dist/src/components/Repository/RepositoryList.d.ts +0 -1
  187. package/dist/src/components/Repository/RepositoryList.d.ts.map +1 -1
  188. package/dist/src/components/Repository/RepositoryList.js +55 -46
  189. package/dist/src/components/Repository/RepositoryList.js.map +1 -1
  190. package/dist/src/components/Repository/useRepositories.d.ts +16 -0
  191. package/dist/src/components/Repository/useRepositories.d.ts.map +1 -0
  192. package/dist/src/components/Repository/useRepositories.js +40 -0
  193. package/dist/src/components/Repository/useRepositories.js.map +1 -0
  194. package/dist/src/components/ResourceSync/RepositoryResourceSyncList.d.ts.map +1 -1
  195. package/dist/src/components/ResourceSync/RepositoryResourceSyncList.js +21 -23
  196. package/dist/src/components/ResourceSync/RepositoryResourceSyncList.js.map +1 -1
  197. package/dist/src/components/Table/Table.d.ts +0 -1
  198. package/dist/src/components/Table/Table.d.ts.map +1 -1
  199. package/dist/src/components/Table/Table.js +2 -2
  200. package/dist/src/components/Table/Table.js.map +1 -1
  201. package/dist/src/components/Table/TablePagination.d.ts +8 -0
  202. package/dist/src/components/Table/TablePagination.d.ts.map +1 -0
  203. package/dist/src/components/Table/TablePagination.js +38 -0
  204. package/dist/src/components/Table/TablePagination.js.map +1 -0
  205. package/dist/src/components/Terminal/Terminal.d.ts.map +1 -1
  206. package/dist/src/components/Terminal/Terminal.js +1 -0
  207. package/dist/src/components/Terminal/Terminal.js.map +1 -1
  208. package/dist/src/components/common/AccessDenied.d.ts +4 -0
  209. package/dist/src/components/common/AccessDenied.d.ts.map +1 -0
  210. package/dist/src/components/common/AccessDenied.js +15 -0
  211. package/dist/src/components/common/AccessDenied.js.map +1 -0
  212. package/dist/src/components/common/ButtonWithPermissions.d.ts +8 -0
  213. package/dist/src/components/common/ButtonWithPermissions.d.ts.map +1 -0
  214. package/dist/src/components/common/ButtonWithPermissions.js +12 -0
  215. package/dist/src/components/common/ButtonWithPermissions.js.map +1 -0
  216. package/dist/src/components/common/LearnMoreLink.d.ts +7 -0
  217. package/dist/src/components/common/LearnMoreLink.d.ts.map +1 -0
  218. package/dist/src/components/common/LearnMoreLink.js +13 -0
  219. package/dist/src/components/common/LearnMoreLink.js.map +1 -0
  220. package/dist/src/components/common/PageWithPermissions.d.ts +7 -0
  221. package/dist/src/components/common/PageWithPermissions.d.ts.map +1 -0
  222. package/dist/src/components/common/PageWithPermissions.js +17 -0
  223. package/dist/src/components/common/PageWithPermissions.js.map +1 -0
  224. package/dist/src/components/form/FilterSelect.d.ts +2 -4
  225. package/dist/src/components/form/FilterSelect.d.ts.map +1 -1
  226. package/dist/src/components/form/FilterSelect.js.map +1 -1
  227. package/dist/src/components/form/FlightCtlForm.css +3 -0
  228. package/dist/src/components/form/FlightCtlForm.d.ts +1 -0
  229. package/dist/src/components/form/FlightCtlForm.d.ts.map +1 -1
  230. package/dist/src/components/form/FlightCtlForm.js +2 -1
  231. package/dist/src/components/form/FlightCtlForm.js.map +1 -1
  232. package/dist/src/components/form/FormSelect.d.ts +1 -0
  233. package/dist/src/components/form/FormSelect.d.ts.map +1 -1
  234. package/dist/src/components/form/FormSelect.js +14 -2
  235. package/dist/src/components/form/FormSelect.js.map +1 -1
  236. package/dist/src/components/form/LabelsField.d.ts +2 -1
  237. package/dist/src/components/form/LabelsField.d.ts.map +1 -1
  238. package/dist/src/components/form/LabelsField.js +6 -6
  239. package/dist/src/components/form/LabelsField.js.map +1 -1
  240. package/dist/src/components/form/validations.d.ts +13 -2
  241. package/dist/src/components/form/validations.d.ts.map +1 -1
  242. package/dist/src/components/form/validations.js +39 -24
  243. package/dist/src/components/form/validations.js.map +1 -1
  244. package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.d.ts.map +1 -1
  245. package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.js +2 -5
  246. package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.js.map +1 -1
  247. package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.d.ts +2 -1
  248. package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.d.ts.map +1 -1
  249. package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.js +4 -4
  250. package/dist/src/components/modals/EditLabelsModal/EditLabelsForm.js.map +1 -1
  251. package/dist/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.d.ts.map +1 -1
  252. package/dist/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.js +2 -3
  253. package/dist/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.js.map +1 -1
  254. package/dist/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.d.ts +1 -1
  255. package/dist/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.d.ts.map +1 -1
  256. package/dist/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.js +6 -5
  257. package/dist/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.js.map +1 -1
  258. package/dist/src/constants.d.ts +2 -1
  259. package/dist/src/constants.d.ts.map +1 -1
  260. package/dist/src/constants.js +3 -1
  261. package/dist/src/constants.js.map +1 -1
  262. package/dist/src/hooks/useAccessReview.d.ts +4 -0
  263. package/dist/src/hooks/useAccessReview.d.ts.map +1 -0
  264. package/dist/src/hooks/useAccessReview.js +33 -0
  265. package/dist/src/hooks/useAccessReview.js.map +1 -0
  266. package/dist/src/hooks/useAppContext.d.ts +4 -3
  267. package/dist/src/hooks/useAppContext.d.ts.map +1 -1
  268. package/dist/src/hooks/useAppContext.js +2 -2
  269. package/dist/src/hooks/useAppContext.js.map +1 -1
  270. package/dist/src/hooks/useFetch.d.ts +4 -2
  271. package/dist/src/hooks/useFetch.d.ts.map +1 -1
  272. package/dist/src/hooks/useFetchPeriodically.d.ts +1 -1
  273. package/dist/src/hooks/useFetchPeriodically.d.ts.map +1 -1
  274. package/dist/src/hooks/useFetchPeriodically.js +4 -1
  275. package/dist/src/hooks/useFetchPeriodically.js.map +1 -1
  276. package/dist/src/hooks/useFleetImportAccessReview.d.ts +3 -0
  277. package/dist/src/hooks/useFleetImportAccessReview.d.ts.map +1 -0
  278. package/dist/src/hooks/useFleetImportAccessReview.js +12 -0
  279. package/dist/src/hooks/useFleetImportAccessReview.js.map +1 -0
  280. package/dist/src/hooks/useTablePagination.d.ts +10 -0
  281. package/dist/src/hooks/useTablePagination.d.ts.map +1 -0
  282. package/dist/src/hooks/useTablePagination.js +33 -0
  283. package/dist/src/hooks/useTablePagination.js.map +1 -0
  284. package/dist/src/hooks/useWebSocket.d.ts +2 -2
  285. package/dist/src/hooks/useWebSocket.d.ts.map +1 -1
  286. package/dist/src/hooks/useWebSocket.js.map +1 -1
  287. package/dist/src/links.d.ts +3 -0
  288. package/dist/src/links.d.ts.map +1 -0
  289. package/dist/src/links.js +6 -0
  290. package/dist/src/links.js.map +1 -0
  291. package/dist/src/types/rbac.d.ts +18 -0
  292. package/dist/src/types/rbac.d.ts.map +1 -0
  293. package/dist/src/types/rbac.js +23 -0
  294. package/dist/src/types/rbac.js.map +1 -0
  295. package/dist/src/utils/api.d.ts +3 -3
  296. package/dist/src/utils/api.d.ts.map +1 -1
  297. package/dist/src/utils/api.js.map +1 -1
  298. package/dist/src/utils/labels.d.ts +1 -1
  299. package/dist/src/utils/labels.d.ts.map +1 -1
  300. package/dist/src/utils/labels.js +4 -8
  301. package/dist/src/utils/labels.js.map +1 -1
  302. package/dist/src/utils/query.d.ts +9 -0
  303. package/dist/src/utils/query.d.ts.map +1 -1
  304. package/dist/src/utils/query.js +33 -1
  305. package/dist/src/utils/query.js.map +1 -1
  306. package/dist/src/utils/search.d.ts +1 -0
  307. package/dist/src/utils/search.d.ts.map +1 -1
  308. package/dist/src/utils/search.js +7 -7
  309. package/dist/src/utils/search.js.map +1 -1
  310. package/package.json +5 -5
  311. package/src/components/DetailsPage/Tables/ApplicationsTable.css +7 -0
  312. package/src/components/DetailsPage/Tables/ApplicationsTable.tsx +150 -13
  313. package/src/components/Device/AddDeviceModal/AddDeviceModal.tsx +31 -132
  314. package/src/components/Device/DeviceDetails/DeviceApplications.tsx +102 -0
  315. package/src/components/Device/DeviceDetails/DeviceDetailsPage.tsx +33 -16
  316. package/src/components/Device/DeviceDetails/DeviceDetailsTab.tsx +8 -38
  317. package/src/components/Device/DeviceDetails/TerminalTab.tsx +21 -4
  318. package/src/components/Device/DevicesPage/DeviceFilterSelect.tsx +13 -34
  319. package/src/components/Device/DevicesPage/DeviceTableRow.tsx +21 -9
  320. package/src/components/Device/DevicesPage/DeviceTableToolbar.tsx +0 -7
  321. package/src/components/Device/DevicesPage/DeviceToolbarFilters.tsx +93 -40
  322. package/src/components/Device/DevicesPage/DevicesPage.tsx +64 -58
  323. package/src/components/Device/DevicesPage/types.ts +1 -13
  324. package/src/components/Device/DevicesPage/useDevices.ts +19 -38
  325. package/src/components/Device/EditDeviceWizard/EditDeviceWizard.tsx +24 -4
  326. package/src/components/Device/EditDeviceWizard/deviceSpecUtils.ts +156 -47
  327. package/src/components/Device/EditDeviceWizard/steps/{ApplicationsForm.tsx → ApplicationTemplates.tsx} +89 -53
  328. package/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.tsx +22 -26
  329. package/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.tsx +17 -12
  330. package/src/components/Device/EditDeviceWizard/steps/{ConfigTemplateForm.tsx → ConfigurationTemplates.tsx} +110 -52
  331. package/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.tsx +108 -11
  332. package/src/components/Device/EditDeviceWizard/steps/ReviewTrackedSystemdServices.tsx +19 -0
  333. package/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.tsx +75 -0
  334. package/src/components/Device/EditDeviceWizard/types.ts +3 -0
  335. package/src/components/Device/EditDeviceWizard/utils.ts +14 -4
  336. package/src/components/Device/{MatchPatternsModal/MatchPatternsModal.tsx → SystemdUnitsModal/SystemdUnitsModal.tsx} +36 -19
  337. package/src/components/Device/SystemdUnitsModal/TrackSystemdUnitsForm.tsx +114 -0
  338. package/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.tsx +28 -9
  339. package/src/components/{Device/DevicesPage → EnrollmentRequest}/EnrollmentRequestList.tsx +57 -48
  340. package/src/components/EnrollmentRequest/EnrollmentRequestTableRow.tsx +28 -17
  341. package/src/components/{Device/DevicesPage → EnrollmentRequest}/EnrollmentRequestTableToolbar.tsx +3 -2
  342. package/src/components/EnrollmentRequest/useEnrollmentRequests.ts +63 -0
  343. package/src/components/Fleet/CreateFleet/CreateFleetWizard.tsx +28 -2
  344. package/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.tsx +2 -5
  345. package/src/components/Fleet/CreateFleet/steps/ReviewStep.tsx +7 -0
  346. package/src/components/Fleet/CreateFleet/utils.ts +101 -49
  347. package/src/components/Fleet/FleetDetails/FleetDetails.tsx +57 -36
  348. package/src/components/Fleet/FleetResourceSyncs.tsx +53 -41
  349. package/src/components/Fleet/FleetRow.tsx +28 -16
  350. package/src/components/Fleet/FleetsPage.tsx +63 -53
  351. package/src/components/Fleet/ImportFleetWizard/ImportFleetWizard.tsx +16 -3
  352. package/src/components/Fleet/ImportFleetWizard/steps/RepositoryStep.tsx +25 -19
  353. package/src/components/Fleet/useFleets.ts +40 -22
  354. package/src/components/OverviewPage/Cards/Status/StatusCard.tsx +5 -18
  355. package/src/components/OverviewPage/Cards/Status/StatusCardFilters.tsx +0 -7
  356. package/src/components/OverviewPage/Overview.tsx +20 -8
  357. package/src/components/Repository/CreateRepository/CreateRepository.tsx +25 -9
  358. package/src/components/Repository/CreateRepository/CreateRepositoryForm.tsx +5 -2
  359. package/src/components/Repository/CreateRepository/utils.ts +23 -7
  360. package/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.tsx +5 -3
  361. package/src/components/Repository/RepositoryDetails/RepositoryDetails.tsx +32 -10
  362. package/src/components/Repository/RepositoryList.tsx +113 -71
  363. package/src/components/Repository/useRepositories.ts +59 -0
  364. package/src/components/ResourceSync/RepositoryResourceSyncList.tsx +41 -40
  365. package/src/components/Table/Table.tsx +3 -4
  366. package/src/components/Table/TablePagination.tsx +74 -0
  367. package/src/components/Terminal/Terminal.tsx +1 -0
  368. package/src/components/common/AccessDenied.tsx +17 -0
  369. package/src/components/common/ButtonWithPermissions.tsx +14 -0
  370. package/src/components/common/LearnMoreLink.tsx +26 -0
  371. package/src/components/common/PageWithPermissions.tsx +19 -0
  372. package/src/components/form/FilterSelect.tsx +2 -4
  373. package/src/components/form/FlightCtlForm.css +3 -0
  374. package/src/components/form/FlightCtlForm.tsx +3 -1
  375. package/src/components/form/FormSelect.tsx +22 -2
  376. package/src/components/form/LabelsField.tsx +17 -13
  377. package/src/components/form/validations.ts +53 -25
  378. package/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.tsx +2 -5
  379. package/src/components/modals/EditLabelsModal/EditLabelsForm.tsx +9 -4
  380. package/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.tsx +2 -4
  381. package/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.tsx +8 -5
  382. package/src/constants.ts +2 -1
  383. package/src/hooks/useAccessReview.ts +33 -0
  384. package/src/hooks/useAppContext.tsx +6 -5
  385. package/src/hooks/useFetchPeriodically.ts +4 -0
  386. package/src/hooks/useFleetImportAccessReview.ts +8 -0
  387. package/src/hooks/useTablePagination.tsx +44 -0
  388. package/src/hooks/useWebSocket.ts +4 -4
  389. package/src/links.ts +5 -0
  390. package/src/types/rbac.ts +18 -0
  391. package/src/utils/api.ts +3 -3
  392. package/src/utils/labels.ts +3 -7
  393. package/src/utils/query.ts +41 -0
  394. package/src/utils/search.ts +1 -1
  395. package/dist/src/components/DetailsPage/Tables/SystemdDetailsTable.d.ts +0 -12
  396. package/dist/src/components/DetailsPage/Tables/SystemdDetailsTable.d.ts.map +0 -1
  397. package/dist/src/components/DetailsPage/Tables/SystemdDetailsTable.js +0 -40
  398. package/dist/src/components/DetailsPage/Tables/SystemdDetailsTable.js.map +0 -1
  399. package/dist/src/components/Device/DeviceDetails/SystemdTable.d.ts +0 -10
  400. package/dist/src/components/Device/DeviceDetails/SystemdTable.d.ts.map +0 -1
  401. package/dist/src/components/Device/DeviceDetails/SystemdTable.js +0 -38
  402. package/dist/src/components/Device/DeviceDetails/SystemdTable.js.map +0 -1
  403. package/dist/src/components/Device/DevicesPage/EnrollmentRequestList.d.ts +0 -6
  404. package/dist/src/components/Device/DevicesPage/EnrollmentRequestList.d.ts.map +0 -1
  405. package/dist/src/components/Device/DevicesPage/EnrollmentRequestList.js.map +0 -1
  406. package/dist/src/components/Device/DevicesPage/EnrollmentRequestTableToolbar.d.ts.map +0 -1
  407. package/dist/src/components/Device/DevicesPage/EnrollmentRequestTableToolbar.js.map +0 -1
  408. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationsForm.d.ts +0 -5
  409. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationsForm.d.ts.map +0 -1
  410. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationsForm.js.map +0 -1
  411. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigTemplateForm.d.ts +0 -4
  412. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigTemplateForm.d.ts.map +0 -1
  413. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigTemplateForm.js.map +0 -1
  414. package/dist/src/components/Device/MatchPatternsModal/MatchPatternsForm.d.ts +0 -11
  415. package/dist/src/components/Device/MatchPatternsModal/MatchPatternsForm.d.ts.map +0 -1
  416. package/dist/src/components/Device/MatchPatternsModal/MatchPatternsForm.js +0 -39
  417. package/dist/src/components/Device/MatchPatternsModal/MatchPatternsForm.js.map +0 -1
  418. package/dist/src/components/Device/MatchPatternsModal/MatchPatternsModal.d.ts.map +0 -1
  419. package/dist/src/components/Device/MatchPatternsModal/MatchPatternsModal.js.map +0 -1
  420. package/dist/src/components/common/HelperTextItems.d.ts +0 -3
  421. package/dist/src/components/common/HelperTextItems.d.ts.map +0 -1
  422. package/dist/src/components/common/HelperTextItems.js +0 -17
  423. package/dist/src/components/common/HelperTextItems.js.map +0 -1
  424. package/dist/src/hooks/useApiTableSort.d.ts +0 -8
  425. package/dist/src/hooks/useApiTableSort.d.ts.map +0 -1
  426. package/dist/src/hooks/useApiTableSort.js +0 -44
  427. package/dist/src/hooks/useApiTableSort.js.map +0 -1
  428. package/dist/src/hooks/useTableSort.d.ts +0 -7
  429. package/dist/src/hooks/useTableSort.d.ts.map +0 -1
  430. package/dist/src/hooks/useTableSort.js +0 -38
  431. package/dist/src/hooks/useTableSort.js.map +0 -1
  432. package/dist/src/utils/sort/generic.d.ts +0 -5
  433. package/dist/src/utils/sort/generic.d.ts.map +0 -1
  434. package/dist/src/utils/sort/generic.js +0 -10
  435. package/dist/src/utils/sort/generic.js.map +0 -1
  436. package/dist/src/utils/sort/repository.d.ts +0 -6
  437. package/dist/src/utils/sort/repository.d.ts.map +0 -1
  438. package/dist/src/utils/sort/repository.js +0 -28
  439. package/dist/src/utils/sort/repository.js.map +0 -1
  440. package/dist/src/utils/sort/resourceSync.d.ts +0 -6
  441. package/dist/src/utils/sort/resourceSync.d.ts.map +0 -1
  442. package/dist/src/utils/sort/resourceSync.js +0 -29
  443. package/dist/src/utils/sort/resourceSync.js.map +0 -1
  444. package/src/components/DetailsPage/Tables/SystemdDetailsTable.tsx +0 -63
  445. package/src/components/Device/DeviceDetails/SystemdTable.tsx +0 -65
  446. package/src/components/Device/MatchPatternsModal/MatchPatternsForm.tsx +0 -92
  447. package/src/components/common/HelperTextItems.tsx +0 -25
  448. package/src/hooks/useApiTableSort.ts +0 -49
  449. package/src/hooks/useTableSort.ts +0 -42
  450. package/src/utils/sort/generic.ts +0 -8
  451. package/src/utils/sort/repository.ts +0 -28
  452. package/src/utils/sort/resourceSync.ts +0 -30
@@ -1,24 +1,17 @@
1
1
  import * as React from 'react';
2
- import {
3
- Button,
4
- EmptyStateActions,
5
- EmptyStateBody,
6
- EmptyStateFooter,
7
- PageSection,
8
- PageSectionVariants,
9
- ToolbarItem,
10
- } from '@patternfly/react-core';
11
- import { Tbody, ThProps } from '@patternfly/react-table';
2
+ import { Button, EmptyStateActions, EmptyStateBody, EmptyStateFooter, ToolbarItem } from '@patternfly/react-core';
3
+ import { Tbody } from '@patternfly/react-table';
12
4
  import { MicrochipIcon } from '@patternfly/react-icons/dist/js/icons/microchip-icon';
13
5
  import { Trans } from 'react-i18next';
14
6
  import { TFunction } from 'i18next';
15
7
 
16
8
  import { useFetch } from '../../../hooks/useFetch';
17
- import { Device, Fleet, FleetList } from '@flightctl/types';
9
+ import { Device } from '@flightctl/types';
18
10
 
19
11
  import ListPage from '../../ListPage/ListPage';
20
12
  import ListPageBody from '../../ListPage/ListPageBody';
21
13
  import { useDeleteListAction } from '../../ListPage/ListPageActions';
14
+ import TablePagination from '../../Table/TablePagination';
22
15
  import AddDeviceModal from '../AddDeviceModal/AddDeviceModal';
23
16
  import Table, { ApiSortTableColumn } from '../../Table/Table';
24
17
  import DeviceTableToolbar from './DeviceTableToolbar';
@@ -29,6 +22,7 @@ import ResourceListEmptyState from '../../common/ResourceListEmptyState';
29
22
  import { useTableSelect } from '../../../hooks/useTableSelect';
30
23
  import { useTranslation } from '../../../hooks/useTranslation';
31
24
  import { Link, ROUTE } from '../../../hooks/useNavigate';
25
+ import { PaginationDetails, useTablePagination } from '../../../hooks/useTablePagination';
32
26
  import { useDevices } from './useDevices';
33
27
  import { useDeviceBackendFilters } from './useDeviceBackendFilters';
34
28
  import {
@@ -36,10 +30,11 @@ import {
36
30
  getDeviceStatusHelperText,
37
31
  getUpdateStatusHelperText,
38
32
  } from '../../Status/utils';
39
- import EnrollmentRequestList from './EnrollmentRequestList';
33
+ import EnrollmentRequestList from '../../EnrollmentRequest/EnrollmentRequestList';
40
34
  import { FilterStatusMap } from './types';
41
- import { useFetchPeriodically } from '../../../hooks/useFetchPeriodically';
42
- import { useApiTableSort } from '../../../hooks/useApiTableSort';
35
+ import PageWithPermissions from '../../common/PageWithPermissions';
36
+ import { RESOURCE, VERB } from '../../../types/rbac';
37
+ import { useAccessReview } from '../../../hooks/useAccessReview';
43
38
 
44
39
  type DeviceEmptyStateProps = {
45
40
  onAddDevice: VoidFunction;
@@ -47,13 +42,18 @@ type DeviceEmptyStateProps = {
47
42
 
48
43
  const DeviceEmptyState: React.FC<DeviceEmptyStateProps> = ({ onAddDevice }) => {
49
44
  const { t } = useTranslation();
45
+ const [canCreateFleet] = useAccessReview(RESOURCE.FLEET, VERB.CREATE);
50
46
  return (
51
47
  <ResourceListEmptyState icon={MicrochipIcon} titleText={t('No devices here!')}>
52
48
  <EmptyStateBody>
53
- <Trans t={t}>
54
- You can add devices and label them to match fleets, or your can{' '}
55
- <Link to={ROUTE.FLEET_CREATE}>start with a fleet</Link> and add devices into it.
56
- </Trans>
49
+ {canCreateFleet ? (
50
+ <Trans t={t}>
51
+ You can add devices and label them to match fleets, or you can{' '}
52
+ <Link to={ROUTE.FLEET_CREATE}>start with a fleet</Link> and add devices into it.
53
+ </Trans>
54
+ ) : (
55
+ t('You can add devices and label them to match fleets')
56
+ )}
57
57
  </EmptyStateBody>
58
58
  <EmptyStateFooter>
59
59
  <EmptyStateActions>
@@ -67,36 +67,27 @@ const DeviceEmptyState: React.FC<DeviceEmptyStateProps> = ({ onAddDevice }) => {
67
67
  const getDeviceColumns = (t: TFunction): ApiSortTableColumn[] => [
68
68
  {
69
69
  name: t('Alias'),
70
- // Sorting works on this field even though "alias" is actually a label
71
- sortableField: 'metadata.alias',
72
70
  },
73
71
  {
74
72
  name: t('Name'),
75
- sortableField: 'metadata.name',
76
73
  },
77
74
  {
78
75
  name: t('Fleet'),
79
- sortableField: 'metadata.owner',
80
76
  },
81
77
  {
82
78
  name: t('Application status'),
83
79
  helperText: getApplicationStatusHelperText(t),
84
- sortableField: 'status.applicationsSummary.status',
85
80
  },
86
81
  {
87
82
  name: t('Device status'),
88
83
  helperText: getDeviceStatusHelperText(t),
89
- sortableField: 'status.summary.status',
90
- defaultSort: true,
91
84
  },
92
85
  {
93
86
  name: t('Update status'),
94
87
  helperText: getUpdateStatusHelperText(t),
95
- sortableField: 'status.updated.status',
96
88
  },
97
89
  {
98
90
  name: t('Last seen'),
99
- sortableField: 'status.lastSeen',
100
91
  },
101
92
  ];
102
93
 
@@ -110,13 +101,12 @@ interface DeviceTableProps {
110
101
  setNameOrAlias: (text: string) => void;
111
102
  setOwnerFleets: (ownerFleets: string[]) => void;
112
103
  setActiveStatuses: (activeStatuses: FilterStatusMap) => void;
113
- allLabels: FlightCtlLabel[];
114
104
  selectedLabels: FlightCtlLabel[];
115
105
  setSelectedLabels: (labels: FlightCtlLabel[]) => void;
116
- fleets: Fleet[];
117
106
  isFilterUpdating: boolean;
118
107
  deviceColumns: ApiSortTableColumn[];
119
- getSortParams: (columnIndex: number) => ThProps['sort'];
108
+ pagination: Pick<PaginationDetails, 'currentPage' | 'setCurrentPage' | 'itemCount'>;
109
+ // getSortParams: (columnIndex: number) => ThProps['sort'];
120
110
  }
121
111
 
122
112
  export const DeviceTable = ({
@@ -128,14 +118,12 @@ export const DeviceTable = ({
128
118
  setOwnerFleets,
129
119
  activeStatuses,
130
120
  setActiveStatuses,
131
- allLabels,
132
121
  selectedLabels,
133
122
  setSelectedLabels,
134
123
  hasFiltersEnabled,
135
- fleets,
136
124
  isFilterUpdating,
137
125
  deviceColumns,
138
- getSortParams,
126
+ pagination,
139
127
  }: DeviceTableProps) => {
140
128
  const { t } = useTranslation();
141
129
  const [addDeviceModal, setAddDeviceModal] = React.useState(false);
@@ -152,6 +140,9 @@ export const DeviceTable = ({
152
140
  },
153
141
  });
154
142
 
143
+ const [canDelete] = useAccessReview(RESOURCE.DEVICE, VERB.DELETE);
144
+ const [canEdit] = useAccessReview(RESOURCE.DEVICE, VERB.PATCH);
145
+
155
146
  return (
156
147
  <>
157
148
  <DeviceTableToolbar
@@ -161,20 +152,20 @@ export const DeviceTable = ({
161
152
  setOwnerFleets={setOwnerFleets}
162
153
  activeStatuses={activeStatuses}
163
154
  setActiveStatuses={setActiveStatuses}
164
- allLabels={allLabels}
165
155
  selectedLabels={selectedLabels}
166
156
  setSelectedLabels={setSelectedLabels}
167
- fleets={fleets}
168
157
  isFilterUpdating={isFilterUpdating}
169
158
  >
170
159
  <ToolbarItem>
171
160
  <Button onClick={() => setAddDeviceModal(true)}>{t('Add devices')}</Button>
172
161
  </ToolbarItem>
173
- <ToolbarItem>
174
- <Button isDisabled={!hasSelectedRows} onClick={() => setIsMassDeleteModalOpen(true)} variant="secondary">
175
- {t('Delete devices')}
176
- </Button>
177
- </ToolbarItem>
162
+ {canDelete && (
163
+ <ToolbarItem>
164
+ <Button isDisabled={!hasSelectedRows} onClick={() => setIsMassDeleteModalOpen(true)} variant="secondary">
165
+ {t('Delete devices')}
166
+ </Button>
167
+ </ToolbarItem>
168
+ )}
178
169
  </DeviceTableToolbar>
179
170
  <Table
180
171
  aria-label={t('Devices table')}
@@ -182,7 +173,6 @@ export const DeviceTable = ({
182
173
  columns={deviceColumns}
183
174
  emptyFilters={!hasFiltersEnabled}
184
175
  emptyData={devices.length === 0}
185
- getSortParams={getSortParams}
186
176
  isAllSelected={isAllSelected}
187
177
  onSelectAll={setAllSelected}
188
178
  >
@@ -195,10 +185,13 @@ export const DeviceTable = ({
195
185
  onRowSelect={onRowSelect}
196
186
  isRowSelected={isRowSelected}
197
187
  rowIndex={index}
188
+ canDelete={canDelete}
189
+ canEdit={canEdit}
198
190
  />
199
191
  ))}
200
192
  </Tbody>
201
193
  </Table>
194
+ <TablePagination isUpdating={isFilterUpdating} pagination={pagination} />
202
195
  {!hasFiltersEnabled && devices.length === 0 && <DeviceEmptyState onAddDevice={() => setAddDeviceModal(true)} />}
203
196
  {deleteDeviceModal}
204
197
  {addDeviceModal && <AddDeviceModal onClose={() => setAddDeviceModal(false)} />}
@@ -216,7 +209,7 @@ export const DeviceTable = ({
216
209
  );
217
210
  };
218
211
 
219
- const DevicesPage = () => {
212
+ const DevicesPage = ({ canListER }: { canListER: boolean }) => {
220
213
  const { t } = useTranslation();
221
214
  const deviceColumns = React.useMemo(() => getDeviceColumns(t), [t]);
222
215
 
@@ -231,30 +224,33 @@ const DevicesPage = () => {
231
224
  selectedLabels,
232
225
  setSelectedLabels,
233
226
  } = useDeviceBackendFilters();
234
- const { getSortParams, sortField, direction } = useApiTableSort(deviceColumns);
235
-
236
- const [data, loading, error, updating, refetch, allLabels] = useDevices({
227
+ const { currentPage, setCurrentPage, onPageFetched, nextContinue, itemCount } = useTablePagination();
228
+ const [data, loading, error, updating, refetch] = useDevices({
237
229
  nameOrAlias,
238
230
  ownerFleets,
239
231
  activeStatuses,
240
232
  labels: selectedLabels,
241
- sortField,
242
- direction,
233
+ nextContinue,
234
+ onPageFetched,
243
235
  });
244
236
 
245
- const [fleetsList, flLoading, flError] = useFetchPeriodically<FleetList>({
246
- endpoint: 'fleets',
247
- });
237
+ const pagination = React.useMemo(
238
+ () => ({
239
+ currentPage,
240
+ setCurrentPage,
241
+ itemCount,
242
+ }),
243
+ [currentPage, setCurrentPage, itemCount],
244
+ );
248
245
 
249
246
  return (
250
- <PageSection variant={PageSectionVariants.light}>
251
- <EnrollmentRequestList refetchDevices={refetch} />
247
+ <>
248
+ {canListER && <EnrollmentRequestList refetchDevices={refetch} />}
252
249
 
253
250
  <ListPage title={t('Devices')}>
254
- <ListPageBody error={error || flError} loading={loading || flLoading}>
251
+ <ListPageBody error={error} loading={loading}>
255
252
  <DeviceTable
256
253
  devices={data}
257
- allLabels={allLabels}
258
254
  refetch={refetch}
259
255
  nameOrAlias={nameOrAlias}
260
256
  setNameOrAlias={setNameOrAlias}
@@ -265,15 +261,25 @@ const DevicesPage = () => {
265
261
  setActiveStatuses={setActiveStatuses}
266
262
  selectedLabels={selectedLabels}
267
263
  setSelectedLabels={setSelectedLabels}
268
- fleets={fleetsList?.items || []}
269
264
  isFilterUpdating={updating}
270
265
  deviceColumns={deviceColumns}
271
- getSortParams={getSortParams}
266
+ pagination={pagination}
272
267
  />
273
268
  </ListPageBody>
274
269
  </ListPage>
275
- </PageSection>
270
+ </>
271
+ );
272
+ };
273
+
274
+ const DevicesPageWithPermissions = () => {
275
+ const [canListDevice, deviceLoading] = useAccessReview(RESOURCE.DEVICE, VERB.LIST);
276
+ const [canListER, erLoading] = useAccessReview(RESOURCE.ENROLLMENT_REQUEST, VERB.LIST);
277
+
278
+ return (
279
+ <PageWithPermissions loading={deviceLoading || erLoading} allowed={canListDevice || canListER}>
280
+ {canListDevice ? <DevicesPage canListER={canListER} /> : <EnrollmentRequestList isStandalone />}
281
+ </PageWithPermissions>
276
282
  );
277
283
  };
278
284
 
279
- export default DevicesPage;
285
+ export default DevicesPageWithPermissions;
@@ -1,18 +1,6 @@
1
- import { DeviceSummaryStatus, FilterSearchParams } from '../../../utils/status/devices';
2
- import { StatusItem } from '../../../utils/status/common';
1
+ import { FilterSearchParams } from '../../../utils/status/devices';
3
2
  import { ApplicationsSummaryStatusType, DeviceSummaryStatusType, DeviceUpdatedStatusType } from '@flightctl/types';
4
3
 
5
- type FilterOptionsProps<T extends DeviceSummaryStatus> = {
6
- filter: string;
7
- items: Array<StatusItem<T>>;
8
- selectedFilters: Array<T>;
9
- onClick: (value: string) => void;
10
- };
11
-
12
- export type FilterOptionsFC = <T extends DeviceSummaryStatus>(
13
- props: FilterOptionsProps<T>,
14
- ) => JSX.Element | JSX.Element[];
15
-
16
4
  export type FilterStatusMap = {
17
5
  [FilterSearchParams.AppStatus]: ApplicationsSummaryStatusType[];
18
6
  [FilterSearchParams.DeviceStatus]: DeviceSummaryStatusType[];
@@ -1,22 +1,20 @@
1
- import * as React from 'react';
2
1
  import { useDebounce } from 'use-debounce';
3
2
 
4
- import { Device, DeviceList, DevicesSummary, SortOrder } from '@flightctl/types';
3
+ import { Device, DeviceList, DevicesSummary } from '@flightctl/types';
5
4
  import { FilterSearchParams } from '../../../utils/status/devices';
6
5
  import * as queryUtils from '../../../utils/query';
7
- import { fromAPILabel } from '../../../utils/labels';
8
6
  import { useFetchPeriodically } from '../../../hooks/useFetchPeriodically';
9
7
  import { FlightCtlLabel } from '../../../types/extraTypes';
10
8
  import { FilterStatusMap } from './types';
9
+ import { PAGE_SIZE } from '../../../constants';
11
10
 
12
11
  type DevicesEndpointArgs = {
13
12
  nameOrAlias?: string;
14
13
  ownerFleets?: string[];
15
14
  activeStatuses?: FilterStatusMap;
16
15
  labels?: FlightCtlLabel[];
17
- sortField?: string;
18
- direction?: string;
19
16
  summaryOnly?: boolean;
17
+ nextContinue?: string;
20
18
  };
21
19
 
22
20
  const getDevicesEndpoint = ({
@@ -24,8 +22,7 @@ const getDevicesEndpoint = ({
24
22
  ownerFleets,
25
23
  activeStatuses,
26
24
  labels,
27
- sortField,
28
- direction,
25
+ nextContinue,
29
26
  summaryOnly,
30
27
  }: DevicesEndpointArgs) => {
31
28
  const filterByAppStatus = activeStatuses?.[FilterSearchParams.AppStatus];
@@ -56,9 +53,11 @@ const getDevicesEndpoint = ({
56
53
  if (summaryOnly) {
57
54
  params.set('summaryOnly', 'true');
58
55
  }
59
- if (sortField) {
60
- params.set('sortBy', sortField);
61
- params.set('sortOrder', direction || SortOrder.ASC);
56
+ if (nextContinue !== undefined) {
57
+ params.set('limit', `${PAGE_SIZE}`);
58
+ }
59
+ if (nextContinue) {
60
+ params.set('continue', nextContinue);
62
61
  }
63
62
  return params.size ? `devices?${params.toString()}` : 'devices';
64
63
  };
@@ -89,35 +88,17 @@ export const useDevices = (args: {
89
88
  ownerFleets?: string[];
90
89
  activeStatuses?: FilterStatusMap;
91
90
  labels?: FlightCtlLabel[];
92
- sortField?: string;
93
- direction?: string;
94
- }): [Device[], boolean, unknown, boolean, VoidFunction, FlightCtlLabel[]] => {
95
- const [deviceLabelList] = useFetchPeriodically<DeviceList>({
96
- endpoint: 'devices',
97
- });
91
+ nextContinue?: string;
92
+ onPageFetched?: (data: DeviceList) => void;
93
+ }): [Device[], boolean, unknown, boolean, VoidFunction] => {
98
94
  const [devicesEndpoint, devicesDebouncing] = useDevicesEndpoint(args);
99
- const [devicesList, devicesLoading, devicesError, devicesRefetch, updating] = useFetchPeriodically<DeviceList>({
100
- endpoint: devicesEndpoint,
101
- });
102
-
103
- const allLabels = React.useMemo(() => {
104
- const labelsSet = new Set<FlightCtlLabel>();
105
95
 
106
- deviceLabelList?.items.forEach((device) => {
107
- const deviceLabels = fromAPILabel(device.metadata.labels || {}).filter((label) => label.key !== 'alias');
108
- deviceLabels.forEach((label) => {
109
- labelsSet.add(label);
110
- });
111
- });
112
- return Array.from(labelsSet);
113
- }, [deviceLabelList]);
96
+ const [devicesList, devicesLoading, devicesError, devicesRefetch, updating] = useFetchPeriodically<DeviceList>(
97
+ {
98
+ endpoint: devicesEndpoint,
99
+ },
100
+ args.onPageFetched,
101
+ );
114
102
 
115
- return [
116
- devicesList?.items || [],
117
- devicesLoading,
118
- devicesError,
119
- updating || devicesDebouncing,
120
- devicesRefetch,
121
- allLabels || [],
122
- ];
103
+ return [devicesList?.items || [], devicesLoading, devicesError, updating || devicesDebouncing, devicesRefetch];
123
104
  };
@@ -25,11 +25,14 @@ import GeneralInfoStep, { generalInfoStepId, isGeneralInfoStepValid } from './st
25
25
  import DeviceTemplateStep, { deviceTemplateStepId, isDeviceTemplateStepValid } from './steps/DeviceTemplateStep';
26
26
  import ReviewDeviceStep, { reviewDeviceStepId } from './steps/ReviewDeviceStep';
27
27
  import { getDevicePatches, getValidationSchema } from './utils';
28
- import { getApplicationValues, getConfigTemplatesValues } from './deviceSpecUtils';
28
+ import { getApplicationValues, getConfigTemplatesValues, hasMicroshiftRegistrationConfig } from './deviceSpecUtils';
29
29
  import { useFetch } from '../../../hooks/useFetch';
30
30
  import { useEditDevice } from './useEditDevice';
31
31
  import EditDeviceWizardNav from './EditDeviceWizardNav';
32
32
  import EditDeviceWizardFooter from './EditDeviceWizardFooter';
33
+ import PageWithPermissions from '../../common/PageWithPermissions';
34
+ import { RESOURCE, VERB } from '../../../types/rbac';
35
+ import { useAccessReview } from '../../../hooks/useAccessReview';
33
36
 
34
37
  import './EditDeviceWizard.css';
35
38
 
@@ -64,15 +67,18 @@ const EditDeviceWizard = () => {
64
67
  </Alert>
65
68
  );
66
69
  } else if (device) {
70
+ const registerMicroShift = hasMicroshiftRegistrationConfig(device.spec);
67
71
  body = (
68
72
  <Formik<EditDeviceFormValues>
69
73
  initialValues={{
70
74
  deviceAlias,
71
- osImage: device.spec?.os?.image,
75
+ osImage: device.spec?.os?.image || '',
72
76
  labels: fromAPILabel(device.metadata.labels || {}).filter((label) => label.key !== 'alias'),
73
- configTemplates: getConfigTemplatesValues(device.spec),
77
+ configTemplates: getConfigTemplatesValues(device.spec, registerMicroShift),
74
78
  fleetMatch: '', // Initially this is always a fleetless device
75
79
  applications: getApplicationValues(device.spec),
80
+ systemdUnits: [],
81
+ registerMicroShift,
76
82
  }}
77
83
  validationSchema={getValidationSchema(t)}
78
84
  validateOnMount
@@ -102,6 +108,11 @@ const EditDeviceWizard = () => {
102
108
  className="fctl-edit-device__wizard"
103
109
  footer={<EditDeviceWizardFooter />}
104
110
  nav={<EditDeviceWizardNav />}
111
+ onStepChange={() => {
112
+ if (submitError) {
113
+ setSubmitError(undefined);
114
+ }
115
+ }}
105
116
  >
106
117
  <WizardStep name={t('General info')} id={generalInfoStepId}>
107
118
  <GeneralInfoStep />
@@ -147,4 +158,13 @@ const EditDeviceWizard = () => {
147
158
  );
148
159
  };
149
160
 
150
- export default EditDeviceWizard;
161
+ const EditDeviceWizardWithPermissions = () => {
162
+ const [allowed, loading] = useAccessReview(RESOURCE.DEVICE, VERB.PATCH);
163
+ return (
164
+ <PageWithPermissions allowed={allowed} loading={loading}>
165
+ <EditDeviceWizard />
166
+ </PageWithPermissions>
167
+ );
168
+ };
169
+
170
+ export default EditDeviceWizardWithPermissions;