keycloak-theme-cloud/src/keycloak-theme/account/KcApp.tsx

43 lines
1.5 KiB
TypeScript
Raw Normal View History

2023-03-21 17:19:01 +01:00
import "./KcApp.css";
import { lazy, Suspense } from "react";
2023-03-21 23:40:16 +01:00
import type { PageProps } from "keycloakify/account";
2023-03-21 17:19:01 +01:00
import type { KcContext } from "./kcContext";
import { useI18n } from "./i18n";
const Template = lazy(() => import("./Template"));
const DefaultTemplate = lazy(() => import("keycloakify/account/Template"));
const Password = lazy(() => import("./pages/Password"));
const MyExtraPage1 = lazy(() => import("./pages/MyExtraPage1"));
const MyExtraPage2 = lazy(() => import("./pages/MyExtraPage2"));
2023-03-21 23:40:16 +01:00
const Fallback = lazy(()=> import("keycloakify/account"));
2023-03-21 17:19:01 +01:00
const classes: PageProps<any, any>["classes"] = {
"kcBodyClass": "my-root-account-class"
2023-03-21 17:19:01 +01:00
};
2023-04-15 22:40:41 +02:00
export default function KcApp(props: { kcContext: KcContext; }) {
2023-03-21 17:19:01 +01:00
const { kcContext } = props;
const i18n = useI18n({ kcContext });
if (i18n === null) {
return null;
}
return (
<Suspense>
{(() => {
switch (kcContext.pageId) {
case "password.ftl": return <Password {...{ kcContext, i18n, Template, classes }} doUseDefaultCss={true} />;
case "my-extra-page-1.ftl": return <MyExtraPage1 {...{ kcContext, i18n, Template, classes }} doUseDefaultCss={true} />;
case "my-extra-page-2.ftl": return <MyExtraPage2 {...{ kcContext, i18n, Template, classes }} doUseDefaultCss={true} />;
default: return <Fallback {...{ kcContext, i18n, classes }} Template={DefaultTemplate} doUseDefaultCss={true} />;
}
})()}
</Suspense>
);
}