keycloakify 9.6.6 → 10.0.0-rc.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.
Files changed (424) hide show
  1. package/README.md +1 -1
  2. package/account/Template.js +34 -14
  3. package/account/Template.js.map +1 -1
  4. package/account/i18n/baseMessages/de.d.ts +1 -1
  5. package/account/i18n/baseMessages/de.js +1 -1
  6. package/account/i18n/baseMessages/de.js.map +1 -1
  7. package/account/i18n/baseMessages/en.d.ts +2 -0
  8. package/account/i18n/baseMessages/en.js +2 -0
  9. package/account/i18n/baseMessages/en.js.map +1 -1
  10. package/account/i18n/baseMessages/es.d.ts +230 -0
  11. package/account/i18n/baseMessages/es.js +231 -1
  12. package/account/i18n/baseMessages/es.js.map +1 -1
  13. package/account/i18n/baseMessages/index.d.ts +353 -407
  14. package/account/i18n/baseMessages/index.js +1 -0
  15. package/account/i18n/baseMessages/index.js.map +1 -1
  16. package/account/i18n/baseMessages/pl.d.ts +115 -1
  17. package/account/i18n/baseMessages/pl.js +115 -1
  18. package/account/i18n/baseMessages/pl.js.map +1 -1
  19. package/account/i18n/baseMessages/tr.d.ts +1 -1
  20. package/account/i18n/baseMessages/tr.js +1 -1
  21. package/account/i18n/baseMessages/tr.js.map +1 -1
  22. package/account/i18n/baseMessages/uk.d.ts +337 -0
  23. package/account/i18n/baseMessages/uk.js +342 -0
  24. package/account/i18n/baseMessages/uk.js.map +1 -0
  25. package/account/i18n/baseMessages/zh-CN.d.ts +10 -0
  26. package/account/i18n/baseMessages/zh-CN.js +10 -0
  27. package/account/i18n/baseMessages/zh-CN.js.map +1 -1
  28. package/bin/constants.d.ts +0 -1
  29. package/bin/constants.js +1 -2
  30. package/bin/constants.js.map +1 -1
  31. package/bin/download-builtin-keycloak-theme.js +12 -2
  32. package/bin/download-builtin-keycloak-theme.js.map +1 -1
  33. package/bin/keycloakify/buildJars/buildJar.d.ts +14 -0
  34. package/bin/keycloakify/buildJars/buildJar.js +216 -0
  35. package/bin/keycloakify/buildJars/buildJar.js.map +1 -0
  36. package/bin/keycloakify/buildJars/buildJars.d.ts +10 -0
  37. package/bin/keycloakify/buildJars/buildJars.js +95 -0
  38. package/bin/keycloakify/buildJars/buildJars.js.map +1 -0
  39. package/bin/keycloakify/buildJars/extensionVersions.d.ts +12 -0
  40. package/bin/keycloakify/buildJars/extensionVersions.js +7 -0
  41. package/bin/keycloakify/buildJars/extensionVersions.js.map +1 -0
  42. package/bin/keycloakify/buildJars/generatePom.d.ts +13 -0
  43. package/bin/keycloakify/buildJars/generatePom.js +94 -0
  44. package/bin/keycloakify/buildJars/generatePom.js.map +1 -0
  45. package/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.d.ts +6 -0
  46. package/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.js +35 -0
  47. package/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.js.map +1 -0
  48. package/bin/keycloakify/buildJars/index.d.ts +1 -0
  49. package/bin/keycloakify/buildJars/index.js +18 -0
  50. package/bin/keycloakify/buildJars/index.js.map +1 -0
  51. package/bin/keycloakify/buildOptions/UserProvidedBuildOptions.d.ts +0 -8
  52. package/bin/keycloakify/buildOptions/UserProvidedBuildOptions.js +1 -3
  53. package/bin/keycloakify/buildOptions/UserProvidedBuildOptions.js.map +1 -1
  54. package/bin/keycloakify/buildOptions/buildOptions.d.ts +0 -2
  55. package/bin/keycloakify/buildOptions/buildOptions.js +3 -5
  56. package/bin/keycloakify/buildOptions/buildOptions.js.map +1 -1
  57. package/bin/keycloakify/buildOptions/getNpmWorkspaceRootDirPath.js +1 -1
  58. package/bin/keycloakify/buildOptions/getNpmWorkspaceRootDirPath.js.map +1 -1
  59. package/bin/keycloakify/generateFtl/ftl_object_to_js_code_declaring_an_object.ftl +103 -232
  60. package/bin/keycloakify/generateFtl/generateFtl.js +17 -39
  61. package/bin/keycloakify/generateFtl/generateFtl.js.map +1 -1
  62. package/bin/keycloakify/generateFtl/pageId.d.ts +1 -1
  63. package/bin/keycloakify/generateFtl/pageId.js +11 -3
  64. package/bin/keycloakify/generateFtl/pageId.js.map +1 -1
  65. package/bin/keycloakify/generateStartKeycloakTestingContainer.d.ts +0 -1
  66. package/bin/keycloakify/generateStartKeycloakTestingContainer.js +3 -6
  67. package/bin/keycloakify/generateStartKeycloakTestingContainer.js.map +1 -1
  68. package/bin/keycloakify/generateTheme/bringInAccountV1.d.ts +1 -1
  69. package/bin/keycloakify/generateTheme/bringInAccountV1.js +5 -9
  70. package/bin/keycloakify/generateTheme/bringInAccountV1.js.map +1 -1
  71. package/bin/keycloakify/generateTheme/generateSrcMainResources.d.ts +21 -0
  72. package/bin/keycloakify/generateTheme/generateSrcMainResources.js +340 -0
  73. package/bin/keycloakify/generateTheme/generateSrcMainResources.js.map +1 -0
  74. package/bin/keycloakify/generateTheme/generateTheme.d.ts +5 -13
  75. package/bin/keycloakify/generateTheme/generateTheme.js +30 -293
  76. package/bin/keycloakify/generateTheme/generateTheme.js.map +1 -1
  77. package/bin/keycloakify/generateTheme/generateThemeVariants.d.ts +5 -0
  78. package/bin/keycloakify/generateTheme/generateThemeVariants.js +67 -0
  79. package/bin/keycloakify/generateTheme/generateThemeVariants.js.map +1 -0
  80. package/bin/keycloakify/generateTheme/readFieldNameUsage.js +54 -18
  81. package/bin/keycloakify/generateTheme/readFieldNameUsage.js.map +1 -1
  82. package/bin/keycloakify/keycloakify.js +28 -104
  83. package/bin/keycloakify/keycloakify.js.map +1 -1
  84. package/lib/useGetClassName.js +2 -2
  85. package/lib/useGetClassName.js.map +1 -1
  86. package/login/Fallback.d.ts +7 -1
  87. package/login/Fallback.js +32 -8
  88. package/login/Fallback.js.map +1 -1
  89. package/login/Template.js +76 -20
  90. package/login/Template.js.map +1 -1
  91. package/login/TemplateProps.d.ts +4 -2
  92. package/login/UserProfileFormFields.d.ts +22 -0
  93. package/login/UserProfileFormFields.js +327 -0
  94. package/login/UserProfileFormFields.js.map +1 -0
  95. package/login/i18n/baseMessages/ar.d.ts +3 -0
  96. package/login/i18n/baseMessages/ar.js +3 -0
  97. package/login/i18n/baseMessages/ar.js.map +1 -1
  98. package/login/i18n/baseMessages/ca.d.ts +1 -0
  99. package/login/i18n/baseMessages/ca.js +1 -0
  100. package/login/i18n/baseMessages/ca.js.map +1 -1
  101. package/login/i18n/baseMessages/cs.d.ts +3 -0
  102. package/login/i18n/baseMessages/cs.js +3 -0
  103. package/login/i18n/baseMessages/cs.js.map +1 -1
  104. package/login/i18n/baseMessages/da.d.ts +1 -0
  105. package/login/i18n/baseMessages/da.js +1 -0
  106. package/login/i18n/baseMessages/da.js.map +1 -1
  107. package/login/i18n/baseMessages/de.d.ts +1 -0
  108. package/login/i18n/baseMessages/de.js +1 -0
  109. package/login/i18n/baseMessages/de.js.map +1 -1
  110. package/login/i18n/baseMessages/el.d.ts +1 -0
  111. package/login/i18n/baseMessages/el.js +1 -0
  112. package/login/i18n/baseMessages/el.js.map +1 -1
  113. package/login/i18n/baseMessages/en.d.ts +7 -0
  114. package/login/i18n/baseMessages/en.js +23 -16
  115. package/login/i18n/baseMessages/en.js.map +1 -1
  116. package/login/i18n/baseMessages/es.d.ts +239 -0
  117. package/login/i18n/baseMessages/es.js +240 -1
  118. package/login/i18n/baseMessages/es.js.map +1 -1
  119. package/login/i18n/baseMessages/fa.d.ts +1 -0
  120. package/login/i18n/baseMessages/fa.js +1 -0
  121. package/login/i18n/baseMessages/fa.js.map +1 -1
  122. package/login/i18n/baseMessages/fi.d.ts +1 -0
  123. package/login/i18n/baseMessages/fi.js +1 -0
  124. package/login/i18n/baseMessages/fi.js.map +1 -1
  125. package/login/i18n/baseMessages/fr.d.ts +1 -0
  126. package/login/i18n/baseMessages/fr.js +2 -1
  127. package/login/i18n/baseMessages/fr.js.map +1 -1
  128. package/login/i18n/baseMessages/hu.d.ts +1 -0
  129. package/login/i18n/baseMessages/hu.js +1 -0
  130. package/login/i18n/baseMessages/hu.js.map +1 -1
  131. package/login/i18n/baseMessages/index.d.ts +211 -416
  132. package/login/i18n/baseMessages/index.js +1 -0
  133. package/login/i18n/baseMessages/index.js.map +1 -1
  134. package/login/i18n/baseMessages/it.d.ts +1 -0
  135. package/login/i18n/baseMessages/it.js +1 -0
  136. package/login/i18n/baseMessages/it.js.map +1 -1
  137. package/login/i18n/baseMessages/ja.d.ts +1 -0
  138. package/login/i18n/baseMessages/ja.js +1 -0
  139. package/login/i18n/baseMessages/ja.js.map +1 -1
  140. package/login/i18n/baseMessages/lt.d.ts +1 -0
  141. package/login/i18n/baseMessages/lt.js +1 -0
  142. package/login/i18n/baseMessages/lt.js.map +1 -1
  143. package/login/i18n/baseMessages/lv.d.ts +1 -0
  144. package/login/i18n/baseMessages/lv.js +1 -0
  145. package/login/i18n/baseMessages/lv.js.map +1 -1
  146. package/login/i18n/baseMessages/nl.d.ts +1 -0
  147. package/login/i18n/baseMessages/nl.js +1 -0
  148. package/login/i18n/baseMessages/nl.js.map +1 -1
  149. package/login/i18n/baseMessages/no.d.ts +1 -0
  150. package/login/i18n/baseMessages/no.js +1 -0
  151. package/login/i18n/baseMessages/no.js.map +1 -1
  152. package/login/i18n/baseMessages/pl.d.ts +1 -0
  153. package/login/i18n/baseMessages/pl.js +1 -0
  154. package/login/i18n/baseMessages/pl.js.map +1 -1
  155. package/login/i18n/baseMessages/pt-BR.d.ts +1 -0
  156. package/login/i18n/baseMessages/pt-BR.js +1 -0
  157. package/login/i18n/baseMessages/pt-BR.js.map +1 -1
  158. package/login/i18n/baseMessages/ru.d.ts +1 -0
  159. package/login/i18n/baseMessages/ru.js +1 -0
  160. package/login/i18n/baseMessages/ru.js.map +1 -1
  161. package/login/i18n/baseMessages/sk.d.ts +2 -0
  162. package/login/i18n/baseMessages/sk.js +3 -1
  163. package/login/i18n/baseMessages/sk.js.map +1 -1
  164. package/login/i18n/baseMessages/sv.d.ts +1 -0
  165. package/login/i18n/baseMessages/sv.js +1 -0
  166. package/login/i18n/baseMessages/sv.js.map +1 -1
  167. package/login/i18n/baseMessages/th.d.ts +1 -0
  168. package/login/i18n/baseMessages/th.js +1 -0
  169. package/login/i18n/baseMessages/th.js.map +1 -1
  170. package/login/i18n/baseMessages/tr.d.ts +1 -0
  171. package/login/i18n/baseMessages/tr.js +1 -0
  172. package/login/i18n/baseMessages/tr.js.map +1 -1
  173. package/login/i18n/baseMessages/uk.d.ts +433 -0
  174. package/login/i18n/baseMessages/uk.js +438 -0
  175. package/login/i18n/baseMessages/uk.js.map +1 -0
  176. package/login/i18n/baseMessages/zh-CN.d.ts +273 -3
  177. package/login/i18n/baseMessages/zh-CN.js +325 -55
  178. package/login/i18n/baseMessages/zh-CN.js.map +1 -1
  179. package/login/i18n/i18n.d.ts +4 -0
  180. package/login/i18n/i18n.js +6 -2
  181. package/login/i18n/i18n.js.map +1 -1
  182. package/login/kcContext/KcContext.d.ts +181 -105
  183. package/login/kcContext/KcContext.js +1 -1
  184. package/login/kcContext/KcContext.js.map +1 -1
  185. package/login/kcContext/createGetKcContext.js +3 -9
  186. package/login/kcContext/createGetKcContext.js.map +1 -1
  187. package/login/kcContext/kcContextMocks.d.ts +1 -1
  188. package/login/kcContext/kcContextMocks.js +92 -198
  189. package/login/kcContext/kcContextMocks.js.map +1 -1
  190. package/login/lib/useDownloadTerms.d.ts +4 -1
  191. package/login/lib/useDownloadTerms.js +9 -4
  192. package/login/lib/useDownloadTerms.js.map +1 -1
  193. package/login/lib/useGetClassName.js +112 -73
  194. package/login/lib/useGetClassName.js.map +1 -1
  195. package/login/lib/useUserProfileForm.d.ts +74 -0
  196. package/login/lib/useUserProfileForm.js +868 -0
  197. package/login/lib/useUserProfileForm.js.map +1 -0
  198. package/login/pages/{UpdateUserProfile.d.ts → Code.d.ts} +2 -2
  199. package/login/pages/Code.js +13 -0
  200. package/login/pages/Code.js.map +1 -0
  201. package/login/pages/DeleteAccountConfirm.d.ts +7 -0
  202. package/login/pages/DeleteAccountConfirm.js +14 -0
  203. package/login/pages/DeleteAccountConfirm.js.map +1 -0
  204. package/login/pages/{RegisterUserProfile.d.ts → DeleteCredential.d.ts} +2 -2
  205. package/login/pages/DeleteCredential.js +14 -0
  206. package/login/pages/DeleteCredential.js.map +1 -0
  207. package/login/pages/Error.js +2 -2
  208. package/login/pages/Error.js.map +1 -1
  209. package/login/pages/FrontchannelLogout.d.ts +7 -0
  210. package/login/pages/FrontchannelLogout.js +14 -0
  211. package/login/pages/FrontchannelLogout.js.map +1 -0
  212. package/login/pages/IdpReviewUserProfile.d.ts +8 -2
  213. package/login/pages/IdpReviewUserProfile.js +3 -4
  214. package/login/pages/IdpReviewUserProfile.js.map +1 -1
  215. package/login/pages/Info.js +14 -1
  216. package/login/pages/Info.js.map +1 -1
  217. package/login/pages/Login.js +24 -38
  218. package/login/pages/Login.js.map +1 -1
  219. package/login/pages/LoginConfigTotp.js +8 -1
  220. package/login/pages/LoginConfigTotp.js.map +1 -1
  221. package/login/pages/{LoginDeviceVerifyUserCode.d.ts → LoginOauth2DeviceVerifyUserCode.d.ts} +1 -1
  222. package/login/pages/{LoginDeviceVerifyUserCode.js → LoginOauth2DeviceVerifyUserCode.js} +2 -2
  223. package/login/pages/LoginOauth2DeviceVerifyUserCode.js.map +1 -0
  224. package/login/pages/LoginOauthGrant.js +3 -2
  225. package/login/pages/LoginOauthGrant.js.map +1 -1
  226. package/login/pages/LoginOtp.js +4 -6
  227. package/login/pages/LoginOtp.js.map +1 -1
  228. package/login/pages/LoginPageExpired.js +1 -1
  229. package/login/pages/LoginPageExpired.js.map +1 -1
  230. package/login/pages/LoginPassword.d.ts +1 -1
  231. package/login/pages/LoginPassword.js +18 -11
  232. package/login/pages/LoginPassword.js.map +1 -1
  233. package/login/pages/LoginRecoveryAuthnCodeConfig.d.ts +7 -0
  234. package/login/pages/LoginRecoveryAuthnCodeConfig.js +147 -0
  235. package/login/pages/LoginRecoveryAuthnCodeConfig.js.map +1 -0
  236. package/login/pages/LoginRecoveryAuthnCodeInput.d.ts +7 -0
  237. package/login/pages/LoginRecoveryAuthnCodeInput.js +14 -0
  238. package/login/pages/LoginRecoveryAuthnCodeInput.js.map +1 -0
  239. package/login/pages/LoginResetOtp.d.ts +7 -0
  240. package/login/pages/LoginResetOtp.js +15 -0
  241. package/login/pages/LoginResetOtp.js.map +1 -0
  242. package/login/pages/LoginResetPassword.js +4 -3
  243. package/login/pages/LoginResetPassword.js.map +1 -1
  244. package/login/pages/LoginUpdatePassword.js +21 -3
  245. package/login/pages/LoginUpdatePassword.js.map +1 -1
  246. package/login/pages/LoginUpdateProfile.d.ts +8 -2
  247. package/login/pages/LoginUpdateProfile.js +11 -5
  248. package/login/pages/LoginUpdateProfile.js.map +1 -1
  249. package/login/pages/LoginUsername.js +11 -35
  250. package/login/pages/LoginUsername.js.map +1 -1
  251. package/login/pages/LoginVerifyEmail.js +1 -1
  252. package/login/pages/LoginVerifyEmail.js.map +1 -1
  253. package/login/pages/LoginX509Info.d.ts +7 -0
  254. package/login/pages/LoginX509Info.js +14 -0
  255. package/login/pages/LoginX509Info.js.map +1 -0
  256. package/login/pages/LogoutConfirm.js +1 -1
  257. package/login/pages/LogoutConfirm.js.map +1 -1
  258. package/login/pages/Register.d.ts +8 -2
  259. package/login/pages/Register.js +26 -4
  260. package/login/pages/Register.js.map +1 -1
  261. package/login/pages/SamlPostForm.js +1 -1
  262. package/login/pages/SamlPostForm.js.map +1 -1
  263. package/login/pages/SelectAuthenticator.js +5 -21
  264. package/login/pages/SelectAuthenticator.js.map +1 -1
  265. package/login/pages/Terms.js +4 -6
  266. package/login/pages/Terms.js.map +1 -1
  267. package/login/pages/UpdateEmail.d.ts +8 -2
  268. package/login/pages/UpdateEmail.js +16 -5
  269. package/login/pages/UpdateEmail.js.map +1 -1
  270. package/login/pages/WebauthnAuthenticate.js +121 -83
  271. package/login/pages/WebauthnAuthenticate.js.map +1 -1
  272. package/login/pages/WebauthnError.d.ts +7 -0
  273. package/login/pages/WebauthnError.js +21 -0
  274. package/login/pages/WebauthnError.js.map +1 -0
  275. package/login/pages/WebauthnRegister.d.ts +7 -0
  276. package/login/pages/WebauthnRegister.js +193 -0
  277. package/login/pages/WebauthnRegister.js.map +1 -0
  278. package/package.json +138 -43
  279. package/src/account/Template.tsx +41 -14
  280. package/src/account/i18n/baseMessages/de.ts +1 -1
  281. package/src/account/i18n/baseMessages/en.ts +2 -0
  282. package/src/account/i18n/baseMessages/es.ts +231 -1
  283. package/src/account/i18n/baseMessages/index.ts +1 -0
  284. package/src/account/i18n/baseMessages/pl.ts +115 -1
  285. package/src/account/i18n/baseMessages/tr.ts +1 -1
  286. package/src/account/i18n/baseMessages/uk.ts +343 -0
  287. package/src/account/i18n/baseMessages/zh-CN.ts +10 -0
  288. package/src/bin/constants.ts +0 -1
  289. package/src/bin/download-builtin-keycloak-theme.ts +14 -1
  290. package/src/bin/keycloakify/buildJars/buildJar.ts +163 -0
  291. package/src/bin/keycloakify/buildJars/buildJars.ts +62 -0
  292. package/src/bin/keycloakify/buildJars/extensionVersions.ts +16 -0
  293. package/src/bin/keycloakify/buildJars/generatePom.ts +86 -0
  294. package/src/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.ts +37 -0
  295. package/src/bin/keycloakify/buildJars/index.ts +1 -0
  296. package/src/bin/keycloakify/buildOptions/UserProvidedBuildOptions.ts +1 -5
  297. package/src/bin/keycloakify/buildOptions/buildOptions.ts +1 -5
  298. package/src/bin/keycloakify/buildOptions/getNpmWorkspaceRootDirPath.ts +1 -1
  299. package/src/bin/keycloakify/generateFtl/ftl_object_to_js_code_declaring_an_object.ftl +103 -232
  300. package/src/bin/keycloakify/generateFtl/generateFtl.ts +15 -31
  301. package/src/bin/keycloakify/generateFtl/pageId.ts +11 -3
  302. package/src/bin/keycloakify/generateStartKeycloakTestingContainer.ts +4 -8
  303. package/src/bin/keycloakify/generateTheme/bringInAccountV1.ts +5 -11
  304. package/src/bin/keycloakify/generateTheme/generateSrcMainResources.ts +267 -0
  305. package/src/bin/keycloakify/generateTheme/generateTheme.ts +22 -309
  306. package/src/bin/keycloakify/generateTheme/generateThemeVariants.ts +50 -0
  307. package/src/bin/keycloakify/generateTheme/readFieldNameUsage.ts +33 -8
  308. package/src/bin/keycloakify/keycloakify.ts +23 -56
  309. package/src/lib/useGetClassName.ts +2 -2
  310. package/src/login/Fallback.tsx +39 -9
  311. package/src/login/Template.tsx +160 -61
  312. package/src/login/TemplateProps.ts +113 -63
  313. package/src/login/UserProfileFormFields.tsx +750 -0
  314. package/src/login/i18n/baseMessages/ar.ts +3 -0
  315. package/src/login/i18n/baseMessages/ca.ts +1 -0
  316. package/src/login/i18n/baseMessages/cs.ts +3 -0
  317. package/src/login/i18n/baseMessages/da.ts +1 -0
  318. package/src/login/i18n/baseMessages/de.ts +1 -0
  319. package/src/login/i18n/baseMessages/el.ts +1 -0
  320. package/src/login/i18n/baseMessages/en.ts +23 -16
  321. package/src/login/i18n/baseMessages/es.ts +240 -1
  322. package/src/login/i18n/baseMessages/fa.ts +1 -0
  323. package/src/login/i18n/baseMessages/fi.ts +1 -0
  324. package/src/login/i18n/baseMessages/fr.ts +2 -1
  325. package/src/login/i18n/baseMessages/hu.ts +1 -0
  326. package/src/login/i18n/baseMessages/index.ts +1 -0
  327. package/src/login/i18n/baseMessages/it.ts +1 -0
  328. package/src/login/i18n/baseMessages/ja.ts +1 -0
  329. package/src/login/i18n/baseMessages/lt.ts +1 -0
  330. package/src/login/i18n/baseMessages/lv.ts +1 -0
  331. package/src/login/i18n/baseMessages/nl.ts +1 -0
  332. package/src/login/i18n/baseMessages/no.ts +1 -0
  333. package/src/login/i18n/baseMessages/pl.ts +1 -0
  334. package/src/login/i18n/baseMessages/pt-BR.ts +1 -0
  335. package/src/login/i18n/baseMessages/ru.ts +1 -0
  336. package/src/login/i18n/baseMessages/sk.ts +3 -1
  337. package/src/login/i18n/baseMessages/sv.ts +1 -0
  338. package/src/login/i18n/baseMessages/th.ts +1 -0
  339. package/src/login/i18n/baseMessages/tr.ts +1 -0
  340. package/src/login/i18n/baseMessages/uk.ts +439 -0
  341. package/src/login/i18n/baseMessages/zh-CN.ts +325 -55
  342. package/src/login/i18n/i18n.tsx +6 -2
  343. package/src/login/kcContext/KcContext.ts +216 -103
  344. package/src/login/kcContext/createGetKcContext.ts +11 -19
  345. package/src/login/kcContext/kcContextMocks.ts +165 -226
  346. package/src/login/lib/useDownloadTerms.ts +15 -7
  347. package/src/login/lib/useGetClassName.ts +112 -83
  348. package/src/login/lib/useUserProfileForm.tsx +1227 -0
  349. package/src/login/pages/Code.tsx +35 -0
  350. package/src/login/pages/DeleteAccountConfirm.tsx +53 -0
  351. package/src/login/pages/DeleteCredential.tsx +45 -0
  352. package/src/login/pages/Error.tsx +2 -2
  353. package/src/login/pages/FrontchannelLogout.tsx +41 -0
  354. package/src/login/pages/IdpReviewUserProfile.tsx +15 -5
  355. package/src/login/pages/Info.tsx +29 -19
  356. package/src/login/pages/Login.tsx +156 -117
  357. package/src/login/pages/LoginConfigTotp.tsx +26 -1
  358. package/src/login/pages/{LoginDeviceVerifyUserCode.tsx → LoginOauth2DeviceVerifyUserCode.tsx} +3 -1
  359. package/src/login/pages/LoginOauthGrant.tsx +38 -2
  360. package/src/login/pages/LoginOtp.tsx +73 -65
  361. package/src/login/pages/LoginPageExpired.tsx +1 -1
  362. package/src/login/pages/LoginPassword.tsx +77 -28
  363. package/src/login/pages/LoginRecoveryAuthnCodeConfig.tsx +260 -0
  364. package/src/login/pages/LoginRecoveryAuthnCodeInput.tsx +73 -0
  365. package/src/login/pages/LoginResetOtp.tsx +70 -0
  366. package/src/login/pages/LoginResetPassword.tsx +11 -4
  367. package/src/login/pages/LoginUpdatePassword.tsx +120 -81
  368. package/src/login/pages/LoginUpdateProfile.tsx +41 -115
  369. package/src/login/pages/LoginUsername.tsx +93 -101
  370. package/src/login/pages/LoginVerifyEmail.tsx +14 -8
  371. package/src/login/pages/LoginX509Info.tsx +94 -0
  372. package/src/login/pages/LogoutConfirm.tsx +2 -2
  373. package/src/login/pages/Register.tsx +83 -131
  374. package/src/login/pages/SamlPostForm.tsx +1 -1
  375. package/src/login/pages/SelectAuthenticator.tsx +29 -52
  376. package/src/login/pages/Terms.tsx +4 -7
  377. package/src/login/pages/UpdateEmail.tsx +69 -54
  378. package/src/login/pages/WebauthnAuthenticate.tsx +205 -165
  379. package/src/login/pages/WebauthnError.tsx +66 -0
  380. package/src/login/pages/WebauthnRegister.tsx +285 -0
  381. package/src/tools/formatNumber.ts +48 -0
  382. package/src/tools/useInsertLinkTags.ts +82 -0
  383. package/src/tools/useInsertScriptTags.ts +106 -0
  384. package/src/tools/useSetClassName.ts +21 -0
  385. package/tools/formatNumber.d.ts +1 -0
  386. package/tools/formatNumber.js +37 -0
  387. package/tools/formatNumber.js.map +1 -0
  388. package/tools/useInsertLinkTags.d.ts +7 -0
  389. package/tools/useInsertLinkTags.js +57 -0
  390. package/tools/useInsertLinkTags.js.map +1 -0
  391. package/tools/useInsertScriptTags.d.ts +20 -0
  392. package/tools/useInsertScriptTags.js +75 -0
  393. package/tools/useInsertScriptTags.js.map +1 -0
  394. package/tools/useSetClassName.d.ts +4 -0
  395. package/tools/useSetClassName.js +16 -0
  396. package/tools/useSetClassName.js.map +1 -0
  397. package/vite-plugin/tsconfig.tsbuildinfo +1 -1
  398. package/bin/keycloakify/generatePom.d.ts +0 -12
  399. package/bin/keycloakify/generatePom.js +0 -59
  400. package/bin/keycloakify/generatePom.js.map +0 -1
  401. package/lib/usePrepareTemplate.d.ts +0 -11
  402. package/lib/usePrepareTemplate.js +0 -80
  403. package/lib/usePrepareTemplate.js.map +0 -1
  404. package/login/lib/useFormValidation.d.ts +0 -47
  405. package/login/lib/useFormValidation.js +0 -316
  406. package/login/lib/useFormValidation.js.map +0 -1
  407. package/login/pages/LoginDeviceVerifyUserCode.js.map +0 -1
  408. package/login/pages/RegisterUserProfile.js +0 -18
  409. package/login/pages/RegisterUserProfile.js.map +0 -1
  410. package/login/pages/UpdateUserProfile.js +0 -17
  411. package/login/pages/UpdateUserProfile.js.map +0 -1
  412. package/login/pages/shared/UserProfileFormFields.d.ts +0 -18
  413. package/login/pages/shared/UserProfileFormFields.js +0 -58
  414. package/login/pages/shared/UserProfileFormFields.js.map +0 -1
  415. package/src/bin/keycloakify/generatePom.ts +0 -70
  416. package/src/lib/usePrepareTemplate.ts +0 -113
  417. package/src/login/lib/useFormValidation.tsx +0 -474
  418. package/src/login/pages/RegisterUserProfile.tsx +0 -72
  419. package/src/login/pages/UpdateUserProfile.tsx +0 -82
  420. package/src/login/pages/shared/UserProfileFormFields.tsx +0 -177
  421. package/src/tools/headInsert.ts +0 -73
  422. package/tools/headInsert.d.ts +0 -12
  423. package/tools/headInsert.js +0 -50
  424. package/tools/headInsert.js.map +0 -1
