@keycloakify/angular 0.0.1-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 (396) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +1 -0
  3. package/lib/i18n.d.ts +4 -0
  4. package/lib/i18n.js +6 -0
  5. package/lib/i18n.js.map +1 -0
  6. package/lib/models/index.d.ts +1 -0
  7. package/lib/models/index.js +2 -0
  8. package/lib/models/index.js.map +1 -0
  9. package/lib/models/script.model.d.ts +6 -0
  10. package/lib/models/script.model.js +2 -0
  11. package/lib/models/script.model.js.map +1 -0
  12. package/lib/providers/keycloakify-angular.providers.d.ts +150 -0
  13. package/lib/providers/keycloakify-angular.providers.js +58 -0
  14. package/lib/providers/keycloakify-angular.providers.js.map +1 -0
  15. package/lib/public-api.d.ts +10 -0
  16. package/lib/public-api.js +4 -0
  17. package/lib/public-api.js.map +1 -0
  18. package/lib/services/i18n.service.d.ts +3 -0
  19. package/lib/services/i18n.service.js +14 -0
  20. package/lib/services/i18n.service.js.map +1 -0
  21. package/lib/services/index.d.ts +2 -0
  22. package/lib/services/index.js +3 -0
  23. package/lib/services/index.js.map +1 -0
  24. package/lib/services/resource-injector.service.d.ts +7 -0
  25. package/lib/services/resource-injector.service.js +57 -0
  26. package/lib/services/resource-injector.service.js.map +1 -0
  27. package/login/DefaultPage.d.ts +260 -0
  28. package/login/DefaultPage.js +121 -0
  29. package/login/DefaultPage.js.map +1 -0
  30. package/login/KcContext.d.ts +1 -0
  31. package/login/KcContext.js +2 -0
  32. package/login/KcContext.js.map +1 -0
  33. package/login/classes/component-reference.class.d.ts +5 -0
  34. package/login/classes/component-reference.class.js +3 -0
  35. package/login/classes/component-reference.class.js.map +1 -0
  36. package/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.d.ts +13 -0
  37. package/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.html +24 -0
  38. package/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.js +123 -0
  39. package/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.js.map +1 -0
  40. package/login/components/field-errors/field-errors.component.d.ts +11 -0
  41. package/login/components/field-errors/field-errors.component.html +15 -0
  42. package/login/components/field-errors/field-errors.component.js +45 -0
  43. package/login/components/field-errors/field-errors.component.js.map +1 -0
  44. package/login/components/group-label/group-label.component.d.ts +10 -0
  45. package/login/components/group-label/group-label.component.html +30 -0
  46. package/login/components/group-label/group-label.component.js +55 -0
  47. package/login/components/group-label/group-label.component.js.map +1 -0
  48. package/login/components/index.d.ts +11 -0
  49. package/login/components/index.js +12 -0
  50. package/login/components/index.js.map +1 -0
  51. package/login/components/input-field-by-type/input-field-by-type.component.d.ts +13 -0
  52. package/login/components/input-field-by-type/input-field-by-type.component.html +63 -0
  53. package/login/components/input-field-by-type/input-field-by-type.component.js +63 -0
  54. package/login/components/input-field-by-type/input-field-by-type.component.js.map +1 -0
  55. package/login/components/input-tag/input-tag.component.d.ts +17 -0
  56. package/login/components/input-tag/input-tag.component.html +49 -0
  57. package/login/components/input-tag/input-tag.component.js +107 -0
  58. package/login/components/input-tag/input-tag.component.js.map +1 -0
  59. package/login/components/input-tag-selects/input-tag-selects.component.d.ts +23 -0
  60. package/login/components/input-tag-selects/input-tag-selects.component.html +29 -0
  61. package/login/components/input-tag-selects/input-tag-selects.component.js +132 -0
  62. package/login/components/input-tag-selects/input-tag-selects.component.js.map +1 -0
  63. package/login/components/logout-other-sessions/logout-other-sessions.component.d.ts +6 -0
  64. package/login/components/logout-other-sessions/logout-other-sessions.component.html +19 -0
  65. package/login/components/logout-other-sessions/logout-other-sessions.component.js +43 -0
  66. package/login/components/logout-other-sessions/logout-other-sessions.component.js.map +1 -0
  67. package/login/components/password-wrapper/password-wrapper.component.d.ts +12 -0
  68. package/login/components/password-wrapper/password-wrapper.component.html +15 -0
  69. package/login/components/password-wrapper/password-wrapper.component.js +57 -0
  70. package/login/components/password-wrapper/password-wrapper.component.js.map +1 -0
  71. package/login/components/select-tag/select-tag.component.d.ts +16 -0
  72. package/login/components/select-tag/select-tag.component.html +31 -0
  73. package/login/components/select-tag/select-tag.component.js +97 -0
  74. package/login/components/select-tag/select-tag.component.js.map +1 -0
  75. package/login/components/textarea-tag/textarea-tag.component.d.ts +14 -0
  76. package/login/components/textarea-tag/textarea-tag.component.html +18 -0
  77. package/login/components/textarea-tag/textarea-tag.component.js +63 -0
  78. package/login/components/textarea-tag/textarea-tag.component.js.map +1 -0
  79. package/login/components/user-profile-form-fields/user-profile-form-fields.component.d.ts +25 -0
  80. package/login/components/user-profile-form-fields/user-profile-form-fields.component.html +85 -0
  81. package/login/components/user-profile-form-fields/user-profile-form-fields.component.js +74 -0
  82. package/login/components/user-profile-form-fields/user-profile-form-fields.component.js.map +1 -0
  83. package/login/containers/template.component.d.ts +28 -0
  84. package/login/containers/template.component.html +203 -0
  85. package/login/containers/template.component.js +78 -0
  86. package/login/containers/template.component.js.map +1 -0
  87. package/login/directives/attributes.directive.d.ts +5 -0
  88. package/login/directives/attributes.directive.js +34 -0
  89. package/login/directives/attributes.directive.js.map +1 -0
  90. package/login/directives/index.d.ts +2 -0
  91. package/login/directives/index.js +3 -0
  92. package/login/directives/index.js.map +1 -0
  93. package/login/directives/kc-class.directive.d.ts +23 -0
  94. package/login/directives/kc-class.directive.js +146 -0
  95. package/login/directives/kc-class.directive.js.map +1 -0
  96. package/login/i18n.d.ts +4 -0
  97. package/login/i18n.js +2 -0
  98. package/login/i18n.js.map +1 -0
  99. package/login/pages/code/code.component.d.ts +8 -0
  100. package/login/pages/code/code.component.html +26 -0
  101. package/login/pages/code/code.component.js +38 -0
  102. package/login/pages/code/code.component.js.map +1 -0
  103. package/login/pages/delete-account-confirm/delete-account-confirm.component.d.ts +8 -0
  104. package/login/pages/delete-account-confirm/delete-account-confirm.component.html +46 -0
  105. package/login/pages/delete-account-confirm/delete-account-confirm.component.js +38 -0
  106. package/login/pages/delete-account-confirm/delete-account-confirm.component.js.map +1 -0
  107. package/login/pages/delete-credential/delete-credential.component.d.ts +13 -0
  108. package/login/pages/delete-credential/delete-credential.component.html +35 -0
  109. package/login/pages/delete-credential/delete-credential.component.js +43 -0
  110. package/login/pages/delete-credential/delete-credential.component.js.map +1 -0
  111. package/login/pages/error/error.component.d.ts +8 -0
  112. package/login/pages/error/error.component.html +25 -0
  113. package/login/pages/error/error.component.js +38 -0
  114. package/login/pages/error/error.component.js.map +1 -0
  115. package/login/pages/frontchannel-logout/frontchannel-logout.component.d.ts +14 -0
  116. package/login/pages/frontchannel-logout/frontchannel-logout.component.html +35 -0
  117. package/login/pages/frontchannel-logout/frontchannel-logout.component.js +47 -0
  118. package/login/pages/frontchannel-logout/frontchannel-logout.component.js.map +1 -0
  119. package/login/pages/idp-review-user-profile/idp-review-user-profile.component.d.ts +15 -0
  120. package/login/pages/idp-review-user-profile/idp-review-user-profile.component.html +41 -0
  121. package/login/pages/idp-review-user-profile/idp-review-user-profile.component.js +54 -0
  122. package/login/pages/idp-review-user-profile/idp-review-user-profile.component.js.map +1 -0
  123. package/login/pages/info/info.component.d.ts +20 -0
  124. package/login/pages/info/info.component.html +54 -0
  125. package/login/pages/info/info.component.js +61 -0
  126. package/login/pages/info/info.component.js.map +1 -0
  127. package/login/pages/login/login.component.d.ts +14 -0
  128. package/login/pages/login/login.component.html +212 -0
  129. package/login/pages/login/login.component.js +58 -0
  130. package/login/pages/login/login.component.js.map +1 -0
  131. package/login/pages/login-config-totp/login-config-totp.component.d.ts +13 -0
  132. package/login/pages/login-config-totp/login-config-totp.component.html +190 -0
  133. package/login/pages/login-config-totp/login-config-totp.component.js +53 -0
  134. package/login/pages/login-config-totp/login-config-totp.component.js.map +1 -0
  135. package/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.d.ts +13 -0
  136. package/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.html +41 -0
  137. package/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.js +43 -0
  138. package/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.js.map +1 -0
  139. package/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.d.ts +13 -0
  140. package/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.html +40 -0
  141. package/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.js +43 -0
  142. package/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.js.map +1 -0
  143. package/login/pages/login-idp-link-email/login-idp-link-email.component.d.ts +13 -0
  144. package/login/pages/login-idp-link-email/login-idp-link-email.component.html +37 -0
  145. package/login/pages/login-idp-link-email/login-idp-link-email.component.js +43 -0
  146. package/login/pages/login-idp-link-email/login-idp-link-email.component.js.map +1 -0
  147. package/login/pages/login-oauth-grant/login-oauth-grant.component.d.ts +13 -0
  148. package/login/pages/login-oauth-grant/login-oauth-grant.component.html +92 -0
  149. package/login/pages/login-oauth-grant/login-oauth-grant.component.js +44 -0
  150. package/login/pages/login-oauth-grant/login-oauth-grant.component.js.map +1 -0
  151. package/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.d.ts +13 -0
  152. package/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.html +63 -0
  153. package/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.js +43 -0
  154. package/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.js.map +1 -0
  155. package/login/pages/login-otp/login-otp.component.d.ts +13 -0
  156. package/login/pages/login-otp/login-otp.component.html +103 -0
  157. package/login/pages/login-otp/login-otp.component.js +44 -0
  158. package/login/pages/login-otp/login-otp.component.js.map +1 -0
  159. package/login/pages/login-page-expired/login-page-expired.component.d.ts +13 -0
  160. package/login/pages/login-page-expired/login-page-expired.component.html +35 -0
  161. package/login/pages/login-page-expired/login-page-expired.component.js +42 -0
  162. package/login/pages/login-page-expired/login-page-expired.component.js.map +1 -0
  163. package/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.d.ts +16 -0
  164. package/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.html +203 -0
  165. package/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.js +91 -0
  166. package/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.js.map +1 -0
  167. package/login/pages/login-password/login-password.component.d.ts +14 -0
  168. package/login/pages/login-password/login-password.component.html +90 -0
  169. package/login/pages/login-password/login-password.component.js +52 -0
  170. package/login/pages/login-password/login-password.component.js.map +1 -0
  171. package/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.d.ts +15 -0
  172. package/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.html +155 -0
  173. package/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.js +51 -0
  174. package/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.js.map +1 -0
  175. package/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.d.ts +13 -0
  176. package/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.html +76 -0
  177. package/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.js +44 -0
  178. package/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.js.map +1 -0
  179. package/login/pages/login-reset-otp/login-reset-otp.component.d.ts +13 -0
  180. package/login/pages/login-reset-otp/login-reset-otp.component.html +65 -0
  181. package/login/pages/login-reset-otp/login-reset-otp.component.js +43 -0
  182. package/login/pages/login-reset-otp/login-reset-otp.component.js.map +1 -0
  183. package/login/pages/login-reset-password/login-reset-password.component.d.ts +13 -0
  184. package/login/pages/login-reset-password/login-reset-password.component.html +95 -0
  185. package/login/pages/login-reset-password/login-reset-password.component.js +44 -0
  186. package/login/pages/login-reset-password/login-reset-password.component.js.map +1 -0
  187. package/login/pages/login-update-password/login-update-password.component.d.ts +13 -0
  188. package/login/pages/login-update-password/login-update-password.component.html +116 -0
  189. package/login/pages/login-update-password/login-update-password.component.js +53 -0
  190. package/login/pages/login-update-password/login-update-password.component.js.map +1 -0
  191. package/login/pages/login-update-profile/login-update-profile.component.d.ts +14 -0
  192. package/login/pages/login-update-profile/login-update-profile.component.html +59 -0
  193. package/login/pages/login-update-profile/login-update-profile.component.js +50 -0
  194. package/login/pages/login-update-profile/login-update-profile.component.js.map +1 -0
  195. package/login/pages/login-username/login-username.component.d.ts +14 -0
  196. package/login/pages/login-username/login-username.component.html +161 -0
  197. package/login/pages/login-username/login-username.component.js +56 -0
  198. package/login/pages/login-username/login-username.component.js.map +1 -0
  199. package/login/pages/login-verify-email/login-verify-email.component.d.ts +13 -0
  200. package/login/pages/login-verify-email/login-verify-email.component.html +27 -0
  201. package/login/pages/login-verify-email/login-verify-email.component.js +43 -0
  202. package/login/pages/login-verify-email/login-verify-email.component.js.map +1 -0
  203. package/login/pages/login-x509-info/login-x509-info.component.d.ts +13 -0
  204. package/login/pages/login-x509-info/login-x509-info.component.html +102 -0
  205. package/login/pages/login-x509-info/login-x509-info.component.js +43 -0
  206. package/login/pages/login-x509-info/login-x509-info.component.js.map +1 -0
  207. package/login/pages/logout-confirm/logout-confirm.component.d.ts +13 -0
  208. package/login/pages/logout-confirm/logout-confirm.component.html +59 -0
  209. package/login/pages/logout-confirm/logout-confirm.component.js +43 -0
  210. package/login/pages/logout-confirm/logout-confirm.component.js.map +1 -0
  211. package/login/pages/register/register.component.d.ts +16 -0
  212. package/login/pages/register/register.component.html +126 -0
  213. package/login/pages/register/register.component.js +62 -0
  214. package/login/pages/register/register.component.js.map +1 -0
  215. package/login/pages/saml-post-form/saml-post-form.component.d.ts +16 -0
  216. package/login/pages/saml-post-form/saml-post-form.component.html +51 -0
  217. package/login/pages/saml-post-form/saml-post-form.component.js +55 -0
  218. package/login/pages/saml-post-form/saml-post-form.component.js.map +1 -0
  219. package/login/pages/select-authenticator/select-authenticator.component.d.ts +13 -0
  220. package/login/pages/select-authenticator/select-authenticator.component.html +49 -0
  221. package/login/pages/select-authenticator/select-authenticator.component.js +51 -0
  222. package/login/pages/select-authenticator/select-authenticator.component.js.map +1 -0
  223. package/login/pages/terms/terms.component.d.ts +13 -0
  224. package/login/pages/terms/terms.component.html +36 -0
  225. package/login/pages/terms/terms.component.js +43 -0
  226. package/login/pages/terms/terms.component.js.map +1 -0
  227. package/login/pages/update-email/update-email.component.d.ts +14 -0
  228. package/login/pages/update-email/update-email.component.html +58 -0
  229. package/login/pages/update-email/update-email.component.js +52 -0
  230. package/login/pages/update-email/update-email.component.js.map +1 -0
  231. package/login/pages/webauthn-authenticate/webauthn-authenticate.component.d.ts +20 -0
  232. package/login/pages/webauthn-authenticate/webauthn-authenticate.component.html +162 -0
  233. package/login/pages/webauthn-authenticate/webauthn-authenticate.component.js +93 -0
  234. package/login/pages/webauthn-authenticate/webauthn-authenticate.component.js.map +1 -0
  235. package/login/pages/webauthn-error/webauthn-error.component.d.ts +14 -0
  236. package/login/pages/webauthn-error/webauthn-error.component.html +60 -0
  237. package/login/pages/webauthn-error/webauthn-error.component.js +57 -0
  238. package/login/pages/webauthn-error/webauthn-error.component.js.map +1 -0
  239. package/login/pages/webauthn-register/webauthn-register.component.d.ts +19 -0
  240. package/login/pages/webauthn-register/webauthn-register.component.html +82 -0
  241. package/login/pages/webauthn-register/webauthn-register.component.js +86 -0
  242. package/login/pages/webauthn-register/webauthn-register.component.js.map +1 -0
  243. package/login/pipes/advanced-msg-str.pipe.d.ts +5 -0
  244. package/login/pipes/advanced-msg-str.pipe.js +31 -0
  245. package/login/pipes/advanced-msg-str.pipe.js.map +1 -0
  246. package/login/pipes/index.d.ts +6 -0
  247. package/login/pipes/index.js +7 -0
  248. package/login/pipes/index.js.map +1 -0
  249. package/login/pipes/input-type.pipe.d.ts +4 -0
  250. package/login/pipes/input-type.pipe.js +23 -0
  251. package/login/pipes/input-type.pipe.js.map +1 -0
  252. package/login/pipes/kc-sanitize.pipe.d.ts +7 -0
  253. package/login/pipes/kc-sanitize.pipe.js +36 -0
  254. package/login/pipes/kc-sanitize.pipe.js.map +1 -0
  255. package/login/pipes/msg-str.pipe.d.ts +6 -0
  256. package/login/pipes/msg-str.pipe.js +31 -0
  257. package/login/pipes/msg-str.pipe.js.map +1 -0
  258. package/login/pipes/to-array.pipe.d.ts +4 -0
  259. package/login/pipes/to-array.pipe.js +24 -0
  260. package/login/pipes/to-array.pipe.js.map +1 -0
  261. package/login/pipes/to-number.pipe.d.ts +4 -0
  262. package/login/pipes/to-number.pipe.js +23 -0
  263. package/login/pipes/to-number.pipe.js.map +1 -0
  264. package/login/services/index.d.ts +2 -0
  265. package/login/services/index.js +3 -0
  266. package/login/services/index.js.map +1 -0
  267. package/login/services/login-resource-injector.service.d.ts +8 -0
  268. package/login/services/login-resource-injector.service.js +71 -0
  269. package/login/services/login-resource-injector.service.js.map +1 -0
  270. package/login/services/user-profile-form.service.d.ts +82 -0
  271. package/login/services/user-profile-form.service.js +1031 -0
  272. package/login/services/user-profile-form.service.js.map +1 -0
  273. package/package.json +450 -0
  274. package/src/lib/i18n.ts +9 -0
  275. package/src/lib/models/index.ts +1 -0
  276. package/src/lib/models/script.model.ts +6 -0
  277. package/src/lib/providers/keycloakify-angular.providers.ts +92 -0
  278. package/src/lib/public-api.ts +12 -0
  279. package/src/lib/services/i18n.service.ts +5 -0
  280. package/src/lib/services/index.ts +2 -0
  281. package/src/lib/services/resource-injector.service.ts +50 -0
  282. package/src/login/DefaultPage.ts +208 -0
  283. package/src/login/KcContext.ts +1 -0
  284. package/src/login/classes/component-reference.class.ts +5 -0
  285. package/src/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.html +24 -0
  286. package/src/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.ts +144 -0
  287. package/src/login/components/field-errors/field-errors.component.html +15 -0
  288. package/src/login/components/field-errors/field-errors.component.ts +41 -0
  289. package/src/login/components/group-label/group-label.component.html +30 -0
  290. package/src/login/components/group-label/group-label.component.ts +50 -0
  291. package/src/login/components/index.ts +11 -0
  292. package/src/login/components/input-field-by-type/input-field-by-type.component.html +63 -0
  293. package/src/login/components/input-field-by-type/input-field-by-type.component.ts +67 -0
  294. package/src/login/components/input-tag/input-tag.component.html +49 -0
  295. package/src/login/components/input-tag/input-tag.component.ts +108 -0
  296. package/src/login/components/input-tag-selects/input-tag-selects.component.html +29 -0
  297. package/src/login/components/input-tag-selects/input-tag-selects.component.ts +150 -0
  298. package/src/login/components/logout-other-sessions/logout-other-sessions.component.html +19 -0
  299. package/src/login/components/logout-other-sessions/logout-other-sessions.component.ts +31 -0
  300. package/src/login/components/password-wrapper/password-wrapper.component.html +15 -0
  301. package/src/login/components/password-wrapper/password-wrapper.component.ts +61 -0
  302. package/src/login/components/select-tag/select-tag.component.html +31 -0
  303. package/src/login/components/select-tag/select-tag.component.ts +109 -0
  304. package/src/login/components/textarea-tag/textarea-tag.component.html +18 -0
  305. package/src/login/components/textarea-tag/textarea-tag.component.ts +63 -0
  306. package/src/login/components/user-profile-form-fields/user-profile-form-fields.component.html +85 -0
  307. package/src/login/components/user-profile-form-fields/user-profile-form-fields.component.ts +84 -0
  308. package/src/login/containers/template.component.html +203 -0
  309. package/src/login/containers/template.component.ts +94 -0
  310. package/src/login/directives/attributes.directive.ts +23 -0
  311. package/src/login/directives/index.ts +2 -0
  312. package/src/login/directives/kc-class.directive.ts +167 -0
  313. package/src/login/i18n.ts +4 -0
  314. package/src/login/pages/code/code.component.html +26 -0
  315. package/src/login/pages/code/code.component.ts +31 -0
  316. package/src/login/pages/delete-account-confirm/delete-account-confirm.component.html +46 -0
  317. package/src/login/pages/delete-account-confirm/delete-account-confirm.component.ts +32 -0
  318. package/src/login/pages/delete-credential/delete-credential.component.html +35 -0
  319. package/src/login/pages/delete-credential/delete-credential.component.ts +43 -0
  320. package/src/login/pages/error/error.component.html +25 -0
  321. package/src/login/pages/error/error.component.ts +31 -0
  322. package/src/login/pages/frontchannel-logout/frontchannel-logout.component.html +35 -0
  323. package/src/login/pages/frontchannel-logout/frontchannel-logout.component.ts +49 -0
  324. package/src/login/pages/idp-review-user-profile/idp-review-user-profile.component.html +41 -0
  325. package/src/login/pages/idp-review-user-profile/idp-review-user-profile.component.ts +55 -0
  326. package/src/login/pages/info/info.component.html +54 -0
  327. package/src/login/pages/info/info.component.ts +65 -0
  328. package/src/login/pages/login/login.component.html +212 -0
  329. package/src/login/pages/login/login.component.ts +61 -0
  330. package/src/login/pages/login-config-totp/login-config-totp.component.html +190 -0
  331. package/src/login/pages/login-config-totp/login-config-totp.component.ts +57 -0
  332. package/src/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.html +41 -0
  333. package/src/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.ts +43 -0
  334. package/src/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.html +40 -0
  335. package/src/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.ts +45 -0
  336. package/src/login/pages/login-idp-link-email/login-idp-link-email.component.html +37 -0
  337. package/src/login/pages/login-idp-link-email/login-idp-link-email.component.ts +43 -0
  338. package/src/login/pages/login-oauth-grant/login-oauth-grant.component.html +92 -0
  339. package/src/login/pages/login-oauth-grant/login-oauth-grant.component.ts +44 -0
  340. package/src/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.html +63 -0
  341. package/src/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.ts +45 -0
  342. package/src/login/pages/login-otp/login-otp.component.html +103 -0
  343. package/src/login/pages/login-otp/login-otp.component.ts +43 -0
  344. package/src/login/pages/login-page-expired/login-page-expired.component.html +35 -0
  345. package/src/login/pages/login-page-expired/login-page-expired.component.ts +42 -0
  346. package/src/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.html +203 -0
  347. package/src/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.ts +101 -0
  348. package/src/login/pages/login-password/login-password.component.html +90 -0
  349. package/src/login/pages/login-password/login-password.component.ts +53 -0
  350. package/src/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.html +155 -0
  351. package/src/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.ts +55 -0
  352. package/src/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.html +76 -0
  353. package/src/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.ts +47 -0
  354. package/src/login/pages/login-reset-otp/login-reset-otp.component.html +65 -0
  355. package/src/login/pages/login-reset-otp/login-reset-otp.component.ts +42 -0
  356. package/src/login/pages/login-reset-password/login-reset-password.component.html +95 -0
  357. package/src/login/pages/login-reset-password/login-reset-password.component.ts +44 -0
  358. package/src/login/pages/login-update-password/login-update-password.component.html +116 -0
  359. package/src/login/pages/login-update-password/login-update-password.component.ts +56 -0
  360. package/src/login/pages/login-update-profile/login-update-profile.component.html +59 -0
  361. package/src/login/pages/login-update-profile/login-update-profile.component.ts +52 -0
  362. package/src/login/pages/login-username/login-username.component.html +161 -0
  363. package/src/login/pages/login-username/login-username.component.ts +56 -0
  364. package/src/login/pages/login-verify-email/login-verify-email.component.html +27 -0
  365. package/src/login/pages/login-verify-email/login-verify-email.component.ts +43 -0
  366. package/src/login/pages/login-x509-info/login-x509-info.component.html +102 -0
  367. package/src/login/pages/login-x509-info/login-x509-info.component.ts +42 -0
  368. package/src/login/pages/logout-confirm/logout-confirm.component.html +59 -0
  369. package/src/login/pages/logout-confirm/logout-confirm.component.ts +42 -0
  370. package/src/login/pages/register/register.component.html +126 -0
  371. package/src/login/pages/register/register.component.ts +62 -0
  372. package/src/login/pages/saml-post-form/saml-post-form.component.html +51 -0
  373. package/src/login/pages/saml-post-form/saml-post-form.component.ts +58 -0
  374. package/src/login/pages/select-authenticator/select-authenticator.component.html +49 -0
  375. package/src/login/pages/select-authenticator/select-authenticator.component.ts +51 -0
  376. package/src/login/pages/terms/terms.component.html +36 -0
  377. package/src/login/pages/terms/terms.component.ts +42 -0
  378. package/src/login/pages/update-email/update-email.component.html +58 -0
  379. package/src/login/pages/update-email/update-email.component.ts +52 -0
  380. package/src/login/pages/webauthn-authenticate/webauthn-authenticate.component.html +162 -0
  381. package/src/login/pages/webauthn-authenticate/webauthn-authenticate.component.ts +106 -0
  382. package/src/login/pages/webauthn-error/webauthn-error.component.html +60 -0
  383. package/src/login/pages/webauthn-error/webauthn-error.component.ts +57 -0
  384. package/src/login/pages/webauthn-register/webauthn-register.component.html +82 -0
  385. package/src/login/pages/webauthn-register/webauthn-register.component.ts +106 -0
  386. package/src/login/pipes/advanced-msg-str.pipe.ts +13 -0
  387. package/src/login/pipes/index.ts +6 -0
  388. package/src/login/pipes/input-type.pipe.ts +15 -0
  389. package/src/login/pipes/kc-sanitize.pipe.ts +36 -0
  390. package/src/login/pipes/msg-str.pipe.ts +14 -0
  391. package/src/login/pipes/to-array.pipe.ts +15 -0
  392. package/src/login/pipes/to-number.pipe.ts +13 -0
  393. package/src/login/services/index.ts +2 -0
  394. package/src/login/services/login-resource-injector.service.ts +72 -0
  395. package/src/login/services/user-profile-form.service.ts +1504 -0
  396. package/src/tsconfig.json +18 -0
