From 554b467e6d7a5fd6fdbd4c317561ff434003be1c Mon Sep 17 00:00:00 2001 From: Christopher Berge Hove Date: Mon, 9 Dec 2024 12:03:49 +0100 Subject: [PATCH] fix: add clearAppKeys action and loading state to portal hooks --- .../modules/portal-config/hooks/use-portal-config.ts | 7 ++++--- .../packages/core/src/modules/portal-config/portal.ts | 5 +++++ .../core/src/modules/portal-config/state/actions.ts | 8 ++++++++ .../src/modules/portal-config/state/create-reducer.ts | 3 +++ .../src/components/portal-menu/PortalMenu.tsx | 11 +++++------ .../portal-client/src/lib/portal-framework-config.tsx | 10 ++++++---- 6 files changed, 31 insertions(+), 13 deletions(-) diff --git a/client/packages/core/src/modules/portal-config/hooks/use-portal-config.ts b/client/packages/core/src/modules/portal-config/hooks/use-portal-config.ts index 284bfea5d..5deabdaa1 100644 --- a/client/packages/core/src/modules/portal-config/hooks/use-portal-config.ts +++ b/client/packages/core/src/modules/portal-config/hooks/use-portal-config.ts @@ -15,6 +15,7 @@ export const usePortal = () => { return { portal: value || portalConfig.current, error, + isLoading: !value, }; }; @@ -31,12 +32,12 @@ export const usePortalConfig = () => { export const usePortalAppsConfig = () => { const { app, context } = useFramework<[PortalConfig, AppModule]>().modules; - const { portal } = usePortal(); + const { portal, isLoading } = usePortal(); useEffect(() => { const sub = context.currentContext$.subscribe((context) => { if ((portal.portalConfig.contexts || []).length > 0) { - context && portal.getAppKeysByContext(context.id); + context ? portal.getAppKeysByContext(context.id) : portal.clearAppKeys(); } else { portal.getAppKeys(); } @@ -60,7 +61,7 @@ export const usePortalAppsConfig = () => { return { apps, error, - isLoading: !apps, + isLoading: isLoading, }; }; diff --git a/client/packages/core/src/modules/portal-config/portal.ts b/client/packages/core/src/modules/portal-config/portal.ts index e4206b0c2..5a7f2afb7 100644 --- a/client/packages/core/src/modules/portal-config/portal.ts +++ b/client/packages/core/src/modules/portal-config/portal.ts @@ -18,6 +18,7 @@ export interface IPortal { appKeys: string[]; getAppKeysByContext(contextId: string): void; getAppKeys(): void; + clearAppKeys(): void; } export type CurrentPortal = IPortal; @@ -41,6 +42,10 @@ export class Portal implements IPortal { this.#state.next(actions.fetchAppKeysByContextId({ contextId }, true)); } + clearAppKeys(): void { + this.#state.next(actions.clearAppKeys()); + } + getAppKeys(): void { this.#state.next(actions.fetchAppKeys()); } diff --git a/client/packages/core/src/modules/portal-config/state/actions.ts b/client/packages/core/src/modules/portal-config/state/actions.ts index 0a3fc3875..8dcbfdaa3 100644 --- a/client/packages/core/src/modules/portal-config/state/actions.ts +++ b/client/packages/core/src/modules/portal-config/state/actions.ts @@ -36,6 +36,14 @@ const createActions = () => ({ (apps: string[]) => ({ payload: apps }), (error: unknown) => ({ payload: error }) ), + clearAppKeys: createAsyncAction( + 'clear_apps', + (update?: boolean) => ({ + payload: null, + meta: { update }, + }), + (apps: string[]) => ({ payload: apps }) + ), setAppKeys: createAction('set_apps', (apps: string[], update?: boolean) => ({ payload: apps, meta: { diff --git a/client/packages/core/src/modules/portal-config/state/create-reducer.ts b/client/packages/core/src/modules/portal-config/state/create-reducer.ts index b2d8936ba..2a499c7f8 100644 --- a/client/packages/core/src/modules/portal-config/state/create-reducer.ts +++ b/client/packages/core/src/modules/portal-config/state/create-reducer.ts @@ -31,6 +31,9 @@ export const createReducer = (value: PortalStateInitial = {}) => builder.addCase(actions.setAppKeys, (state, action) => { state.apps = action.payload; }); + builder.addCase(actions.clearAppKeys, (state, action) => { + state.apps = []; + }); }); export default createReducer; diff --git a/client/packages/portal-client/src/components/portal-menu/PortalMenu.tsx b/client/packages/portal-client/src/components/portal-menu/PortalMenu.tsx index 1ec6e677b..6782e5cf4 100644 --- a/client/packages/portal-client/src/components/portal-menu/PortalMenu.tsx +++ b/client/packages/portal-client/src/components/portal-menu/PortalMenu.tsx @@ -6,8 +6,7 @@ import { appsMatchingSearch, usePortalApps } from '@portal/core'; import { useState, useMemo } from 'react'; import { useFavorites } from '@portal/core'; import styled from 'styled-components'; -import { AppContextMessage, AppGroup, LoadingMenu } from '@portal/components'; -import { useApps } from '@equinor/fusion-framework-react/app'; +import { AppGroup, LoadingMenu } from '@portal/components'; const Styles = { Divider: styled.div` @@ -37,10 +36,11 @@ const Styles = { AppsListWrapper: styled.div` overflow: auto; height: inherit; + min-width: 550px; `, - Wrapper: styled.div` - column-count: 3; + Wrapper: styled.div<{ count?: number }>` + column-count: ${({ count }) => (count && count > 1 ? 3 : 0)}; height: 100%; gap: 1.5rem; overflow: auto; @@ -140,7 +140,6 @@ export function MenuGroups() { - {displayAppGroups && !!displayAppGroups?.length ? ( activeItem.includes('Pinned Apps') && favorites?.length === 0 ? ( @@ -148,7 +147,7 @@ export function MenuGroups() { add them to the pinned app section. ) : ( - + {displayAppGroups && displayAppGroups.map((appGroup) => { appGroup.apps = appGroup.apps.sort((a, b) => { diff --git a/client/packages/portal-client/src/lib/portal-framework-config.tsx b/client/packages/portal-client/src/lib/portal-framework-config.tsx index 0196c8535..3af54efec 100644 --- a/client/packages/portal-client/src/lib/portal-framework-config.tsx +++ b/client/packages/portal-client/src/lib/portal-framework-config.tsx @@ -70,10 +70,12 @@ export function createPortalFramework(portalConfig: PortalConfig) { enableAppModule(config); - config.configureHttpClient('app', { - baseUri: new URL('/apps-proxy/', location.origin).href, - defaultScopes: portalConfig.serviceDiscovery.client.defaultScopes, - }); + if (process.env.NODE_ENV === 'development') { + config.configureHttpClient('app', { + baseUri: new URL('/apps-proxy/', location.origin).href, + defaultScopes: portalConfig.serviceDiscovery.client.defaultScopes, + }); + } config.configureMsal(portalConfig.msal.client, portalConfig.msal.options);