Skip to content

Commit

Permalink
frontend: ClusterNotFoundPopup: Fix to work with multi clusters
Browse files Browse the repository at this point in the history
Now when there's a wrong cluster name in the URL when using
multiple clusters it also gives a cluster not found alert
message for each cluster not found.

NOTE: A maximum of only two alerts will be shown.

Signed-off-by: René Dudfield <renedudfield@microsoft.com>
  • Loading branch information
illume committed Jan 3, 2025
1 parent de854a6 commit 3812f0f
Showing 1 changed file with 15 additions and 12 deletions.
27 changes: 15 additions & 12 deletions frontend/src/components/App/Layout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import { useDispatch } from 'react-redux';
import { useClustersConf } from '../../lib/k8s';
import { request } from '../../lib/k8s/apiProxy';
import { Cluster } from '../../lib/k8s/cluster';
import { getCluster } from '../../lib/util';
import { getCluster, getClusterGroup } from '../../lib/util';
import { setConfig } from '../../redux/configSlice';
import { ConfigState } from '../../redux/configSlice';
import { useTypedSelector } from '../../redux/reducers/reducers';
Expand All @@ -27,8 +27,8 @@ export interface LayoutProps {}

const CLUSTER_FETCH_INTERVAL = 10 * 1000; // ms

function ClusterNotFoundPopup() {
const cluster = getCluster();
function ClusterNotFoundPopup({ cluster }: { cluster?: string }) {
const problemCluster = cluster || getCluster();
const { t } = useTranslation();

return (
Expand All @@ -46,7 +46,9 @@ function ClusterNotFoundPopup() {
p={0.5}
alignItems="center"
>
<Box p={0.5}>{t(`Something went wrong with cluster {{ cluster }}`, { cluster })}</Box>
<Box p={0.5}>
{t(`Something went wrong with cluster {{ cluster }}`, { cluster: problemCluster })}
</Box>
<Button variant="contained" size="small" href={window.desktopApi ? '#' : '/'}>
{t('Choose another cluster')}
</Button>
Expand Down Expand Up @@ -101,7 +103,6 @@ export default function Layout({}: LayoutProps) {
const isFullWidth = useTypedSelector(state => state.ui.isFullWidth);
const { t } = useTranslation();
const allClusters = useClustersConf();
const clusterInURL = getCluster();
const theme = useTheme();

/** This fetches the cluster config from the backend and updates the redux store on an interval.
Expand Down Expand Up @@ -180,9 +181,15 @@ export default function Layout({}: LayoutProps) {
});
};

const urlClusters = getClusterGroup();
const clustersNotInURL =
allClusters && urlClusters.length !== 0
? urlClusters.filter(clusterName => !Object.keys(allClusters).includes(clusterName))
: [];
const containerProps = isFullWidth
? ({ maxWidth: false, disableGutters: true } as const)
: ({ maxWidth: 'xl' } as const);
const MAXIMUM_NUM_ALERTS = 2;

return (
<>
Expand All @@ -208,13 +215,9 @@ export default function Layout({}: LayoutProps) {
<TopBar />
<Sidebar />
<Main id="main" sx={{ flexGrow: 1, marginLeft: 'initial' }}>
{allClusters &&
!!clusterInURL &&
!Object.keys(allClusters).includes(getCluster() || '') ? (
<ClusterNotFoundPopup />
) : (
''
)}
{clustersNotInURL.slice(0, MAXIMUM_NUM_ALERTS).map(clusterName => (
<ClusterNotFoundPopup key={clusterName} cluster={clusterName} />
))}
<AlertNotification />
<Box>
<Div sx={theme.mixins.toolbar} />
Expand Down

0 comments on commit 3812f0f

Please sign in to comment.