@@ -0,0 +1,31 @@
1
+ @let attr = attribute();
2
+ @let multiple = isMultiple();
3
+ @if (attr) {
4
+ <select
5
+ [id]="attr.name"
6
+ [name]="attr.name"
7
+ [value]="valueOrValues()"
8
+ [kcClass]="'kcInputClass'"
9
+ [attr.aria-invalid]="!!displayableErrors()?.length"
10
+ [disabled]="attr.readOnly"
11
+ [multiple]="multiple"
12
+ [size]="!attr.annotations.inputTypeSize ? undefined : (attr.annotations.inputTypeSize | toNumber)"
13
+ (change)="onChange($event)"
14
+ (blur)="onBlur()"
15
+ >
16
+ @if (!multiple) {
17
+ <option value=""></option>
18
+ }
19
+ @for (option of options(); track option) {
20
+ <option [value]="option">
21
+ @if (!!attr.annotations.inputOptionLabels) {
22
+ {{ attr.annotations.inputOptionLabels[option] ?? option | advancedMsgStr }}
23
+ } @else if (!!attr.annotations.inputOptionLabelsI18nPrefix) {
24
+ {{ attr.annotations.inputOptionLabelsI18nPrefix + '.' + option | advancedMsgStr }}
25
+ } @else {
26
+ {{ option }}
27
+ }
28
+ </option>
29
+ }
30
+ </select>
31
+ }
@@ -0,0 +1,109 @@
1
+ import {
2
+ ChangeDetectionStrategy,
3
+ Component,
4
+ computed,
5
+ forwardRef,
6
+ inject,
7
+ input,
8
+ output
9
+ } from "@angular/core";
10
+ import { CLASSES, USE_DEFAULT_CSS } from "@keycloakify/angular/lib/public-api";
11
+ import { Attribute } from "keycloakify/login/KcContext";
12
+ import { ClassKey } from "keycloakify/login/lib/kcClsx";
13
+ import { ComponentReference } from "@keycloakify/angular/login/classes/component-reference.class";
14
+ import { KcClassDirective } from "@keycloakify/angular/login/directives/kc-class.directive";
15
+ import { AdvancedMsgStrPipe } from "@keycloakify/angular/login/pipes/advanced-msg-str.pipe";
16
+ import { ToNumberPipe } from "@keycloakify/angular/login/pipes/to-number.pipe";
17
+ import {
18
+ FormAction,
19
+ FormFieldError
20
+ } from "@keycloakify/angular/login/services/user-profile-form.service";
21
+
22
+ @Component({
23
+ standalone: true,
24
+ styles: [
25
+ `
26
+ :host {
27
+ display: contents;
28
+ }
29
+ `
30
+ ],
31
+ imports: [KcClassDirective, ToNumberPipe, AdvancedMsgStrPipe],
32
+ selector: "kc-select-tag",
33
+ templateUrl: "select-tag.component.html",
34
+ changeDetection: ChangeDetectionStrategy.OnPush,
35
+ providers: [
36
+ {
37
+ provide: ComponentReference,
38
+ useExisting: forwardRef(() => SelectTagComponent)
39
+ }
40
+ ]
41
+ })
42
+ export class SelectTagComponent extends ComponentReference {
43
+ attribute = input<Attribute>();
44
+ valueOrValues = input<string | string[]>();
45
+ displayableErrors = input<FormFieldError[]>();
46
+ dispatchFormAction = output<FormAction>();
47
+ override doUseDefaultCss = inject<boolean>(USE_DEFAULT_CSS);
48
+ override classes = inject<Partial<Record<ClassKey, string>>>(CLASSES);
49
+
50
+ isMultiple = computed(() => {
51
+ return this.attribute()?.annotations?.inputType === "multiselect";
52
+ });
53
+
54
+ options = computed(() => {
55
+ const attribute = this.attribute();
56
+ if (attribute) {
57
+ return (() => {
58
+ walk: {
59
+ const { inputOptionsFromValidation } = attribute.annotations;
60
+
61
+ if (inputOptionsFromValidation === undefined) {
62
+ break walk;
63
+ }
64
+
65
+ const validator = (
66
+ attribute.validators as Record<string, { options?: string[] }>
67
+ )[inputOptionsFromValidation];
68
+
69
+ if (validator === undefined) {
70
+ break walk;
71
+ }
72
+
73
+ if (validator.options === undefined) {
74
+ break walk;
75
+ }
76
+
77
+ return validator.options;
78
+ }
79
+
80
+ return attribute.validators.options?.options ?? [];
81
+ })();
82
+ }
83
+ return [];
84
+ });
85
+
86
+ onChange(event: Event) {
87
+ this.dispatchFormAction.emit({
88
+ action: "update",
89
+ name: this.attribute()?.name ?? "",
90
+ valueOrValues: (() => {
91
+ if (this.isMultiple()) {
92
+ return Array.from(
93
+ (event.target as HTMLSelectElement).selectedOptions
94
+ ).map(option => option.value);
95
+ }
96
+
97
+ return (event.target as HTMLSelectElement).value;
98
+ })()
99
+ });
100
+ }
101
+
102
+ onBlur() {
103
+ this.dispatchFormAction.emit({
104
+ action: "focus lost",
105
+ name: this.attribute()?.name ?? "",
106
+ fieldIndex: undefined
107
+ });
108
+ }
109
+ }
@@ -0,0 +1,18 @@
1
+ @let attr = attribute();
2
+ @if (attr) {
3
+ <textarea
4
+ [id]="attr.name"
5
+ [name]="attr.name"
6
+ [kcClass]="'kcInputClass'"
7
+ [attr.aria-invalid]="!!displayableErrors()?.length"
8
+ [disabled]="attr.readOnly"
9
+ [cols]="attr.annotations.inputTypeCols === undefined ? undefined : (attr.annotations.inputTypeCols | toNumber)"
10
+ [rows]="attr.annotations.inputTypeRows === undefined ? undefined : (attr.annotations.inputTypeRows | toNumber)"
11
+ [maxLength]="
12
+ attr.annotations.inputTypeMaxlength === undefined ? undefined : (attr.annotations.inputTypeMaxlength | toNumber)
13
+ "
14
+ [value]="value()"
15
+ (change)="onChange($event)"
16
+ (blur)="onBlur()"
17
+ ></textarea>
18
+ }
@@ -0,0 +1,63 @@
1
+ import {
2
+ ChangeDetectionStrategy,
3
+ Component,
4
+ forwardRef,
5
+ inject,
6
+ input,
7
+ output
8
+ } from "@angular/core";
9
+ import { CLASSES, USE_DEFAULT_CSS } from "@keycloakify/angular/lib/public-api";
10
+ import { Attribute } from "keycloakify/login/KcContext";
11
+ import { ClassKey } from "keycloakify/login/lib/kcClsx";
12
+ import { ComponentReference } from "@keycloakify/angular/login/classes/component-reference.class";
13
+ import { KcClassDirective } from "@keycloakify/angular/login/directives/kc-class.directive";
14
+ import { ToNumberPipe } from "@keycloakify/angular/login/pipes/to-number.pipe";
15
+ import {
16
+ FormAction,
17
+ FormFieldError
18
+ } from "@keycloakify/angular/login/services/user-profile-form.service";
19
+
20
+ @Component({
21
+ standalone: true,
22
+ styles: [
23
+ `
24
+ :host {
25
+ display: contents;
26
+ }
27
+ `
28
+ ],
29
+ imports: [KcClassDirective, ToNumberPipe],
30
+ selector: "kc-textarea-tag",
31
+ templateUrl: "textarea-tag.component.html",
32
+ changeDetection: ChangeDetectionStrategy.OnPush,
33
+ providers: [
34
+ {
35
+ provide: ComponentReference,
36
+ useExisting: forwardRef(() => TextareaTagComponent)
37
+ }
38
+ ]
39
+ })
40
+ export class TextareaTagComponent extends ComponentReference {
41
+ attribute = input<Attribute>();
42
+ value = input<string>();
43
+ displayableErrors = input<FormFieldError[]>();
44
+ dispatchFormAction = output<FormAction>();
45
+ override doUseDefaultCss = inject<boolean>(USE_DEFAULT_CSS);
46
+ override classes = inject<Partial<Record<ClassKey, string>>>(CLASSES);
47
+
48
+ onChange(event: Event) {
49
+ this.dispatchFormAction.emit({
50
+ action: "update",
51
+ name: this.attribute()?.name ?? "",
52
+ valueOrValues: (event.target as HTMLTextAreaElement).value
53
+ });
54
+ }
55
+
56
+ onBlur() {
57
+ this.dispatchFormAction.emit({
58
+ action: "focus lost",
59
+ name: this.attribute()?.name ?? "",
60
+ fieldIndex: undefined
61
+ });
62
+ }
63
+ }
@@ -0,0 +1,85 @@
1
+ @let formFieldStates = formState().formFieldStates;
2
+
3
+ @for (fieldState of formFieldStates; track fieldState.attribute) {
4
+ <!-- [groupNameRef]="groupNameRef"
5
+ TODO: verify this logic
6
+ -->
7
+ <kc-group-label [attribute]="fieldState.attribute"> </kc-group-label>
8
+
9
+ @if (beforeField) {
10
+ <ng-container
11
+ [ngTemplateOutlet]="beforeField"
12
+ [ngTemplateOutletContext]="{
13
+ attribute: fieldState.attribute,
14
+ valueOrValues: fieldState.valueOrValues,
15
+ displayableErrors: fieldState.displayableErrors,
16
+ }"
17
+ >
18
+ </ng-container>
19
+ }
20
+
21
+ <div
22
+ [kcClass]="'kcFormGroupClass'"
23
+ [style.display]="fieldState.attribute.name === 'password-confirm' && !doMakeUserConfirmPassword ? 'none' : 'block'"
24
+ >
25
+ <div [kcClass]="'kcLabelWrapperClass'">
26
+ <label
27
+ [for]="fieldState.attribute.name"
28
+ [kcClass]="'kcLabelClass'"
29
+ >
30
+ {{ fieldState.attribute.displayName ?? '' | advancedMsgStr }}
31
+ @if (fieldState.attribute.required) {
32
+ *
33
+ }
34
+ </label>
35
+ </div>
36
+
37
+ <div [kcClass]="'kcInputWrapperClass'">
38
+ @if (fieldState.attribute.annotations.inputHelperTextBefore) {
39
+ <div
40
+ [kcClass]="'kcInputHelperTextBeforeClass'"
41
+ [id]="'form-help-text-before-' + fieldState.attribute.name"
42
+ aria-live="polite"
43
+ >
44
+ {{ fieldState.attribute.annotations.inputHelperTextBefore | advancedMsgStr }}
45
+ </div>
46
+ }
47
+
48
+ <kc-input-field-by-type
49
+ [attribute]="fieldState.attribute"
50
+ [valueOrValues]="fieldState.valueOrValues"
51
+ [displayableErrors]="fieldState.displayableErrors"
52
+ (dispatchFormAction)="onDispatch($event)"
53
+ >
54
+ </kc-input-field-by-type>
55
+
56
+ <kc-field-errors
57
+ [attribute]="fieldState.attribute"
58
+ [displayableErrors]="fieldState.displayableErrors"
59
+ >
60
+ </kc-field-errors>
61
+ @if (fieldState.attribute.annotations.inputHelperTextAfter) {
62
+ <div
63
+ [kcClass]="'kcInputHelperTextAfterClass'"
64
+ [id]="'form-help-text-after-' + fieldState.attribute.name"
65
+ aria-live="polite"
66
+ >
67
+ {{ fieldState.attribute.annotations.inputHelperTextAfter | advancedMsgStr }}
68
+ </div>
69
+ }
70
+
71
+ @if (afterField) {
72
+ <ng-container
73
+ [ngTemplateOutlet]="afterField"
74
+ [ngTemplateOutletContext]="{
75
+ attribute: fieldState.attribute,
76
+ valueOrValues: fieldState.valueOrValues,
77
+ displayableErrors: fieldState.displayableErrors,
78
+ }"
79
+ >
80
+ </ng-container>
81
+ }
82
+ <!-- NOTE: Downloading of html5DataAnnotations scripts is done in the useUserProfileForm hook -->
83
+ </div>
84
+ </div>
85
+ }
@@ -0,0 +1,84 @@
1
+ import { NgTemplateOutlet } from "@angular/common";
2
+ import {
3
+ ChangeDetectionStrategy,
4
+ Component,
5
+ ContentChild,
6
+ effect,
7
+ forwardRef,
8
+ inject,
9
+ output,
10
+ TemplateRef
11
+ } from "@angular/core";
12
+ import {
13
+ DO_MAKE_USER_CONFIRM_PASSWORD,
14
+ KC_CONTEXT,
15
+ CLASSES,
16
+ USE_DEFAULT_CSS
17
+ } from "@keycloakify/angular/lib/public-api";
18
+ import { ClassKey } from "keycloakify/login/lib/kcClsx";
19
+ import { KcContext } from "keycloakify/login/KcContext";
20
+ import { ComponentReference } from "@keycloakify/angular/login/classes/component-reference.class";
21
+ import { KcClassDirective } from "@keycloakify/angular/login/directives/kc-class.directive";
22
+ import { AdvancedMsgStrPipe } from "@keycloakify/angular/login/pipes/advanced-msg-str.pipe";
23
+ import {
24
+ FormAction,
25
+ UserProfileFormService
26
+ } from "@keycloakify/angular/login/services/user-profile-form.service";
27
+ import { FieldErrorsComponent } from "@keycloakify/angular/login/components/field-errors/field-errors.component";
28
+ import { GroupLabelComponent } from "@keycloakify/angular/login/components/group-label/group-label.component";
29
+ import { InputFieldByTypeComponent } from "@keycloakify/angular/login/components/input-field-by-type/input-field-by-type.component";
30
+
31
+ @Component({
32
+ standalone: true,
33
+ styles: [
34
+ `
35
+ :host {
36
+ display: contents;
37
+ }
38
+ `
39
+ ],
40
+ imports: [
41
+ KcClassDirective,
42
+ FieldErrorsComponent,
43
+ InputFieldByTypeComponent,
44
+ GroupLabelComponent,
45
+ NgTemplateOutlet,
46
+ AdvancedMsgStrPipe
47
+ ],
48
+ selector: "kc-user-profile-form-fields",
49
+ templateUrl: "user-profile-form-fields.component.html",
50
+ changeDetection: ChangeDetectionStrategy.OnPush,
51
+ providers: [
52
+ UserProfileFormService,
53
+ {
54
+ provide: ComponentReference,
55
+ useExisting: forwardRef(() => UserProfileFormFieldsComponent)
56
+ }
57
+ ]
58
+ })
59
+ export class UserProfileFormFieldsComponent extends ComponentReference {
60
+ kcContext = inject<KcContext>(KC_CONTEXT);
61
+ userProfileFormService = inject(UserProfileFormService);
62
+ doMakeUserConfirmPassword = inject(DO_MAKE_USER_CONFIRM_PASSWORD);
63
+ override doUseDefaultCss = inject<boolean>(USE_DEFAULT_CSS);
64
+ override classes = inject<Partial<Record<ClassKey, string>>>(CLASSES);
65
+
66
+ onIsFormSubmittable = output<boolean>();
67
+
68
+ formState = this.userProfileFormService.formState;
69
+
70
+ @ContentChild("beforField") beforeField: TemplateRef<unknown> | undefined;
71
+ @ContentChild("afterField") afterField: TemplateRef<unknown> | undefined;
72
+
73
+ constructor() {
74
+ super();
75
+ effect(() => {
76
+ const isFormSubmittable = this.formState().isFormSubmittable;
77
+ this.onIsFormSubmittable.emit(isFormSubmittable);
78
+ });
79
+ }
80
+
81
+ onDispatch(formAction: FormAction) {
82
+ this.userProfileFormService.dispatchFormAction(formAction);
83
+ }
84
+ }
@@ -0,0 +1,203 @@
1
+ @let realm = kcContext.realm;
2
+ @let message = kcContext.message;
3
+ @let auth = kcContext.auth;
4
+ @let isAppInitiatedAction = kcContext.isAppInitiatedAction;
5
+ @let url = kcContext.url;
6
+ @let isReadyToRender = isReadyToRender$ | async;
7
+
8
+ @if (isReadyToRender) {
9
+ <div [kcClass]="'kcLoginClass'">
10
+ <div
11
+ id="kc-header"
12
+ [kcClass]="'kcHeaderClass'"
13
+ >
14
+ <div
15
+ id="kc-header-wrapper"
16
+ [kcClass]="'kcHeaderWrapperClass'"
17
+ >
18
+ <div [innerHTML]="realm?.displayNameHtml | kcSanitize: 'html'"></div>
19
+ </div>
20
+ </div>
21
+
22
+ <div [kcClass]="'kcFormCardClass'">
23
+ <header [kcClass]="'kcFormHeaderClass'">
24
+ <!-- Locale switcher -->
25
+ @if (i18n.enabledLanguages.length > 1) {
26
+ <div
27
+ id="kc-locale"
28
+ [kcClass]="'kcLocaleMainClass'"
29
+ >
30
+ <div
31
+ id="kc-locale-wrapper"
32
+ [kcClass]="'kcLocaleWrapperClass'"
33
+ >
34
+ <div
35
+ id="kc-locale-dropdown"
36
+ [kcClass]="'kcLocaleDropDownClass'"
37
+ class="menu-button-links"
38
+ >
39
+ <button
40
+ tabindex="1"
41
+ id="kc-current-locale-link"
42
+ [attr.aria-label]="'languages' | msgStr"
43
+ aria-haspopup="true"
44
+ aria-expanded="false"
45
+ aria-controls="language-switch1"
46
+ >
47
+ {{ i18n.currentLanguage.label }}
48
+ </button>
49
+ <ul
50
+ role="menu"
51
+ tabindex="-1"
52
+ aria-labelledby="kc-current-locale-link"
53
+ aria-activedescendant=""
54
+ id="language-switch1"
55
+ [kcClass]="'kcLocaleListClass'"
56
+ >
57
+ @for (entry of i18n.enabledLanguages; track entry; let idx = $index) {
58
+ <li
59
+ [kcClass]="'kcLocaleListItemClass'"
60
+ role="none"
61
+ >
62
+ <a
63
+ role="menuitem"
64
+ tabindex="-1"
65
+ [href]="entry.href"
66
+ [kcClass]="'kcLocaleItemClass'"
67
+ [id]="'language-' + idx"
68
+ >
69
+ {{ entry.label }}
70
+ </a>
71
+ </li>
72
+ }
73
+ </ul>
74
+ </div>
75
+ </div>
76
+ </div>
77
+ }
78
+
79
+ <!-- Header content -->
80
+ <ng-template #node>
81
+ @if (auth && !auth.showUsername && !auth.showResetCredentials) {
82
+ <h1 id="kc-page-title">
83
+ <ng-content select="[headerNode]"></ng-content>
84
+ </h1>
85
+ } @else {
86
+ <div
87
+ id="kc-username"
88
+ [kcClass]="'kcFormGroupClass'"
89
+ >
90
+ <label id="kc-attempted-username">{{ auth?.attemptedUsername }}</label>
91
+ <a
92
+ id="reset-login"
93
+ [href]="url?.loginRestartFlowUrl"
94
+ [attr.aria-label]="'restartLoginTooltip' | msgStr"
95
+ >
96
+ <div class="kc-login-tooltip">
97
+ <i [kcClass]="'kcResetFlowIcon'"></i>
98
+ <span class="kc-tooltip-text">
99
+ {{ 'restartLoginTooltip' | msgStr }}
100
+ </span>
101
+ </div>
102
+ </a>
103
+ </div>
104
+ }
105
+ </ng-template>
106
+
107
+ @if (displayRequiredFields()) {
108
+ <div [kcClass]="'kcContentWrapperClass'">
109
+ <div
110
+ [kcClass]="'kcLabelWrapperClass'"
111
+ class="subtitle"
112
+ >
113
+ <span class="subtitle">
114
+ <span class="required">*</span>
115
+ {{ 'requiredFields' | msgStr }}
116
+ </span>
117
+ </div>
118
+ <div class="col-md-10">
119
+ <ng-container [ngTemplateOutlet]="node"></ng-container>
120
+ </div>
121
+ </div>
122
+ } @else {
123
+ <ng-container [ngTemplateOutlet]="node"></ng-container>
124
+ }
125
+ </header>
126
+
127
+ <div id="kc-content">
128
+ <div id="kc-content-wrapper">
129
+ <!-- Message display -->
130
+ @if (displayMessage() && message && (message.type !== 'warning' || !isAppInitiatedAction)) {
131
+ <div
132
+ [kcClass]="'kcAlertClass'"
133
+ [ngClass]="message.type === 'error' ? 'pf-m-danger' : 'pf-m-' + message.type"
134
+ [class]="'alert-' + message.type"
135
+ >
136
+ <div class="pf-c-alert__icon">
137
+ @switch (message.type) {
138
+ @case ('success') {
139
+ <span [kcClass]="'kcFeedbackSuccessIcon'"></span>
140
+ }
141
+ @case ('warning') {
142
+ <span [kcClass]="'kcFeedbackWarningIcon'"></span>
143
+ }
144
+ @case ('info') {
145
+ <span [kcClass]="'kcFeedbackInfoIcon'"></span>
146
+ }
147
+ @case ('error') {
148
+ <span [kcClass]="'kcFeedbackErrorIcon'"></span>
149
+ }
150
+ }
151
+ </div>
152
+ <span
153
+ [kcClass]="'kcAlertTitleClass'"
154
+ [innerHTML]="message.summary | kcSanitize: 'html'"
155
+ ></span>
156
+ </div>
157
+ }
158
+ <!-- Content -->
159
+ <ng-content select="[content]"></ng-content>
160
+ @if (!!auth && auth?.showTryAnotherWayLink) {
161
+ <form
162
+ id="kc-select-try-another-way-form"
163
+ [action]="url?.loginAction"
164
+ method="post"
165
+ >
166
+ <div [kcClass]="'kcFormGroupClass'">
167
+ <div [kcClass]="'kcFormGroupClass'">
168
+ <input
169
+ type="hidden"
170
+ name="tryAnotherWay"
171
+ value="on"
172
+ />
173
+ <a
174
+ id="try-another-way"
175
+ (click)="tryAnotherWay()"
176
+ >
177
+ {{ 'doTryAnotherWay' | msgStr }}
178
+ </a>
179
+ </div>
180
+ </div>
181
+ </form>
182
+ }
183
+
184
+ <ng-content select="[socialProvidersNode]"></ng-content>
185
+ <!-- Info display -->
186
+ @if (displayInfo()) {
187
+ <div
188
+ id="kc-info"
189
+ [kcClass]="'kcSignUpClass'"
190
+ >
191
+ <div
192
+ id="kc-info-wrapper"
193
+ [kcClass]="'kcInfoAreaWrapperClass'"
194
+ >
195
+ <ng-content select="[infoNode]"></ng-content>
196
+ </div>
197
+ </div>
198
+ }
199
+ </div>
200
+ </div>
201
+ </div>
202
+ </div>
203
+ }
@@ -0,0 +1,94 @@
1
+ import { AsyncPipe, NgTemplateOutlet } from "@angular/common";
2
+ import {
3
+ ChangeDetectionStrategy,
4
+ Component,
5
+ forwardRef,
6
+ inject,
7
+ input,
8
+ OnInit,
9
+ Renderer2
10
+ } from "@angular/core";
11
+ import { Meta, Title } from "@angular/platform-browser";
12
+ import {
13
+ CLASSES,
14
+ I18N,
15
+ KC_CONTEXT,
16
+ USE_DEFAULT_CSS
17
+ } from "@keycloakify/angular/lib/public-api";
18
+ import type { I18n } from "@keycloakify/angular/login/i18n";
19
+ import { KcContext } from "keycloakify/login/KcContext/KcContext";
20
+ import { ClassKey, getKcClsx } from "keycloakify/login/lib/kcClsx";
21
+ import { Observable } from "rxjs";
22
+ import { ComponentReference } from "@keycloakify/angular/login/classes/component-reference.class";
23
+ import { KcClassDirective } from "@keycloakify/angular/login/directives/kc-class.directive";
24
+ import { KcSanitizePipe } from "@keycloakify/angular/login/pipes";
25
+ import { MsgStrPipe } from "@keycloakify/angular/login/pipes/msg-str.pipe";
26
+ import { LoginResourceInjectorService } from "@keycloakify/angular/login/services/login-resource-injector.service";
27
+
28
+ @Component({
29
+ selector: "kc-login-template",
30
+ templateUrl: "./template.component.html",
31
+ standalone: true,
32
+ imports: [AsyncPipe, KcSanitizePipe, NgTemplateOutlet, KcClassDirective, MsgStrPipe],
33
+ changeDetection: ChangeDetectionStrategy.OnPush,
34
+ providers: [
35
+ {
36
+ provide: ComponentReference,
37
+ useExisting: forwardRef(() => TemplateComponent)
38
+ }
39
+ ]
40
+ })
41
+ export class TemplateComponent extends ComponentReference implements OnInit {
42
+ i18n = inject<I18n>(I18N);
43
+ renderer = inject(Renderer2);
44
+ meta = inject(Meta);
45
+ title = inject(Title);
46
+ kcContext = inject<KcContext>(KC_CONTEXT);
47
+ override doUseDefaultCss = inject<boolean>(USE_DEFAULT_CSS);
48
+ override classes = inject<Partial<Record<ClassKey, string>>>(CLASSES);
49
+ loginResourceInjectorService = inject(LoginResourceInjectorService);
50
+
51
+ displayInfo = input(false);
52
+ displayMessage = input(true);
53
+ displayRequiredFields = input(false);
54
+ documentTitle = input<string>();
55
+ bodyClassName = input<string>();
56
+
57
+ isReadyToRender$: Observable<boolean>;
58
+
59
+ constructor() {
60
+ super();
61
+ this.title.setTitle(
62
+ this.documentTitle() ??
63
+ this.i18n.msgStr("loginTitle", this.kcContext.realm.displayName)
64
+ );
65
+ this.isReadyToRender$ = this.loginResourceInjectorService.injectResource(
66
+ this.doUseDefaultCss
67
+ );
68
+ }
69
+
70
+ ngOnInit() {
71
+ this.applyKcIndexClasses();
72
+ }
73
+
74
+ private applyKcIndexClasses() {
75
+ const kcClsx = getKcClsx({
76
+ doUseDefaultCss: this.doUseDefaultCss,
77
+ classes: this.classes
78
+ }).kcClsx;
79
+ const kcBodyClass = this.bodyClassName() ?? kcClsx("kcBodyClass");
80
+ const kcHtmlClass = kcClsx("kcHtmlClass");
81
+ const kcBodyClasses = kcBodyClass.split(/\s+/);
82
+ const kcHtmlClasses = kcHtmlClass.split(/\s+/);
83
+ kcBodyClasses.forEach(klass => {
84
+ this.renderer.addClass(document.body, klass);
85
+ });
86
+ kcHtmlClasses.forEach(klass => {
87
+ this.renderer.addClass(document.documentElement, klass);
88
+ });
89
+ }
90
+
91
+ tryAnotherWay() {
92
+ document.forms["kc-select-try-another-way-form" as never].submit();
93
+ }
94
+ }