@flightctl/ui-components 0.7.2 → 0.8.0-rc1

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 (408) hide show
  1. package/dist/src/components/DetailsPage/DetailsPageActions.d.ts +1 -1
  2. package/dist/src/components/DetailsPage/DetailsPageActions.d.ts.map +1 -1
  3. package/dist/src/components/DetailsPage/DetailsPageActions.js +1 -1
  4. package/dist/src/components/DetailsPage/DetailsPageActions.js.map +1 -1
  5. package/dist/src/components/Device/AddDeviceModal/AddDeviceModal.d.ts.map +1 -1
  6. package/dist/src/components/Device/AddDeviceModal/AddDeviceModal.js +18 -14
  7. package/dist/src/components/Device/AddDeviceModal/AddDeviceModal.js.map +1 -1
  8. package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.d.ts.map +1 -1
  9. package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.js +10 -11
  10. package/dist/src/components/Device/DeviceDetails/DeviceDetailsPage.js.map +1 -1
  11. package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.d.ts.map +1 -1
  12. package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.js +31 -10
  13. package/dist/src/components/Device/DeviceDetails/DeviceDetailsTab.js.map +1 -1
  14. package/dist/src/components/Device/DevicesPage/DecommissionedDevicesTable.js +2 -2
  15. package/dist/src/components/Device/DevicesPage/DecommissionedDevicesTable.js.map +1 -1
  16. package/dist/src/components/Device/DevicesPage/EnrolledDevicesTable.js +2 -2
  17. package/dist/src/components/Device/DevicesPage/EnrolledDevicesTable.js.map +1 -1
  18. package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.d.ts.map +1 -1
  19. package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.js +4 -2
  20. package/dist/src/components/Device/EditDeviceWizard/EditDeviceWizard.js.map +1 -1
  21. package/dist/src/components/Device/EditDeviceWizard/deviceSpecUtils.d.ts.map +1 -1
  22. package/dist/src/components/Device/EditDeviceWizard/deviceSpecUtils.js +29 -1
  23. package/dist/src/components/Device/EditDeviceWizard/deviceSpecUtils.js.map +1 -1
  24. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationImageForm.d.ts +2 -1
  25. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationImageForm.d.ts.map +1 -1
  26. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationImageForm.js +6 -5
  27. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationImageForm.js.map +1 -1
  28. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationInlineForm.d.ts +3 -2
  29. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationInlineForm.d.ts.map +1 -1
  30. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationInlineForm.js +13 -9
  31. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationInlineForm.js.map +1 -1
  32. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.d.ts +3 -1
  33. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.d.ts.map +1 -1
  34. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.js +20 -17
  35. package/dist/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.js.map +1 -1
  36. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.d.ts +2 -1
  37. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.d.ts.map +1 -1
  38. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.js +18 -14
  39. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.js.map +1 -1
  40. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.d.ts +2 -1
  41. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.d.ts.map +1 -1
  42. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.js +21 -14
  43. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.js.map +1 -1
  44. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.d.ts +3 -1
  45. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.d.ts.map +1 -1
  46. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.js +34 -20
  47. package/dist/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.js.map +1 -1
  48. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.d.ts +2 -1
  49. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.d.ts.map +1 -1
  50. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.js +14 -15
  51. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.js.map +1 -1
  52. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceUpdateStep.d.ts +3 -1
  53. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceUpdateStep.d.ts.map +1 -1
  54. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceUpdateStep.js +6 -36
  55. package/dist/src/components/Device/EditDeviceWizard/steps/DeviceUpdateStep.js.map +1 -1
  56. package/dist/src/components/Device/EditDeviceWizard/steps/GeneralInfoStep.js +1 -1
  57. package/dist/src/components/Device/EditDeviceWizard/steps/GeneralInfoStep.js.map +1 -1
  58. package/dist/src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.js +1 -1
  59. package/dist/src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.js.map +1 -1
  60. package/dist/src/components/Device/EditDeviceWizard/steps/ReviewUpdatePolicy.js +2 -2
  61. package/dist/src/components/Device/EditDeviceWizard/steps/ReviewUpdatePolicy.js.map +1 -1
  62. package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.d.ts +4 -2
  63. package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.d.ts.map +1 -1
  64. package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.js +19 -1
  65. package/dist/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.js.map +1 -1
  66. package/dist/src/components/Device/EditDeviceWizard/utils.d.ts +1 -14
  67. package/dist/src/components/Device/EditDeviceWizard/utils.d.ts.map +1 -1
  68. package/dist/src/components/Device/EditDeviceWizard/utils.js +3 -3
  69. package/dist/src/components/Device/EditDeviceWizard/utils.js.map +1 -1
  70. package/dist/src/components/Device/SystemdUnitsModal/SystemdUnitsModal.d.ts.map +1 -1
  71. package/dist/src/components/Device/SystemdUnitsModal/SystemdUnitsModal.js +28 -26
  72. package/dist/src/components/Device/SystemdUnitsModal/SystemdUnitsModal.js.map +1 -1
  73. package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.d.ts.map +1 -1
  74. package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.js +11 -16
  75. package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.js.map +1 -1
  76. package/dist/src/components/Events/EventItem.d.ts +7 -0
  77. package/dist/src/components/Events/EventItem.d.ts.map +1 -0
  78. package/dist/src/components/Events/EventItem.js +25 -0
  79. package/dist/src/components/Events/EventItem.js.map +1 -0
  80. package/dist/src/components/Events/EventsCard.css +5 -0
  81. package/dist/src/components/Events/EventsCard.d.ts +11 -0
  82. package/dist/src/components/Events/EventsCard.d.ts.map +1 -0
  83. package/dist/src/components/Events/EventsCard.js +81 -0
  84. package/dist/src/components/Events/EventsCard.js.map +1 -0
  85. package/dist/src/components/Events/useEvents.d.ts +21 -0
  86. package/dist/src/components/Events/useEvents.d.ts.map +1 -0
  87. package/dist/src/components/Events/useEvents.js +105 -0
  88. package/dist/src/components/Events/useEvents.js.map +1 -0
  89. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.d.ts.map +1 -1
  90. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.js +27 -9
  91. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizard.js.map +1 -1
  92. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.d.ts +2 -1
  93. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.d.ts.map +1 -1
  94. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.js +13 -2
  95. package/dist/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.js.map +1 -1
  96. package/dist/src/components/Fleet/CreateFleet/fleetSpecUtils.d.ts +3 -33
  97. package/dist/src/components/Fleet/CreateFleet/fleetSpecUtils.d.ts.map +1 -1
  98. package/dist/src/components/Fleet/CreateFleet/fleetSpecUtils.js +7 -21
  99. package/dist/src/components/Fleet/CreateFleet/fleetSpecUtils.js.map +1 -1
  100. package/dist/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.d.ts +4 -2
  101. package/dist/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.d.ts.map +1 -1
  102. package/dist/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.js +10 -1
  103. package/dist/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.js.map +1 -1
  104. package/dist/src/components/Fleet/CreateFleet/steps/GeneralInfoStep.d.ts +5 -3
  105. package/dist/src/components/Fleet/CreateFleet/steps/GeneralInfoStep.d.ts.map +1 -1
  106. package/dist/src/components/Fleet/CreateFleet/steps/GeneralInfoStep.js +4 -4
  107. package/dist/src/components/Fleet/CreateFleet/steps/GeneralInfoStep.js.map +1 -1
  108. package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.d.ts.map +1 -1
  109. package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.js +10 -9
  110. package/dist/src/components/Fleet/CreateFleet/steps/ReviewStep.js.map +1 -1
  111. package/dist/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.d.ts +3 -1
  112. package/dist/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.d.ts.map +1 -1
  113. package/dist/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.js +8 -86
  114. package/dist/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.js.map +1 -1
  115. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.d.ts +3 -1
  116. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.d.ts.map +1 -1
  117. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.js +4 -4
  118. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.js.map +1 -1
  119. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.d.ts +3 -1
  120. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.d.ts.map +1 -1
  121. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.js +16 -13
  122. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.js.map +1 -1
  123. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepUpdatePolicy.d.ts +3 -1
  124. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepUpdatePolicy.d.ts.map +1 -1
  125. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepUpdatePolicy.js +20 -20
  126. package/dist/src/components/Fleet/CreateFleet/steps/UpdateStepUpdatePolicy.js.map +1 -1
  127. package/dist/src/components/Fleet/CreateFleet/utils.d.ts +1 -1
  128. package/dist/src/components/Fleet/CreateFleet/utils.d.ts.map +1 -1
  129. package/dist/src/components/Fleet/CreateFleet/utils.js +37 -23
  130. package/dist/src/components/Fleet/CreateFleet/utils.js.map +1 -1
  131. package/dist/src/components/Fleet/DeleteFleetModal/DeleteFleetModal.d.ts.map +1 -1
  132. package/dist/src/components/Fleet/DeleteFleetModal/DeleteFleetModal.js +20 -16
  133. package/dist/src/components/Fleet/DeleteFleetModal/DeleteFleetModal.js.map +1 -1
  134. package/dist/src/components/Fleet/FleetDetails/FleetDetailsContent.d.ts.map +1 -1
  135. package/dist/src/components/Fleet/FleetDetails/FleetDetailsContent.js +8 -5
  136. package/dist/src/components/Fleet/FleetDetails/FleetDetailsContent.js.map +1 -1
  137. package/dist/src/components/Fleet/FleetDetails/{FleetDetails.d.ts → FleetDetailsPage.d.ts} +1 -1
  138. package/dist/src/components/Fleet/FleetDetails/FleetDetailsPage.d.ts.map +1 -0
  139. package/dist/src/components/Fleet/FleetDetails/{FleetDetails.js → FleetDetailsPage.js} +23 -17
  140. package/dist/src/components/Fleet/FleetDetails/FleetDetailsPage.js.map +1 -0
  141. package/dist/src/components/Fleet/FleetRow.d.ts.map +1 -1
  142. package/dist/src/components/Fleet/FleetRow.js +9 -12
  143. package/dist/src/components/Fleet/FleetRow.js.map +1 -1
  144. package/dist/src/components/Masthead/UserPreferencesModal.d.ts.map +1 -1
  145. package/dist/src/components/Masthead/UserPreferencesModal.js +14 -15
  146. package/dist/src/components/Masthead/UserPreferencesModal.js.map +1 -1
  147. package/dist/src/components/Masthead/UserPreferencesProvider.d.ts +8 -5
  148. package/dist/src/components/Masthead/UserPreferencesProvider.d.ts.map +1 -1
  149. package/dist/src/components/Masthead/UserPreferencesProvider.js +7 -5
  150. package/dist/src/components/Masthead/UserPreferencesProvider.js.map +1 -1
  151. package/dist/src/components/Repository/CreateRepository/CreateRepositoryForm.d.ts.map +1 -1
  152. package/dist/src/components/Repository/CreateRepository/CreateRepositoryForm.js +11 -7
  153. package/dist/src/components/Repository/CreateRepository/CreateRepositoryForm.js.map +1 -1
  154. package/dist/src/components/Repository/CreateRepository/utils.d.ts.map +1 -1
  155. package/dist/src/components/Repository/CreateRepository/utils.js +2 -3
  156. package/dist/src/components/Repository/CreateRepository/utils.js.map +1 -1
  157. package/dist/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.d.ts.map +1 -1
  158. package/dist/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.js +25 -24
  159. package/dist/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.js.map +1 -1
  160. package/dist/src/components/Repository/RepositoryDetails/RepositoryDetails.d.ts.map +1 -1
  161. package/dist/src/components/Repository/RepositoryDetails/RepositoryDetails.js +22 -8
  162. package/dist/src/components/Repository/RepositoryDetails/RepositoryDetails.js.map +1 -1
  163. package/dist/src/components/ResourceSync/RepositoryResourceSyncList.d.ts.map +1 -1
  164. package/dist/src/components/ResourceSync/RepositoryResourceSyncList.js +18 -15
  165. package/dist/src/components/ResourceSync/RepositoryResourceSyncList.js.map +1 -1
  166. package/dist/src/components/common/CodeEditor/CodeEditorTheme.d.ts +5 -0
  167. package/dist/src/components/common/CodeEditor/CodeEditorTheme.d.ts.map +1 -0
  168. package/dist/src/components/common/CodeEditor/CodeEditorTheme.js +52 -0
  169. package/dist/src/components/common/CodeEditor/CodeEditorTheme.js.map +1 -0
  170. package/dist/src/components/common/CodeEditor/Shortcut.css +22 -0
  171. package/dist/src/components/common/CodeEditor/Shortcut.d.ts +20 -0
  172. package/dist/src/components/common/CodeEditor/Shortcut.d.ts.map +1 -0
  173. package/dist/src/components/common/CodeEditor/Shortcut.js +46 -0
  174. package/dist/src/components/common/CodeEditor/Shortcut.js.map +1 -0
  175. package/dist/src/components/common/CodeEditor/YamlEditor.css +12 -0
  176. package/dist/src/components/common/CodeEditor/YamlEditor.d.ts +16 -0
  177. package/dist/src/components/common/CodeEditor/YamlEditor.d.ts.map +1 -0
  178. package/dist/src/components/common/CodeEditor/YamlEditor.js +48 -0
  179. package/dist/src/components/common/CodeEditor/YamlEditor.js.map +1 -0
  180. package/dist/src/components/common/CodeEditor/YamlEditorBase.css +3 -0
  181. package/dist/src/components/common/CodeEditor/YamlEditorBase.d.ts +11 -0
  182. package/dist/src/components/common/CodeEditor/YamlEditorBase.d.ts.map +1 -0
  183. package/dist/src/components/common/CodeEditor/YamlEditorBase.js +75 -0
  184. package/dist/src/components/common/CodeEditor/YamlEditorBase.js.map +1 -0
  185. package/dist/src/components/common/CodeEditor/useShortcutPopover.d.ts +3 -0
  186. package/dist/src/components/common/CodeEditor/useShortcutPopover.d.ts.map +1 -0
  187. package/dist/src/components/common/CodeEditor/useShortcutPopover.js +26 -0
  188. package/dist/src/components/common/CodeEditor/useShortcutPopover.js.map +1 -0
  189. package/dist/src/components/common/LabelsView.d.ts +1 -3
  190. package/dist/src/components/common/LabelsView.d.ts.map +1 -1
  191. package/dist/src/components/common/LabelsView.js +2 -4
  192. package/dist/src/components/common/LabelsView.js.map +1 -1
  193. package/dist/src/components/common/LeaveFormConfirmation.d.ts.map +1 -1
  194. package/dist/src/components/common/LeaveFormConfirmation.js +8 -7
  195. package/dist/src/components/common/LeaveFormConfirmation.js.map +1 -1
  196. package/dist/src/components/common/TechPreviewBadge.d.ts.map +1 -1
  197. package/dist/src/components/common/TechPreviewBadge.js +3 -2
  198. package/dist/src/components/common/TechPreviewBadge.js.map +1 -1
  199. package/dist/src/components/form/FlightCtlActionGroup.d.ts +1 -1
  200. package/dist/src/components/form/FlightCtlActionGroup.d.ts.map +1 -1
  201. package/dist/src/components/form/FlightCtlActionGroup.js.map +1 -1
  202. package/dist/src/components/form/FormSelect.d.ts +4 -2
  203. package/dist/src/components/form/FormSelect.d.ts.map +1 -1
  204. package/dist/src/components/form/FormSelect.js +12 -1
  205. package/dist/src/components/form/FormSelect.js.map +1 -1
  206. package/dist/src/components/form/FormSelectTypeahead.d.ts +4 -3
  207. package/dist/src/components/form/FormSelectTypeahead.d.ts.map +1 -1
  208. package/dist/src/components/form/FormSelectTypeahead.js +18 -1
  209. package/dist/src/components/form/FormSelectTypeahead.js.map +1 -1
  210. package/dist/src/components/form/LabelsField.d.ts +4 -3
  211. package/dist/src/components/form/LabelsField.d.ts.map +1 -1
  212. package/dist/src/components/form/LabelsField.js +15 -5
  213. package/dist/src/components/form/LabelsField.js.map +1 -1
  214. package/dist/src/components/form/NameField.d.ts +2 -2
  215. package/dist/src/components/form/NameField.d.ts.map +1 -1
  216. package/dist/src/components/form/NameField.js +14 -4
  217. package/dist/src/components/form/NameField.js.map +1 -1
  218. package/dist/src/components/form/RichValidationTextField.d.ts +2 -2
  219. package/dist/src/components/form/RichValidationTextField.d.ts.map +1 -1
  220. package/dist/src/components/form/RichValidationTextField.js +13 -1
  221. package/dist/src/components/form/RichValidationTextField.js.map +1 -1
  222. package/dist/src/components/form/TextListField.d.ts +4 -2
  223. package/dist/src/components/form/TextListField.d.ts.map +1 -1
  224. package/dist/src/components/form/TextListField.js +13 -3
  225. package/dist/src/components/form/TextListField.js.map +1 -1
  226. package/dist/src/components/form/UploadField.d.ts +3 -2
  227. package/dist/src/components/form/UploadField.d.ts.map +1 -1
  228. package/dist/src/components/form/UploadField.js +10 -1
  229. package/dist/src/components/form/UploadField.js.map +1 -1
  230. package/dist/src/components/form/validations.js +1 -1
  231. package/dist/src/components/form/validations.js.map +1 -1
  232. package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.d.ts.map +1 -1
  233. package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.js +4 -1
  234. package/dist/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.js.map +1 -1
  235. package/dist/src/components/modals/CreateRepositoryModal/CreateRepositoryModal.d.ts.map +1 -1
  236. package/dist/src/components/modals/CreateRepositoryModal/CreateRepositoryModal.js +5 -3
  237. package/dist/src/components/modals/CreateRepositoryModal/CreateRepositoryModal.js.map +1 -1
  238. package/dist/src/components/modals/DecommissionModal/DecommissionModal.d.ts.map +1 -1
  239. package/dist/src/components/modals/DecommissionModal/DecommissionModal.js +32 -29
  240. package/dist/src/components/modals/DecommissionModal/DecommissionModal.js.map +1 -1
  241. package/dist/src/components/modals/DeleteModal/DeleteModal.d.ts.map +1 -1
  242. package/dist/src/components/modals/DeleteModal/DeleteModal.js +18 -15
  243. package/dist/src/components/modals/DeleteModal/DeleteModal.js.map +1 -1
  244. package/dist/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.d.ts.map +1 -1
  245. package/dist/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.js +33 -30
  246. package/dist/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.js.map +1 -1
  247. package/dist/src/components/modals/massModals/MassDecommissionDeviceModal/MassDecommissionDeviceModal.d.ts.map +1 -1
  248. package/dist/src/components/modals/massModals/MassDecommissionDeviceModal/MassDecommissionDeviceModal.js +27 -24
  249. package/dist/src/components/modals/massModals/MassDecommissionDeviceModal/MassDecommissionDeviceModal.js.map +1 -1
  250. package/dist/src/components/modals/massModals/MassDeleteDeviceModal/MassDeleteDeviceModal.d.ts.map +1 -1
  251. package/dist/src/components/modals/massModals/MassDeleteDeviceModal/MassDeleteDeviceModal.js +26 -23
  252. package/dist/src/components/modals/massModals/MassDeleteDeviceModal/MassDeleteDeviceModal.js.map +1 -1
  253. package/dist/src/components/modals/massModals/MassDeleteFleetModal/MassDeleteFleetModal.d.ts.map +1 -1
  254. package/dist/src/components/modals/massModals/MassDeleteFleetModal/MassDeleteFleetModal.js +30 -25
  255. package/dist/src/components/modals/massModals/MassDeleteFleetModal/MassDeleteFleetModal.js.map +1 -1
  256. package/dist/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.d.ts.map +1 -1
  257. package/dist/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.js +29 -26
  258. package/dist/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.js.map +1 -1
  259. package/dist/src/components/modals/massModals/MassDeleteResourceSyncModal/MassDeleteResourceSyncModal.d.ts +1 -1
  260. package/dist/src/components/modals/massModals/MassDeleteResourceSyncModal/MassDeleteResourceSyncModal.d.ts.map +1 -1
  261. package/dist/src/components/modals/massModals/MassDeleteResourceSyncModal/MassDeleteResourceSyncModal.js +28 -25
  262. package/dist/src/components/modals/massModals/MassDeleteResourceSyncModal/MassDeleteResourceSyncModal.js.map +1 -1
  263. package/dist/src/constants.d.ts +2 -1
  264. package/dist/src/constants.d.ts.map +1 -1
  265. package/dist/src/constants.js +3 -1
  266. package/dist/src/constants.js.map +1 -1
  267. package/dist/src/hooks/useAppLinks.d.ts +5 -0
  268. package/dist/src/hooks/useAppLinks.d.ts.map +1 -0
  269. package/dist/src/hooks/useAppLinks.js +45 -0
  270. package/dist/src/hooks/useAppLinks.js.map +1 -0
  271. package/dist/src/{components/EnrollmentRequest/EnrollmentRequestDetails/useEnrollmentRequestSystemInfo.d.ts → hooks/useDeviceSpecSystemInfo.d.ts} +2 -2
  272. package/dist/src/hooks/useDeviceSpecSystemInfo.d.ts.map +1 -0
  273. package/dist/src/{components/EnrollmentRequest/EnrollmentRequestDetails/useEnrollmentRequestSystemInfo.js → hooks/useDeviceSpecSystemInfo.js} +18 -10
  274. package/dist/src/hooks/useDeviceSpecSystemInfo.js.map +1 -0
  275. package/dist/src/hooks/useFetchPeriodically.d.ts +2 -2
  276. package/dist/src/hooks/useFetchPeriodically.d.ts.map +1 -1
  277. package/dist/src/hooks/useFetchPeriodically.js +1 -1
  278. package/dist/src/hooks/useFetchPeriodically.js.map +1 -1
  279. package/dist/src/hooks/useThemePreferences.d.ts +6 -3
  280. package/dist/src/hooks/useThemePreferences.d.ts.map +1 -1
  281. package/dist/src/hooks/useThemePreferences.js +46 -23
  282. package/dist/src/hooks/useThemePreferences.js.map +1 -1
  283. package/dist/src/types/deviceSpec.d.ts +7 -1
  284. package/dist/src/types/deviceSpec.d.ts.map +1 -1
  285. package/dist/src/types/deviceSpec.js +16 -12
  286. package/dist/src/types/deviceSpec.js.map +1 -1
  287. package/dist/src/types/extraTypes.d.ts +3 -2
  288. package/dist/src/types/extraTypes.d.ts.map +1 -1
  289. package/dist/src/types/extraTypes.js.map +1 -1
  290. package/dist/src/utils/dates.d.ts +2 -1
  291. package/dist/src/utils/dates.d.ts.map +1 -1
  292. package/dist/src/utils/dates.js +20 -20
  293. package/dist/src/utils/dates.js.map +1 -1
  294. package/dist/src/utils/patch.d.ts.map +1 -1
  295. package/dist/src/utils/patch.js +2 -1
  296. package/dist/src/utils/patch.js.map +1 -1
  297. package/package.json +6 -2
  298. package/src/components/DetailsPage/DetailsPageActions.tsx +2 -1
  299. package/src/components/Device/AddDeviceModal/AddDeviceModal.tsx +27 -22
  300. package/src/components/Device/DeviceDetails/DeviceDetailsPage.tsx +10 -19
  301. package/src/components/Device/DeviceDetails/DeviceDetailsTab.tsx +65 -21
  302. package/src/components/Device/DevicesPage/DecommissionedDevicesTable.tsx +2 -2
  303. package/src/components/Device/DevicesPage/EnrolledDevicesTable.tsx +2 -2
  304. package/src/components/Device/EditDeviceWizard/EditDeviceWizard.tsx +6 -1
  305. package/src/components/Device/EditDeviceWizard/deviceSpecUtils.ts +28 -1
  306. package/src/components/Device/EditDeviceWizard/steps/ApplicationImageForm.tsx +19 -5
  307. package/src/components/Device/EditDeviceWizard/steps/ApplicationInlineForm.tsx +53 -23
  308. package/src/components/Device/EditDeviceWizard/steps/ApplicationTemplates.tsx +68 -53
  309. package/src/components/Device/EditDeviceWizard/steps/ConfigInlineTemplateForm.tsx +40 -25
  310. package/src/components/Device/EditDeviceWizard/steps/ConfigWithRepositoryTemplateForm.tsx +39 -5
  311. package/src/components/Device/EditDeviceWizard/steps/ConfigurationTemplates.tsx +81 -38
  312. package/src/components/Device/EditDeviceWizard/steps/DeviceTemplateStep.tsx +15 -19
  313. package/src/components/Device/EditDeviceWizard/steps/DeviceUpdateStep.tsx +7 -47
  314. package/src/components/Device/EditDeviceWizard/steps/GeneralInfoStep.tsx +1 -1
  315. package/src/components/Device/EditDeviceWizard/steps/ReviewDeviceStep.tsx +1 -1
  316. package/src/components/Device/EditDeviceWizard/steps/ReviewUpdatePolicy.tsx +2 -2
  317. package/src/components/Device/EditDeviceWizard/steps/SystemdUnitsForm.tsx +30 -2
  318. package/src/components/Device/EditDeviceWizard/utils.ts +6 -7
  319. package/src/components/Device/SystemdUnitsModal/SystemdUnitsModal.tsx +38 -35
  320. package/src/components/EnrollmentRequest/EnrollmentRequestDetails/EnrollmentRequestDetails.tsx +8 -19
  321. package/src/components/Events/EventItem.tsx +38 -0
  322. package/src/components/Events/EventsCard.css +5 -0
  323. package/src/components/Events/EventsCard.tsx +157 -0
  324. package/src/components/Events/useEvents.ts +136 -0
  325. package/src/components/Fleet/CreateFleet/CreateFleetWizard.tsx +29 -13
  326. package/src/components/Fleet/CreateFleet/CreateFleetWizardFooter.tsx +25 -10
  327. package/src/components/Fleet/CreateFleet/fleetSpecUtils.ts +9 -23
  328. package/src/components/Fleet/CreateFleet/steps/DeviceLabelSelector.tsx +12 -1
  329. package/src/components/Fleet/CreateFleet/steps/GeneralInfoStep.tsx +10 -5
  330. package/src/components/Fleet/CreateFleet/steps/ReviewStep.tsx +20 -17
  331. package/src/components/Fleet/CreateFleet/steps/UpdatePolicyStep.tsx +18 -122
  332. package/src/components/Fleet/CreateFleet/steps/UpdateStepDisruptionBudget.tsx +4 -1
  333. package/src/components/Fleet/CreateFleet/steps/UpdateStepRolloutPolicy.tsx +50 -31
  334. package/src/components/Fleet/CreateFleet/steps/UpdateStepUpdatePolicy.tsx +57 -12
  335. package/src/components/Fleet/CreateFleet/utils.ts +40 -22
  336. package/src/components/Fleet/DeleteFleetModal/DeleteFleetModal.tsx +28 -28
  337. package/src/components/Fleet/FleetDetails/FleetDetailsContent.tsx +10 -9
  338. package/src/components/Fleet/FleetDetails/{FleetDetails.tsx → FleetDetailsPage.tsx} +40 -25
  339. package/src/components/Fleet/FleetRow.tsx +10 -11
  340. package/src/components/Masthead/UserPreferencesModal.tsx +43 -56
  341. package/src/components/Masthead/UserPreferencesProvider.tsx +15 -10
  342. package/src/components/Repository/CreateRepository/CreateRepositoryForm.tsx +14 -15
  343. package/src/components/Repository/CreateRepository/utils.ts +2 -3
  344. package/src/components/Repository/RepositoryDetails/DeleteRepositoryModal.tsx +54 -55
  345. package/src/components/Repository/RepositoryDetails/RepositoryDetails.tsx +47 -14
  346. package/src/components/ResourceSync/RepositoryResourceSyncList.tsx +28 -25
  347. package/src/components/common/CodeEditor/CodeEditorTheme.ts +53 -0
  348. package/src/components/common/CodeEditor/Shortcut.css +22 -0
  349. package/src/components/common/CodeEditor/Shortcut.tsx +90 -0
  350. package/src/components/common/CodeEditor/YamlEditor.css +12 -0
  351. package/src/components/common/CodeEditor/YamlEditor.tsx +81 -0
  352. package/src/components/common/CodeEditor/YamlEditorBase.css +3 -0
  353. package/src/components/common/CodeEditor/YamlEditorBase.tsx +124 -0
  354. package/src/components/common/CodeEditor/useShortcutPopover.tsx +39 -0
  355. package/src/components/common/LabelsView.tsx +2 -11
  356. package/src/components/common/LeaveFormConfirmation.tsx +14 -18
  357. package/src/components/common/TechPreviewBadge.tsx +3 -1
  358. package/src/components/form/FlightCtlActionGroup.tsx +1 -1
  359. package/src/components/form/FormSelect.tsx +14 -3
  360. package/src/components/form/FormSelectTypeahead.tsx +24 -3
  361. package/src/components/form/LabelsField.tsx +20 -20
  362. package/src/components/form/NameField.tsx +18 -4
  363. package/src/components/form/RichValidationTextField.tsx +20 -1
  364. package/src/components/form/TextListField.tsx +19 -3
  365. package/src/components/form/UploadField.tsx +16 -2
  366. package/src/components/form/validations.ts +1 -1
  367. package/src/components/modals/ApproveDeviceModal/ApproveDeviceModal.tsx +12 -7
  368. package/src/components/modals/CreateRepositoryModal/CreateRepositoryModal.tsx +6 -3
  369. package/src/components/modals/DecommissionModal/DecommissionModal.tsx +60 -56
  370. package/src/components/modals/DeleteModal/DeleteModal.tsx +25 -27
  371. package/src/components/modals/massModals/MassApproveDeviceModal/MassApproveDeviceModal.tsx +81 -92
  372. package/src/components/modals/massModals/MassDecommissionDeviceModal/MassDecommissionDeviceModal.tsx +64 -67
  373. package/src/components/modals/massModals/MassDeleteDeviceModal/MassDeleteDeviceModal.tsx +60 -62
  374. package/src/components/modals/massModals/MassDeleteFleetModal/MassDeleteFleetModal.tsx +80 -87
  375. package/src/components/modals/massModals/MassDeleteRepositoryModal/MassDeleteRepositoryModal.tsx +70 -73
  376. package/src/components/modals/massModals/MassDeleteResourceSyncModal/MassDeleteResourceSyncModal.tsx +62 -63
  377. package/src/constants.ts +2 -1
  378. package/src/hooks/useAppLinks.ts +49 -0
  379. package/src/{components/EnrollmentRequest/EnrollmentRequestDetails/useEnrollmentRequestSystemInfo.tsx → hooks/useDeviceSpecSystemInfo.tsx} +15 -7
  380. package/src/hooks/useFetchPeriodically.ts +3 -3
  381. package/src/hooks/useThemePreferences.ts +48 -21
  382. package/src/types/deviceSpec.ts +25 -12
  383. package/src/types/extraTypes.ts +7 -4
  384. package/src/utils/dates.ts +23 -24
  385. package/src/utils/patch.ts +3 -1
  386. package/dist/src/components/Device/DeviceDetails/DeviceStatusDebugModal.css +0 -3
  387. package/dist/src/components/Device/DeviceDetails/DeviceStatusDebugModal.d.ts +0 -9
  388. package/dist/src/components/Device/DeviceDetails/DeviceStatusDebugModal.d.ts.map +0 -1
  389. package/dist/src/components/Device/DeviceDetails/DeviceStatusDebugModal.js +0 -34
  390. package/dist/src/components/Device/DeviceDetails/DeviceStatusDebugModal.js.map +0 -1
  391. package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/useEnrollmentRequestSystemInfo.d.ts.map +0 -1
  392. package/dist/src/components/EnrollmentRequest/EnrollmentRequestDetails/useEnrollmentRequestSystemInfo.js.map +0 -1
  393. package/dist/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.d.ts +0 -9
  394. package/dist/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.d.ts.map +0 -1
  395. package/dist/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.js +0 -61
  396. package/dist/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.js.map +0 -1
  397. package/dist/src/components/Fleet/FleetDetails/FleetDetails.d.ts.map +0 -1
  398. package/dist/src/components/Fleet/FleetDetails/FleetDetails.js.map +0 -1
  399. package/dist/src/components/common/LabelsView.css +0 -9
  400. package/dist/src/links.d.ts +0 -7
  401. package/dist/src/links.d.ts.map +0 -1
  402. package/dist/src/links.js +0 -14
  403. package/dist/src/links.js.map +0 -1
  404. package/src/components/Device/DeviceDetails/DeviceStatusDebugModal.css +0 -3
  405. package/src/components/Device/DeviceDetails/DeviceStatusDebugModal.tsx +0 -60
  406. package/src/components/Fleet/CreateFleet/steps/UpdateConfirmChangesModal.tsx +0 -96
  407. package/src/components/common/LabelsView.css +0 -9
  408. package/src/links.ts +0 -16
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react';
2
- import { useEffect } from 'react';
3
- import { Alert, Button, Modal, Spinner, Stack, StackItem, Text, TextContent } from '@patternfly/react-core';
4
2
  import { Trans } from 'react-i18next';