@@ -3,21 +3,23 @@ import type { PageProps } from "keycloakify/login/pages/PageProps";
3
3
  import { assert, type Equals } from "tsafe/assert";
4
4
  import type { I18n } from "./i18n";
5
5
  import type { KcContext } from "./kcContext";
6
+ import type { LazyOrNot } from "keycloakify/tools/LazyOrNot";
7
+ import type { UserProfileFormFieldsProps } from "keycloakify/login/UserProfileFormFields";
6
8
 
7
9
  const Login = lazy(() => import("keycloakify/login/pages/Login"));
8
10
  const Register = lazy(() => import("keycloakify/login/pages/Register"));
9
- const RegisterUserProfile = lazy(() => import("keycloakify/login/pages/RegisterUserProfile"));
10
11
  const Info = lazy(() => import("keycloakify/login/pages/Info"));
11
12
  const Error = lazy(() => import("keycloakify/login/pages/Error"));
12
13
  const LoginResetPassword = lazy(() => import("keycloakify/login/pages/LoginResetPassword"));
13
14
  const LoginVerifyEmail = lazy(() => import("keycloakify/login/pages/LoginVerifyEmail"));
14
15
  const Terms = lazy(() => import("keycloakify/login/pages/Terms"));
15
- const LoginDeviceVerifyUserCode = lazy(() => import("keycloakify/login/pages/LoginDeviceVerifyUserCode"));
16
+ const LoginOauth2DeviceVerifyUserCode = lazy(() => import("keycloakify/login/pages/LoginOauth2DeviceVerifyUserCode"));
16
17
  const LoginOauthGrant = lazy(() => import("keycloakify/login/pages/LoginOauthGrant"));
