From 9e10cec665ab48a7b4f53f8f70560a5a3a2d153d Mon Sep 17 00:00:00 2001 From: Erik Jan de Wit Date: Tue, 30 Apr 2024 08:58:45 +0200 Subject: [PATCH] only render when ui when feature is enabled (#29101) fixes: #29057 Signed-off-by: Erik Jan de Wit --- js/apps/admin-ui/src/PageNav.tsx | 20 ++++++++++--------- .../components/routable-tabs/RoutableTabs.tsx | 13 +++++++----- .../admin-ui/src/utils/useIsFeatureEnabled.ts | 1 + 3 files changed, 20 insertions(+), 14 deletions(-) diff --git a/js/apps/admin-ui/src/PageNav.tsx b/js/apps/admin-ui/src/PageNav.tsx index 0baba946c7..4c271c5c45 100644 --- a/js/apps/admin-ui/src/PageNav.tsx +++ b/js/apps/admin-ui/src/PageNav.tsx @@ -19,6 +19,7 @@ import { AddRealmRoute } from "./realm/routes/AddRealm"; import { routes } from "./routes"; import "./page-nav.css"; +import useIsFeatureEnabled, { Feature } from "./utils/useIsFeatureEnabled"; type LeftNavProps = { title: string; path: string; id?: string }; @@ -61,9 +62,9 @@ export const PageNav = () => { const { t } = useTranslation(); const { hasSomeAccess } = useAccess(); const { componentTypes } = useServerInfo(); + const isFeatureEnabled = useIsFeatureEnabled(); const pages = componentTypes?.["org.keycloak.services.ui.extend.UiPageProvider"]; - const navigate = useNavigate(); type SelectedItem = { @@ -122,14 +123,15 @@ export const PageNav = () => { - {pages?.map((p) => ( - - ))} + {isFeatureEnabled(Feature.DeclarativeUI) && + pages?.map((p) => ( + + ))} )} diff --git a/js/apps/admin-ui/src/components/routable-tabs/RoutableTabs.tsx b/js/apps/admin-ui/src/components/routable-tabs/RoutableTabs.tsx index bd5535be24..1a2d7f42c1 100644 --- a/js/apps/admin-ui/src/components/routable-tabs/RoutableTabs.tsx +++ b/js/apps/admin-ui/src/components/routable-tabs/RoutableTabs.tsx @@ -23,6 +23,7 @@ import { import { useServerInfo } from "../../context/server-info/ServerInfoProvider"; import { PageHandler } from "../../page/PageHandler"; import { TAB_PROVIDER } from "../../page/PageList"; +import useIsFeatureEnabled, { Feature } from "../../utils/useIsFeatureEnabled"; // TODO: Remove the custom 'children' props and type once the following issue has been resolved: // https://github.com/patternfly/patternfly-react/issues/6766 @@ -47,6 +48,7 @@ export const RoutableTabs = ({ const params = useParams(); const { componentTypes } = useServerInfo(); const tabs = componentTypes?.[TAB_PROVIDER] || []; + const isFeatureEnabled = useIsFeatureEnabled(); const matchedTabs = tabs .filter((tab) => matchPath({ path: tab.metadata.path }, pathname)) @@ -92,11 +94,12 @@ export const RoutableTabs = ({ {...otherProps} > {children as any} - {matchedTabs.map((t) => ( - - - - ))} + {isFeatureEnabled(Feature.DeclarativeUI) && + matchedTabs.map((t) => ( + + + + ))} ); }; diff --git a/js/apps/admin-ui/src/utils/useIsFeatureEnabled.ts b/js/apps/admin-ui/src/utils/useIsFeatureEnabled.ts index 3b59a421bd..af54199120 100644 --- a/js/apps/admin-ui/src/utils/useIsFeatureEnabled.ts +++ b/js/apps/admin-ui/src/utils/useIsFeatureEnabled.ts @@ -9,6 +9,7 @@ export enum Feature { DeviceFlow = "DEVICE_FLOW", TransientUsers = "TRANSIENT_USERS", ClientTypes = "CLIENT_TYPES", + DeclarativeUI = "DECLARATIVE_UI", } export default function useIsFeatureEnabled() {