From 167b9a12c60ccbe5eb0961e2855c2b90c41f14e3 Mon Sep 17 00:00:00 2001 From: Lucy Fu Date: Thu, 14 Nov 2024 16:39:38 -0500 Subject: [PATCH] Fixes #38013 - Add Image mode card on host details tab --- .../DetailsTabCards/ImageModeCard.js | 79 +++++++++++++++++++ webpack/global_index.js | 4 +- 2 files changed, 82 insertions(+), 1 deletion(-) create mode 100644 webpack/components/extensions/HostDetails/DetailsTabCards/ImageModeCard.js diff --git a/webpack/components/extensions/HostDetails/DetailsTabCards/ImageModeCard.js b/webpack/components/extensions/HostDetails/DetailsTabCards/ImageModeCard.js new file mode 100644 index 00000000000..d6333d515b7 --- /dev/null +++ b/webpack/components/extensions/HostDetails/DetailsTabCards/ImageModeCard.js @@ -0,0 +1,79 @@ +import React from 'react'; +import PropTypes from 'prop-types'; +import { translate as __ } from 'foremanReact/common/I18n'; +import { + DescriptionList, + DescriptionListGroup, + DescriptionListDescription as Dd, + DescriptionListTerm as Dt, +} from '@patternfly/react-core'; +import CardTemplate from 'foremanReact/components/HostDetails/Templates/CardItem/CardTemplate'; +import FontAwesomeImageModeIcon from '../../../../components/extensions/Hosts/FontAwesomeImageModeIcon'; + +const cardHeader = ( + <> + {__('Image mode details')} + + +); + +const ImageModeCard = ({ isExpandedGlobal, hostDetails }) => { + const imageMode = hostDetails?.content_facet_attributes?.bootc_booted_image; + if (!imageMode) return null; + const getValueOrDash = value => (value || '—'); + return ( + + + +
{__('Running image')}
+
{getValueOrDash(hostDetails.content_facet_attributes.bootc_booted_image)}
+
{__('Running image digest')}
+
{getValueOrDash(hostDetails.content_facet_attributes.bootc_booted_digest)}
+ +
{__('Staged image')}
+
{getValueOrDash(hostDetails.content_facet_attributes.bootc_staged_image)}
+
{__('Staged image digest')}
+
{getValueOrDash(hostDetails.content_facet_attributes.bootc_staged_digest)}
+ +
{__('Available image')}
+
{getValueOrDash(hostDetails.content_facet_attributes.bootc_available_image)}
+
{__('Available image digest')}
+
{getValueOrDash(hostDetails.content_facet_attributes.bootc_available_digest)}
+ +
{__('Rollback image')}
+
{getValueOrDash(hostDetails.content_facet_attributes.bootc_rollback_image)}
+
{__('Rollback image digest')}
+
{getValueOrDash(hostDetails.content_facet_attributes.bootc_rollback_digest)}
+
+
+
+ ); +}; + +ImageModeCard.propTypes = { + isExpandedGlobal: PropTypes.bool, + hostDetails: PropTypes.shape({ + content_facet_attributes: PropTypes.shape({ + bootc_booted_image: PropTypes.string, + bootc_booted_digest: PropTypes.string, + bootc_staged_image: PropTypes.string, + bootc_staged_digest: PropTypes.string, + bootc_available_image: PropTypes.string, + bootc_available_digest: PropTypes.string, + bootc_rollback_image: PropTypes.string, + bootc_rollback_digest: PropTypes.string, + }), + }), +}; + +ImageModeCard.defaultProps = { + isExpandedGlobal: false, + hostDetails: {}, +}; + +export default ImageModeCard; diff --git a/webpack/global_index.js b/webpack/global_index.js index e1dbe296ae6..6086a60340f 100644 --- a/webpack/global_index.js +++ b/webpack/global_index.js @@ -19,6 +19,7 @@ import ErrataOverviewCard from './components/extensions/HostDetails/Cards/Errata import InstalledProductsCard from './components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard'; import RegistrationCard from './components/extensions/HostDetails/DetailsTabCards/RegistrationCard'; import HwPropertiesCard from './components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard'; +import ImageModeCard from './components/extensions/HostDetails/DetailsTabCards/ImageModeCard'; import TracesTab from './components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js'; import extendReducer from './components/extensions/reducers'; @@ -71,6 +72,8 @@ addGlobalFill('recent-communication-card-item', 'Recent communication', , 100); addGlobalFill('host-tab-details-cards', 'Registration details', , 200); +addGlobalFill('host-tab-details-cards', 'HW properties', , 200); +addGlobalFill('host-tab-details-cards', 'Image mode details', , 3000); addGlobalFill('host-details-tab-properties-1', 'Subscription UUID', ); addGlobalFill('host-details-tab-properties-2', 'Tracer', ); addGlobalFill('host-details-tab-properties-3', 'Virtualization', ); @@ -89,7 +92,6 @@ addGlobalFill( 100, ); -addGlobalFill('host-tab-details-cards', 'HW properties', , 200); // Hosts Index page extensions addGlobalFill('_all-hosts-modals', 'BulkChangeHostCVModal', , 100);