From 1c818cc8efc879e2f50f618438f9b06f7816c4f5 Mon Sep 17 00:00:00 2001 From: Karel Hala Date: Tue, 28 Mar 2023 09:47:15 +0200 Subject: [PATCH] fix(RHCLOUD-24793): Show ROS tab is azure or aws cloud provider (#1800) * fix(RHCLOUD-24793): Show ROS tab is azure or aws cloud provider * Enable ros only for AWS --- src/routes/InventoryDetail.js | 9 +++++++-- src/store/reducers.js | 14 +------------- 2 files changed, 8 insertions(+), 15 deletions(-) diff --git a/src/routes/InventoryDetail.js b/src/routes/InventoryDetail.js index d0908b114..35b2f5e3c 100644 --- a/src/routes/InventoryDetail.js +++ b/src/routes/InventoryDetail.js @@ -1,4 +1,4 @@ -import React, { useEffect, useState, useCallback } from 'react'; +import React, { useEffect, useState, useCallback, useMemo } from 'react'; import PropTypes from 'prop-types'; import { useSelector, useStore, useDispatch } from 'react-redux'; import { useLocation, useParams, Link, useHistory } from 'react-router-dom'; @@ -75,6 +75,11 @@ const Inventory = () => { const writePermissions = useWritePermissions(); const entityLoaded = useSelector(({ entityDetails }) => entityDetails?.loaded); const entity = useSelector(({ entityDetails }) => entityDetails?.entity); + const cloudProvider = useSelector(({ systemProfileStore }) => systemProfileStore?.systemProfile?.cloud_provider); + const availableApps = useMemo(() => appList.map((app) => app.name === 'ros' ? { + ...app, + isVisible: cloudProvider === 'aws' + } : app), [cloudProvider]); const clearNotifications = () => dispatch(actions.clearNotifications()); useEffect(() => { @@ -122,7 +127,7 @@ const Inventory = () => { } activeApp={activeApp} - appList={appList} + appList={availableApps} onTabSelect={onTabSelect} /> ); diff --git a/src/store/reducers.js b/src/store/reducers.js index 8b3c08794..70c08da17 100644 --- a/src/store/reducers.js +++ b/src/store/reducers.js @@ -58,17 +58,6 @@ function entitySelected(state, { payload }) { }; } -function resourceOptTabVisibility(state, { payload }) { - return { - ...state, - activeApps: state.activeApps?.map((entity) => entity.name === 'ros' ? ({ - ...entity, - isVisible: payload - }) : entity - ) - }; -} - function entityDeleted(state, { meta }) { const selected = state.selected || (new Map()); meta.systems.forEach(id => selected.delete(id)); @@ -135,8 +124,7 @@ export const tableReducer = applyReducerHash( export const entitesDetailReducer = () => applyReducerHash( { - [INVENTORY_ACTION_TYPES.LOAD_ENTITY_FULFILLED]: entityLoaded, - [INVENTORY_ACTION_TYPES.LOAD_SYSTEM_PROFILE_FULFILLED]: resourceOptTabVisibility + [INVENTORY_ACTION_TYPES.LOAD_ENTITY_FULFILLED]: entityLoaded }, defaultState );