keycloakify 10.0.0-rc.97 → 10.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/PUBLIC_URL.js +2 -2
- package/PUBLIC_URL.js.map +1 -1
- package/README.md +28 -242
- package/account/KcContext/KcContext.d.ts +4 -1
- package/account/KcContext/KcContext.js.map +1 -1
- package/account/KcContext/kcContextMocks.js +7 -4
- package/account/KcContext/kcContextMocks.js.map +1 -1
- package/account/Template.js +3 -1
- package/account/Template.js.map +1 -1
- package/account/i18n/GenericI18n.d.ts +6 -0
- package/account/i18n/GenericI18n.js +2 -0
- package/account/i18n/GenericI18n.js.map +1 -0
- package/account/i18n/i18n.d.ts +24 -30
- package/account/i18n/i18n.js +50 -70
- package/account/i18n/i18n.js.map +1 -1
- package/account/i18n/index.d.ts +4 -3
- package/account/i18n/index.js.map +1 -1
- package/account/i18n/messages_defaultSet/ar.js.map +1 -0
- package/account/i18n/messages_defaultSet/ca.js.map +1 -0
- package/account/i18n/messages_defaultSet/cs.js.map +1 -0
- package/account/i18n/messages_defaultSet/da.js.map +1 -0
- package/account/i18n/messages_defaultSet/de.js.map +1 -0
- package/account/i18n/messages_defaultSet/el.js.map +1 -0
- package/account/i18n/messages_defaultSet/en.js.map +1 -0
- package/account/i18n/messages_defaultSet/es.js.map +1 -0
- package/account/i18n/messages_defaultSet/fa.js.map +1 -0
- package/account/i18n/messages_defaultSet/fi.js.map +1 -0
- package/account/i18n/messages_defaultSet/fr.js.map +1 -0
- package/account/i18n/messages_defaultSet/hu.js.map +1 -0
- package/account/i18n/{baseMessages → messages_defaultSet}/index.d.ts +1 -1
- package/account/i18n/{baseMessages → messages_defaultSet}/index.js +3 -3
- package/account/i18n/messages_defaultSet/index.js.map +1 -0
- package/account/i18n/messages_defaultSet/it.js.map +1 -0
- package/account/i18n/messages_defaultSet/ja.js.map +1 -0
- package/account/i18n/messages_defaultSet/lt.js.map +1 -0
- package/account/i18n/messages_defaultSet/lv.js.map +1 -0
- package/account/i18n/messages_defaultSet/nl.js.map +1 -0
- package/account/i18n/messages_defaultSet/no.js.map +1 -0
- package/account/i18n/messages_defaultSet/pl.js.map +1 -0
- package/account/i18n/messages_defaultSet/pt-BR.js.map +1 -0
- package/account/i18n/messages_defaultSet/ru.js.map +1 -0
- package/account/i18n/messages_defaultSet/sk.js.map +1 -0
- package/account/i18n/messages_defaultSet/sv.js.map +1 -0
- package/account/i18n/messages_defaultSet/th.js.map +1 -0
- package/account/i18n/messages_defaultSet/tr.js.map +1 -0
- package/account/i18n/messages_defaultSet/uk.js.map +1 -0
- package/account/i18n/messages_defaultSet/zh-CN.js.map +1 -0
- package/account/i18n/useI18n.d.ts +6 -5
- package/account/i18n/useI18n.js +37 -4
- package/account/i18n/useI18n.js.map +1 -1
- package/account/pages/Applications.js +1 -1
- package/account/pages/Applications.js.map +1 -1
- package/account/pages/FederatedIdentity.js +1 -1
- package/account/pages/FederatedIdentity.js.map +1 -1
- package/account/pages/Totp.js +5 -1
- package/account/pages/Totp.js.map +1 -1
- package/bin/193.index.js +5 -5
- package/bin/{490.index.js → 246.index.js} +22 -4
- package/bin/31.index.js +264 -203
- package/bin/440.index.js +178 -106
- package/bin/453.index.js +59 -7
- package/bin/526.index.js +525 -137
- package/bin/599.index.js +567 -0
- package/bin/{893.index.js → 622.index.js} +239 -231
- package/bin/{36.index.js → 678.index.js} +577 -71
- package/bin/{180.index.js → 697.index.js} +611 -526
- package/bin/743.index.js +70 -0
- package/bin/780.index.js +895 -0
- package/bin/786.index.js +185 -0
- package/bin/932.index.js +740 -52
- package/bin/{456.index.js → 941.index.js} +3 -1988
- package/bin/97.index.js +29 -7
- package/bin/main.js +1994 -8
- package/bin/shared/KeycloakVersionRange.d.ts +3 -3
- package/bin/shared/buildContext.d.ts +52 -16
- package/bin/shared/buildContext.js.map +1 -1
- package/bin/shared/constants.d.ts +18 -17
- package/bin/shared/constants.js +15 -14
- package/bin/shared/constants.js.map +1 -1
- package/bin/shared/copyKeycloakResourcesToPublic.js.map +1 -1
- package/bin/shared/downloadKeycloakDefaultTheme.js.map +1 -1
- package/bin/shared/generateKcGenTs.d.ts +3 -0
- package/bin/shared/generateKcGenTs.js.map +1 -1
- package/bin/shared/getLatestsSemVersionedTag.d.ts +15 -0
- package/bin/shared/getLatestsSemVersionedTag.js.map +1 -0
- package/bin/shared/promptKeycloakVersion.d.ts +3 -1
- package/bin/shared/promptKeycloakVersion.js.map +1 -1
- package/lib/getKcClsx.js +2 -1
- package/lib/getKcClsx.js.map +1 -1
- package/login/KcContext/KcContext.d.ts +10 -11
- package/login/KcContext/KcContext.js.map +1 -1
- package/login/KcContext/kcContextMocks.js +4 -5
- package/login/KcContext/kcContextMocks.js.map +1 -1
- package/login/Template.js +13 -7
- package/login/Template.js.map +1 -1
- package/login/TemplateProps.d.ts +0 -1
- package/login/UserProfileFormFields.js +6 -5
- package/login/UserProfileFormFields.js.map +1 -1
- package/login/i18n/GenericI18n.d.ts +6 -0
- package/login/i18n/GenericI18n.js +2 -0
- package/login/i18n/GenericI18n.js.map +1 -0
- package/login/i18n/i18n.d.ts +22 -32
- package/login/i18n/i18n.js +51 -92
- package/login/i18n/i18n.js.map +1 -1
- package/login/i18n/index.d.ts +4 -3
- package/login/i18n/index.js.map +1 -1
- package/login/i18n/messages_defaultSet/ar.js.map +1 -0
- package/login/i18n/messages_defaultSet/ca.js.map +1 -0
- package/login/i18n/messages_defaultSet/cs.js.map +1 -0
- package/login/i18n/messages_defaultSet/da.js.map +1 -0
- package/login/i18n/messages_defaultSet/de.js.map +1 -0
- package/login/i18n/messages_defaultSet/el.js.map +1 -0
- package/login/i18n/messages_defaultSet/en.js.map +1 -0
- package/login/i18n/messages_defaultSet/es.js.map +1 -0
- package/login/i18n/messages_defaultSet/fa.js.map +1 -0
- package/login/i18n/messages_defaultSet/fi.js.map +1 -0
- package/login/i18n/messages_defaultSet/fr.js.map +1 -0
- package/login/i18n/messages_defaultSet/hu.js.map +1 -0
- package/login/i18n/{baseMessages → messages_defaultSet}/index.d.ts +1 -1
- package/login/i18n/{baseMessages → messages_defaultSet}/index.js +3 -3
- package/login/i18n/messages_defaultSet/index.js.map +1 -0
- package/login/i18n/messages_defaultSet/it.js.map +1 -0
- package/login/i18n/messages_defaultSet/ja.js.map +1 -0
- package/login/i18n/messages_defaultSet/lt.js.map +1 -0
- package/login/i18n/messages_defaultSet/lv.js.map +1 -0
- package/login/i18n/messages_defaultSet/nl.js.map +1 -0
- package/login/i18n/messages_defaultSet/no.js.map +1 -0
- package/login/i18n/messages_defaultSet/pl.js.map +1 -0
- package/login/i18n/messages_defaultSet/pt-BR.js.map +1 -0
- package/login/i18n/messages_defaultSet/ru.js.map +1 -0
- package/login/i18n/messages_defaultSet/sk.js.map +1 -0
- package/login/i18n/messages_defaultSet/sv.js.map +1 -0
- package/login/i18n/messages_defaultSet/th.js.map +1 -0
- package/login/i18n/messages_defaultSet/tr.js.map +1 -0
- package/login/i18n/messages_defaultSet/uk.js.map +1 -0
- package/login/i18n/messages_defaultSet/zh-CN.js.map +1 -0
- package/login/i18n/useI18n.d.ts +6 -5
- package/login/i18n/useI18n.js +37 -4
- package/login/i18n/useI18n.js.map +1 -1
- package/login/lib/useUserProfileForm.d.ts +2 -0
- package/login/lib/useUserProfileForm.js +44 -10
- package/login/lib/useUserProfileForm.js.map +1 -1
- package/login/pages/Error.js +1 -1
- package/login/pages/Error.js.map +1 -1
- package/login/pages/Info.js +15 -3
- package/login/pages/Info.js.map +1 -1
- package/login/pages/Login.js +6 -2
- package/login/pages/Login.js.map +1 -1
- package/login/pages/LoginConfigTotp.js +5 -1
- package/login/pages/LoginConfigTotp.js.map +1 -1
- package/login/pages/LoginOtp.js +3 -1
- package/login/pages/LoginOtp.js.map +1 -1
- package/login/pages/LoginPassword.js +3 -1
- package/login/pages/LoginPassword.js.map +1 -1
- package/login/pages/LoginRecoveryAuthnCodeInput.js +3 -1
- package/login/pages/LoginRecoveryAuthnCodeInput.js.map +1 -1
- package/login/pages/LoginResetPassword.js +3 -1
- package/login/pages/LoginResetPassword.js.map +1 -1
- package/login/pages/LoginUpdatePassword.js +5 -1
- package/login/pages/LoginUpdatePassword.js.map +1 -1
- package/login/pages/Register.js +3 -1
- package/login/pages/Register.js.map +1 -1
- package/login/pages/SamlPostForm.js +1 -1
- package/login/pages/SamlPostForm.js.map +1 -1
- package/login/pages/SelectAuthenticator.js +2 -2
- package/login/pages/SelectAuthenticator.js.map +1 -1
- package/login/pages/WebauthnAuthenticate.js +3 -3
- package/login/pages/WebauthnAuthenticate.js.map +1 -1
- package/login/pages/WebauthnRegister.js +2 -2
- package/package.json +267 -245
- package/src/PUBLIC_URL.ts +2 -2
- package/src/account/KcContext/KcContext.ts +4 -1
- package/src/account/KcContext/kcContextMocks.ts +7 -4
- package/src/account/Template.tsx +6 -1
- package/src/account/i18n/GenericI18n.tsx +6 -0
- package/src/account/i18n/i18n.tsx +91 -129
- package/src/account/i18n/index.ts +4 -3
- package/src/account/i18n/{baseMessages → messages_defaultSet}/index.ts +3 -3
- package/src/account/i18n/useI18n.tsx +95 -0
- package/src/account/pages/Applications.tsx +0 -1
- package/src/account/pages/FederatedIdentity.tsx +1 -1
- package/src/account/pages/Totp.tsx +16 -6
- package/src/bin/add-story.ts +42 -10
- package/src/bin/eject-page.ts +119 -11
- package/src/bin/initialize-account-theme/copyBoilerplate.ts +32 -0
- package/src/bin/initialize-account-theme/index.ts +1 -0
- package/src/bin/initialize-account-theme/initialize-account-theme.ts +112 -0
- package/src/bin/initialize-account-theme/initializeAccountTheme_multiPage.ts +21 -0
- package/src/bin/initialize-account-theme/initializeAccountTheme_singlePage.ts +152 -0
- package/src/bin/initialize-account-theme/src/multi-page/KcContext.ts +12 -0
- package/src/bin/initialize-account-theme/src/multi-page/KcPage.tsx +25 -0
- package/src/bin/initialize-account-theme/src/multi-page/KcPageStory.tsx +38 -0
- package/src/bin/initialize-account-theme/src/multi-page/i18n.ts +5 -0
- package/src/bin/initialize-account-theme/src/single-page/KcContext.ts +7 -0
- package/src/bin/initialize-account-theme/src/single-page/KcPage.tsx +11 -0
- package/src/bin/initialize-account-theme/updateAccountThemeImplementationInConfig.ts +92 -0
- package/src/bin/initialize-email-theme.ts +1 -1
- package/src/bin/keycloakify/buildJars/buildJar.ts +38 -24
- package/src/bin/keycloakify/buildJars/buildJars.ts +6 -3
- package/src/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.ts +5 -5
- package/src/bin/keycloakify/generateFtl/generateFtl.ts +16 -16
- package/src/bin/keycloakify/generateFtl/kcContextDeclarationTemplate.ftl +471 -364
- package/src/bin/keycloakify/generateResources/bringInAccountV1.ts +7 -7
- package/src/bin/keycloakify/generateResources/generateMessageProperties.ts +3 -3
- package/src/bin/keycloakify/generateResources/generateResourcesForMainTheme.ts +125 -59
- package/src/bin/keycloakify/generateResources/generateResourcesForThemeVariant.ts +2 -2
- package/src/bin/keycloakify/generateResources/readExtraPageNames.ts +5 -8
- package/src/bin/keycloakify/keycloakify.ts +8 -6
- package/src/bin/keycloakify/replacers/replaceImportsInCssCode.ts +41 -27
- package/src/bin/keycloakify/replacers/replaceImportsInJsCode/replaceImportsInJsCode.ts +2 -2
- package/src/bin/keycloakify/replacers/replaceImportsInJsCode/vite.ts +6 -6
- package/src/bin/keycloakify/replacers/replaceImportsInJsCode/webpack.ts +4 -4
- package/src/bin/main.ts +19 -2
- package/src/bin/shared/KeycloakVersionRange.ts +4 -4
- package/src/bin/shared/buildContext.ts +360 -251
- package/src/bin/shared/constants.ts +19 -17
- package/src/bin/shared/copyKeycloakResourcesToPublic.ts +6 -6
- package/src/bin/shared/downloadKeycloakDefaultTheme.ts +48 -27
- package/src/bin/shared/downloadKeycloakStaticResources.ts +2 -2
- package/src/bin/shared/generateKcGenTs.ts +110 -3
- package/src/bin/shared/getLatestsSemVersionedTag.ts +201 -0
- package/src/bin/shared/promptKeycloakVersion.ts +20 -80
- package/src/bin/start-keycloak/appBuild.ts +15 -11
- package/src/bin/start-keycloak/keycloakifyBuild.ts +3 -3
- package/src/bin/start-keycloak/myrealm-realm-18.json +4 -4
- package/src/bin/start-keycloak/myrealm-realm-19.json +4 -4
- package/src/bin/start-keycloak/myrealm-realm-20.json +4 -4
- package/src/bin/start-keycloak/myrealm-realm-21.json +4 -4
- package/src/bin/start-keycloak/myrealm-realm-23.json +3 -3
- package/src/bin/start-keycloak/myrealm-realm-24.json +4 -4
- package/src/bin/start-keycloak/myrealm-realm-25.json +4 -4
- package/src/bin/start-keycloak/start-keycloak.ts +256 -102
- package/src/bin/tools/assertNoPnpmDlx.ts +17 -0
- package/src/bin/tools/downloadAndExtractArchive.ts +10 -9
- package/src/bin/tools/fetchProxyOptions.ts +32 -11
- package/src/bin/tools/npmInstall.ts +63 -0
- package/src/bin/tools/octokit-addons/getLatestsSemVersionedTag.ts +3 -2
- package/src/bin/tsconfig.json +3 -1
- package/src/lib/getKcClsx.ts +2 -2
- package/src/login/KcContext/KcContext.ts +10 -28
- package/src/login/KcContext/kcContextMocks.ts +5 -6
- package/src/login/Template.tsx +32 -54
- package/src/login/TemplateProps.ts +0 -1
- package/src/login/UserProfileFormFields.tsx +15 -11
- package/src/login/i18n/GenericI18n.tsx +6 -0
- package/src/login/i18n/i18n.tsx +91 -166
- package/src/login/i18n/index.ts +4 -3
- package/src/login/i18n/{baseMessages → messages_defaultSet}/index.ts +3 -3
- package/src/login/i18n/useI18n.tsx +95 -0
- package/src/login/lib/useUserProfileForm.tsx +68 -20
- package/src/login/pages/Error.tsx +1 -1
- package/src/login/pages/Info.tsx +26 -6
- package/src/login/pages/Login.tsx +20 -9
- package/src/login/pages/LoginConfigTotp.tsx +16 -6
- package/src/login/pages/LoginOtp.tsx +8 -3
- package/src/login/pages/LoginPassword.tsx +8 -3
- package/src/login/pages/LoginRecoveryAuthnCodeInput.tsx +8 -3
- package/src/login/pages/LoginResetPassword.tsx +8 -3
- package/src/login/pages/LoginUpdatePassword.tsx +55 -47
- package/src/login/pages/Register.tsx +8 -3
- package/src/login/pages/SamlPostForm.tsx +1 -1
- package/src/login/pages/SelectAuthenticator.tsx +4 -4
- package/src/login/pages/WebauthnAuthenticate.tsx +5 -5
- package/src/login/pages/WebauthnRegister.tsx +2 -2
- package/src/tools/useInsertLinkTags.ts +9 -1
- package/src/tools/useInsertScriptTags.ts +9 -1
- package/src/vite-plugin/vite-plugin.ts +15 -13
- package/stories/account/pages/Applications.stories.tsx +80 -0
- package/stories/account/pages/Log.stories.tsx +1 -0
- package/stories/account-spa/index.stories.tsx +94 -0
- package/stories/intro/intro.stories.tsx +90 -0
- package/stories/login/pages/Info.stories.tsx +7 -2
- package/stories/login/pages/Login.stories.tsx +25 -13
- package/stories/login/pages/Register.stories.tsx +11 -9
- package/stories/login/pages/SelectAuthenticator.stories.tsx +41 -0
- package/stories/login/pages/Terms.stories.tsx +6 -2
- package/tools/useInsertLinkTags.js +7 -1
- package/tools/useInsertLinkTags.js.map +1 -1
- package/tools/useInsertScriptTags.js +7 -1
- package/tools/useInsertScriptTags.js.map +1 -1
- package/vite-plugin/index.js +25820 -25686
- package/vite-plugin/vite-plugin.d.ts +6 -4
- package/account/i18n/baseMessages/ar.js.map +0 -1
- package/account/i18n/baseMessages/ca.js.map +0 -1
- package/account/i18n/baseMessages/cs.js.map +0 -1
- package/account/i18n/baseMessages/da.js.map +0 -1
- package/account/i18n/baseMessages/de.js.map +0 -1
- package/account/i18n/baseMessages/el.js.map +0 -1
- package/account/i18n/baseMessages/en.js.map +0 -1
- package/account/i18n/baseMessages/es.js.map +0 -1
- package/account/i18n/baseMessages/fa.js.map +0 -1
- package/account/i18n/baseMessages/fi.js.map +0 -1
- package/account/i18n/baseMessages/fr.js.map +0 -1
- package/account/i18n/baseMessages/hu.js.map +0 -1
- package/account/i18n/baseMessages/index.js.map +0 -1
- package/account/i18n/baseMessages/it.js.map +0 -1
- package/account/i18n/baseMessages/ja.js.map +0 -1
- package/account/i18n/baseMessages/lt.js.map +0 -1
- package/account/i18n/baseMessages/lv.js.map +0 -1
- package/account/i18n/baseMessages/nl.js.map +0 -1
- package/account/i18n/baseMessages/no.js.map +0 -1
- package/account/i18n/baseMessages/pl.js.map +0 -1
- package/account/i18n/baseMessages/pt-BR.js.map +0 -1
- package/account/i18n/baseMessages/ru.js.map +0 -1
- package/account/i18n/baseMessages/sk.js.map +0 -1
- package/account/i18n/baseMessages/sv.js.map +0 -1
- package/account/i18n/baseMessages/th.js.map +0 -1
- package/account/i18n/baseMessages/tr.js.map +0 -1
- package/account/i18n/baseMessages/uk.js.map +0 -1
- package/account/i18n/baseMessages/zh-CN.js.map +0 -1
- package/bin/538.index.js +0 -108
- package/login/i18n/baseMessages/ar.js.map +0 -1
- package/login/i18n/baseMessages/ca.js.map +0 -1
- package/login/i18n/baseMessages/cs.js.map +0 -1
- package/login/i18n/baseMessages/da.js.map +0 -1
- package/login/i18n/baseMessages/de.js.map +0 -1
- package/login/i18n/baseMessages/el.js.map +0 -1
- package/login/i18n/baseMessages/en.js.map +0 -1
- package/login/i18n/baseMessages/es.js.map +0 -1
- package/login/i18n/baseMessages/fa.js.map +0 -1
- package/login/i18n/baseMessages/fi.js.map +0 -1
- package/login/i18n/baseMessages/fr.js.map +0 -1
- package/login/i18n/baseMessages/hu.js.map +0 -1
- package/login/i18n/baseMessages/index.js.map +0 -1
- package/login/i18n/baseMessages/it.js.map +0 -1
- package/login/i18n/baseMessages/ja.js.map +0 -1
- package/login/i18n/baseMessages/lt.js.map +0 -1
- package/login/i18n/baseMessages/lv.js.map +0 -1
- package/login/i18n/baseMessages/nl.js.map +0 -1
- package/login/i18n/baseMessages/no.js.map +0 -1
- package/login/i18n/baseMessages/pl.js.map +0 -1
- package/login/i18n/baseMessages/pt-BR.js.map +0 -1
- package/login/i18n/baseMessages/ru.js.map +0 -1
- package/login/i18n/baseMessages/sk.js.map +0 -1
- package/login/i18n/baseMessages/sv.js.map +0 -1
- package/login/i18n/baseMessages/th.js.map +0 -1
- package/login/i18n/baseMessages/tr.js.map +0 -1
- package/login/i18n/baseMessages/uk.js.map +0 -1
- package/login/i18n/baseMessages/zh-CN.js.map +0 -1
- package/src/account/i18n/useI18n.ts +0 -44
- package/src/login/i18n/useI18n.ts +0 -44
- package/src/tools/ExtractAfterStartingWith.ts +0 -4
- package/tools/ExtractAfterStartingWith.d.ts +0 -1
- package/tools/ExtractAfterStartingWith.js +0 -2
- package/tools/ExtractAfterStartingWith.js.map +0 -1
- /package/account/i18n/{baseMessages → messages_defaultSet}/ar.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/ar.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/ca.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/ca.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/cs.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/cs.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/da.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/da.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/de.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/de.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/el.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/el.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/en.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/en.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/es.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/es.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/fa.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/fa.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/fi.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/fi.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/fr.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/fr.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/hu.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/hu.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/it.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/it.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/ja.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/ja.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/lt.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/lt.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/lv.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/lv.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/nl.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/nl.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/no.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/no.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/pl.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/pl.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/pt-BR.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/pt-BR.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/ru.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/ru.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/sk.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/sk.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/sv.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/sv.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/th.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/th.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/tr.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/tr.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/uk.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/uk.js +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/zh-CN.d.ts +0 -0
- /package/account/i18n/{baseMessages → messages_defaultSet}/zh-CN.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/ar.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/ar.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/ca.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/ca.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/cs.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/cs.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/da.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/da.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/de.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/de.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/el.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/el.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/en.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/en.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/es.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/es.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/fa.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/fa.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/fi.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/fi.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/fr.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/fr.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/hu.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/hu.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/it.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/it.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/ja.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/ja.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/lt.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/lt.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/lv.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/lv.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/nl.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/nl.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/no.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/no.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/pl.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/pl.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/pt-BR.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/pt-BR.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/ru.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/ru.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/sk.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/sk.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/sv.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/sv.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/th.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/th.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/tr.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/tr.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/uk.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/uk.js +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/zh-CN.d.ts +0 -0
- /package/login/i18n/{baseMessages → messages_defaultSet}/zh-CN.js +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/ar.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/ca.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/cs.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/da.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/de.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/el.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/en.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/es.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/fa.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/fi.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/fr.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/hu.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/it.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/ja.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/lt.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/lv.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/nl.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/no.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/pl.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/pt-BR.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/ru.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/sk.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/sv.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/th.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/tr.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/uk.ts +0 -0
- /package/src/account/i18n/{baseMessages → messages_defaultSet}/zh-CN.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/ar.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/ca.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/cs.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/da.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/de.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/el.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/en.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/es.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/fa.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/fi.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/fr.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/hu.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/it.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/ja.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/lt.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/lv.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/nl.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/no.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/pl.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/pt-BR.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/ru.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/sk.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/sv.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/th.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/tr.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/uk.ts +0 -0
- /package/src/login/i18n/{baseMessages → messages_defaultSet}/zh-CN.ts +0 -0
@@ -9,7 +9,7 @@ import { formatNumber } from "keycloakify/tools/formatNumber";
|
|
9
9
|
import { useInsertScriptTags } from "keycloakify/tools/useInsertScriptTags";
|
10
10
|
import type { PasswordPolicies, Attribute, Validators } from "keycloakify/login/KcContext";
|
11
11
|
import type { KcContext } from "../KcContext";
|
12
|
-
import type {
|
12
|
+
import type { MessageKey_defaultSet } from "keycloakify/login/i18n";
|
13
13
|
import { KcContextLike as KcContextLike_i18n } from "keycloakify/login/i18n";
|
14
14
|
import type { I18n } from "../i18n";
|
15
15
|
|
@@ -59,6 +59,8 @@ export type FormAction =
|
|
59
59
|
action: "update";
|
60
60
|
name: string;
|
61
61
|
valueOrValues: string | string[];
|
62
|
+
/** Default false */
|
63
|
+
displayErrorsImmediately?: boolean;
|
62
64
|
}
|
63
65
|
| {
|
64
66
|
action: "focus lost";
|
@@ -148,7 +150,7 @@ export function useUserProfileForm(params: UseUserProfileFormParams): ReturnType
|
|
148
150
|
.map(name =>
|
149
151
|
id<Attribute>({
|
150
152
|
name: name,
|
151
|
-
displayName: id<`\${${
|
153
|
+
displayName: id<`\${${MessageKey_defaultSet}}`>(`\${${name}}`),
|
152
154
|
required: true,
|
153
155
|
value: (kcContext.register as any).formData[name] ?? "",
|
154
156
|
html5DataAnnotations: {},
|
@@ -176,7 +178,7 @@ export function useUserProfileForm(params: UseUserProfileFormParams): ReturnType
|
|
176
178
|
.map(name =>
|
177
179
|
id<Attribute>({
|
178
180
|
name: name,
|
179
|
-
displayName: id<`\${${
|
181
|
+
displayName: id<`\${${MessageKey_defaultSet}}`>(`\${${name}}`),
|
180
182
|
required: true,
|
181
183
|
value: (kcContext as any).user[name] ?? "",
|
182
184
|
html5DataAnnotations: {},
|
@@ -202,7 +204,7 @@ export function useUserProfileForm(params: UseUserProfileFormParams): ReturnType
|
|
202
204
|
return [
|
203
205
|
id<Attribute>({
|
204
206
|
name: "email",
|
205
|
-
displayName: id<`\${${
|
207
|
+
displayName: id<`\${${MessageKey_defaultSet}}`>(`\${email}`),
|
206
208
|
required: true,
|
207
209
|
value: (kcContext.email as any).value ?? "",
|
208
210
|
html5DataAnnotations: {},
|
@@ -227,7 +229,7 @@ export function useUserProfileForm(params: UseUserProfileFormParams): ReturnType
|
|
227
229
|
break patch_legacy_group;
|
228
230
|
}
|
229
231
|
|
230
|
-
const { group, groupDisplayHeader, groupDisplayDescription
|
232
|
+
const { group, groupDisplayHeader, groupDisplayDescription, groupAnnotations } = attribute as Attribute & {
|
231
233
|
group: string;
|
232
234
|
groupDisplayHeader?: string;
|
233
235
|
groupDisplayDescription?: string;
|
@@ -250,6 +252,7 @@ export function useUserProfileForm(params: UseUserProfileFormParams): ReturnType
|
|
250
252
|
name: group,
|
251
253
|
displayHeader: groupDisplayHeader,
|
252
254
|
displayDescription: groupDisplayDescription,
|
255
|
+
annotations: groupAnnotations,
|
253
256
|
html5DataAnnotations: {}
|
254
257
|
};
|
255
258
|
}
|
@@ -292,7 +295,7 @@ export function useUserProfileForm(params: UseUserProfileFormParams): ReturnType
|
|
292
295
|
0,
|
293
296
|
{
|
294
297
|
name: "password",
|
295
|
-
displayName: id<`\${${
|
298
|
+
displayName: id<`\${${MessageKey_defaultSet}}`>("${password}"),
|
296
299
|
required: true,
|
297
300
|
readOnly: false,
|
298
301
|
validators: {},
|
@@ -302,7 +305,7 @@ export function useUserProfileForm(params: UseUserProfileFormParams): ReturnType
|
|
302
305
|
},
|
303
306
|
{
|
304
307
|
name: "password-confirm",
|
305
|
-
displayName: id<`\${${
|
308
|
+
displayName: id<`\${${MessageKey_defaultSet}}`>("${passwordConfirm}"),
|
306
309
|
required: true,
|
307
310
|
readOnly: false,
|
308
311
|
validators: {},
|
@@ -412,6 +415,24 @@ export function useUserProfileForm(params: UseUserProfileFormParams): ReturnType
|
|
412
415
|
formFieldStates: state.formFieldStates
|
413
416
|
});
|
414
417
|
|
418
|
+
simulate_focus_lost: {
|
419
|
+
const { displayErrorsImmediately = false } = formAction;
|
420
|
+
|
421
|
+
if (!displayErrorsImmediately) {
|
422
|
+
break simulate_focus_lost;
|
423
|
+
}
|
424
|
+
|
425
|
+
for (const fieldIndex of formAction.valueOrValues instanceof Array
|
426
|
+
? formAction.valueOrValues.map((...[, index]) => index)
|
427
|
+
: [undefined]) {
|
428
|
+
state = reducer(state, {
|
429
|
+
action: "focus lost",
|
430
|
+
name: formAction.name,
|
431
|
+
fieldIndex
|
432
|
+
});
|
433
|
+
}
|
434
|
+
}
|
435
|
+
|
415
436
|
update_password_confirm: {
|
416
437
|
if (doMakeUserConfirmPassword) {
|
417
438
|
break update_password_confirm;
|
@@ -424,7 +445,31 @@ export function useUserProfileForm(params: UseUserProfileFormParams): ReturnType
|
|
424
445
|
state = reducer(state, {
|
425
446
|
action: "update",
|
426
447
|
name: "password-confirm",
|
427
|
-
valueOrValues: formAction.valueOrValues
|
448
|
+
valueOrValues: formAction.valueOrValues,
|
449
|
+
displayErrorsImmediately: formAction.displayErrorsImmediately
|
450
|
+
});
|
451
|
+
}
|
452
|
+
|
453
|
+
trigger_password_confirm_validation_on_password_change: {
|
454
|
+
if (!doMakeUserConfirmPassword) {
|
455
|
+
break trigger_password_confirm_validation_on_password_change;
|
456
|
+
}
|
457
|
+
|
458
|
+
if (formAction.name !== "password") {
|
459
|
+
break trigger_password_confirm_validation_on_password_change;
|
460
|
+
}
|
461
|
+
|
462
|
+
state = reducer(state, {
|
463
|
+
action: "update",
|
464
|
+
name: "password-confirm",
|
465
|
+
valueOrValues: (() => {
|
466
|
+
const formFieldState = state.formFieldStates.find(({ attribute }) => attribute.name === "password-confirm");
|
467
|
+
|
468
|
+
assert(formFieldState !== undefined);
|
469
|
+
|
470
|
+
return formFieldState.valueOrValues;
|
471
|
+
})(),
|
472
|
+
displayErrorsImmediately: formAction.displayErrorsImmediately
|
428
473
|
});
|
429
474
|
}
|
430
475
|
|
@@ -612,7 +657,14 @@ function useGetErrors(params: { kcContext: KcContextLike_useGetErrors; i18n: I18
|
|
612
657
|
return [
|
613
658
|
{
|
614
659
|
errorMessageStr,
|
615
|
-
errorMessage:
|
660
|
+
errorMessage: (
|
661
|
+
<span
|
662
|
+
key={0}
|
663
|
+
dangerouslySetInnerHTML={{
|
664
|
+
__html: errorMessageStr
|
665
|
+
}}
|
666
|
+
/>
|
667
|
+
),
|
616
668
|
fieldIndex: undefined,
|
617
669
|
source: {
|
618
670
|
type: "server"
|
@@ -1126,7 +1178,7 @@ function useGetErrors(params: { kcContext: KcContextLike_useGetErrors; i18n: I18
|
|
1126
1178
|
break validator_x;
|
1127
1179
|
}
|
1128
1180
|
|
1129
|
-
const msgArgs = [errorMessageKey ?? id<
|
1181
|
+
const msgArgs = [errorMessageKey ?? id<MessageKey_defaultSet>("shouldMatchPattern"), pattern] as const;
|
1130
1182
|
|
1131
1183
|
errors.push({
|
1132
1184
|
errorMessage: <Fragment key={`${attributeName}-${errors.length}`}>{advancedMsg(...msgArgs)}</Fragment>,
|
@@ -1165,7 +1217,7 @@ function useGetErrors(params: { kcContext: KcContextLike_useGetErrors; i18n: I18
|
|
1165
1217
|
break validator_x;
|
1166
1218
|
}
|
1167
1219
|
|
1168
|
-
const msgArgs = [id<
|
1220
|
+
const msgArgs = [id<MessageKey_defaultSet>("invalidEmailMessage")] as const;
|
1169
1221
|
|
1170
1222
|
errors.push({
|
1171
1223
|
errorMessage: <Fragment key={`${attributeName}-${errors.length}`}>{msg(...msgArgs)}</Fragment>,
|
@@ -1257,11 +1309,11 @@ function useGetErrors(params: { kcContext: KcContextLike_useGetErrors; i18n: I18
|
|
1257
1309
|
break validator_x;
|
1258
1310
|
}
|
1259
1311
|
|
1260
|
-
const msgArgs = [id<
|
1312
|
+
const msgArgs = [id<MessageKey_defaultSet>("notAValidOption")] as const;
|
1261
1313
|
|
1262
1314
|
errors.push({
|
1263
|
-
errorMessage: <Fragment key={`${attributeName}-${errors.length}`}>{
|
1264
|
-
errorMessageStr:
|
1315
|
+
errorMessage: <Fragment key={`${attributeName}-${errors.length}`}>{msg(...msgArgs)}</Fragment>,
|
1316
|
+
errorMessageStr: msgStr(...msgArgs),
|
1265
1317
|
fieldIndex: undefined,
|
1266
1318
|
source: {
|
1267
1319
|
type: "validator",
|
@@ -1342,14 +1394,10 @@ export function getButtonToDisplayForMultivaluedAttributeField(params: { attribu
|
|
1342
1394
|
})();
|
1343
1395
|
|
1344
1396
|
if (maxCount === undefined) {
|
1345
|
-
return
|
1346
|
-
}
|
1347
|
-
|
1348
|
-
if (values.length === maxCount) {
|
1349
|
-
return false;
|
1397
|
+
return true;
|
1350
1398
|
}
|
1351
1399
|
|
1352
|
-
return
|
1400
|
+
return values.length !== maxCount;
|
1353
1401
|
})();
|
1354
1402
|
|
1355
1403
|
return { hasRemove, hasAdd };
|
@@ -19,7 +19,7 @@ export default function Error(props: PageProps<Extract<KcContext, { pageId: "err
|
|
19
19
|
headerNode={msg("errorTitle")}
|
20
20
|
>
|
21
21
|
<div id="kc-error-message">
|
22
|
-
<p className="instruction"
|
22
|
+
<p className="instruction" dangerouslySetInnerHTML={{ __html: message.summary }} />
|
23
23
|
{!skipLink && client !== undefined && client.baseUrl !== undefined && (
|
24
24
|
<p>
|
25
25
|
<a id="backToApplication" href={client.baseUrl}>
|
package/src/login/pages/Info.tsx
CHANGED
@@ -5,7 +5,7 @@ import type { I18n } from "../i18n";
|
|
5
5
|
export default function Info(props: PageProps<Extract<KcContext, { pageId: "info.ftl" }>, I18n>) {
|
6
6
|
const { kcContext, i18n, doUseDefaultCss, Template, classes } = props;
|
7
7
|
|
8
|
-
const {
|
8
|
+
const { advancedMsgStr, msg } = i18n;
|
9
9
|
|
10
10
|
const { messageHeader, message, requiredActions, skipLink, pageRedirectUri, actionUri, client } = kcContext;
|
11
11
|
|
@@ -16,13 +16,33 @@ export default function Info(props: PageProps<Extract<KcContext, { pageId: "info
|
|
16
16
|
doUseDefaultCss={doUseDefaultCss}
|
17
17
|
classes={classes}
|
18
18
|
displayMessage={false}
|
19
|
-
headerNode={
|
19
|
+
headerNode={
|
20
|
+
<span
|
21
|
+
dangerouslySetInnerHTML={{
|
22
|
+
__html: messageHeader ?? message.summary
|
23
|
+
}}
|
24
|
+
/>
|
25
|
+
}
|
20
26
|
>
|
21
27
|
<div id="kc-info-message">
|
22
|
-
<p
|
23
|
-
|
24
|
-
{
|
25
|
-
|
28
|
+
<p
|
29
|
+
className="instruction"
|
30
|
+
dangerouslySetInnerHTML={{
|
31
|
+
__html: (() => {
|
32
|
+
let html = message.summary;
|
33
|
+
|
34
|
+
if (requiredActions) {
|
35
|
+
html += "<b>";
|
36
|
+
|
37
|
+
html += requiredActions.map(requiredAction => advancedMsgStr(`requiredAction.${requiredAction}`)).join(", ");
|
38
|
+
|
39
|
+
html += "</b>";
|
40
|
+
}
|
41
|
+
|
42
|
+
return html;
|
43
|
+
})()
|
44
|
+
}}
|
45
|
+
/>
|
26
46
|
{(() => {
|
27
47
|
if (skipLink) {
|
28
48
|
return null;
|
@@ -60,9 +60,10 @@ export default function Login(props: PageProps<Extract<KcContext, { pageId: "log
|
|
60
60
|
href={p.loginUrl}
|
61
61
|
>
|
62
62
|
{p.iconClasses && <i className={clsx(kcClsx("kcCommonLogoIdP"), p.iconClasses)} aria-hidden="true"></i>}
|
63
|
-
<span
|
64
|
-
{p.
|
65
|
-
|
63
|
+
<span
|
64
|
+
className={clsx(kcClsx("kcFormSocialAccountNameClass"), p.iconClasses && "kc-social-icon-text")}
|
65
|
+
dangerouslySetInnerHTML={{ __html: p.displayName }}
|
66
|
+
></span>
|
66
67
|
</a>
|
67
68
|
</li>
|
68
69
|
))}
|
@@ -105,9 +106,14 @@ export default function Login(props: PageProps<Extract<KcContext, { pageId: "log
|
|
105
106
|
aria-invalid={messagesPerField.existsError("username", "password")}
|
106
107
|
/>
|
107
108
|
{messagesPerField.existsError("username", "password") && (
|
108
|
-
<span
|
109
|
-
|
110
|
-
|
109
|
+
<span
|
110
|
+
id="input-error"
|
111
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
112
|
+
aria-live="polite"
|
113
|
+
dangerouslySetInnerHTML={{
|
114
|
+
__html: messagesPerField.getFirstError("username", "password")
|
115
|
+
}}
|
116
|
+
/>
|
111
117
|
)}
|
112
118
|
</div>
|
113
119
|
)}
|
@@ -128,9 +134,14 @@ export default function Login(props: PageProps<Extract<KcContext, { pageId: "log
|
|
128
134
|
/>
|
129
135
|
</PasswordWrapper>
|
130
136
|
{usernameHidden && messagesPerField.existsError("username", "password") && (
|
131
|
-
<span
|
132
|
-
|
133
|
-
|
137
|
+
<span
|
138
|
+
id="input-error"
|
139
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
140
|
+
aria-live="polite"
|
141
|
+
dangerouslySetInnerHTML={{
|
142
|
+
__html: messagesPerField.getFirstError("username", "password")
|
143
|
+
}}
|
144
|
+
/>
|
134
145
|
)}
|
135
146
|
</div>
|
136
147
|
|
@@ -112,9 +112,14 @@ export default function LoginConfigTotp(props: PageProps<Extract<KcContext, { pa
|
|
112
112
|
/>
|
113
113
|
|
114
114
|
{messagesPerField.existsError("totp") && (
|
115
|
-
<span
|
116
|
-
|
117
|
-
|
115
|
+
<span
|
116
|
+
id="input-error-otp-code"
|
117
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
118
|
+
aria-live="polite"
|
119
|
+
dangerouslySetInnerHTML={{
|
120
|
+
__html: messagesPerField.get("totp")
|
121
|
+
}}
|
122
|
+
/>
|
118
123
|
)}
|
119
124
|
</div>
|
120
125
|
<input type="hidden" id="totpSecret" name="totpSecret" value={totp.totpSecret} />
|
@@ -138,9 +143,14 @@ export default function LoginConfigTotp(props: PageProps<Extract<KcContext, { pa
|
|
138
143
|
aria-invalid={messagesPerField.existsError("userLabel")}
|
139
144
|
/>
|
140
145
|
{messagesPerField.existsError("userLabel") && (
|
141
|
-
<span
|
142
|
-
|
143
|
-
|
146
|
+
<span
|
147
|
+
id="input-error-otp-label"
|
148
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
149
|
+
aria-live="polite"
|
150
|
+
dangerouslySetInnerHTML={{
|
151
|
+
__html: messagesPerField.get("userLabel")
|
152
|
+
}}
|
153
|
+
/>
|
144
154
|
)}
|
145
155
|
</div>
|
146
156
|
</div>
|
@@ -70,9 +70,14 @@ export default function LoginOtp(props: PageProps<Extract<KcContext, { pageId: "
|
|
70
70
|
aria-invalid={messagesPerField.existsError("totp")}
|
71
71
|
/>
|
72
72
|
{messagesPerField.existsError("totp") && (
|
73
|
-
<span
|
74
|
-
|
75
|
-
|
73
|
+
<span
|
74
|
+
id="input-error-otp-code"
|
75
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
76
|
+
aria-live="polite"
|
77
|
+
dangerouslySetInnerHTML={{
|
78
|
+
__html: messagesPerField.get("totp")
|
79
|
+
}}
|
80
|
+
/>
|
76
81
|
)}
|
77
82
|
</div>
|
78
83
|
</div>
|
@@ -60,9 +60,14 @@ export default function LoginPassword(props: PageProps<Extract<KcContext, { page
|
|
60
60
|
</PasswordWrapper>
|
61
61
|
|
62
62
|
{messagesPerField.existsError("password") && (
|
63
|
-
<span
|
64
|
-
|
65
|
-
|
63
|
+
<span
|
64
|
+
id="input-error-password"
|
65
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
66
|
+
aria-live="polite"
|
67
|
+
dangerouslySetInnerHTML={{
|
68
|
+
__html: messagesPerField.get("password")
|
69
|
+
}}
|
70
|
+
/>
|
66
71
|
)}
|
67
72
|
</div>
|
68
73
|
<div className={kcClsx("kcFormGroupClass", "kcFormSettingClass")}>
|
@@ -43,9 +43,14 @@ export default function LoginRecoveryAuthnCodeInput(props: PageProps<Extract<KcC
|
|
43
43
|
autoFocus
|
44
44
|
/>
|
45
45
|
{messagesPerField.existsError("recoveryCodeInput") && (
|
46
|
-
<span
|
47
|
-
|
48
|
-
|
46
|
+
<span
|
47
|
+
id="input-error"
|
48
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
49
|
+
aria-live="polite"
|
50
|
+
dangerouslySetInnerHTML={{
|
51
|
+
__html: messagesPerField.get("recoveryCodeInput")
|
52
|
+
}}
|
53
|
+
/>
|
49
54
|
)}
|
50
55
|
</div>
|
51
56
|
</div>
|
@@ -48,9 +48,14 @@ export default function LoginResetPassword(props: PageProps<Extract<KcContext, {
|
|
48
48
|
aria-invalid={messagesPerField.existsError("username")}
|
49
49
|
/>
|
50
50
|
{messagesPerField.existsError("username") && (
|
51
|
-
<span
|
52
|
-
|
53
|
-
|
51
|
+
<span
|
52
|
+
id="input-error-username"
|
53
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
54
|
+
aria-live="polite"
|
55
|
+
dangerouslySetInnerHTML={{
|
56
|
+
__html: messagesPerField.get("username")
|
57
|
+
}}
|
58
|
+
/>
|
54
59
|
)}
|
55
60
|
</div>
|
56
61
|
</div>
|
@@ -32,25 +32,30 @@ export default function LoginUpdatePassword(props: PageProps<Extract<KcContext,
|
|
32
32
|
<label htmlFor="password-new" className={kcClsx("kcLabelClass")}>
|
33
33
|
{msg("passwordNew")}
|
34
34
|
</label>
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
35
|
+
</div>
|
36
|
+
<div className={kcClsx("kcInputWrapperClass")}>
|
37
|
+
<PasswordWrapper kcClsx={kcClsx} i18n={i18n} passwordInputId="password-new">
|
38
|
+
<input
|
39
|
+
type="password"
|
40
|
+
id="password-new"
|
41
|
+
name="password-new"
|
42
|
+
className={kcClsx("kcInputClass")}
|
43
|
+
autoFocus
|
44
|
+
autoComplete="new-password"
|
45
|
+
aria-invalid={messagesPerField.existsError("password", "password-confirm")}
|
46
|
+
/>
|
47
|
+
</PasswordWrapper>
|
48
|
+
|
49
|
+
{messagesPerField.existsError("password") && (
|
50
|
+
<span
|
51
|
+
id="input-error-password"
|
52
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
53
|
+
aria-live="polite"
|
54
|
+
dangerouslySetInnerHTML={{
|
55
|
+
__html: messagesPerField.get("password")
|
56
|
+
}}
|
57
|
+
/>
|
58
|
+
)}
|
54
59
|
</div>
|
55
60
|
</div>
|
56
61
|
|
@@ -74,37 +79,40 @@ export default function LoginUpdatePassword(props: PageProps<Extract<KcContext,
|
|
74
79
|
</PasswordWrapper>
|
75
80
|
|
76
81
|
{messagesPerField.existsError("password-confirm") && (
|
77
|
-
<span
|
78
|
-
|
79
|
-
|
82
|
+
<span
|
83
|
+
id="input-error-password-confirm"
|
84
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
85
|
+
aria-live="polite"
|
86
|
+
dangerouslySetInnerHTML={{
|
87
|
+
__html: messagesPerField.get("password-confirm")
|
88
|
+
}}
|
89
|
+
/>
|
80
90
|
)}
|
81
91
|
</div>
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
<
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
"kcButtonLargeClass"
|
93
|
-
)}
|
94
|
-
type="submit"
|
95
|
-
value={msgStr("doSubmit")}
|
96
|
-
/>
|
97
|
-
{isAppInitiatedAction && (
|
98
|
-
<button
|
99
|
-
className={kcClsx("kcButtonClass", "kcButtonDefaultClass", "kcButtonLargeClass")}
|
100
|
-
type="submit"
|
101
|
-
name="cancel-aia"
|
102
|
-
value="true"
|
103
|
-
>
|
104
|
-
{msg("doCancel")}
|
105
|
-
</button>
|
92
|
+
</div>
|
93
|
+
<div className={kcClsx("kcFormGroupClass")}>
|
94
|
+
<LogoutOtherSessions kcClsx={kcClsx} i18n={i18n} />
|
95
|
+
<div id="kc-form-buttons" className={kcClsx("kcFormButtonsClass")}>
|
96
|
+
<input
|
97
|
+
className={kcClsx(
|
98
|
+
"kcButtonClass",
|
99
|
+
"kcButtonPrimaryClass",
|
100
|
+
!isAppInitiatedAction && "kcButtonBlockClass",
|
101
|
+
"kcButtonLargeClass"
|
106
102
|
)}
|
107
|
-
|
103
|
+
type="submit"
|
104
|
+
value={msgStr("doSubmit")}
|
105
|
+
/>
|
106
|
+
{isAppInitiatedAction && (
|
107
|
+
<button
|
108
|
+
className={kcClsx("kcButtonClass", "kcButtonDefaultClass", "kcButtonLargeClass")}
|
109
|
+
type="submit"
|
110
|
+
name="cancel-aia"
|
111
|
+
value="true"
|
112
|
+
>
|
113
|
+
{msg("doCancel")}
|
114
|
+
</button>
|
115
|
+
)}
|
108
116
|
</div>
|
109
117
|
</div>
|
110
118
|
</form>
|
@@ -118,9 +118,14 @@ function TermsAcceptance(props: {
|
|
118
118
|
</div>
|
119
119
|
{messagesPerField.existsError("termsAccepted") && (
|
120
120
|
<div className={kcClsx("kcLabelWrapperClass")}>
|
121
|
-
<span
|
122
|
-
|
123
|
-
|
121
|
+
<span
|
122
|
+
id="input-error-terms-accepted"
|
123
|
+
className={kcClsx("kcInputErrorMessageClass")}
|
124
|
+
aria-live="polite"
|
125
|
+
dangerouslySetInnerHTML={{
|
126
|
+
__html: messagesPerField.get("termsAccepted")
|
127
|
+
}}
|
128
|
+
/>
|
124
129
|
</div>
|
125
130
|
)}
|
126
131
|
</div>
|
@@ -8,7 +8,7 @@ export default function SelectAuthenticator(props: PageProps<Extract<KcContext,
|
|
8
8
|
const { url, auth } = kcContext;
|
9
9
|
|
10
10
|
const { kcClsx } = getKcClsx({ doUseDefaultCss, classes });
|
11
|
-
const { msg } = i18n;
|
11
|
+
const { msg, advancedMsg } = i18n;
|
12
12
|
|
13
13
|
return (
|
14
14
|
<Template
|
@@ -30,11 +30,11 @@ export default function SelectAuthenticator(props: PageProps<Extract<KcContext,
|
|
30
30
|
value={authenticationSelection.authExecId}
|
31
31
|
>
|
32
32
|
<div className={kcClsx("kcSelectAuthListItemIconClass")}>
|
33
|
-
<i className={kcClsx(authenticationSelection.iconCssClass
|
33
|
+
<i className={kcClsx("kcSelectAuthListItemIconPropertyClass", authenticationSelection.iconCssClass)} />
|
34
34
|
</div>
|
35
35
|
<div className={kcClsx("kcSelectAuthListItemBodyClass")}>
|
36
|
-
<div className={kcClsx("kcSelectAuthListItemHeadingClass")}>{
|
37
|
-
<div className={kcClsx("kcSelectAuthListItemDescriptionClass")}>{
|
36
|
+
<div className={kcClsx("kcSelectAuthListItemHeadingClass")}>{advancedMsg(authenticationSelection.displayName)}</div>
|
37
|
+
<div className={kcClsx("kcSelectAuthListItemDescriptionClass")}>{advancedMsg(authenticationSelection.helpText)}</div>
|
38
38
|
</div>
|
39
39
|
<div className={kcClsx("kcSelectAuthListItemFillClass")} />
|
40
40
|
<div className={kcClsx("kcSelectAuthListItemArrowClass")}>
|
@@ -204,13 +204,13 @@ export default function WebauthnAuthenticate(props: PageProps<Extract<KcContext,
|
|
204
204
|
className={kcClsx("kcSelectAuthListItemDescriptionClass")}
|
205
205
|
>
|
206
206
|
{authenticator.transports.displayNameProperties
|
207
|
-
.map((
|
208
|
-
|
207
|
+
.map((displayNameProperty, i, arr) => ({
|
208
|
+
displayNameProperty,
|
209
209
|
hasNext: i !== arr.length - 1
|
210
210
|
}))
|
211
|
-
.map(({
|
212
|
-
<Fragment key={
|
213
|
-
|
211
|
+
.map(({ displayNameProperty, hasNext }) => (
|
212
|
+
<Fragment key={displayNameProperty}>
|
213
|
+
{advancedMsg(displayNameProperty)}
|
214
214
|
{hasNext && <span>, </span>}
|
215
215
|
</Fragment>
|
216
216
|
))}
|
@@ -153,7 +153,7 @@ export default function WebauthnRegister(props: PageProps<Extract<KcContext, { p
|
|
153
153
|
|
154
154
|
function getPubKeyCredParams(signatureAlgorithmsList) {
|
155
155
|
let pubKeyCredParams = [];
|
156
|
-
if (signatureAlgorithmsList ===
|
156
|
+
if (signatureAlgorithmsList.length === 0) {
|
157
157
|
pubKeyCredParams.push({type: "public-key", alg: -7});
|
158
158
|
return pubKeyCredParams;
|
159
159
|
}
|
@@ -184,7 +184,7 @@ export default function WebauthnRegister(props: PageProps<Extract<KcContext, { p
|
|
184
184
|
}
|
185
185
|
|
186
186
|
function getTransportsAsString(transportsList) {
|
187
|
-
if (transportsList === '' || transportsList
|
187
|
+
if (transportsList === '' || Array.isArray(transportsList)) return "";
|
188
188
|
|
189
189
|
let transportsString = "";
|
190
190
|
|