Skip to content

Commit

Permalink
Fix namespace selector
Browse files Browse the repository at this point in the history
Signed-off-by: lucferbux <[email protected]>
  • Loading branch information
lucferbux committed Jan 9, 2025
1 parent 1a386d7 commit 68093cd
Show file tree
Hide file tree
Showing 5 changed files with 91 additions and 11 deletions.
9 changes: 6 additions & 3 deletions clients/ui/frontend/src/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import App from './app/App';
import { BrowserStorageContextProvider } from './shared/components/browserStorage/BrowserStorageContext';
import { NotificationContextProvider } from './app/context/NotificationContext';
import { NamespaceSelectorContextProvider } from './shared/context/NamespaceSelectorContext';
import DashboardScriptLoader from './shared/context/DashboardScriptLoader';

const theme = createTheme({ cssVariables: true });
const root = ReactDOM.createRoot(document.getElementById('root')!);
Expand All @@ -16,9 +17,11 @@ root.render(
<BrowserStorageContextProvider>
<ThemeProvider theme={theme}>
<NotificationContextProvider>
<NamespaceSelectorContextProvider>
<App />
</NamespaceSelectorContextProvider>
<DashboardScriptLoader>
<NamespaceSelectorContextProvider>
<App />
</NamespaceSelectorContextProvider>
</DashboardScriptLoader>
</NotificationContextProvider>
</ThemeProvider>
</BrowserStorageContextProvider>
Expand Down
5 changes: 0 additions & 5 deletions clients/ui/frontend/src/shared/api/apiUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -189,8 +189,3 @@ export const isModelRegistryResponse = <T>(response: unknown): response is Model
export const assembleModelRegistryBody = <T>(data: T): ModelRegistryBody<T> => ({
data,
});

export const getNamespaceQueryParam = (): string | null => {
const params = new URLSearchParams(window.location.search);
return params.get('ns');
};
58 changes: 58 additions & 0 deletions clients/ui/frontend/src/shared/context/DashboardScriptLoader.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import React, { useEffect, useState } from 'react';
import { isIntegrated } from '../utilities/const';
import { Bullseye, Spinner } from '@patternfly/react-core';

type DashboardScriptLoaderProps = {
children: React.ReactNode;
};

const loadScript = (src: string, onLoad: () => void, onError: () => void) => {
const script = document.createElement('script');
script.src = src;
script.async = true;
script.onload = onLoad;
script.onerror = onError;
document.head.appendChild(script);
};

/* eslint-disable no-console */
const DashboardScriptLoader: React.FC<DashboardScriptLoaderProps> = ({ children }) => {
const [scriptLoaded, setScriptLoaded] = useState(false);

useEffect(() => {
const scriptUrl = '/dashboard_lib.bundle.js';

if (!isIntegrated()) {
console.warn(
'DashboardScriptLoader: Script not loaded because deployment mode is not integrated',
);
setScriptLoaded(true);
return;
}

fetch(scriptUrl, { method: 'HEAD' })
.then((response) => {
if (response.ok) {
loadScript(
scriptUrl,
() => setScriptLoaded(true),
() => console.error('Failed to load the script'),
);
} else {
console.warn('Script not found');
}
})
.catch((error) => console.error('Error checking script existence', error))
.finally(() => setScriptLoaded(true));
}, []);

return !scriptLoaded ? (
<Bullseye>
<Spinner />
</Bullseye>
) : (
<>{children}</>
);
};

export default DashboardScriptLoader;
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import * as React from 'react';
import useNamespaces from '~/shared/hooks/useNamespaces';
import { Namespace } from '~/shared/types';
import { isIntegrated } from '~/shared/utilities/const';

export type NamespaceSelectorContextType = {
namespacesLoaded: boolean;
Expand Down Expand Up @@ -31,6 +32,13 @@ export const NamespaceSelectorContextProvider: React.FC<NamespaceSelectorContext
</EnabledNamespaceSelectorContextProvider>
);

declare global {
interface Window {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
centraldashboard: any;
}
}

const EnabledNamespaceSelectorContextProvider: React.FC<NamespaceSelectorContextProviderProps> = ({
children,
}) => {
Expand All @@ -40,6 +48,24 @@ const EnabledNamespaceSelectorContextProvider: React.FC<NamespaceSelectorContext

const firstNamespace = namespaces.length > 0 ? namespaces[0] : null;

React.useEffect(() => {
if (isIntegrated()) {
// Initialize the central dashboard client
try {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
window.centraldashboard.CentralDashboardEventHandler.init((cdeh: any) => {
// eslint-disable-next-line no-param-reassign
cdeh.onNamespaceSelected = (newNamespace: string) => {
setPreferredNamespace({ name: newNamespace });
};
});
} catch (err) {
/* eslint-disable no-console */
console.error('Failed to initialize central dashboard client', err);
}
}
}, []);

const contextValue = React.useMemo(
() => ({
namespacesLoaded: isLoaded,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,12 +1,10 @@
import React from 'react';
import { NamespaceSelectorContext } from '~/shared/context/NamespaceSelectorContext';
import { isStandalone } from '~/shared/utilities/const';
import { getNamespaceQueryParam } from '~/shared/api/apiUtils';
import { useDeepCompareMemoize } from '~/shared/utilities/useDeepCompareMemoize';

const useQueryParamNamespaces = (): Record<string, unknown> => {
const { preferredNamespace: namespaceSelector } = React.useContext(NamespaceSelectorContext);
const namespace = isStandalone() ? namespaceSelector?.name : getNamespaceQueryParam();
const namespace = namespaceSelector?.name;

return useDeepCompareMemoize({ namespace });
};
Expand Down

0 comments on commit 68093cd

Please sign in to comment.