@keycloakify/angular 0.0.1-rc.9 → 0.0.2

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 (1075) hide show
  1. package/README.md +78 -1
  2. package/account/DefaultPage/DefaultPage.d.ts +38 -0
  3. package/account/DefaultPage/index.d.ts +5 -0
  4. package/account/DefaultPage/public-api.d.ts +1 -0
  5. package/account/KcContext/KcContext.d.ts +1 -0
  6. package/account/KcContext/index.d.ts +5 -0
  7. package/account/KcContext/public-api.d.ts +1 -0
  8. package/account/account.d.ts +12 -0
  9. package/account/classes/component-reference/component-reference.class.d.ts +6 -0
  10. package/account/classes/component-reference/index.d.ts +5 -0
  11. package/account/classes/component-reference/public-api.d.ts +1 -0
  12. package/account/containers/template/index.d.ts +5 -0
  13. package/account/containers/template/public-api.d.ts +1 -0
  14. package/account/containers/template/template.component.d.ts +38 -0
  15. package/account/defaultPage.d.ts +3 -0
  16. package/account/directives/kc-class/index.d.ts +5 -0
  17. package/account/directives/kc-class/kc-class.directive.d.ts +26 -0
  18. package/account/directives/kc-class/public-api.d.ts +1 -0
  19. package/account/i18n/i18n.d.ts +4 -0
  20. package/account/i18n/index.d.ts +5 -0
  21. package/account/i18n/public-api.d.ts +1 -0
  22. package/account/index.d.ts +5 -0
  23. package/account/pages/account/account.component.d.ts +15 -0
  24. package/account/pages/account/index.d.ts +5 -0
  25. package/account/pages/account/public-api.d.ts +1 -0
  26. package/account/pages/applications/applications.component.d.ts +14 -0
  27. package/account/pages/applications/index.d.ts +5 -0
  28. package/account/pages/applications/public-api.d.ts +1 -0
  29. package/account/pages/federatedIdentity/federatedIdentity.component.d.ts +14 -0
  30. package/account/pages/federatedIdentity/index.d.ts +5 -0
  31. package/account/pages/federatedIdentity/public-api.d.ts +1 -0
  32. package/account/pages/log/index.d.ts +5 -0
  33. package/account/pages/log/log.component.d.ts +14 -0
  34. package/account/pages/log/public-api.d.ts +1 -0
  35. package/account/pages/password/index.d.ts +5 -0
  36. package/account/pages/password/password.component.d.ts +29 -0
  37. package/account/pages/password/public-api.d.ts +1 -0
  38. package/account/pages/sessions/index.d.ts +5 -0
  39. package/account/pages/sessions/public-api.d.ts +1 -0
  40. package/account/pages/sessions/sessions.component.d.ts +14 -0
  41. package/account/pages/totp/index.d.ts +5 -0
  42. package/account/pages/totp/public-api.d.ts +1 -0
  43. package/account/pages/totp/totp.component.d.ts +14 -0
  44. package/account/providers/keycloakify-angular/index.d.ts +5 -0
  45. package/account/providers/keycloakify-angular/keycloakify-angular.providers.d.ts +17 -0
  46. package/account/providers/keycloakify-angular/public-api.d.ts +1 -0
  47. package/account/public-api.d.ts +1 -0
  48. package/account/services/account-resource-injector/account-resource-injector.service.d.ts +10 -0
  49. package/account/services/account-resource-injector/index.d.ts +5 -0
  50. package/account/services/account-resource-injector/public-api.d.ts +1 -0
  51. package/account/services/i18n/index.d.ts +5 -0
  52. package/account/services/i18n/public-api.d.ts +1 -0
  53. package/account/tokens/classes/classes.token.d.ts +16 -0
  54. package/account/tokens/classes/index.d.ts +5 -0
  55. package/account/tokens/classes/public-api.d.ts +1 -0
  56. package/account/tokens/i18n/i18n.token.d.ts +2 -0
  57. package/account/tokens/i18n/index.d.ts +5 -0
  58. package/account/tokens/i18n/public-api.d.ts +1 -0
  59. package/account/tokens/kc-context/index.d.ts +5 -0
  60. package/account/tokens/kc-context/kc-context.token.d.ts +3 -0
  61. package/account/tokens/kc-context/public-api.d.ts +1 -0
  62. package/bin/338.index.js +316 -0
  63. package/bin/603.index.js +4964 -0
  64. package/bin/758.index.js +144 -0
  65. package/bin/925.index.js +1115 -0
  66. package/bin/main.js +462 -0
  67. package/esm2022/account/DefaultPage/DefaultPage.mjs +34 -0
  68. package/esm2022/account/DefaultPage/keycloakify-angular-account-DefaultPage.mjs +5 -0
  69. package/esm2022/account/DefaultPage/public-api.mjs +2 -0
  70. package/esm2022/account/KcContext/KcContext.mjs +2 -0
  71. package/esm2022/account/KcContext/keycloakify-angular-account-KcContext.mjs +5 -0
  72. package/esm2022/account/KcContext/public-api.mjs +2 -0
  73. package/esm2022/account/account.mjs +3 -0
  74. package/esm2022/account/classes/component-reference/component-reference.class.mjs +3 -0
  75. package/esm2022/account/classes/component-reference/keycloakify-angular-account-classes-component-reference.mjs +5 -0
  76. package/esm2022/account/classes/component-reference/public-api.mjs +2 -0
  77. package/esm2022/account/containers/template/keycloakify-angular-account-containers-template.mjs +5 -0
  78. package/esm2022/account/containers/template/public-api.mjs +2 -0
  79. package/esm2022/account/containers/template/template.component.mjs +97 -0
  80. package/esm2022/account/defaultPage.mjs +26 -0
  81. package/esm2022/account/directives/kc-class/kc-class.directive.mjs +141 -0
  82. package/esm2022/account/directives/kc-class/keycloakify-angular-account-directives-kc-class.mjs +5 -0
  83. package/esm2022/account/directives/kc-class/public-api.mjs +2 -0
  84. package/esm2022/account/i18n/i18n.mjs +2 -0
  85. package/esm2022/account/i18n/keycloakify-angular-account-i18n.mjs +5 -0
  86. package/esm2022/account/i18n/public-api.mjs +2 -0
  87. package/esm2022/account/keycloakify-angular-account.mjs +5 -0
  88. package/esm2022/account/pages/account/account.component.mjs +39 -0
  89. package/esm2022/account/pages/account/keycloakify-angular-account-pages-account.mjs +5 -0
  90. package/esm2022/account/pages/account/public-api.mjs +2 -0
  91. package/esm2022/account/pages/applications/applications.component.mjs +37 -0
  92. package/esm2022/account/pages/applications/keycloakify-angular-account-pages-applications.mjs +5 -0
  93. package/esm2022/account/pages/applications/public-api.mjs +2 -0
  94. package/esm2022/account/pages/federatedIdentity/federatedIdentity.component.mjs +36 -0
  95. package/esm2022/account/pages/federatedIdentity/keycloakify-angular-account-pages-federatedIdentity.mjs +5 -0
  96. package/esm2022/account/pages/federatedIdentity/public-api.mjs +2 -0
  97. package/esm2022/account/pages/log/keycloakify-angular-account-pages-log.mjs +5 -0
  98. package/esm2022/account/pages/log/log.component.mjs +36 -0
  99. package/esm2022/account/pages/log/public-api.mjs +2 -0
  100. package/esm2022/account/pages/password/keycloakify-angular-account-pages-password.mjs +5 -0
  101. package/esm2022/account/pages/password/password.component.mjs +108 -0
  102. package/esm2022/account/pages/password/public-api.mjs +2 -0
  103. package/esm2022/account/pages/sessions/keycloakify-angular-account-pages-sessions.mjs +5 -0
  104. package/esm2022/account/pages/sessions/public-api.mjs +2 -0
  105. package/esm2022/account/pages/sessions/sessions.component.mjs +36 -0
  106. package/esm2022/account/pages/totp/keycloakify-angular-account-pages-totp.mjs +5 -0
  107. package/esm2022/account/pages/totp/public-api.mjs +2 -0
  108. package/esm2022/account/pages/totp/totp.component.mjs +37 -0
  109. package/esm2022/account/providers/keycloakify-angular/keycloakify-angular-account-providers-keycloakify-angular.mjs +5 -0
  110. package/esm2022/account/providers/keycloakify-angular/keycloakify-angular.providers.mjs +47 -0
  111. package/esm2022/account/providers/keycloakify-angular/public-api.mjs +2 -0
  112. package/esm2022/account/public-api.mjs +2 -0
  113. package/esm2022/account/services/account-resource-injector/account-resource-injector.service.mjs +37 -0
  114. package/esm2022/account/services/account-resource-injector/keycloakify-angular-account-services-account-resource-injector.mjs +5 -0
  115. package/esm2022/account/services/account-resource-injector/public-api.mjs +2 -0
  116. package/esm2022/account/services/i18n/i18n.service.mjs +12 -0
  117. package/esm2022/account/services/i18n/keycloakify-angular-account-services-i18n.mjs +5 -0
  118. package/esm2022/account/services/i18n/public-api.mjs +2 -0
  119. package/esm2022/account/tokens/classes/classes.token.mjs +3 -0
  120. package/esm2022/account/tokens/classes/keycloakify-angular-account-tokens-classes.mjs +5 -0
  121. package/esm2022/account/tokens/classes/public-api.mjs +2 -0
  122. package/esm2022/account/tokens/i18n/i18n.token.mjs +3 -0
  123. package/esm2022/account/tokens/i18n/keycloakify-angular-account-tokens-i18n.mjs +5 -0
  124. package/esm2022/account/tokens/i18n/public-api.mjs +2 -0
  125. package/esm2022/account/tokens/kc-context/kc-context.token.mjs +3 -0
  126. package/esm2022/account/tokens/kc-context/keycloakify-angular-account-tokens-kc-context.mjs +5 -0
  127. package/esm2022/account/tokens/kc-context/public-api.mjs +2 -0
  128. package/esm2022/keycloakify-angular.mjs +5 -0
  129. package/esm2022/lib/directives/attributes/attributes.directive.mjs +26 -0
  130. package/esm2022/lib/directives/attributes/keycloakify-angular-lib-directives-attributes.mjs +5 -0
  131. package/esm2022/lib/directives/attributes/public-api.mjs +2 -0
  132. package/esm2022/lib/keycloakify-angular-lib.mjs +5 -0
  133. package/esm2022/lib/models/script/keycloakify-angular-lib-models-script.mjs +5 -0
  134. package/esm2022/lib/models/script/public-api.mjs +2 -0
  135. package/esm2022/lib/models/script/script.model.mjs +2 -0
  136. package/esm2022/lib/pipes/input-type/input-type.pipe.mjs +20 -0
  137. package/esm2022/lib/pipes/input-type/keycloakify-angular-lib-pipes-input-type.mjs +5 -0
  138. package/esm2022/lib/pipes/input-type/public-api.mjs +2 -0
  139. package/esm2022/lib/pipes/is-array-with-empty-object/is-array-with-empty-object.pipe.mjs +20 -0
  140. package/esm2022/lib/pipes/is-array-with-empty-object/keycloakify-angular-lib-pipes-is-array-with-empty-object.mjs +5 -0
  141. package/esm2022/lib/pipes/is-array-with-empty-object/public-api.mjs +2 -0
  142. package/esm2022/lib/pipes/kc-sanitize/kc-sanitize.pipe.mjs +29 -0
  143. package/esm2022/lib/pipes/kc-sanitize/keycloakify-angular-lib-pipes-kc-sanitize.mjs +5 -0
  144. package/esm2022/lib/pipes/kc-sanitize/public-api.mjs +2 -0
  145. package/esm2022/lib/pipes/to-array/keycloakify-angular-lib-pipes-to-array.mjs +5 -0
  146. package/esm2022/lib/pipes/to-array/public-api.mjs +2 -0
  147. package/esm2022/lib/pipes/to-array/to-array.pipe.mjs +21 -0
  148. package/esm2022/lib/pipes/to-number/keycloakify-angular-lib-pipes-to-number.mjs +5 -0
  149. package/esm2022/lib/pipes/to-number/public-api.mjs +2 -0
  150. package/esm2022/lib/pipes/to-number/to-number.pipe.mjs +20 -0
  151. package/esm2022/lib/public-api.mjs +2 -0
  152. package/esm2022/lib/services/resource-injector/keycloakify-angular-lib-services-resource-injector.mjs +5 -0
  153. package/esm2022/lib/services/resource-injector/public-api.mjs +2 -0
  154. package/esm2022/lib/services/resource-injector/resource-injector.service.mjs +54 -0
  155. package/esm2022/lib/tokens/use-default-css/keycloakify-angular-lib-tokens-use-default-css.mjs +5 -0
  156. package/esm2022/lib/tokens/use-default-css/public-api.mjs +2 -0
  157. package/esm2022/lib/tokens/use-default-css/use-default-css.token.mjs +3 -0
  158. package/esm2022/login/KcContext/KcContext.mjs +2 -0
  159. package/esm2022/login/KcContext/keycloakify-angular-login-KcContext.mjs +5 -0
  160. package/esm2022/login/KcContext/public-api.mjs +2 -0
  161. package/esm2022/login/classes/component-reference/component-reference.class.mjs +3 -0
  162. package/esm2022/login/classes/component-reference/keycloakify-angular-login-classes-component-reference.mjs +5 -0
  163. package/esm2022/login/classes/component-reference/public-api.mjs +2 -0
  164. package/esm2022/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.mjs +106 -0
  165. package/esm2022/login/components/add-remove-buttons-multi-valued-attribute/keycloakify-angular-login-components-add-remove-buttons-multi-valued-attribute.mjs +5 -0
  166. package/esm2022/login/components/add-remove-buttons-multi-valued-attribute/public-api.mjs +2 -0
  167. package/esm2022/login/components/field-errors/field-errors.component.mjs +33 -0
  168. package/esm2022/login/components/field-errors/keycloakify-angular-login-components-field-errors.mjs +5 -0
  169. package/esm2022/login/components/field-errors/public-api.mjs +2 -0
  170. package/esm2022/login/components/group-label/group-label.component.mjs +43 -0
  171. package/esm2022/login/components/group-label/keycloakify-angular-login-components-group-label.mjs +5 -0
  172. package/esm2022/login/components/group-label/public-api.mjs +2 -0
  173. package/esm2022/login/components/input-field-by-type/input-field-by-type.component.mjs +46 -0
  174. package/esm2022/login/components/input-field-by-type/keycloakify-angular-login-components-input-field-by-type.mjs +5 -0
  175. package/esm2022/login/components/input-field-by-type/public-api.mjs +2 -0
  176. package/esm2022/login/components/input-tag/input-tag.component.mjs +90 -0
  177. package/esm2022/login/components/input-tag/keycloakify-angular-login-components-input-tag.mjs +5 -0
  178. package/esm2022/login/components/input-tag/public-api.mjs +2 -0
  179. package/esm2022/login/components/input-tag-selects/input-tag-selects.component.mjs +117 -0
  180. package/esm2022/login/components/input-tag-selects/keycloakify-angular-login-components-input-tag-selects.mjs +5 -0
  181. package/esm2022/login/components/input-tag-selects/public-api.mjs +2 -0
  182. package/esm2022/login/components/logout-other-sessions/keycloakify-angular-login-components-logout-other-sessions.mjs +5 -0
  183. package/esm2022/login/components/logout-other-sessions/logout-other-sessions.component.mjs +32 -0
  184. package/esm2022/login/components/logout-other-sessions/public-api.mjs +2 -0
  185. package/esm2022/login/components/password-wrapper/keycloakify-angular-login-components-password-wrapper.mjs +5 -0
  186. package/esm2022/login/components/password-wrapper/password-wrapper.component.mjs +46 -0
  187. package/esm2022/login/components/password-wrapper/public-api.mjs +2 -0
  188. package/esm2022/login/components/select-tag/keycloakify-angular-login-components-select-tag.mjs +5 -0
  189. package/esm2022/login/components/select-tag/public-api.mjs +2 -0
  190. package/esm2022/login/components/select-tag/select-tag.component.mjs +82 -0
  191. package/esm2022/login/components/textarea-tag/keycloakify-angular-login-components-textarea-tag.mjs +5 -0
  192. package/esm2022/login/components/textarea-tag/public-api.mjs +2 -0
  193. package/esm2022/login/components/textarea-tag/textarea-tag.component.mjs +49 -0
  194. package/esm2022/login/components/user-profile-form-fields/keycloakify-angular-login-components-user-profile-form-fields.mjs +5 -0
  195. package/esm2022/login/components/user-profile-form-fields/public-api.mjs +2 -0
  196. package/esm2022/login/components/user-profile-form-fields/user-profile-form-fields.component.mjs +62 -0
  197. package/esm2022/login/containers/template/keycloakify-angular-login-containers-template.mjs +5 -0
  198. package/esm2022/login/containers/template/public-api.mjs +2 -0
  199. package/esm2022/login/containers/template/template.component.mjs +138 -0
  200. package/esm2022/login/defaultPage.mjs +77 -0
  201. package/esm2022/login/directives/kc-class/kc-class.directive.mjs +138 -0
  202. package/esm2022/login/directives/kc-class/keycloakify-angular-login-directives-kc-class.mjs +5 -0
  203. package/esm2022/login/directives/kc-class/public-api.mjs +2 -0
  204. package/esm2022/login/i18n/i18n.mjs +2 -0
  205. package/esm2022/login/i18n/keycloakify-angular-login-i18n.mjs +5 -0
  206. package/esm2022/login/i18n/public-api.mjs +2 -0
  207. package/esm2022/login/keycloakify-angular-login.mjs +5 -0
  208. package/esm2022/login/login.mjs +3 -0
  209. package/esm2022/login/pages/code/code.component.mjs +40 -0
  210. package/esm2022/login/pages/code/keycloakify-angular-login-pages-code.mjs +5 -0
  211. package/esm2022/login/pages/code/public-api.mjs +2 -0
  212. package/esm2022/login/pages/delete-account-confirm/delete-account-confirm.component.mjs +40 -0
  213. package/esm2022/login/pages/delete-account-confirm/keycloakify-angular-login-pages-delete-account-confirm.mjs +5 -0
  214. package/esm2022/login/pages/delete-account-confirm/public-api.mjs +2 -0
  215. package/esm2022/login/pages/delete-credential/delete-credential.component.mjs +40 -0
  216. package/esm2022/login/pages/delete-credential/keycloakify-angular-login-pages-delete-credential.mjs +5 -0
  217. package/esm2022/login/pages/delete-credential/public-api.mjs +2 -0
  218. package/esm2022/login/pages/error/error.component.mjs +40 -0
  219. package/esm2022/login/pages/error/keycloakify-angular-login-pages-error.mjs +5 -0
  220. package/esm2022/login/pages/error/public-api.mjs +2 -0
  221. package/esm2022/login/pages/frontchannel-logout/frontchannel-logout.component.mjs +46 -0
  222. package/esm2022/login/pages/frontchannel-logout/keycloakify-angular-login-pages-frontchannel-logout.mjs +5 -0
  223. package/esm2022/login/pages/frontchannel-logout/public-api.mjs +2 -0
  224. package/esm2022/login/pages/idp-review-user-profile/idp-review-user-profile.component.mjs +53 -0
  225. package/esm2022/login/pages/idp-review-user-profile/keycloakify-angular-login-pages-idp-review-user-profile.mjs +5 -0
  226. package/esm2022/login/pages/idp-review-user-profile/public-api.mjs +2 -0
  227. package/esm2022/login/pages/info/info.component.mjs +49 -0
  228. package/esm2022/login/pages/info/keycloakify-angular-login-pages-info.mjs +5 -0
  229. package/esm2022/login/pages/info/public-api.mjs +2 -0
  230. package/esm2022/login/pages/login/keycloakify-angular-login-pages-login.mjs +5 -0
  231. package/esm2022/login/pages/login/login.component.mjs +44 -0
  232. package/esm2022/login/pages/login/public-api.mjs +2 -0
  233. package/esm2022/login/pages/login-config-totp/keycloakify-angular-login-pages-login-config-totp.mjs +5 -0
  234. package/esm2022/login/pages/login-config-totp/login-config-totp.component.mjs +42 -0
  235. package/esm2022/login/pages/login-config-totp/public-api.mjs +2 -0
  236. package/esm2022/login/pages/login-idp-link-confirm/keycloakify-angular-login-pages-login-idp-link-confirm.mjs +5 -0
  237. package/esm2022/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.mjs +36 -0
  238. package/esm2022/login/pages/login-idp-link-confirm/public-api.mjs +2 -0
  239. package/esm2022/login/pages/login-idp-link-confirm-override/keycloakify-angular-login-pages-login-idp-link-confirm-override.mjs +5 -0
  240. package/esm2022/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.mjs +36 -0
  241. package/esm2022/login/pages/login-idp-link-confirm-override/public-api.mjs +2 -0
  242. package/esm2022/login/pages/login-idp-link-email/keycloakify-angular-login-pages-login-idp-link-email.mjs +5 -0
  243. package/esm2022/login/pages/login-idp-link-email/login-idp-link-email.component.mjs +36 -0
  244. package/esm2022/login/pages/login-idp-link-email/public-api.mjs +2 -0
  245. package/esm2022/login/pages/login-oauth-grant/keycloakify-angular-login-pages-login-oauth-grant.mjs +5 -0
  246. package/esm2022/login/pages/login-oauth-grant/login-oauth-grant.component.mjs +37 -0
  247. package/esm2022/login/pages/login-oauth-grant/public-api.mjs +2 -0
  248. package/esm2022/login/pages/login-oauth2-device-verify-user-code/keycloakify-angular-login-pages-login-oauth2-device-verify-user-code.mjs +5 -0
  249. package/esm2022/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.mjs +40 -0
  250. package/esm2022/login/pages/login-oauth2-device-verify-user-code/public-api.mjs +2 -0
  251. package/esm2022/login/pages/login-otp/keycloakify-angular-login-pages-login-otp.mjs +5 -0
  252. package/esm2022/login/pages/login-otp/login-otp.component.mjs +41 -0
  253. package/esm2022/login/pages/login-otp/public-api.mjs +2 -0
  254. package/esm2022/login/pages/login-page-expired/keycloakify-angular-login-pages-login-page-expired.mjs +5 -0
  255. package/esm2022/login/pages/login-page-expired/login-page-expired.component.mjs +39 -0
  256. package/esm2022/login/pages/login-page-expired/public-api.mjs +2 -0
  257. package/esm2022/login/pages/login-passkeys-conditional-authenticate/keycloakify-angular-login-pages-login-passkeys-conditional-authenticate.mjs +5 -0
  258. package/esm2022/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.mjs +88 -0
  259. package/esm2022/login/pages/login-passkeys-conditional-authenticate/public-api.mjs +2 -0
  260. package/esm2022/login/pages/login-password/keycloakify-angular-login-pages-login-password.mjs +5 -0
  261. package/esm2022/login/pages/login-password/login-password.component.mjs +44 -0
  262. package/esm2022/login/pages/login-password/public-api.mjs +2 -0
  263. package/esm2022/login/pages/login-recovery-authn-code-config/keycloakify-angular-login-pages-login-recovery-authn-code-config.mjs +5 -0
  264. package/esm2022/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.mjs +43 -0
  265. package/esm2022/login/pages/login-recovery-authn-code-config/public-api.mjs +2 -0
  266. package/esm2022/login/pages/login-recovery-authn-code-input/keycloakify-angular-login-pages-login-recovery-authn-code-input.mjs +5 -0
  267. package/esm2022/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.mjs +41 -0
  268. package/esm2022/login/pages/login-recovery-authn-code-input/public-api.mjs +2 -0
  269. package/esm2022/login/pages/login-reset-otp/keycloakify-angular-login-pages-login-reset-otp.mjs +5 -0
  270. package/esm2022/login/pages/login-reset-otp/login-reset-otp.component.mjs +40 -0
  271. package/esm2022/login/pages/login-reset-otp/public-api.mjs +2 -0
  272. package/esm2022/login/pages/login-reset-password/keycloakify-angular-login-pages-login-reset-password.mjs +5 -0
  273. package/esm2022/login/pages/login-reset-password/login-reset-password.component.mjs +41 -0
  274. package/esm2022/login/pages/login-reset-password/public-api.mjs +2 -0
  275. package/esm2022/login/pages/login-update-password/keycloakify-angular-login-pages-login-update-password.mjs +5 -0
  276. package/esm2022/login/pages/login-update-password/login-update-password.component.mjs +43 -0
  277. package/esm2022/login/pages/login-update-password/public-api.mjs +2 -0
  278. package/esm2022/login/pages/login-update-profile/keycloakify-angular-login-pages-login-update-profile.mjs +5 -0
  279. package/esm2022/login/pages/login-update-profile/login-update-profile.component.mjs +50 -0
  280. package/esm2022/login/pages/login-update-profile/public-api.mjs +2 -0
  281. package/esm2022/login/pages/login-username/keycloakify-angular-login-pages-login-username.mjs +5 -0
  282. package/esm2022/login/pages/login-username/login-username.component.mjs +43 -0
  283. package/esm2022/login/pages/login-username/public-api.mjs +2 -0
  284. package/esm2022/login/pages/login-verify-email/keycloakify-angular-login-pages-login-verify-email.mjs +5 -0
  285. package/esm2022/login/pages/login-verify-email/login-verify-email.component.mjs +40 -0
  286. package/esm2022/login/pages/login-verify-email/public-api.mjs +2 -0
  287. package/esm2022/login/pages/login-x509-info/keycloakify-angular-login-pages-login-x509-info.mjs +5 -0
  288. package/esm2022/login/pages/login-x509-info/login-x509-info.component.mjs +40 -0
  289. package/esm2022/login/pages/login-x509-info/public-api.mjs +2 -0
  290. package/esm2022/login/pages/logout-confirm/keycloakify-angular-login-pages-logout-confirm.mjs +5 -0
  291. package/esm2022/login/pages/logout-confirm/logout-confirm.component.mjs +36 -0
  292. package/esm2022/login/pages/logout-confirm/public-api.mjs +2 -0
  293. package/esm2022/login/pages/register/keycloakify-angular-login-pages-register.mjs +5 -0
  294. package/esm2022/login/pages/register/public-api.mjs +2 -0
  295. package/esm2022/login/pages/register/register.component.mjs +55 -0
  296. package/esm2022/login/pages/saml-post-form/keycloakify-angular-login-pages-saml-post-form.mjs +5 -0
  297. package/esm2022/login/pages/saml-post-form/public-api.mjs +2 -0
  298. package/esm2022/login/pages/saml-post-form/saml-post-form.component.mjs +50 -0
  299. package/esm2022/login/pages/select-authenticator/keycloakify-angular-login-pages-select-authenticator.mjs +5 -0
  300. package/esm2022/login/pages/select-authenticator/public-api.mjs +2 -0
  301. package/esm2022/login/pages/select-authenticator/select-authenticator.component.mjs +41 -0
  302. package/esm2022/login/pages/terms/keycloakify-angular-login-pages-terms.mjs +5 -0
  303. package/esm2022/login/pages/terms/public-api.mjs +2 -0
  304. package/esm2022/login/pages/terms/terms.component.mjs +40 -0
  305. package/esm2022/login/pages/update-email/keycloakify-angular-login-pages-update-email.mjs +5 -0
  306. package/esm2022/login/pages/update-email/public-api.mjs +2 -0
  307. package/esm2022/login/pages/update-email/update-email.component.mjs +47 -0
  308. package/esm2022/login/pages/webauthn-authenticate/keycloakify-angular-login-pages-webauthn-authenticate.mjs +5 -0
  309. package/esm2022/login/pages/webauthn-authenticate/public-api.mjs +2 -0
  310. package/esm2022/login/pages/webauthn-authenticate/webauthn-authenticate.component.mjs +80 -0
  311. package/esm2022/login/pages/webauthn-error/keycloakify-angular-login-pages-webauthn-error.mjs +5 -0
  312. package/esm2022/login/pages/webauthn-error/public-api.mjs +2 -0
  313. package/esm2022/login/pages/webauthn-error/webauthn-error.component.mjs +49 -0
  314. package/esm2022/login/pages/webauthn-register/keycloakify-angular-login-pages-webauthn-register.mjs +5 -0
  315. package/esm2022/login/pages/webauthn-register/public-api.mjs +2 -0
  316. package/esm2022/login/pages/webauthn-register/webauthn-register.component.mjs +76 -0
  317. package/esm2022/login/providers/keycloakify-angular/keycloakify-angular-login-providers-keycloakify-angular.mjs +5 -0
  318. package/esm2022/login/providers/keycloakify-angular/keycloakify-angular.providers.mjs +52 -0
  319. package/esm2022/login/providers/keycloakify-angular/public-api.mjs +2 -0
  320. package/esm2022/login/public-api.mjs +2 -0
  321. package/esm2022/login/services/i18n/i18n.service.mjs +12 -0
  322. package/esm2022/login/services/i18n/keycloakify-angular-login-services-i18n.mjs +5 -0
  323. package/esm2022/login/services/i18n/public-api.mjs +2 -0
  324. package/esm2022/login/services/login-resource-injector/keycloakify-angular-login-services-login-resource-injector.mjs +5 -0
  325. package/esm2022/login/services/login-resource-injector/login-resource-injector.service.mjs +68 -0
  326. package/esm2022/login/services/login-resource-injector/public-api.mjs +2 -0
  327. package/esm2022/login/services/submit/keycloakify-angular-login-services-submit.mjs +5 -0
  328. package/esm2022/login/services/submit/public-api.mjs +2 -0
  329. package/esm2022/login/services/submit/submit.service.mjs +20 -0
  330. package/esm2022/login/services/user-profile-form/keycloakify-angular-login-services-user-profile-form.mjs +5 -0
  331. package/esm2022/login/services/user-profile-form/public-api.mjs +2 -0
  332. package/esm2022/login/services/user-profile-form/user-profile-form.service.mjs +1019 -0
  333. package/esm2022/login/tokens/classes/classes.token.mjs +3 -0
  334. package/esm2022/login/tokens/classes/keycloakify-angular-login-tokens-classes.mjs +5 -0
  335. package/esm2022/login/tokens/classes/public-api.mjs +2 -0
  336. package/esm2022/login/tokens/i18n/i18n.token.mjs +3 -0
  337. package/esm2022/login/tokens/i18n/keycloakify-angular-login-tokens-i18n.mjs +5 -0
  338. package/esm2022/login/tokens/i18n/public-api.mjs +2 -0
  339. package/esm2022/login/tokens/kc-context/kc-context.token.mjs +3 -0
  340. package/esm2022/login/tokens/kc-context/keycloakify-angular-login-tokens-kc-context.mjs +5 -0
  341. package/esm2022/login/tokens/kc-context/public-api.mjs +2 -0
  342. package/esm2022/login/tokens/make-user-confirm-password/keycloakify-angular-login-tokens-make-user-confirm-password.mjs +5 -0
  343. package/esm2022/login/tokens/make-user-confirm-password/make-user-confirm-password.token.mjs +3 -0
  344. package/esm2022/login/tokens/make-user-confirm-password/public-api.mjs +2 -0
  345. package/esm2022/public-api.mjs +2 -0
  346. package/fesm2022/keycloakify-angular-account-DefaultPage.mjs +39 -0
  347. package/fesm2022/keycloakify-angular-account-DefaultPage.mjs.map +1 -0
  348. package/fesm2022/keycloakify-angular-account-KcContext.mjs +4 -0
  349. package/fesm2022/keycloakify-angular-account-KcContext.mjs.map +1 -0
  350. package/fesm2022/keycloakify-angular-account-classes-component-reference.mjs +9 -0
  351. package/fesm2022/keycloakify-angular-account-classes-component-reference.mjs.map +1 -0
  352. package/fesm2022/keycloakify-angular-account-containers-template.mjs +104 -0
  353. package/fesm2022/keycloakify-angular-account-containers-template.mjs.map +1 -0
  354. package/fesm2022/keycloakify-angular-account-directives-kc-class.mjs +148 -0
  355. package/fesm2022/keycloakify-angular-account-directives-kc-class.mjs.map +1 -0
  356. package/fesm2022/keycloakify-angular-account-i18n.mjs +4 -0
  357. package/fesm2022/keycloakify-angular-account-i18n.mjs.map +1 -0
  358. package/fesm2022/keycloakify-angular-account-pages-account.mjs +46 -0
  359. package/fesm2022/keycloakify-angular-account-pages-account.mjs.map +1 -0
  360. package/fesm2022/keycloakify-angular-account-pages-applications.mjs +44 -0
  361. package/fesm2022/keycloakify-angular-account-pages-applications.mjs.map +1 -0
  362. package/fesm2022/keycloakify-angular-account-pages-federatedIdentity.mjs +43 -0
  363. package/fesm2022/keycloakify-angular-account-pages-federatedIdentity.mjs.map +1 -0
  364. package/fesm2022/keycloakify-angular-account-pages-log.mjs +43 -0
  365. package/fesm2022/keycloakify-angular-account-pages-log.mjs.map +1 -0
  366. package/fesm2022/keycloakify-angular-account-pages-password.mjs +115 -0
  367. package/fesm2022/keycloakify-angular-account-pages-password.mjs.map +1 -0
  368. package/fesm2022/keycloakify-angular-account-pages-sessions.mjs +43 -0
  369. package/fesm2022/keycloakify-angular-account-pages-sessions.mjs.map +1 -0
  370. package/fesm2022/keycloakify-angular-account-pages-totp.mjs +44 -0
  371. package/fesm2022/keycloakify-angular-account-pages-totp.mjs.map +1 -0
  372. package/fesm2022/keycloakify-angular-account-providers-keycloakify-angular.mjs +54 -0
  373. package/fesm2022/keycloakify-angular-account-providers-keycloakify-angular.mjs.map +1 -0
  374. package/fesm2022/keycloakify-angular-account-services-account-resource-injector.mjs +44 -0
  375. package/fesm2022/keycloakify-angular-account-services-account-resource-injector.mjs.map +1 -0
  376. package/fesm2022/keycloakify-angular-account-services-i18n.mjs +19 -0
  377. package/fesm2022/keycloakify-angular-account-services-i18n.mjs.map +1 -0
  378. package/fesm2022/keycloakify-angular-account-tokens-classes.mjs +10 -0
  379. package/fesm2022/keycloakify-angular-account-tokens-classes.mjs.map +1 -0
  380. package/fesm2022/keycloakify-angular-account-tokens-i18n.mjs +10 -0
  381. package/fesm2022/keycloakify-angular-account-tokens-i18n.mjs.map +1 -0
  382. package/fesm2022/keycloakify-angular-account-tokens-kc-context.mjs +10 -0
  383. package/fesm2022/keycloakify-angular-account-tokens-kc-context.mjs.map +1 -0
  384. package/fesm2022/keycloakify-angular-account.mjs +34 -0
  385. package/fesm2022/keycloakify-angular-account.mjs.map +1 -0
  386. package/fesm2022/keycloakify-angular-lib-directives-attributes.mjs +33 -0
  387. package/fesm2022/keycloakify-angular-lib-directives-attributes.mjs.map +1 -0
  388. package/fesm2022/keycloakify-angular-lib-models-script.mjs +4 -0
  389. package/fesm2022/keycloakify-angular-lib-models-script.mjs.map +1 -0
  390. package/fesm2022/keycloakify-angular-lib-pipes-input-type.mjs +27 -0
  391. package/fesm2022/keycloakify-angular-lib-pipes-input-type.mjs.map +1 -0
  392. package/fesm2022/keycloakify-angular-lib-pipes-is-array-with-empty-object.mjs +27 -0
  393. package/fesm2022/keycloakify-angular-lib-pipes-is-array-with-empty-object.mjs.map +1 -0
  394. package/fesm2022/keycloakify-angular-lib-pipes-kc-sanitize.mjs +36 -0
  395. package/fesm2022/keycloakify-angular-lib-pipes-kc-sanitize.mjs.map +1 -0
  396. package/fesm2022/keycloakify-angular-lib-pipes-to-array.mjs +28 -0
  397. package/fesm2022/keycloakify-angular-lib-pipes-to-array.mjs.map +1 -0
  398. package/fesm2022/keycloakify-angular-lib-pipes-to-number.mjs +27 -0
  399. package/fesm2022/keycloakify-angular-lib-pipes-to-number.mjs.map +1 -0
  400. package/fesm2022/keycloakify-angular-lib-services-resource-injector.mjs +61 -0
  401. package/fesm2022/keycloakify-angular-lib-services-resource-injector.mjs.map +1 -0
  402. package/fesm2022/keycloakify-angular-lib-tokens-use-default-css.mjs +10 -0
  403. package/fesm2022/keycloakify-angular-lib-tokens-use-default-css.mjs.map +1 -0
  404. package/fesm2022/keycloakify-angular-lib.mjs +8 -0
  405. package/fesm2022/keycloakify-angular-lib.mjs.map +1 -0
  406. package/fesm2022/keycloakify-angular-login-KcContext.mjs +4 -0
  407. package/fesm2022/keycloakify-angular-login-KcContext.mjs.map +1 -0
  408. package/fesm2022/keycloakify-angular-login-classes-component-reference.mjs +9 -0
  409. package/fesm2022/keycloakify-angular-login-classes-component-reference.mjs.map +1 -0
  410. package/fesm2022/keycloakify-angular-login-components-add-remove-buttons-multi-valued-attribute.mjs +113 -0
  411. package/fesm2022/keycloakify-angular-login-components-add-remove-buttons-multi-valued-attribute.mjs.map +1 -0
  412. package/fesm2022/keycloakify-angular-login-components-field-errors.mjs +40 -0
  413. package/fesm2022/keycloakify-angular-login-components-field-errors.mjs.map +1 -0
  414. package/fesm2022/keycloakify-angular-login-components-group-label.mjs +50 -0
  415. package/fesm2022/keycloakify-angular-login-components-group-label.mjs.map +1 -0
  416. package/fesm2022/keycloakify-angular-login-components-input-field-by-type.mjs +53 -0
  417. package/fesm2022/keycloakify-angular-login-components-input-field-by-type.mjs.map +1 -0
  418. package/fesm2022/keycloakify-angular-login-components-input-tag-selects.mjs +124 -0
  419. package/fesm2022/keycloakify-angular-login-components-input-tag-selects.mjs.map +1 -0
  420. package/fesm2022/keycloakify-angular-login-components-input-tag.mjs +97 -0
  421. package/fesm2022/keycloakify-angular-login-components-input-tag.mjs.map +1 -0
  422. package/fesm2022/keycloakify-angular-login-components-logout-other-sessions.mjs +39 -0
  423. package/fesm2022/keycloakify-angular-login-components-logout-other-sessions.mjs.map +1 -0
  424. package/fesm2022/keycloakify-angular-login-components-password-wrapper.mjs +53 -0
  425. package/fesm2022/keycloakify-angular-login-components-password-wrapper.mjs.map +1 -0
  426. package/fesm2022/keycloakify-angular-login-components-select-tag.mjs +89 -0
  427. package/fesm2022/keycloakify-angular-login-components-select-tag.mjs.map +1 -0
  428. package/fesm2022/keycloakify-angular-login-components-textarea-tag.mjs +56 -0
  429. package/fesm2022/keycloakify-angular-login-components-textarea-tag.mjs.map +1 -0
  430. package/fesm2022/keycloakify-angular-login-components-user-profile-form-fields.mjs +69 -0
  431. package/fesm2022/keycloakify-angular-login-components-user-profile-form-fields.mjs.map +1 -0
  432. package/fesm2022/keycloakify-angular-login-containers-template.mjs +145 -0
  433. package/fesm2022/keycloakify-angular-login-containers-template.mjs.map +1 -0
  434. package/fesm2022/keycloakify-angular-login-directives-kc-class.mjs +145 -0
  435. package/fesm2022/keycloakify-angular-login-directives-kc-class.mjs.map +1 -0
  436. package/fesm2022/keycloakify-angular-login-i18n.mjs +4 -0
  437. package/fesm2022/keycloakify-angular-login-i18n.mjs.map +1 -0
  438. package/fesm2022/keycloakify-angular-login-pages-code.mjs +47 -0
  439. package/fesm2022/keycloakify-angular-login-pages-code.mjs.map +1 -0
  440. package/fesm2022/keycloakify-angular-login-pages-delete-account-confirm.mjs +47 -0
  441. package/fesm2022/keycloakify-angular-login-pages-delete-account-confirm.mjs.map +1 -0
  442. package/fesm2022/keycloakify-angular-login-pages-delete-credential.mjs +47 -0
  443. package/fesm2022/keycloakify-angular-login-pages-delete-credential.mjs.map +1 -0
  444. package/fesm2022/keycloakify-angular-login-pages-error.mjs +47 -0
  445. package/fesm2022/keycloakify-angular-login-pages-error.mjs.map +1 -0
  446. package/fesm2022/keycloakify-angular-login-pages-frontchannel-logout.mjs +53 -0
  447. package/fesm2022/keycloakify-angular-login-pages-frontchannel-logout.mjs.map +1 -0
  448. package/fesm2022/keycloakify-angular-login-pages-idp-review-user-profile.mjs +60 -0
  449. package/fesm2022/keycloakify-angular-login-pages-idp-review-user-profile.mjs.map +1 -0
  450. package/fesm2022/keycloakify-angular-login-pages-info.mjs +56 -0
  451. package/fesm2022/keycloakify-angular-login-pages-info.mjs.map +1 -0
  452. package/fesm2022/keycloakify-angular-login-pages-login-config-totp.mjs +49 -0
  453. package/fesm2022/keycloakify-angular-login-pages-login-config-totp.mjs.map +1 -0
  454. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm-override.mjs +43 -0
  455. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm-override.mjs.map +1 -0
  456. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm.mjs +43 -0
  457. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm.mjs.map +1 -0
  458. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-email.mjs +43 -0
  459. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-email.mjs.map +1 -0
  460. package/fesm2022/keycloakify-angular-login-pages-login-oauth-grant.mjs +44 -0
  461. package/fesm2022/keycloakify-angular-login-pages-login-oauth-grant.mjs.map +1 -0
  462. package/fesm2022/keycloakify-angular-login-pages-login-oauth2-device-verify-user-code.mjs +47 -0
  463. package/fesm2022/keycloakify-angular-login-pages-login-oauth2-device-verify-user-code.mjs.map +1 -0
  464. package/fesm2022/keycloakify-angular-login-pages-login-otp.mjs +48 -0
  465. package/fesm2022/keycloakify-angular-login-pages-login-otp.mjs.map +1 -0
  466. package/fesm2022/keycloakify-angular-login-pages-login-page-expired.mjs +46 -0
  467. package/fesm2022/keycloakify-angular-login-pages-login-page-expired.mjs.map +1 -0
  468. package/fesm2022/keycloakify-angular-login-pages-login-passkeys-conditional-authenticate.mjs +95 -0
  469. package/fesm2022/keycloakify-angular-login-pages-login-passkeys-conditional-authenticate.mjs.map +1 -0
  470. package/fesm2022/keycloakify-angular-login-pages-login-password.mjs +51 -0
  471. package/fesm2022/keycloakify-angular-login-pages-login-password.mjs.map +1 -0
  472. package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-config.mjs +50 -0
  473. package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-config.mjs.map +1 -0
  474. package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-input.mjs +48 -0
  475. package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-input.mjs.map +1 -0
  476. package/fesm2022/keycloakify-angular-login-pages-login-reset-otp.mjs +47 -0
  477. package/fesm2022/keycloakify-angular-login-pages-login-reset-otp.mjs.map +1 -0
  478. package/fesm2022/keycloakify-angular-login-pages-login-reset-password.mjs +48 -0
  479. package/fesm2022/keycloakify-angular-login-pages-login-reset-password.mjs.map +1 -0
  480. package/fesm2022/keycloakify-angular-login-pages-login-update-password.mjs +50 -0
  481. package/fesm2022/keycloakify-angular-login-pages-login-update-password.mjs.map +1 -0
  482. package/fesm2022/keycloakify-angular-login-pages-login-update-profile.mjs +57 -0
  483. package/fesm2022/keycloakify-angular-login-pages-login-update-profile.mjs.map +1 -0
  484. package/fesm2022/keycloakify-angular-login-pages-login-username.mjs +50 -0
  485. package/fesm2022/keycloakify-angular-login-pages-login-username.mjs.map +1 -0
  486. package/fesm2022/keycloakify-angular-login-pages-login-verify-email.mjs +47 -0
  487. package/fesm2022/keycloakify-angular-login-pages-login-verify-email.mjs.map +1 -0
  488. package/fesm2022/keycloakify-angular-login-pages-login-x509-info.mjs +47 -0
  489. package/fesm2022/keycloakify-angular-login-pages-login-x509-info.mjs.map +1 -0
  490. package/fesm2022/keycloakify-angular-login-pages-login.mjs +51 -0
  491. package/fesm2022/keycloakify-angular-login-pages-login.mjs.map +1 -0
  492. package/fesm2022/keycloakify-angular-login-pages-logout-confirm.mjs +43 -0
  493. package/fesm2022/keycloakify-angular-login-pages-logout-confirm.mjs.map +1 -0
  494. package/fesm2022/keycloakify-angular-login-pages-register.mjs +62 -0
  495. package/fesm2022/keycloakify-angular-login-pages-register.mjs.map +1 -0
  496. package/fesm2022/keycloakify-angular-login-pages-saml-post-form.mjs +57 -0
  497. package/fesm2022/keycloakify-angular-login-pages-saml-post-form.mjs.map +1 -0
  498. package/fesm2022/keycloakify-angular-login-pages-select-authenticator.mjs +48 -0
  499. package/fesm2022/keycloakify-angular-login-pages-select-authenticator.mjs.map +1 -0
  500. package/fesm2022/keycloakify-angular-login-pages-terms.mjs +47 -0
  501. package/fesm2022/keycloakify-angular-login-pages-terms.mjs.map +1 -0
  502. package/fesm2022/keycloakify-angular-login-pages-update-email.mjs +54 -0
  503. package/fesm2022/keycloakify-angular-login-pages-update-email.mjs.map +1 -0
  504. package/fesm2022/keycloakify-angular-login-pages-webauthn-authenticate.mjs +87 -0
  505. package/fesm2022/keycloakify-angular-login-pages-webauthn-authenticate.mjs.map +1 -0
  506. package/fesm2022/keycloakify-angular-login-pages-webauthn-error.mjs +56 -0
  507. package/fesm2022/keycloakify-angular-login-pages-webauthn-error.mjs.map +1 -0
  508. package/fesm2022/keycloakify-angular-login-pages-webauthn-register.mjs +83 -0
  509. package/fesm2022/keycloakify-angular-login-pages-webauthn-register.mjs.map +1 -0
  510. package/fesm2022/keycloakify-angular-login-providers-keycloakify-angular.mjs +59 -0
  511. package/fesm2022/keycloakify-angular-login-providers-keycloakify-angular.mjs.map +1 -0
  512. package/fesm2022/keycloakify-angular-login-services-i18n.mjs +19 -0
  513. package/fesm2022/keycloakify-angular-login-services-i18n.mjs.map +1 -0
  514. package/fesm2022/keycloakify-angular-login-services-login-resource-injector.mjs +75 -0
  515. package/fesm2022/keycloakify-angular-login-services-login-resource-injector.mjs.map +1 -0
  516. package/fesm2022/keycloakify-angular-login-services-submit.mjs +27 -0
  517. package/fesm2022/keycloakify-angular-login-services-submit.mjs.map +1 -0
  518. package/fesm2022/keycloakify-angular-login-services-user-profile-form.mjs +1026 -0
  519. package/fesm2022/keycloakify-angular-login-services-user-profile-form.mjs.map +1 -0
  520. package/fesm2022/keycloakify-angular-login-tokens-classes.mjs +10 -0
  521. package/fesm2022/keycloakify-angular-login-tokens-classes.mjs.map +1 -0
  522. package/fesm2022/keycloakify-angular-login-tokens-i18n.mjs +10 -0
  523. package/fesm2022/keycloakify-angular-login-tokens-i18n.mjs.map +1 -0
  524. package/fesm2022/keycloakify-angular-login-tokens-kc-context.mjs +10 -0
  525. package/fesm2022/keycloakify-angular-login-tokens-kc-context.mjs.map +1 -0
  526. package/fesm2022/keycloakify-angular-login-tokens-make-user-confirm-password.mjs +10 -0
  527. package/fesm2022/keycloakify-angular-login-tokens-make-user-confirm-password.mjs.map +1 -0
  528. package/fesm2022/keycloakify-angular-login.mjs +85 -0
  529. package/fesm2022/keycloakify-angular-login.mjs.map +1 -0
  530. package/fesm2022/keycloakify-angular.mjs +8 -0
  531. package/fesm2022/keycloakify-angular.mjs.map +1 -0
  532. package/index.d.ts +5 -0
  533. package/lib/directives/attributes/index.d.ts +5 -0
  534. package/lib/directives/attributes/public-api.d.ts +1 -0
  535. package/lib/index.d.ts +5 -0
  536. package/lib/models/script/index.d.ts +5 -0
  537. package/lib/models/script/public-api.d.ts +1 -0
  538. package/lib/pipes/input-type/index.d.ts +5 -0
  539. package/lib/pipes/input-type/public-api.d.ts +1 -0
  540. package/lib/pipes/is-array-with-empty-object/index.d.ts +5 -0
  541. package/lib/pipes/is-array-with-empty-object/is-array-with-empty-object.pipe.d.ts +7 -0
  542. package/lib/pipes/is-array-with-empty-object/public-api.d.ts +1 -0
  543. package/lib/pipes/kc-sanitize/index.d.ts +5 -0
  544. package/lib/pipes/kc-sanitize/public-api.d.ts +1 -0
  545. package/lib/pipes/to-array/index.d.ts +5 -0
  546. package/lib/pipes/to-array/public-api.d.ts +1 -0
  547. package/lib/pipes/to-number/index.d.ts +5 -0
  548. package/lib/pipes/to-number/public-api.d.ts +1 -0
  549. package/lib/public-api.d.ts +1 -0
  550. package/lib/services/resource-injector/index.d.ts +5 -0
  551. package/lib/services/resource-injector/public-api.d.ts +1 -0
  552. package/lib/services/{resource-injector.service.d.ts → resource-injector/resource-injector.service.d.ts} +1 -1
  553. package/lib/tokens/use-default-css/index.d.ts +5 -0
  554. package/lib/tokens/use-default-css/public-api.d.ts +1 -0
  555. package/login/KcContext/index.d.ts +5 -0
  556. package/login/KcContext/public-api.d.ts +1 -0
  557. package/login/classes/{component-reference.class.d.ts → component-reference/component-reference.class.d.ts} +1 -1
  558. package/login/classes/component-reference/index.d.ts +5 -0
  559. package/login/classes/component-reference/public-api.d.ts +1 -0
  560. package/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.d.ts +2 -2
  561. package/login/components/add-remove-buttons-multi-valued-attribute/index.d.ts +5 -0
  562. package/login/components/add-remove-buttons-multi-valued-attribute/public-api.d.ts +1 -0
  563. package/login/components/field-errors/field-errors.component.d.ts +3 -3
  564. package/login/components/field-errors/index.d.ts +5 -0
  565. package/login/components/field-errors/public-api.d.ts +1 -0
  566. package/login/components/group-label/group-label.component.d.ts +3 -3
  567. package/login/components/group-label/index.d.ts +5 -0
  568. package/login/components/group-label/public-api.d.ts +1 -0
  569. package/login/components/input-field-by-type/index.d.ts +5 -0
  570. package/login/components/input-field-by-type/input-field-by-type.component.d.ts +3 -3
  571. package/login/components/input-field-by-type/public-api.d.ts +1 -0
  572. package/login/components/input-tag/index.d.ts +5 -0
  573. package/login/components/input-tag/input-tag.component.d.ts +4 -4
  574. package/login/components/input-tag/public-api.d.ts +1 -0
  575. package/login/components/input-tag-selects/index.d.ts +5 -0
  576. package/login/components/input-tag-selects/input-tag-selects.component.d.ts +4 -4
  577. package/login/components/input-tag-selects/public-api.d.ts +1 -0
  578. package/login/components/logout-other-sessions/index.d.ts +5 -0
  579. package/login/components/logout-other-sessions/logout-other-sessions.component.d.ts +3 -3
  580. package/login/components/logout-other-sessions/public-api.d.ts +1 -0
  581. package/login/components/password-wrapper/index.d.ts +5 -0
  582. package/login/components/password-wrapper/password-wrapper.component.d.ts +3 -3
  583. package/login/components/password-wrapper/public-api.d.ts +1 -0
  584. package/login/components/select-tag/index.d.ts +5 -0
  585. package/login/components/select-tag/public-api.d.ts +1 -0
  586. package/login/components/select-tag/select-tag.component.d.ts +4 -4
  587. package/login/components/textarea-tag/index.d.ts +5 -0
  588. package/login/components/textarea-tag/public-api.d.ts +1 -0
  589. package/login/components/textarea-tag/textarea-tag.component.d.ts +3 -3
  590. package/login/components/user-profile-form-fields/index.d.ts +5 -0
  591. package/login/components/user-profile-form-fields/public-api.d.ts +1 -0
  592. package/login/components/user-profile-form-fields/user-profile-form-fields.component.d.ts +6 -6
  593. package/login/containers/template/index.d.ts +5 -0
  594. package/login/containers/template/public-api.d.ts +1 -0
  595. package/login/containers/template/template.component.d.ts +46 -0
  596. package/login/defaultPage.d.ts +3 -0
  597. package/login/directives/kc-class/index.d.ts +5 -0
  598. package/login/directives/kc-class/public-api.d.ts +1 -0
  599. package/login/i18n/index.d.ts +5 -0
  600. package/login/i18n/public-api.d.ts +1 -0
  601. package/login/index.d.ts +5 -0
  602. package/login/login.d.ts +14 -0
  603. package/login/pages/code/code.component.d.ts +14 -5
  604. package/login/pages/code/index.d.ts +5 -0
  605. package/login/pages/code/public-api.d.ts +1 -0
  606. package/login/pages/delete-account-confirm/delete-account-confirm.component.d.ts +14 -5
  607. package/login/pages/delete-account-confirm/index.d.ts +5 -0
  608. package/login/pages/delete-account-confirm/public-api.d.ts +1 -0
  609. package/login/pages/delete-credential/delete-credential.component.d.ts +12 -8
  610. package/login/pages/delete-credential/index.d.ts +5 -0
  611. package/login/pages/delete-credential/public-api.d.ts +1 -0
  612. package/login/pages/error/error.component.d.ts +14 -5
  613. package/login/pages/error/index.d.ts +5 -0
  614. package/login/pages/error/public-api.d.ts +1 -0
  615. package/login/pages/frontchannel-logout/frontchannel-logout.component.d.ts +12 -8
  616. package/login/pages/frontchannel-logout/index.d.ts +5 -0
  617. package/login/pages/frontchannel-logout/public-api.d.ts +1 -0
  618. package/login/pages/idp-review-user-profile/idp-review-user-profile.component.d.ts +14 -11
  619. package/login/pages/idp-review-user-profile/index.d.ts +5 -0
  620. package/login/pages/idp-review-user-profile/public-api.d.ts +1 -0
  621. package/login/pages/info/index.d.ts +5 -0
  622. package/login/pages/info/info.component.d.ts +12 -8
  623. package/login/pages/info/public-api.d.ts +1 -0
  624. package/login/pages/login/index.d.ts +5 -0
  625. package/login/pages/login/login.component.d.ts +13 -9
  626. package/login/pages/login/public-api.d.ts +1 -0
  627. package/login/pages/login-config-totp/index.d.ts +5 -0
  628. package/login/pages/login-config-totp/login-config-totp.component.d.ts +12 -8
  629. package/login/pages/login-config-totp/public-api.d.ts +1 -0
  630. package/login/pages/login-idp-link-confirm/index.d.ts +5 -0
  631. package/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.d.ts +11 -10
  632. package/login/pages/login-idp-link-confirm/public-api.d.ts +1 -0
  633. package/login/pages/login-idp-link-confirm-override/index.d.ts +5 -0
  634. package/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.d.ts +11 -10
  635. package/login/pages/login-idp-link-confirm-override/public-api.d.ts +1 -0
  636. package/login/pages/login-idp-link-email/index.d.ts +5 -0
  637. package/login/pages/login-idp-link-email/login-idp-link-email.component.d.ts +11 -10
  638. package/login/pages/login-idp-link-email/public-api.d.ts +1 -0
  639. package/login/pages/login-oauth-grant/index.d.ts +5 -0
  640. package/login/pages/login-oauth-grant/login-oauth-grant.component.d.ts +11 -10
  641. package/login/pages/login-oauth-grant/public-api.d.ts +1 -0
  642. package/login/pages/login-oauth2-device-verify-user-code/index.d.ts +5 -0
  643. package/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.d.ts +12 -8
  644. package/login/pages/login-oauth2-device-verify-user-code/public-api.d.ts +1 -0
  645. package/login/pages/login-otp/index.d.ts +5 -0
  646. package/login/pages/login-otp/login-otp.component.d.ts +12 -8
  647. package/login/pages/login-otp/public-api.d.ts +1 -0
  648. package/login/pages/login-page-expired/index.d.ts +5 -0
  649. package/login/pages/login-page-expired/login-page-expired.component.d.ts +12 -8
  650. package/login/pages/login-page-expired/public-api.d.ts +1 -0
  651. package/login/pages/login-passkeys-conditional-authenticate/index.d.ts +5 -0
  652. package/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.d.ts +13 -5
  653. package/login/pages/login-passkeys-conditional-authenticate/public-api.d.ts +1 -0
  654. package/login/pages/login-password/index.d.ts +5 -0
  655. package/login/pages/login-password/login-password.component.d.ts +13 -8
  656. package/login/pages/login-password/public-api.d.ts +1 -0
  657. package/login/pages/login-recovery-authn-code-config/index.d.ts +5 -0
  658. package/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.d.ts +12 -8
  659. package/login/pages/login-recovery-authn-code-config/public-api.d.ts +1 -0
  660. package/login/pages/login-recovery-authn-code-input/index.d.ts +5 -0
  661. package/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.d.ts +12 -8
  662. package/login/pages/login-recovery-authn-code-input/public-api.d.ts +1 -0
  663. package/login/pages/login-reset-otp/index.d.ts +5 -0
  664. package/login/pages/login-reset-otp/login-reset-otp.component.d.ts +12 -8
  665. package/login/pages/login-reset-otp/public-api.d.ts +1 -0
  666. package/login/pages/login-reset-password/index.d.ts +5 -0
  667. package/login/pages/login-reset-password/login-reset-password.component.d.ts +12 -8
  668. package/login/pages/login-reset-password/public-api.d.ts +1 -0
  669. package/login/pages/login-update-password/index.d.ts +5 -0
  670. package/login/pages/login-update-password/login-update-password.component.d.ts +12 -8
  671. package/login/pages/login-update-password/public-api.d.ts +1 -0
  672. package/login/pages/login-update-profile/index.d.ts +5 -0
  673. package/login/pages/login-update-profile/login-update-profile.component.d.ts +13 -10
  674. package/login/pages/login-update-profile/public-api.d.ts +1 -0
  675. package/login/pages/login-username/index.d.ts +5 -0
  676. package/login/pages/login-username/login-username.component.d.ts +13 -9
  677. package/login/pages/login-username/public-api.d.ts +1 -0
  678. package/login/pages/login-verify-email/index.d.ts +5 -0
  679. package/login/pages/login-verify-email/login-verify-email.component.d.ts +12 -8
  680. package/login/pages/login-verify-email/public-api.d.ts +1 -0
  681. package/login/pages/login-x509-info/index.d.ts +5 -0
  682. package/login/pages/login-x509-info/login-x509-info.component.d.ts +12 -8
  683. package/login/pages/login-x509-info/public-api.d.ts +1 -0
  684. package/login/pages/logout-confirm/index.d.ts +5 -0
  685. package/login/pages/logout-confirm/logout-confirm.component.d.ts +11 -10
  686. package/login/pages/logout-confirm/public-api.d.ts +1 -0
  687. package/login/pages/register/index.d.ts +5 -0
  688. package/login/pages/register/public-api.d.ts +1 -0
  689. package/login/pages/register/register.component.d.ts +15 -12
  690. package/login/pages/saml-post-form/index.d.ts +5 -0
  691. package/login/pages/saml-post-form/public-api.d.ts +1 -0
  692. package/login/pages/saml-post-form/saml-post-form.component.d.ts +13 -10
  693. package/login/pages/select-authenticator/index.d.ts +5 -0
  694. package/login/pages/select-authenticator/public-api.d.ts +1 -0
  695. package/login/pages/select-authenticator/select-authenticator.component.d.ts +12 -8
  696. package/login/pages/terms/index.d.ts +5 -0
  697. package/login/pages/terms/public-api.d.ts +1 -0
  698. package/login/pages/terms/terms.component.d.ts +12 -8
  699. package/login/pages/update-email/index.d.ts +5 -0
  700. package/login/pages/update-email/public-api.d.ts +1 -0
  701. package/login/pages/update-email/update-email.component.d.ts +13 -13
  702. package/login/pages/webauthn-authenticate/index.d.ts +5 -0
  703. package/login/pages/webauthn-authenticate/public-api.d.ts +1 -0
  704. package/login/pages/webauthn-authenticate/webauthn-authenticate.component.d.ts +12 -8
  705. package/login/pages/webauthn-error/index.d.ts +5 -0
  706. package/login/pages/webauthn-error/public-api.d.ts +1 -0
  707. package/login/pages/webauthn-error/webauthn-error.component.d.ts +12 -8
  708. package/login/pages/webauthn-register/index.d.ts +5 -0
  709. package/login/pages/webauthn-register/public-api.d.ts +1 -0
  710. package/login/pages/webauthn-register/webauthn-register.component.d.ts +13 -9
  711. package/login/providers/keycloakify-angular/index.d.ts +5 -0
  712. package/login/providers/{keycloakify-angular.providers.d.ts → keycloakify-angular/keycloakify-angular.providers.d.ts} +4 -2
  713. package/login/providers/keycloakify-angular/public-api.d.ts +1 -0
  714. package/login/public-api.d.ts +1 -0
  715. package/login/services/i18n/i18n.service.d.ts +6 -0
  716. package/login/services/i18n/index.d.ts +5 -0
  717. package/login/services/i18n/public-api.d.ts +1 -0
  718. package/login/services/login-resource-injector/index.d.ts +5 -0
  719. package/login/services/{login-resource-injector.service.d.ts → login-resource-injector/login-resource-injector.service.d.ts} +1 -1
  720. package/login/services/login-resource-injector/public-api.d.ts +1 -0
  721. package/login/services/submit/index.d.ts +5 -0
  722. package/login/services/submit/public-api.d.ts +1 -0
  723. package/login/services/user-profile-form/index.d.ts +5 -0
  724. package/login/services/user-profile-form/public-api.d.ts +1 -0
  725. package/login/services/{user-profile-form.service.d.ts → user-profile-form/user-profile-form.service.d.ts} +1 -1
  726. package/login/tokens/classes/index.d.ts +5 -0
  727. package/login/tokens/classes/public-api.d.ts +1 -0
  728. package/login/tokens/i18n/index.d.ts +5 -0
  729. package/login/tokens/i18n/public-api.d.ts +1 -0
  730. package/login/tokens/kc-context/index.d.ts +5 -0
  731. package/login/tokens/{kc-context.token.d.ts → kc-context/kc-context.token.d.ts} +1 -1
  732. package/login/tokens/kc-context/public-api.d.ts +1 -0
  733. package/login/tokens/make-user-confirm-password/index.d.ts +5 -0
  734. package/login/tokens/make-user-confirm-password/public-api.d.ts +1 -0
  735. package/package.json +597 -322
  736. package/public-api.d.ts +1 -0
  737. package/src/account/DefaultPage.ts +61 -0
  738. package/src/account/KcContext.ts +1 -0
  739. package/src/account/account.ts +13 -0
  740. package/src/account/classes/component-reference/component-reference.class.ts +6 -0
  741. package/src/account/classes/component-reference/index.ts +1 -0
  742. package/src/account/containers/template/index.ts +1 -0
  743. package/src/account/containers/template/template.component.html +130 -0
  744. package/src/account/containers/template/template.component.ts +116 -0
  745. package/src/account/defaultPage.ts +44 -0
  746. package/src/account/directives/kc-class/index.ts +1 -0
  747. package/src/account/directives/kc-class/kc-class.directive.ts +170 -0
  748. package/src/account/i18n.ts +4 -0
  749. package/src/account/index.ts +1 -0
  750. package/src/account/pages/account/account.component.html +161 -0
  751. package/src/account/pages/account/account.component.ts +34 -0
  752. package/src/account/pages/account/index.ts +1 -0
  753. package/src/account/pages/applications/applications.component.html +148 -0
  754. package/src/account/pages/applications/applications.component.ts +32 -0
  755. package/src/account/pages/applications/index.ts +1 -0
  756. package/src/account/pages/federatedIdentity/federatedIdentity.component.html +93 -0
  757. package/src/account/pages/federatedIdentity/federatedIdentity.component.ts +31 -0
  758. package/src/account/pages/federatedIdentity/index.ts +1 -0
  759. package/src/account/pages/log/index.ts +1 -0
  760. package/src/account/pages/log/log.component.html +40 -0
  761. package/src/account/pages/log/log.component.ts +31 -0
  762. package/src/account/pages/password/index.ts +1 -0
  763. package/src/account/pages/password/password.component.html +127 -0
  764. package/src/account/pages/password/password.component.ts +112 -0
  765. package/src/account/pages/sessions/index.ts +1 -0
  766. package/src/account/pages/sessions/sessions.component.html +59 -0
  767. package/src/account/pages/sessions/sessions.component.ts +31 -0
  768. package/src/account/pages/totp/index.ts +1 -0
  769. package/src/account/pages/totp/totp.component.html +254 -0
  770. package/src/account/pages/totp/totp.component.ts +32 -0
  771. package/src/account/providers/keycloakify-angular/index.ts +1 -0
  772. package/src/account/providers/keycloakify-angular/keycloakify-angular.providers.ts +62 -0
  773. package/src/account/services/account-resource-injector/account-resource-injector.service.ts +41 -0
  774. package/src/account/services/account-resource-injector/index.ts +1 -0
  775. package/src/account/services/i18n/index.ts +1 -0
  776. package/src/account/tokens/classes/classes.token.ts +6 -0
  777. package/src/account/tokens/classes/index.ts +1 -0
  778. package/src/account/tokens/i18n/i18n.token.ts +3 -0
  779. package/src/account/tokens/i18n/index.ts +1 -0
  780. package/src/account/tokens/kc-context/index.ts +1 -0
  781. package/src/account/tokens/kc-context/kc-context.token.ts +6 -0
  782. package/src/bin/core.ts +10 -0
  783. package/src/bin/eject-page.ts +421 -0
  784. package/src/bin/initialize-account-theme/boilerplate/KcContext.ts +11 -0
  785. package/src/bin/initialize-account-theme/boilerplate/KcContextMock.ts +18 -0
  786. package/src/bin/initialize-account-theme/boilerplate/KcPage.ts +19 -0
  787. package/src/bin/initialize-account-theme/boilerplate/i18n.ts +11 -0
  788. package/src/bin/initialize-account-theme/initialize-account-theme.ts +98 -0
  789. package/src/bin/initialize-account-theme/updateAccountThemeImplementationInConfig.ts +101 -0
  790. package/src/bin/main.ts +38 -0
  791. package/src/bin/tools/SemVer.ts +114 -0
  792. package/src/bin/tools/String.prototype.replaceAll.ts +37 -0
  793. package/src/bin/tools/crawl.ts +35 -0
  794. package/src/bin/tools/fs.rmSync.ts +34 -0
  795. package/src/bin/tools/getThisCodebaseRootDirPath.ts +19 -0
  796. package/src/bin/tools/kebabCaseToSnakeCase.ts +7 -0
  797. package/src/bin/tools/transformCodebase.ts +88 -0
  798. package/src/bin/tsconfig.json +20 -0
  799. package/src/bin/update-kc-gen.ts +149 -0
  800. package/src/index.ts +1 -0
  801. package/src/lib/directives/attributes/index.ts +1 -0
  802. package/src/lib/index.ts +1 -0
  803. package/src/lib/models/script/index.ts +1 -0
  804. package/src/lib/pipes/input-type/index.ts +1 -0
  805. package/src/lib/pipes/is-array-with-empty-object/index.ts +1 -0
  806. package/src/lib/pipes/is-array-with-empty-object/is-array-with-empty-object.pipe.ts +16 -0
  807. package/src/lib/pipes/kc-sanitize/index.ts +1 -0
  808. package/src/lib/pipes/to-array/index.ts +1 -0
  809. package/src/{login/pipes → lib/pipes/to-array}/to-array.pipe.ts +1 -0
  810. package/src/lib/pipes/to-number/index.ts +1 -0
  811. package/src/lib/services/resource-injector/index.ts +1 -0
  812. package/src/lib/services/{resource-injector.service.ts → resource-injector/resource-injector.service.ts} +1 -1
  813. package/src/lib/tokens/use-default-css/index.ts +1 -0
  814. package/src/login/classes/{component-reference.class.ts → component-reference/component-reference.class.ts} +1 -1
  815. package/src/login/classes/component-reference/index.ts +1 -0
  816. package/src/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.html +2 -2
  817. package/src/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.ts +3 -3
  818. package/src/login/components/add-remove-buttons-multi-valued-attribute/index.ts +1 -0
  819. package/src/login/components/field-errors/field-errors.component.html +1 -1
  820. package/src/login/components/field-errors/field-errors.component.ts +6 -6
  821. package/src/login/components/field-errors/index.ts +1 -0
  822. package/src/login/components/group-label/group-label.component.ts +8 -8
  823. package/src/login/components/group-label/index.ts +1 -0
  824. package/src/login/components/input-field-by-type/index.ts +1 -0
  825. package/src/login/components/input-field-by-type/input-field-by-type.component.html +6 -6
  826. package/src/login/components/input-field-by-type/input-field-by-type.component.ts +11 -11
  827. package/src/login/components/input-tag/index.ts +1 -0
  828. package/src/login/components/input-tag/input-tag.component.html +2 -2
  829. package/src/login/components/input-tag/input-tag.component.ts +14 -14
  830. package/src/login/components/input-tag-selects/index.ts +1 -0
  831. package/src/login/components/input-tag-selects/input-tag-selects.component.ts +8 -8
  832. package/src/login/components/logout-other-sessions/index.ts +1 -0
  833. package/src/login/components/logout-other-sessions/logout-other-sessions.component.ts +8 -8
  834. package/src/login/components/password-wrapper/index.ts +1 -0
  835. package/src/login/components/password-wrapper/password-wrapper.component.html +2 -2
  836. package/src/login/components/password-wrapper/password-wrapper.component.ts +8 -8
  837. package/src/login/components/select-tag/index.ts +1 -0
  838. package/src/login/components/select-tag/select-tag.component.ts +9 -9
  839. package/src/login/components/textarea-tag/index.ts +1 -0
  840. package/src/login/components/textarea-tag/textarea-tag.component.ts +7 -7
  841. package/src/login/components/user-profile-form-fields/index.ts +1 -0
  842. package/src/login/components/user-profile-form-fields/user-profile-form-fields.component.html +7 -11
  843. package/src/login/components/user-profile-form-fields/user-profile-form-fields.component.ts +15 -15
  844. package/src/login/containers/template/index.ts +1 -0
  845. package/src/login/containers/{template.component.html → template/template.component.html} +30 -15
  846. package/src/login/containers/template/template.component.ts +162 -0
  847. package/src/login/defaultPage.ts +153 -0
  848. package/src/login/directives/kc-class/index.ts +1 -0
  849. package/src/login/directives/{kc-class.directive.ts → kc-class/kc-class.directive.ts} +2 -3
  850. package/src/login/index.ts +1 -0
  851. package/src/login/login.ts +15 -0
  852. package/src/login/pages/code/code.component.html +20 -23
  853. package/src/login/pages/code/code.component.ts +24 -13
  854. package/src/login/pages/code/index.ts +1 -0
  855. package/src/login/pages/delete-account-confirm/delete-account-confirm.component.html +41 -45
  856. package/src/login/pages/delete-account-confirm/delete-account-confirm.component.ts +24 -13
  857. package/src/login/pages/delete-account-confirm/index.ts +1 -0
  858. package/src/login/pages/delete-credential/delete-credential.component.html +29 -31
  859. package/src/login/pages/delete-credential/delete-credential.component.ts +24 -18
  860. package/src/login/pages/delete-credential/index.ts +1 -0
  861. package/src/login/pages/error/error.component.html +19 -22
  862. package/src/login/pages/error/error.component.ts +24 -13
  863. package/src/login/pages/error/index.ts +1 -0
  864. package/src/login/pages/frontchannel-logout/frontchannel-logout.component.html +25 -34
  865. package/src/login/pages/frontchannel-logout/frontchannel-logout.component.ts +24 -17
  866. package/src/login/pages/frontchannel-logout/index.ts +1 -0
  867. package/src/login/pages/idp-review-user-profile/idp-review-user-profile.component.html +29 -38
  868. package/src/login/pages/idp-review-user-profile/idp-review-user-profile.component.ts +27 -22
  869. package/src/login/pages/idp-review-user-profile/index.ts +1 -0
  870. package/src/login/pages/info/index.ts +1 -0
  871. package/src/login/pages/info/info.component.html +41 -50
  872. package/src/login/pages/info/info.component.ts +24 -18
  873. package/src/login/pages/login/index.ts +1 -0
  874. package/src/login/pages/login/login.component.html +187 -195
  875. package/src/login/pages/login/login.component.ts +29 -22
  876. package/src/login/pages/login-config-totp/index.ts +1 -0
  877. package/src/login/pages/login-config-totp/login-config-totp.component.html +181 -190
  878. package/src/login/pages/login-config-totp/login-config-totp.component.ts +25 -20
  879. package/src/login/pages/login-idp-link-confirm/index.ts +1 -0
  880. package/src/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.html +27 -37
  881. package/src/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.ts +20 -20
  882. package/src/login/pages/login-idp-link-confirm-override/index.ts +1 -0
  883. package/src/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.html +26 -36
  884. package/src/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.ts +20 -20
  885. package/src/login/pages/login-idp-link-email/index.ts +1 -0
  886. package/src/login/pages/login-idp-link-email/login-idp-link-email.component.html +26 -34
  887. package/src/login/pages/login-idp-link-email/login-idp-link-email.component.ts +20 -20
  888. package/src/login/pages/login-oauth-grant/index.ts +1 -0
  889. package/src/login/pages/login-oauth-grant/login-oauth-grant.component.html +76 -84
  890. package/src/login/pages/login-oauth-grant/login-oauth-grant.component.ts +20 -20
  891. package/src/login/pages/login-oauth2-device-verify-user-code/index.ts +1 -0
  892. package/src/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.html +49 -58
  893. package/src/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.ts +23 -18
  894. package/src/login/pages/login-otp/index.ts +1 -0
  895. package/src/login/pages/login-otp/login-otp.component.html +89 -98
  896. package/src/login/pages/login-otp/login-otp.component.ts +24 -18
  897. package/src/login/pages/login-page-expired/index.ts +1 -0
  898. package/src/login/pages/login-page-expired/login-page-expired.component.html +25 -33
  899. package/src/login/pages/login-page-expired/login-page-expired.component.ts +22 -17
  900. package/src/login/pages/login-passkeys-conditional-authenticate/index.ts +1 -0
  901. package/src/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.html +173 -179
  902. package/src/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.ts +24 -15
  903. package/src/login/pages/login-password/index.ts +1 -0
  904. package/src/login/pages/login-password/login-password.component.html +75 -83
  905. package/src/login/pages/login-password/login-password.component.ts +26 -19
  906. package/src/login/pages/login-recovery-authn-code-config/index.ts +1 -0
  907. package/src/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.html +136 -145
  908. package/src/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.ts +26 -19
  909. package/src/login/pages/login-recovery-authn-code-input/index.ts +1 -0
  910. package/src/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.html +59 -69
  911. package/src/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.ts +24 -18
  912. package/src/login/pages/login-reset-otp/index.ts +1 -0
  913. package/src/login/pages/login-reset-otp/login-reset-otp.component.html +54 -62
  914. package/src/login/pages/login-reset-otp/login-reset-otp.component.ts +23 -17
  915. package/src/login/pages/login-reset-password/index.ts +1 -0
  916. package/src/login/pages/login-reset-password/login-reset-password.component.html +78 -86
  917. package/src/login/pages/login-reset-password/login-reset-password.component.ts +24 -18
  918. package/src/login/pages/login-update-password/index.ts +1 -0
  919. package/src/login/pages/login-update-password/login-update-password.component.html +98 -108
  920. package/src/login/pages/login-update-password/login-update-password.component.ts +25 -19
  921. package/src/login/pages/login-update-profile/index.ts +1 -0
  922. package/src/login/pages/login-update-profile/login-update-profile.component.html +44 -53
  923. package/src/login/pages/login-update-profile/login-update-profile.component.ts +26 -20
  924. package/src/login/pages/login-username/index.ts +1 -0
  925. package/src/login/pages/login-username/login-username.component.html +141 -149
  926. package/src/login/pages/login-username/login-username.component.ts +25 -19
  927. package/src/login/pages/login-verify-email/index.ts +1 -0
  928. package/src/login/pages/login-verify-email/login-verify-email.component.html +18 -26
  929. package/src/login/pages/login-verify-email/login-verify-email.component.ts +23 -18
  930. package/src/login/pages/login-x509-info/index.ts +1 -0
  931. package/src/login/pages/login-x509-info/login-x509-info.component.html +85 -94
  932. package/src/login/pages/login-x509-info/login-x509-info.component.ts +23 -18
  933. package/src/login/pages/logout-confirm/index.ts +1 -0
  934. package/src/login/pages/logout-confirm/logout-confirm.component.html +39 -49
  935. package/src/login/pages/logout-confirm/logout-confirm.component.ts +20 -20
  936. package/src/login/pages/register/index.ts +1 -0
  937. package/src/login/pages/register/register.component.html +101 -111
  938. package/src/login/pages/register/register.component.ts +29 -23
  939. package/src/login/pages/saml-post-form/index.ts +1 -0
  940. package/src/login/pages/saml-post-form/saml-post-form.component.html +39 -48
  941. package/src/login/pages/saml-post-form/saml-post-form.component.ts +26 -21
  942. package/src/login/pages/select-authenticator/index.ts +1 -0
  943. package/src/login/pages/select-authenticator/select-authenticator.component.html +37 -45
  944. package/src/login/pages/select-authenticator/select-authenticator.component.ts +24 -18
  945. package/src/login/pages/terms/index.ts +1 -0
  946. package/src/login/pages/terms/terms.component.html +25 -34
  947. package/src/login/pages/terms/terms.component.ts +24 -18
  948. package/src/login/pages/update-email/index.ts +1 -0
  949. package/src/login/pages/update-email/update-email.component.html +44 -53
  950. package/src/login/pages/update-email/update-email.component.ts +24 -24
  951. package/src/login/pages/webauthn-authenticate/index.ts +1 -0
  952. package/src/login/pages/webauthn-authenticate/webauthn-authenticate.component.html +135 -145
  953. package/src/login/pages/webauthn-authenticate/webauthn-authenticate.component.ts +26 -20
  954. package/src/login/pages/webauthn-error/index.ts +1 -0
  955. package/src/login/pages/webauthn-error/webauthn-error.component.html +45 -55
  956. package/src/login/pages/webauthn-error/webauthn-error.component.ts +25 -19
  957. package/src/login/pages/webauthn-register/index.ts +1 -0
  958. package/src/login/pages/webauthn-register/webauthn-register.component.html +65 -75
  959. package/src/login/pages/webauthn-register/webauthn-register.component.ts +27 -21
  960. package/src/login/providers/keycloakify-angular/index.ts +1 -0
  961. package/src/login/providers/{keycloakify-angular.providers.ts → keycloakify-angular/keycloakify-angular.providers.ts} +11 -11
  962. package/src/login/services/i18n/i18n.service.ts +7 -0
  963. package/src/login/services/i18n/index.ts +1 -0
  964. package/src/login/services/login-resource-injector/index.ts +1 -0
  965. package/src/login/services/{login-resource-injector.service.ts → login-resource-injector/login-resource-injector.service.ts} +4 -4
  966. package/src/login/services/submit/index.ts +1 -0
  967. package/src/login/services/{submit.service.ts → submit/submit.service.ts} +1 -1
  968. package/src/login/services/user-profile-form/index.ts +1 -0
  969. package/src/login/services/{user-profile-form.service.ts → user-profile-form/user-profile-form.service.ts} +6 -6
  970. package/src/login/tokens/{classes.token.ts → classes/classes.token.ts} +1 -1
  971. package/src/login/tokens/classes/index.ts +1 -0
  972. package/src/login/tokens/i18n/index.ts +1 -0
  973. package/src/login/tokens/kc-context/index.ts +1 -0
  974. package/src/login/tokens/{kc-context.token.ts → kc-context/kc-context.token.ts} +1 -1
  975. package/src/login/tokens/make-user-confirm-password/index.ts +1 -0
  976. package/lib/models/script.model.js +0 -2
  977. package/lib/services/resource-injector.service.js +0 -54
  978. package/lib/tokens/use-default-css.token.js +0 -3
  979. package/login/DefaultPage.d.ts +0 -260
  980. package/login/DefaultPage.js +0 -121
  981. package/login/KcContext.js +0 -2
  982. package/login/classes/component-reference.class.js +0 -3
  983. package/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.js +0 -106
  984. package/login/components/field-errors/field-errors.component.js +0 -33
  985. package/login/components/group-label/group-label.component.js +0 -43
  986. package/login/components/input-field-by-type/input-field-by-type.component.js +0 -46
  987. package/login/components/input-tag/input-tag.component.js +0 -90
  988. package/login/components/input-tag-selects/input-tag-selects.component.js +0 -117
  989. package/login/components/logout-other-sessions/logout-other-sessions.component.js +0 -32
  990. package/login/components/password-wrapper/password-wrapper.component.js +0 -46
  991. package/login/components/select-tag/select-tag.component.js +0 -82
  992. package/login/components/textarea-tag/textarea-tag.component.js +0 -49
  993. package/login/components/user-profile-form-fields/user-profile-form-fields.component.js +0 -62
  994. package/login/containers/template.component.d.ts +0 -31
  995. package/login/containers/template.component.js +0 -72
  996. package/login/directives/attributes.directive.js +0 -26
  997. package/login/directives/kc-class.directive.js +0 -138
  998. package/login/i18n.js +0 -2
  999. package/login/pages/code/code.component.js +0 -35
  1000. package/login/pages/delete-account-confirm/delete-account-confirm.component.js +0 -35
  1001. package/login/pages/delete-credential/delete-credential.component.js +0 -40
  1002. package/login/pages/error/error.component.js +0 -35
  1003. package/login/pages/frontchannel-logout/frontchannel-logout.component.js +0 -44
  1004. package/login/pages/idp-review-user-profile/idp-review-user-profile.component.js +0 -53
  1005. package/login/pages/info/info.component.js +0 -49
  1006. package/login/pages/login/login.component.js +0 -44
  1007. package/login/pages/login-config-totp/login-config-totp.component.js +0 -42
  1008. package/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.js +0 -40
  1009. package/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.js +0 -40
  1010. package/login/pages/login-idp-link-email/login-idp-link-email.component.js +0 -40
  1011. package/login/pages/login-oauth-grant/login-oauth-grant.component.js +0 -40
  1012. package/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.js +0 -40
  1013. package/login/pages/login-otp/login-otp.component.js +0 -41
  1014. package/login/pages/login-page-expired/login-page-expired.component.js +0 -39
  1015. package/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.js +0 -84
  1016. package/login/pages/login-password/login-password.component.js +0 -43
  1017. package/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.js +0 -43
  1018. package/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.js +0 -41
  1019. package/login/pages/login-reset-otp/login-reset-otp.component.js +0 -40
  1020. package/login/pages/login-reset-password/login-reset-password.component.js +0 -41
  1021. package/login/pages/login-update-password/login-update-password.component.js +0 -43
  1022. package/login/pages/login-update-profile/login-update-profile.component.js +0 -50
  1023. package/login/pages/login-username/login-username.component.js +0 -43
  1024. package/login/pages/login-verify-email/login-verify-email.component.js +0 -40
  1025. package/login/pages/login-x509-info/login-x509-info.component.js +0 -40
  1026. package/login/pages/logout-confirm/logout-confirm.component.js +0 -40
  1027. package/login/pages/register/register.component.js +0 -55
  1028. package/login/pages/saml-post-form/saml-post-form.component.js +0 -52
  1029. package/login/pages/select-authenticator/select-authenticator.component.js +0 -41
  1030. package/login/pages/terms/terms.component.js +0 -40
  1031. package/login/pages/update-email/update-email.component.js +0 -51
  1032. package/login/pages/webauthn-authenticate/webauthn-authenticate.component.js +0 -80
  1033. package/login/pages/webauthn-error/webauthn-error.component.js +0 -49
  1034. package/login/pages/webauthn-register/webauthn-register.component.js +0 -76
  1035. package/login/pipes/input-type.pipe.js +0 -20
  1036. package/login/pipes/kc-sanitize.pipe.js +0 -29
  1037. package/login/pipes/to-array.pipe.js +0 -20
  1038. package/login/pipes/to-number.pipe.js +0 -20
  1039. package/login/providers/keycloakify-angular.providers.js +0 -53
  1040. package/login/services/i18n.service.js +0 -12
  1041. package/login/services/login-resource-injector.service.js +0 -68
  1042. package/login/services/submit.service.js +0 -20
  1043. package/login/services/user-profile-form.service.js +0 -1019
  1044. package/login/tokens/classes.token.js +0 -3
  1045. package/login/tokens/i18n.token.js +0 -3
  1046. package/login/tokens/kc-context.token.js +0 -3
  1047. package/login/tokens/make-user-confirm-password.token.js +0 -3
  1048. package/src/login/DefaultPage.ts +0 -208
  1049. package/src/login/containers/template.component.ts +0 -78
  1050. package/src/tsconfig.json +0 -23
  1051. /package/{login/services → account/services/i18n}/i18n.service.d.ts +0 -0
  1052. /package/{login/directives → lib/directives/attributes}/attributes.directive.d.ts +0 -0
  1053. /package/lib/models/{script.model.d.ts → script/script.model.d.ts} +0 -0
  1054. /package/{login/pipes → lib/pipes/input-type}/input-type.pipe.d.ts +0 -0
  1055. /package/{login/pipes → lib/pipes/kc-sanitize}/kc-sanitize.pipe.d.ts +0 -0
  1056. /package/{login/pipes → lib/pipes/to-array}/to-array.pipe.d.ts +0 -0
  1057. /package/{login/pipes → lib/pipes/to-number}/to-number.pipe.d.ts +0 -0
  1058. /package/lib/tokens/{use-default-css.token.d.ts → use-default-css/use-default-css.token.d.ts} +0 -0
  1059. /package/login/{KcContext.d.ts → KcContext/KcContext.d.ts} +0 -0
  1060. /package/login/directives/{kc-class.directive.d.ts → kc-class/kc-class.directive.d.ts} +0 -0
  1061. /package/login/{i18n.d.ts → i18n/i18n.d.ts} +0 -0
  1062. /package/login/services/{submit.service.d.ts → submit/submit.service.d.ts} +0 -0
  1063. /package/login/tokens/{classes.token.d.ts → classes/classes.token.d.ts} +0 -0
  1064. /package/login/tokens/{i18n.token.d.ts → i18n/i18n.token.d.ts} +0 -0
  1065. /package/login/tokens/{make-user-confirm-password.token.d.ts → make-user-confirm-password/make-user-confirm-password.token.d.ts} +0 -0
  1066. /package/src/{login/services → account/services/i18n}/i18n.service.ts +0 -0
  1067. /package/src/{login/directives → lib/directives/attributes}/attributes.directive.ts +0 -0
  1068. /package/src/lib/models/{script.model.ts → script/script.model.ts} +0 -0
  1069. /package/src/{login/pipes → lib/pipes/input-type}/input-type.pipe.ts +0 -0
  1070. /package/src/{login/pipes → lib/pipes/kc-sanitize}/kc-sanitize.pipe.ts +0 -0
  1071. /package/src/{login/pipes → lib/pipes/to-number}/to-number.pipe.ts +0 -0
  1072. /package/src/lib/tokens/{use-default-css.token.ts → use-default-css/use-default-css.token.ts} +0 -0
  1073. /package/src/login/tokens/{i18n.token.ts → i18n/i18n.token.ts} +0 -0
  1074. /package/src/login/tokens/{make-user-confirm-password.token.ts → make-user-confirm-password/make-user-confirm-password.token.ts} +0 -0
  1075. /package/{stories → src/stories}/login/pages/login/login.stories.ts +0 -0
