diff --git a/frontend/src/component/menu/Header/DrawerMenu/DrawerMenu.tsx b/frontend/src/component/menu/Header/DrawerMenu/DrawerMenu.tsx index 1d773ef187..61a3e4c6ff 100644 --- a/frontend/src/component/menu/Header/DrawerMenu/DrawerMenu.tsx +++ b/frontend/src/component/menu/Header/DrawerMenu/DrawerMenu.tsx @@ -8,7 +8,6 @@ import { ReactComponent as UnleashLogo } from 'assets/img/logoDarkWithText.svg'; import { ReactComponent as UnleashLogoWhite } from 'assets/img/logoWithWhiteText.svg'; import NavigationLink from '../NavigationLink/NavigationLink'; import { basePath } from 'utils/formatPath'; -import { IFlags } from 'interfaces/uiConfig'; import { INavigationMenuItem } from 'interfaces/route'; import styles from './DrawerMenu.module.scss'; // FIXME: useStyle - theme import theme from 'themes/theme'; @@ -36,7 +35,6 @@ interface IDrawerMenuProps { href: string; title: string; }>; - flags?: IFlags; routes: { mainNavRoutes: INavigationMenuItem[]; mobileRoutes: INavigationMenuItem[]; @@ -46,7 +44,6 @@ interface IDrawerMenuProps { export const DrawerMenu: VFC = ({ links = [], - flags = {}, open = false, toggleDrawer, routes, diff --git a/frontend/src/component/menu/Header/Header.tsx b/frontend/src/component/menu/Header/Header.tsx index 8881262cea..8dc31766c5 100644 --- a/frontend/src/component/menu/Header/Header.tsx +++ b/frontend/src/component/menu/Header/Header.tsx @@ -147,7 +147,6 @@ const Header: VFC = () => { ['uiConfig']['flags']; + +export const useUiFlag = (flag: K) => { + const { uiConfig } = useUiConfig(); + + return uiConfig?.flags?.[flag] || false; +}; diff --git a/frontend/src/interfaces/route.ts b/frontend/src/interfaces/route.ts index 8755f81553..06a38243bb 100644 --- a/frontend/src/interfaces/route.ts +++ b/frontend/src/interfaces/route.ts @@ -1,5 +1,5 @@ import { VoidFunctionComponent } from 'react'; -import { IFlags, IUiConfig } from 'interfaces/uiConfig'; +import { UiFlags, IUiConfig } from 'interfaces/uiConfig'; export interface IRoute { path: string; @@ -7,7 +7,7 @@ export interface IRoute { type: 'protected' | 'unprotected'; layout?: string; parent?: string; - flag?: keyof IFlags; + flag?: keyof UiFlags; configFlag?: keyof IUiConfig; hidden?: boolean; enterprise?: boolean; @@ -20,7 +20,7 @@ export interface INavigationMenuItem { path: string; title: string; menu: IRouteMenu; - flag?: keyof IFlags; + flag?: keyof UiFlags; configFlag?: keyof IUiConfig; group?: string; } diff --git a/frontend/src/interfaces/uiConfig.ts b/frontend/src/interfaces/uiConfig.ts index a6c48096ef..be189c7201 100644 --- a/frontend/src/interfaces/uiConfig.ts +++ b/frontend/src/interfaces/uiConfig.ts @@ -4,7 +4,14 @@ import { Variant } from 'utils/variants'; export interface IUiConfig { authenticationType?: string; baseUriPath?: string; - flags: IFlags; + /** + * @deprecated `useUiFlags` can be used instead + * @example + * ```ts + * const yourFlag = useUiFlags("yourFlag") + * ``` + */ + flags: UiFlags; name: string; slogan: string; environment?: string; @@ -29,7 +36,7 @@ export interface IProclamationToast { link: string; } -export interface IFlags { +export type UiFlags = { P: boolean; RE: boolean; EEA?: boolean; @@ -59,7 +66,7 @@ export interface IFlags { featureNamingPattern?: boolean; doraMetrics?: boolean; [key: string]: boolean | Variant | undefined; -} +}; export interface IVersionInfo { instanceId: string;