3
+ import { Alert, Button, Spinner, Stack, StackItem, Text, TextContent } from '@patternfly/react-core';
4
+ import { Modal, ModalBody, ModalFooter, ModalHeader } from '@patternfly/react-core/next';
5
5
 
6
6
  import { ResourceSyncList } from '@flightctl/types';
7
7
 
@@ -63,7 +63,7 @@ const DeleteRepositoryModal = ({ repositoryId, onClose, onDeleteSuccess }: Delet
63
63
  // eslint-disable-next-line react-hooks/exhaustive-deps
64
64
  }, [get, repositoryId]);
65
65
 
66
- useEffect(() => {
66
+ React.useEffect(() => {
67
67
  void loadRS();
68
68
  }, [loadRS]);
69
69
 
@@ -83,14 +83,54 @@ const DeleteRepositoryModal = ({ repositoryId, onClose, onDeleteSuccess }: Delet
83
83
  };
84
84
 
85
85
  return (
86
- <Modal
87
- title={t('Delete repository ?')}
88
- isOpen
89
- titleIconVariant="warning"
90
- onClose={onClose}
91
- variant={hasResourceSyncs ? 'medium' : 'small'}
92
- actions={[
93
- rsError ? (
86
+ <Modal isOpen onClose={onClose} variant={hasResourceSyncs ? 'medium' : 'small'}>
87
+ <ModalHeader title={t('Delete repository ?')} titleIconVariant="warning" />
88
+ <ModalBody>
89
+ <Stack hasGutter>
90
+ {hasResourceSyncs && (
91
+ <StackItem>
92
+ <TextContent>
93
+ <Text>
94
+ {t(
95
+ 'This repository defines resource syncs. By deleting the repository, its resource syncs will also be deleted.',
96
+ )}
97
+ </Text>
98
+ <Text>
99
+ {t(
100
+ `Any fleet that is being managed by this repository's resource syncs, will stop being managed by the service.`,
101
+ )}
102
+ </Text>
103
+ </TextContent>
104
+ </StackItem>
105
+ )}
106
+ {rsError ? (
107
+ <Alert isInline variant="warning" title={t('Cannot delete repository')}>
108
+ {rsError}
109
+ </Alert>
110
+ ) : (
111
+ <StackItem>
112
+ <Trans t={t}>
113
+ Are you sure you want to delete the repository <b>{repositoryId}</b>?
114
+ </Trans>
115
+ </StackItem>
116
+ )}
117
+ {(isDeleting && message) ||
118
+ (isLoadingRSs && (
119
+ <StackItem>
120
+ <Spinner size="sm" /> {isLoadingRSs ? t('Checking if the repository has resource syncs') : message}
121
+ </StackItem>
122
+ ))}
123
+ {error && (
124
+ <StackItem>
125
+ <Alert isInline variant="danger" title={t('An error occurred')}>
126
+ {error}
127
+ </Alert>
128
+ </StackItem>
129
+ )}
130
+ </Stack>
131
+ </ModalBody>
132
+ <ModalFooter>
133
+ {rsError ? (
94
134
  <Button variant="primary" onClick={loadRS}>
95
135
  {t('Reload resource syncs')}
96
136
  </Button>
@@ -105,52 +145,11 @@ const DeleteRepositoryModal = ({ repositoryId, onClose, onDeleteSuccess }: Delet
105
145
  >
106
146
  {t('Delete repository')}
107
147
  </Button>
108
- ),
148
+ )}
109
149
  <Button key="cancel" variant="link" onClick={onClose} isDisabled={isDeleting}>
110
150
  {t('Cancel')}
111
- </Button>,
112
- ]}
113
- >
114
- <Stack hasGutter>
115
- {hasResourceSyncs && (
116
- <StackItem>
117
- <TextContent>
118
- <Text>
119
- {t(
120
- 'This repository defines resource syncs. By deleting the repository, its resource syncs will also be deleted.',
121
- )}
122
- {t(
123
- `Any fleet that is being managed by this repository's resource syncs, will stop being managed by the service.`,
124
- )}
125
- </Text>
126
- </TextContent>
127
- </StackItem>
128
- )}
129
- {rsError ? (
130
- <Alert isInline variant="warning" title={t('Cannot delete repository')}>
131
- {rsError}
132
- </Alert>
133
- ) : (
134
- <StackItem>
135
- <Trans t={t}>
136
- Are you sure you want to delete the repository <b>{repositoryId}</b>?
137
- </Trans>
138
- </StackItem>
139
- )}
140
- {(isDeleting && message) ||
141
- (isLoadingRSs && (
142
- <StackItem>
143
- <Spinner size="sm" /> {isLoadingRSs ? t('Checking if the repository has resource syncs') : message}
144
- </StackItem>
145
- ))}
146
- {error && (
147
- <StackItem>
148
- <Alert isInline variant="danger" title={t('An error occurred')}>
149
- {error}
150
- </Alert>
151
- </StackItem>
152
- )}
153
- </Stack>
151
+ </Button>
152
+ </ModalFooter>
154
153
  </Modal>
155
154
  );
156
155
  };
@@ -1,8 +1,8 @@
1
1
  import * as React from 'react';
2
- import { DropdownItem, DropdownList, Grid, GridItem } from '@patternfly/react-core';
2
+ import { Card, CardBody, DropdownItem, DropdownList, Grid, GridItem, Nav, NavList } from '@patternfly/react-core';
3
3
 
4
4
  import { useFetchPeriodically } from '../../../hooks/useFetchPeriodically';
5
- import { RepoSpecType, Repository } from '@flightctl/types';
5
+ import { RepoSpecType, Repository, ResourceKind } from '@flightctl/types';
6
6
 
7
7
  import DetailsPage from '../../DetailsPage/DetailsPage';
8
8
  import DetailsPageActions from '../../DetailsPage/DetailsPageActions';
@@ -15,14 +15,17 @@ import { useAppContext } from '../../../hooks/useAppContext';
15
15
  import { useAccessReview } from '../../../hooks/useAccessReview';
16
16
  import { RESOURCE, VERB } from '../../../types/rbac';
17
17
  import PageWithPermissions from '../../common/PageWithPermissions';
18
+ import YamlEditor from '../../common/CodeEditor/YamlEditor';
19
+ import EventsCard from '../../Events/EventsCard';
20
+ import NavItem from '../../NavItem/NavItem';
18
21
 
19
22
  const RepositoryDetails = () => {
20
23
  const { t } = useTranslation();
21
24
  const {
22
- router: { useParams },
25
+ router: { useParams, Routes, Route, Navigate },
23
26
  } = useAppContext();
24
27
  const { repositoryId } = useParams() as { repositoryId: string };
25
- const [repoDetails, isLoading, error] = useFetchPeriodically<Required<Repository>>({
28
+ const [repoDetails, isLoading, error, refetch] = useFetchPeriodically<Required<Repository>>({
26
29
  endpoint: `repositories/${repositoryId}`,
27
30
  });
28
31
  const [isDeleteModalOpen, setIsDeleteModalOpen] = React.useState<boolean>(false);
@@ -62,19 +65,49 @@ const RepositoryDetails = () => {
62
65
  </DetailsPageActions>
63
66
  )
64
67
  }
68
+ nav={
69
+ <Nav variant="tertiary">
70
+ <NavList>
71
+ <NavItem to="details">{t('Details')}</NavItem>
72
+ <NavItem to="yaml">{t('YAML')}</NavItem>
73
+ </NavList>
74
+ </Nav>
75
+ }
65
76
  >
66
77
  {repoDetails && (
67
78
  <>
68
- <Grid hasGutter>
69
- <GridItem>
70
- <RepositoryGeneralDetailsCard repoDetails={repoDetails} />
71
- </GridItem>
72
- {canListRS && repoDetails.spec.type !== RepoSpecType.HTTP && (
73
- <GridItem>
74
- <RepositoryResourceSyncsCard repositoryId={repositoryId} />
75
- </GridItem>
76
- )}
77
- </Grid>
79
+ <Routes>
80
+ <Route index element={<Navigate to="details" replace />} />
81
+
82
+ <Route
83
+ path="details"
84
+ element={
85
+ <Grid hasGutter>
86
+ <GridItem md={9}>
87
+ <Card>
88
+ <CardBody>
89
+ <RepositoryGeneralDetailsCard repoDetails={repoDetails} />
90
+ </CardBody>
91
+ </Card>
92
+ {canListRS && repoDetails.spec.type !== RepoSpecType.HTTP && (
93
+ <Card>
94
+ <CardBody>
95
+ <RepositoryResourceSyncsCard repositoryId={repositoryId} />
96
+ </CardBody>
97
+ </Card>
98
+ )}
99
+ </GridItem>
100
+ <GridItem md={3}>
101
+ <EventsCard kind={ResourceKind.REPOSITORY} objId={repositoryId} />
102
+ </GridItem>
103
+ </Grid>
104
+ }
105
+ />
106
+ <Route
107
+ path="yaml"
108
+ element={<YamlEditor filename={repositoryId} apiObj={repoDetails} refetch={refetch} />}
109
+ />
110
+ </Routes>
78
111
  {isDeleteModalOpen && (
79
112
  <DeleteRepositoryModal
80
113
  onClose={() => setIsDeleteModalOpen(false)}
@@ -6,12 +6,12 @@ import {
6
6
  EmptyStateActions,
7
7
  EmptyStateBody,
8
8
  EmptyStateFooter,
9
- Modal,
10
9
  Toolbar,
11
10
  ToolbarContent,
12
11
  ToolbarGroup,
13
12
  ToolbarItem,
14
13
  } from '@patternfly/react-core';
14
+ import { Modal, ModalBody, ModalHeader } from '@patternfly/react-core/next';
15
15
  import { TFunction } from 'i18next';
16
16
  import { PlusCircleIcon } from '@patternfly/react-icons/dist/js/icons/plus-circle-icon';
17
17
  import { CodeBranchIcon } from '@patternfly/react-icons/dist/js/icons/code-branch-icon';
@@ -136,30 +136,33 @@ const CreateResourceSyncModal = ({
136
136
  const [submitError, setSubmitError] = React.useState<string | undefined>();
137
137
 
138
138
  return (
139
- <Modal variant="medium" title={t('Add a resource sync')} onClose={() => onClose()} isOpen>
140
- <Formik<SingleResourceSyncValues>
141
- initialValues={{ resourceSyncs: [{ name: '', targetRevision: '', path: '' }] }}
142
- validationSchema={singleResourceSyncSchema(t, storedRSs)}
143
- onSubmit={async (values: SingleResourceSyncValues) => {
144
- const rsToAdd = getResourceSync(repositoryId, values.resourceSyncs[0]);
145
- try {
146
- await post<ResourceSync>('resourcesyncs', rsToAdd);
147
- setSubmitError(undefined);
148
- onClose(true);
149
- } catch (e) {
150
- setSubmitError(getErrorMessage(e));
151
- }
152
- }}
153
- >
154
- <>
155
- <CreateResourceSyncModalForm onClose={onClose} />
156
- {submitError && (
157
- <Alert variant="danger" title={t('Unexpected error occurred')} isInline>
158
- {submitError}
159
- </Alert>
160
- )}
161
- </>
162
- </Formik>
139
+ <Modal variant="medium" onClose={() => onClose()} isOpen>
140
+ <ModalHeader title={t('Add a resource sync')} />
141
+ <ModalBody>
142
+ <Formik<SingleResourceSyncValues>
143
+ initialValues={{ resourceSyncs: [{ name: '', targetRevision: '', path: '' }] }}
144
+ validationSchema={singleResourceSyncSchema(t, storedRSs)}
145
+ onSubmit={async (values: SingleResourceSyncValues) => {
146
+ const rsToAdd = getResourceSync(repositoryId, values.resourceSyncs[0]);
147
+ try {
148
+ await post<ResourceSync>('resourcesyncs', rsToAdd);
149
+ setSubmitError(undefined);
150
+ onClose(true);
151
+ } catch (e) {
152
+ setSubmitError(getErrorMessage(e));
153
+ }
154
+ }}
155
+ >
156
+ <>
157
+ <CreateResourceSyncModalForm onClose={onClose} />
158
+ {submitError && (
159
+ <Alert variant="danger" title={t('Unexpected error occurred')} isInline>
160
+ {submitError}
161
+ </Alert>
162
+ )}
163
+ </>
164
+ </Formik>
165
+ </ModalBody>
163
166
  </Modal>
164
167
  );
165
168
  };
@@ -0,0 +1,53 @@
1
+ import * as monacoEditor from 'monaco-editor';
2
+
3
+ type Monaco = typeof monacoEditor;
4
+
5
+ // TODO import from PF6 react-tokens. These are not available in PF5
6
+ const t_color_green_70 = '#204d00';
7
+ const t_color_white = '#ffffff';
8
+ const t_color_black = '#000000';
9
+ const t_color_gray_60 = '#4d4d4d';
10
+ const t_color_yellow_70 = '#73480b';
11
+ const t_color_yellow_30 = '#ffcc17';
12
+ const t_color_green_30 = '#afdc8f';
13
+ const t_color_blue_30 = '#92c5f9';
14
+ const t_color_blue_70 = '#003366';
15
+ const t_color_purple_70 = '#21134d';
16
+ const t_color_purple_30 = '#b6a6e9';
17
+ const t_color_gray_90 = '#1f1f1f';
18
+ const t_color_gray_20 = '#e0e0e0';
19
+
20
+ // Defines the same color scheme as in the OCP console
21
+ export const defineConsoleThemes = (monaco: Monaco) => {
22
+ monaco.editor.defineTheme('console-light', {
23
+ base: 'vs',
24
+ inherit: true,
25
+ colors: {
26
+ 'editor.background': t_color_white,
27
+ 'editorLineNumber.activeForeground': t_color_black,
28
+ 'editorLineNumber.foreground': t_color_gray_60,
29
+ },
30
+ rules: [
31
+ { token: 'number', foreground: t_color_green_70 },
32
+ { token: 'type', foreground: t_color_yellow_70 },
33
+ { token: 'string', foreground: t_color_blue_70 },
34
+ { token: 'keyword', foreground: t_color_purple_70 },
35
+ ],
36
+ });
37
+
38
+ monaco.editor.defineTheme('console-dark', {
39
+ base: 'vs-dark',
40
+ inherit: true,
41
+ colors: {
42
+ 'editor.background': t_color_gray_90,
43
+ 'editorLineNumber.activeForeground': t_color_white,
44
+ 'editorLineNumber.foreground': t_color_gray_20,
45
+ },
46
+ rules: [
47
+ { token: 'number', foreground: t_color_green_30 },
48
+ { token: 'type', foreground: t_color_blue_30 },
49
+ { token: 'string', foreground: t_color_yellow_30 },
50
+ { token: 'keyword', foreground: t_color_purple_30 },
51
+ ],
52
+ });
53
+ };
@@ -0,0 +1,22 @@
1
+ .fctl-shortcut__cell {
2
+ padding-bottom: var(--pf-v5-global--spacer--md);
3
+ }
4
+
5
+ .fctl-shortcut__cell:first-child {
6
+ padding-right: var(--pf-v5-global--spacer--md);
7
+ text-align: right;
8
+ white-space: nowrap;
9
+ vertical-align: top;
10
+ }
11
+
12
+ .fctl-shortcut__command:not(:last-child):after {
13
+ content: ' + ';
14
+ }
15
+
16
+ .fctl-shortcut__command-key {
17
+ border: var(--pf-v5-global--BorderWidth--sm) solid var(--pf-v5-global--BorderColor--100);
18
+ border-radius: 3px;
19
+ color: var(--pf-v5-global--Color--200);
20
+ font-size: var(--pf-v5-global--FontSize--sm);
21
+ padding: 1px 3px;
22
+ }
@@ -0,0 +1,90 @@
1
+ import * as React from 'react';
2
+ import { MouseIcon } from '@patternfly/react-icons/dist/js/icons/mouse-icon';
3
+ import upperFirst from 'lodash/upperFirst';
4
+
5
+ import { useTranslation } from '../../../hooks/useTranslation';
6
+
7
+ import './Shortcut.css';
8
+
9
+ interface ShortcutProps {
10
+ children: React.ReactNode;
11
+ alt?: boolean;
12
+ click?: boolean;
13
+ ctrl?: boolean;
14
+ ctrlCmd?: boolean;
15
+ drag?: boolean;
16
+ hover?: boolean;
17
+ keyName?: string;
18
+ rightClick?: boolean;
19
+ shift?: boolean;
20
+ dragNdrop?: boolean;
21
+ }
22
+
23
+ export const ShortcutCommand = ({ children }: React.PropsWithChildren) => (
24
+ <span className="fctl-shortcut__command">
25
+ <kbd className="fctl-shortcut__command-key">{children}</kbd>
26
+ </span>
27
+ );
28
+
29
+ export const isMac = window.navigator.platform.includes('Mac');
30
+
31
+ const Shortcut = ({
32
+ children,
33
+ alt,
34
+ click,
35
+ ctrl,
36
+ ctrlCmd,
37
+ drag,
38
+ hover,
39
+ keyName,
40
+ rightClick,
41
+ shift,
42
+ dragNdrop,
43
+ }: ShortcutProps) => {
44
+ const { t } = useTranslation();
45
+ return (
46
+ <tr role="row">
47
+ <td className="fctl-shortcut__cell" role="cell">
48
+ {(ctrl || (!isMac && ctrlCmd)) && <ShortcutCommand>Ctrl</ShortcutCommand>}
49
+ {alt && <ShortcutCommand>{isMac ? '⌥ Opt' : 'Alt'}</ShortcutCommand>}
50
+ {shift && <ShortcutCommand>Shift</ShortcutCommand>}
51
+ {isMac && ctrlCmd && <ShortcutCommand>⌘ Cmd</ShortcutCommand>}
52
+ {hover && (
53
+ <ShortcutCommand>
54
+ <MouseIcon /> {t('Hover')}
55
+ </ShortcutCommand>
56
+ )}
57
+ {keyName && (
58
+ <ShortcutCommand>
59
+ {keyName.length === 1 ? keyName.toUpperCase() : upperFirst(keyName.toLowerCase())}
60
+ </ShortcutCommand>
61
+ )}
62
+ {drag && (
63
+ <ShortcutCommand>
64
+ <MouseIcon /> {t('Drag')}
65
+ </ShortcutCommand>
66
+ )}
67
+ {click && (
68
+ <ShortcutCommand>
69
+ <MouseIcon /> {t('Click')}
70
+ </ShortcutCommand>
71
+ )}
72
+ {rightClick && (
73
+ <ShortcutCommand>
74
+ <MouseIcon /> {t('Right click')}
75
+ </ShortcutCommand>
76
+ )}
77
+ {dragNdrop && (
78
+ <ShortcutCommand>
79
+ <MouseIcon /> {t('Drag + Drop')}
80
+ </ShortcutCommand>
81
+ )}
82
+ </td>
83
+ <td className="fctl-shortcut__cell" role="cell">
84
+ {children}
85
+ </td>
86
+ </tr>
87
+ );
88
+ };
89
+
90
+ export default Shortcut;
@@ -0,0 +1,12 @@
1
+ .fctl-yaml-editor .monaco-editor {
2
+ min-height: 70vh;
3
+ }
4
+
5
+ /* Style of the bar with the line numbers for light and dark themes */
6
+ .fctl-yaml-editor .monaco-editor .margin {
7
+ --vscode-editorGutter-background: #f5f5f5;
8
+ }
9
+
10
+ .pf-v5-theme-dark .fctl-yaml-editor .monaco-editor .margin {
11
+ --vscode-editorGutter-background: #292e34;
12
+ }
@@ -0,0 +1,81 @@
1
+ import * as React from 'react';
2
+ import { Alert } from '@patternfly/react-core';
3
+ import { CodeEditorProps as PfCodeEditorProps } from '@patternfly/react-code-editor';
4
+ import { dump } from 'js-yaml';
5
+
6
+ import { Device, Fleet, Repository } from '@flightctl/types';
7
+ import { useTranslation } from '../../../hooks/useTranslation';
8
+ import { useAppContext } from '../../../hooks/useAppContext';
9
+ import YamlEditorBase from './YamlEditorBase';
10
+
11
+ import './YamlEditor.css';
12
+
13
+ type FlightCtlYamlResource = Fleet | Device | Repository;
14
+
15
+ type YamlEditorProps<R extends FlightCtlYamlResource> = Partial<Omit<PfCodeEditorProps, 'ref' | 'code'>> & {
16
+ /** FlightCtl resource to display in the editor. */
17
+ apiObj: R;
18
+ /** Filename to use when YAML is downloaded */
19
+ filename: string;
20
+ /** Function to reload the resource */
21
+ refetch: VoidFunction;
22
+ };
23
+
24
+ const convertObjToYAMLString = (obj: FlightCtlYamlResource) => {
25
+ let yaml = '';
26
+ if (obj) {
27
+ try {
28
+ yaml = dump(obj, { lineWidth: -1 });
29
+ } catch (e) {
30
+ yaml = `# Error converting object to YAML\n# ${e instanceof Error ? e.message : String(e)}`;
31
+ }
32
+ }
33
+ return yaml;
34
+ };
35
+
36
+ const YamlEditor = <R extends FlightCtlYamlResource>({ filename, apiObj, refetch }: YamlEditorProps<R>) => {
37
+ const [yaml, setYaml] = React.useState<string>(convertObjToYAMLString(apiObj));
38
+ const [resourceVersion, setResourceVersion] = React.useState<string>(apiObj.metadata.resourceVersion || '0');
39
+ const [doUpdate, setDoUpdate] = React.useState<boolean>(false);
40
+
41
+ const {
42
+ router: { useNavigate },
43
+ } = useAppContext();
44
+ const navigate = useNavigate();
45
+
46
+ const hasChanged = resourceVersion !== apiObj.metadata.resourceVersion;
47
+
48
+ React.useEffect(() => {
49
+ if (doUpdate) {
50
+ setYaml(convertObjToYAMLString(apiObj));
51
+ setResourceVersion(apiObj.metadata.resourceVersion || '0');
52
+ setDoUpdate(false);
53
+ }
54
+ }, [doUpdate, apiObj]);
55
+
56
+ const { t } = useTranslation();
57
+
58
+ return (
59
+ <div className="fctl-yaml-editor">
60
+ <YamlEditorBase
61
+ filename={filename}
62
+ code={yaml}
63
+ onCancel={() => {
64
+ navigate('../.');
65
+ }}
66
+ onReload={() => {
67
+ void refetch();
68
+ setDoUpdate(true);
69
+ }}
70
+ />
71
+
72
+ {hasChanged && (
73
+ <Alert isInline variant="info" title={t('This object has been updated.')}>
74
+ {t('Click reload to see the new version.')}
75
+ </Alert>
76
+ )}
77
+ </div>
78
+ );
79
+ };
80
+
81
+ export default YamlEditor;
@@ -0,0 +1,3 @@
1
+ .fctl-yaml-editor-base__action-group {
2
+ --pf-v5-c-form__group--m-action--MarginTop: 0;
3
+ }