@@ -0,0 +1,1026 @@
1
+ import * as i0 from '@angular/core';
2
+ import { inject, signal, computed, Injectable } from '@angular/core';
3
+ import { DomSanitizer } from '@angular/platform-browser';
4
+ import { LoginResourceInjectorService } from '@keycloakify/angular/login/services/login-resource-injector';
5
+ import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
6
+ import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
7
+ import { DO_MAKE_USER_CONFIRM_PASSWORD } from '@keycloakify/angular/login/tokens/make-user-confirm-password';
8
+ import { emailRegexp } from 'keycloakify/tools/emailRegExp';
9
+ import { formatNumber } from 'keycloakify/tools/formatNumber';
10
+ import { structuredCloneButFunctions } from 'keycloakify/tools/structuredCloneButFunctions';
11
+ import { id, assert } from 'tsafe';
12
+
13
+ /* eslint-disable @typescript-eslint/no-explicit-any */
14
+ /* eslint-disable @typescript-eslint/ban-ts-comment */
15
+ class UserProfileFormService {
16
+ constructor() {
17
+ this.kcContext = inject(KC_LOGIN_CONTEXT);
18
+ this.i18n = inject(LOGIN_I18N);
19
+ this.doMakeUserConfirmPassword = inject(DO_MAKE_USER_CONFIRM_PASSWORD);
20
+ this.loginResourceInjectorService = inject(LoginResourceInjectorService);
21
+ this.sanitizer = inject(DomSanitizer);
22
+ this.initialState = (() => {
23
+ const attributes = (() => {
24
+ mock_user_profile_attributes_for_older_keycloak_versions: {
25
+ if ('profile' in this.kcContext &&
26
+ 'attributesByName' in this.kcContext.profile &&
27
+ Object.keys(this.kcContext.profile.attributesByName).length !== 0) {
28
+ break mock_user_profile_attributes_for_older_keycloak_versions;
29
+ }
30
+ if ('register' in this.kcContext &&
31
+ this.kcContext.register instanceof Object &&
32
+ 'formData' in this.kcContext.register) {
33
+ //NOTE: Handle legacy register.ftl page
34
+ return ['firstName', 'lastName', 'email', 'username']
35
+ .filter(name => name !== 'username'
36
+ ? true
37
+ : !this.kcContext.realm.registrationEmailAsUsername)
38
+ .map(name => id({
39
+ name: name,
40
+ displayName: id(`\${${name}}`),
41
+ required: true,
42
+ value: this.kcContext.register.formData[name] ?? '',
43
+ html5DataAnnotations: {},
44
+ readOnly: false,
45
+ validators: {},
46
+ annotations: {},
47
+ autocomplete: (() => {
48
+ switch (name) {
49
+ case 'email':
50
+ return 'email';
51
+ case 'username':
52
+ return 'username';
53
+ default:
54
+ return undefined;
55
+ }
56
+ })()
57
+ }));
58
+ }
59
+ if ('user' in this.kcContext && this.kcContext.user instanceof Object) {
60
+ //NOTE: Handle legacy login-update-profile.ftl
61
+ return ['username', 'email', 'firstName', 'lastName']
62
+ .filter(name => name !== 'username'
63
+ ? true
64
+ : this.kcContext.user.editUsernameAllowed)
65
+ .map(name => id({
66
+ name: name,
67
+ displayName: id(`\${${name}}`),
68
+ required: true,
69
+ value: this.kcContext.user[name] ?? '',
70
+ html5DataAnnotations: {},
71
+ readOnly: false,
72
+ validators: {},
73
+ annotations: {},
74
+ autocomplete: (() => {
75
+ switch (name) {
76
+ case 'email':
77
+ return 'email';
78
+ case 'username':
79
+ return 'username';
80
+ default:
81
+ return undefined;
82
+ }
83
+ })()
84
+ }));
85
+ }
86
+ if ('email' in this.kcContext && this.kcContext.email instanceof Object) {
87
+ //NOTE: Handle legacy update-email.ftl
88
+ return [
89
+ id({
90
+ name: 'email',
91
+ displayName: id(`\${email}`),
92
+ required: true,
93
+ value: this.kcContext.email.value ?? '',
94
+ html5DataAnnotations: {},
95
+ readOnly: false,
96
+ validators: {},
97
+ annotations: {},
98
+ autocomplete: 'email'
99
+ })
100
+ ];
101
+ }
102
+ assert(false, 'Unable to mock user profile from the current kcContext');
103
+ }
104
+ return Object.values(this.kcContext.profile.attributesByName).map(structuredCloneButFunctions);
105
+ })();
106
+ // Retro-compatibility and consistency patches
107
+ attributes.forEach(attribute => {
108
+ patch_legacy_group: {
109
+ if (typeof attribute.group !== 'string') {
110
+ break patch_legacy_group;
111
+ }
112
+ const { group, groupDisplayHeader, groupDisplayDescription, groupAnnotations } = attribute;
113
+ delete attribute.group;
114
+ // @ts-expect-error
115
+ delete attribute.groupDisplayHeader;
116
+ // @ts-expect-error
117
+ delete attribute.groupDisplayDescription;
118
+ // @ts-expect-error
119
+ delete attribute.groupAnnotations;
120
+ if (group === '') {
121
+ break patch_legacy_group;
122
+ }
123
+ attribute.group = {
124
+ name: group,
125
+ displayHeader: groupDisplayHeader,
126
+ displayDescription: groupDisplayDescription,
127
+ annotations: groupAnnotations,
128
+ html5DataAnnotations: {}
129
+ };
130
+ }
131
+ // Attributes with options rendered by default as select inputs
132
+ if (attribute.validators.options !== undefined &&
133
+ attribute.annotations.inputType === undefined) {
134
+ attribute.annotations.inputType = 'select';
135
+ }
136
+ // Consistency patch on values/value property
137
+ {
138
+ if (this.getIsMultivaluedSingleField({ attribute })) {
139
+ attribute.multivalued = true;
140
+ }
141
+ if (attribute.multivalued) {
142
+ attribute.values ??=
143
+ attribute.value !== undefined ? [attribute.value] : [];
144
+ delete attribute.value;
145
+ }
146
+ else {
147
+ attribute.value ??= attribute.values?.[0];
148
+ delete attribute.values;
149
+ }
150
+ }
151
+ });
152
+ add_password_and_password_confirm: {
153
+ if (!this.kcContext.passwordRequired) {
154
+ break add_password_and_password_confirm;
155
+ }
156
+ attributes.forEach((attribute, i) => {
157
+ if (attribute.name !==
158
+ (this.kcContext.realm.registrationEmailAsUsername
159
+ ? 'email'
160
+ : 'username')) {
161
+ // NOTE: We want to add password and password-confirm after the field that identifies the user.
162
+ // It's either email or username.
163
+ return;
164
+ }
165
+ attributes.splice(i + 1, 0, {
166
+ name: 'password',
167
+ displayName: id('${password}'),
168
+ required: true,
169
+ readOnly: false,
170
+ validators: {},
171
+ annotations: {},
172
+ autocomplete: 'new-password',
173
+ html5DataAnnotations: {}
174
+ }, {
175
+ name: 'password-confirm',
176
+ displayName: id('${passwordConfirm}'),
177
+ required: true,
178
+ readOnly: false,
179
+ validators: {},
180
+ annotations: {},
181
+ html5DataAnnotations: {},
182
+ autocomplete: 'new-password'
183
+ });
184
+ });
185
+ }
186
+ const initialFormFieldState = [];
187
+ for (const attribute of attributes) {
188
+ handle_multi_valued_attribute: {
189
+ if (!attribute.multivalued) {
190
+ break handle_multi_valued_attribute;
191
+ }
192
+ const values = attribute.values?.length ? attribute.values : [''];
193
+ apply_validator_min_range: {
194
+ if (this.getIsMultivaluedSingleField({ attribute })) {
195
+ break apply_validator_min_range;
196
+ }
197
+ const validator = attribute.validators.multivalued;
198
+ if (validator === undefined) {
199
+ break apply_validator_min_range;
200
+ }
201
+ const { min: minStr } = validator;
202
+ if (!minStr) {
203
+ break apply_validator_min_range;
204
+ }
205
+ const min = parseInt(`${minStr}`);
206
+ for (let index = values.length; index < min; index++) {
207
+ values.push('');
208
+ }
209
+ }
210
+ initialFormFieldState.push({
211
+ attribute,
212
+ valueOrValues: values
213
+ });
214
+ continue;
215
+ }
216
+ initialFormFieldState.push({
217
+ attribute,
218
+ valueOrValues: attribute.value ?? ''
219
+ });
220
+ }
221
+ const initialState = {
222
+ formFieldStates: initialFormFieldState.map(({ attribute, valueOrValues }) => ({
223
+ attribute,
224
+ errors: this.getErrors({
225
+ attributeName: attribute.name,
226
+ formFieldStates: initialFormFieldState
227
+ }),
228
+ hasLostFocusAtLeastOnce: valueOrValues instanceof Array &&
229
+ !this.getIsMultivaluedSingleField({ attribute })
230
+ ? valueOrValues.map(() => false)
231
+ : false,
232
+ valueOrValues: valueOrValues
233
+ }))
234
+ };
235
+ return initialState;
236
+ })();
237
+ this.state = signal(this.initialState);
238
+ this.formState = computed(() => {
239
+ const state = this.state();
240
+ return {
241
+ formFieldStates: state.formFieldStates.map(({ errors, hasLostFocusAtLeastOnce: hasLostFocusAtLeastOnceOrArr, attribute, ...valueOrValuesWrap }) => ({
242
+ displayableErrors: errors.filter(error => {
243
+ const hasLostFocusAtLeastOnce = typeof hasLostFocusAtLeastOnceOrArr === 'boolean'
244
+ ? hasLostFocusAtLeastOnceOrArr
245
+ : error.fieldIndex !== undefined
246
+ ? hasLostFocusAtLeastOnceOrArr[error.fieldIndex]
247
+ : hasLostFocusAtLeastOnceOrArr[hasLostFocusAtLeastOnceOrArr.length - 1];
248
+ let value = false;
249
+ switch (error.source.type) {
250
+ case 'server':
251
+ value = true;
252
+ break;
253
+ case 'other':
254
+ switch (error.source.rule) {
255
+ case 'requiredField':
256
+ value = hasLostFocusAtLeastOnce;
257
+ break;
258
+ case 'passwordConfirmMatchesPassword':
259
+ value = hasLostFocusAtLeastOnce;
260
+ break;
261
+ }
262
+ // assert<Equals<typeof error.source.rule, never>>(false);
263
+ break;
264
+ case 'passwordPolicy':
265
+ switch (error.source.name) {
266
+ case 'length':
267
+ value = hasLostFocusAtLeastOnce;
268
+ break;
269
+ case 'digits':
270
+ value = hasLostFocusAtLeastOnce;
271
+ break;
272
+ case 'lowerCase':
273
+ value = hasLostFocusAtLeastOnce;
274
+ break;
275
+ case 'upperCase':
276
+ value = hasLostFocusAtLeastOnce;
277
+ break;
278
+ case 'specialChars':
279
+ value = hasLostFocusAtLeastOnce;
280
+ break;
281
+ case 'notUsername':
282
+ value = true;
283
+ break;
284
+ case 'notEmail':
285
+ value = true;
286
+ break;
287
+ }
288
+ // assert<Equals<typeof error.source, never>>(false);
289
+ break;
290
+ case 'validator':
291
+ switch (error.source.name) {
292
+ case 'length':
293
+ value = hasLostFocusAtLeastOnce;
294
+ break;
295
+ case 'pattern':
296
+ value = hasLostFocusAtLeastOnce;
297
+ break;
298
+ case 'email':
299
+ value = hasLostFocusAtLeastOnce;
300
+ break;
301
+ case 'integer':
302
+ value = hasLostFocusAtLeastOnce;
303
+ break;
304
+ case 'multivalued':
305
+ value = hasLostFocusAtLeastOnce;
306
+ break;
307
+ case 'options':
308
+ value = hasLostFocusAtLeastOnce;
309
+ break;
310
+ }
311
+ // assert<Equals<typeof error.source, never>>(false);
312
+ break;
313
+ }
314
+ return value;
315
+ }),
316
+ attribute,
317
+ ...valueOrValuesWrap
318
+ })),
319
+ isFormSubmittable: state.formFieldStates.every(({ errors }) => errors.length === 0)
320
+ };
321
+ });
322
+ this.loginResourceInjectorService.insertAdditionalScripts(Object.keys(this.kcContext.profile?.html5DataAnnotations ?? {})
323
+ .filter(key => key !== 'kcMultivalued' && key !== 'kcNumberFormat') // NOTE: Keycloakify handles it.
324
+ .map(key => ({
325
+ type: 'module',
326
+ src: `${this.kcContext.url.resourcesPath}/js/${key}.js`,
327
+ id: `${this.kcContext.url.resourcesPath}/js/${key}.js`
328
+ })));
329
+ }
330
+ dispatchFormAction(formAction) {
331
+ if (!formAction)
332
+ return;
333
+ const state = this.state();
334
+ const formFieldState = state.formFieldStates.find(({ attribute }) => attribute.name === formAction.name);
335
+ assert(formFieldState !== undefined);
336
+ switch (formAction.action) {
337
+ case 'update':
338
+ formFieldState.valueOrValues = formAction.valueOrValues;
339
+ apply_formatters: {
340
+ const { attribute } = formFieldState;
341
+ const { kcNumberFormat } = attribute.html5DataAnnotations ?? {};
342
+ if (!kcNumberFormat) {
343
+ break apply_formatters;
344
+ }
345
+ if (formFieldState.valueOrValues instanceof Array) {
346
+ formFieldState.valueOrValues = formFieldState.valueOrValues.map(value => formatNumber(value, kcNumberFormat));
347
+ }
348
+ else {
349
+ formFieldState.valueOrValues = formatNumber(formFieldState.valueOrValues, kcNumberFormat);
350
+ }
351
+ }
352
+ formFieldState.errors = this.getErrors({
353
+ attributeName: formAction.name,
354
+ formFieldStates: state.formFieldStates
355
+ });
356
+ simulate_focus_lost: {
357
+ const { displayErrorsImmediately = false } = formAction;
358
+ if (!displayErrorsImmediately) {
359
+ break simulate_focus_lost;
360
+ }
361
+ for (const fieldIndex of formAction.valueOrValues instanceof Array
362
+ ? formAction.valueOrValues.map((...[, index]) => index)
363
+ : [undefined]) {
364
+ this.dispatchFormAction({
365
+ action: 'focus lost',
366
+ name: formAction.name,
367
+ fieldIndex
368
+ });
369
+ }
370
+ }
371
+ update_password_confirm: {
372
+ if (this.doMakeUserConfirmPassword) {
373
+ break update_password_confirm;
374
+ }
375
+ if (formAction.name !== 'password') {
376
+ break update_password_confirm;
377
+ }
378
+ this.dispatchFormAction({
379
+ action: 'update',
380
+ name: 'password-confirm',
381
+ valueOrValues: formAction.valueOrValues,
382
+ displayErrorsImmediately: formAction.displayErrorsImmediately
383
+ });
384
+ }
385
+ trigger_password_confirm_validation_on_password_change: {
386
+ if (!this.doMakeUserConfirmPassword) {
387
+ break trigger_password_confirm_validation_on_password_change;
388
+ }
389
+ if (formAction.name !== 'password') {
390
+ break trigger_password_confirm_validation_on_password_change;
391
+ }
392
+ this.dispatchFormAction({
393
+ action: 'update',
394
+ name: 'password-confirm',
395
+ valueOrValues: (() => {
396
+ const formFieldState = state.formFieldStates.find(({ attribute }) => attribute.name === 'password-confirm');
397
+ assert(formFieldState !== undefined);
398
+ return formFieldState.valueOrValues;
399
+ })(),
400
+ displayErrorsImmediately: formAction.displayErrorsImmediately
401
+ });
402
+ }
403
+ break;
404
+ case 'focus lost':
405
+ if (formFieldState.hasLostFocusAtLeastOnce instanceof Array) {
406
+ const { fieldIndex } = formAction;
407
+ assert(fieldIndex !== undefined);
408
+ formFieldState.hasLostFocusAtLeastOnce[fieldIndex] = true;
409
+ break;
410
+ }
411
+ formFieldState.hasLostFocusAtLeastOnce = true;
412
+ break;
413
+ }
414
+ this.state.update(state => ({
415
+ ...state,
416
+ formFieldStates: state.formFieldStates.map(f => {
417
+ if (f.attribute === formFieldState.attribute)
418
+ return formFieldState;
419
+ return f;
420
+ })
421
+ }));
422
+ }
423
+ getIsMultivaluedSingleField(params) {
424
+ const { attribute } = params;
425
+ return attribute.annotations.inputType?.startsWith('multiselect') ?? false;
426
+ }
427
+ getErrors(params) {
428
+ const { messagesPerField, passwordPolicies } = this.kcContext;
429
+ const { msgStr, advancedMsgStr } = this.i18n;
430
+ const { attributeName, formFieldStates } = params;
431
+ const formFieldState = formFieldStates.find(({ attribute }) => attribute.name === attributeName);
432
+ assert(formFieldState !== undefined);
433
+ const { attribute } = formFieldState;
434
+ const valueOrValues = (() => {
435
+ let { valueOrValues } = formFieldState;
436
+ unFormat_number: {
437
+ const { kcNumberUnFormat } = attribute.html5DataAnnotations ?? {};
438
+ if (!kcNumberUnFormat) {
439
+ break unFormat_number;
440
+ }
441
+ if (valueOrValues instanceof Array) {
442
+ valueOrValues = valueOrValues.map(value => formatNumber(value, kcNumberUnFormat));
443
+ }
444
+ else {
445
+ valueOrValues = formatNumber(valueOrValues, kcNumberUnFormat);
446
+ }
447
+ }
448
+ return valueOrValues;
449
+ })();
450
+ assert(attribute !== undefined);
451
+ server_side_error: {
452
+ if (attribute.multivalued) {
453
+ const defaultValues = attribute.values?.length ? attribute.values : [''];
454
+ assert(valueOrValues instanceof Array);
455
+ const values = valueOrValues;
456
+ if (JSON.stringify(defaultValues) !==
457
+ JSON.stringify(values.slice(0, defaultValues.length))) {
458
+ break server_side_error;
459
+ }
460
+ }
461
+ else {
462
+ const defaultValue = attribute.value ?? '';
463
+ assert(typeof valueOrValues === 'string');
464
+ const value = valueOrValues;
465
+ if (defaultValue !== value) {
466
+ break server_side_error;
467
+ }
468
+ }
469
+ let doesErrorExist;
470
+ try {
471
+ doesErrorExist = messagesPerField.existsError(attributeName);
472
+ }
473
+ catch {
474
+ break server_side_error;
475
+ }
476
+ if (!doesErrorExist) {
477
+ break server_side_error;
478
+ }
479
+ const errorMessageStr = messagesPerField.get(attributeName);
480
+ return [
481
+ {
482
+ errorMessageStr,
483
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span>${errorMessageStr}</span>`),
484
+ fieldIndex: undefined,
485
+ source: {
486
+ type: 'server'
487
+ }
488
+ }
489
+ ];
490
+ }
491
+ handle_multi_valued_multi_fields: {
492
+ if (!attribute.multivalued) {
493
+ break handle_multi_valued_multi_fields;
494
+ }
495
+ if (this.getIsMultivaluedSingleField({ attribute })) {
496
+ break handle_multi_valued_multi_fields;
497
+ }
498
+ assert(valueOrValues instanceof Array);
499
+ const values = valueOrValues;
500
+ const errors = values
501
+ .map((...[, index]) => {
502
+ const specificValueErrors = this.getErrors({
503
+ attributeName,
504
+ formFieldStates: formFieldStates.map(formFieldState => {
505
+ if (formFieldState.attribute.name === attributeName) {
506
+ assert(formFieldState.valueOrValues instanceof Array);
507
+ return {
508
+ attribute: {
509
+ ...attribute,
510
+ annotations: {
511
+ ...attribute.annotations,
512
+ inputType: undefined
513
+ },
514
+ multivalued: false
515
+ },
516
+ valueOrValues: formFieldState.valueOrValues[index]
517
+ };
518
+ }
519
+ return formFieldState;
520
+ })
521
+ });
522
+ return specificValueErrors
523
+ .filter(error => {
524
+ if (error.source.type === 'other' &&
525
+ error.source.rule === 'requiredField') {
526
+ return false;
527
+ }
528
+ return true;
529
+ })
530
+ .map((error) => ({
531
+ ...error,
532
+ fieldIndex: index
533
+ }));
534
+ })
535
+ .reduce((acc, errors) => [...acc, ...errors], []);
536
+ required_field: {
537
+ if (!attribute.required) {
538
+ break required_field;
539
+ }
540
+ if (values.every(value => value !== '')) {
541
+ break required_field;
542
+ }
543
+ const msgArgs = ['error-user-attribute-required'];
544
+ errors.push({
545
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
546
+ errorMessageStr: msgStr(...msgArgs),
547
+ fieldIndex: undefined,
548
+ source: {
549
+ type: 'other',
550
+ rule: 'requiredField'
551
+ }
552
+ });
553
+ }
554
+ return errors;
555
+ }
556
+ handle_multi_valued_single_field: {
557
+ if (!attribute.multivalued) {
558
+ break handle_multi_valued_single_field;
559
+ }
560
+ if (!this.getIsMultivaluedSingleField({ attribute })) {
561
+ break handle_multi_valued_single_field;
562
+ }
563
+ const validatorName = 'multivalued';
564
+ const validator = attribute.validators[validatorName];
565
+ if (validator === undefined) {
566
+ return [];
567
+ }
568
+ const { min: minStr } = validator;
569
+ const min = minStr ? parseInt(`${minStr}`) : attribute.required ? 1 : 0;
570
+ assert(!isNaN(min));
571
+ const { max: maxStr } = validator;
572
+ const max = !maxStr ? Infinity : parseInt(`${maxStr}`);
573
+ assert(!isNaN(max));
574
+ assert(valueOrValues instanceof Array);
575
+ const values = valueOrValues;
576
+ if (min <= values.length && values.length <= max) {
577
+ return [];
578
+ }
579
+ const msgArgs = [
580
+ 'error-invalid-multivalued-size',
581
+ `${min}`,
582
+ `${max}`
583
+ ];
584
+ return [
585
+ {
586
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="0">${msgStr(...msgArgs)}</span>`),
587
+ errorMessageStr: msgStr(...msgArgs),
588
+ fieldIndex: undefined,
589
+ source: {
590
+ type: 'validator',
591
+ name: validatorName
592
+ }
593
+ }
594
+ ];
595
+ }
596
+ assert(typeof valueOrValues === 'string');
597
+ const value = valueOrValues;
598
+ const errors = [];
599
+ check_password_policies: {
600
+ if (attributeName !== 'password') {
601
+ break check_password_policies;
602
+ }
603
+ if (passwordPolicies === undefined) {
604
+ break check_password_policies;
605
+ }
606
+ check_password_policy_x: {
607
+ const policyName = 'length';
608
+ const policy = passwordPolicies[policyName];
609
+ if (!policy) {
610
+ break check_password_policy_x;
611
+ }
612
+ const minLength = policy;
613
+ if (value.length >= minLength) {
614
+ break check_password_policy_x;
615
+ }
616
+ const msgArgs = [
617
+ 'invalidPasswordMinLengthMessage',
618
+ `${minLength}`
619
+ ];
620
+ errors.push({
621
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
622
+ errorMessageStr: msgStr(...msgArgs),
623
+ fieldIndex: undefined,
624
+ source: {
625
+ type: 'passwordPolicy',
626
+ name: policyName
627
+ }
628
+ });
629
+ }
630
+ check_password_policy_x: {
631
+ const policyName = 'digits';
632
+ const policy = passwordPolicies[policyName];
633
+ if (!policy) {
634
+ break check_password_policy_x;
635
+ }
636
+ const minNumberOfDigits = policy;
637
+ if (value.split('').filter(char => !isNaN(parseInt(char))).length >=
638
+ minNumberOfDigits) {
639
+ break check_password_policy_x;
640
+ }
641
+ const msgArgs = [
642
+ 'invalidPasswordMinDigitsMessage',
643
+ `${minNumberOfDigits}`
644
+ ];
645
+ errors.push({
646
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
647
+ errorMessageStr: msgStr(...msgArgs),
648
+ fieldIndex: undefined,
649
+ source: {
650
+ type: 'passwordPolicy',
651
+ name: policyName
652
+ }
653
+ });
654
+ }
655
+ check_password_policy_x: {
656
+ const policyName = 'lowerCase';
657
+ const policy = passwordPolicies[policyName];
658
+ if (!policy) {
659
+ break check_password_policy_x;
660
+ }
661
+ const minNumberOfLowerCaseChar = policy;
662
+ if (value
663
+ .split('')
664
+ .filter(char => char === char.toLowerCase() && char !== char.toUpperCase()).length >= minNumberOfLowerCaseChar) {
665
+ break check_password_policy_x;
666
+ }
667
+ const msgArgs = [
668
+ 'invalidPasswordMinLowerCaseCharsMessage',
669
+ `${minNumberOfLowerCaseChar}`
670
+ ];
671
+ errors.push({
672
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
673
+ errorMessageStr: msgStr(...msgArgs),
674
+ fieldIndex: undefined,
675
+ source: {
676
+ type: 'passwordPolicy',
677
+ name: policyName
678
+ }
679
+ });
680
+ }
681
+ check_password_policy_x: {
682
+ const policyName = 'upperCase';
683
+ const policy = passwordPolicies[policyName];
684
+ if (!policy) {
685
+ break check_password_policy_x;
686
+ }
687
+ const minNumberOfUpperCaseChar = policy;
688
+ if (value
689
+ .split('')
690
+ .filter(char => char === char.toUpperCase() && char !== char.toLowerCase()).length >= minNumberOfUpperCaseChar) {
691
+ break check_password_policy_x;
692
+ }
693
+ const msgArgs = [
694
+ 'invalidPasswordMinUpperCaseCharsMessage',
695
+ `${minNumberOfUpperCaseChar}`
696
+ ];
697
+ errors.push({
698
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
699
+ errorMessageStr: msgStr(...msgArgs),
700
+ fieldIndex: undefined,
701
+ source: {
702
+ type: 'passwordPolicy',
703
+ name: policyName
704
+ }
705
+ });
706
+ }
707
+ check_password_policy_x: {
708
+ const policyName = 'specialChars';
709
+ const policy = passwordPolicies[policyName];
710
+ if (!policy) {
711
+ break check_password_policy_x;
712
+ }
713
+ const minNumberOfSpecialChar = policy;
714
+ if (value.split('').filter(char => !char.match(/[a-zA-Z0-9]/)).length >=
715
+ minNumberOfSpecialChar) {
716
+ break check_password_policy_x;
717
+ }
718
+ const msgArgs = [
719
+ 'invalidPasswordMinSpecialCharsMessage',
720
+ `${minNumberOfSpecialChar}`
721
+ ];
722
+ errors.push({
723
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
724
+ errorMessageStr: msgStr(...msgArgs),
725
+ fieldIndex: undefined,
726
+ source: {
727
+ type: 'passwordPolicy',
728
+ name: policyName
729
+ }
730
+ });
731
+ }
732
+ check_password_policy_x: {
733
+ const policyName = 'notUsername';
734
+ const notUsername = passwordPolicies[policyName];
735
+ if (!notUsername) {
736
+ break check_password_policy_x;
737
+ }
738
+ const usernameFormFieldState = formFieldStates.find(formFieldState => formFieldState.attribute.name === 'username');
739
+ if (!usernameFormFieldState) {
740
+ break check_password_policy_x;
741
+ }
742
+ const usernameValue = (() => {
743
+ let { valueOrValues } = usernameFormFieldState;
744
+ assert(typeof valueOrValues === 'string');
745
+ unFormat_number: {
746
+ const { kcNumberUnFormat } = attribute.html5DataAnnotations ?? {};
747
+ if (!kcNumberUnFormat) {
748
+ break unFormat_number;
749
+ }
750
+ valueOrValues = formatNumber(valueOrValues, kcNumberUnFormat);
751
+ }
752
+ return valueOrValues;
753
+ })();
754
+ if (usernameValue === '') {
755
+ break check_password_policy_x;
756
+ }
757
+ if (value !== usernameValue) {
758
+ break check_password_policy_x;
759
+ }
760
+ const msgArgs = ['invalidPasswordNotUsernameMessage'];
761
+ errors.push({
762
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
763
+ errorMessageStr: msgStr(...msgArgs),
764
+ fieldIndex: undefined,
765
+ source: {
766
+ type: 'passwordPolicy',
767
+ name: policyName
768
+ }
769
+ });
770
+ }
771
+ check_password_policy_x: {
772
+ const policyName = 'notEmail';
773
+ const notEmail = passwordPolicies[policyName];
774
+ if (!notEmail) {
775
+ break check_password_policy_x;
776
+ }
777
+ const emailFormFieldState = formFieldStates.find(formFieldState => formFieldState.attribute.name === 'email');
778
+ if (!emailFormFieldState) {
779
+ break check_password_policy_x;
780
+ }
781
+ assert(typeof emailFormFieldState.valueOrValues === 'string');
782
+ {
783
+ const emailValue = emailFormFieldState.valueOrValues;
784
+ if (emailValue === '') {
785
+ break check_password_policy_x;
786
+ }
787
+ if (value !== emailValue) {
788
+ break check_password_policy_x;
789
+ }
790
+ }
791
+ const msgArgs = ['invalidPasswordNotEmailMessage'];
792
+ errors.push({
793
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
794
+ errorMessageStr: msgStr(...msgArgs),
795
+ fieldIndex: undefined,
796
+ source: {
797
+ type: 'passwordPolicy',
798
+ name: policyName
799
+ }
800
+ });
801
+ }
802
+ }
803
+ password_confirm_matches_password: {
804
+ if (attributeName !== 'password-confirm') {
805
+ break password_confirm_matches_password;
806
+ }
807
+ const passwordFormFieldState = formFieldStates.find(formFieldState => formFieldState.attribute.name === 'password');
808
+ assert(passwordFormFieldState !== undefined);
809
+ assert(typeof passwordFormFieldState.valueOrValues === 'string');
810
+ {
811
+ const passwordValue = passwordFormFieldState.valueOrValues;
812
+ if (value === passwordValue) {
813
+ break password_confirm_matches_password;
814
+ }
815
+ }
816
+ const msgArgs = ['invalidPasswordConfirmMessage'];
817
+ errors.push({
818
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
819
+ errorMessageStr: msgStr(...msgArgs),
820
+ fieldIndex: undefined,
821
+ source: {
822
+ type: 'other',
823
+ rule: 'passwordConfirmMatchesPassword'
824
+ }
825
+ });
826
+ }
827
+ const { validators } = attribute;
828
+ required_field: {
829
+ if (!attribute.required) {
830
+ break required_field;
831
+ }
832
+ if (value !== '') {
833
+ break required_field;
834
+ }
835
+ const msgArgs = ['error-user-attribute-required'];
836
+ errors.push({
837
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
838
+ errorMessageStr: msgStr(...msgArgs),
839
+ fieldIndex: undefined,
840
+ source: {
841
+ type: 'other',
842
+ rule: 'requiredField'
843
+ }
844
+ });
845
+ }
846
+ validator_x: {
847
+ const validatorName = 'length';
848
+ const validator = validators[validatorName];
849
+ if (!validator) {
850
+ break validator_x;
851
+ }
852
+ const { 'ignore.empty.value': ignoreEmptyValue = false, max, min } = validator;
853
+ if (ignoreEmptyValue && value === '') {
854
+ break validator_x;
855
+ }
856
+ const source = {
857
+ type: 'validator',
858
+ name: validatorName
859
+ };
860
+ if (max && value.length > parseInt(`${max}`)) {
861
+ const msgArgs = ['error-invalid-length-too-long', `${max}`];
862
+ errors.push({
863
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
864
+ errorMessageStr: msgStr(...msgArgs),
865
+ fieldIndex: undefined,
866
+ source
867
+ });
868
+ }
869
+ if (min && value.length < parseInt(`${min}`)) {
870
+ const msgArgs = ['error-invalid-length-too-short', `${min}`];
871
+ errors.push({
872
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
873
+ errorMessageStr: msgStr(...msgArgs),
874
+ fieldIndex: undefined,
875
+ source
876
+ });
877
+ }
878
+ }
879
+ validator_x: {
880
+ const validatorName = 'pattern';
881
+ const validator = validators[validatorName];
882
+ if (validator === undefined) {
883
+ break validator_x;
884
+ }
885
+ const { 'ignore.empty.value': ignoreEmptyValue = false, pattern, 'error-message': errorMessageKey } = validator;
886
+ if (ignoreEmptyValue && value === '') {
887
+ break validator_x;
888
+ }
889
+ if (new RegExp(pattern).test(value)) {
890
+ break validator_x;
891
+ }
892
+ const msgArgs = [
893
+ errorMessageKey ?? id('shouldMatchPattern'),
894
+ pattern
895
+ ];
896
+ errors.push({
897
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${advancedMsgStr(...msgArgs)}</span>`),
898
+ errorMessageStr: advancedMsgStr(...msgArgs),
899
+ fieldIndex: undefined,
900
+ source: {
901
+ type: 'validator',
902
+ name: validatorName
903
+ }
904
+ });
905
+ }
906
+ validator_x: {
907
+ {
908
+ const lastError = errors[errors.length - 1];
909
+ if (lastError !== undefined &&
910
+ lastError.source.type === 'validator' &&
911
+ lastError.source.name === 'pattern') {
912
+ break validator_x;
913
+ }
914
+ }
915
+ const validatorName = 'email';
916
+ const validator = validators[validatorName];
917
+ if (validator === undefined) {
918
+ break validator_x;
919
+ }
920
+ const { 'ignore.empty.value': ignoreEmptyValue = false } = validator;
921
+ if (ignoreEmptyValue && value === '') {
922
+ break validator_x;
923
+ }
924
+ if (emailRegexp.test(value)) {
925
+ break validator_x;
926
+ }
927
+ const msgArgs = [id('invalidEmailMessage')];
928
+ errors.push({
929
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
930
+ errorMessageStr: msgStr(...msgArgs),
931
+ fieldIndex: undefined,
932
+ source: {
933
+ type: 'validator',
934
+ name: validatorName
935
+ }
936
+ });
937
+ }
938
+ validator_x: {
939
+ const validatorName = 'integer';
940
+ const validator = validators[validatorName];
941
+ if (validator === undefined) {
942
+ break validator_x;
943
+ }
944
+ const { 'ignore.empty.value': ignoreEmptyValue = false, max, min } = validator;
945
+ if (ignoreEmptyValue && value === '') {
946
+ break validator_x;
947
+ }
948
+ const intValue = parseInt(value);
949
+ const source = {
950
+ type: 'validator',
951
+ name: validatorName
952
+ };
953
+ if (isNaN(intValue)) {
954
+ const msgArgs = ['mustBeAnInteger'];
955
+ errors.push({
956
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
957
+ errorMessageStr: msgStr(...msgArgs),
958
+ fieldIndex: undefined,
959
+ source
960
+ });
961
+ break validator_x;
962
+ }
963
+ if (max && intValue > parseInt(`${max}`)) {
964
+ const msgArgs = ['error-number-out-of-range-too-big', `${max}`];
965
+ errors.push({
966
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
967
+ errorMessageStr: msgStr(...msgArgs),
968
+ fieldIndex: undefined,
969
+ source
970
+ });
971
+ break validator_x;
972
+ }
973
+ if (min && intValue < parseInt(`${min}`)) {
974
+ const msgArgs = [
975
+ 'error-number-out-of-range-too-small',
976
+ `${min}`
977
+ ];
978
+ errors.push({
979
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
980
+ errorMessageStr: msgStr(...msgArgs),
981
+ fieldIndex: undefined,
982
+ source
983
+ });
984
+ break validator_x;
985
+ }
986
+ }
987
+ validator_x: {
988
+ const validatorName = 'options';
989
+ const validator = validators[validatorName];
990
+ if (validator === undefined) {
991
+ break validator_x;
992
+ }
993
+ if (value === '') {
994
+ break validator_x;
995
+ }
996
+ if (validator.options.indexOf(value) >= 0) {
997
+ break validator_x;
998
+ }
999
+ const msgArgs = [id('notAValidOption')];
1000
+ errors.push({
1001
+ errorMessage: this.sanitizer.bypassSecurityTrustHtml(`<span data-key="${attributeName}-${errors.length}">${msgStr(...msgArgs)}</span>`),
1002
+ errorMessageStr: msgStr(...msgArgs),
1003
+ fieldIndex: undefined,
1004
+ source: {
1005
+ type: 'validator',
1006
+ name: validatorName
1007
+ }
1008
+ });
1009
+ }
1010
+ //TODO: Implement missing validators. See Validators type definition.
1011
+ return errors;
1012
+ }
1013
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: UserProfileFormService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
1014
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: UserProfileFormService, providedIn: 'root' }); }
1015
+ }
1016
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: UserProfileFormService, decorators: [{
1017
+ type: Injectable,
1018
+ args: [{ providedIn: 'root' }]
1019
+ }], ctorParameters: () => [] });
1020
+
1021
+ /**
1022
+ * Generated bundle index. Do not edit.
1023
+ */
1024
+
1025
+ export { UserProfileFormService };
1026
+ //# sourceMappingURL=keycloakify-angular-login-services-user-profile-form.mjs.map