keycloakify 10.0.0-rc.7 → 10.0.0-rc.70

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 (805) hide show
  1. package/PUBLIC_URL.d.ts +1 -1
  2. package/PUBLIC_URL.js +3 -3
  3. package/PUBLIC_URL.js.map +1 -1
  4. package/account/DefaultPage.d.ts +5 -0
  5. package/account/{Fallback.js → DefaultPage.js} +3 -3
  6. package/account/DefaultPage.js.map +1 -0
  7. package/account/{kcContext → KcContext}/KcContext.d.ts +13 -0
  8. package/account/KcContext/KcContext.js.map +1 -0
  9. package/account/KcContext/getKcContextMock.d.ts +24 -0
  10. package/account/KcContext/getKcContextMock.js +28 -0
  11. package/account/KcContext/getKcContextMock.js.map +1 -0
  12. package/account/KcContext/index.d.ts +2 -0
  13. package/account/KcContext/index.js +2 -0
  14. package/account/KcContext/index.js.map +1 -0
  15. package/account/{kcContext → KcContext}/kcContextMocks.d.ts +1 -1
  16. package/account/KcContext/kcContextMocks.js +143 -0
  17. package/account/KcContext/kcContextMocks.js.map +1 -0
  18. package/account/Template.d.ts +2 -2
  19. package/account/Template.js +11 -11
  20. package/account/Template.js.map +1 -1
  21. package/account/TemplateProps.d.ts +3 -5
  22. package/account/i18n/baseMessages/ar.d.ts +2 -0
  23. package/account/i18n/baseMessages/ar.js +3 -1
  24. package/account/i18n/baseMessages/ar.js.map +1 -1
  25. package/account/i18n/baseMessages/ca.d.ts +2 -0
  26. package/account/i18n/baseMessages/ca.js +3 -1
  27. package/account/i18n/baseMessages/ca.js.map +1 -1
  28. package/account/i18n/baseMessages/cs.d.ts +2 -0
  29. package/account/i18n/baseMessages/cs.js +3 -1
  30. package/account/i18n/baseMessages/cs.js.map +1 -1
  31. package/account/i18n/baseMessages/da.d.ts +2 -0
  32. package/account/i18n/baseMessages/da.js +3 -1
  33. package/account/i18n/baseMessages/da.js.map +1 -1
  34. package/account/i18n/baseMessages/de.d.ts +2 -0
  35. package/account/i18n/baseMessages/de.js +3 -1
  36. package/account/i18n/baseMessages/de.js.map +1 -1
  37. package/account/i18n/baseMessages/el.d.ts +2 -0
  38. package/account/i18n/baseMessages/el.js +3 -1
  39. package/account/i18n/baseMessages/el.js.map +1 -1
  40. package/account/i18n/baseMessages/en.d.ts +2 -0
  41. package/account/i18n/baseMessages/en.js +3 -1
  42. package/account/i18n/baseMessages/en.js.map +1 -1
  43. package/account/i18n/baseMessages/es.d.ts +2 -0
  44. package/account/i18n/baseMessages/es.js +3 -1
  45. package/account/i18n/baseMessages/es.js.map +1 -1
  46. package/account/i18n/baseMessages/fa.d.ts +2 -0
  47. package/account/i18n/baseMessages/fa.js +3 -1
  48. package/account/i18n/baseMessages/fa.js.map +1 -1
  49. package/account/i18n/baseMessages/fi.d.ts +2 -0
  50. package/account/i18n/baseMessages/fi.js +3 -1
  51. package/account/i18n/baseMessages/fi.js.map +1 -1
  52. package/account/i18n/baseMessages/fr.d.ts +2 -0
  53. package/account/i18n/baseMessages/fr.js +3 -1
  54. package/account/i18n/baseMessages/fr.js.map +1 -1
  55. package/account/i18n/baseMessages/hu.d.ts +2 -0
  56. package/account/i18n/baseMessages/hu.js +3 -1
  57. package/account/i18n/baseMessages/hu.js.map +1 -1
  58. package/account/i18n/baseMessages/index.d.ts +18 -0
  59. package/account/i18n/baseMessages/index.js.map +1 -1
  60. package/account/i18n/baseMessages/it.d.ts +2 -0
  61. package/account/i18n/baseMessages/it.js +3 -1
  62. package/account/i18n/baseMessages/it.js.map +1 -1
  63. package/account/i18n/baseMessages/ja.d.ts +2 -0
  64. package/account/i18n/baseMessages/ja.js +3 -1
  65. package/account/i18n/baseMessages/ja.js.map +1 -1
  66. package/account/i18n/baseMessages/lt.d.ts +2 -0
  67. package/account/i18n/baseMessages/lt.js +3 -1
  68. package/account/i18n/baseMessages/lt.js.map +1 -1
  69. package/account/i18n/baseMessages/lv.d.ts +2 -0
  70. package/account/i18n/baseMessages/lv.js +3 -1
  71. package/account/i18n/baseMessages/lv.js.map +1 -1
  72. package/account/i18n/baseMessages/nl.d.ts +2 -0
  73. package/account/i18n/baseMessages/nl.js +3 -1
  74. package/account/i18n/baseMessages/nl.js.map +1 -1
  75. package/account/i18n/baseMessages/no.d.ts +2 -0
  76. package/account/i18n/baseMessages/no.js +3 -1
  77. package/account/i18n/baseMessages/no.js.map +1 -1
  78. package/account/i18n/baseMessages/pl.d.ts +2 -0
  79. package/account/i18n/baseMessages/pl.js +3 -1
  80. package/account/i18n/baseMessages/pl.js.map +1 -1
  81. package/account/i18n/baseMessages/pt-BR.d.ts +2 -0
  82. package/account/i18n/baseMessages/pt-BR.js +3 -1
  83. package/account/i18n/baseMessages/pt-BR.js.map +1 -1
  84. package/account/i18n/baseMessages/ru.d.ts +2 -0
  85. package/account/i18n/baseMessages/ru.js +3 -1
  86. package/account/i18n/baseMessages/ru.js.map +1 -1
  87. package/account/i18n/baseMessages/sk.d.ts +2 -0
  88. package/account/i18n/baseMessages/sk.js +3 -1
  89. package/account/i18n/baseMessages/sk.js.map +1 -1
  90. package/account/i18n/baseMessages/sv.d.ts +2 -0
  91. package/account/i18n/baseMessages/sv.js +3 -1
  92. package/account/i18n/baseMessages/sv.js.map +1 -1
  93. package/account/i18n/baseMessages/th.d.ts +2 -0
  94. package/account/i18n/baseMessages/th.js +3 -1
  95. package/account/i18n/baseMessages/th.js.map +1 -1
  96. package/account/i18n/baseMessages/tr.d.ts +2 -0
  97. package/account/i18n/baseMessages/tr.js +3 -1
  98. package/account/i18n/baseMessages/tr.js.map +1 -1
  99. package/account/i18n/baseMessages/uk.d.ts +2 -0
  100. package/account/i18n/baseMessages/uk.js +3 -1
  101. package/account/i18n/baseMessages/uk.js.map +1 -1
  102. package/account/i18n/baseMessages/zh-CN.d.ts +2 -0
  103. package/account/i18n/baseMessages/zh-CN.js +3 -1
  104. package/account/i18n/baseMessages/zh-CN.js.map +1 -1
  105. package/account/i18n/i18n.d.ts +31 -32
  106. package/account/i18n/i18n.js +135 -94
  107. package/account/i18n/i18n.js.map +1 -1
  108. package/account/i18n/index.d.ts +5 -1
  109. package/account/i18n/index.js +2 -1
  110. package/account/i18n/index.js.map +1 -1
  111. package/account/index.d.ts +3 -7
  112. package/account/index.js +1 -5
  113. package/account/index.js.map +1 -1
  114. package/account/lib/kcClsx.d.ts +9 -0
  115. package/account/lib/kcClsx.js +19 -0
  116. package/account/lib/kcClsx.js.map +1 -0
  117. package/account/pages/Account.d.ts +1 -1
  118. package/account/pages/Account.js +7 -6
  119. package/account/pages/Account.js.map +1 -1
  120. package/account/pages/Applications.d.ts +1 -1
  121. package/account/pages/Applications.js +7 -8
  122. package/account/pages/Applications.js.map +1 -1
  123. package/account/pages/FederatedIdentity.d.ts +3 -3
  124. package/account/pages/FederatedIdentity.js +1 -1
  125. package/account/pages/FederatedIdentity.js.map +1 -1
  126. package/account/pages/Log.d.ts +1 -1
  127. package/account/pages/Log.js +3 -3
  128. package/account/pages/Log.js.map +1 -1
  129. package/account/pages/PageProps.d.ts +4 -6
  130. package/account/pages/Password.d.ts +1 -1
  131. package/account/pages/Password.js +16 -13
  132. package/account/pages/Password.js.map +1 -1
  133. package/account/pages/Sessions.d.ts +1 -1
  134. package/account/pages/Sessions.js +3 -4
  135. package/account/pages/Sessions.js.map +1 -1
  136. package/account/pages/Totp.d.ts +1 -1
  137. package/account/pages/Totp.js +5 -10
  138. package/account/pages/Totp.js.map +1 -1
  139. package/bin/180.index.js +4664 -0
  140. package/bin/193.index.js +160 -0
  141. package/bin/246.index.js +466 -0
  142. package/bin/36.index.js +9980 -0
  143. package/bin/363.index.js +1502 -0
  144. package/bin/420.index.js +508 -0
  145. package/bin/430.index.js +1349 -0
  146. package/bin/453.index.js +768 -0
  147. package/bin/456.index.js +6200 -0
  148. package/bin/490.index.js +75195 -0
  149. package/bin/509.index.js +438 -0
  150. package/bin/525.index.js +41826 -0
  151. package/bin/526.index.js +973 -0
  152. package/bin/538.index.js +108 -0
  153. package/bin/751.index.js +734 -0
  154. package/bin/772.index.js +1524 -0
  155. package/bin/837.index.js +787 -0
  156. package/bin/932.index.js +269 -0
  157. package/bin/97.index.js +676 -0
  158. package/bin/main.js +7553 -146379
  159. package/bin/shared/KeycloakVersionRange.d.ts +5 -0
  160. package/bin/shared/KeycloakVersionRange.js.map +1 -0
  161. package/bin/shared/buildContext.d.ts +67 -0
  162. package/bin/shared/buildContext.js.map +1 -0
  163. package/bin/shared/constants.d.ts +18 -0
  164. package/bin/shared/constants.js.map +1 -0
  165. package/bin/shared/copyKeycloakResourcesToPublic.d.ts +8 -0
  166. package/bin/shared/copyKeycloakResourcesToPublic.js.map +1 -0
  167. package/bin/shared/downloadKeycloakDefaultTheme.d.ts +10 -0
  168. package/bin/shared/downloadKeycloakDefaultTheme.js.map +1 -0
  169. package/bin/shared/downloadKeycloakStaticResources.d.ts +9 -0
  170. package/bin/shared/downloadKeycloakStaticResources.js.map +1 -0
  171. package/bin/shared/generateKcGenTs.d.ts +12 -0
  172. package/bin/shared/generateKcGenTs.js.map +1 -0
  173. package/bin/shared/metaInfKeycloakThemes.d.ts +13 -0
  174. package/bin/shared/metaInfKeycloakThemes.js.map +1 -0
  175. package/bin/shared/promptKeycloakVersion.d.ts +7 -0
  176. package/bin/shared/promptKeycloakVersion.js.map +1 -0
  177. package/lib/BASE_URL.js.map +1 -1
  178. package/lib/getKcClsx.d.ts +11 -0
  179. package/lib/getKcClsx.js +55 -0
  180. package/lib/getKcClsx.js.map +1 -0
  181. package/login/{Fallback.d.ts → DefaultPage.d.ts} +7 -6
  182. package/login/{Fallback.js → DefaultPage.js} +2 -2
  183. package/login/DefaultPage.js.map +1 -0
  184. package/login/{kcContext → KcContext}/KcContext.d.ts +32 -17
  185. package/login/{kcContext → KcContext}/KcContext.js +1 -0
  186. package/login/KcContext/KcContext.js.map +1 -0
  187. package/login/KcContext/getKcContextMock.d.ts +24 -0
  188. package/login/KcContext/getKcContextMock.js +28 -0
  189. package/login/KcContext/getKcContextMock.js.map +1 -0
  190. package/login/KcContext/index.d.ts +2 -0
  191. package/login/KcContext/index.js +2 -0
  192. package/login/KcContext/index.js.map +1 -0
  193. package/login/{kcContext → KcContext}/kcContextMocks.d.ts +1 -1
  194. package/login/KcContext/kcContextMocks.js +331 -0
  195. package/login/KcContext/kcContextMocks.js.map +1 -0
  196. package/login/Template.d.ts +2 -2
  197. package/login/Template.js +22 -22
  198. package/login/Template.js.map +1 -1
  199. package/login/TemplateProps.d.ts +3 -5
  200. package/login/UserProfileFormFields.d.ts +3 -20
  201. package/login/UserProfileFormFields.js +78 -122
  202. package/login/UserProfileFormFields.js.map +1 -1
  203. package/login/UserProfileFormFieldsProps.d.ts +24 -0
  204. package/login/UserProfileFormFieldsProps.js +2 -0
  205. package/login/UserProfileFormFieldsProps.js.map +1 -0
  206. package/login/i18n/baseMessages/ar.d.ts +9 -0
  207. package/login/i18n/baseMessages/ar.js +10 -1
  208. package/login/i18n/baseMessages/ar.js.map +1 -1
  209. package/login/i18n/baseMessages/ca.d.ts +10 -1
  210. package/login/i18n/baseMessages/ca.js +11 -2
  211. package/login/i18n/baseMessages/ca.js.map +1 -1
  212. package/login/i18n/baseMessages/cs.d.ts +9 -0
  213. package/login/i18n/baseMessages/cs.js +10 -1
  214. package/login/i18n/baseMessages/cs.js.map +1 -1
  215. package/login/i18n/baseMessages/da.d.ts +9 -0
  216. package/login/i18n/baseMessages/da.js +10 -1
  217. package/login/i18n/baseMessages/da.js.map +1 -1
  218. package/login/i18n/baseMessages/de.d.ts +9 -0
  219. package/login/i18n/baseMessages/de.js +10 -1
  220. package/login/i18n/baseMessages/de.js.map +1 -1
  221. package/login/i18n/baseMessages/el.d.ts +9 -1
  222. package/login/i18n/baseMessages/el.js +10 -2
  223. package/login/i18n/baseMessages/el.js.map +1 -1
  224. package/login/i18n/baseMessages/en.d.ts +10 -1
  225. package/login/i18n/baseMessages/en.js +11 -2
  226. package/login/i18n/baseMessages/en.js.map +1 -1
  227. package/login/i18n/baseMessages/es.d.ts +10 -1
  228. package/login/i18n/baseMessages/es.js +11 -2
  229. package/login/i18n/baseMessages/es.js.map +1 -1
  230. package/login/i18n/baseMessages/fa.d.ts +9 -1
  231. package/login/i18n/baseMessages/fa.js +10 -2
  232. package/login/i18n/baseMessages/fa.js.map +1 -1
  233. package/login/i18n/baseMessages/fi.d.ts +9 -0
  234. package/login/i18n/baseMessages/fi.js +10 -1
  235. package/login/i18n/baseMessages/fi.js.map +1 -1
  236. package/login/i18n/baseMessages/fr.d.ts +9 -0
  237. package/login/i18n/baseMessages/fr.js +10 -1
  238. package/login/i18n/baseMessages/fr.js.map +1 -1
  239. package/login/i18n/baseMessages/hu.d.ts +10 -1
  240. package/login/i18n/baseMessages/hu.js +11 -2
  241. package/login/i18n/baseMessages/hu.js.map +1 -1
  242. package/login/i18n/baseMessages/index.d.ts +109 -2
  243. package/login/i18n/baseMessages/index.js.map +1 -1
  244. package/login/i18n/baseMessages/it.d.ts +9 -0
  245. package/login/i18n/baseMessages/it.js +10 -1
  246. package/login/i18n/baseMessages/it.js.map +1 -1
  247. package/login/i18n/baseMessages/ja.d.ts +9 -0
  248. package/login/i18n/baseMessages/ja.js +10 -1
  249. package/login/i18n/baseMessages/ja.js.map +1 -1
  250. package/login/i18n/baseMessages/lt.d.ts +9 -0
  251. package/login/i18n/baseMessages/lt.js +10 -1
  252. package/login/i18n/baseMessages/lt.js.map +1 -1
  253. package/login/i18n/baseMessages/lv.d.ts +9 -0
  254. package/login/i18n/baseMessages/lv.js +10 -1
  255. package/login/i18n/baseMessages/lv.js.map +1 -1
  256. package/login/i18n/baseMessages/nl.d.ts +9 -0
  257. package/login/i18n/baseMessages/nl.js +10 -1
  258. package/login/i18n/baseMessages/nl.js.map +1 -1
  259. package/login/i18n/baseMessages/no.d.ts +9 -0
  260. package/login/i18n/baseMessages/no.js +10 -1
  261. package/login/i18n/baseMessages/no.js.map +1 -1
  262. package/login/i18n/baseMessages/pl.d.ts +9 -0
  263. package/login/i18n/baseMessages/pl.js +10 -1
  264. package/login/i18n/baseMessages/pl.js.map +1 -1
  265. package/login/i18n/baseMessages/pt-BR.d.ts +9 -0
  266. package/login/i18n/baseMessages/pt-BR.js +10 -1
  267. package/login/i18n/baseMessages/pt-BR.js.map +1 -1
  268. package/login/i18n/baseMessages/ru.d.ts +9 -0
  269. package/login/i18n/baseMessages/ru.js +10 -1
  270. package/login/i18n/baseMessages/ru.js.map +1 -1
  271. package/login/i18n/baseMessages/sk.d.ts +9 -0
  272. package/login/i18n/baseMessages/sk.js +10 -1
  273. package/login/i18n/baseMessages/sk.js.map +1 -1
  274. package/login/i18n/baseMessages/sv.d.ts +9 -0
  275. package/login/i18n/baseMessages/sv.js +10 -1
  276. package/login/i18n/baseMessages/sv.js.map +1 -1
  277. package/login/i18n/baseMessages/th.d.ts +9 -0
  278. package/login/i18n/baseMessages/th.js +10 -1
  279. package/login/i18n/baseMessages/th.js.map +1 -1
  280. package/login/i18n/baseMessages/tr.d.ts +9 -0
  281. package/login/i18n/baseMessages/tr.js +10 -1
  282. package/login/i18n/baseMessages/tr.js.map +1 -1
  283. package/login/i18n/baseMessages/uk.d.ts +9 -0
  284. package/login/i18n/baseMessages/uk.js +10 -1
  285. package/login/i18n/baseMessages/uk.js.map +1 -1
  286. package/login/i18n/baseMessages/zh-CN.d.ts +10 -1
  287. package/login/i18n/baseMessages/zh-CN.js +11 -2
  288. package/login/i18n/baseMessages/zh-CN.js.map +1 -1
  289. package/login/i18n/i18n.d.ts +32 -34
  290. package/login/i18n/i18n.js +144 -96
  291. package/login/i18n/i18n.js.map +1 -1
  292. package/login/i18n/index.d.ts +5 -1
  293. package/login/i18n/index.js +2 -1
  294. package/login/i18n/index.js.map +1 -1
  295. package/login/index.d.ts +3 -7
  296. package/login/index.js +1 -5
  297. package/login/index.js.map +1 -1
  298. package/login/lib/kcClsx.d.ts +9 -0
  299. package/login/lib/kcClsx.js +130 -0
  300. package/login/lib/kcClsx.js.map +1 -0
  301. package/login/lib/useDownloadTerms.d.ts +12 -3
  302. package/login/lib/useDownloadTerms.js +16 -21
  303. package/login/lib/useDownloadTerms.js.map +1 -1
  304. package/login/lib/useUserProfileForm.d.ts +20 -8
  305. package/login/lib/useUserProfileForm.js +402 -295
  306. package/login/lib/useUserProfileForm.js.map +1 -1
  307. package/login/pages/Code.d.ts +1 -1
  308. package/login/pages/Code.js +3 -3
  309. package/login/pages/Code.js.map +1 -1
  310. package/login/pages/DeleteAccountConfirm.d.ts +1 -1
  311. package/login/pages/DeleteAccountConfirm.js +7 -4
  312. package/login/pages/DeleteAccountConfirm.js.map +1 -1
  313. package/login/pages/DeleteCredential.d.ts +1 -1
  314. package/login/pages/DeleteCredential.js +3 -4
  315. package/login/pages/DeleteCredential.js.map +1 -1
  316. package/login/pages/Error.d.ts +1 -1
  317. package/login/pages/Error.js +1 -1
  318. package/login/pages/Error.js.map +1 -1
  319. package/login/pages/FrontchannelLogout.d.ts +1 -1
  320. package/login/pages/FrontchannelLogout.js +1 -1
  321. package/login/pages/FrontchannelLogout.js.map +1 -1
  322. package/login/pages/IdpReviewUserProfile.d.ts +4 -3
  323. package/login/pages/IdpReviewUserProfile.js +4 -5
  324. package/login/pages/IdpReviewUserProfile.js.map +1 -1
  325. package/login/pages/Info.d.ts +1 -1
  326. package/login/pages/Info.js +5 -7
  327. package/login/pages/Info.js.map +1 -1
  328. package/login/pages/Login.d.ts +1 -1
  329. package/login/pages/Login.js +7 -7
  330. package/login/pages/Login.js.map +1 -1
  331. package/login/pages/LoginConfigTotp.d.ts +1 -1
  332. package/login/pages/LoginConfigTotp.js +6 -7
  333. package/login/pages/LoginConfigTotp.js.map +1 -1
  334. package/login/pages/LoginIdpLinkConfirm.d.ts +1 -1
  335. package/login/pages/LoginIdpLinkConfirm.js +3 -4
  336. package/login/pages/LoginIdpLinkConfirm.js.map +1 -1
  337. package/login/pages/LoginIdpLinkEmail.d.ts +2 -2
  338. package/login/pages/LoginIdpLinkEmail.js +1 -1
  339. package/login/pages/LoginIdpLinkEmail.js.map +1 -1
  340. package/login/pages/LoginOauth2DeviceVerifyUserCode.d.ts +3 -3
  341. package/login/pages/LoginOauth2DeviceVerifyUserCode.js +3 -4
  342. package/login/pages/LoginOauth2DeviceVerifyUserCode.js.map +1 -1
  343. package/login/pages/LoginOauthGrant.d.ts +3 -3
  344. package/login/pages/LoginOauthGrant.js +4 -5
  345. package/login/pages/LoginOauthGrant.js.map +1 -1
  346. package/login/pages/LoginOtp.d.ts +1 -1
  347. package/login/pages/LoginOtp.js +3 -4
  348. package/login/pages/LoginOtp.js.map +1 -1
  349. package/login/pages/LoginPageExpired.d.ts +1 -1
  350. package/login/pages/LoginPageExpired.js +1 -1
  351. package/login/pages/LoginPageExpired.js.map +1 -1
  352. package/login/pages/LoginPassword.d.ts +1 -1
  353. package/login/pages/LoginPassword.js +6 -6
  354. package/login/pages/LoginPassword.js.map +1 -1
  355. package/login/pages/LoginRecoveryAuthnCodeConfig.d.ts +1 -1
  356. package/login/pages/LoginRecoveryAuthnCodeConfig.js +16 -16
  357. package/login/pages/LoginRecoveryAuthnCodeConfig.js.map +1 -1
  358. package/login/pages/LoginRecoveryAuthnCodeInput.d.ts +1 -1
  359. package/login/pages/LoginRecoveryAuthnCodeInput.js +3 -4
  360. package/login/pages/LoginRecoveryAuthnCodeInput.js.map +1 -1
  361. package/login/pages/LoginResetOtp.d.ts +1 -1
  362. package/login/pages/LoginResetOtp.js +3 -4
  363. package/login/pages/LoginResetOtp.js.map +1 -1
  364. package/login/pages/LoginResetPassword.d.ts +1 -1
  365. package/login/pages/LoginResetPassword.js +4 -5
  366. package/login/pages/LoginResetPassword.js.map +1 -1
  367. package/login/pages/LoginUpdatePassword.d.ts +1 -1
  368. package/login/pages/LoginUpdatePassword.js +7 -8
  369. package/login/pages/LoginUpdatePassword.js.map +1 -1
  370. package/login/pages/LoginUpdateProfile.d.ts +4 -3
  371. package/login/pages/LoginUpdateProfile.js +5 -9
  372. package/login/pages/LoginUpdateProfile.js.map +1 -1
  373. package/login/pages/LoginUsername.d.ts +1 -1
  374. package/login/pages/LoginUsername.js +5 -5
  375. package/login/pages/LoginUsername.js.map +1 -1
  376. package/login/pages/LoginVerifyEmail.d.ts +1 -1
  377. package/login/pages/LoginVerifyEmail.js +1 -1
  378. package/login/pages/LoginVerifyEmail.js.map +1 -1
  379. package/login/pages/LoginX509Info.d.ts +1 -1
  380. package/login/pages/LoginX509Info.js +3 -4
  381. package/login/pages/LoginX509Info.js.map +1 -1
  382. package/login/pages/LogoutConfirm.d.ts +1 -1
  383. package/login/pages/LogoutConfirm.js +3 -4
  384. package/login/pages/LogoutConfirm.js.map +1 -1
  385. package/login/pages/PageProps.d.ts +3 -5
  386. package/login/pages/Register.d.ts +4 -3
  387. package/login/pages/Register.js +7 -13
  388. package/login/pages/Register.js.map +1 -1
  389. package/login/pages/SamlPostForm.d.ts +1 -1
  390. package/login/pages/SamlPostForm.js +1 -1
  391. package/login/pages/SamlPostForm.js.map +1 -1
  392. package/login/pages/SelectAuthenticator.d.ts +2 -2
  393. package/login/pages/SelectAuthenticator.js +3 -7
  394. package/login/pages/SelectAuthenticator.js.map +1 -1
  395. package/login/pages/Terms.d.ts +1 -1
  396. package/login/pages/Terms.js +6 -7
  397. package/login/pages/Terms.js.map +1 -1
  398. package/login/pages/UpdateEmail.d.ts +3 -2
  399. package/login/pages/UpdateEmail.js +6 -10
  400. package/login/pages/UpdateEmail.js.map +1 -1
  401. package/login/pages/WebauthnAuthenticate.d.ts +1 -1
  402. package/login/pages/WebauthnAuthenticate.js +25 -22
  403. package/login/pages/WebauthnAuthenticate.js.map +1 -1
  404. package/login/pages/WebauthnError.d.ts +1 -1
  405. package/login/pages/WebauthnError.js +4 -5
  406. package/login/pages/WebauthnError.js.map +1 -1
  407. package/login/pages/WebauthnRegister.d.ts +1 -1
  408. package/login/pages/WebauthnRegister.js +15 -16
  409. package/login/pages/WebauthnRegister.js.map +1 -1
  410. package/package.json +420 -313
  411. package/src/PUBLIC_URL.ts +3 -3
  412. package/src/account/{Fallback.tsx → DefaultPage.tsx} +5 -5
  413. package/src/account/{kcContext → KcContext}/KcContext.ts +24 -2
  414. package/src/account/KcContext/getKcContextMock.ts +69 -0
  415. package/src/account/KcContext/index.ts +2 -0
  416. package/src/account/KcContext/kcContextMocks.ts +190 -0
  417. package/src/account/Template.tsx +12 -14
  418. package/src/account/TemplateProps.ts +4 -5
  419. package/src/account/i18n/baseMessages/ar.ts +3 -1
  420. package/src/account/i18n/baseMessages/ca.ts +3 -1
  421. package/src/account/i18n/baseMessages/cs.ts +3 -1
  422. package/src/account/i18n/baseMessages/da.ts +3 -1
  423. package/src/account/i18n/baseMessages/de.ts +3 -1
  424. package/src/account/i18n/baseMessages/el.ts +3 -1
  425. package/src/account/i18n/baseMessages/en.ts +3 -1
  426. package/src/account/i18n/baseMessages/es.ts +3 -1
  427. package/src/account/i18n/baseMessages/fa.ts +3 -1
  428. package/src/account/i18n/baseMessages/fi.ts +3 -1
  429. package/src/account/i18n/baseMessages/fr.ts +3 -1
  430. package/src/account/i18n/baseMessages/hu.ts +3 -1
  431. package/src/account/i18n/baseMessages/it.ts +3 -1
  432. package/src/account/i18n/baseMessages/ja.ts +3 -1
  433. package/src/account/i18n/baseMessages/lt.ts +3 -1
  434. package/src/account/i18n/baseMessages/lv.ts +3 -1
  435. package/src/account/i18n/baseMessages/nl.ts +3 -1
  436. package/src/account/i18n/baseMessages/no.ts +3 -1
  437. package/src/account/i18n/baseMessages/pl.ts +3 -1
  438. package/src/account/i18n/baseMessages/pt-BR.ts +3 -1
  439. package/src/account/i18n/baseMessages/ru.ts +3 -1
  440. package/src/account/i18n/baseMessages/sk.ts +3 -1
  441. package/src/account/i18n/baseMessages/sv.ts +3 -1
  442. package/src/account/i18n/baseMessages/th.ts +3 -1
  443. package/src/account/i18n/baseMessages/tr.ts +3 -1
  444. package/src/account/i18n/baseMessages/uk.ts +3 -1
  445. package/src/account/i18n/baseMessages/zh-CN.ts +3 -1
  446. package/src/account/i18n/i18n.tsx +230 -137
  447. package/src/account/i18n/index.ts +5 -1
  448. package/src/account/index.ts +3 -10
  449. package/src/account/lib/kcClsx.ts +25 -0
  450. package/src/account/pages/Account.tsx +12 -18
  451. package/src/account/pages/Applications.tsx +8 -9
  452. package/src/account/pages/FederatedIdentity.tsx +3 -3
  453. package/src/account/pages/Log.tsx +5 -5
  454. package/src/account/pages/PageProps.ts +4 -6
  455. package/src/account/pages/Password.tsx +17 -19
  456. package/src/account/pages/Sessions.tsx +5 -6
  457. package/src/account/pages/Totp.tsx +18 -38
  458. package/src/bin/add-story.ts +104 -0
  459. package/src/bin/copy-keycloak-resources-to-public.ts +3 -6
  460. package/src/bin/eject-page.ts +257 -0
  461. package/src/bin/initialize-email-theme.ts +30 -26
  462. package/src/bin/keycloakify/buildJars/buildJar.ts +138 -77
  463. package/src/bin/keycloakify/buildJars/buildJars.ts +35 -31
  464. package/src/bin/keycloakify/buildJars/extensionVersions.ts +3 -2
  465. package/src/bin/keycloakify/buildJars/generatePom.ts +19 -11
  466. package/src/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.ts +42 -10
  467. package/src/bin/keycloakify/generateFtl/generateFtl.ts +68 -24
  468. package/src/bin/keycloakify/generateFtl/{ftl_object_to_js_code_declaring_an_object.ftl → kcContextDeclarationTemplate.ftl} +225 -193
  469. package/src/bin/keycloakify/generateResources/bringInAccountV1.ts +89 -0
  470. package/src/bin/keycloakify/{generateSrcMainResources → generateResources}/generateMessageProperties.ts +31 -43
  471. package/src/bin/keycloakify/generateResources/generateResources.ts +42 -0
  472. package/src/bin/keycloakify/generateResources/generateResourcesForMainTheme.ts +304 -0
  473. package/src/bin/keycloakify/generateResources/generateResourcesForThemeVariant.ts +70 -0
  474. package/src/bin/keycloakify/generateResources/index.ts +1 -0
  475. package/src/bin/keycloakify/{generateSrcMainResources → generateResources}/readExtraPageNames.ts +21 -7
  476. package/src/bin/keycloakify/{generateSrcMainResources → generateResources}/readFieldNameUsage.ts +34 -7
  477. package/src/bin/keycloakify/keycloakify.ts +54 -20
  478. package/src/bin/keycloakify/replacers/replaceImportsInCssCode.ts +28 -9
  479. package/src/bin/keycloakify/replacers/replaceImportsInInlineCssCode.ts +12 -8
  480. package/src/bin/keycloakify/replacers/replaceImportsInJsCode/replaceImportsInJsCode.ts +14 -11
  481. package/src/bin/keycloakify/replacers/replaceImportsInJsCode/vite.ts +31 -16
  482. package/src/bin/keycloakify/replacers/replaceImportsInJsCode/webpack.ts +53 -18
  483. package/src/bin/main.ts +96 -44
  484. package/src/bin/shared/KeycloakVersionRange.ts +4 -2
  485. package/src/bin/shared/buildContext.ts +768 -0
  486. package/src/bin/shared/constants.ts +10 -4
  487. package/src/bin/shared/copyKeycloakResourcesToPublic.ts +35 -21
  488. package/src/bin/shared/downloadKeycloakDefaultTheme.ts +234 -0
  489. package/src/bin/shared/downloadKeycloakStaticResources.ts +30 -26
  490. package/src/bin/shared/generateKcGenTs.ts +68 -0
  491. package/src/bin/shared/metaInfKeycloakThemes.ts +25 -19
  492. package/src/bin/shared/promptKeycloakVersion.ts +39 -15
  493. package/src/bin/start-keycloak/appBuild.ts +129 -0
  494. package/src/bin/start-keycloak/index.ts +1 -0
  495. package/src/bin/start-keycloak/keycloakifyBuild.ts +42 -0
  496. package/src/bin/start-keycloak/myrealm-realm-18.json +2155 -0
  497. package/src/bin/start-keycloak/myrealm-realm-19.json +2186 -0
  498. package/src/bin/start-keycloak/myrealm-realm-20.json +2197 -0
  499. package/src/bin/start-keycloak/myrealm-realm-21.json +2201 -0
  500. package/src/bin/start-keycloak/myrealm-realm-23.json +2150 -0
  501. package/src/bin/start-keycloak/myrealm-realm-24.json +2318 -0
  502. package/src/bin/start-keycloak/myrealm-realm-25.json +2400 -0
  503. package/src/bin/start-keycloak/start-keycloak.ts +451 -0
  504. package/src/bin/tools/SemVer.ts +32 -13
  505. package/src/bin/tools/String.prototype.replaceAll.ts +9 -2
  506. package/src/bin/tools/crawl.ts +4 -1
  507. package/src/bin/tools/crc32.ts +42 -24
  508. package/src/bin/tools/downloadAndExtractArchive/downloadAndExtractArchive.ts +262 -0
  509. package/src/bin/tools/{fetchProxyOptions.ts → downloadAndExtractArchive/fetchProxyOptions.ts} +39 -8
  510. package/src/bin/tools/downloadAndExtractArchive/index.ts +1 -0
  511. package/src/bin/tools/escapeStringForPropertiesFile.ts +64 -0
  512. package/src/bin/tools/extractArchive.ts +140 -0
  513. package/src/bin/tools/getAbsoluteAndInOsFormatPath.ts +10 -2
  514. package/src/bin/tools/getNpmWorkspaceRootDirPath.ts +52 -6
  515. package/src/bin/tools/octokit-addons/getLatestsSemVersionedTag.ts +8 -2
  516. package/src/bin/tools/octokit-addons/listTags.ts +15 -4
  517. package/src/bin/tools/partitionPromiseSettledResults.ts +12 -3
  518. package/src/bin/tools/readThisNpmPackageVersion.ts +5 -1
  519. package/src/bin/tools/transformCodebase.ts +29 -10
  520. package/src/bin/tools/trimIndent.ts +4 -1
  521. package/src/bin/tsconfig.json +4 -3
  522. package/src/bin/update-kc-gen.ts +13 -0
  523. package/src/lib/getKcClsx.ts +89 -0
  524. package/src/login/{Fallback.tsx → DefaultPage.tsx} +7 -6
  525. package/src/login/{kcContext → KcContext}/KcContext.ts +67 -31
  526. package/src/login/KcContext/getKcContextMock.ts +69 -0
  527. package/src/login/KcContext/index.ts +8 -0
  528. package/src/login/KcContext/kcContextMocks.ts +580 -0
  529. package/src/login/Template.tsx +52 -55
  530. package/src/login/TemplateProps.ts +3 -6
  531. package/src/login/UserProfileFormFields.tsx +125 -210
  532. package/src/login/UserProfileFormFieldsProps.tsx +22 -0
  533. package/src/login/i18n/baseMessages/ar.ts +10 -1
  534. package/src/login/i18n/baseMessages/ca.ts +11 -2
  535. package/src/login/i18n/baseMessages/cs.ts +10 -1
  536. package/src/login/i18n/baseMessages/da.ts +10 -1
  537. package/src/login/i18n/baseMessages/de.ts +10 -1
  538. package/src/login/i18n/baseMessages/el.ts +10 -2
  539. package/src/login/i18n/baseMessages/en.ts +11 -2
  540. package/src/login/i18n/baseMessages/es.ts +11 -2
  541. package/src/login/i18n/baseMessages/fa.ts +10 -2
  542. package/src/login/i18n/baseMessages/fi.ts +10 -1
  543. package/src/login/i18n/baseMessages/fr.ts +10 -1
  544. package/src/login/i18n/baseMessages/hu.ts +11 -2
  545. package/src/login/i18n/baseMessages/it.ts +10 -1
  546. package/src/login/i18n/baseMessages/ja.ts +10 -1
  547. package/src/login/i18n/baseMessages/lt.ts +10 -1
  548. package/src/login/i18n/baseMessages/lv.ts +10 -1
  549. package/src/login/i18n/baseMessages/nl.ts +10 -1
  550. package/src/login/i18n/baseMessages/no.ts +10 -1
  551. package/src/login/i18n/baseMessages/pl.ts +10 -1
  552. package/src/login/i18n/baseMessages/pt-BR.ts +10 -1
  553. package/src/login/i18n/baseMessages/ru.ts +10 -1
  554. package/src/login/i18n/baseMessages/sk.ts +10 -1
  555. package/src/login/i18n/baseMessages/sv.ts +10 -1
  556. package/src/login/i18n/baseMessages/th.ts +10 -1
  557. package/src/login/i18n/baseMessages/tr.ts +10 -1
  558. package/src/login/i18n/baseMessages/uk.ts +10 -1
  559. package/src/login/i18n/baseMessages/zh-CN.ts +11 -2
  560. package/src/login/i18n/i18n.tsx +248 -139
  561. package/src/login/i18n/index.ts +5 -1
  562. package/src/login/index.ts +3 -10
  563. package/src/login/lib/kcClsx.ts +143 -0
  564. package/src/login/lib/useDownloadTerms.ts +32 -32
  565. package/src/login/lib/useUserProfileForm.tsx +480 -351
  566. package/src/login/pages/Code.tsx +8 -5
  567. package/src/login/pages/DeleteAccountConfirm.tsx +15 -10
  568. package/src/login/pages/DeleteCredential.tsx +9 -7
  569. package/src/login/pages/Error.tsx +9 -2
  570. package/src/login/pages/FrontchannelLogout.tsx +6 -3
  571. package/src/login/pages/IdpReviewUserProfile.tsx +20 -21
  572. package/src/login/pages/Info.tsx +5 -8
  573. package/src/login/pages/Login.tsx +34 -53
  574. package/src/login/pages/LoginConfigTotp.tsx +35 -39
  575. package/src/login/pages/LoginIdpLinkConfirm.tsx +7 -18
  576. package/src/login/pages/LoginIdpLinkEmail.tsx +9 -3
  577. package/src/login/pages/LoginOauth2DeviceVerifyUserCode.tsx +24 -23
  578. package/src/login/pages/LoginOauthGrant.tsx +14 -20
  579. package/src/login/pages/LoginOtp.tsx +27 -30
  580. package/src/login/pages/LoginPageExpired.tsx +2 -2
  581. package/src/login/pages/LoginPassword.tsx +21 -31
  582. package/src/login/pages/LoginRecoveryAuthnCodeConfig.tsx +34 -34
  583. package/src/login/pages/LoginRecoveryAuthnCodeInput.tsx +19 -22
  584. package/src/login/pages/LoginResetOtp.tsx +19 -22
  585. package/src/login/pages/LoginResetPassword.tsx +21 -24
  586. package/src/login/pages/LoginUpdatePassword.tsx +40 -50
  587. package/src/login/pages/LoginUpdateProfile.tsx +32 -30
  588. package/src/login/pages/LoginUsername.tsx +23 -34
  589. package/src/login/pages/LoginVerifyEmail.tsx +5 -2
  590. package/src/login/pages/LoginX509Info.tsx +24 -33
  591. package/src/login/pages/LogoutConfirm.tsx +8 -14
  592. package/src/login/pages/PageProps.ts +3 -5
  593. package/src/login/pages/Register.tsx +37 -48
  594. package/src/login/pages/SamlPostForm.tsx +2 -2
  595. package/src/login/pages/SelectAuthenticator.tsx +23 -24
  596. package/src/login/pages/Terms.tsx +18 -18
  597. package/src/login/pages/UpdateEmail.tsx +30 -33
  598. package/src/login/pages/WebauthnAuthenticate.tsx +40 -44
  599. package/src/login/pages/WebauthnError.tsx +15 -19
  600. package/src/login/pages/WebauthnRegister.tsx +28 -37
  601. package/src/tools/Array.prototype.every.ts +4 -1
  602. package/src/tools/ExtractAfterStartingWith.ts +4 -0
  603. package/src/tools/LazyOrNot.ts +3 -1
  604. package/src/tools/Object.fromEntries.ts +23 -0
  605. package/src/tools/StatefulObservable/README.md +16 -0
  606. package/src/tools/StatefulObservable/StatefulObservable.ts +58 -0
  607. package/src/tools/StatefulObservable/hooks/index.ts +2 -0
  608. package/src/tools/StatefulObservable/hooks/useObservable.ts +25 -0
  609. package/src/tools/StatefulObservable/hooks/useRerenderOnChange.ts +19 -0
  610. package/src/tools/StatefulObservable/index.ts +2 -0
  611. package/src/tools/ValueOf.ts +2 -0
  612. package/src/tools/clsx.ts +6 -42
  613. package/src/tools/clsx_withTransform.ts +55 -0
  614. package/src/tools/deepAssign.ts +57 -19
  615. package/src/tools/formatNumber.ts +7 -3
  616. package/src/tools/structuredCloneButFunctions.ts +24 -0
  617. package/src/tools/useConstCallback.ts +3 -1
  618. package/src/tools/useInsertLinkTags.ts +78 -74
  619. package/src/tools/useInsertScriptTags.ts +69 -73
  620. package/src/tools/useOnFirstMount.ts +18 -0
  621. package/src/tools/useSetClassName.ts +4 -1
  622. package/src/vite-plugin/vite-plugin.ts +73 -37
  623. package/stories/account/pages/Account.stories.tsx +18 -0
  624. package/stories/account/pages/FederatedIdentity.stories.tsx +38 -0
  625. package/stories/account/pages/Log.stories.tsx +356 -0
  626. package/stories/account/pages/Password.stories.tsx +28 -0
  627. package/stories/account/pages/Sessions.stories.tsx +59 -0
  628. package/stories/account/pages/Totp.stories.tsx +182 -0
  629. package/stories/login/pages/Code.stories.tsx +18 -0
  630. package/stories/login/pages/DeleteAccountConfirm.stories.tsx +18 -0
  631. package/stories/login/pages/DeleteCredential.stories.tsx +18 -0
  632. package/stories/login/pages/Error.stories.tsx +28 -0
  633. package/stories/login/pages/FrontchannelLogout.stories.tsx +18 -0
  634. package/stories/login/pages/IdpReviewUserProfile.stories.tsx +18 -0
  635. package/stories/login/pages/Info.stories.tsx +52 -0
  636. package/stories/login/pages/Login.stories.tsx +221 -0
  637. package/stories/login/pages/LoginConfigTotp.stories.tsx +43 -0
  638. package/stories/login/pages/LoginDeviceVerifyUserCode.stories.tsx +18 -0
  639. package/stories/login/pages/LoginIdpLinkConfirm.stories.tsx +18 -0
  640. package/stories/login/pages/LoginIdpLinkEmail.stories.tsx +18 -0
  641. package/stories/login/pages/LoginOauth2DeviceVerifyUserCode.stories.tsx +18 -0
  642. package/stories/login/pages/LoginOauthGrant.stories.tsx +18 -0
  643. package/stories/login/pages/LoginOtp.stories.tsx +18 -0
  644. package/stories/login/pages/LoginPageExpired.stories.tsx +18 -0
  645. package/stories/login/pages/LoginPassword.stories.tsx +18 -0
  646. package/stories/login/pages/LoginRecoveryAuthnCodeConfig.stories.tsx +18 -0
  647. package/stories/login/pages/LoginRecoveryAuthnCodeInput.stories.tsx +18 -0
  648. package/stories/login/pages/LoginResetOtp.stories.tsx +18 -0
  649. package/stories/login/pages/LoginResetPassword.stories.tsx +31 -0
  650. package/stories/login/pages/LoginUpdatePassword.stories.tsx +18 -0
  651. package/stories/login/pages/LoginUpdateProfile.stories.tsx +18 -0
  652. package/stories/login/pages/LoginUsername.stories.tsx +31 -0
  653. package/stories/login/pages/LoginVerifyEmail.stories.tsx +30 -0
  654. package/stories/login/pages/LoginX509Info.stories.tsx +18 -0
  655. package/stories/login/pages/LogoutConfirm.stories.tsx +18 -0
  656. package/stories/login/pages/Register.stories.tsx +135 -0
  657. package/stories/login/pages/SamlPostForm.stories.tsx +18 -0
  658. package/stories/login/pages/SelectAuthenticator.stories.tsx +43 -0
  659. package/stories/login/pages/Terms.stories.tsx +42 -0
  660. package/stories/login/pages/UpdateEmail.stories.tsx +18 -0
  661. package/stories/login/pages/WebauthnAuthenticate.stories.tsx +18 -0
  662. package/stories/login/pages/WebauthnError.stories.tsx +18 -0
  663. package/stories/login/pages/WebauthnRegister.stories.tsx +18 -0
  664. package/tools/Array.prototype.every.js +2 -1
  665. package/tools/Array.prototype.every.js.map +1 -1
  666. package/tools/ExtractAfterStartingWith.d.ts +1 -0
  667. package/tools/ExtractAfterStartingWith.js +2 -0
  668. package/tools/ExtractAfterStartingWith.js.map +1 -0
  669. package/tools/HTMLElement.prototype.prepend.js.map +1 -1
  670. package/tools/Object.fromEntries.d.ts +1 -0
  671. package/tools/Object.fromEntries.js +17 -0
  672. package/tools/Object.fromEntries.js.map +1 -0
  673. package/tools/StatefulObservable/StatefulObservable.d.ts +8 -0
  674. package/tools/StatefulObservable/StatefulObservable.js +36 -0
  675. package/tools/StatefulObservable/StatefulObservable.js.map +1 -0
  676. package/tools/StatefulObservable/hooks/index.d.ts +2 -0
  677. package/tools/StatefulObservable/hooks/index.js +3 -0
  678. package/tools/StatefulObservable/hooks/index.js.map +1 -0
  679. package/tools/StatefulObservable/hooks/useObservable.d.ts +8 -0
  680. package/tools/StatefulObservable/hooks/useObservable.js +17 -0
  681. package/tools/StatefulObservable/hooks/useObservable.js.map +1 -0
  682. package/tools/StatefulObservable/hooks/useRerenderOnChange.d.ts +5 -0
  683. package/tools/StatefulObservable/hooks/useRerenderOnChange.js +14 -0
  684. package/tools/StatefulObservable/hooks/useRerenderOnChange.js.map +1 -0
  685. package/tools/StatefulObservable/index.d.ts +2 -0
  686. package/tools/StatefulObservable/index.js +3 -0
  687. package/tools/StatefulObservable/index.js.map +1 -0
  688. package/tools/ValueOf.d.ts +2 -0
  689. package/tools/ValueOf.js +2 -0
  690. package/tools/ValueOf.js.map +1 -0
  691. package/tools/clsx.d.ts +3 -2
  692. package/tools/clsx.js +5 -41
  693. package/tools/clsx.js.map +1 -1
  694. package/tools/clsx_withTransform.d.ts +5 -0
  695. package/tools/clsx_withTransform.js +43 -0
  696. package/tools/clsx_withTransform.js.map +1 -0
  697. package/tools/deepAssign.d.ts +1 -0
  698. package/tools/deepAssign.js +41 -16
  699. package/tools/deepAssign.js.map +1 -1
  700. package/tools/formatNumber.js +2 -1
  701. package/tools/formatNumber.js.map +1 -1
  702. package/tools/structuredCloneButFunctions.d.ts +7 -0
  703. package/tools/structuredCloneButFunctions.js +19 -0
  704. package/tools/structuredCloneButFunctions.js.map +1 -0
  705. package/tools/useConstCallback.js.map +1 -1
  706. package/tools/useInsertLinkTags.d.ts +11 -6
  707. package/tools/useInsertLinkTags.js +53 -52
  708. package/tools/useInsertLinkTags.js.map +1 -1
  709. package/tools/useInsertScriptTags.d.ts +15 -6
  710. package/tools/useInsertScriptTags.js +56 -61
  711. package/tools/useInsertScriptTags.js.map +1 -1
  712. package/tools/useOnFirstMount.d.ts +2 -0
  713. package/tools/useOnFirstMount.js +15 -0
  714. package/tools/useOnFirstMount.js.map +1 -0
  715. package/tools/useSetClassName.js.map +1 -1
  716. package/vite-plugin/index.d.ts +1 -0
  717. package/vite-plugin/index.js +53389 -0
  718. package/vite-plugin/vite-plugin.d.ts +5 -0
  719. package/account/Fallback.d.ts +0 -5
  720. package/account/Fallback.js.map +0 -1
  721. package/account/kcContext/KcContext.js.map +0 -1
  722. package/account/kcContext/createGetKcContext.d.ts +0 -19
  723. package/account/kcContext/createGetKcContext.js +0 -73
  724. package/account/kcContext/createGetKcContext.js.map +0 -1
  725. package/account/kcContext/getKcContext.d.ts +0 -13
  726. package/account/kcContext/getKcContext.js +0 -13
  727. package/account/kcContext/getKcContext.js.map +0 -1
  728. package/account/kcContext/getKcContextFromWindow.d.ts +0 -8
  729. package/account/kcContext/getKcContextFromWindow.js +0 -5
  730. package/account/kcContext/getKcContextFromWindow.js.map +0 -1
  731. package/account/kcContext/index.d.ts +0 -1
  732. package/account/kcContext/index.js +0 -2
  733. package/account/kcContext/index.js.map +0 -1
  734. package/account/kcContext/kcContextMocks.js +0 -215
  735. package/account/kcContext/kcContextMocks.js.map +0 -1
  736. package/account/lib/useGetClassName.d.ts +0 -7
  737. package/account/lib/useGetClassName.js +0 -19
  738. package/account/lib/useGetClassName.js.map +0 -1
  739. package/lib/isStorybook.d.ts +0 -1
  740. package/lib/isStorybook.js +0 -2
  741. package/lib/isStorybook.js.map +0 -1
  742. package/lib/useGetClassName.d.ts +0 -10
  743. package/lib/useGetClassName.js +0 -14
  744. package/lib/useGetClassName.js.map +0 -1
  745. package/login/Fallback.js.map +0 -1
  746. package/login/kcContext/KcContext.js.map +0 -1
  747. package/login/kcContext/createGetKcContext.d.ts +0 -19
  748. package/login/kcContext/createGetKcContext.js +0 -109
  749. package/login/kcContext/createGetKcContext.js.map +0 -1
  750. package/login/kcContext/getKcContext.d.ts +0 -13
  751. package/login/kcContext/getKcContext.js +0 -13
  752. package/login/kcContext/getKcContext.js.map +0 -1
  753. package/login/kcContext/getKcContextFromWindow.d.ts +0 -8
  754. package/login/kcContext/getKcContextFromWindow.js +0 -5
  755. package/login/kcContext/getKcContextFromWindow.js.map +0 -1
  756. package/login/kcContext/index.d.ts +0 -1
  757. package/login/kcContext/index.js +0 -2
  758. package/login/kcContext/index.js.map +0 -1
  759. package/login/kcContext/kcContextMocks.js +0 -390
  760. package/login/kcContext/kcContextMocks.js.map +0 -1
  761. package/login/lib/useGetClassName.d.ts +0 -7
  762. package/login/lib/useGetClassName.js +0 -130
  763. package/login/lib/useGetClassName.js.map +0 -1
  764. package/src/account/kcContext/createGetKcContext.ts +0 -108
  765. package/src/account/kcContext/getKcContext.ts +0 -21
  766. package/src/account/kcContext/getKcContextFromWindow.ts +0 -11
  767. package/src/account/kcContext/index.ts +0 -1
  768. package/src/account/kcContext/kcContextMocks.ts +0 -260
  769. package/src/account/lib/useGetClassName.ts +0 -20
  770. package/src/bin/download-builtin-keycloak-theme.ts +0 -30
  771. package/src/bin/eject-keycloak-page.ts +0 -126
  772. package/src/bin/keycloakify/generateSrcMainResources/bringInAccountV1.ts +0 -79
  773. package/src/bin/keycloakify/generateSrcMainResources/generateSrcMainResources.ts +0 -32
  774. package/src/bin/keycloakify/generateSrcMainResources/generateSrcMainResourcesForMainTheme.ts +0 -261
  775. package/src/bin/keycloakify/generateSrcMainResources/generateSrcMainResourcesForThemeVariant.ts +0 -56
  776. package/src/bin/keycloakify/generateSrcMainResources/index.ts +0 -1
  777. package/src/bin/keycloakify/generateStartKeycloakTestingContainer.ts +0 -60
  778. package/src/bin/shared/buildOptions.ts +0 -277
  779. package/src/bin/shared/downloadAndUnzip.ts +0 -203
  780. package/src/bin/shared/downloadBuiltinKeycloakTheme.ts +0 -264
  781. package/src/bin/shared/getJarFileBasename.ts +0 -9
  782. package/src/bin/shared/getThemeSrcDirPath.ts +0 -47
  783. package/src/bin/start-keycloak.ts +0 -236
  784. package/src/bin/tools/unzip.ts +0 -141
  785. package/src/lib/isStorybook.ts +0 -1
  786. package/src/lib/useGetClassName.ts +0 -18
  787. package/src/login/kcContext/createGetKcContext.ts +0 -159
  788. package/src/login/kcContext/getKcContext.ts +0 -21
  789. package/src/login/kcContext/getKcContextFromWindow.ts +0 -11
  790. package/src/login/kcContext/index.ts +0 -1
  791. package/src/login/kcContext/kcContextMocks.ts +0 -630
  792. package/src/login/lib/useGetClassName.ts +0 -132
  793. package/src/tools/AndByDiscriminatingKey.ts +0 -25
  794. package/src/tools/deepClone.ts +0 -17
  795. package/src/tools/memoize.ts +0 -55
  796. package/tools/AndByDiscriminatingKey.d.ts +0 -5
  797. package/tools/AndByDiscriminatingKey.js +0 -2
  798. package/tools/AndByDiscriminatingKey.js.map +0 -1
  799. package/tools/deepClone.d.ts +0 -2
  800. package/tools/deepClone.js +0 -14
  801. package/tools/deepClone.js.map +0 -1
  802. package/tools/memoize.d.ts +0 -7
  803. package/tools/memoize.js +0 -38
  804. package/tools/memoize.js.map +0 -1
  805. /package/account/{kcContext → KcContext}/KcContext.js +0 -0
