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
@@ -1,113 +0,0 @@
1
- import { useReducer, useEffect } from "react";
2
- import { headInsert } from "keycloakify/tools/headInsert";
3
- import { clsx } from "keycloakify/tools/clsx";
4
- import { assert } from "tsafe/assert";
5
-
6
- export function usePrepareTemplate(params: {
7
- doFetchDefaultThemeResources: boolean;
8
- styles?: string[];
9
- scripts?: string[];
10
- htmlClassName: string | undefined;
11
- bodyClassName: string | undefined;
12
- htmlLangProperty?: string | undefined;
13
- documentTitle?: string;
14
- }) {
15
- const { doFetchDefaultThemeResources, styles = [], scripts = [], htmlClassName, bodyClassName, htmlLangProperty, documentTitle } = params;
16
-
17
- const [isReady, setReady] = useReducer(() => true, !doFetchDefaultThemeResources);
18
-
19
- useEffect(() => {
20
- if (htmlLangProperty === undefined) {
21
- return;
22
- }
23
-
24
- const html = document.querySelector("html");
25
- assert(html !== null);
26
- html.lang = htmlLangProperty;
27
- }, [htmlLangProperty]);
28
-
29
- useEffect(() => {
30
- if (documentTitle === undefined) {
31
- return;
32
- }
33
-
34
- document.title = documentTitle;
35
- }, [documentTitle]);
36
-
37
- useEffect(() => {
38
- if (!doFetchDefaultThemeResources) {
39
- return;
40
- }
41
-
42
- let isUnmounted = false;
43
-
44
- const removeArray: (() => void)[] = [];
45
-
46
- (async () => {
47
- for (const style of [...styles].reverse()) {
48
- const { prLoaded, remove } = headInsert({
49
- "type": "css",
50
- "position": "prepend",
51
- "href": style
52
- });
53
-
54
- removeArray.push(remove);
55
-
56
- // TODO: Find a way to do that in parallel (without breaking the order)
57
- await prLoaded;
58
-
59
- if (isUnmounted) {
60
- return;
61
- }
62
- }
63
-
64
- setReady();
65
- })();
66
-
67
- scripts.forEach(src => {
68
- const { remove } = headInsert({
69
- "type": "javascript",
70
- src
71
- });
72
-
73
- removeArray.push(remove);
74
- });
75
-
76
- return () => {
77
- isUnmounted = true;
78
- removeArray.forEach(remove => remove());
79
- };
80
- }, []);
81
-
82
- useSetClassName({
83
- "target": "html",
84
- "className": htmlClassName
85
- });
86
-
87
- useSetClassName({
88
- "target": "body",
89
- "className": bodyClassName
90
- });
91
-
92
- return { isReady };
93
- }
94
-
95
- function useSetClassName(params: { target: "html" | "body"; className: string | undefined }) {
96
- const { target, className } = params;
97
-
98
- useEffect(() => {
99
- if (className === undefined) {
100
- return;
101
- }
102
-
103
- const htmlClassList = document.getElementsByTagName(target)[0].classList;
104
-
105
- const tokens = clsx(className).split(" ");
106
-
107
- htmlClassList.add(...tokens);
108
-
109
- return () => {
110
- htmlClassList.remove(...tokens);
111
- };
112
- }, [className]);
113
- }
@@ -1,474 +0,0 @@
1
- import "keycloakify/tools/Array.prototype.every";
2
- import { useMemo, useReducer, Fragment } from "react";
3
- import { id } from "tsafe/id";
4
- import type { MessageKey } from "keycloakify/login/i18n/i18n";
5
- import type { Attribute, Validators } from "keycloakify/login/kcContext/KcContext";
6
- import { useConstCallback } from "keycloakify/tools/useConstCallback";
7
- import { emailRegexp } from "keycloakify/tools/emailRegExp";
8
- import type { KcContext } from "../kcContext";
9
- import type { I18n } from "../i18n";
10
-
11
- /**
12
- * NOTE: The attributesWithPassword returned is actually augmented with
13
- * artificial password related attributes only if kcContext.passwordRequired === true
14
- */
15
- export function useFormValidation(params: {
16
- kcContext: {
17
- messagesPerField: Pick<KcContext.Common["messagesPerField"], "existsError" | "get">;
18
- profile: {
19
- attributes: Attribute[];
20
- };
21
- passwordRequired?: boolean;
22
- realm: { registrationEmailAsUsername: boolean };
23
- };
24
- /** NOTE: Try to avoid passing a new ref every render for better performances. */
25
- passwordValidators?: Validators;
26
- i18n: I18n;
27
- }) {
28
- const { kcContext, passwordValidators = {}, i18n } = params;
29
-
30
- const attributesWithPassword = useMemo(
31
- () =>
32
- !kcContext.passwordRequired
33
- ? kcContext.profile.attributes
34
- : (() => {
35
- const name = kcContext.realm.registrationEmailAsUsername ? "email" : "username";
36
-
37
- return kcContext.profile.attributes.reduce<Attribute[]>(
38
- (prev, curr) => [
39
- ...prev,
40
- ...(curr.name !== name
41
- ? [curr]
42
- : [
43
- curr,
44
- id<Attribute>({
45
- "name": "password",
46
- "displayName": id<`\${${MessageKey}}`>("${password}"),
47
- "required": true,
48
- "readOnly": false,
49
- "validators": passwordValidators,
50
- "annotations": {},
51
- "groupAnnotations": {},
52
- "autocomplete": "new-password"
53
- }),
54
- id<Attribute>({
55
- "name": "password-confirm",
56
- "displayName": id<`\${${MessageKey}}`>("${passwordConfirm}"),
57
- "required": true,
58
- "readOnly": false,
59
- "validators": {
60
- "_compareToOther": {
61
- "name": "password",
62
- "ignore.empty.value": true,
63
- "shouldBe": "equal",
64
- "error-message": id<`\${${MessageKey}}`>("${invalidPasswordConfirmMessage}")
65
- }
66
- },
67
- "annotations": {},
68
- "groupAnnotations": {},
69
- "autocomplete": "new-password"
70
- })
71
- ])
72
- ],
73
- []
74
- );
75
- })(),
76
- [kcContext, passwordValidators]
77
- );
78
-
79
- const { getErrors } = useGetErrors({
80
- "kcContext": {
81
- "messagesPerField": kcContext.messagesPerField,
82
- "profile": {
83
- "attributes": attributesWithPassword
84
- }
85
- },
86
- i18n
87
- });
88
-
89
- const initialInternalState = useMemo(
90
- () =>
91
- Object.fromEntries(
92
- attributesWithPassword
93
- .map(attribute => ({
94
- attribute,
95
- "errors": getErrors({
96
- "name": attribute.name,
97
- "fieldValueByAttributeName": Object.fromEntries(
98
- attributesWithPassword.map(({ name, value }) => [name, { "value": value ?? "" }])
99
- )
100
- })
101
- }))
102
- .map(({ attribute, errors }) => [
103
- attribute.name,
104
- {
105
- "value": attribute.value ?? "",
106
- errors,
107
- "doDisplayPotentialErrorMessages": errors.length !== 0
108
- }
109
- ])
110
- ),
111
- [attributesWithPassword]
112
- );
113
-
114
- type InternalState = typeof initialInternalState;
115
-
116
- const [formValidationInternalState, formValidationDispatch] = useReducer(
117
- (
118
- state: InternalState,
119
- params:
120
- | {
121
- action: "update value";
122
- name: string;
123
- newValue: string;
124
- }
125
- | {
126
- action: "focus lost";
127
- name: string;
128
- }
129
- ): InternalState => ({
130
- ...state,
131
- [params.name]: {
132
- ...state[params.name],
133
- ...(() => {
134
- switch (params.action) {
135
- case "focus lost":
136
- return { "doDisplayPotentialErrorMessages": true };
137
- case "update value":
138
- return {
139
- "value": params.newValue,
140
- "errors": getErrors({
141
- "name": params.name,
142
- "fieldValueByAttributeName": {
143
- ...state,
144
- [params.name]: { "value": params.newValue }
145
- }
146
- })
147
- };
148
- }
149
- })()
150
- }
151
- }),
152
- initialInternalState
153
- );
154
-
155
- const formValidationState = useMemo(
156
- () => ({
157
- "fieldStateByAttributeName": Object.fromEntries(
158
- Object.entries(formValidationInternalState).map(([name, { value, errors, doDisplayPotentialErrorMessages }]) => [
159
- name,
160
- { value, "displayableErrors": doDisplayPotentialErrorMessages ? errors : [] }
161
- ])
162
- ),
163
- "isFormSubmittable": Object.entries(formValidationInternalState).every(
164
- ([name, { value, errors }]) =>
165
- errors.length === 0 && (value !== "" || !attributesWithPassword.find(attribute => attribute.name === name)!.required)
166
- )
167
- }),
168
- [formValidationInternalState, attributesWithPassword]
169
- );
170
-
171
- return {
172
- formValidationState,
173
- formValidationDispatch,
174
- attributesWithPassword
175
- };
176
- }
177
-
178
- /** Expect to be used in a component wrapped within a <I18nProvider> */
179
- function useGetErrors(params: {
180
- kcContext: {
181
- messagesPerField: Pick<KcContext.Common["messagesPerField"], "existsError" | "get">;
182
- profile: {
183
- attributes: { name: string; value?: string; validators: Validators }[];
184
- };
185
- };
186
- i18n: I18n;
187
- }) {
188
- const { kcContext, i18n } = params;
189
-
190
- const {
191
- messagesPerField,
192
- profile: { attributes }
193
- } = kcContext;
194
-
195
- const { msg, msgStr, advancedMsg, advancedMsgStr } = i18n;
196
-
197
- const getErrors = useConstCallback((params: { name: string; fieldValueByAttributeName: Record<string, { value: string }> }) => {
198
- const { name, fieldValueByAttributeName } = params;
199
-
200
- const { value } = fieldValueByAttributeName[name];
201
-
202
- const { value: defaultValue, validators } = attributes.find(attribute => attribute.name === name)!;
203
-
204
- block: {
205
- if ((defaultValue ?? "") !== value) {
206
- break block;
207
- }
208
-
209
- let doesErrorExist: boolean;
210
-
211
- try {
212
- doesErrorExist = messagesPerField.existsError(name);
213
- } catch {
214
- break block;
215
- }
216
-
217
- if (!doesErrorExist) {
218
- break block;
219
- }
220
-
221
- const errorMessageStr = messagesPerField.get(name);
222
-
223
- return [
224
- {
225
- "validatorName": undefined,
226
- errorMessageStr,
227
- "errorMessage": <span key={0}>{errorMessageStr}</span>
228
- }
229
- ];
230
- }
231
-
232
- const errors: {
233
- errorMessage: JSX.Element;
234
- errorMessageStr: string;
235
- validatorName: keyof Validators | undefined;
236
- }[] = [];
237
-
238
- scope: {
239
- const validatorName = "length";
240
-
241
- const validator = validators[validatorName];
242
-
243
- if (validator === undefined) {
244
- break scope;
245
- }
246
-
247
- const { "ignore.empty.value": ignoreEmptyValue = false, max, min } = validator;
248
-
249
- if (ignoreEmptyValue && value === "") {
250
- break scope;
251
- }
252
-
253
- if (max !== undefined && value.length > parseInt(max)) {
254
- const msgArgs = ["error-invalid-length-too-long", max] as const;
255
-
256
- errors.push({
257
- "errorMessage": <Fragment key={errors.length}>{msg(...msgArgs)}</Fragment>,
258
- "errorMessageStr": msgStr(...msgArgs),
259
- validatorName
260
- });
261
- }
262
-
263
- if (min !== undefined && value.length < parseInt(min)) {
264
- const msgArgs = ["error-invalid-length-too-short", min] as const;
265
-
266
- errors.push({
267
- "errorMessage": <Fragment key={errors.length}>{msg(...msgArgs)}</Fragment>,
268
- "errorMessageStr": msgStr(...msgArgs),
269
- validatorName
270
- });
271
- }
272
- }
273
-
274
- scope: {
275
- const validatorName = "_compareToOther";
276
-
277
- const validator = validators[validatorName];
278
-
279
- if (validator === undefined) {
280
- break scope;
281
- }
282
-
283
- const { "ignore.empty.value": ignoreEmptyValue = false, name: otherName, shouldBe, "error-message": errorMessageKey } = validator;
284
-
285
- if (ignoreEmptyValue && value === "") {
286
- break scope;
287
- }
288
-
289
- const { value: otherValue } = fieldValueByAttributeName[otherName];
290
-
291
- const isValid = (() => {
292
- switch (shouldBe) {
293
- case "different":
294
- return otherValue !== value;
295
- case "equal":
296
- return otherValue === value;
297
- }
298
- })();
299
-
300
- if (isValid) {
301
- break scope;
302
- }
303
-
304
- const msgArg = [
305
- errorMessageKey ??
306
- id<MessageKey>(
307
- (() => {
308
- switch (shouldBe) {
309
- case "equal":
310
- return "shouldBeEqual";
311
- case "different":
312
- return "shouldBeDifferent";
313
- }
314
- })()
315
- ),
316
- otherName,
317
- name,
318
- shouldBe
319
- ] as const;
320
-
321
- errors.push({
322
- validatorName,
323
- "errorMessage": <Fragment key={errors.length}>{advancedMsg(...msgArg)}</Fragment>,
324
- "errorMessageStr": advancedMsgStr(...msgArg)
325
- });
326
- }
327
-
328
- scope: {
329
- const validatorName = "pattern";
330
-
331
- const validator = validators[validatorName];
332
-
333
- if (validator === undefined) {
334
- break scope;
335
- }
336
-
337
- const { "ignore.empty.value": ignoreEmptyValue = false, pattern, "error-message": errorMessageKey } = validator;
338
-
339
- if (ignoreEmptyValue && value === "") {
340
- break scope;
341
- }
342
-
343
- if (new RegExp(pattern).test(value)) {
344
- break scope;
345
- }
346
-
347
- const msgArgs = [errorMessageKey ?? id<MessageKey>("shouldMatchPattern"), pattern] as const;
348
-
349
- errors.push({
350
- validatorName,
351
- "errorMessage": <Fragment key={errors.length}>{advancedMsg(...msgArgs)}</Fragment>,
352
- "errorMessageStr": advancedMsgStr(...msgArgs)
353
- });
354
- }
355
-
356
- scope: {
357
- if ([...errors].reverse()[0]?.validatorName === "pattern") {
358
- break scope;
359
- }
360
-
361
- const validatorName = "email";
362
-
363
- const validator = validators[validatorName];
364
-
365
- if (validator === undefined) {
366
- break scope;
367
- }
368
-
369
- const { "ignore.empty.value": ignoreEmptyValue = false } = validator;
370
-
371
- if (ignoreEmptyValue && value === "") {
372
- break scope;
373
- }
374
-
375
- if (emailRegexp.test(value)) {
376
- break scope;
377
- }
378
-
379
- const msgArgs = [id<MessageKey>("invalidEmailMessage")] as const;
380
-
381
- errors.push({
382
- validatorName,
383
- "errorMessage": <Fragment key={errors.length}>{msg(...msgArgs)}</Fragment>,
384
- "errorMessageStr": msgStr(...msgArgs)
385
- });
386
- }
387
-
388
- scope: {
389
- const validatorName = "integer";
390
-
391
- const validator = validators[validatorName];
392
-
393
- if (validator === undefined) {
394
- break scope;
395
- }
396
-
397
- const { "ignore.empty.value": ignoreEmptyValue = false, max, min } = validator;
398
-
399
- if (ignoreEmptyValue && value === "") {
400
- break scope;
401
- }
402
-
403
- const intValue = parseInt(value);
404
-
405
- if (isNaN(intValue)) {
406
- const msgArgs = ["mustBeAnInteger"] as const;
407
-
408
- errors.push({
409
- validatorName,
410
- "errorMessage": <Fragment key={errors.length}>{msg(...msgArgs)}</Fragment>,
411
- "errorMessageStr": msgStr(...msgArgs)
412
- });
413
-
414
- break scope;
415
- }
416
-
417
- if (max !== undefined && intValue > parseInt(max)) {
418
- const msgArgs = ["error-number-out-of-range-too-big", max] as const;
419
-
420
- errors.push({
421
- validatorName,
422
- "errorMessage": <Fragment key={errors.length}>{msg(...msgArgs)}</Fragment>,
423
- "errorMessageStr": msgStr(...msgArgs)
424
- });
425
-
426
- break scope;
427
- }
428
-
429
- if (min !== undefined && intValue < parseInt(min)) {
430
- const msgArgs = ["error-number-out-of-range-too-small", min] as const;
431
-
432
- errors.push({
433
- validatorName,
434
- "errorMessage": <Fragment key={errors.length}>{msg(...msgArgs)}</Fragment>,
435
- "errorMessageStr": msgStr(...msgArgs)
436
- });
437
-
438
- break scope;
439
- }
440
- }
441
-
442
- scope: {
443
- const validatorName = "options";
444
-
445
- const validator = validators[validatorName];
446
-
447
- if (validator === undefined) {
448
- break scope;
449
- }
450
-
451
- if (value === "") {
452
- break scope;
453
- }
454
-
455
- if (validator.options.indexOf(value) >= 0) {
456
- break scope;
457
- }
458
-
459
- const msgArgs = [id<MessageKey>("notAValidOption")] as const;
460
-
461
- errors.push({
462
- validatorName,
463
- "errorMessage": <Fragment key={errors.length}>{advancedMsg(...msgArgs)}</Fragment>,
464
- "errorMessageStr": advancedMsgStr(...msgArgs)
465
- });
466
- }
467
-
468
- //TODO: Implement missing validators.
469
-
470
- return errors;
471
- });
472
-
473
- return { getErrors };
474
- }
@@ -1,72 +0,0 @@
1
- import { useState } from "react";
2
- import { clsx } from "keycloakify/tools/clsx";
3
- import { UserProfileFormFields } from "./shared/UserProfileFormFields";
4
- import type { PageProps } from "keycloakify/login/pages/PageProps";
5
- import { useGetClassName } from "keycloakify/login/lib/useGetClassName";
6
- import type { KcContext } from "../kcContext";
7
- import type { I18n } from "../i18n";
8
-
9
- export default function RegisterUserProfile(props: PageProps<Extract<KcContext, { pageId: "register-user-profile.ftl" }>, I18n>) {
10
- const { kcContext, i18n, doUseDefaultCss, Template, classes } = props;
11
-
12
- const { getClassName } = useGetClassName({
13
- doUseDefaultCss,
14
- classes
15
- });
16
-
17
- const { url, messagesPerField, recaptchaRequired, recaptchaSiteKey, realm } = kcContext;
18
-
19
- realm.registrationEmailAsUsername;
20
-
21
- const { msg, msgStr } = i18n;
22
-
23
- const [isFormSubmittable, setIsFormSubmittable] = useState(false);
24
-
25
- return (
26
- <Template
27
- {...{ kcContext, i18n, doUseDefaultCss, classes }}
28
- displayMessage={messagesPerField.exists("global")}
29
- displayRequiredFields={true}
30
- headerNode={msg("registerTitle")}
31
- >
32
- <form id="kc-register-form" className={getClassName("kcFormClass")} action={url.registrationAction} method="post">
33
- <UserProfileFormFields
34
- kcContext={kcContext}
35
- onIsFormSubmittableValueChange={setIsFormSubmittable}
36
- i18n={i18n}
37
- getClassName={getClassName}
38
- />
39
- {recaptchaRequired && (
40
- <div className="form-group">
41
- <div className={getClassName("kcInputWrapperClass")}>
42
- <div className="g-recaptcha" data-size="compact" data-sitekey={recaptchaSiteKey} />
43
- </div>
44
- </div>
45
- )}
46
- <div className={getClassName("kcFormGroupClass")} style={{ "marginBottom": 30 }}>
47
- <div id="kc-form-options" className={getClassName("kcFormOptionsClass")}>
48
- <div className={getClassName("kcFormOptionsWrapperClass")}>
49
- <span>
50
- <a href={url.loginUrl}>{msg("backToLogin")}</a>
51
- </span>
52
- </div>
53
- </div>
54
-
55
- <div id="kc-form-buttons" className={getClassName("kcFormButtonsClass")}>
56
- <input
57
- className={clsx(
58
- getClassName("kcButtonClass"),
59
- getClassName("kcButtonPrimaryClass"),
60
- getClassName("kcButtonBlockClass"),
61
- getClassName("kcButtonLargeClass")
62
- )}
63
- type="submit"
64
- value={msgStr("doRegister")}
65
- disabled={!isFormSubmittable}
66
- />
67
- </div>
68
- </div>
69
- </form>
70
- </Template>
71
- );
72
- }