17
18
  const LoginOtp = lazy(() => import("keycloakify/login/pages/LoginOtp"));
18
19
  const LoginPassword = lazy(() => import("keycloakify/login/pages/LoginPassword"));
19
20
  const LoginUsername = lazy(() => import("keycloakify/login/pages/LoginUsername"));
20
21
  const WebauthnAuthenticate = lazy(() => import("keycloakify/login/pages/WebauthnAuthenticate"));
22
+ const WebauthnRegister = lazy(() => import("keycloakify/login/pages/WebauthnRegister"));
21
23
  const LoginUpdatePassword = lazy(() => import("keycloakify/login/pages/LoginUpdatePassword"));
22
24
  const LoginUpdateProfile = lazy(() => import("keycloakify/login/pages/LoginUpdateProfile"));
23
25
  const LoginIdpLinkConfirm = lazy(() => import("keycloakify/login/pages/LoginIdpLinkConfirm"));
@@ -25,13 +27,25 @@ const LoginPageExpired = lazy(() => import("keycloakify/login/pages/LoginPageExp
25
27
  const LoginIdpLinkEmail = lazy(() => import("keycloakify/login/pages/LoginIdpLinkEmail"));
26
28
  const LoginConfigTotp = lazy(() => import("keycloakify/login/pages/LoginConfigTotp"));
27
29
  const LogoutConfirm = lazy(() => import("keycloakify/login/pages/LogoutConfirm"));
28
- const UpdateUserProfile = lazy(() => import("keycloakify/login/pages/UpdateUserProfile"));
29
30
  const IdpReviewUserProfile = lazy(() => import("keycloakify/login/pages/IdpReviewUserProfile"));
30
31
  const UpdateEmail = lazy(() => import("keycloakify/login/pages/UpdateEmail"));
31
32
  const SelectAuthenticator = lazy(() => import("keycloakify/login/pages/SelectAuthenticator"));
32
33
  const SamlPostForm = lazy(() => import("keycloakify/login/pages/SamlPostForm"));
34
+ const DeleteCredential = lazy(() => import("keycloakify/login/pages/DeleteCredential"));
35
+ const Code = lazy(() => import("keycloakify/login/pages/Code"));
36
+ const DeleteAccountConfirm = lazy(() => import("keycloakify/login/pages/DeleteAccountConfirm"));
37
+ const FrontchannelLogout = lazy(() => import("keycloakify/login/pages/FrontchannelLogout"));
38
+ const LoginRecoveryAuthnCodeConfig = lazy(() => import("keycloakify/login/pages/LoginRecoveryAuthnCodeConfig"));
39
+ const LoginRecoveryAuthnCodeInput = lazy(() => import("keycloakify/login/pages/LoginRecoveryAuthnCodeInput"));
40
+ const LoginResetOtp = lazy(() => import("keycloakify/login/pages/LoginResetOtp"));
41
+ const LoginX509Info = lazy(() => import("keycloakify/login/pages/LoginX509Info"));
42
+ const WebauthnError = lazy(() => import("keycloakify/login/pages/WebauthnError"));
33
43
 
34
- export default function Fallback(props: PageProps<KcContext, I18n>) {
44
+ type FallbackProps = PageProps<KcContext, I18n> & {
45
+ UserProfileFormFields: LazyOrNot<(props: UserProfileFormFieldsProps) => JSX.Element>;
46
+ };
47
+
48
+ export default function Fallback(props: FallbackProps) {
35
49
  const { kcContext, ...rest } = props;
36
50
 
37
51
  return (
@@ -42,8 +56,6 @@ export default function Fallback(props: PageProps<KcContext, I18n>) {
42
56
  return <Login kcContext={kcContext} {...rest} />;
43
57
  case "register.ftl":
44
58
  return <Register kcContext={kcContext} {...rest} />;
45
- case "register-user-profile.ftl":
46
- return <RegisterUserProfile kcContext={kcContext} {...rest} />;
47
59
  case "info.ftl":
48
60
  return <Info kcContext={kcContext} {...rest} />;
49
61
  case "error.ftl":
@@ -55,7 +67,7 @@ export default function Fallback(props: PageProps<KcContext, I18n>) {
55
67
  case "terms.ftl":
56
68
  return <Terms kcContext={kcContext} {...rest} />;
57
69
  case "login-oauth2-device-verify-user-code.ftl":
58
- return <LoginDeviceVerifyUserCode kcContext={kcContext} {...rest} />;
70
+ return <LoginOauth2DeviceVerifyUserCode kcContext={kcContext} {...rest} />;
59
71
  case "login-oauth-grant.ftl":
60
72
  return <LoginOauthGrant kcContext={kcContext} {...rest} />;
61
73
  case "login-otp.ftl":
@@ -66,6 +78,8 @@ export default function Fallback(props: PageProps<KcContext, I18n>) {
66
78
  return <LoginPassword kcContext={kcContext} {...rest} />;
67
79
  case "webauthn-authenticate.ftl":
68
80
  return <WebauthnAuthenticate kcContext={kcContext} {...rest} />;
81
+ case "webauthn-register.ftl":
82
+ return <WebauthnRegister kcContext={kcContext} {...rest} />;
69
83
  case "login-update-password.ftl":
70
84
  return <LoginUpdatePassword kcContext={kcContext} {...rest} />;
71
85
  case "login-update-profile.ftl":
@@ -80,8 +94,6 @@ export default function Fallback(props: PageProps<KcContext, I18n>) {
80
94
  return <LoginConfigTotp kcContext={kcContext} {...rest} />;
81
95
  case "logout-confirm.ftl":
82
96
  return <LogoutConfirm kcContext={kcContext} {...rest} />;
83
- case "update-user-profile.ftl":
84
- return <UpdateUserProfile kcContext={kcContext} {...rest} />;
85
97
  case "idp-review-user-profile.ftl":
86
98
  return <IdpReviewUserProfile kcContext={kcContext} {...rest} />;
87
99
  case "update-email.ftl":
@@ -90,6 +102,24 @@ export default function Fallback(props: PageProps<KcContext, I18n>) {
90
102
  return <SelectAuthenticator kcContext={kcContext} {...rest} />;
91
103
  case "saml-post-form.ftl":
92
104
  return <SamlPostForm kcContext={kcContext} {...rest} />;
105
+ case "delete-credential.ftl":
106
+ return <DeleteCredential kcContext={kcContext} {...rest} />;
107
+ case "code.ftl":
108
+ return <Code kcContext={kcContext} {...rest} />;
109
+ case "delete-account-confirm.ftl":
110
+ return <DeleteAccountConfirm kcContext={kcContext} {...rest} />;
111
+ case "frontchannel-logout.ftl":
112
+ return <FrontchannelLogout kcContext={kcContext} {...rest} />;
113
+ case "login-recovery-authn-code-config.ftl":
114
+ return <LoginRecoveryAuthnCodeConfig kcContext={kcContext} {...rest} />;
115
+ case "login-recovery-authn-code-input.ftl":
116
+ return <LoginRecoveryAuthnCodeInput kcContext={kcContext} {...rest} />;
117
+ case "login-reset-otp.ftl":
118
+ return <LoginResetOtp kcContext={kcContext} {...rest} />;
119
+ case "login-x509-info.ftl":
120
+ return <LoginX509Info kcContext={kcContext} {...rest} />;
121
+ case "webauthn-error.ftl":
122
+ return <WebauthnError kcContext={kcContext} {...rest} />;
93
123
  }
94
124
  assert<Equals<typeof kcContext, never>>(false);
95
125
  })()}
@@ -1,21 +1,28 @@
1
+ import { useEffect } from "react";
1
2
  import { assert } from "keycloakify/tools/assert";
2
3
  import { clsx } from "keycloakify/tools/clsx";
3
- import { usePrepareTemplate } from "keycloakify/lib/usePrepareTemplate";
4
4
  import { type TemplateProps } from "keycloakify/login/TemplateProps";
5
5
  import { useGetClassName } from "keycloakify/login/lib/useGetClassName";
6
+ import { createUseInsertScriptTags } from "keycloakify/tools/useInsertScriptTags";
7
+ import { createUseInsertLinkTags } from "keycloakify/tools/useInsertLinkTags";
8
+ import { useSetClassName } from "keycloakify/tools/useSetClassName";
6
9
  import type { KcContext } from "./kcContext";
7
10
  import type { I18n } from "./i18n";
8
11
 
12
+ const { useInsertLinkTags } = createUseInsertLinkTags();
13
+ const { useInsertScriptTags } = createUseInsertScriptTags();
14
+
9
15
  export default function Template(props: TemplateProps<KcContext, I18n>) {
10
16
  const {
11
17
  displayInfo = false,
12
18
  displayMessage = true,
13
19
  displayRequiredFields = false,
14
- displayWide = false,
15
- showAnotherWayIfPresent = true,
16
20
  headerNode,
17
21
  showUsernameNode = null,
22
+ socialProvidersNode = null,
18
23
  infoNode = null,
24
+ documentTitle,
25
+ bodyClassName,
19
26
  kcContext,
20
27
  i18n,
21
28
  doUseDefaultCss,
@@ -25,25 +32,87 @@ export default function Template(props: TemplateProps<KcContext, I18n>) {
25
32
 
26
33
  const { getClassName } = useGetClassName({ doUseDefaultCss, classes });
27
34
 
28
- const { msg, changeLocale, labelBySupportedLanguageTag, currentLanguageTag } = i18n;
29
-
30
- const { realm, locale, auth, url, message, isAppInitiatedAction } = kcContext;
31
-
32
- const { isReady } = usePrepareTemplate({
33
- "doFetchDefaultThemeResources": doUseDefaultCss,
34
- "styles": [
35
- `${url.resourcesCommonPath}/node_modules/patternfly/dist/css/patternfly.min.css`,
36
- `${url.resourcesCommonPath}/node_modules/patternfly/dist/css/patternfly-additions.min.css`,
37
- `${url.resourcesCommonPath}/lib/zocial/zocial.css`,
38
- `${url.resourcesPath}/css/login.css`
39
- ],
40
- "htmlClassName": getClassName("kcHtmlClass"),
41
- "bodyClassName": getClassName("kcBodyClass"),
42
- "htmlLangProperty": locale?.currentLanguageTag,
43
- "documentTitle": i18n.msgStr("loginTitle", kcContext.realm.displayName)
35
+ const { msg, msgStr, changeLocale, labelBySupportedLanguageTag, currentLanguageTag } = i18n;
36
+
37
+ const { realm, locale, auth, url, message, isAppInitiatedAction, authenticationSession, scripts } = kcContext;
38
+
39
+ useEffect(() => {
40
+ document.title = documentTitle ?? msgStr("loginTitle", kcContext.realm.displayName);
41
+ }, []);
42
+
43
+ useSetClassName({
44
+ "qualifiedName": "html",
45
+ "className": getClassName("kcHtmlClass")
46
+ });
47
+
48
+ useSetClassName({
49
+ "qualifiedName": "body",
50
+ "className": bodyClassName ?? getClassName("kcBodyClass")
51
+ });
52
+
53
+ useEffect(() => {
54
+ const { currentLanguageTag } = locale ?? {};
55
+
56
+ if (currentLanguageTag === undefined) {
57
+ return;
58
+ }
59
+
60
+ const html = document.querySelector("html");
61
+ assert(html !== null);
62
+ html.lang = currentLanguageTag;
63
+ }, []);
64
+
65
+ const { areAllStyleSheetsLoaded } = useInsertLinkTags({
66
+ "hrefs": !doUseDefaultCss
67
+ ? []
68
+ : [
69
+ `${url.resourcesCommonPath}/node_modules/@patternfly/patternfly/patternfly.min.css`,
70
+ `${url.resourcesCommonPath}/node_modules/patternfly/dist/css/patternfly.min.css`,
71
+ `${url.resourcesCommonPath}/node_modules/patternfly/dist/css/patternfly-additions.min.css`,
72
+ `${url.resourcesCommonPath}/lib/pficon/pficon.css`,
73
+ `${url.resourcesPath}/css/login.css`
74
+ ]
44
75
  });
45
76
 
46
- if (!isReady) {
77
+ const { insertScriptTags } = useInsertScriptTags({
78
+ "scriptTags": [
79
+ {
80
+ "type": "module",
81
+ "src": `${url.resourcesPath}/js/menu-button-links.js`
82
+ },
83
+ ...(authenticationSession === undefined
84
+ ? []
85
+ : [
86
+ {
87
+ "type": "module",
88
+ "textContent": [
89
+ `import { checkCookiesAndSetTimer } from "${url.resourcesPath}/js/authChecker.js";`,
90
+ ``,
91
+ `checkCookiesAndSetTimer(`,
92
+ ` "${authenticationSession.authSessionId}",`,
93
+ ` "${authenticationSession.tabId}",`,
94
+ ` "${url.ssoLoginInOtherTabsUrl}"`,
95
+ `);`
96
+ ].join("\n")
97
+ } as const
98
+ ]),
99
+ ...scripts.map(
100
+ script =>
101
+ ({
102
+ "type": "text/javascript",
103
+ "src": script
104
+ } as const)
105
+ )
106
+ ]
107
+ });
108
+
109
+ useEffect(() => {
110
+ if (areAllStyleSheetsLoaded) {
111
+ insertScriptTags();
112
+ }
113
+ }, [areAllStyleSheetsLoaded]);
114
+
115
+ if (!areAllStyleSheetsLoaded) {
47
116
  return null;
48
117
  }
49
118
 
@@ -55,12 +124,12 @@ export default function Template(props: TemplateProps<KcContext, I18n>) {
55
124
  </div>
56
125
  </div>
57
126
 
58
- <div className={clsx(getClassName("kcFormCardClass"), displayWide && getClassName("kcFormCardAccountClass"))}>
127
+ <div className={getClassName("kcFormCardClass")}>
59
128
  <header className={getClassName("kcFormHeaderClass")}>
60
129
  {realm.internationalizationEnabled && (assert(locale !== undefined), true) && locale.supported.length > 1 && (
61
- <div id="kc-locale">
130
+ <div className={getClassName("kcLocaleMainClass")} id="kc-locale">
62
131
  <div id="kc-locale-wrapper" className={getClassName("kcLocaleWrapperClass")}>
63
- <div className="kc-dropdown" id="kc-locale-dropdown">
132
+ <div id="kc-locale-dropdown" className={clsx("menu-button-links", getClassName("kcLocaleDropDownClass"))}>
64
133
  {/* eslint-disable-next-line jsx-a11y/anchor-is-valid */}
65
134
  <a href="#" id="kc-current-locale-link">
66
135
  {labelBySupportedLanguageTag[currentLanguageTag]}
@@ -75,6 +144,40 @@ export default function Template(props: TemplateProps<KcContext, I18n>) {
75
144
  </li>
76
145
  ))}
77
146
  </ul>
147
+
148
+ <button
149
+ tabIndex={1}
150
+ id="kc-current-locale-link"
151
+ aria-label={msgStr("languages" as any)}
152
+ aria-haspopup={true}
153
+ aria-expanded={false}
154
+ aria-controls="language-switch1"
155
+ >
156
+ {labelBySupportedLanguageTag[currentLanguageTag]}
157
+ </button>
158
+ <ul
159
+ role="menu"
160
+ tabIndex={-1}
161
+ aria-labelledby="kc-current-locale-link"
162
+ aria-activedescendant=""
163
+ id="language-switch1"
164
+ className={getClassName("kcLocaleListClass")}
165
+ >
166
+ {locale.supported.map(({ languageTag }, i) => (
167
+ <li key={languageTag} className={getClassName("kcLocaleListItemClass")} role="none">
168
+ {/* eslint-disable-next-line jsx-a11y/anchor-is-valid */}
169
+ <a
170
+ role="menuitem"
171
+ id={`language-${i}`}
172
+ className={getClassName("kcLocaleItemClass")}
173
+ href="#"
174
+ onClick={() => changeLocale(languageTag)}
175
+ >
176
+ {labelBySupportedLanguageTag[languageTag]}
177
+ </a>
178
+ </li>
179
+ ))}
180
+ </ul>
78
181
  </div>
79
182
  </div>
80
183
  </div>
@@ -104,26 +207,9 @@ export default function Template(props: TemplateProps<KcContext, I18n>) {
104
207
  </div>
105
208
  <div className="col-md-10">
106
209
  {showUsernameNode}
107
- <div className={getClassName("kcFormGroupClass")}>
108
- <div id="kc-username">
109
- <label id="kc-attempted-username">{auth?.attemptedUsername}</label>
110
- <a id="reset-login" href={url.loginRestartFlowUrl}>
111
- <div className="kc-login-tooltip">
112
- <i className={getClassName("kcResetFlowIcon")}></i>
113
- <span className="kc-tooltip-text">{msg("restartLoginTooltip")}</span>
114
- </div>
115
- </a>
116
- </div>
117
- </div>
118
- </div>
119
- </div>
120
- ) : (
121
- <>
122
- {showUsernameNode}
123
- <div className={getClassName("kcFormGroupClass")}>
124
- <div id="kc-username">
125
- <label id="kc-attempted-username">{auth?.attemptedUsername}</label>
126
- <a id="reset-login" href={url.loginRestartFlowUrl}>
210
+ <div id="kc-username" className={getClassName("kcFormGroupClass")}>
211
+ <label id="kc-attempted-username">{auth.attemptedUsername}</label>
212
+ <a id="reset-login" href={url.loginRestartFlowUrl} aria-label={msgStr("restartLoginTooltip")}>
127
213
  <div className="kc-login-tooltip">
128
214
  <i className={getClassName("kcResetFlowIcon")}></i>
129
215
  <span className="kc-tooltip-text">{msg("restartLoginTooltip")}</span>
@@ -131,6 +217,19 @@ export default function Template(props: TemplateProps<KcContext, I18n>) {
131
217
  </a>
132
218
  </div>
133
219
  </div>
220
+ </div>
221
+ ) : (
222
+ <>
223
+ {showUsernameNode}
224
+ <div id="kc-username" className={getClassName("kcFormGroupClass")}>
225
+ <label id="kc-attempted-username">{auth.attemptedUsername}</label>
226
+ <a id="reset-login" href={url.loginRestartFlowUrl} aria-label={msgStr("restartLoginTooltip")}>
227
+ <div className="kc-login-tooltip">
228
+ <i className={getClassName("kcResetFlowIcon")}></i>
229
+ <span className="kc-tooltip-text">{msg("restartLoginTooltip")}</span>
230
+ </div>
231
+ </a>
232
+ </div>
134
233
  </>
135
234
  )}
136
235
  </header>
@@ -138,13 +237,21 @@ export default function Template(props: TemplateProps<KcContext, I18n>) {
138
237
  <div id="kc-content-wrapper">
139
238
  {/* App-initiated actions should not see warning messages about the need to complete the action during login. */}
140
239
  {displayMessage && message !== undefined && (message.type !== "warning" || !isAppInitiatedAction) && (
141
- <div className={clsx("alert", `alert-${message.type}`)}>
142
- {message.type === "success" && <span className={getClassName("kcFeedbackSuccessIcon")}></span>}
143
- {message.type === "warning" && <span className={getClassName("kcFeedbackWarningIcon")}></span>}
144
- {message.type === "error" && <span className={getClassName("kcFeedbackErrorIcon")}></span>}
145
- {message.type === "info" && <span className={getClassName("kcFeedbackInfoIcon")}></span>}
240
+ <div
241
+ className={clsx(
242
+ `alert-${message.type}`,
243
+ getClassName("kcAlertClass"),
244
+ `pf-m-${message?.type === "error" ? "danger" : message.type}`
245
+ )}
246
+ >
247
+ <div className="pf-c-alert__icon">
248
+ {message.type === "success" && <span className={getClassName("kcFeedbackSuccessIcon")}></span>}
249
+ {message.type === "warning" && <span className={getClassName("kcFeedbackWarningIcon")}></span>}
250
+ {message.type === "error" && <span className={getClassName("kcFeedbackErrorIcon")}></span>}
251
+ {message.type === "info" && <span className={getClassName("kcFeedbackInfoIcon")}></span>}
252
+ </div>
146
253
  <span
147
- className="kc-feedback-text"
254
+ className={getClassName("kcAlertTitleClass")}
148
255
  dangerouslySetInnerHTML={{
149
256
  "__html": message.summary
150
257
  }}
@@ -152,18 +259,9 @@ export default function Template(props: TemplateProps<KcContext, I18n>) {
152
259
  </div>
153
260
  )}
154
261
  {children}
155
- {auth !== undefined && auth.showTryAnotherWayLink && showAnotherWayIfPresent && (
156
- <form
157
- id="kc-select-try-another-way-form"
158
- action={url.loginAction}
159
- method="post"
160
- className={clsx(displayWide && getClassName("kcContentWrapperClass"))}
161
- >
162
- <div
163
- className={clsx(
164
- displayWide && [getClassName("kcFormSocialAccountContentClass"), getClassName("kcFormSocialAccountClass")]
165
- )}
166
- >
262
+ {auth !== undefined && auth.showTryAnotherWayLink && (
263
+ <form id="kc-select-try-another-way-form" action={url.loginAction} method="post">
264
+ <div className={getClassName("kcFormGroupClass")}>
167
265
  <div className={getClassName("kcFormGroupClass")}>
168
266
  <input type="hidden" name="tryAnotherWay" value="on" />
169
267
  {/* eslint-disable-next-line jsx-a11y/anchor-is-valid */}
@@ -181,6 +279,7 @@ export default function Template(props: TemplateProps<KcContext, I18n>) {
181
279
  </div>
182
280
  </form>
183
281
  )}
282
+ {socialProvidersNode}
184
283
  {displayInfo && (
185
284
  <div id="kc-info" className={getClassName("kcSignUpClass")}>
186
285
  <div id="kc-info-wrapper" className={getClassName("kcInfoAreaWrapperClass")}>
@@ -11,89 +11,139 @@ export type TemplateProps<KcContext extends KcContext.Common, I18nExtended exten
11
11
  displayInfo?: boolean;
12
12
  displayMessage?: boolean;
13
13
  displayRequiredFields?: boolean;
14
- displayWide?: boolean;
15
14
  showAnotherWayIfPresent?: boolean;
16
15
  headerNode: ReactNode;
17
16
  showUsernameNode?: ReactNode;
17
+ socialProvidersNode?: ReactNode;
18
18
  infoNode?: ReactNode;
19
+ documentTitle?: string;
20
+ bodyClassName?: string;
19
21
 
20
22
  children: ReactNode;
21
23
  };
22
24
 
23
25
  export type ClassKey =
24
26
  | "kcBodyClass"
25
- | "kcHtmlClass"
26
- | "kcLoginClass"
27
- | "kcHeaderClass"
28
27
  | "kcHeaderWrapperClass"
29
- | "kcFormCardClass"
30
- | "kcFormCardAccountClass"
31
- | "kcFormHeaderClass"
32
28
  | "kcLocaleWrapperClass"
33
- | "kcContentWrapperClass"
34
- | "kcLabelWrapperClass"
35
- | "kcFormGroupClass"
36
- | "kcResetFlowIcon"
37
- | "kcFeedbackSuccessIcon"
38
- | "kcFeedbackWarningIcon"
39
- | "kcFeedbackErrorIcon"
40
- | "kcFeedbackInfoIcon"
41
- | "kcFormSocialAccountContentClass"
42
- | "kcFormSocialAccountClass"
43
- | "kcSignUpClass"
44
29
  | "kcInfoAreaWrapperClass"
45
- | "kcLogoClass"
46
- | "kcContainerClass"
47
- | "kcContentClass"
48
- | "kcFeedbackAreaClass"
49
- | "kcLocaleClass"
50
- | "kcAlertIconClasserror"
51
- | "kcFormAreaClass"
52
- | "kcFormSocialAccountListClass"
53
- | "kcFormSocialAccountDoubleListClass"
54
- | "kcFormSocialAccountListLinkClass"
55
- | "kcWebAuthnKeyIcon"
30
+ | "kcFormButtonsWrapperClass"
31
+ | "kcFormOptionsWrapperClass"
32
+ | "kcCheckboxInputClass"
33
+ | "kcLocaleDropDownClass"
34
+ | "kcLocaleListItemClass"
35
+ | "kcContentWrapperClass"
36
+ | "kcLogoIdP-facebook"
37
+ | "kcAuthenticatorOTPClass"
38
+ | "kcLogoIdP-bitbucket"
39
+ | "kcAuthenticatorWebAuthnClass"
56
40
  | "kcWebAuthnDefaultIcon"
41
+ | "kcLogoIdP-stackoverflow"
42
+ | "kcSelectAuthListItemClass"
43
+ | "kcLogoIdP-microsoft"
44
+ | "kcLoginOTPListItemHeaderClass"
45
+ | "kcLocaleItemClass"
46
+ | "kcLoginOTPListItemIconBodyClass"
47
+ | "kcInputHelperTextAfterClass"
57
48
  | "kcFormClass"
58
- | "kcFormGroupErrorClass"
59
- | "kcLabelClass"
60
- | "kcInputClass"
61
- | "kcInputErrorMessageClass"
49
+ | "kcSelectAuthListClass"
50
+ | "kcInputClassRadioCheckboxLabelDisabled"
51
+ | "kcSelectAuthListItemIconClass"
52
+ | "kcRecoveryCodesWarning"
53
+ | "kcFormSettingClass"
54
+ | "kcWebAuthnBLE"
62
55
  | "kcInputWrapperClass"
63
- | "kcFormOptionsClass"
56
+ | "kcSelectAuthListItemArrowIconClass"
57
+ | "kcFeedbackAreaClass"
58
+ | "kcFormPasswordVisibilityButtonClass"
59
+ | "kcLogoIdP-google"
60
+ | "kcCheckLabelClass"
61
+ | "kcSelectAuthListItemFillClass"
62
+ | "kcAuthenticatorDefaultClass"
63
+ | "kcLogoIdP-gitlab"
64
+ | "kcFormAreaClass"
64
65
  | "kcFormButtonsClass"
65
- | "kcFormSettingClass"
66
- | "kcTextareaClass"
66
+ | "kcInputClassRadioLabel"
67
+ | "kcAuthenticatorWebAuthnPasswordlessClass"
68
+ | "kcSelectAuthListItemHeadingClass"
67
69
  | "kcInfoAreaClass"
70
+ | "kcLogoLink"
71
+ | "kcContainerClass"
72
+ | "kcSelectAuthListItemTitle"
73
+ | "kcHtmlClass"
74
+ | "kcLoginOTPListItemTitleClass"
75
+ | "kcLogoIdP-openshift-v4"
76
+ | "kcWebAuthnUnknownIcon"
77
+ | "kcFormSocialAccountNameClass"
78
+ | "kcLogoIdP-openshift-v3"
79
+ | "kcLoginOTPListInputClass"
80
+ | "kcWebAuthnUSB"
81
+ | "kcInputClassRadio"
82
+ | "kcWebAuthnKeyIcon"
83
+ | "kcFeedbackInfoIcon"
84
+ | "kcCommonLogoIdP"
85
+ | "kcRecoveryCodesActions"
68
86
  | "kcFormGroupHeader"
69
- | "kcButtonClass"
70
- | "kcButtonPrimaryClass"
71
- | "kcButtonDefaultClass"
72
- | "kcButtonLargeClass"
87
+ | "kcFormSocialAccountSectionClass"
88
+ | "kcLogoIdP-instagram"
89
+ | "kcAlertClass"
90
+ | "kcHeaderClass"
91
+ | "kcLabelWrapperClass"
92
+ | "kcFormPasswordVisibilityIconShow"
93
+ | "kcFormSocialAccountLinkClass"
94
+ | "kcLocaleMainClass"
95
+ | "kcInputGroup"
96
+ | "kcTextareaClass"
73
97
  | "kcButtonBlockClass"
98
+ | "kcButtonClass"
99
+ | "kcWebAuthnNFC"
100
+ | "kcLocaleClass"
101
+ | "kcInputClassCheckboxInput"
102
+ | "kcFeedbackErrorIcon"
74
103
  | "kcInputLargeClass"
104
+ | "kcInputErrorMessageClass"
105
+ | "kcRecoveryCodesList"
106
+ | "kcFormSocialAccountListClass"
107
+ | "kcAlertTitleClass"
108
+ | "kcAuthenticatorPasswordClass"
109
+ | "kcCheckInputClass"
110
+ | "kcLogoIdP-linkedin"
111
+ | "kcLogoIdP-twitter"
112
+ | "kcFeedbackWarningIcon"
113
+ | "kcResetFlowIcon"
114
+ | "kcSelectAuthListItemIconPropertyClass"
115
+ | "kcFeedbackSuccessIcon"
116
+ | "kcLoginOTPListClass"
75
117
  | "kcSrOnlyClass"
76
- | "kcSelectAuthListClass"
77
- | "kcSelectAuthListItemClass"
78
- | "kcSelectAuthListItemFillClass"
79
- | "kcSelectAuthListItemInfoClass"
80
- | "kcSelectAuthListItemLeftClass"
81
- | "kcSelectAuthListItemBodyClass"
118
+ | "kcFormSocialAccountListGridClass"
119
+ | "kcButtonDefaultClass"
120
+ | "kcFormGroupErrorClass"
82
121
  | "kcSelectAuthListItemDescriptionClass"
83
- | "kcSelectAuthListItemHeadingClass"
84
- | "kcSelectAuthListItemHelpTextClass"
85
- | "kcSelectAuthListItemIconPropertyClass"
86
- | "kcSelectAuthListItemIconClass"
87
- | "kcSelectAuthListItemTitle"
88
- | "kcAuthenticatorDefaultClass"
89
- | "kcAuthenticatorPasswordClass"
90
- | "kcAuthenticatorOTPClass"
91
- | "kcAuthenticatorWebAuthnClass"
92
- | "kcAuthenticatorWebAuthnPasswordlessClass"
93
- | "kcSelectOTPListClass"
94
- | "kcSelectOTPListItemClass"
95
- | "kcAuthenticatorOtpCircleClass"
96
- | "kcSelectOTPItemHeadingClass"
97
- | "kcFormOptionsWrapperClass"
98
- | "kcFormButtonsWrapperClass"
99
- | "kcInputGroup";
122
+ | "kcSelectAuthListItemBodyClass"
123
+ | "kcWebAuthnInternal"
124
+ | "kcSelectAuthListItemArrowClass"
125
+ | "kcCheckClass"
126
+ | "kcContentClass"
127
+ | "kcLogoClass"
128
+ | "kcLoginOTPListItemIconClass"
129
+ | "kcLoginClass"
130
+ | "kcSignUpClass"
131
+ | "kcButtonLargeClass"
132
+ | "kcFormCardClass"
133
+ | "kcLocaleListClass"
134
+ | "kcInputClass"
135
+ | "kcFormGroupClass"
136
+ | "kcLogoIdP-paypal"
137
+ | "kcInputClassCheckbox"
138
+ | "kcRecoveryCodesConfirmation"
139
+ | "kcFormPasswordVisibilityIconHide"
140
+ | "kcInputClassRadioInput"
141
+ | "kcFormSocialAccountListButtonClass"
142
+ | "kcInputClassCheckboxLabel"
143
+ | "kcFormOptionsClass"
144
+ | "kcFormHeaderClass"
145
+ | "kcFormSocialAccountGridItem"
146
+ | "kcButtonPrimaryClass"
147
+ | "kcInputHelperTextBeforeClass"
148
+ | "kcLogoIdP-github"
149
+ | "kcLabelClass";