@@ -5,11 +5,19 @@ const per_page = 99;
5
5
  export function listTagsFactory(params: { octokit: Octokit }) {
6
6
  const { octokit } = params;
7
7
 
8
- const octokit_repo_listTags = async (params: { owner: string; repo: string; per_page: number; page: number }) => {
8
+ const octokit_repo_listTags = async (params: {
9
+ owner: string;
10
+ repo: string;
11
+ per_page: number;
12
+ page: number;
13
+ }) => {
9
14
  return octokit.repos.listTags(params);
10
15
  };
11
16
 
12
- async function* listTags(params: { owner: string; repo: string }): AsyncGenerator<string> {
17
+ async function* listTags(params: {
18
+ owner: string;
19
+ repo: string;
20
+ }): AsyncGenerator<string> {
13
21
  const { owner, repo } = params;
14
22
 
15
23
  let page = 1;
@@ -19,7 +27,7 @@ export function listTagsFactory(params: { octokit: Octokit }) {
19
27
  owner,
20
28
  repo,
21
29
  per_page,
22
- "page": page++
30
+ page: page++
23
31
  });
24
32
 
25
33
  for (const branch of resp.data.map(({ name }) => name)) {
@@ -33,7 +41,10 @@ export function listTagsFactory(params: { octokit: Octokit }) {
33
41
  }
34
42
 
35
43
  /** Returns the same "latest" tag as deno.land/x, not actually the latest though */
36
- async function getLatestTag(params: { owner: string; repo: string }): Promise<string | undefined> {
44
+ async function getLatestTag(params: {
45
+ owner: string;
46
+ repo: string;
47
+ }): Promise<string | undefined> {
37
48
  const { owner, repo } = params;
38
49
 
39
50
  const itRes = await listTags({ owner, repo }).next();
@@ -2,10 +2,19 @@ export type PromiseSettledAndPartitioned<T> = [T[], any[]];
2
2
 
3
3
  export function partitionPromiseSettledResults<T>() {
4
4
  return [
5
- ([successes, failures]: PromiseSettledAndPartitioned<T>, item: PromiseSettledResult<T>) =>
5
+ (
6
+ [successes, failures]: PromiseSettledAndPartitioned<T>,
7
+ item: PromiseSettledResult<T>
8
+ ) =>
6
9
  item.status === "rejected"
7
- ? ([successes, [item.reason, ...failures]] as PromiseSettledAndPartitioned<T>)
8
- : ([[item.value, ...successes], failures] as PromiseSettledAndPartitioned<T>),
10
+ ? ([
11
+ successes,
12
+ [item.reason, ...failures]
13
+ ] as PromiseSettledAndPartitioned<T>)
14
+ : ([
15
+ [item.value, ...successes],
16
+ failures
17
+ ] as PromiseSettledAndPartitioned<T>),
9
18
  [[], []] as PromiseSettledAndPartitioned<T>
10
19
  ] as const;
11
20
  }
@@ -4,7 +4,11 @@ import * as fs from "fs";
4
4
  import { join as pathJoin } from "path";
5
5
 
6
6
  export function readThisNpmPackageVersion(): string {
7
- const version = JSON.parse(fs.readFileSync(pathJoin(getThisCodebaseRootDirPath(), "package.json")).toString("utf8"))["version"];
7
+ const version = JSON.parse(
8
+ fs
9
+ .readFileSync(pathJoin(getThisCodebaseRootDirPath(), "package.json"))
10
+ .toString("utf8")
11
+ )["version"];
8
12
 
9
13
  assert(typeof version === "string");
10
14
 
@@ -3,7 +3,11 @@ import * as path from "path";
3
3
  import { crawl } from "./crawl";
4
4
  import { rmSync } from "../tools/fs.rmSync";
5
5
 
6
- type TransformSourceCode = (params: { sourceCode: Buffer; filePath: string; fileRelativePath: string }) =>
6
+ type TransformSourceCode = (params: {
7
+ sourceCode: Buffer;
8
+ filePath: string;
9
+ fileRelativePath: string;
10
+ }) =>
7
11
  | {
8
12
  modifiedSourceCode: Buffer;
9
13
  newFileName?: string;
@@ -15,18 +19,27 @@ type TransformSourceCode = (params: { sourceCode: Buffer; filePath: string; file
15
19
  * If source and destination are the same this function can be used to apply the transformation in place
16
20
  * like filtering out some files or modifying them.
17
21
  * */
18
- export function transformCodebase(params: { srcDirPath: string; destDirPath: string; transformSourceCode?: TransformSourceCode }) {
22
+ export function transformCodebase(params: {
23
+ srcDirPath: string;
24
+ destDirPath: string;
25
+ transformSourceCode?: TransformSourceCode;
26
+ }) {
19
27
  const { srcDirPath, transformSourceCode } = params;
20
28
 
21
29
  const isTargetSameAsSource = path.relative(srcDirPath, params.destDirPath) === "";
22
30
 
23
- const destDirPath = isTargetSameAsSource ? path.join(srcDirPath, "..", "tmp_xOsPdkPsTdzPs34sOkHs") : params.destDirPath;
31
+ const destDirPath = isTargetSameAsSource
32
+ ? path.join(srcDirPath, "..", "tmp_xOsPdkPsTdzPs34sOkHs")
33
+ : params.destDirPath;
24
34
 
25
35
  fs.mkdirSync(destDirPath, {
26
- "recursive": true
36
+ recursive: true
27
37
  });
28
38
 
29
- for (const fileRelativePath of crawl({ "dirPath": srcDirPath, "returnedPathsType": "relative to dirPath" })) {
39
+ for (const fileRelativePath of crawl({
40
+ dirPath: srcDirPath,
41
+ returnedPathsType: "relative to dirPath"
42
+ })) {
30
43
  const filePath = path.join(srcDirPath, fileRelativePath);
31
44
  const destFilePath = path.join(destDirPath, fileRelativePath);
32
45
 
@@ -34,7 +47,7 @@ export function transformCodebase(params: { srcDirPath: string; destDirPath: str
34
47
  // it using the lower level implementation.
35
48
  if (transformSourceCode === undefined) {
36
49
  fs.mkdirSync(path.dirname(destFilePath), {
37
- "recursive": true
50
+ recursive: true
38
51
  });
39
52
 
40
53
  fs.copyFileSync(filePath, destFilePath);
@@ -43,7 +56,7 @@ export function transformCodebase(params: { srcDirPath: string; destDirPath: str
43
56
  }
44
57
 
45
58
  const transformSourceCodeResult = transformSourceCode({
46
- "sourceCode": fs.readFileSync(filePath),
59
+ sourceCode: fs.readFileSync(filePath),
47
60
  filePath,
48
61
  fileRelativePath
49
62
  });
@@ -53,16 +66,22 @@ export function transformCodebase(params: { srcDirPath: string; destDirPath: str
53
66
  }
54
67
 
55
68
  fs.mkdirSync(path.dirname(destFilePath), {
56
- "recursive": true
69
+ recursive: true
57
70
  });
58
71
 
59
72
  const { newFileName, modifiedSourceCode } = transformSourceCodeResult;
60
73
 
61
- fs.writeFileSync(path.join(path.dirname(destFilePath), newFileName ?? path.basename(destFilePath)), modifiedSourceCode);
74
+ fs.writeFileSync(
75
+ path.join(
76
+ path.dirname(destFilePath),
77
+ newFileName ?? path.basename(destFilePath)
78
+ ),
79
+ modifiedSourceCode
80
+ );
62
81
  }
63
82
 
64
83
  if (isTargetSameAsSource) {
65
- rmSync(srcDirPath, { "recursive": true });
84
+ rmSync(srcDirPath, { recursive: true });
66
85
 
67
86
  fs.renameSync(destDirPath, srcDirPath);
68
87
  }
@@ -14,7 +14,10 @@ function populateTemplate(strings: TemplateStringsArray, ...args: unknown[]) {
14
14
  if (args[i]) {
15
15
  // if the interpolation value has newlines, indent the interpolation values
16
16
  // using the last known string indent
17
- const chunk = String(args[i]).replace(/([\r?\n])/g, "$1" + " ".repeat(lastStringLineLength));
17
+ const chunk = String(args[i]).replace(
18
+ /([\r?\n])/g,
19
+ "$1" + " ".repeat(lastStringLineLength)
20
+ );
18
21
  chunks.push(chunk);
19
22
  }
20
23
  }
@@ -1,10 +1,11 @@
1
1
  {
2
2
  "extends": "../../tsproject.json",
3
3
  "compilerOptions": {
4
- "module": "CommonJS",
5
- "target": "ES5",
4
+ "module": "ES2020",
5
+ "target": "ES2017",
6
6
  "esModuleInterop": true,
7
- "lib": ["es2015", "DOM", "ES2019.Object"],
7
+ "lib": ["es2015", "ES2019.Object"],
8
+ "moduleResolution": "node",
8
9
  "outDir": "../../dist/bin",
9
10
  "rootDir": "."
10
11
  }
@@ -0,0 +1,13 @@
1
+ import type { CliCommandOptions } from "./main";
2
+ import { getBuildContext } from "./shared/buildContext";
3
+ import { generateKcGenTs } from "./shared/generateKcGenTs";
4
+
5
+ export async function command(params: { cliCommandOptions: CliCommandOptions }) {
6
+ const { cliCommandOptions } = params;
7
+
8
+ const buildContext = getBuildContext({
9
+ cliCommandOptions
10
+ });
11
+
12
+ await generateKcGenTs({ buildContext });
13
+ }
@@ -0,0 +1,89 @@
1
+ import type { Param0 } from "tsafe";
2
+ import { type CxArg, clsx_withTransform } from "../tools/clsx_withTransform";
3
+ import { clsx } from "../tools/clsx";
4
+ import { assert } from "tsafe/assert";
5
+ import { is } from "tsafe/is";
6
+
7
+ export function createGetKcClsx<ClassKey extends string>(params: {
8
+ defaultClasses: Record<ClassKey, string | undefined>;
9
+ }) {
10
+ const { defaultClasses } = params;
11
+
12
+ function areSameParams(
13
+ params1: Param0<typeof getKcClsx>,
14
+ params2: Param0<typeof getKcClsx>
15
+ ): boolean {
16
+ if (params1.doUseDefaultCss !== params2.doUseDefaultCss) {
17
+ return false;
18
+ }
19
+
20
+ if (params1.classes === params2.classes) {
21
+ return true;
22
+ }
23
+
24
+ if (params1.classes === undefined || params2.classes === undefined) {
25
+ return false;
26
+ }
27
+
28
+ if (Object.keys(params1.classes).length !== Object.keys(params2.classes).length) {
29
+ return false;
30
+ }
31
+
32
+ for (const key in params1.classes) {
33
+ if (params1.classes[key] !== params2.classes[key]) {
34
+ return false;
35
+ }
36
+ }
37
+
38
+ return true;
39
+ }
40
+
41
+ let cache:
42
+ | {
43
+ params: Param0<typeof getKcClsx>;
44
+ result: ReturnType<typeof getKcClsx>;
45
+ }
46
+ | undefined = undefined;
47
+
48
+ function getKcClsx(params: {
49
+ doUseDefaultCss: boolean;
50
+ classes: Partial<Record<ClassKey, string>> | undefined;
51
+ }): { kcClsx: (...args: CxArg<ClassKey>[]) => string } {
52
+ // NOTE: We implement a cache here only so that getClassName can be stable across renders.
53
+ // We don't want to use useConstCallback because we want this to be useable outside of React.
54
+ use_cache: {
55
+ if (cache === undefined) {
56
+ break use_cache;
57
+ }
58
+
59
+ if (!areSameParams(cache.params, params)) {
60
+ break use_cache;
61
+ }
62
+
63
+ return cache.result;
64
+ }
65
+
66
+ const { classes, doUseDefaultCss } = params;
67
+
68
+ function kcClsx(...args: CxArg<ClassKey>[]): string {
69
+ return clsx_withTransform({
70
+ args,
71
+ transform: classKey => {
72
+ assert(is<ClassKey>(classKey));
73
+
74
+ return clsx(
75
+ classKey,
76
+ doUseDefaultCss ? defaultClasses[classKey] : undefined,
77
+ classes?.[classKey]
78
+ );
79
+ }
80
+ });
81
+ }
82
+
83
+ cache = { params, result: { kcClsx } };
84
+
85
+ return { kcClsx };
86
+ }
87
+
88
+ return { getKcClsx };
89
+ }
@@ -1,10 +1,10 @@
1
1
  import { lazy, Suspense } from "react";
2
- import type { PageProps } from "keycloakify/login/pages/PageProps";
3
2
  import { assert, type Equals } from "tsafe/assert";
4
- import type { I18n } from "./i18n";
5
- import type { KcContext } from "./kcContext";
6
3
  import type { LazyOrNot } from "keycloakify/tools/LazyOrNot";
7
- import type { UserProfileFormFieldsProps } from "keycloakify/login/UserProfileFormFields";
4
+ import type { PageProps } from "keycloakify/login/pages/PageProps";
5
+ import type { I18n } from "keycloakify/login/i18n";
6
+ import type { KcContext } from "keycloakify/login/KcContext";
7
+ import type { UserProfileFormFieldsProps } from "keycloakify/login/UserProfileFormFieldsProps";
8
8
 
9
9
  const Login = lazy(() => import("keycloakify/login/pages/Login"));
10
10
  const Register = lazy(() => import("keycloakify/login/pages/Register"));
@@ -41,11 +41,12 @@ const LoginResetOtp = lazy(() => import("keycloakify/login/pages/LoginResetOtp")
41
41
  const LoginX509Info = lazy(() => import("keycloakify/login/pages/LoginX509Info"));
42
42
  const WebauthnError = lazy(() => import("keycloakify/login/pages/WebauthnError"));
43
43
 
44
- type FallbackProps = PageProps<KcContext, I18n> & {
44
+ type DefaultPageProps = PageProps<KcContext, I18n> & {
45
45
  UserProfileFormFields: LazyOrNot<(props: UserProfileFormFieldsProps) => JSX.Element>;
46
+ doMakeUserConfirmPassword: boolean;
46
47
  };
47
48
 
48
- export default function Fallback(props: FallbackProps) {
49
+ export default function DefaultPage(props: DefaultPageProps) {
49
50
  const { kcContext, ...rest } = props;
50
51
 
51
52
  return (
@@ -1,9 +1,30 @@
1
- import type { ThemeType, LoginThemePageId } from "keycloakify/bin/shared/constants";
1
+ import type {
2
+ ThemeType,
3
+ LoginThemePageId,
4
+ nameOfTheLocalizationRealmOverridesUserProfileProperty
5
+ } from "keycloakify/bin/shared/constants";
6
+ import type { ExtractAfterStartingWith } from "keycloakify/tools/ExtractAfterStartingWith";
7
+ import type { ValueOf } from "keycloakify/tools/ValueOf";
2
8
  import { assert } from "tsafe/assert";
3
9
  import type { Equals } from "tsafe";
4
10
  import type { MessageKey } from "../i18n/i18n";
5
11
 
6
- type ExtractAfterStartingWith<Prefix extends string, StrEnum> = StrEnum extends `${Prefix}${infer U}` ? U : never;
12
+ export type ExtendKcContext<
13
+ KcContextExtension extends { properties?: Record<string, string | undefined> },
14
+ KcContextExtensionPerPage extends Record<string, Record<string, unknown>>
15
+ > = ValueOf<{
16
+ [PageId in keyof KcContextExtensionPerPage | KcContext["pageId"]]: Extract<
17
+ KcContext,
18
+ { pageId: PageId }
19
+ > extends never
20
+ ? KcContext.Common &
21
+ KcContextExtension & {
22
+ pageId: PageId;
23
+ } & KcContextExtensionPerPage[PageId]
24
+ : Extract<KcContext, { pageId: PageId }> &
25
+ KcContextExtension &
26
+ KcContextExtensionPerPage[PageId];
27
+ }>;
7
28
 
8
29
  /** Take theses type definition with a grain of salt.
9
30
  * Some values might be undefined on some pages.
@@ -103,7 +124,10 @@ export declare namespace KcContext {
103
124
  * @param text to return
104
125
  * @return text if message exists for given field, else undefined
105
126
  */
106
- printIfExists: <T extends string>(fieldName: string, text: T) => T | undefined;
127
+ printIfExists: <T extends string>(
128
+ fieldName: string,
129
+ text: T
130
+ ) => T | undefined;
107
131
  /**
108
132
  * Check if exists error message for given fields
109
133
  *
@@ -128,12 +152,13 @@ export declare namespace KcContext {
128
152
 
129
153
  getFirstError: (...fieldNames: string[]) => string;
130
154
  };
131
- properties: Record<string, string | undefined>;
132
155
  authenticationSession?: {
133
156
  authSessionId: string;
134
157
  tabId: string;
135
158
  ssoLoginInOtherTabsUrl: string;
136
159
  };
160
+ properties: {};
161
+ __localizationRealmOverridesUserProfile?: Record<string, string>;
137
162
  };
138
163
 
139
164
  export type SamlPostForm = Common & {
@@ -184,17 +209,13 @@ export declare namespace KcContext {
184
209
  export type Register = Common & {
185
210
  pageId: "register.ftl";
186
211
  profile: UserProfile;
212
+ passwordPolicies?: PasswordPolicies;
187
213
  url: {
188
214
  registrationAction: string;
189
215
  };
190
216
  passwordRequired: boolean;
191
217
  recaptchaRequired: boolean;
192
218
  recaptchaSiteKey?: string;
193
- /**
194
- * Theses values are added by: https://github.com/jcputney/keycloak-theme-additional-info-extension
195
- * A Keycloak Java extension used as dependency in Keycloakify.
196
- */
197
- passwordPolicies?: PasswordPolicies;
198
219
  termsAcceptanceRequired?: boolean;
199
220
  };
200
221
 
@@ -208,6 +229,7 @@ export declare namespace KcContext {
208
229
  client: {
209
230
  baseUrl?: string;
210
231
  };
232
+ message: NonNullable<Common["message"]>;
211
233
  };
212
234
 
213
235
  export type Error = Common & {
@@ -454,16 +476,19 @@ export declare namespace KcContext {
454
476
  export type LoginUpdateProfile = Common & {
455
477
  pageId: "login-update-profile.ftl";
456
478
  profile: UserProfile;
479
+ passwordPolicies?: PasswordPolicies;
457
480
  };
458
481
 
459
482
  export type IdpReviewUserProfile = Common & {
460
483
  pageId: "idp-review-user-profile.ftl";
461
484
  profile: UserProfile;
485
+ passwordPolicies?: PasswordPolicies;
462
486
  };
463
487
 
464
488
  export type UpdateEmail = Common & {
465
489
  pageId: "update-email.ftl";
466
490
  profile: UserProfile;
491
+ passwordPolicies?: PasswordPolicies;
467
492
  };
468
493
 
469
494
  export type SelectAuthenticator = Common & {
@@ -574,7 +599,6 @@ export declare namespace KcContext {
574
599
  }
575
600
 
576
601
  export type UserProfile = {
577
- attributes: Attribute[];
578
602
  attributesByName: Record<string, Attribute>;
579
603
  html5DataAnnotations?: Record<string, string>;
580
604
  };
@@ -673,31 +697,31 @@ export type Attribute = {
673
697
  | "photo";
674
698
  };
675
699
 
676
- export type Validators = Partial<{
677
- length: Validators.DoIgnoreEmpty & Validators.Range;
678
- integer: Validators.DoIgnoreEmpty & Validators.Range;
679
- email: Validators.DoIgnoreEmpty;
680
- pattern: Validators.DoIgnoreEmpty & Validators.ErrorMessage & { pattern: string };
681
- options: Validators.Options;
682
- multivalued: Validators.DoIgnoreEmpty & Validators.Range;
700
+ export type Validators = {
701
+ length?: Validators.DoIgnoreEmpty & Validators.Range;
702
+ integer?: Validators.DoIgnoreEmpty & Validators.Range;
703
+ email?: Validators.DoIgnoreEmpty;
704
+ pattern?: Validators.DoIgnoreEmpty & Validators.ErrorMessage & { pattern: string };
705
+ options?: Validators.Options;
706
+ multivalued?: Validators.DoIgnoreEmpty & Validators.Range;
683
707
  // NOTE: Following are the validators for which we don't implement client side validation yet
684
708
  // or for which the validation can't be performed on the client side.
685
709
  /*
686
- double: Validators.DoIgnoreEmpty & Validators.Range;
687
- "up-immutable-attribute": {};
688
- "up-attribute-required-by-metadata-value": {};
689
- "up-username-has-value": {};
690
- "up-duplicate-username": {};
691
- "up-username-mutation": {};
692
- "up-email-exists-as-username": {};
693
- "up-blank-attribute-value": Validators.ErrorMessage & { "fail-on-null": boolean; };
694
- "up-duplicate-email": {};
695
- "local-date": Validators.DoIgnoreEmpty;
696
- "person-name-prohibited-characters": Validators.DoIgnoreEmpty & Validators.ErrorMessage;
697
- uri: Validators.DoIgnoreEmpty;
698
- "username-prohibited-characters": Validators.DoIgnoreEmpty & Validators.ErrorMessage;
710
+ double?: Validators.DoIgnoreEmpty & Validators.Range;
711
+ "up-immutable-attribute"?: {};
712
+ "up-attribute-required-by-metadata-value"?: {};
713
+ "up-username-has-value"?: {};
714
+ "up-duplicate-username"?: {};
715
+ "up-username-mutation"?: {};
716
+ "up-email-exists-as-username"?: {};
717
+ "up-blank-attribute-value"?: Validators.ErrorMessage & { "fail-on-null": boolean; };
718
+ "up-duplicate-email"?: {};
719
+ "local-date"?: Validators.DoIgnoreEmpty;
720
+ "person-name-prohibited-characters"?: Validators.DoIgnoreEmpty & Validators.ErrorMessage;
721
+ uri?: Validators.DoIgnoreEmpty;
722
+ "username-prohibited-characters"?: Validators.DoIgnoreEmpty & Validators.ErrorMessage;
699
723
  */
700
- }>;
724
+ };
701
725
 
702
726
  export declare namespace Validators {
703
727
  export type DoIgnoreEmpty = {
@@ -728,6 +752,10 @@ export declare namespace Validators {
728
752
  assert<Equals<OnlyInExpected, never>>();
729
753
  }
730
754
 
755
+ /**
756
+ * Theses values are added by: https://github.com/jcputney/keycloak-theme-additional-info-extension
757
+ * A Keycloak Java extension used as dependency in Keycloakify.
758
+ */
731
759
  export type PasswordPolicies = {
732
760
  /** The minimum length of the password */
733
761
  length?: number;
@@ -744,3 +772,11 @@ export type PasswordPolicies = {
744
772
  /** Whether the password can be the email address */
745
773
  notEmail?: boolean;
746
774
  };
775
+
776
+ assert<
777
+ KcContext.Common extends Partial<
778
+ Record<typeof nameOfTheLocalizationRealmOverridesUserProfileProperty, unknown>
779
+ >
780
+ ? true
781
+ : false
782
+ >();
@@ -0,0 +1,69 @@
1
+ import type { ExtendKcContext, KcContext as KcContextBase } from "./KcContext";
2
+ import type { LoginThemePageId } from "keycloakify/bin/shared/constants";
3
+ import type { DeepPartial } from "keycloakify/tools/DeepPartial";
4
+ import { deepAssign } from "keycloakify/tools/deepAssign";
5
+ import { structuredCloneButFunctions } from "keycloakify/tools/structuredCloneButFunctions";
6
+ import { kcContextMocks, kcContextCommonMock } from "./kcContextMocks";
7
+ import { exclude } from "tsafe/exclude";
8
+
9
+ export function createGetKcContextMock<
10
+ KcContextExtension extends { properties?: Record<string, string | undefined> },
11
+ KcContextExtensionPerPage extends Record<`${string}.ftl`, Record<string, unknown>>
12
+ >(params: {
13
+ kcContextExtension: KcContextExtension;
14
+ kcContextExtensionPerPage: KcContextExtensionPerPage;
15
+ overrides?: DeepPartial<KcContextExtension & KcContextBase.Common>;
16
+ overridesPerPage?: {
17
+ [PageId in LoginThemePageId | keyof KcContextExtensionPerPage]?: DeepPartial<
18
+ Extract<
19
+ ExtendKcContext<KcContextExtension, KcContextExtensionPerPage>,
20
+ { pageId: PageId }
21
+ >
22
+ >;
23
+ };
24
+ }) {
25
+ const {
26
+ kcContextExtension,
27
+ kcContextExtensionPerPage,
28
+ overrides: overrides_global,
29
+ overridesPerPage: overridesPerPage_global
30
+ } = params;
31
+
32
+ type KcContext = ExtendKcContext<KcContextExtension, KcContextExtensionPerPage>;
33
+
34
+ function getKcContextMock<
35
+ PageId extends LoginThemePageId | keyof KcContextExtensionPerPage
36
+ >(params: {
37
+ pageId: PageId;
38
+ overrides?: DeepPartial<Extract<KcContext, { pageId: PageId }>>;
39
+ }): Extract<KcContext, { pageId: PageId }> {
40
+ const { pageId, overrides } = params;
41
+
42
+ const kcContextMock = structuredCloneButFunctions(
43
+ kcContextMocks.find(kcContextMock => kcContextMock.pageId === pageId) ?? {
44
+ ...kcContextCommonMock,
45
+ pageId
46
+ }
47
+ );
48
+
49
+ [
50
+ kcContextExtension,
51
+ kcContextExtensionPerPage[pageId],
52
+ overrides_global,
53
+ overridesPerPage_global?.[pageId],
54
+ overrides
55
+ ]
56
+ .filter(exclude(undefined))
57
+ .forEach(overrides =>
58
+ deepAssign({
59
+ target: kcContextMock,
60
+ source: overrides
61
+ })
62
+ );
63
+
64
+ // @ts-expect-error
65
+ return kcContextMock;
66
+ }
67
+
68
+ return { getKcContextMock };
69
+ }
@@ -0,0 +1,8 @@
1
+ export type {
2
+ ExtendKcContext,
3
+ KcContext,
4
+ Attribute,
5
+ PasswordPolicies,
6
+ Validators
7
+ } from "./KcContext";
8
+ export { createGetKcContextMock } from "./getKcContextMock";