@keycloakify/angular 0.1.8 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (496) hide show
  1. package/README.md +6 -0
  2. package/bin/197.index.js +13 -0
  3. package/bin/381.index.js +13 -0
  4. package/bin/504.index.js +13 -0
  5. package/bin/87.index.js +13 -0
  6. package/bin/main.js +178 -474
  7. package/fesm2022/keycloakify-angular-account-directives-kc-class.mjs +3 -3
  8. package/fesm2022/keycloakify-angular-account-directives-kc-class.mjs.map +1 -1
  9. package/fesm2022/keycloakify-angular-account-pages-account.mjs +4 -4
  10. package/fesm2022/keycloakify-angular-account-pages-account.mjs.map +1 -1
  11. package/fesm2022/keycloakify-angular-account-pages-applications.mjs +4 -4
  12. package/fesm2022/keycloakify-angular-account-pages-applications.mjs.map +1 -1
  13. package/fesm2022/keycloakify-angular-account-pages-federatedIdentity.mjs +4 -4
  14. package/fesm2022/keycloakify-angular-account-pages-federatedIdentity.mjs.map +1 -1
  15. package/fesm2022/keycloakify-angular-account-pages-log.mjs +4 -4
  16. package/fesm2022/keycloakify-angular-account-pages-log.mjs.map +1 -1
  17. package/fesm2022/keycloakify-angular-account-pages-password.mjs +4 -4
  18. package/fesm2022/keycloakify-angular-account-pages-password.mjs.map +1 -1
  19. package/fesm2022/keycloakify-angular-account-pages-sessions.mjs +4 -4
  20. package/fesm2022/keycloakify-angular-account-pages-sessions.mjs.map +1 -1
  21. package/fesm2022/keycloakify-angular-account-pages-totp.mjs +4 -4
  22. package/fesm2022/keycloakify-angular-account-pages-totp.mjs.map +1 -1
  23. package/fesm2022/keycloakify-angular-account-providers-keycloakify-angular.mjs +15 -20
  24. package/fesm2022/keycloakify-angular-account-providers-keycloakify-angular.mjs.map +1 -1
  25. package/fesm2022/keycloakify-angular-account-services-account-resource-injector.mjs +3 -3
  26. package/fesm2022/keycloakify-angular-account-services-account-resource-injector.mjs.map +1 -1
  27. package/fesm2022/keycloakify-angular-account-services-i18n.mjs +3 -3
  28. package/fesm2022/keycloakify-angular-account-services-i18n.mjs.map +1 -1
  29. package/fesm2022/keycloakify-angular-account-template.mjs +4 -4
  30. package/fesm2022/keycloakify-angular-account-template.mjs.map +1 -1
  31. package/fesm2022/keycloakify-angular-lib-directives-attributes.mjs +3 -3
  32. package/fesm2022/keycloakify-angular-lib-directives-attributes.mjs.map +1 -1
  33. package/fesm2022/keycloakify-angular-lib-pipes-input-type.mjs +3 -3
  34. package/fesm2022/keycloakify-angular-lib-pipes-input-type.mjs.map +1 -1
  35. package/fesm2022/keycloakify-angular-lib-pipes-is-array-with-empty-object.mjs +3 -3
  36. package/fesm2022/keycloakify-angular-lib-pipes-is-array-with-empty-object.mjs.map +1 -1
  37. package/fesm2022/keycloakify-angular-lib-pipes-kc-sanitize.mjs +3 -3
  38. package/fesm2022/keycloakify-angular-lib-pipes-kc-sanitize.mjs.map +1 -1
  39. package/fesm2022/keycloakify-angular-lib-pipes-to-array.mjs +3 -3
  40. package/fesm2022/keycloakify-angular-lib-pipes-to-array.mjs.map +1 -1
  41. package/fesm2022/keycloakify-angular-lib-pipes-to-number.mjs +3 -3
  42. package/fesm2022/keycloakify-angular-lib-pipes-to-number.mjs.map +1 -1
  43. package/fesm2022/keycloakify-angular-lib-services-resource-injector.mjs +3 -3
  44. package/fesm2022/keycloakify-angular-lib-services-resource-injector.mjs.map +1 -1
  45. package/fesm2022/keycloakify-angular-login-components-add-remove-buttons-multi-valued-attribute.mjs +4 -4
  46. package/fesm2022/keycloakify-angular-login-components-add-remove-buttons-multi-valued-attribute.mjs.map +1 -1
  47. package/fesm2022/keycloakify-angular-login-components-field-errors.mjs +4 -4
  48. package/fesm2022/keycloakify-angular-login-components-field-errors.mjs.map +1 -1
  49. package/fesm2022/keycloakify-angular-login-components-group-label.mjs +4 -4
  50. package/fesm2022/keycloakify-angular-login-components-group-label.mjs.map +1 -1
  51. package/fesm2022/keycloakify-angular-login-components-input-field-by-type.mjs +4 -4
  52. package/fesm2022/keycloakify-angular-login-components-input-field-by-type.mjs.map +1 -1
  53. package/fesm2022/keycloakify-angular-login-components-input-tag-selects.mjs +4 -4
  54. package/fesm2022/keycloakify-angular-login-components-input-tag-selects.mjs.map +1 -1
  55. package/fesm2022/keycloakify-angular-login-components-input-tag.mjs +4 -4
  56. package/fesm2022/keycloakify-angular-login-components-input-tag.mjs.map +1 -1
  57. package/fesm2022/keycloakify-angular-login-components-logout-other-sessions.mjs +4 -4
  58. package/fesm2022/keycloakify-angular-login-components-logout-other-sessions.mjs.map +1 -1
  59. package/fesm2022/keycloakify-angular-login-components-password-wrapper.mjs +4 -4
  60. package/fesm2022/keycloakify-angular-login-components-password-wrapper.mjs.map +1 -1
  61. package/fesm2022/keycloakify-angular-login-components-select-tag.mjs +4 -4
  62. package/fesm2022/keycloakify-angular-login-components-select-tag.mjs.map +1 -1
  63. package/fesm2022/keycloakify-angular-login-components-textarea-tag.mjs +4 -4
  64. package/fesm2022/keycloakify-angular-login-components-textarea-tag.mjs.map +1 -1
  65. package/fesm2022/keycloakify-angular-login-components-user-profile-form-fields.mjs +4 -4
  66. package/fesm2022/keycloakify-angular-login-components-user-profile-form-fields.mjs.map +1 -1
  67. package/fesm2022/keycloakify-angular-login-directives-kc-class.mjs +3 -3
  68. package/fesm2022/keycloakify-angular-login-directives-kc-class.mjs.map +1 -1
  69. package/fesm2022/keycloakify-angular-login-pages-code.mjs +4 -4
  70. package/fesm2022/keycloakify-angular-login-pages-code.mjs.map +1 -1
  71. package/fesm2022/keycloakify-angular-login-pages-delete-account-confirm.mjs +4 -4
  72. package/fesm2022/keycloakify-angular-login-pages-delete-account-confirm.mjs.map +1 -1
  73. package/fesm2022/keycloakify-angular-login-pages-delete-credential.mjs +4 -4
  74. package/fesm2022/keycloakify-angular-login-pages-delete-credential.mjs.map +1 -1
  75. package/fesm2022/keycloakify-angular-login-pages-error.mjs +4 -4
  76. package/fesm2022/keycloakify-angular-login-pages-error.mjs.map +1 -1
  77. package/fesm2022/keycloakify-angular-login-pages-frontchannel-logout.mjs +4 -4
  78. package/fesm2022/keycloakify-angular-login-pages-frontchannel-logout.mjs.map +1 -1
  79. package/fesm2022/keycloakify-angular-login-pages-idp-review-user-profile.mjs +4 -4
  80. package/fesm2022/keycloakify-angular-login-pages-idp-review-user-profile.mjs.map +1 -1
  81. package/fesm2022/keycloakify-angular-login-pages-info.mjs +4 -4
  82. package/fesm2022/keycloakify-angular-login-pages-info.mjs.map +1 -1
  83. package/fesm2022/keycloakify-angular-login-pages-login-config-totp.mjs +4 -4
  84. package/fesm2022/keycloakify-angular-login-pages-login-config-totp.mjs.map +1 -1
  85. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm-override.mjs +4 -4
  86. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm-override.mjs.map +1 -1
  87. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm.mjs +4 -4
  88. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm.mjs.map +1 -1
  89. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-email.mjs +4 -4
  90. package/fesm2022/keycloakify-angular-login-pages-login-idp-link-email.mjs.map +1 -1
  91. package/fesm2022/keycloakify-angular-login-pages-login-oauth-grant.mjs +4 -4
  92. package/fesm2022/keycloakify-angular-login-pages-login-oauth-grant.mjs.map +1 -1
  93. package/fesm2022/keycloakify-angular-login-pages-login-oauth2-device-verify-user-code.mjs +4 -4
  94. package/fesm2022/keycloakify-angular-login-pages-login-oauth2-device-verify-user-code.mjs.map +1 -1
  95. package/fesm2022/keycloakify-angular-login-pages-login-otp.mjs +4 -4
  96. package/fesm2022/keycloakify-angular-login-pages-login-otp.mjs.map +1 -1
  97. package/fesm2022/keycloakify-angular-login-pages-login-page-expired.mjs +4 -4
  98. package/fesm2022/keycloakify-angular-login-pages-login-page-expired.mjs.map +1 -1
  99. package/fesm2022/keycloakify-angular-login-pages-login-passkeys-conditional-authenticate.mjs +4 -4
  100. package/fesm2022/keycloakify-angular-login-pages-login-passkeys-conditional-authenticate.mjs.map +1 -1
  101. package/fesm2022/keycloakify-angular-login-pages-login-password.mjs +4 -4
  102. package/fesm2022/keycloakify-angular-login-pages-login-password.mjs.map +1 -1
  103. package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-config.mjs +4 -4
  104. package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-config.mjs.map +1 -1
  105. package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-input.mjs +4 -4
  106. package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-input.mjs.map +1 -1
  107. package/fesm2022/keycloakify-angular-login-pages-login-reset-otp.mjs +4 -4
  108. package/fesm2022/keycloakify-angular-login-pages-login-reset-otp.mjs.map +1 -1
  109. package/fesm2022/keycloakify-angular-login-pages-login-reset-password.mjs +4 -4
  110. package/fesm2022/keycloakify-angular-login-pages-login-reset-password.mjs.map +1 -1
  111. package/fesm2022/keycloakify-angular-login-pages-login-update-password.mjs +4 -4
  112. package/fesm2022/keycloakify-angular-login-pages-login-update-password.mjs.map +1 -1
  113. package/fesm2022/keycloakify-angular-login-pages-login-update-profile.mjs +4 -4
  114. package/fesm2022/keycloakify-angular-login-pages-login-update-profile.mjs.map +1 -1
  115. package/fesm2022/keycloakify-angular-login-pages-login-username.mjs +4 -4
  116. package/fesm2022/keycloakify-angular-login-pages-login-username.mjs.map +1 -1
  117. package/fesm2022/keycloakify-angular-login-pages-login-verify-email.mjs +4 -4
  118. package/fesm2022/keycloakify-angular-login-pages-login-verify-email.mjs.map +1 -1
  119. package/fesm2022/keycloakify-angular-login-pages-login-x509-info.mjs +4 -4
  120. package/fesm2022/keycloakify-angular-login-pages-login-x509-info.mjs.map +1 -1
  121. package/fesm2022/keycloakify-angular-login-pages-login.mjs +4 -4
  122. package/fesm2022/keycloakify-angular-login-pages-login.mjs.map +1 -1
  123. package/fesm2022/keycloakify-angular-login-pages-logout-confirm.mjs +4 -4
  124. package/fesm2022/keycloakify-angular-login-pages-logout-confirm.mjs.map +1 -1
  125. package/fesm2022/keycloakify-angular-login-pages-register.mjs +4 -4
  126. package/fesm2022/keycloakify-angular-login-pages-register.mjs.map +1 -1
  127. package/fesm2022/keycloakify-angular-login-pages-saml-post-form.mjs +4 -4
  128. package/fesm2022/keycloakify-angular-login-pages-saml-post-form.mjs.map +1 -1
  129. package/fesm2022/keycloakify-angular-login-pages-select-authenticator.mjs +4 -4
  130. package/fesm2022/keycloakify-angular-login-pages-select-authenticator.mjs.map +1 -1
  131. package/fesm2022/keycloakify-angular-login-pages-terms.mjs +4 -4
  132. package/fesm2022/keycloakify-angular-login-pages-terms.mjs.map +1 -1
  133. package/fesm2022/keycloakify-angular-login-pages-update-email.mjs +4 -4
  134. package/fesm2022/keycloakify-angular-login-pages-update-email.mjs.map +1 -1
  135. package/fesm2022/keycloakify-angular-login-pages-webauthn-authenticate.mjs +4 -4
  136. package/fesm2022/keycloakify-angular-login-pages-webauthn-authenticate.mjs.map +1 -1
  137. package/fesm2022/keycloakify-angular-login-pages-webauthn-error.mjs +4 -4
  138. package/fesm2022/keycloakify-angular-login-pages-webauthn-error.mjs.map +1 -1
  139. package/fesm2022/keycloakify-angular-login-pages-webauthn-register.mjs +4 -4
  140. package/fesm2022/keycloakify-angular-login-pages-webauthn-register.mjs.map +1 -1
  141. package/fesm2022/keycloakify-angular-login-providers-keycloakify-angular.mjs +15 -20
  142. package/fesm2022/keycloakify-angular-login-providers-keycloakify-angular.mjs.map +1 -1
  143. package/fesm2022/keycloakify-angular-login-services-i18n.mjs +3 -3
  144. package/fesm2022/keycloakify-angular-login-services-i18n.mjs.map +1 -1
  145. package/fesm2022/keycloakify-angular-login-services-login-resource-injector.mjs +3 -3
  146. package/fesm2022/keycloakify-angular-login-services-login-resource-injector.mjs.map +1 -1
  147. package/fesm2022/keycloakify-angular-login-services-user-profile-form.mjs +3 -3
  148. package/fesm2022/keycloakify-angular-login-services-user-profile-form.mjs.map +1 -1
  149. package/fesm2022/keycloakify-angular-login-template.mjs +4 -4
  150. package/fesm2022/keycloakify-angular-login-template.mjs.map +1 -1
  151. package/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.d.ts +1 -1
  152. package/package.json +2 -185
  153. package/src/account/pages/account/account.component.ts +0 -1
  154. package/src/account/pages/applications/applications.component.ts +0 -1
  155. package/src/account/pages/federatedIdentity/federatedIdentity.component.ts +0 -1
  156. package/src/account/pages/log/log.component.ts +0 -1
  157. package/src/account/pages/password/password.component.ts +0 -1
  158. package/src/account/pages/sessions/sessions.component.ts +0 -1
  159. package/src/account/pages/totp/totp.component.ts +0 -1
  160. package/src/account/providers/keycloakify-angular/keycloakify-angular.providers.ts +10 -8
  161. package/src/account/template/template.component.ts +0 -1
  162. package/src/bin/add-story.ts +2 -0
  163. package/src/bin/eject-page.ts +2 -0
  164. package/src/bin/initialize-account-theme/boilerplate/KcPageStory.ts +0 -1
  165. package/src/bin/tsconfig.json +3 -4
  166. package/src/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.ts +0 -1
  167. package/src/login/components/field-errors/field-errors.component.ts +0 -1
  168. package/src/login/components/group-label/group-label.component.ts +0 -1
  169. package/src/login/components/input-field-by-type/input-field-by-type.component.ts +0 -1
  170. package/src/login/components/input-tag/input-tag.component.ts +0 -1
  171. package/src/login/components/input-tag-selects/input-tag-selects.component.ts +0 -1
  172. package/src/login/components/logout-other-sessions/logout-other-sessions.component.ts +0 -1
  173. package/src/login/components/password-wrapper/password-wrapper.component.ts +0 -1
  174. package/src/login/components/select-tag/select-tag.component.ts +0 -1
  175. package/src/login/components/textarea-tag/textarea-tag.component.ts +0 -1
  176. package/src/login/components/user-profile-form-fields/user-profile-form-fields.component.ts +0 -1
  177. package/src/login/pages/code/code.component.ts +0 -1
  178. package/src/login/pages/delete-account-confirm/delete-account-confirm.component.ts +0 -1
  179. package/src/login/pages/delete-credential/delete-credential.component.ts +0 -1
  180. package/src/login/pages/error/error.component.ts +0 -1
  181. package/src/login/pages/frontchannel-logout/frontchannel-logout.component.ts +0 -1
  182. package/src/login/pages/idp-review-user-profile/idp-review-user-profile.component.ts +0 -1
  183. package/src/login/pages/info/info.component.ts +0 -1
  184. package/src/login/pages/login/login.component.ts +0 -1
  185. package/src/login/pages/login-config-totp/login-config-totp.component.ts +0 -1
  186. package/src/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.ts +0 -1
  187. package/src/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.ts +0 -1
  188. package/src/login/pages/login-idp-link-email/login-idp-link-email.component.ts +0 -1
  189. package/src/login/pages/login-oauth-grant/login-oauth-grant.component.ts +0 -1
  190. package/src/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.ts +0 -1
  191. package/src/login/pages/login-otp/login-otp.component.ts +0 -1
  192. package/src/login/pages/login-page-expired/login-page-expired.component.ts +0 -1
  193. package/src/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.ts +0 -1
  194. package/src/login/pages/login-password/login-password.component.ts +0 -1
  195. package/src/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.ts +0 -1
  196. package/src/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.ts +0 -1
  197. package/src/login/pages/login-reset-otp/login-reset-otp.component.ts +0 -1
  198. package/src/login/pages/login-reset-password/login-reset-password.component.ts +0 -1
  199. package/src/login/pages/login-update-password/login-update-password.component.ts +0 -1
  200. package/src/login/pages/login-update-profile/login-update-profile.component.ts +0 -1
  201. package/src/login/pages/login-username/login-username.component.ts +0 -1
  202. package/src/login/pages/login-verify-email/login-verify-email.component.ts +0 -1
  203. package/src/login/pages/login-x509-info/login-x509-info.component.ts +0 -1
  204. package/src/login/pages/logout-confirm/logout-confirm.component.ts +0 -1
  205. package/src/login/pages/register/register.component.ts +0 -1
  206. package/src/login/pages/saml-post-form/saml-post-form.component.ts +0 -1
  207. package/src/login/pages/select-authenticator/select-authenticator.component.ts +0 -1
  208. package/src/login/pages/terms/terms.component.ts +0 -1
  209. package/src/login/pages/update-email/update-email.component.ts +0 -1
  210. package/src/login/pages/webauthn-authenticate/webauthn-authenticate.component.ts +0 -1
  211. package/src/login/pages/webauthn-error/webauthn-error.component.ts +0 -1
  212. package/src/login/pages/webauthn-register/webauthn-register.component.ts +0 -1
  213. package/src/login/providers/keycloakify-angular/keycloakify-angular.providers.ts +10 -8
  214. package/src/login/template/template.component.ts +0 -1
  215. package/bin/108.index.js +0 -306
  216. package/bin/338.index.js +0 -510
  217. package/bin/398.index.js +0 -4982
  218. package/bin/693.index.js +0 -1304
  219. package/bin/758.index.js +0 -1095
  220. package/bin/84.index.js +0 -720
  221. package/esm2022/account/DefaultPage/DefaultPage.mjs +0 -34
  222. package/esm2022/account/DefaultPage/index.mjs +0 -2
  223. package/esm2022/account/DefaultPage/keycloakify-angular-account-DefaultPage.mjs +0 -5
  224. package/esm2022/account/KcContext/KcContext.mjs +0 -2
  225. package/esm2022/account/KcContext/index.mjs +0 -2
  226. package/esm2022/account/KcContext/keycloakify-angular-account-KcContext.mjs +0 -5
  227. package/esm2022/account/account.mjs +0 -3
  228. package/esm2022/account/classes/component-reference/component-reference.class.mjs +0 -3
  229. package/esm2022/account/classes/component-reference/index.mjs +0 -2
  230. package/esm2022/account/classes/component-reference/keycloakify-angular-account-classes-component-reference.mjs +0 -5
  231. package/esm2022/account/defaultPage.mjs +0 -26
  232. package/esm2022/account/directives/kc-class/index.mjs +0 -2
  233. package/esm2022/account/directives/kc-class/kc-class.directive.mjs +0 -141
  234. package/esm2022/account/directives/kc-class/keycloakify-angular-account-directives-kc-class.mjs +0 -5
  235. package/esm2022/account/i18n/i18n.mjs +0 -2
  236. package/esm2022/account/i18n/index.mjs +0 -2
  237. package/esm2022/account/i18n/keycloakify-angular-account-i18n.mjs +0 -5
  238. package/esm2022/account/index.mjs +0 -2
  239. package/esm2022/account/keycloakify-angular-account.mjs +0 -5
  240. package/esm2022/account/pages/account/account.component.mjs +0 -39
  241. package/esm2022/account/pages/account/index.mjs +0 -2
  242. package/esm2022/account/pages/account/keycloakify-angular-account-pages-account.mjs +0 -5
  243. package/esm2022/account/pages/applications/applications.component.mjs +0 -37
  244. package/esm2022/account/pages/applications/index.mjs +0 -2
  245. package/esm2022/account/pages/applications/keycloakify-angular-account-pages-applications.mjs +0 -5
  246. package/esm2022/account/pages/federatedIdentity/federatedIdentity.component.mjs +0 -36
  247. package/esm2022/account/pages/federatedIdentity/index.mjs +0 -2
  248. package/esm2022/account/pages/federatedIdentity/keycloakify-angular-account-pages-federatedIdentity.mjs +0 -5
  249. package/esm2022/account/pages/log/index.mjs +0 -2
  250. package/esm2022/account/pages/log/keycloakify-angular-account-pages-log.mjs +0 -5
  251. package/esm2022/account/pages/log/log.component.mjs +0 -36
  252. package/esm2022/account/pages/password/index.mjs +0 -2
  253. package/esm2022/account/pages/password/keycloakify-angular-account-pages-password.mjs +0 -5
  254. package/esm2022/account/pages/password/password.component.mjs +0 -108
  255. package/esm2022/account/pages/sessions/index.mjs +0 -2
  256. package/esm2022/account/pages/sessions/keycloakify-angular-account-pages-sessions.mjs +0 -5
  257. package/esm2022/account/pages/sessions/sessions.component.mjs +0 -36
  258. package/esm2022/account/pages/totp/index.mjs +0 -2
  259. package/esm2022/account/pages/totp/keycloakify-angular-account-pages-totp.mjs +0 -5
  260. package/esm2022/account/pages/totp/totp.component.mjs +0 -37
  261. package/esm2022/account/providers/keycloakify-angular/index.mjs +0 -2
  262. package/esm2022/account/providers/keycloakify-angular/keycloakify-angular-account-providers-keycloakify-angular.mjs +0 -5
  263. package/esm2022/account/providers/keycloakify-angular/keycloakify-angular.providers.mjs +0 -47
  264. package/esm2022/account/services/account-resource-injector/account-resource-injector.service.mjs +0 -37
  265. package/esm2022/account/services/account-resource-injector/index.mjs +0 -2
  266. package/esm2022/account/services/account-resource-injector/keycloakify-angular-account-services-account-resource-injector.mjs +0 -5
  267. package/esm2022/account/services/i18n/i18n.service.mjs +0 -12
  268. package/esm2022/account/services/i18n/index.mjs +0 -2
  269. package/esm2022/account/services/i18n/keycloakify-angular-account-services-i18n.mjs +0 -5
  270. package/esm2022/account/template/index.mjs +0 -2
  271. package/esm2022/account/template/keycloakify-angular-account-template.mjs +0 -5
  272. package/esm2022/account/template/template.component.mjs +0 -83
  273. package/esm2022/account/tokens/classes/classes.token.mjs +0 -3
  274. package/esm2022/account/tokens/classes/index.mjs +0 -2
  275. package/esm2022/account/tokens/classes/keycloakify-angular-account-tokens-classes.mjs +0 -5
  276. package/esm2022/account/tokens/i18n/i18n.token.mjs +0 -3
  277. package/esm2022/account/tokens/i18n/index.mjs +0 -2
  278. package/esm2022/account/tokens/i18n/keycloakify-angular-account-tokens-i18n.mjs +0 -5
  279. package/esm2022/account/tokens/kc-context/index.mjs +0 -2
  280. package/esm2022/account/tokens/kc-context/kc-context.token.mjs +0 -3
  281. package/esm2022/account/tokens/kc-context/keycloakify-angular-account-tokens-kc-context.mjs +0 -5
  282. package/esm2022/index.mjs +0 -2
  283. package/esm2022/keycloakify-angular.mjs +0 -5
  284. package/esm2022/lib/directives/attributes/attributes.directive.mjs +0 -26
  285. package/esm2022/lib/directives/attributes/index.mjs +0 -2
  286. package/esm2022/lib/directives/attributes/keycloakify-angular-lib-directives-attributes.mjs +0 -5
  287. package/esm2022/lib/index.mjs +0 -2
  288. package/esm2022/lib/keycloakify-angular-lib.mjs +0 -5
  289. package/esm2022/lib/models/script/index.mjs +0 -2
  290. package/esm2022/lib/models/script/keycloakify-angular-lib-models-script.mjs +0 -5
  291. package/esm2022/lib/models/script/script.model.mjs +0 -2
  292. package/esm2022/lib/pipes/input-type/index.mjs +0 -2
  293. package/esm2022/lib/pipes/input-type/input-type.pipe.mjs +0 -20
  294. package/esm2022/lib/pipes/input-type/keycloakify-angular-lib-pipes-input-type.mjs +0 -5
  295. package/esm2022/lib/pipes/is-array-with-empty-object/index.mjs +0 -2
  296. package/esm2022/lib/pipes/is-array-with-empty-object/is-array-with-empty-object.pipe.mjs +0 -20
  297. package/esm2022/lib/pipes/is-array-with-empty-object/keycloakify-angular-lib-pipes-is-array-with-empty-object.mjs +0 -5
  298. package/esm2022/lib/pipes/kc-sanitize/index.mjs +0 -2
  299. package/esm2022/lib/pipes/kc-sanitize/kc-sanitize.pipe.mjs +0 -29
  300. package/esm2022/lib/pipes/kc-sanitize/keycloakify-angular-lib-pipes-kc-sanitize.mjs +0 -5
  301. package/esm2022/lib/pipes/to-array/index.mjs +0 -2
  302. package/esm2022/lib/pipes/to-array/keycloakify-angular-lib-pipes-to-array.mjs +0 -5
  303. package/esm2022/lib/pipes/to-array/to-array.pipe.mjs +0 -21
  304. package/esm2022/lib/pipes/to-number/index.mjs +0 -2
  305. package/esm2022/lib/pipes/to-number/keycloakify-angular-lib-pipes-to-number.mjs +0 -5
  306. package/esm2022/lib/pipes/to-number/to-number.pipe.mjs +0 -20
  307. package/esm2022/lib/services/resource-injector/index.mjs +0 -2
  308. package/esm2022/lib/services/resource-injector/keycloakify-angular-lib-services-resource-injector.mjs +0 -5
  309. package/esm2022/lib/services/resource-injector/resource-injector.service.mjs +0 -55
  310. package/esm2022/lib/tokens/use-default-css/index.mjs +0 -2
  311. package/esm2022/lib/tokens/use-default-css/keycloakify-angular-lib-tokens-use-default-css.mjs +0 -5
  312. package/esm2022/lib/tokens/use-default-css/use-default-css.token.mjs +0 -3
  313. package/esm2022/login/KcContext/KcContext.mjs +0 -2
  314. package/esm2022/login/KcContext/index.mjs +0 -2
  315. package/esm2022/login/KcContext/keycloakify-angular-login-KcContext.mjs +0 -5
  316. package/esm2022/login/classes/component-reference/component-reference.class.mjs +0 -3
  317. package/esm2022/login/classes/component-reference/index.mjs +0 -2
  318. package/esm2022/login/classes/component-reference/keycloakify-angular-login-classes-component-reference.mjs +0 -5
  319. package/esm2022/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.mjs +0 -60
  320. package/esm2022/login/components/add-remove-buttons-multi-valued-attribute/index.mjs +0 -2
  321. package/esm2022/login/components/add-remove-buttons-multi-valued-attribute/keycloakify-angular-login-components-add-remove-buttons-multi-valued-attribute.mjs +0 -5
  322. package/esm2022/login/components/field-errors/field-errors.component.mjs +0 -33
  323. package/esm2022/login/components/field-errors/index.mjs +0 -2
  324. package/esm2022/login/components/field-errors/keycloakify-angular-login-components-field-errors.mjs +0 -5
  325. package/esm2022/login/components/group-label/group-label.component.mjs +0 -43
  326. package/esm2022/login/components/group-label/index.mjs +0 -2
  327. package/esm2022/login/components/group-label/keycloakify-angular-login-components-group-label.mjs +0 -5
  328. package/esm2022/login/components/input-field-by-type/index.mjs +0 -2
  329. package/esm2022/login/components/input-field-by-type/input-field-by-type.component.mjs +0 -46
  330. package/esm2022/login/components/input-field-by-type/keycloakify-angular-login-components-input-field-by-type.mjs +0 -5
  331. package/esm2022/login/components/input-tag/index.mjs +0 -2
  332. package/esm2022/login/components/input-tag/input-tag.component.mjs +0 -90
  333. package/esm2022/login/components/input-tag/keycloakify-angular-login-components-input-tag.mjs +0 -5
  334. package/esm2022/login/components/input-tag-selects/index.mjs +0 -2
  335. package/esm2022/login/components/input-tag-selects/input-tag-selects.component.mjs +0 -117
  336. package/esm2022/login/components/input-tag-selects/keycloakify-angular-login-components-input-tag-selects.mjs +0 -5
  337. package/esm2022/login/components/logout-other-sessions/index.mjs +0 -2
  338. package/esm2022/login/components/logout-other-sessions/keycloakify-angular-login-components-logout-other-sessions.mjs +0 -5
  339. package/esm2022/login/components/logout-other-sessions/logout-other-sessions.component.mjs +0 -32
  340. package/esm2022/login/components/password-wrapper/index.mjs +0 -2
  341. package/esm2022/login/components/password-wrapper/keycloakify-angular-login-components-password-wrapper.mjs +0 -5
  342. package/esm2022/login/components/password-wrapper/password-wrapper.component.mjs +0 -46
  343. package/esm2022/login/components/select-tag/index.mjs +0 -2
  344. package/esm2022/login/components/select-tag/keycloakify-angular-login-components-select-tag.mjs +0 -5
  345. package/esm2022/login/components/select-tag/select-tag.component.mjs +0 -82
  346. package/esm2022/login/components/textarea-tag/index.mjs +0 -2
  347. package/esm2022/login/components/textarea-tag/keycloakify-angular-login-components-textarea-tag.mjs +0 -5
  348. package/esm2022/login/components/textarea-tag/textarea-tag.component.mjs +0 -49
  349. package/esm2022/login/components/user-profile-form-fields/index.mjs +0 -2
  350. package/esm2022/login/components/user-profile-form-fields/keycloakify-angular-login-components-user-profile-form-fields.mjs +0 -5
  351. package/esm2022/login/components/user-profile-form-fields/user-profile-form-fields.component.mjs +0 -55
  352. package/esm2022/login/defaultPage.mjs +0 -77
  353. package/esm2022/login/directives/kc-class/index.mjs +0 -2
  354. package/esm2022/login/directives/kc-class/kc-class.directive.mjs +0 -138
  355. package/esm2022/login/directives/kc-class/keycloakify-angular-login-directives-kc-class.mjs +0 -5
  356. package/esm2022/login/i18n/i18n.mjs +0 -2
  357. package/esm2022/login/i18n/index.mjs +0 -2
  358. package/esm2022/login/i18n/keycloakify-angular-login-i18n.mjs +0 -5
  359. package/esm2022/login/index.mjs +0 -2
  360. package/esm2022/login/keycloakify-angular-login.mjs +0 -5
  361. package/esm2022/login/login.mjs +0 -3
  362. package/esm2022/login/pages/code/code.component.mjs +0 -40
  363. package/esm2022/login/pages/code/index.mjs +0 -2
  364. package/esm2022/login/pages/code/keycloakify-angular-login-pages-code.mjs +0 -5
  365. package/esm2022/login/pages/delete-account-confirm/delete-account-confirm.component.mjs +0 -40
  366. package/esm2022/login/pages/delete-account-confirm/index.mjs +0 -2
  367. package/esm2022/login/pages/delete-account-confirm/keycloakify-angular-login-pages-delete-account-confirm.mjs +0 -5
  368. package/esm2022/login/pages/delete-credential/delete-credential.component.mjs +0 -40
  369. package/esm2022/login/pages/delete-credential/index.mjs +0 -2
  370. package/esm2022/login/pages/delete-credential/keycloakify-angular-login-pages-delete-credential.mjs +0 -5
  371. package/esm2022/login/pages/error/error.component.mjs +0 -40
  372. package/esm2022/login/pages/error/index.mjs +0 -2
  373. package/esm2022/login/pages/error/keycloakify-angular-login-pages-error.mjs +0 -5
  374. package/esm2022/login/pages/frontchannel-logout/frontchannel-logout.component.mjs +0 -46
  375. package/esm2022/login/pages/frontchannel-logout/index.mjs +0 -2
  376. package/esm2022/login/pages/frontchannel-logout/keycloakify-angular-login-pages-frontchannel-logout.mjs +0 -5
  377. package/esm2022/login/pages/idp-review-user-profile/idp-review-user-profile.component.mjs +0 -51
  378. package/esm2022/login/pages/idp-review-user-profile/index.mjs +0 -2
  379. package/esm2022/login/pages/idp-review-user-profile/keycloakify-angular-login-pages-idp-review-user-profile.mjs +0 -5
  380. package/esm2022/login/pages/info/index.mjs +0 -2
  381. package/esm2022/login/pages/info/info.component.mjs +0 -49
  382. package/esm2022/login/pages/info/keycloakify-angular-login-pages-info.mjs +0 -5
  383. package/esm2022/login/pages/login/index.mjs +0 -2
  384. package/esm2022/login/pages/login/keycloakify-angular-login-pages-login.mjs +0 -5
  385. package/esm2022/login/pages/login/login.component.mjs +0 -44
  386. package/esm2022/login/pages/login-config-totp/index.mjs +0 -2
  387. package/esm2022/login/pages/login-config-totp/keycloakify-angular-login-pages-login-config-totp.mjs +0 -5
  388. package/esm2022/login/pages/login-config-totp/login-config-totp.component.mjs +0 -42
  389. package/esm2022/login/pages/login-idp-link-confirm/index.mjs +0 -2
  390. package/esm2022/login/pages/login-idp-link-confirm/keycloakify-angular-login-pages-login-idp-link-confirm.mjs +0 -5
  391. package/esm2022/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.mjs +0 -36
  392. package/esm2022/login/pages/login-idp-link-confirm-override/index.mjs +0 -2
  393. package/esm2022/login/pages/login-idp-link-confirm-override/keycloakify-angular-login-pages-login-idp-link-confirm-override.mjs +0 -5
  394. package/esm2022/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.mjs +0 -36
  395. package/esm2022/login/pages/login-idp-link-email/index.mjs +0 -2
  396. package/esm2022/login/pages/login-idp-link-email/keycloakify-angular-login-pages-login-idp-link-email.mjs +0 -5
  397. package/esm2022/login/pages/login-idp-link-email/login-idp-link-email.component.mjs +0 -36
  398. package/esm2022/login/pages/login-oauth-grant/index.mjs +0 -2
  399. package/esm2022/login/pages/login-oauth-grant/keycloakify-angular-login-pages-login-oauth-grant.mjs +0 -5
  400. package/esm2022/login/pages/login-oauth-grant/login-oauth-grant.component.mjs +0 -37
  401. package/esm2022/login/pages/login-oauth2-device-verify-user-code/index.mjs +0 -2
  402. package/esm2022/login/pages/login-oauth2-device-verify-user-code/keycloakify-angular-login-pages-login-oauth2-device-verify-user-code.mjs +0 -5
  403. package/esm2022/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.mjs +0 -40
  404. package/esm2022/login/pages/login-otp/index.mjs +0 -2
  405. package/esm2022/login/pages/login-otp/keycloakify-angular-login-pages-login-otp.mjs +0 -5
  406. package/esm2022/login/pages/login-otp/login-otp.component.mjs +0 -41
  407. package/esm2022/login/pages/login-page-expired/index.mjs +0 -2
  408. package/esm2022/login/pages/login-page-expired/keycloakify-angular-login-pages-login-page-expired.mjs +0 -5
  409. package/esm2022/login/pages/login-page-expired/login-page-expired.component.mjs +0 -39
  410. package/esm2022/login/pages/login-passkeys-conditional-authenticate/index.mjs +0 -2
  411. package/esm2022/login/pages/login-passkeys-conditional-authenticate/keycloakify-angular-login-pages-login-passkeys-conditional-authenticate.mjs +0 -5
  412. package/esm2022/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.mjs +0 -88
  413. package/esm2022/login/pages/login-password/index.mjs +0 -2
  414. package/esm2022/login/pages/login-password/keycloakify-angular-login-pages-login-password.mjs +0 -5
  415. package/esm2022/login/pages/login-password/login-password.component.mjs +0 -44
  416. package/esm2022/login/pages/login-recovery-authn-code-config/index.mjs +0 -2
  417. package/esm2022/login/pages/login-recovery-authn-code-config/keycloakify-angular-login-pages-login-recovery-authn-code-config.mjs +0 -5
  418. package/esm2022/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.mjs +0 -164
  419. package/esm2022/login/pages/login-recovery-authn-code-input/index.mjs +0 -2
  420. package/esm2022/login/pages/login-recovery-authn-code-input/keycloakify-angular-login-pages-login-recovery-authn-code-input.mjs +0 -5
  421. package/esm2022/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.mjs +0 -41
  422. package/esm2022/login/pages/login-reset-otp/index.mjs +0 -2
  423. package/esm2022/login/pages/login-reset-otp/keycloakify-angular-login-pages-login-reset-otp.mjs +0 -5
  424. package/esm2022/login/pages/login-reset-otp/login-reset-otp.component.mjs +0 -40
  425. package/esm2022/login/pages/login-reset-password/index.mjs +0 -2
  426. package/esm2022/login/pages/login-reset-password/keycloakify-angular-login-pages-login-reset-password.mjs +0 -5
  427. package/esm2022/login/pages/login-reset-password/login-reset-password.component.mjs +0 -41
  428. package/esm2022/login/pages/login-update-password/index.mjs +0 -2
  429. package/esm2022/login/pages/login-update-password/keycloakify-angular-login-pages-login-update-password.mjs +0 -5
  430. package/esm2022/login/pages/login-update-password/login-update-password.component.mjs +0 -43
  431. package/esm2022/login/pages/login-update-profile/index.mjs +0 -2
  432. package/esm2022/login/pages/login-update-profile/keycloakify-angular-login-pages-login-update-profile.mjs +0 -5
  433. package/esm2022/login/pages/login-update-profile/login-update-profile.component.mjs +0 -48
  434. package/esm2022/login/pages/login-username/index.mjs +0 -2
  435. package/esm2022/login/pages/login-username/keycloakify-angular-login-pages-login-username.mjs +0 -5
  436. package/esm2022/login/pages/login-username/login-username.component.mjs +0 -43
  437. package/esm2022/login/pages/login-verify-email/index.mjs +0 -2
  438. package/esm2022/login/pages/login-verify-email/keycloakify-angular-login-pages-login-verify-email.mjs +0 -5
  439. package/esm2022/login/pages/login-verify-email/login-verify-email.component.mjs +0 -40
  440. package/esm2022/login/pages/login-x509-info/index.mjs +0 -2
  441. package/esm2022/login/pages/login-x509-info/keycloakify-angular-login-pages-login-x509-info.mjs +0 -5
  442. package/esm2022/login/pages/login-x509-info/login-x509-info.component.mjs +0 -40
  443. package/esm2022/login/pages/logout-confirm/index.mjs +0 -2
  444. package/esm2022/login/pages/logout-confirm/keycloakify-angular-login-pages-logout-confirm.mjs +0 -5
  445. package/esm2022/login/pages/logout-confirm/logout-confirm.component.mjs +0 -36
  446. package/esm2022/login/pages/register/index.mjs +0 -2
  447. package/esm2022/login/pages/register/keycloakify-angular-login-pages-register.mjs +0 -5
  448. package/esm2022/login/pages/register/register.component.mjs +0 -53
  449. package/esm2022/login/pages/saml-post-form/index.mjs +0 -2
  450. package/esm2022/login/pages/saml-post-form/keycloakify-angular-login-pages-saml-post-form.mjs +0 -5
  451. package/esm2022/login/pages/saml-post-form/saml-post-form.component.mjs +0 -50
  452. package/esm2022/login/pages/select-authenticator/index.mjs +0 -2
  453. package/esm2022/login/pages/select-authenticator/keycloakify-angular-login-pages-select-authenticator.mjs +0 -5
  454. package/esm2022/login/pages/select-authenticator/select-authenticator.component.mjs +0 -41
  455. package/esm2022/login/pages/terms/index.mjs +0 -2
  456. package/esm2022/login/pages/terms/keycloakify-angular-login-pages-terms.mjs +0 -5
  457. package/esm2022/login/pages/terms/terms.component.mjs +0 -40
  458. package/esm2022/login/pages/update-email/index.mjs +0 -2
  459. package/esm2022/login/pages/update-email/keycloakify-angular-login-pages-update-email.mjs +0 -5
  460. package/esm2022/login/pages/update-email/update-email.component.mjs +0 -45
  461. package/esm2022/login/pages/webauthn-authenticate/index.mjs +0 -2
  462. package/esm2022/login/pages/webauthn-authenticate/keycloakify-angular-login-pages-webauthn-authenticate.mjs +0 -5
  463. package/esm2022/login/pages/webauthn-authenticate/webauthn-authenticate.component.mjs +0 -80
  464. package/esm2022/login/pages/webauthn-error/index.mjs +0 -2
  465. package/esm2022/login/pages/webauthn-error/keycloakify-angular-login-pages-webauthn-error.mjs +0 -5
  466. package/esm2022/login/pages/webauthn-error/webauthn-error.component.mjs +0 -49
  467. package/esm2022/login/pages/webauthn-register/index.mjs +0 -2
  468. package/esm2022/login/pages/webauthn-register/keycloakify-angular-login-pages-webauthn-register.mjs +0 -5
  469. package/esm2022/login/pages/webauthn-register/webauthn-register.component.mjs +0 -76
  470. package/esm2022/login/providers/keycloakify-angular/index.mjs +0 -2
  471. package/esm2022/login/providers/keycloakify-angular/keycloakify-angular-login-providers-keycloakify-angular.mjs +0 -5
  472. package/esm2022/login/providers/keycloakify-angular/keycloakify-angular.providers.mjs +0 -52
  473. package/esm2022/login/services/i18n/i18n.service.mjs +0 -12
  474. package/esm2022/login/services/i18n/index.mjs +0 -2
  475. package/esm2022/login/services/i18n/keycloakify-angular-login-services-i18n.mjs +0 -5
  476. package/esm2022/login/services/login-resource-injector/index.mjs +0 -2
  477. package/esm2022/login/services/login-resource-injector/keycloakify-angular-login-services-login-resource-injector.mjs +0 -5
  478. package/esm2022/login/services/login-resource-injector/login-resource-injector.service.mjs +0 -69
  479. package/esm2022/login/services/user-profile-form/index.mjs +0 -2
  480. package/esm2022/login/services/user-profile-form/keycloakify-angular-login-services-user-profile-form.mjs +0 -5
  481. package/esm2022/login/services/user-profile-form/user-profile-form.service.mjs +0 -71
  482. package/esm2022/login/template/index.mjs +0 -2
  483. package/esm2022/login/template/keycloakify-angular-login-template.mjs +0 -5
  484. package/esm2022/login/template/template.component.mjs +0 -123
  485. package/esm2022/login/tokens/classes/classes.token.mjs +0 -3
  486. package/esm2022/login/tokens/classes/index.mjs +0 -2
  487. package/esm2022/login/tokens/classes/keycloakify-angular-login-tokens-classes.mjs +0 -5
  488. package/esm2022/login/tokens/i18n/i18n.token.mjs +0 -3
  489. package/esm2022/login/tokens/i18n/index.mjs +0 -2
  490. package/esm2022/login/tokens/i18n/keycloakify-angular-login-tokens-i18n.mjs +0 -5
  491. package/esm2022/login/tokens/kc-context/index.mjs +0 -2
  492. package/esm2022/login/tokens/kc-context/kc-context.token.mjs +0 -3
  493. package/esm2022/login/tokens/kc-context/keycloakify-angular-login-tokens-kc-context.mjs +0 -5
  494. package/esm2022/login/tokens/make-user-confirm-password/index.mjs +0 -2
  495. package/esm2022/login/tokens/make-user-confirm-password/keycloakify-angular-login-tokens-make-user-confirm-password.mjs +0 -5
  496. package/esm2022/login/tokens/make-user-confirm-password/make-user-confirm-password.token.mjs +0 -3
@@ -1,44 +0,0 @@
1
- import { AsyncPipe, CommonModule, NgClass } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, forwardRef, inject, signal, viewChild } from '@angular/core';
3
- import { KcSanitizePipe } from '@keycloakify/angular/lib/pipes/kc-sanitize';
4
- import { USE_DEFAULT_CSS } from '@keycloakify/angular/lib/tokens/use-default-css';
5
- import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
6
- import { PasswordWrapperComponent } from '@keycloakify/angular/login/components/password-wrapper';
7
- import { KcClassDirective } from '@keycloakify/angular/login/directives/kc-class';
8
- import { LOGIN_CLASSES } from '@keycloakify/angular/login/tokens/classes';
9
- import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
10
- import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
11
- import * as i0 from "@angular/core";
12
- export class LoginComponent extends ComponentReference {
13
- constructor() {
14
- super(...arguments);
15
- this.kcContext = inject(KC_LOGIN_CONTEXT);
16
- this.i18n = inject(LOGIN_I18N);
17
- this.doUseDefaultCss = inject(USE_DEFAULT_CSS);
18
- this.classes = inject(LOGIN_CLASSES);
19
- this.displayRequiredFields = false;
20
- this.displayInfo = !!this.kcContext?.realm?.password && !!this.kcContext?.realm?.registrationAllowed && !this.kcContext?.registrationDisabled;
21
- this.displayMessage = !this.kcContext?.messagesPerField?.existsError('username', 'password');
22
- this.headerNode = viewChild('headerNode');
23
- this.infoNode = viewChild('infoNode');
24
- this.socialProvidersNode = viewChild('socialProvidersNode');
25
- this.isLoginButtonDisabled = signal(false);
26
- }
27
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
28
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: LoginComponent, isStandalone: true, selector: "kc-login", providers: [
29
- {
30
- provide: ComponentReference,
31
- useExisting: forwardRef(() => LoginComponent)
32
- }
33
- ], viewQueries: [{ propertyName: "headerNode", first: true, predicate: ["headerNode"], descendants: true, isSignal: true }, { propertyName: "infoNode", first: true, predicate: ["infoNode"], descendants: true, isSignal: true }, { propertyName: "socialProvidersNode", first: true, predicate: ["socialProvidersNode"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@let realm = kcContext.realm;\n@let usernameHidden = kcContext.usernameHidden;\n@let auth = kcContext.auth;\n@let messagesPerField = kcContext.messagesPerField;\n@let url = kcContext.url;\n@let login = kcContext.login;\n\n<ng-template #headerNode>\n {{ i18n.msgStr('loginAccountTitle') }}\n</ng-template>\n<ng-template #infoNode>\n @let url = kcContext.url;\n <div id=\"kc-registration-container\">\n <div id=\"kc-registration\">\n <span>\n {{ i18n.msgStr('noAccount') }}\n <a\n tabindex=\"8\"\n [href]=\"url?.registrationUrl\"\n >\n {{ i18n.msgStr('doRegister') }}\n </a>\n </span>\n </div>\n </div>\n</ng-template>\n<ng-template #socialProvidersNode>\n @let realm = kcContext.realm;\n @let social = kcContext.social;\n @if (!!realm?.password && !!social?.providers?.length) {\n <div\n id=\"kc-social-providers\"\n [kcClass]=\"'kcFormSocialAccountSectionClass'\"\n >\n <hr />\n <h2>{{ i18n.msgStr('identity-provider-login-label') }}</h2>\n <ul\n [kcClass]=\"{\n kcFormSocialAccountListClass: true,\n kcFormSocialAccountListGridClass: (social?.providers?.length ?? 0) > 3\n }\"\n >\n @for (provider of social?.providers; track provider.alias; let idx = $index) {\n <li>\n <a\n type=\"button\"\n [id]=\"provider.alias\"\n [kcClass]=\"{\n kcFormSocialAccountListButtonClass: true,\n kcFormSocialAccountGridItem: (social?.providers?.length ?? 0) > 3\n }\"\n [href]=\"provider.loginUrl\"\n >\n @if (provider.iconClasses) {\n <i\n aria-hidden=\"true\"\n [ngClass]=\"provider.iconClasses\"\n [kcClass]=\"'kcCommonLogoIdP'\"\n ></i>\n }\n <span\n [ngClass]=\"{\n 'kc-social-icon-text': provider.iconClasses\n }\"\n [kcClass]=\"'kcFormSocialAccountNameClass'\"\n [innerHTML]=\"provider.displayName | kcSanitize: 'html'\"\n ></span>\n </a>\n </li>\n }\n </ul>\n </div>\n }\n</ng-template>\n<div id=\"kc-form\">\n <div id=\"kc-form-wrapper\">\n <!-- login.component.html -->\n @if (realm?.password) {\n <form\n id=\"kc-form-login\"\n method=\"post\"\n [action]=\"url?.loginAction\"\n (onSubmit)=\"isLoginButtonDisabled.set(true)\"\n >\n @if (!usernameHidden) {\n <div [kcClass]=\"'kcFormGroupClass'\">\n <label\n for=\"username\"\n [kcClass]=\"'kcLabelClass'\"\n >\n @if (!realm?.loginWithEmailAllowed) {\n {{ i18n.msgStr('username') }}\n } @else if (!realm?.registrationEmailAsUsername) {\n {{ i18n.msgStr('usernameOrEmail') }}\n } @else {\n {{ i18n.msgStr('email') }}\n }\n </label>\n <input\n tabindex=\"2\"\n id=\"username\"\n name=\"username\"\n type=\"text\"\n autofocus\n [kcClass]=\"'kcInputClass'\"\n [defaultValue]=\"login?.username || ''\"\n [attr.aria-invalid]=\"messagesPerField?.existsError('username', 'password')\"\n />\n @if (messagesPerField?.existsError('username', 'password')) {\n <span\n id=\"input-error\"\n aria-live=\"polite\"\n [kcClass]=\"'kcInputErrorMessageClass'\"\n [innerHTML]=\"messagesPerField.getFirstError('username', 'password') | kcSanitize: 'html'\"\n >\n </span>\n }\n </div>\n }\n\n <div [kcClass]=\"'kcFormGroupClass'\">\n <label\n for=\"password\"\n [kcClass]=\"'kcLabelClass'\"\n >\n {{ i18n.msgStr('password') }}\n </label>\n\n <kc-password-wrapper passwordInputId=\"password\">\n <input\n tabindex=\"3\"\n id=\"password\"\n name=\"password\"\n type=\"password\"\n autocomplete=\"off\"\n [kcClass]=\"'kcInputClass'\"\n [attr.aria-invalid]=\"messagesPerField.existsError('username', 'password')\"\n />\n </kc-password-wrapper>\n @if (usernameHidden && messagesPerField?.existsError('username', 'password')) {\n <span\n id=\"input-error\"\n aria-live=\"polite\"\n [kcClass]=\"'kcInputErrorMessageClass'\"\n [innerHTML]=\"messagesPerField.getFirstError('username', 'password') | kcSanitize: 'html'\"\n >\n </span>\n }\n </div>\n\n <div [kcClass]=\"['kcFormGroupClass', 'kcFormSettingClass']\">\n <div id=\"kc-form-options\">\n @if (realm?.rememberMe && !usernameHidden) {\n <div class=\"checkbox\">\n <label>\n <input\n tabindex=\"5\"\n id=\"rememberMe\"\n name=\"rememberMe\"\n type=\"checkbox\"\n [defaultChecked]=\"!!login?.rememberMe\"\n />\n {{ i18n.msgStr('rememberMe') }}\n </label>\n </div>\n }\n </div>\n\n <div [kcClass]=\"'kcFormOptionsWrapperClass'\">\n @if (realm?.resetPasswordAllowed) {\n <span>\n <a\n tabindex=\"6\"\n [href]=\"url?.loginResetCredentialsUrl\"\n >{{ i18n.msgStr('doForgotPassword') }}</a\n >\n </span>\n }\n </div>\n </div>\n <div\n id=\"kc-form-buttons\"\n [kcClass]=\"'kcFormGroupClass'\"\n >\n <input\n type=\"hidden\"\n id=\"id-hidden-input\"\n name=\"credentialId\"\n [value]=\"auth?.selectedCredential\"\n />\n <input\n tabindex=\"7\"\n name=\"login\"\n id=\"kc-login\"\n type=\"submit\"\n [kcClass]=\"['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonBlockClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doLogIn')\"\n [disabled]=\"isLoginButtonDisabled()\"\n />\n </div>\n </form>\n }\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: KcClassDirective, selector: "[kcClass]", inputs: ["class", "ngClass", "kcClass"] }, { kind: "pipe", type: KcSanitizePipe, name: "kcSanitize" }, { kind: "component", type: PasswordWrapperComponent, selector: "kc-password-wrapper", inputs: ["passwordInputId"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
34
- }
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginComponent, decorators: [{
36
- type: Component,
37
- args: [{ selector: 'kc-login', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [KcClassDirective, AsyncPipe, KcSanitizePipe, PasswordWrapperComponent, NgClass, CommonModule], providers: [
38
- {
39
- provide: ComponentReference,
40
- useExisting: forwardRef(() => LoginComponent)
41
- }
42
- ], template: "@let realm = kcContext.realm;\n@let usernameHidden = kcContext.usernameHidden;\n@let auth = kcContext.auth;\n@let messagesPerField = kcContext.messagesPerField;\n@let url = kcContext.url;\n@let login = kcContext.login;\n\n<ng-template #headerNode>\n {{ i18n.msgStr('loginAccountTitle') }}\n</ng-template>\n<ng-template #infoNode>\n @let url = kcContext.url;\n <div id=\"kc-registration-container\">\n <div id=\"kc-registration\">\n <span>\n {{ i18n.msgStr('noAccount') }}\n <a\n tabindex=\"8\"\n [href]=\"url?.registrationUrl\"\n >\n {{ i18n.msgStr('doRegister') }}\n </a>\n </span>\n </div>\n </div>\n</ng-template>\n<ng-template #socialProvidersNode>\n @let realm = kcContext.realm;\n @let social = kcContext.social;\n @if (!!realm?.password && !!social?.providers?.length) {\n <div\n id=\"kc-social-providers\"\n [kcClass]=\"'kcFormSocialAccountSectionClass'\"\n >\n <hr />\n <h2>{{ i18n.msgStr('identity-provider-login-label') }}</h2>\n <ul\n [kcClass]=\"{\n kcFormSocialAccountListClass: true,\n kcFormSocialAccountListGridClass: (social?.providers?.length ?? 0) > 3\n }\"\n >\n @for (provider of social?.providers; track provider.alias; let idx = $index) {\n <li>\n <a\n type=\"button\"\n [id]=\"provider.alias\"\n [kcClass]=\"{\n kcFormSocialAccountListButtonClass: true,\n kcFormSocialAccountGridItem: (social?.providers?.length ?? 0) > 3\n }\"\n [href]=\"provider.loginUrl\"\n >\n @if (provider.iconClasses) {\n <i\n aria-hidden=\"true\"\n [ngClass]=\"provider.iconClasses\"\n [kcClass]=\"'kcCommonLogoIdP'\"\n ></i>\n }\n <span\n [ngClass]=\"{\n 'kc-social-icon-text': provider.iconClasses\n }\"\n [kcClass]=\"'kcFormSocialAccountNameClass'\"\n [innerHTML]=\"provider.displayName | kcSanitize: 'html'\"\n ></span>\n </a>\n </li>\n }\n </ul>\n </div>\n }\n</ng-template>\n<div id=\"kc-form\">\n <div id=\"kc-form-wrapper\">\n <!-- login.component.html -->\n @if (realm?.password) {\n <form\n id=\"kc-form-login\"\n method=\"post\"\n [action]=\"url?.loginAction\"\n (onSubmit)=\"isLoginButtonDisabled.set(true)\"\n >\n @if (!usernameHidden) {\n <div [kcClass]=\"'kcFormGroupClass'\">\n <label\n for=\"username\"\n [kcClass]=\"'kcLabelClass'\"\n >\n @if (!realm?.loginWithEmailAllowed) {\n {{ i18n.msgStr('username') }}\n } @else if (!realm?.registrationEmailAsUsername) {\n {{ i18n.msgStr('usernameOrEmail') }}\n } @else {\n {{ i18n.msgStr('email') }}\n }\n </label>\n <input\n tabindex=\"2\"\n id=\"username\"\n name=\"username\"\n type=\"text\"\n autofocus\n [kcClass]=\"'kcInputClass'\"\n [defaultValue]=\"login?.username || ''\"\n [attr.aria-invalid]=\"messagesPerField?.existsError('username', 'password')\"\n />\n @if (messagesPerField?.existsError('username', 'password')) {\n <span\n id=\"input-error\"\n aria-live=\"polite\"\n [kcClass]=\"'kcInputErrorMessageClass'\"\n [innerHTML]=\"messagesPerField.getFirstError('username', 'password') | kcSanitize: 'html'\"\n >\n </span>\n }\n </div>\n }\n\n <div [kcClass]=\"'kcFormGroupClass'\">\n <label\n for=\"password\"\n [kcClass]=\"'kcLabelClass'\"\n >\n {{ i18n.msgStr('password') }}\n </label>\n\n <kc-password-wrapper passwordInputId=\"password\">\n <input\n tabindex=\"3\"\n id=\"password\"\n name=\"password\"\n type=\"password\"\n autocomplete=\"off\"\n [kcClass]=\"'kcInputClass'\"\n [attr.aria-invalid]=\"messagesPerField.existsError('username', 'password')\"\n />\n </kc-password-wrapper>\n @if (usernameHidden && messagesPerField?.existsError('username', 'password')) {\n <span\n id=\"input-error\"\n aria-live=\"polite\"\n [kcClass]=\"'kcInputErrorMessageClass'\"\n [innerHTML]=\"messagesPerField.getFirstError('username', 'password') | kcSanitize: 'html'\"\n >\n </span>\n }\n </div>\n\n <div [kcClass]=\"['kcFormGroupClass', 'kcFormSettingClass']\">\n <div id=\"kc-form-options\">\n @if (realm?.rememberMe && !usernameHidden) {\n <div class=\"checkbox\">\n <label>\n <input\n tabindex=\"5\"\n id=\"rememberMe\"\n name=\"rememberMe\"\n type=\"checkbox\"\n [defaultChecked]=\"!!login?.rememberMe\"\n />\n {{ i18n.msgStr('rememberMe') }}\n </label>\n </div>\n }\n </div>\n\n <div [kcClass]=\"'kcFormOptionsWrapperClass'\">\n @if (realm?.resetPasswordAllowed) {\n <span>\n <a\n tabindex=\"6\"\n [href]=\"url?.loginResetCredentialsUrl\"\n >{{ i18n.msgStr('doForgotPassword') }}</a\n >\n </span>\n }\n </div>\n </div>\n <div\n id=\"kc-form-buttons\"\n [kcClass]=\"'kcFormGroupClass'\"\n >\n <input\n type=\"hidden\"\n id=\"id-hidden-input\"\n name=\"credentialId\"\n [value]=\"auth?.selectedCredential\"\n />\n <input\n tabindex=\"7\"\n name=\"login\"\n id=\"kc-login\"\n type=\"submit\"\n [kcClass]=\"['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonBlockClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doLogIn')\"\n [disabled]=\"isLoginButtonDisabled()\"\n />\n </div>\n </form>\n }\n </div>\n</div>\n" }]
43
- }] });
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xvZ2luL3BhZ2VzL2xvZ2luL2xvZ2luLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9sb2dpbi9wYWdlcy9sb2dpbi9sb2dpbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFvQixTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUgsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUNsRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUM1RixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUNsRyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUdsRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDMUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3BFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDOztBQWdCaEYsTUFBTSxPQUFPLGNBQWUsU0FBUSxrQkFBa0I7SUFidEQ7O1FBY0ksY0FBUyxHQUFHLE1BQU0sQ0FBOEMsZ0JBQWdCLENBQUMsQ0FBQztRQUNsRixTQUFJLEdBQUcsTUFBTSxDQUFPLFVBQVUsQ0FBQyxDQUFDO1FBRXZCLG9CQUFlLEdBQUcsTUFBTSxDQUFVLGVBQWUsQ0FBQyxDQUFDO1FBQ25ELFlBQU8sR0FBRyxNQUFNLENBQW9DLGFBQWEsQ0FBQyxDQUFDO1FBSzVFLDBCQUFxQixHQUFHLEtBQUssQ0FBQztRQUM5QixnQkFBVyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLEtBQUssRUFBRSxRQUFRLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsS0FBSyxFQUFFLG1CQUFtQixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxvQkFBb0IsQ0FBQztRQUN6SSxtQkFBYyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBRXhGLGVBQVUsR0FBRyxTQUFTLENBQTJCLFlBQVksQ0FBQyxDQUFDO1FBQy9ELGFBQVEsR0FBRyxTQUFTLENBQTJCLFVBQVUsQ0FBQyxDQUFDO1FBQzNELHdCQUFtQixHQUFHLFNBQVMsQ0FBMkIscUJBQXFCLENBQUMsQ0FBQztRQUVqRiwwQkFBcUIsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDekM7K0dBbkJZLGNBQWM7bUdBQWQsY0FBYyx1REFQWjtZQUNQO2dCQUNJLE9BQU8sRUFBRSxrQkFBa0I7Z0JBQzNCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsY0FBYyxDQUFDO2FBQ2hEO1NBQ0osK1lDekJMLDZtUkE0TUEsNENEekxjLGdCQUFnQiwwRkFBYSxjQUFjLG1EQUFFLHdCQUF3Qiw2RkFBRSxPQUFPLG1GQUFFLFlBQVk7OzRGQVE3RixjQUFjO2tCQWIxQixTQUFTOytCQUNJLFVBQVUsY0FFUixJQUFJLG1CQUNDLHVCQUF1QixDQUFDLE1BQU0sV0FDdEMsQ0FBQyxnQkFBZ0IsRUFBRSxTQUFTLEVBQUUsY0FBYyxFQUFFLHdCQUF3QixFQUFFLE9BQU8sRUFBRSxZQUFZLENBQUMsYUFDNUY7d0JBQ1A7NEJBQ0ksT0FBTyxFQUFFLGtCQUFrQjs0QkFDM0IsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsZUFBZSxDQUFDO3lCQUNoRDtxQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFzeW5jUGlwZSwgQ29tbW9uTW9kdWxlLCBOZ0NsYXNzIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGZvcndhcmRSZWYsIGluamVjdCwgc2lnbmFsLCB0eXBlIFRlbXBsYXRlUmVmLCB2aWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEtjU2FuaXRpemVQaXBlIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbGliL3BpcGVzL2tjLXNhbml0aXplJztcbmltcG9ydCB7IFVTRV9ERUZBVUxUX0NTUyB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xpYi90b2tlbnMvdXNlLWRlZmF1bHQtY3NzJztcbmltcG9ydCB7IENvbXBvbmVudFJlZmVyZW5jZSB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL2NsYXNzZXMvY29tcG9uZW50LXJlZmVyZW5jZSc7XG5pbXBvcnQgeyBQYXNzd29yZFdyYXBwZXJDb21wb25lbnQgfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi9jb21wb25lbnRzL3Bhc3N3b3JkLXdyYXBwZXInO1xuaW1wb3J0IHsgS2NDbGFzc0RpcmVjdGl2ZSB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL2RpcmVjdGl2ZXMva2MtY2xhc3MnO1xuaW1wb3J0IHR5cGUgeyBJMThuIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vaTE4bic7XG5pbXBvcnQgdHlwZSB7IEtjQ29udGV4dCB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL0tjQ29udGV4dCc7XG5pbXBvcnQgeyBMT0dJTl9DTEFTU0VTIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vdG9rZW5zL2NsYXNzZXMnO1xuaW1wb3J0IHsgTE9HSU5fSTE4TiB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL3Rva2Vucy9pMThuJztcbmltcG9ydCB7IEtDX0xPR0lOX0NPTlRFWFQgfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi90b2tlbnMva2MtY29udGV4dCc7XG5pbXBvcnQgdHlwZSB7IENsYXNzS2V5IH0gZnJvbSAna2V5Y2xvYWtpZnkvbG9naW4vbGliL2tjQ2xzeCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAna2MtbG9naW4nLFxuICAgIHRlbXBsYXRlVXJsOiAnbG9naW4uY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaW1wb3J0czogW0tjQ2xhc3NEaXJlY3RpdmUsIEFzeW5jUGlwZSwgS2NTYW5pdGl6ZVBpcGUsIFBhc3N3b3JkV3JhcHBlckNvbXBvbmVudCwgTmdDbGFzcywgQ29tbW9uTW9kdWxlXSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogQ29tcG9uZW50UmVmZXJlbmNlLFxuICAgICAgICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gTG9naW5Db21wb25lbnQpXG4gICAgICAgIH1cbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIExvZ2luQ29tcG9uZW50IGV4dGVuZHMgQ29tcG9uZW50UmVmZXJlbmNlIHtcbiAgICBrY0NvbnRleHQgPSBpbmplY3Q8RXh0cmFjdDxLY0NvbnRleHQsIHsgcGFnZUlkOiAnbG9naW4uZnRsJyB9Pj4oS0NfTE9HSU5fQ09OVEVYVCk7XG4gICAgaTE4biA9IGluamVjdDxJMThuPihMT0dJTl9JMThOKTtcblxuICAgIG92ZXJyaWRlIGRvVXNlRGVmYXVsdENzcyA9IGluamVjdDxib29sZWFuPihVU0VfREVGQVVMVF9DU1MpO1xuICAgIG92ZXJyaWRlIGNsYXNzZXMgPSBpbmplY3Q8UGFydGlhbDxSZWNvcmQ8Q2xhc3NLZXksIHN0cmluZz4+PihMT0dJTl9DTEFTU0VTKTtcblxuICAgIGRvY3VtZW50VGl0bGU6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgICBib2R5Q2xhc3NOYW1lOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cbiAgICBkaXNwbGF5UmVxdWlyZWRGaWVsZHMgPSBmYWxzZTtcbiAgICBkaXNwbGF5SW5mbyA9ICEhdGhpcy5rY0NvbnRleHQ/LnJlYWxtPy5wYXNzd29yZCAmJiAhIXRoaXMua2NDb250ZXh0Py5yZWFsbT8ucmVnaXN0cmF0aW9uQWxsb3dlZCAmJiAhdGhpcy5rY0NvbnRleHQ/LnJlZ2lzdHJhdGlvbkRpc2FibGVkO1xuICAgIGRpc3BsYXlNZXNzYWdlID0gIXRoaXMua2NDb250ZXh0Py5tZXNzYWdlc1BlckZpZWxkPy5leGlzdHNFcnJvcigndXNlcm5hbWUnLCAncGFzc3dvcmQnKTtcblxuICAgIGhlYWRlck5vZGUgPSB2aWV3Q2hpbGQ8VGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+PignaGVhZGVyTm9kZScpO1xuICAgIGluZm9Ob2RlID0gdmlld0NoaWxkPFRlbXBsYXRlUmVmPEhUTUxFbGVtZW50Pj4oJ2luZm9Ob2RlJyk7XG4gICAgc29jaWFsUHJvdmlkZXJzTm9kZSA9IHZpZXdDaGlsZDxUZW1wbGF0ZVJlZjxIVE1MRWxlbWVudD4+KCdzb2NpYWxQcm92aWRlcnNOb2RlJyk7XG5cbiAgICBpc0xvZ2luQnV0dG9uRGlzYWJsZWQgPSBzaWduYWwoZmFsc2UpO1xufVxuIiwiQGxldCByZWFsbSA9IGtjQ29udGV4dC5yZWFsbTtcbkBsZXQgdXNlcm5hbWVIaWRkZW4gPSBrY0NvbnRleHQudXNlcm5hbWVIaWRkZW47XG5AbGV0IGF1dGggPSBrY0NvbnRleHQuYXV0aDtcbkBsZXQgbWVzc2FnZXNQZXJGaWVsZCA9IGtjQ29udGV4dC5tZXNzYWdlc1BlckZpZWxkO1xuQGxldCB1cmwgPSBrY0NvbnRleHQudXJsO1xuQGxldCBsb2dpbiA9IGtjQ29udGV4dC5sb2dpbjtcblxuPG5nLXRlbXBsYXRlICNoZWFkZXJOb2RlPlxuICAgIHt7IGkxOG4ubXNnU3RyKCdsb2dpbkFjY291bnRUaXRsZScpIH19XG48L25nLXRlbXBsYXRlPlxuPG5nLXRlbXBsYXRlICNpbmZvTm9kZT5cbiAgICBAbGV0IHVybCA9IGtjQ29udGV4dC51cmw7XG4gICAgPGRpdiBpZD1cImtjLXJlZ2lzdHJhdGlvbi1jb250YWluZXJcIj5cbiAgICAgICAgPGRpdiBpZD1cImtjLXJlZ2lzdHJhdGlvblwiPlxuICAgICAgICAgICAgPHNwYW4+XG4gICAgICAgICAgICAgICAge3sgaTE4bi5tc2dTdHIoJ25vQWNjb3VudCcpIH19XG4gICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgdGFiaW5kZXg9XCI4XCJcbiAgICAgICAgICAgICAgICAgICAgW2hyZWZdPVwidXJsPy5yZWdpc3RyYXRpb25VcmxcIlxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAge3sgaTE4bi5tc2dTdHIoJ2RvUmVnaXN0ZXInKSB9fVxuICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuPG5nLXRlbXBsYXRlICNzb2NpYWxQcm92aWRlcnNOb2RlPlxuICAgIEBsZXQgcmVhbG0gPSBrY0NvbnRleHQucmVhbG07XG4gICAgQGxldCBzb2NpYWwgPSBrY0NvbnRleHQuc29jaWFsO1xuICAgIEBpZiAoISFyZWFsbT8ucGFzc3dvcmQgJiYgISFzb2NpYWw/LnByb3ZpZGVycz8ubGVuZ3RoKSB7XG4gICAgICAgIDxkaXZcbiAgICAgICAgICAgIGlkPVwia2Mtc29jaWFsLXByb3ZpZGVyc1wiXG4gICAgICAgICAgICBba2NDbGFzc109XCIna2NGb3JtU29jaWFsQWNjb3VudFNlY3Rpb25DbGFzcydcIlxuICAgICAgICA+XG4gICAgICAgICAgICA8aHIgLz5cbiAgICAgICAgICAgIDxoMj57eyBpMThuLm1zZ1N0cignaWRlbnRpdHktcHJvdmlkZXItbG9naW4tbGFiZWwnKSB9fTwvaDI+XG4gICAgICAgICAgICA8dWxcbiAgICAgICAgICAgICAgICBba2NDbGFzc109XCJ7XG4gICAgICAgICAgICAgICAgICAgIGtjRm9ybVNvY2lhbEFjY291bnRMaXN0Q2xhc3M6IHRydWUsXG4gICAgICAgICAgICAgICAgICAgIGtjRm9ybVNvY2lhbEFjY291bnRMaXN0R3JpZENsYXNzOiAoc29jaWFsPy5wcm92aWRlcnM/Lmxlbmd0aCA/PyAwKSA+IDNcbiAgICAgICAgICAgICAgICB9XCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICBAZm9yIChwcm92aWRlciBvZiBzb2NpYWw/LnByb3ZpZGVyczsgdHJhY2sgcHJvdmlkZXIuYWxpYXM7IGxldCBpZHggPSAkaW5kZXgpIHtcbiAgICAgICAgICAgICAgICAgICAgPGxpPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbaWRdPVwicHJvdmlkZXIuYWxpYXNcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtrY0NsYXNzXT1cIntcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAga2NGb3JtU29jaWFsQWNjb3VudExpc3RCdXR0b25DbGFzczogdHJ1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAga2NGb3JtU29jaWFsQWNjb3VudEdyaWRJdGVtOiAoc29jaWFsPy5wcm92aWRlcnM/Lmxlbmd0aCA/PyAwKSA+IDNcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9XCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbaHJlZl09XCJwcm92aWRlci5sb2dpblVybFwiXG4gICAgICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgQGlmIChwcm92aWRlci5pY29uQ2xhc3Nlcykge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8aVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYXJpYS1oaWRkZW49XCJ0cnVlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtuZ0NsYXNzXT1cInByb3ZpZGVyLmljb25DbGFzc2VzXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtrY0NsYXNzXT1cIidrY0NvbW1vbkxvZ29JZFAnXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPjwvaT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHNwYW5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW25nQ2xhc3NdPVwie1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJ2tjLXNvY2lhbC1pY29uLXRleHQnOiBwcm92aWRlci5pY29uQ2xhc3Nlc1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB9XCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2tjQ2xhc3NdPVwiJ2tjRm9ybVNvY2lhbEFjY291bnROYW1lQ2xhc3MnXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2lubmVySFRNTF09XCJwcm92aWRlci5kaXNwbGF5TmFtZSB8IGtjU2FuaXRpemU6ICdodG1sJ1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPjwvc3Bhbj5cbiAgICAgICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICAgPC9saT5cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICA8L3VsPlxuICAgICAgICA8L2Rpdj5cbiAgICB9XG48L25nLXRlbXBsYXRlPlxuPGRpdiBpZD1cImtjLWZvcm1cIj5cbiAgICA8ZGl2IGlkPVwia2MtZm9ybS13cmFwcGVyXCI+XG4gICAgICAgIDwhLS0gbG9naW4uY29tcG9uZW50Lmh0bWwgLS0+XG4gICAgICAgIEBpZiAocmVhbG0/LnBhc3N3b3JkKSB7XG4gICAgICAgICAgICA8Zm9ybVxuICAgICAgICAgICAgICAgIGlkPVwia2MtZm9ybS1sb2dpblwiXG4gICAgICAgICAgICAgICAgbWV0aG9kPVwicG9zdFwiXG4gICAgICAgICAgICAgICAgW2FjdGlvbl09XCJ1cmw/LmxvZ2luQWN0aW9uXCJcbiAgICAgICAgICAgICAgICAob25TdWJtaXQpPVwiaXNMb2dpbkJ1dHRvbkRpc2FibGVkLnNldCh0cnVlKVwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgQGlmICghdXNlcm5hbWVIaWRkZW4pIHtcbiAgICAgICAgICAgICAgICAgICAgPGRpdiBba2NDbGFzc109XCIna2NGb3JtR3JvdXBDbGFzcydcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgIDxsYWJlbFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZvcj1cInVzZXJuYW1lXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBba2NDbGFzc109XCIna2NMYWJlbENsYXNzJ1wiXG4gICAgICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgQGlmICghcmVhbG0/LmxvZ2luV2l0aEVtYWlsQWxsb3dlZCkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB7eyBpMThuLm1zZ1N0cigndXNlcm5hbWUnKSB9fVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0gQGVsc2UgaWYgKCFyZWFsbT8ucmVnaXN0cmF0aW9uRW1haWxBc1VzZXJuYW1lKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHt7IGkxOG4ubXNnU3RyKCd1c2VybmFtZU9yRW1haWwnKSB9fVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0gQGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB7eyBpMThuLm1zZ1N0cignZW1haWwnKSB9fVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgIDwvbGFiZWw+XG4gICAgICAgICAgICAgICAgICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0YWJpbmRleD1cIjJcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlkPVwidXNlcm5hbWVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5hbWU9XCJ1c2VybmFtZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdHlwZT1cInRleHRcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGF1dG9mb2N1c1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtrY0NsYXNzXT1cIidrY0lucHV0Q2xhc3MnXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbZGVmYXVsdFZhbHVlXT1cImxvZ2luPy51c2VybmFtZSB8fCAnJ1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgW2F0dHIuYXJpYS1pbnZhbGlkXT1cIm1lc3NhZ2VzUGVyRmllbGQ/LmV4aXN0c0Vycm9yKCd1c2VybmFtZScsICdwYXNzd29yZCcpXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICAgICAgICBAaWYgKG1lc3NhZ2VzUGVyRmllbGQ/LmV4aXN0c0Vycm9yKCd1c2VybmFtZScsICdwYXNzd29yZCcpKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHNwYW5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWQ9XCJpbnB1dC1lcnJvclwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFyaWEtbGl2ZT1cInBvbGl0ZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtrY0NsYXNzXT1cIidrY0lucHV0RXJyb3JNZXNzYWdlQ2xhc3MnXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2lubmVySFRNTF09XCJtZXNzYWdlc1BlckZpZWxkLmdldEZpcnN0RXJyb3IoJ3VzZXJuYW1lJywgJ3Bhc3N3b3JkJykgfCBrY1Nhbml0aXplOiAnaHRtbCdcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgIDxkaXYgW2tjQ2xhc3NdPVwiJ2tjRm9ybUdyb3VwQ2xhc3MnXCI+XG4gICAgICAgICAgICAgICAgICAgIDxsYWJlbFxuICAgICAgICAgICAgICAgICAgICAgICAgZm9yPVwicGFzc3dvcmRcIlxuICAgICAgICAgICAgICAgICAgICAgICAgW2tjQ2xhc3NdPVwiJ2tjTGFiZWxDbGFzcydcIlxuICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAgICB7eyBpMThuLm1zZ1N0cigncGFzc3dvcmQnKSB9fVxuICAgICAgICAgICAgICAgICAgICA8L2xhYmVsPlxuXG4gICAgICAgICAgICAgICAgICAgIDxrYy1wYXNzd29yZC13cmFwcGVyIHBhc3N3b3JkSW5wdXRJZD1cInBhc3N3b3JkXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0YWJpbmRleD1cIjNcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlkPVwicGFzc3dvcmRcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5hbWU9XCJwYXNzd29yZFwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdHlwZT1cInBhc3N3b3JkXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBhdXRvY29tcGxldGU9XCJvZmZcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtrY0NsYXNzXT1cIidrY0lucHV0Q2xhc3MnXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBbYXR0ci5hcmlhLWludmFsaWRdPVwibWVzc2FnZXNQZXJGaWVsZC5leGlzdHNFcnJvcigndXNlcm5hbWUnLCAncGFzc3dvcmQnKVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICA8L2tjLXBhc3N3b3JkLXdyYXBwZXI+XG4gICAgICAgICAgICAgICAgICAgIEBpZiAodXNlcm5hbWVIaWRkZW4gJiYgbWVzc2FnZXNQZXJGaWVsZD8uZXhpc3RzRXJyb3IoJ3VzZXJuYW1lJywgJ3Bhc3N3b3JkJykpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgaWQ9XCJpbnB1dC1lcnJvclwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYXJpYS1saXZlPVwicG9saXRlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBba2NDbGFzc109XCIna2NJbnB1dEVycm9yTWVzc2FnZUNsYXNzJ1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgW2lubmVySFRNTF09XCJtZXNzYWdlc1BlckZpZWxkLmdldEZpcnN0RXJyb3IoJ3VzZXJuYW1lJywgJ3Bhc3N3b3JkJykgfCBrY1Nhbml0aXplOiAnaHRtbCdcIlxuICAgICAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICAgICAgICA8ZGl2IFtrY0NsYXNzXT1cIlsna2NGb3JtR3JvdXBDbGFzcycsICdrY0Zvcm1TZXR0aW5nQ2xhc3MnXVwiPlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGlkPVwia2MtZm9ybS1vcHRpb25zXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICBAaWYgKHJlYWxtPy5yZW1lbWJlck1lICYmICF1c2VybmFtZUhpZGRlbikge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjaGVja2JveFwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8bGFiZWw+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0YWJpbmRleD1cIjVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlkPVwicmVtZW1iZXJNZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbmFtZT1cInJlbWVtYmVyTWVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHR5cGU9XCJjaGVja2JveFwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2RlZmF1bHRDaGVja2VkXT1cIiEhbG9naW4/LnJlbWVtYmVyTWVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHt7IGkxOG4ubXNnU3RyKCdyZW1lbWJlck1lJykgfX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPC9sYWJlbD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICAgICAgICAgICAgPGRpdiBba2NDbGFzc109XCIna2NGb3JtT3B0aW9uc1dyYXBwZXJDbGFzcydcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgIEBpZiAocmVhbG0/LnJlc2V0UGFzc3dvcmRBbGxvd2VkKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHNwYW4+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxhXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0YWJpbmRleD1cIjZcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2hyZWZdPVwidXJsPy5sb2dpblJlc2V0Q3JlZGVudGlhbHNVcmxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPnt7IGkxOG4ubXNnU3RyKCdkb0ZvcmdvdFBhc3N3b3JkJykgfX08L2FcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgICAgICBpZD1cImtjLWZvcm0tYnV0dG9uc1wiXG4gICAgICAgICAgICAgICAgICAgIFtrY0NsYXNzXT1cIidrY0Zvcm1Hcm91cENsYXNzJ1wiXG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgICAgICAgICAgICAgIHR5cGU9XCJoaWRkZW5cIlxuICAgICAgICAgICAgICAgICAgICAgICAgaWQ9XCJpZC1oaWRkZW4taW5wdXRcIlxuICAgICAgICAgICAgICAgICAgICAgICAgbmFtZT1cImNyZWRlbnRpYWxJZFwiXG4gICAgICAgICAgICAgICAgICAgICAgICBbdmFsdWVdPVwiYXV0aD8uc2VsZWN0ZWRDcmVkZW50aWFsXCJcbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICAgPGlucHV0XG4gICAgICAgICAgICAgICAgICAgICAgICB0YWJpbmRleD1cIjdcIlxuICAgICAgICAgICAgICAgICAgICAgICAgbmFtZT1cImxvZ2luXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIGlkPVwia2MtbG9naW5cIlxuICAgICAgICAgICAgICAgICAgICAgICAgdHlwZT1cInN1Ym1pdFwiXG4gICAgICAgICAgICAgICAgICAgICAgICBba2NDbGFzc109XCJbJ2tjQnV0dG9uQ2xhc3MnLCAna2NCdXR0b25QcmltYXJ5Q2xhc3MnLCAna2NCdXR0b25CbG9ja0NsYXNzJywgJ2tjQnV0dG9uTGFyZ2VDbGFzcyddXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIFt2YWx1ZV09XCJpMThuLm1zZ1N0cignZG9Mb2dJbicpXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJpc0xvZ2luQnV0dG9uRGlzYWJsZWQoKVwiXG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Zvcm0+XG4gICAgICAgIH1cbiAgICA8L2Rpdj5cbjwvZGl2PlxuIl19
@@ -1,2 +0,0 @@
1
- export * from './login-config-totp.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbG9naW4vcGFnZXMvbG9naW4tY29uZmlnLXRvdHAvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbG9naW4tY29uZmlnLXRvdHAuY29tcG9uZW50JztcbiJdfQ==
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Y2xvYWtpZnktYW5ndWxhci1sb2dpbi1wYWdlcy1sb2dpbi1jb25maWctdG90cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9sb2dpbi9wYWdlcy9sb2dpbi1jb25maWctdG90cC9rZXljbG9ha2lmeS1hbmd1bGFyLWxvZ2luLXBhZ2VzLWxvZ2luLWNvbmZpZy10b3RwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
@@ -1,42 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, forwardRef, inject, viewChild } from '@angular/core';
2
- import { KcSanitizePipe } from '@keycloakify/angular/lib/pipes/kc-sanitize';
3
- import { USE_DEFAULT_CSS } from '@keycloakify/angular/lib/tokens/use-default-css';
4
- import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
5
- import { LogoutOtherSessionsComponent } from '@keycloakify/angular/login/components/logout-other-sessions';
6
- import { KcClassDirective } from '@keycloakify/angular/login/directives/kc-class';
7
- import { LOGIN_CLASSES } from '@keycloakify/angular/login/tokens/classes';
8
- import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
9
- import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
10
- import * as i0 from "@angular/core";
11
- export class LoginConfigTotpComponent extends ComponentReference {
12
- constructor() {
13
- super(...arguments);
14
- this.kcContext = inject(KC_LOGIN_CONTEXT);
15
- this.i18n = inject(LOGIN_I18N);
16
- this.doUseDefaultCss = inject(USE_DEFAULT_CSS);
17
- this.classes = inject(LOGIN_CLASSES);
18
- this.displayRequiredFields = false;
19
- this.displayInfo = false;
20
- this.displayMessage = !this.kcContext.messagesPerField.existsError('totp', 'userLabel');
21
- this.headerNode = viewChild('headerNode');
22
- this.infoNode = viewChild('infoNode');
23
- this.socialProvidersNode = viewChild('socialProvidersNode');
24
- }
25
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginConfigTotpComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
26
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: LoginConfigTotpComponent, isStandalone: true, selector: "kc-login-config-totp", providers: [
27
- {
28
- provide: ComponentReference,
29
- useExisting: forwardRef(() => LoginConfigTotpComponent)
30
- }
31
- ], viewQueries: [{ propertyName: "headerNode", first: true, predicate: ["headerNode"], descendants: true, isSignal: true }, { propertyName: "infoNode", first: true, predicate: ["infoNode"], descendants: true, isSignal: true }, { propertyName: "socialProvidersNode", first: true, predicate: ["socialProvidersNode"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@let totp = kcContext.totp;\n@let url = kcContext.url;\n@let messagesPerField = kcContext.messagesPerField;\n@let mode = kcContext.mode;\n@let isAppInitiatedAction = kcContext.isAppInitiatedAction;\n\n<ng-template #headerNode>\n {{ i18n.msgStr('loginTotpStep1') }}\n</ng-template>\n<ol id=\"kc-totp-settings\">\n <li>\n <p>{{ i18n.msgStr('loginTotpStep1') }}</p>\n <ul id=\"kc-totp-supported-apps\">\n @for (app of totp.supportedApplications; track app) {\n <li>{{ i18n.advancedMsgStr(app) }}</li>\n }\n </ul>\n </li>\n @if (kcContext.mode === 'manual') {\n <li>\n <p>{{ i18n.msgStr('loginTotpManualStep2') }}</p>\n <p>\n <span id=\"kc-totp-secret-key\">{{ totp.totpSecretEncoded }}</span>\n </p>\n <p>\n <a\n id=\"mode-barcode\"\n [href]=\"totp.qrUrl\"\n >\n {{ i18n.msgStr('loginTotpScanBarcode') }}\n </a>\n </p>\n </li>\n <li>\n <p>{{ i18n.msgStr('loginTotpManualStep3') }}</p>\n <p></p>\n <ul>\n <li id=\"kc-totp-type\">\n {{ i18n.msgStr('loginTotpType') }}:\n {{ i18n.advancedMsgStr('loginTotp.' + totp.policy.type) }}\n </li>\n <li id=\"kc-totp-algorithm\">\n {{ i18n.msgStr('loginTotpAlgorithm') }}:\n {{ totp.policy.getAlgorithmKey() }}\n </li>\n <li id=\"kc-totp-digits\">{{ i18n.msgStr('loginTotpDigits') }}: {{ totp.policy.digits }}</li>\n @if (totp.policy.type === 'totp') {\n <li id=\"kc-totp-period\">\n {{ i18n.msgStr('loginTotpInterval') }}:\n {{ totp.policy.period }}\n </li>\n } @else {\n <li id=\"kc-totp-counter\">\n {{ i18n.msgStr('loginTotpCounter') }}:\n {{ totp.policy.initialCounter }}\n </li>\n }\n </ul>\n </li>\n } @else {\n <li>\n <p>{{ i18n.msgStr('loginTotpStep2') }}</p>\n <img\n id=\"kc-totp-secret-qr-code\"\n alt=\"Figure: Barcode\"\n [src]=\"'data:image/png;base64, ' + totp.totpSecretQrCode\"\n />\n <br />\n <p>\n <a\n id=\"mode-manual\"\n [href]=\"totp.manualUrl\"\n >\n {{ i18n.msgStr('loginTotpUnableToScan') }}\n </a>\n </p>\n </li>\n }\n <li>\n <p>{{ i18n.msgStr('loginTotpStep3') }}</p>\n <p>{{ i18n.msgStr('loginTotpStep3DeviceName') }}</p>\n </li>\n</ol>\n<form\n id=\"kc-totp-settings-form\"\n method=\"post\"\n [action]=\"url.loginAction\"\n [kcClass]=\"'kcFormClass'\"\n>\n <div [kcClass]=\"'kcFormGroupClass'\">\n <div [kcClass]=\"'kcInputWrapperClass'\">\n <label\n for=\"totp\"\n [kcClass]=\"'kcLabelClass'\"\n >\n {{ i18n.msgStr('authenticatorCode') }}\n </label>\n <span class=\"required\">*</span>\n </div>\n <div [kcClass]=\"'kcInputWrapperClass'\">\n <input\n type=\"text\"\n id=\"totp\"\n name=\"totp\"\n autoComplete=\"off\"\n [kcClass]=\"'kcInputClass'\"\n [attr.aria-invalid]=\"messagesPerField.existsError('totp')\"\n />\n @if (messagesPerField.existsError('totp')) {\n <span\n id=\"input-error-otp-code\"\n aria-live=\"polite\"\n [kcClass]=\"'kcInputErrorMessageClass'\"\n [innerHTML]=\"messagesPerField.get('totp') | kcSanitize: 'html'\"\n ></span>\n }\n </div>\n <input\n type=\"hidden\"\n id=\"totpSecret\"\n name=\"totpSecret\"\n [value]=\"totp.totpSecret\"\n />\n @if (mode) {\n <input\n type=\"hidden\"\n id=\"mode\"\n [value]=\"mode\"\n />\n }\n </div>\n <div [kcClass]=\"'kcFormGroupClass'\">\n <div [kcClass]=\"'kcInputWrapperClass'\">\n <label\n for=\"userLabel\"\n [kcClass]=\"'kcLabelClass'\"\n >\n {{ i18n.msgStr('loginTotpDeviceName') }}\n </label>\n @if (totp.otpCredentials.length >= 1) {\n <span class=\"required\">*</span>\n }\n </div>\n <div [kcClass]=\"'kcInputWrapperClass'\">\n <input\n type=\"text\"\n id=\"userLabel\"\n name=\"userLabel\"\n autoComplete=\"off\"\n [kcClass]=\"'kcInputClass'\"\n [attr.aria-invalid]=\"messagesPerField.existsError('userLabel')\"\n />\n @if (messagesPerField.existsError('userLabel')) {\n <span\n id=\"input-error-otp-label\"\n aria-live=\"polite\"\n [kcClass]=\"'kcInputErrorMessageClass'\"\n [innerHTML]=\"messagesPerField.get('userLabel') | kcSanitize: 'html'\"\n ></span>\n }\n </div>\n </div>\n <div [kcClass]=\"'kcFormGroupClass'\">\n <kc-logout-other-sessions />\n </div>\n\n @if (isAppInitiatedAction) {\n <input\n type=\"submit\"\n id=\"saveTOTPBtn\"\n [kcClass]=\"['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doSubmit')\"\n />\n <button\n type=\"submit\"\n id=\"cancelTOTPBtn\"\n name=\"cancel-aia\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass', 'kcButtonLargeClass']\"\n [value]=\"true\"\n >\n {{ i18n.msgStr('doCancel') }}\n </button>\n } @else {\n <input\n type=\"submit\"\n id=\"saveTOTPBtn\"\n [kcClass]=\"['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doSubmit')\"\n />\n }\n</form>\n", dependencies: [{ kind: "directive", type: KcClassDirective, selector: "[kcClass]", inputs: ["class", "ngClass", "kcClass"] }, { kind: "pipe", type: KcSanitizePipe, name: "kcSanitize" }, { kind: "component", type: LogoutOtherSessionsComponent, selector: "kc-logout-other-sessions" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
32
- }
33
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginConfigTotpComponent, decorators: [{
34
- type: Component,
35
- args: [{ standalone: true, imports: [KcClassDirective, KcSanitizePipe, LogoutOtherSessionsComponent], selector: 'kc-login-config-totp', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
36
- {
37
- provide: ComponentReference,
38
- useExisting: forwardRef(() => LoginConfigTotpComponent)
39
- }
40
- ], template: "@let totp = kcContext.totp;\n@let url = kcContext.url;\n@let messagesPerField = kcContext.messagesPerField;\n@let mode = kcContext.mode;\n@let isAppInitiatedAction = kcContext.isAppInitiatedAction;\n\n<ng-template #headerNode>\n {{ i18n.msgStr('loginTotpStep1') }}\n</ng-template>\n<ol id=\"kc-totp-settings\">\n <li>\n <p>{{ i18n.msgStr('loginTotpStep1') }}</p>\n <ul id=\"kc-totp-supported-apps\">\n @for (app of totp.supportedApplications; track app) {\n <li>{{ i18n.advancedMsgStr(app) }}</li>\n }\n </ul>\n </li>\n @if (kcContext.mode === 'manual') {\n <li>\n <p>{{ i18n.msgStr('loginTotpManualStep2') }}</p>\n <p>\n <span id=\"kc-totp-secret-key\">{{ totp.totpSecretEncoded }}</span>\n </p>\n <p>\n <a\n id=\"mode-barcode\"\n [href]=\"totp.qrUrl\"\n >\n {{ i18n.msgStr('loginTotpScanBarcode') }}\n </a>\n </p>\n </li>\n <li>\n <p>{{ i18n.msgStr('loginTotpManualStep3') }}</p>\n <p></p>\n <ul>\n <li id=\"kc-totp-type\">\n {{ i18n.msgStr('loginTotpType') }}:\n {{ i18n.advancedMsgStr('loginTotp.' + totp.policy.type) }}\n </li>\n <li id=\"kc-totp-algorithm\">\n {{ i18n.msgStr('loginTotpAlgorithm') }}:\n {{ totp.policy.getAlgorithmKey() }}\n </li>\n <li id=\"kc-totp-digits\">{{ i18n.msgStr('loginTotpDigits') }}: {{ totp.policy.digits }}</li>\n @if (totp.policy.type === 'totp') {\n <li id=\"kc-totp-period\">\n {{ i18n.msgStr('loginTotpInterval') }}:\n {{ totp.policy.period }}\n </li>\n } @else {\n <li id=\"kc-totp-counter\">\n {{ i18n.msgStr('loginTotpCounter') }}:\n {{ totp.policy.initialCounter }}\n </li>\n }\n </ul>\n </li>\n } @else {\n <li>\n <p>{{ i18n.msgStr('loginTotpStep2') }}</p>\n <img\n id=\"kc-totp-secret-qr-code\"\n alt=\"Figure: Barcode\"\n [src]=\"'data:image/png;base64, ' + totp.totpSecretQrCode\"\n />\n <br />\n <p>\n <a\n id=\"mode-manual\"\n [href]=\"totp.manualUrl\"\n >\n {{ i18n.msgStr('loginTotpUnableToScan') }}\n </a>\n </p>\n </li>\n }\n <li>\n <p>{{ i18n.msgStr('loginTotpStep3') }}</p>\n <p>{{ i18n.msgStr('loginTotpStep3DeviceName') }}</p>\n </li>\n</ol>\n<form\n id=\"kc-totp-settings-form\"\n method=\"post\"\n [action]=\"url.loginAction\"\n [kcClass]=\"'kcFormClass'\"\n>\n <div [kcClass]=\"'kcFormGroupClass'\">\n <div [kcClass]=\"'kcInputWrapperClass'\">\n <label\n for=\"totp\"\n [kcClass]=\"'kcLabelClass'\"\n >\n {{ i18n.msgStr('authenticatorCode') }}\n </label>\n <span class=\"required\">*</span>\n </div>\n <div [kcClass]=\"'kcInputWrapperClass'\">\n <input\n type=\"text\"\n id=\"totp\"\n name=\"totp\"\n autoComplete=\"off\"\n [kcClass]=\"'kcInputClass'\"\n [attr.aria-invalid]=\"messagesPerField.existsError('totp')\"\n />\n @if (messagesPerField.existsError('totp')) {\n <span\n id=\"input-error-otp-code\"\n aria-live=\"polite\"\n [kcClass]=\"'kcInputErrorMessageClass'\"\n [innerHTML]=\"messagesPerField.get('totp') | kcSanitize: 'html'\"\n ></span>\n }\n </div>\n <input\n type=\"hidden\"\n id=\"totpSecret\"\n name=\"totpSecret\"\n [value]=\"totp.totpSecret\"\n />\n @if (mode) {\n <input\n type=\"hidden\"\n id=\"mode\"\n [value]=\"mode\"\n />\n }\n </div>\n <div [kcClass]=\"'kcFormGroupClass'\">\n <div [kcClass]=\"'kcInputWrapperClass'\">\n <label\n for=\"userLabel\"\n [kcClass]=\"'kcLabelClass'\"\n >\n {{ i18n.msgStr('loginTotpDeviceName') }}\n </label>\n @if (totp.otpCredentials.length >= 1) {\n <span class=\"required\">*</span>\n }\n </div>\n <div [kcClass]=\"'kcInputWrapperClass'\">\n <input\n type=\"text\"\n id=\"userLabel\"\n name=\"userLabel\"\n autoComplete=\"off\"\n [kcClass]=\"'kcInputClass'\"\n [attr.aria-invalid]=\"messagesPerField.existsError('userLabel')\"\n />\n @if (messagesPerField.existsError('userLabel')) {\n <span\n id=\"input-error-otp-label\"\n aria-live=\"polite\"\n [kcClass]=\"'kcInputErrorMessageClass'\"\n [innerHTML]=\"messagesPerField.get('userLabel') | kcSanitize: 'html'\"\n ></span>\n }\n </div>\n </div>\n <div [kcClass]=\"'kcFormGroupClass'\">\n <kc-logout-other-sessions />\n </div>\n\n @if (isAppInitiatedAction) {\n <input\n type=\"submit\"\n id=\"saveTOTPBtn\"\n [kcClass]=\"['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doSubmit')\"\n />\n <button\n type=\"submit\"\n id=\"cancelTOTPBtn\"\n name=\"cancel-aia\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass', 'kcButtonLargeClass']\"\n [value]=\"true\"\n >\n {{ i18n.msgStr('doCancel') }}\n </button>\n } @else {\n <input\n type=\"submit\"\n id=\"saveTOTPBtn\"\n [kcClass]=\"['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doSubmit')\"\n />\n }\n</form>\n" }]
41
- }] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4tY29uZmlnLXRvdHAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xvZ2luL3BhZ2VzL2xvZ2luLWNvbmZpZy10b3RwL2xvZ2luLWNvbmZpZy10b3RwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9sb2dpbi9wYWdlcy9sb2dpbi1jb25maWctdG90cC9sb2dpbi1jb25maWctdG90cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQW9CLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwSCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDNUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQzVGLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQzNHLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBR2xGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOENBQThDLENBQUM7O0FBZ0JoRixNQUFNLE9BQU8sd0JBQXlCLFNBQVEsa0JBQWtCO0lBYmhFOztRQWNJLGNBQVMsR0FBRyxNQUFNLENBQTBELGdCQUFnQixDQUFDLENBQUM7UUFDOUYsU0FBSSxHQUFHLE1BQU0sQ0FBTyxVQUFVLENBQUMsQ0FBQztRQUN2QixvQkFBZSxHQUFHLE1BQU0sQ0FBVSxlQUFlLENBQUMsQ0FBQztRQUNuRCxZQUFPLEdBQUcsTUFBTSxDQUFvQyxhQUFhLENBQUMsQ0FBQztRQUs1RSwwQkFBcUIsR0FBRyxLQUFLLENBQUM7UUFDOUIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsbUJBQWMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxXQUFXLENBQUMsQ0FBQztRQUVuRixlQUFVLEdBQUcsU0FBUyxDQUEyQixZQUFZLENBQUMsQ0FBQztRQUMvRCxhQUFRLEdBQUcsU0FBUyxDQUEyQixVQUFVLENBQUMsQ0FBQztRQUMzRCx3QkFBbUIsR0FBRyxTQUFTLENBQTJCLHFCQUFxQixDQUFDLENBQUM7S0FDcEY7K0dBaEJZLHdCQUF3QjttR0FBeEIsd0JBQXdCLG1FQVB0QjtZQUNQO2dCQUNJLE9BQU8sRUFBRSxrQkFBa0I7Z0JBQzNCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsd0JBQXdCLENBQUM7YUFDMUQ7U0FDSiwrWUN4QkwsMDhNQStMQSw0Q0RoTGMsZ0JBQWdCLDBGQUFFLGNBQWMsbURBQUUsNEJBQTRCOzs0RkFXL0Qsd0JBQXdCO2tCQWJwQyxTQUFTO2lDQUNNLElBQUksV0FDUCxDQUFDLGdCQUFnQixFQUFFLGNBQWMsRUFBRSw0QkFBNEIsQ0FBQyxZQUMvRCxzQkFBc0IsbUJBRWYsdUJBQXVCLENBQUMsTUFBTSxhQUNwQzt3QkFDUDs0QkFDSSxPQUFPLEVBQUUsa0JBQWtCOzRCQUMzQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSx5QkFBeUIsQ0FBQzt5QkFDMUQ7cUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBmb3J3YXJkUmVmLCBpbmplY3QsIHR5cGUgVGVtcGxhdGVSZWYsIHZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgS2NTYW5pdGl6ZVBpcGUgfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9saWIvcGlwZXMva2Mtc2FuaXRpemUnO1xuaW1wb3J0IHsgVVNFX0RFRkFVTFRfQ1NTIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbGliL3Rva2Vucy91c2UtZGVmYXVsdC1jc3MnO1xuaW1wb3J0IHsgQ29tcG9uZW50UmVmZXJlbmNlIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vY2xhc3Nlcy9jb21wb25lbnQtcmVmZXJlbmNlJztcbmltcG9ydCB7IExvZ291dE90aGVyU2Vzc2lvbnNDb21wb25lbnQgfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi9jb21wb25lbnRzL2xvZ291dC1vdGhlci1zZXNzaW9ucyc7XG5pbXBvcnQgeyBLY0NsYXNzRGlyZWN0aXZlIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vZGlyZWN0aXZlcy9rYy1jbGFzcyc7XG5pbXBvcnQgdHlwZSB7IEkxOG4gfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi9pMThuJztcbmltcG9ydCB0eXBlIHsgS2NDb250ZXh0IH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vS2NDb250ZXh0JztcbmltcG9ydCB7IExPR0lOX0NMQVNTRVMgfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi90b2tlbnMvY2xhc3Nlcyc7XG5pbXBvcnQgeyBMT0dJTl9JMThOIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vdG9rZW5zL2kxOG4nO1xuaW1wb3J0IHsgS0NfTE9HSU5fQ09OVEVYVCB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL3Rva2Vucy9rYy1jb250ZXh0JztcbmltcG9ydCB0eXBlIHsgQ2xhc3NLZXkgfSBmcm9tICdrZXljbG9ha2lmeS9sb2dpbi9saWIva2NDbHN4JztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbS2NDbGFzc0RpcmVjdGl2ZSwgS2NTYW5pdGl6ZVBpcGUsIExvZ291dE90aGVyU2Vzc2lvbnNDb21wb25lbnRdLFxuICAgIHNlbGVjdG9yOiAna2MtbG9naW4tY29uZmlnLXRvdHAnLFxuICAgIHRlbXBsYXRlVXJsOiAnbG9naW4tY29uZmlnLXRvdHAuY29tcG9uZW50Lmh0bWwnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBDb21wb25lbnRSZWZlcmVuY2UsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBMb2dpbkNvbmZpZ1RvdHBDb21wb25lbnQpXG4gICAgICAgIH1cbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIExvZ2luQ29uZmlnVG90cENvbXBvbmVudCBleHRlbmRzIENvbXBvbmVudFJlZmVyZW5jZSB7XG4gICAga2NDb250ZXh0ID0gaW5qZWN0PEV4dHJhY3Q8S2NDb250ZXh0LCB7IHBhZ2VJZDogJ2xvZ2luLWNvbmZpZy10b3RwLmZ0bCcgfT4+KEtDX0xPR0lOX0NPTlRFWFQpO1xuICAgIGkxOG4gPSBpbmplY3Q8STE4bj4oTE9HSU5fSTE4Tik7XG4gICAgb3ZlcnJpZGUgZG9Vc2VEZWZhdWx0Q3NzID0gaW5qZWN0PGJvb2xlYW4+KFVTRV9ERUZBVUxUX0NTUyk7XG4gICAgb3ZlcnJpZGUgY2xhc3NlcyA9IGluamVjdDxQYXJ0aWFsPFJlY29yZDxDbGFzc0tleSwgc3RyaW5nPj4+KExPR0lOX0NMQVNTRVMpO1xuXG4gICAgZG9jdW1lbnRUaXRsZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIGJvZHlDbGFzc05hbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICAgIGRpc3BsYXlSZXF1aXJlZEZpZWxkcyA9IGZhbHNlO1xuICAgIGRpc3BsYXlJbmZvID0gZmFsc2U7XG4gICAgZGlzcGxheU1lc3NhZ2UgPSAhdGhpcy5rY0NvbnRleHQubWVzc2FnZXNQZXJGaWVsZC5leGlzdHNFcnJvcigndG90cCcsICd1c2VyTGFiZWwnKTtcblxuICAgIGhlYWRlck5vZGUgPSB2aWV3Q2hpbGQ8VGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+PignaGVhZGVyTm9kZScpO1xuICAgIGluZm9Ob2RlID0gdmlld0NoaWxkPFRlbXBsYXRlUmVmPEhUTUxFbGVtZW50Pj4oJ2luZm9Ob2RlJyk7XG4gICAgc29jaWFsUHJvdmlkZXJzTm9kZSA9IHZpZXdDaGlsZDxUZW1wbGF0ZVJlZjxIVE1MRWxlbWVudD4+KCdzb2NpYWxQcm92aWRlcnNOb2RlJyk7XG59XG4iLCJAbGV0IHRvdHAgPSBrY0NvbnRleHQudG90cDtcbkBsZXQgdXJsID0ga2NDb250ZXh0LnVybDtcbkBsZXQgbWVzc2FnZXNQZXJGaWVsZCA9IGtjQ29udGV4dC5tZXNzYWdlc1BlckZpZWxkO1xuQGxldCBtb2RlID0ga2NDb250ZXh0Lm1vZGU7XG5AbGV0IGlzQXBwSW5pdGlhdGVkQWN0aW9uID0ga2NDb250ZXh0LmlzQXBwSW5pdGlhdGVkQWN0aW9uO1xuXG48bmctdGVtcGxhdGUgI2hlYWRlck5vZGU+XG4gICAge3sgaTE4bi5tc2dTdHIoJ2xvZ2luVG90cFN0ZXAxJykgfX1cbjwvbmctdGVtcGxhdGU+XG48b2wgaWQ9XCJrYy10b3RwLXNldHRpbmdzXCI+XG4gICAgPGxpPlxuICAgICAgICA8cD57eyBpMThuLm1zZ1N0cignbG9naW5Ub3RwU3RlcDEnKSB9fTwvcD5cbiAgICAgICAgPHVsIGlkPVwia2MtdG90cC1zdXBwb3J0ZWQtYXBwc1wiPlxuICAgICAgICAgICAgQGZvciAoYXBwIG9mIHRvdHAuc3VwcG9ydGVkQXBwbGljYXRpb25zOyB0cmFjayBhcHApIHtcbiAgICAgICAgICAgICAgICA8bGk+e3sgaTE4bi5hZHZhbmNlZE1zZ1N0cihhcHApIH19PC9saT5cbiAgICAgICAgICAgIH1cbiAgICAgICAgPC91bD5cbiAgICA8L2xpPlxuICAgIEBpZiAoa2NDb250ZXh0Lm1vZGUgPT09ICdtYW51YWwnKSB7XG4gICAgICAgIDxsaT5cbiAgICAgICAgICAgIDxwPnt7IGkxOG4ubXNnU3RyKCdsb2dpblRvdHBNYW51YWxTdGVwMicpIH19PC9wPlxuICAgICAgICAgICAgPHA+XG4gICAgICAgICAgICAgICAgPHNwYW4gaWQ9XCJrYy10b3RwLXNlY3JldC1rZXlcIj57eyB0b3RwLnRvdHBTZWNyZXRFbmNvZGVkIH19PC9zcGFuPlxuICAgICAgICAgICAgPC9wPlxuICAgICAgICAgICAgPHA+XG4gICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgaWQ9XCJtb2RlLWJhcmNvZGVcIlxuICAgICAgICAgICAgICAgICAgICBbaHJlZl09XCJ0b3RwLnFyVXJsXCJcbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIHt7IGkxOG4ubXNnU3RyKCdsb2dpblRvdHBTY2FuQmFyY29kZScpIH19XG4gICAgICAgICAgICAgICAgPC9hPlxuICAgICAgICAgICAgPC9wPlxuICAgICAgICA8L2xpPlxuICAgICAgICA8bGk+XG4gICAgICAgICAgICA8cD57eyBpMThuLm1zZ1N0cignbG9naW5Ub3RwTWFudWFsU3RlcDMnKSB9fTwvcD5cbiAgICAgICAgICAgIDxwPjwvcD5cbiAgICAgICAgICAgIDx1bD5cbiAgICAgICAgICAgICAgICA8bGkgaWQ9XCJrYy10b3RwLXR5cGVcIj5cbiAgICAgICAgICAgICAgICAgICAge3sgaTE4bi5tc2dTdHIoJ2xvZ2luVG90cFR5cGUnKSB9fTpcbiAgICAgICAgICAgICAgICAgICAge3sgaTE4bi5hZHZhbmNlZE1zZ1N0cignbG9naW5Ub3RwLicgKyB0b3RwLnBvbGljeS50eXBlKSB9fVxuICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICAgPGxpIGlkPVwia2MtdG90cC1hbGdvcml0aG1cIj5cbiAgICAgICAgICAgICAgICAgICAge3sgaTE4bi5tc2dTdHIoJ2xvZ2luVG90cEFsZ29yaXRobScpIH19OlxuICAgICAgICAgICAgICAgICAgICB7eyB0b3RwLnBvbGljeS5nZXRBbGdvcml0aG1LZXkoKSB9fVxuICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICAgPGxpIGlkPVwia2MtdG90cC1kaWdpdHNcIj57eyBpMThuLm1zZ1N0cignbG9naW5Ub3RwRGlnaXRzJykgfX06IHt7IHRvdHAucG9saWN5LmRpZ2l0cyB9fTwvbGk+XG4gICAgICAgICAgICAgICAgQGlmICh0b3RwLnBvbGljeS50eXBlID09PSAndG90cCcpIHtcbiAgICAgICAgICAgICAgICAgICAgPGxpIGlkPVwia2MtdG90cC1wZXJpb2RcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgIHt7IGkxOG4ubXNnU3RyKCdsb2dpblRvdHBJbnRlcnZhbCcpIH19OlxuICAgICAgICAgICAgICAgICAgICAgICAge3sgdG90cC5wb2xpY3kucGVyaW9kIH19XG4gICAgICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICAgfSBAZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIDxsaSBpZD1cImtjLXRvdHAtY291bnRlclwiPlxuICAgICAgICAgICAgICAgICAgICAgICAge3sgaTE4bi5tc2dTdHIoJ2xvZ2luVG90cENvdW50ZXInKSB9fTpcbiAgICAgICAgICAgICAgICAgICAgICAgIHt7IHRvdHAucG9saWN5LmluaXRpYWxDb3VudGVyIH19XG4gICAgICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgPC91bD5cbiAgICAgICAgPC9saT5cbiAgICB9IEBlbHNlIHtcbiAgICAgICAgPGxpPlxuICAgICAgICAgICAgPHA+e3sgaTE4bi5tc2dTdHIoJ2xvZ2luVG90cFN0ZXAyJykgfX08L3A+XG4gICAgICAgICAgICA8aW1nXG4gICAgICAgICAgICAgICAgaWQ9XCJrYy10b3RwLXNlY3JldC1xci1jb2RlXCJcbiAgICAgICAgICAgICAgICBhbHQ9XCJGaWd1cmU6IEJhcmNvZGVcIlxuICAgICAgICAgICAgICAgIFtzcmNdPVwiJ2RhdGE6aW1hZ2UvcG5nO2Jhc2U2NCwgJyArIHRvdHAudG90cFNlY3JldFFyQ29kZVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICAgPGJyIC8+XG4gICAgICAgICAgICA8cD5cbiAgICAgICAgICAgICAgICA8YVxuICAgICAgICAgICAgICAgICAgICBpZD1cIm1vZGUtbWFudWFsXCJcbiAgICAgICAgICAgICAgICAgICAgW2hyZWZdPVwidG90cC5tYW51YWxVcmxcIlxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAge3sgaTE4bi5tc2dTdHIoJ2xvZ2luVG90cFVuYWJsZVRvU2NhbicpIH19XG4gICAgICAgICAgICAgICAgPC9hPlxuICAgICAgICAgICAgPC9wPlxuICAgICAgICA8L2xpPlxuICAgIH1cbiAgICA8bGk+XG4gICAgICAgIDxwPnt7IGkxOG4ubXNnU3RyKCdsb2dpblRvdHBTdGVwMycpIH19PC9wPlxuICAgICAgICA8cD57eyBpMThuLm1zZ1N0cignbG9naW5Ub3RwU3RlcDNEZXZpY2VOYW1lJykgfX08L3A+XG4gICAgPC9saT5cbjwvb2w+XG48Zm9ybVxuICAgIGlkPVwia2MtdG90cC1zZXR0aW5ncy1mb3JtXCJcbiAgICBtZXRob2Q9XCJwb3N0XCJcbiAgICBbYWN0aW9uXT1cInVybC5sb2dpbkFjdGlvblwiXG4gICAgW2tjQ2xhc3NdPVwiJ2tjRm9ybUNsYXNzJ1wiXG4+XG4gICAgPGRpdiBba2NDbGFzc109XCIna2NGb3JtR3JvdXBDbGFzcydcIj5cbiAgICAgICAgPGRpdiBba2NDbGFzc109XCIna2NJbnB1dFdyYXBwZXJDbGFzcydcIj5cbiAgICAgICAgICAgIDxsYWJlbFxuICAgICAgICAgICAgICAgIGZvcj1cInRvdHBcIlxuICAgICAgICAgICAgICAgIFtrY0NsYXNzXT1cIidrY0xhYmVsQ2xhc3MnXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7eyBpMThuLm1zZ1N0cignYXV0aGVudGljYXRvckNvZGUnKSB9fVxuICAgICAgICAgICAgPC9sYWJlbD5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwicmVxdWlyZWRcIj4qPC9zcGFuPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBba2NDbGFzc109XCIna2NJbnB1dFdyYXBwZXJDbGFzcydcIj5cbiAgICAgICAgICAgIDxpbnB1dFxuICAgICAgICAgICAgICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICAgICAgICAgICAgICBpZD1cInRvdHBcIlxuICAgICAgICAgICAgICAgIG5hbWU9XCJ0b3RwXCJcbiAgICAgICAgICAgICAgICBhdXRvQ29tcGxldGU9XCJvZmZcIlxuICAgICAgICAgICAgICAgIFtrY0NsYXNzXT1cIidrY0lucHV0Q2xhc3MnXCJcbiAgICAgICAgICAgICAgICBbYXR0ci5hcmlhLWludmFsaWRdPVwibWVzc2FnZXNQZXJGaWVsZC5leGlzdHNFcnJvcigndG90cCcpXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgICBAaWYgKG1lc3NhZ2VzUGVyRmllbGQuZXhpc3RzRXJyb3IoJ3RvdHAnKSkge1xuICAgICAgICAgICAgICAgIDxzcGFuXG4gICAgICAgICAgICAgICAgICAgIGlkPVwiaW5wdXQtZXJyb3Itb3RwLWNvZGVcIlxuICAgICAgICAgICAgICAgICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgICAgICAgICAgICAgICBba2NDbGFzc109XCIna2NJbnB1dEVycm9yTWVzc2FnZUNsYXNzJ1wiXG4gICAgICAgICAgICAgICAgICAgIFtpbm5lckhUTUxdPVwibWVzc2FnZXNQZXJGaWVsZC5nZXQoJ3RvdHAnKSB8IGtjU2FuaXRpemU6ICdodG1sJ1wiXG4gICAgICAgICAgICAgICAgPjwvc3Bhbj5cbiAgICAgICAgICAgIH1cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgICAgdHlwZT1cImhpZGRlblwiXG4gICAgICAgICAgICBpZD1cInRvdHBTZWNyZXRcIlxuICAgICAgICAgICAgbmFtZT1cInRvdHBTZWNyZXRcIlxuICAgICAgICAgICAgW3ZhbHVlXT1cInRvdHAudG90cFNlY3JldFwiXG4gICAgICAgIC8+XG4gICAgICAgIEBpZiAobW9kZSkge1xuICAgICAgICAgICAgPGlucHV0XG4gICAgICAgICAgICAgICAgdHlwZT1cImhpZGRlblwiXG4gICAgICAgICAgICAgICAgaWQ9XCJtb2RlXCJcbiAgICAgICAgICAgICAgICBbdmFsdWVdPVwibW9kZVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICB9XG4gICAgPC9kaXY+XG4gICAgPGRpdiBba2NDbGFzc109XCIna2NGb3JtR3JvdXBDbGFzcydcIj5cbiAgICAgICAgPGRpdiBba2NDbGFzc109XCIna2NJbnB1dFdyYXBwZXJDbGFzcydcIj5cbiAgICAgICAgICAgIDxsYWJlbFxuICAgICAgICAgICAgICAgIGZvcj1cInVzZXJMYWJlbFwiXG4gICAgICAgICAgICAgICAgW2tjQ2xhc3NdPVwiJ2tjTGFiZWxDbGFzcydcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHt7IGkxOG4ubXNnU3RyKCdsb2dpblRvdHBEZXZpY2VOYW1lJykgfX1cbiAgICAgICAgICAgIDwvbGFiZWw+XG4gICAgICAgICAgICBAaWYgKHRvdHAub3RwQ3JlZGVudGlhbHMubGVuZ3RoID49IDEpIHtcbiAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cInJlcXVpcmVkXCI+Kjwvc3Bhbj5cbiAgICAgICAgICAgIH1cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgW2tjQ2xhc3NdPVwiJ2tjSW5wdXRXcmFwcGVyQ2xhc3MnXCI+XG4gICAgICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgICAgICAgaWQ9XCJ1c2VyTGFiZWxcIlxuICAgICAgICAgICAgICAgIG5hbWU9XCJ1c2VyTGFiZWxcIlxuICAgICAgICAgICAgICAgIGF1dG9Db21wbGV0ZT1cIm9mZlwiXG4gICAgICAgICAgICAgICAgW2tjQ2xhc3NdPVwiJ2tjSW5wdXRDbGFzcydcIlxuICAgICAgICAgICAgICAgIFthdHRyLmFyaWEtaW52YWxpZF09XCJtZXNzYWdlc1BlckZpZWxkLmV4aXN0c0Vycm9yKCd1c2VyTGFiZWwnKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICAgQGlmIChtZXNzYWdlc1BlckZpZWxkLmV4aXN0c0Vycm9yKCd1c2VyTGFiZWwnKSkge1xuICAgICAgICAgICAgICAgIDxzcGFuXG4gICAgICAgICAgICAgICAgICAgIGlkPVwiaW5wdXQtZXJyb3Itb3RwLWxhYmVsXCJcbiAgICAgICAgICAgICAgICAgICAgYXJpYS1saXZlPVwicG9saXRlXCJcbiAgICAgICAgICAgICAgICAgICAgW2tjQ2xhc3NdPVwiJ2tjSW5wdXRFcnJvck1lc3NhZ2VDbGFzcydcIlxuICAgICAgICAgICAgICAgICAgICBbaW5uZXJIVE1MXT1cIm1lc3NhZ2VzUGVyRmllbGQuZ2V0KCd1c2VyTGFiZWwnKSB8IGtjU2FuaXRpemU6ICdodG1sJ1wiXG4gICAgICAgICAgICAgICAgPjwvc3Bhbj5cbiAgICAgICAgICAgIH1cbiAgICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBba2NDbGFzc109XCIna2NGb3JtR3JvdXBDbGFzcydcIj5cbiAgICAgICAgPGtjLWxvZ291dC1vdGhlci1zZXNzaW9ucyAvPlxuICAgIDwvZGl2PlxuXG4gICAgQGlmIChpc0FwcEluaXRpYXRlZEFjdGlvbikge1xuICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgIHR5cGU9XCJzdWJtaXRcIlxuICAgICAgICAgICAgaWQ9XCJzYXZlVE9UUEJ0blwiXG4gICAgICAgICAgICBba2NDbGFzc109XCJbJ2tjQnV0dG9uQ2xhc3MnLCAna2NCdXR0b25QcmltYXJ5Q2xhc3MnLCAna2NCdXR0b25MYXJnZUNsYXNzJ11cIlxuICAgICAgICAgICAgW3ZhbHVlXT1cImkxOG4ubXNnU3RyKCdkb1N1Ym1pdCcpXCJcbiAgICAgICAgLz5cbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgdHlwZT1cInN1Ym1pdFwiXG4gICAgICAgICAgICBpZD1cImNhbmNlbFRPVFBCdG5cIlxuICAgICAgICAgICAgbmFtZT1cImNhbmNlbC1haWFcIlxuICAgICAgICAgICAgW2tjQ2xhc3NdPVwiWydrY0J1dHRvbkNsYXNzJywgJ2tjQnV0dG9uRGVmYXVsdENsYXNzJywgJ2tjQnV0dG9uTGFyZ2VDbGFzcycsICdrY0J1dHRvbkxhcmdlQ2xhc3MnXVwiXG4gICAgICAgICAgICBbdmFsdWVdPVwidHJ1ZVwiXG4gICAgICAgID5cbiAgICAgICAgICAgIHt7IGkxOG4ubXNnU3RyKCdkb0NhbmNlbCcpIH19XG4gICAgICAgIDwvYnV0dG9uPlxuICAgIH0gQGVsc2Uge1xuICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgIHR5cGU9XCJzdWJtaXRcIlxuICAgICAgICAgICAgaWQ9XCJzYXZlVE9UUEJ0blwiXG4gICAgICAgICAgICBba2NDbGFzc109XCJbJ2tjQnV0dG9uQ2xhc3MnLCAna2NCdXR0b25QcmltYXJ5Q2xhc3MnLCAna2NCdXR0b25MYXJnZUNsYXNzJ11cIlxuICAgICAgICAgICAgW3ZhbHVlXT1cImkxOG4ubXNnU3RyKCdkb1N1Ym1pdCcpXCJcbiAgICAgICAgLz5cbiAgICB9XG48L2Zvcm0+XG4iXX0=
@@ -1,2 +0,0 @@
1
- export * from './login-idp-link-confirm.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbG9naW4vcGFnZXMvbG9naW4taWRwLWxpbmstY29uZmlybS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG9DQUFvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9sb2dpbi1pZHAtbGluay1jb25maXJtLmNvbXBvbmVudCc7XG4iXX0=
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Y2xvYWtpZnktYW5ndWxhci1sb2dpbi1wYWdlcy1sb2dpbi1pZHAtbGluay1jb25maXJtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xvZ2luL3BhZ2VzL2xvZ2luLWlkcC1saW5rLWNvbmZpcm0va2V5Y2xvYWtpZnktYW5ndWxhci1sb2dpbi1wYWdlcy1sb2dpbi1pZHAtbGluay1jb25maXJtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
@@ -1,36 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, forwardRef, inject, viewChild } from '@angular/core';
2
- import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
3
- import { KcClassDirective } from '@keycloakify/angular/login/directives/kc-class';
4
- import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
5
- import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
6
- import * as i0 from "@angular/core";
7
- export class LoginIdpLinkConfirmComponent extends ComponentReference {
8
- constructor() {
9
- super(...arguments);
10
- this.kcContext = inject(KC_LOGIN_CONTEXT);
11
- this.i18n = inject(LOGIN_I18N);
12
- this.displayRequiredFields = false;
13
- this.displayInfo = false;
14
- this.displayMessage = !this.kcContext.messagesPerField.existsError('totp', 'userLabel');
15
- this.headerNode = viewChild('headerNode');
16
- this.infoNode = viewChild('infoNode');
17
- this.socialProvidersNode = viewChild('socialProvidersNode');
18
- }
19
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginIdpLinkConfirmComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
20
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: LoginIdpLinkConfirmComponent, isStandalone: true, selector: "kc-login-idp-link-confirm", providers: [
21
- {
22
- provide: ComponentReference,
23
- useExisting: forwardRef(() => LoginIdpLinkConfirmComponent)
24
- }
25
- ], viewQueries: [{ propertyName: "headerNode", first: true, predicate: ["headerNode"], descendants: true, isSignal: true }, { propertyName: "infoNode", first: true, predicate: ["infoNode"], descendants: true, isSignal: true }, { propertyName: "socialProvidersNode", first: true, predicate: ["socialProvidersNode"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@let url = kcContext.url;\n@let idpAlias = kcContext.idpAlias;\n<ng-template #headerNode>\n {{ i18n.msgStr('confirmLinkIdpTitle') }}\n</ng-template>\n<form\n id=\"kc-register-form\"\n method=\"post\"\n [action]=\"url.loginAction\"\n>\n <div [kcClass]=\"'kcFormGroupClass'\">\n <button\n type=\"submit\"\n name=\"submitAction\"\n id=\"updateProfile\"\n value=\"updateProfile\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonBlockClass', 'kcButtonLargeClass']\"\n >\n {{ i18n.msgStr('confirmLinkIdpReviewProfile') }}\n </button>\n <button\n type=\"submit\"\n name=\"submitAction\"\n id=\"linkAccount\"\n value=\"linkAccount\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonBlockClass', 'kcButtonLargeClass']\"\n >\n {{ i18n.msgStr('confirmLinkIdpContinue', idpAlias) }}\n </button>\n </div>\n</form>\n", dependencies: [{ kind: "directive", type: KcClassDirective, selector: "[kcClass]", inputs: ["class", "ngClass", "kcClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
26
- }
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginIdpLinkConfirmComponent, decorators: [{
28
- type: Component,
29
- args: [{ standalone: true, imports: [KcClassDirective], selector: 'kc-login-idp-link-confirm', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
30
- {
31
- provide: ComponentReference,
32
- useExisting: forwardRef(() => LoginIdpLinkConfirmComponent)
33
- }
34
- ], template: "@let url = kcContext.url;\n@let idpAlias = kcContext.idpAlias;\n<ng-template #headerNode>\n {{ i18n.msgStr('confirmLinkIdpTitle') }}\n</ng-template>\n<form\n id=\"kc-register-form\"\n method=\"post\"\n [action]=\"url.loginAction\"\n>\n <div [kcClass]=\"'kcFormGroupClass'\">\n <button\n type=\"submit\"\n name=\"submitAction\"\n id=\"updateProfile\"\n value=\"updateProfile\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonBlockClass', 'kcButtonLargeClass']\"\n >\n {{ i18n.msgStr('confirmLinkIdpReviewProfile') }}\n </button>\n <button\n type=\"submit\"\n name=\"submitAction\"\n id=\"linkAccount\"\n value=\"linkAccount\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonBlockClass', 'kcButtonLargeClass']\"\n >\n {{ i18n.msgStr('confirmLinkIdpContinue', idpAlias) }}\n </button>\n </div>\n</form>\n" }]
35
- }] });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4taWRwLWxpbmstY29uZmlybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbG9naW4vcGFnZXMvbG9naW4taWRwLWxpbmstY29uZmlybS9sb2dpbi1pZHAtbGluay1jb25maXJtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9sb2dpbi9wYWdlcy9sb2dpbi1pZHAtbGluay1jb25maXJtL2xvZ2luLWlkcC1saW5rLWNvbmZpcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFvQixTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDcEgsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0RBQXdELENBQUM7QUFDNUYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFHbEYsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3BFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDOztBQWVoRixNQUFNLE9BQU8sNEJBQTZCLFNBQVEsa0JBQWtCO0lBYnBFOztRQWNJLGNBQVMsR0FBRyxNQUFNLENBQStELGdCQUFnQixDQUFDLENBQUM7UUFDbkcsU0FBSSxHQUFHLE1BQU0sQ0FBTyxVQUFVLENBQUMsQ0FBQztRQUtoQywwQkFBcUIsR0FBRyxLQUFLLENBQUM7UUFDOUIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsbUJBQWMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxXQUFXLENBQUMsQ0FBQztRQUVuRixlQUFVLEdBQUcsU0FBUyxDQUEyQixZQUFZLENBQUMsQ0FBQztRQUMvRCxhQUFRLEdBQUcsU0FBUyxDQUEyQixVQUFVLENBQUMsQ0FBQztRQUMzRCx3QkFBbUIsR0FBRyxTQUFTLENBQTJCLHFCQUFxQixDQUFDLENBQUM7S0FDcEY7K0dBZFksNEJBQTRCO21HQUE1Qiw0QkFBNEIsd0VBUDFCO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLGtCQUFrQjtnQkFDM0IsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQzthQUM5RDtTQUNKLCtZQ25CTCxxZ0NBK0JBLDRDRHJCYyxnQkFBZ0I7OzRGQVdqQiw0QkFBNEI7a0JBYnhDLFNBQVM7aUNBQ00sSUFBSSxXQUNQLENBQUMsZ0JBQWdCLENBQUMsWUFDakIsMkJBQTJCLG1CQUVwQix1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxrQkFBa0I7NEJBQzNCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLDZCQUE2QixDQUFDO3lCQUM5RDtxQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGZvcndhcmRSZWYsIGluamVjdCwgdHlwZSBUZW1wbGF0ZVJlZiwgdmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21wb25lbnRSZWZlcmVuY2UgfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi9jbGFzc2VzL2NvbXBvbmVudC1yZWZlcmVuY2UnO1xuaW1wb3J0IHsgS2NDbGFzc0RpcmVjdGl2ZSB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL2RpcmVjdGl2ZXMva2MtY2xhc3MnO1xuaW1wb3J0IHR5cGUgeyBJMThuIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vaTE4bic7XG5pbXBvcnQgdHlwZSB7IEtjQ29udGV4dCB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL0tjQ29udGV4dCc7XG5pbXBvcnQgeyBMT0dJTl9JMThOIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vdG9rZW5zL2kxOG4nO1xuaW1wb3J0IHsgS0NfTE9HSU5fQ09OVEVYVCB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL3Rva2Vucy9rYy1jb250ZXh0JztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbS2NDbGFzc0RpcmVjdGl2ZV0sXG4gICAgc2VsZWN0b3I6ICdrYy1sb2dpbi1pZHAtbGluay1jb25maXJtJyxcbiAgICB0ZW1wbGF0ZVVybDogJ2xvZ2luLWlkcC1saW5rLWNvbmZpcm0uY29tcG9uZW50Lmh0bWwnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBDb21wb25lbnRSZWZlcmVuY2UsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBMb2dpbklkcExpbmtDb25maXJtQ29tcG9uZW50KVxuICAgICAgICB9XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBMb2dpbklkcExpbmtDb25maXJtQ29tcG9uZW50IGV4dGVuZHMgQ29tcG9uZW50UmVmZXJlbmNlIHtcbiAgICBrY0NvbnRleHQgPSBpbmplY3Q8RXh0cmFjdDxLY0NvbnRleHQsIHsgcGFnZUlkOiAnbG9naW4taWRwLWxpbmstY29uZmlybS5mdGwnIH0+PihLQ19MT0dJTl9DT05URVhUKTtcbiAgICBpMThuID0gaW5qZWN0PEkxOG4+KExPR0lOX0kxOE4pO1xuXG4gICAgZG9jdW1lbnRUaXRsZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIGJvZHlDbGFzc05hbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICAgIGRpc3BsYXlSZXF1aXJlZEZpZWxkcyA9IGZhbHNlO1xuICAgIGRpc3BsYXlJbmZvID0gZmFsc2U7XG4gICAgZGlzcGxheU1lc3NhZ2UgPSAhdGhpcy5rY0NvbnRleHQubWVzc2FnZXNQZXJGaWVsZC5leGlzdHNFcnJvcigndG90cCcsICd1c2VyTGFiZWwnKTtcblxuICAgIGhlYWRlck5vZGUgPSB2aWV3Q2hpbGQ8VGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+PignaGVhZGVyTm9kZScpO1xuICAgIGluZm9Ob2RlID0gdmlld0NoaWxkPFRlbXBsYXRlUmVmPEhUTUxFbGVtZW50Pj4oJ2luZm9Ob2RlJyk7XG4gICAgc29jaWFsUHJvdmlkZXJzTm9kZSA9IHZpZXdDaGlsZDxUZW1wbGF0ZVJlZjxIVE1MRWxlbWVudD4+KCdzb2NpYWxQcm92aWRlcnNOb2RlJyk7XG59XG4iLCJAbGV0IHVybCA9IGtjQ29udGV4dC51cmw7XG5AbGV0IGlkcEFsaWFzID0ga2NDb250ZXh0LmlkcEFsaWFzO1xuPG5nLXRlbXBsYXRlICNoZWFkZXJOb2RlPlxuICAgIHt7IGkxOG4ubXNnU3RyKCdjb25maXJtTGlua0lkcFRpdGxlJykgfX1cbjwvbmctdGVtcGxhdGU+XG48Zm9ybVxuICAgIGlkPVwia2MtcmVnaXN0ZXItZm9ybVwiXG4gICAgbWV0aG9kPVwicG9zdFwiXG4gICAgW2FjdGlvbl09XCJ1cmwubG9naW5BY3Rpb25cIlxuPlxuICAgIDxkaXYgW2tjQ2xhc3NdPVwiJ2tjRm9ybUdyb3VwQ2xhc3MnXCI+XG4gICAgICAgIDxidXR0b25cbiAgICAgICAgICAgIHR5cGU9XCJzdWJtaXRcIlxuICAgICAgICAgICAgbmFtZT1cInN1Ym1pdEFjdGlvblwiXG4gICAgICAgICAgICBpZD1cInVwZGF0ZVByb2ZpbGVcIlxuICAgICAgICAgICAgdmFsdWU9XCJ1cGRhdGVQcm9maWxlXCJcbiAgICAgICAgICAgIFtrY0NsYXNzXT1cIlsna2NCdXR0b25DbGFzcycsICdrY0J1dHRvbkRlZmF1bHRDbGFzcycsICdrY0J1dHRvbkJsb2NrQ2xhc3MnLCAna2NCdXR0b25MYXJnZUNsYXNzJ11cIlxuICAgICAgICA+XG4gICAgICAgICAgICB7eyBpMThuLm1zZ1N0cignY29uZmlybUxpbmtJZHBSZXZpZXdQcm9maWxlJykgfX1cbiAgICAgICAgPC9idXR0b24+XG4gICAgICAgIDxidXR0b25cbiAgICAgICAgICAgIHR5cGU9XCJzdWJtaXRcIlxuICAgICAgICAgICAgbmFtZT1cInN1Ym1pdEFjdGlvblwiXG4gICAgICAgICAgICBpZD1cImxpbmtBY2NvdW50XCJcbiAgICAgICAgICAgIHZhbHVlPVwibGlua0FjY291bnRcIlxuICAgICAgICAgICAgW2tjQ2xhc3NdPVwiWydrY0J1dHRvbkNsYXNzJywgJ2tjQnV0dG9uRGVmYXVsdENsYXNzJywgJ2tjQnV0dG9uQmxvY2tDbGFzcycsICdrY0J1dHRvbkxhcmdlQ2xhc3MnXVwiXG4gICAgICAgID5cbiAgICAgICAgICAgIHt7IGkxOG4ubXNnU3RyKCdjb25maXJtTGlua0lkcENvbnRpbnVlJywgaWRwQWxpYXMpIH19XG4gICAgICAgIDwvYnV0dG9uPlxuICAgIDwvZGl2PlxuPC9mb3JtPlxuIl19
@@ -1,2 +0,0 @@
1
- export * from './login-idp-link-confirm-override.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbG9naW4vcGFnZXMvbG9naW4taWRwLWxpbmstY29uZmlybS1vdmVycmlkZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZDQUE2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9sb2dpbi1pZHAtbGluay1jb25maXJtLW92ZXJyaWRlLmNvbXBvbmVudCc7XG4iXX0=
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Y2xvYWtpZnktYW5ndWxhci1sb2dpbi1wYWdlcy1sb2dpbi1pZHAtbGluay1jb25maXJtLW92ZXJyaWRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xvZ2luL3BhZ2VzL2xvZ2luLWlkcC1saW5rLWNvbmZpcm0tb3ZlcnJpZGUva2V5Y2xvYWtpZnktYW5ndWxhci1sb2dpbi1wYWdlcy1sb2dpbi1pZHAtbGluay1jb25maXJtLW92ZXJyaWRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
@@ -1,36 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, forwardRef, inject, viewChild } from '@angular/core';
2
- import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
3
- import { KcClassDirective } from '@keycloakify/angular/login/directives/kc-class';
4
- import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
5
- import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
6
- import * as i0 from "@angular/core";
7
- export class LoginIdpLinkConfirmOverrideComponent extends ComponentReference {
8
- constructor() {
9
- super(...arguments);
10
- this.kcContext = inject(KC_LOGIN_CONTEXT);
11
- this.i18n = inject(LOGIN_I18N);
12
- this.displayRequiredFields = false;
13
- this.displayInfo = false;
14
- this.displayMessage = !this.kcContext.messagesPerField.existsError('totp', 'userLabel');
15
- this.headerNode = viewChild('headerNode');
16
- this.infoNode = viewChild('infoNode');
17
- this.socialProvidersNode = viewChild('socialProvidersNode');
18
- }
19
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginIdpLinkConfirmOverrideComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
20
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: LoginIdpLinkConfirmOverrideComponent, isStandalone: true, selector: "kc-login-idp-link-confirm-override", providers: [
21
- {
22
- provide: ComponentReference,
23
- useExisting: forwardRef(() => LoginIdpLinkConfirmOverrideComponent)
24
- }
25
- ], viewQueries: [{ propertyName: "headerNode", first: true, predicate: ["headerNode"], descendants: true, isSignal: true }, { propertyName: "infoNode", first: true, predicate: ["infoNode"], descendants: true, isSignal: true }, { propertyName: "socialProvidersNode", first: true, predicate: ["socialProvidersNode"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@let url = kcContext.url;\n@let idpDisplayName = kcContext.idpDisplayName;\n\n<ng-template #headerNode>\n {{ i18n.msgStr('confirmOverrideIdpTitle') }}\n</ng-template>\n<form\n id=\"kc-register-form\"\n method=\"post\"\n [action]=\"url.loginAction\"\n>\n {{ i18n.msgStr('pageExpiredMsg1') }}\n <a\n id=\"loginRestartLink\"\n [href]=\"url.loginRestartFlowUrl\"\n >\n {{ i18n.msgStr('doClickHere') }}\n </a>\n <br />\n <br />\n <button\n type=\"submit\"\n name=\"submitAction\"\n id=\"confirmOverride\"\n value=\"confirmOverride\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonBlockClass', 'kcButtonLargeClass']\"\n >\n {{ i18n.msgStr('confirmOverrideIdpContinue', idpDisplayName) }}\n </button>\n</form>\n", dependencies: [{ kind: "directive", type: KcClassDirective, selector: "[kcClass]", inputs: ["class", "ngClass", "kcClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
26
- }
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginIdpLinkConfirmOverrideComponent, decorators: [{
28
- type: Component,
29
- args: [{ standalone: true, imports: [KcClassDirective], selector: 'kc-login-idp-link-confirm-override', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
30
- {
31
- provide: ComponentReference,
32
- useExisting: forwardRef(() => LoginIdpLinkConfirmOverrideComponent)
33
- }
34
- ], template: "@let url = kcContext.url;\n@let idpDisplayName = kcContext.idpDisplayName;\n\n<ng-template #headerNode>\n {{ i18n.msgStr('confirmOverrideIdpTitle') }}\n</ng-template>\n<form\n id=\"kc-register-form\"\n method=\"post\"\n [action]=\"url.loginAction\"\n>\n {{ i18n.msgStr('pageExpiredMsg1') }}\n <a\n id=\"loginRestartLink\"\n [href]=\"url.loginRestartFlowUrl\"\n >\n {{ i18n.msgStr('doClickHere') }}\n </a>\n <br />\n <br />\n <button\n type=\"submit\"\n name=\"submitAction\"\n id=\"confirmOverride\"\n value=\"confirmOverride\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonBlockClass', 'kcButtonLargeClass']\"\n >\n {{ i18n.msgStr('confirmOverrideIdpContinue', idpDisplayName) }}\n </button>\n</form>\n" }]
35
- }] });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4taWRwLWxpbmstY29uZmlybS1vdmVycmlkZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbG9naW4vcGFnZXMvbG9naW4taWRwLWxpbmstY29uZmlybS1vdmVycmlkZS9sb2dpbi1pZHAtbGluay1jb25maXJtLW92ZXJyaWRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9sb2dpbi9wYWdlcy9sb2dpbi1pZHAtbGluay1jb25maXJtLW92ZXJyaWRlL2xvZ2luLWlkcC1saW5rLWNvbmZpcm0tb3ZlcnJpZGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFvQixTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDcEgsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0RBQXdELENBQUM7QUFDNUYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFHbEYsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3BFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDOztBQWVoRixNQUFNLE9BQU8sb0NBQXFDLFNBQVEsa0JBQWtCO0lBYjVFOztRQWNJLGNBQVMsR0FBRyxNQUFNLENBQXdFLGdCQUFnQixDQUFDLENBQUM7UUFDNUcsU0FBSSxHQUFHLE1BQU0sQ0FBTyxVQUFVLENBQUMsQ0FBQztRQUtoQywwQkFBcUIsR0FBRyxLQUFLLENBQUM7UUFDOUIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsbUJBQWMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxXQUFXLENBQUMsQ0FBQztRQUVuRixlQUFVLEdBQUcsU0FBUyxDQUEyQixZQUFZLENBQUMsQ0FBQztRQUMvRCxhQUFRLEdBQUcsU0FBUyxDQUEyQixVQUFVLENBQUMsQ0FBQztRQUMzRCx3QkFBbUIsR0FBRyxTQUFTLENBQTJCLHFCQUFxQixDQUFDLENBQUM7S0FDcEY7K0dBZFksb0NBQW9DO21HQUFwQyxvQ0FBb0MsaUZBUGxDO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLGtCQUFrQjtnQkFDM0IsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxvQ0FBb0MsQ0FBQzthQUN0RTtTQUNKLCtZQ25CTCwwekJBOEJBLDRDRHBCYyxnQkFBZ0I7OzRGQVdqQixvQ0FBb0M7a0JBYmhELFNBQVM7aUNBQ00sSUFBSSxXQUNQLENBQUMsZ0JBQWdCLENBQUMsWUFDakIsb0NBQW9DLG1CQUU3Qix1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxrQkFBa0I7NEJBQzNCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLHFDQUFxQyxDQUFDO3lCQUN0RTtxQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGZvcndhcmRSZWYsIGluamVjdCwgdHlwZSBUZW1wbGF0ZVJlZiwgdmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21wb25lbnRSZWZlcmVuY2UgfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi9jbGFzc2VzL2NvbXBvbmVudC1yZWZlcmVuY2UnO1xuaW1wb3J0IHsgS2NDbGFzc0RpcmVjdGl2ZSB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL2RpcmVjdGl2ZXMva2MtY2xhc3MnO1xuaW1wb3J0IHR5cGUgeyBJMThuIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vaTE4bic7XG5pbXBvcnQgdHlwZSB7IEtjQ29udGV4dCB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL0tjQ29udGV4dCc7XG5pbXBvcnQgeyBMT0dJTl9JMThOIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vdG9rZW5zL2kxOG4nO1xuaW1wb3J0IHsgS0NfTE9HSU5fQ09OVEVYVCB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL3Rva2Vucy9rYy1jb250ZXh0JztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbS2NDbGFzc0RpcmVjdGl2ZV0sXG4gICAgc2VsZWN0b3I6ICdrYy1sb2dpbi1pZHAtbGluay1jb25maXJtLW92ZXJyaWRlJyxcbiAgICB0ZW1wbGF0ZVVybDogJ2xvZ2luLWlkcC1saW5rLWNvbmZpcm0tb3ZlcnJpZGUuY29tcG9uZW50Lmh0bWwnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBDb21wb25lbnRSZWZlcmVuY2UsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBMb2dpbklkcExpbmtDb25maXJtT3ZlcnJpZGVDb21wb25lbnQpXG4gICAgICAgIH1cbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIExvZ2luSWRwTGlua0NvbmZpcm1PdmVycmlkZUNvbXBvbmVudCBleHRlbmRzIENvbXBvbmVudFJlZmVyZW5jZSB7XG4gICAga2NDb250ZXh0ID0gaW5qZWN0PEV4dHJhY3Q8S2NDb250ZXh0LCB7IHBhZ2VJZDogJ2xvZ2luLWlkcC1saW5rLWNvbmZpcm0tb3ZlcnJpZGUuZnRsJyB9Pj4oS0NfTE9HSU5fQ09OVEVYVCk7XG4gICAgaTE4biA9IGluamVjdDxJMThuPihMT0dJTl9JMThOKTtcblxuICAgIGRvY3VtZW50VGl0bGU6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgICBib2R5Q2xhc3NOYW1lOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cbiAgICBkaXNwbGF5UmVxdWlyZWRGaWVsZHMgPSBmYWxzZTtcbiAgICBkaXNwbGF5SW5mbyA9IGZhbHNlO1xuICAgIGRpc3BsYXlNZXNzYWdlID0gIXRoaXMua2NDb250ZXh0Lm1lc3NhZ2VzUGVyRmllbGQuZXhpc3RzRXJyb3IoJ3RvdHAnLCAndXNlckxhYmVsJyk7XG5cbiAgICBoZWFkZXJOb2RlID0gdmlld0NoaWxkPFRlbXBsYXRlUmVmPEhUTUxFbGVtZW50Pj4oJ2hlYWRlck5vZGUnKTtcbiAgICBpbmZvTm9kZSA9IHZpZXdDaGlsZDxUZW1wbGF0ZVJlZjxIVE1MRWxlbWVudD4+KCdpbmZvTm9kZScpO1xuICAgIHNvY2lhbFByb3ZpZGVyc05vZGUgPSB2aWV3Q2hpbGQ8VGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+Pignc29jaWFsUHJvdmlkZXJzTm9kZScpO1xufVxuIiwiQGxldCB1cmwgPSBrY0NvbnRleHQudXJsO1xuQGxldCBpZHBEaXNwbGF5TmFtZSA9IGtjQ29udGV4dC5pZHBEaXNwbGF5TmFtZTtcblxuPG5nLXRlbXBsYXRlICNoZWFkZXJOb2RlPlxuICAgIHt7IGkxOG4ubXNnU3RyKCdjb25maXJtT3ZlcnJpZGVJZHBUaXRsZScpIH19XG48L25nLXRlbXBsYXRlPlxuPGZvcm1cbiAgICBpZD1cImtjLXJlZ2lzdGVyLWZvcm1cIlxuICAgIG1ldGhvZD1cInBvc3RcIlxuICAgIFthY3Rpb25dPVwidXJsLmxvZ2luQWN0aW9uXCJcbj5cbiAgICB7eyBpMThuLm1zZ1N0cigncGFnZUV4cGlyZWRNc2cxJykgfX1cbiAgICA8YVxuICAgICAgICBpZD1cImxvZ2luUmVzdGFydExpbmtcIlxuICAgICAgICBbaHJlZl09XCJ1cmwubG9naW5SZXN0YXJ0Rmxvd1VybFwiXG4gICAgPlxuICAgICAgICB7eyBpMThuLm1zZ1N0cignZG9DbGlja0hlcmUnKSB9fVxuICAgIDwvYT5cbiAgICA8YnIgLz5cbiAgICA8YnIgLz5cbiAgICA8YnV0dG9uXG4gICAgICAgIHR5cGU9XCJzdWJtaXRcIlxuICAgICAgICBuYW1lPVwic3VibWl0QWN0aW9uXCJcbiAgICAgICAgaWQ9XCJjb25maXJtT3ZlcnJpZGVcIlxuICAgICAgICB2YWx1ZT1cImNvbmZpcm1PdmVycmlkZVwiXG4gICAgICAgIFtrY0NsYXNzXT1cIlsna2NCdXR0b25DbGFzcycsICdrY0J1dHRvbkRlZmF1bHRDbGFzcycsICdrY0J1dHRvbkJsb2NrQ2xhc3MnLCAna2NCdXR0b25MYXJnZUNsYXNzJ11cIlxuICAgID5cbiAgICAgICAge3sgaTE4bi5tc2dTdHIoJ2NvbmZpcm1PdmVycmlkZUlkcENvbnRpbnVlJywgaWRwRGlzcGxheU5hbWUpIH19XG4gICAgPC9idXR0b24+XG48L2Zvcm0+XG4iXX0=
@@ -1,2 +0,0 @@
1
- export * from './login-idp-link-email.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbG9naW4vcGFnZXMvbG9naW4taWRwLWxpbmstZW1haWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQ0FBa0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbG9naW4taWRwLWxpbmstZW1haWwuY29tcG9uZW50JztcbiJdfQ==
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Y2xvYWtpZnktYW5ndWxhci1sb2dpbi1wYWdlcy1sb2dpbi1pZHAtbGluay1lbWFpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9sb2dpbi9wYWdlcy9sb2dpbi1pZHAtbGluay1lbWFpbC9rZXljbG9ha2lmeS1hbmd1bGFyLWxvZ2luLXBhZ2VzLWxvZ2luLWlkcC1saW5rLWVtYWlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
@@ -1,36 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, forwardRef, inject, viewChild } from '@angular/core';
2
- import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
3
- import { KcClassDirective } from '@keycloakify/angular/login/directives/kc-class';
4
- import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
5
- import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
6
- import * as i0 from "@angular/core";
7
- export class LoginIdpLinkEmailComponent extends ComponentReference {
8
- constructor() {
9
- super(...arguments);
10
- this.kcContext = inject(KC_LOGIN_CONTEXT);
11
- this.i18n = inject(LOGIN_I18N);
12
- this.displayRequiredFields = false;
13
- this.displayInfo = false;
14
- this.displayMessage = false;
15
- this.headerNode = viewChild('headerNode');
16
- this.infoNode = viewChild('infoNode');
17
- this.socialProvidersNode = viewChild('socialProvidersNode');
18
- }
19
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginIdpLinkEmailComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
20
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: LoginIdpLinkEmailComponent, isStandalone: true, selector: "kc-login-idp-link-email", providers: [
21
- {
22
- provide: ComponentReference,
23
- useExisting: forwardRef(() => LoginIdpLinkEmailComponent)
24
- }
25
- ], viewQueries: [{ propertyName: "headerNode", first: true, predicate: ["headerNode"], descendants: true, isSignal: true }, { propertyName: "infoNode", first: true, predicate: ["infoNode"], descendants: true, isSignal: true }, { propertyName: "socialProvidersNode", first: true, predicate: ["socialProvidersNode"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@let idpAlias = kcContext.idpAlias;\n@let brokerContext = kcContext.brokerContext;\n@let realm = kcContext.realm;\n@let url = kcContext.url;\n\n<ng-template #headerNode>\n @let idpAlias = kcContext.idpAlias;\n {{ i18n.msgStr('emailLinkIdpTitle', idpAlias) }}\n</ng-template>\n<p\n id=\"instruction1\"\n class=\"instruction\"\n>\n {{ i18n.msgStr('emailLinkIdp1', idpAlias, brokerContext.username, realm.displayName) }}\n</p>\n<p\n id=\"instruction2\"\n class=\"instruction\"\n>\n {{ i18n.msgStr('emailLinkIdp2') }}\n <a [href]=\"url.loginAction\">{{ i18n.msgStr('doClickHere') }}</a>\n {{ i18n.msgStr('emailLinkIdp3') }}\n</p>\n<p\n id=\"instruction3\"\n class=\"instruction\"\n>\n {{ i18n.msgStr('emailLinkIdp4') }}\n <a [href]=\"url.loginAction\">{{ i18n.msgStr('doClickHere') }}</a>\n {{ i18n.msgStr('emailLinkIdp5') }}\n</p>\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
26
- }
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginIdpLinkEmailComponent, decorators: [{
28
- type: Component,
29
- args: [{ standalone: true, imports: [KcClassDirective], selector: 'kc-login-idp-link-email', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
30
- {
31
- provide: ComponentReference,
32
- useExisting: forwardRef(() => LoginIdpLinkEmailComponent)
33
- }
34
- ], template: "@let idpAlias = kcContext.idpAlias;\n@let brokerContext = kcContext.brokerContext;\n@let realm = kcContext.realm;\n@let url = kcContext.url;\n\n<ng-template #headerNode>\n @let idpAlias = kcContext.idpAlias;\n {{ i18n.msgStr('emailLinkIdpTitle', idpAlias) }}\n</ng-template>\n<p\n id=\"instruction1\"\n class=\"instruction\"\n>\n {{ i18n.msgStr('emailLinkIdp1', idpAlias, brokerContext.username, realm.displayName) }}\n</p>\n<p\n id=\"instruction2\"\n class=\"instruction\"\n>\n {{ i18n.msgStr('emailLinkIdp2') }}\n <a [href]=\"url.loginAction\">{{ i18n.msgStr('doClickHere') }}</a>\n {{ i18n.msgStr('emailLinkIdp3') }}\n</p>\n<p\n id=\"instruction3\"\n class=\"instruction\"\n>\n {{ i18n.msgStr('emailLinkIdp4') }}\n <a [href]=\"url.loginAction\">{{ i18n.msgStr('doClickHere') }}</a>\n {{ i18n.msgStr('emailLinkIdp5') }}\n</p>\n" }]
35
- }] });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4taWRwLWxpbmstZW1haWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xvZ2luL3BhZ2VzL2xvZ2luLWlkcC1saW5rLWVtYWlsL2xvZ2luLWlkcC1saW5rLWVtYWlsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9sb2dpbi9wYWdlcy9sb2dpbi1pZHAtbGluay1lbWFpbC9sb2dpbi1pZHAtbGluay1lbWFpbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQW9CLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwSCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUM1RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUdsRixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOENBQThDLENBQUM7O0FBZWhGLE1BQU0sT0FBTywwQkFBMkIsU0FBUSxrQkFBa0I7SUFibEU7O1FBY0ksY0FBUyxHQUFHLE1BQU0sQ0FBNkQsZ0JBQWdCLENBQUMsQ0FBQztRQUNqRyxTQUFJLEdBQUcsTUFBTSxDQUFPLFVBQVUsQ0FBQyxDQUFDO1FBS2hDLDBCQUFxQixHQUFHLEtBQUssQ0FBQztRQUM5QixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUNwQixtQkFBYyxHQUFHLEtBQUssQ0FBQztRQUV2QixlQUFVLEdBQUcsU0FBUyxDQUEyQixZQUFZLENBQUMsQ0FBQztRQUMvRCxhQUFRLEdBQUcsU0FBUyxDQUEyQixVQUFVLENBQUMsQ0FBQztRQUMzRCx3QkFBbUIsR0FBRyxTQUFTLENBQTJCLHFCQUFxQixDQUFDLENBQUM7S0FDcEY7K0dBZFksMEJBQTBCO21HQUExQiwwQkFBMEIsc0VBUHhCO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLGtCQUFrQjtnQkFDM0IsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQywwQkFBMEIsQ0FBQzthQUM1RDtTQUNKLCtZQ25CTCw0MkJBK0JBOzs0RkRWYSwwQkFBMEI7a0JBYnRDLFNBQVM7aUNBQ00sSUFBSSxXQUNQLENBQUMsZ0JBQWdCLENBQUMsWUFDakIseUJBQXlCLG1CQUVsQix1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxrQkFBa0I7NEJBQzNCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLDJCQUEyQixDQUFDO3lCQUM1RDtxQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGZvcndhcmRSZWYsIGluamVjdCwgdHlwZSBUZW1wbGF0ZVJlZiwgdmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21wb25lbnRSZWZlcmVuY2UgfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi9jbGFzc2VzL2NvbXBvbmVudC1yZWZlcmVuY2UnO1xuaW1wb3J0IHsgS2NDbGFzc0RpcmVjdGl2ZSB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL2RpcmVjdGl2ZXMva2MtY2xhc3MnO1xuaW1wb3J0IHR5cGUgeyBJMThuIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vaTE4bic7XG5pbXBvcnQgdHlwZSB7IEtjQ29udGV4dCB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL0tjQ29udGV4dCc7XG5pbXBvcnQgeyBMT0dJTl9JMThOIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vdG9rZW5zL2kxOG4nO1xuaW1wb3J0IHsgS0NfTE9HSU5fQ09OVEVYVCB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL3Rva2Vucy9rYy1jb250ZXh0JztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbS2NDbGFzc0RpcmVjdGl2ZV0sXG4gICAgc2VsZWN0b3I6ICdrYy1sb2dpbi1pZHAtbGluay1lbWFpbCcsXG4gICAgdGVtcGxhdGVVcmw6ICdsb2dpbi1pZHAtbGluay1lbWFpbC5jb21wb25lbnQuaHRtbCcsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IENvbXBvbmVudFJlZmVyZW5jZSxcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IExvZ2luSWRwTGlua0VtYWlsQ29tcG9uZW50KVxuICAgICAgICB9XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBMb2dpbklkcExpbmtFbWFpbENvbXBvbmVudCBleHRlbmRzIENvbXBvbmVudFJlZmVyZW5jZSB7XG4gICAga2NDb250ZXh0ID0gaW5qZWN0PEV4dHJhY3Q8S2NDb250ZXh0LCB7IHBhZ2VJZDogJ2xvZ2luLWlkcC1saW5rLWVtYWlsLmZ0bCcgfT4+KEtDX0xPR0lOX0NPTlRFWFQpO1xuICAgIGkxOG4gPSBpbmplY3Q8STE4bj4oTE9HSU5fSTE4Tik7XG5cbiAgICBkb2N1bWVudFRpdGxlOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgYm9keUNsYXNzTmFtZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXG4gICAgZGlzcGxheVJlcXVpcmVkRmllbGRzID0gZmFsc2U7XG4gICAgZGlzcGxheUluZm8gPSBmYWxzZTtcbiAgICBkaXNwbGF5TWVzc2FnZSA9IGZhbHNlO1xuXG4gICAgaGVhZGVyTm9kZSA9IHZpZXdDaGlsZDxUZW1wbGF0ZVJlZjxIVE1MRWxlbWVudD4+KCdoZWFkZXJOb2RlJyk7XG4gICAgaW5mb05vZGUgPSB2aWV3Q2hpbGQ8VGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+PignaW5mb05vZGUnKTtcbiAgICBzb2NpYWxQcm92aWRlcnNOb2RlID0gdmlld0NoaWxkPFRlbXBsYXRlUmVmPEhUTUxFbGVtZW50Pj4oJ3NvY2lhbFByb3ZpZGVyc05vZGUnKTtcbn1cbiIsIkBsZXQgaWRwQWxpYXMgPSBrY0NvbnRleHQuaWRwQWxpYXM7XG5AbGV0IGJyb2tlckNvbnRleHQgPSBrY0NvbnRleHQuYnJva2VyQ29udGV4dDtcbkBsZXQgcmVhbG0gPSBrY0NvbnRleHQucmVhbG07XG5AbGV0IHVybCA9IGtjQ29udGV4dC51cmw7XG5cbjxuZy10ZW1wbGF0ZSAjaGVhZGVyTm9kZT5cbiAgICBAbGV0IGlkcEFsaWFzID0ga2NDb250ZXh0LmlkcEFsaWFzO1xuICAgIHt7IGkxOG4ubXNnU3RyKCdlbWFpbExpbmtJZHBUaXRsZScsIGlkcEFsaWFzKSB9fVxuPC9uZy10ZW1wbGF0ZT5cbjxwXG4gICAgaWQ9XCJpbnN0cnVjdGlvbjFcIlxuICAgIGNsYXNzPVwiaW5zdHJ1Y3Rpb25cIlxuPlxuICAgIHt7IGkxOG4ubXNnU3RyKCdlbWFpbExpbmtJZHAxJywgaWRwQWxpYXMsIGJyb2tlckNvbnRleHQudXNlcm5hbWUsIHJlYWxtLmRpc3BsYXlOYW1lKSB9fVxuPC9wPlxuPHBcbiAgICBpZD1cImluc3RydWN0aW9uMlwiXG4gICAgY2xhc3M9XCJpbnN0cnVjdGlvblwiXG4+XG4gICAge3sgaTE4bi5tc2dTdHIoJ2VtYWlsTGlua0lkcDInKSB9fVxuICAgIDxhIFtocmVmXT1cInVybC5sb2dpbkFjdGlvblwiPnt7IGkxOG4ubXNnU3RyKCdkb0NsaWNrSGVyZScpIH19PC9hPlxuICAgIHt7IGkxOG4ubXNnU3RyKCdlbWFpbExpbmtJZHAzJykgfX1cbjwvcD5cbjxwXG4gICAgaWQ9XCJpbnN0cnVjdGlvbjNcIlxuICAgIGNsYXNzPVwiaW5zdHJ1Y3Rpb25cIlxuPlxuICAgIHt7IGkxOG4ubXNnU3RyKCdlbWFpbExpbmtJZHA0JykgfX1cbiAgICA8YSBbaHJlZl09XCJ1cmwubG9naW5BY3Rpb25cIj57eyBpMThuLm1zZ1N0cignZG9DbGlja0hlcmUnKSB9fTwvYT5cbiAgICB7eyBpMThuLm1zZ1N0cignZW1haWxMaW5rSWRwNScpIH19XG48L3A+XG4iXX0=
@@ -1,2 +0,0 @@
1
- export * from './login-oauth-grant.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbG9naW4vcGFnZXMvbG9naW4tb2F1dGgtZ3JhbnQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbG9naW4tb2F1dGgtZ3JhbnQuY29tcG9uZW50JztcbiJdfQ==
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Y2xvYWtpZnktYW5ndWxhci1sb2dpbi1wYWdlcy1sb2dpbi1vYXV0aC1ncmFudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9sb2dpbi9wYWdlcy9sb2dpbi1vYXV0aC1ncmFudC9rZXljbG9ha2lmeS1hbmd1bGFyLWxvZ2luLXBhZ2VzLWxvZ2luLW9hdXRoLWdyYW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
@@ -1,37 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, forwardRef, inject, viewChild } from '@angular/core';
2
- import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
3
- import { KcClassDirective } from '@keycloakify/angular/login/directives/kc-class';
4
- import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
5
- import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
6
- import * as i0 from "@angular/core";
7
- export class LoginOauthGrantComponent extends ComponentReference {
8
- constructor() {
9
- super(...arguments);
10
- this.kcContext = inject(KC_LOGIN_CONTEXT);
11
- this.i18n = inject(LOGIN_I18N);
12
- this.bodyClassName = 'oauth';
13
- this.displayRequiredFields = false;
14
- this.displayInfo = false;
15
- this.displayMessage = false;
16
- this.headerNode = viewChild('headerNode');
17
- this.infoNode = viewChild('infoNode');
18
- this.socialProvidersNode = viewChild('socialProvidersNode');
19
- }
20
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginOauthGrantComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
21
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: LoginOauthGrantComponent, isStandalone: true, selector: "kc-login-oauth-grant", providers: [
22
- {
23
- provide: ComponentReference,
24
- useExisting: forwardRef(() => LoginOauthGrantComponent)
25
- }
26
- ], viewQueries: [{ propertyName: "headerNode", first: true, predicate: ["headerNode"], descendants: true, isSignal: true }, { propertyName: "infoNode", first: true, predicate: ["infoNode"], descendants: true, isSignal: true }, { propertyName: "socialProvidersNode", first: true, predicate: ["socialProvidersNode"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@let client = kcContext.client;\n@let oauth = kcContext.oauth;\n@let url = kcContext.url;\n\n<ng-template #headerNode>\n @let client = kcContext.client;\n @if (client.attributes['logoUri']) {\n <img\n alt=\"\"\n [src]=\"client.attributes['logoUri']\"\n />\n }\n <p>\n {{ i18n.msgStr('oauthGrantTitle', client.name ? i18n.advancedMsgStr(client.name) : client.clientId) }}\n </p>\n</ng-template>\n\n<div\n id=\"kc-oauth\"\n class=\"content-area\"\n>\n <h3>{{ i18n.msgStr('oauthGrantRequest') }}</h3>\n <ul>\n @for (clientScope of oauth.clientScopesRequested; track clientScope) {\n <li>\n <span>\n {{ i18n.advancedMsgStr(clientScope.consentScreenText) }}\n @if (clientScope.dynamicScopeParameter) {\n : <b>{{ clientScope.dynamicScopeParameter }}</b>\n }\n </span>\n </li>\n }\n </ul>\n\n @if (client.attributes['policyUri'] || client.attributes['tosUri']) {\n <h3>\n @if (client.name) {\n {{ i18n.msgStr('oauthGrantInformation', i18n.advancedMsgStr(client.name)) }}\n } @else {\n {{ i18n.msgStr('oauthGrantInformation', client.clientId) }}\n }\n @if (client.attributes['policyUri']) {\n {{ i18n.msgStr('oauthGrantReview') }}\n <a\n target=\"_blank\"\n [href]=\"client.attributes['policyUri']\"\n >\n {{ i18n.msgStr('oauthGrantPolicy') }}\n </a>\n }\n </h3>\n }\n <form\n class=\"form-actions\"\n method=\"post\"\n [action]=\"url.oauthAction\"\n >\n <input\n type=\"hidden\"\n name=\"code\"\n [value]=\"oauth.code\"\n />\n <div [kcClass]=\"'kcFormGroupClass'\">\n <div id=\"kc-form-options\">\n <div [kcClass]=\"'kcFormOptionsWrapperClass'\"></div>\n </div>\n\n <div id=\"kc-form-buttons\">\n <div [kcClass]=\"'kcFormButtonsWrapperClass'\">\n <input\n type=\"submit\"\n [kcClass]=\"['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doYes')\"\n />\n <input\n type=\"submit\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doNo')\"\n />\n </div>\n </div>\n </div>\n </form>\n <div class=\"clearfix\"></div>\n</div>\n", dependencies: [{ kind: "directive", type: KcClassDirective, selector: "[kcClass]", inputs: ["class", "ngClass", "kcClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
27
- }
28
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: LoginOauthGrantComponent, decorators: [{
29
- type: Component,
30
- args: [{ standalone: true, imports: [KcClassDirective], selector: 'kc-login-oauth-grant', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
31
- {
32
- provide: ComponentReference,
33
- useExisting: forwardRef(() => LoginOauthGrantComponent)
34
- }
35
- ], template: "@let client = kcContext.client;\n@let oauth = kcContext.oauth;\n@let url = kcContext.url;\n\n<ng-template #headerNode>\n @let client = kcContext.client;\n @if (client.attributes['logoUri']) {\n <img\n alt=\"\"\n [src]=\"client.attributes['logoUri']\"\n />\n }\n <p>\n {{ i18n.msgStr('oauthGrantTitle', client.name ? i18n.advancedMsgStr(client.name) : client.clientId) }}\n </p>\n</ng-template>\n\n<div\n id=\"kc-oauth\"\n class=\"content-area\"\n>\n <h3>{{ i18n.msgStr('oauthGrantRequest') }}</h3>\n <ul>\n @for (clientScope of oauth.clientScopesRequested; track clientScope) {\n <li>\n <span>\n {{ i18n.advancedMsgStr(clientScope.consentScreenText) }}\n @if (clientScope.dynamicScopeParameter) {\n : <b>{{ clientScope.dynamicScopeParameter }}</b>\n }\n </span>\n </li>\n }\n </ul>\n\n @if (client.attributes['policyUri'] || client.attributes['tosUri']) {\n <h3>\n @if (client.name) {\n {{ i18n.msgStr('oauthGrantInformation', i18n.advancedMsgStr(client.name)) }}\n } @else {\n {{ i18n.msgStr('oauthGrantInformation', client.clientId) }}\n }\n @if (client.attributes['policyUri']) {\n {{ i18n.msgStr('oauthGrantReview') }}\n <a\n target=\"_blank\"\n [href]=\"client.attributes['policyUri']\"\n >\n {{ i18n.msgStr('oauthGrantPolicy') }}\n </a>\n }\n </h3>\n }\n <form\n class=\"form-actions\"\n method=\"post\"\n [action]=\"url.oauthAction\"\n >\n <input\n type=\"hidden\"\n name=\"code\"\n [value]=\"oauth.code\"\n />\n <div [kcClass]=\"'kcFormGroupClass'\">\n <div id=\"kc-form-options\">\n <div [kcClass]=\"'kcFormOptionsWrapperClass'\"></div>\n </div>\n\n <div id=\"kc-form-buttons\">\n <div [kcClass]=\"'kcFormButtonsWrapperClass'\">\n <input\n type=\"submit\"\n [kcClass]=\"['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doYes')\"\n />\n <input\n type=\"submit\"\n [kcClass]=\"['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass']\"\n [value]=\"i18n.msgStr('doNo')\"\n />\n </div>\n </div>\n </div>\n </form>\n <div class=\"clearfix\"></div>\n</div>\n" }]
36
- }] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4tb2F1dGgtZ3JhbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xvZ2luL3BhZ2VzL2xvZ2luLW9hdXRoLWdyYW50L2xvZ2luLW9hdXRoLWdyYW50LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9sb2dpbi9wYWdlcy9sb2dpbi1vYXV0aC1ncmFudC9sb2dpbi1vYXV0aC1ncmFudC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQW9CLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwSCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUM1RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUdsRixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOENBQThDLENBQUM7O0FBZWhGLE1BQU0sT0FBTyx3QkFBeUIsU0FBUSxrQkFBa0I7SUFiaEU7O1FBY0ksY0FBUyxHQUFHLE1BQU0sQ0FBMEQsZ0JBQWdCLENBQUMsQ0FBQztRQUM5RixTQUFJLEdBQUcsTUFBTSxDQUFPLFVBQVUsQ0FBQyxDQUFDO1FBR2hDLGtCQUFhLEdBQUcsT0FBTyxDQUFDO1FBRXhCLDBCQUFxQixHQUFHLEtBQUssQ0FBQztRQUM5QixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUNwQixtQkFBYyxHQUFHLEtBQUssQ0FBQztRQUV2QixlQUFVLEdBQUcsU0FBUyxDQUEyQixZQUFZLENBQUMsQ0FBQztRQUMvRCxhQUFRLEdBQUcsU0FBUyxDQUEyQixVQUFVLENBQUMsQ0FBQztRQUMzRCx3QkFBbUIsR0FBRyxTQUFTLENBQTJCLHFCQUFxQixDQUFDLENBQUM7S0FDcEY7K0dBZFksd0JBQXdCO21HQUF4Qix3QkFBd0IsbUVBUHRCO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLGtCQUFrQjtnQkFDM0IsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyx3QkFBd0IsQ0FBQzthQUMxRDtTQUNKLCtZQ25CTCxreUZBc0ZBLDRDRDVFYyxnQkFBZ0I7OzRGQVdqQix3QkFBd0I7a0JBYnBDLFNBQVM7aUNBQ00sSUFBSSxXQUNQLENBQUMsZ0JBQWdCLENBQUMsWUFDakIsc0JBQXNCLG1CQUVmLHVCQUF1QixDQUFDLE1BQU0sYUFDcEM7d0JBQ1A7NEJBQ0ksT0FBTyxFQUFFLGtCQUFrQjs0QkFDM0IsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUseUJBQXlCLENBQUM7eUJBQzFEO3FCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgZm9yd2FyZFJlZiwgaW5qZWN0LCB0eXBlIFRlbXBsYXRlUmVmLCB2aWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudFJlZmVyZW5jZSB9IGZyb20gJ0BrZXljbG9ha2lmeS9hbmd1bGFyL2xvZ2luL2NsYXNzZXMvY29tcG9uZW50LXJlZmVyZW5jZSc7XG5pbXBvcnQgeyBLY0NsYXNzRGlyZWN0aXZlIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vZGlyZWN0aXZlcy9rYy1jbGFzcyc7XG5pbXBvcnQgdHlwZSB7IEkxOG4gfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi9pMThuJztcbmltcG9ydCB0eXBlIHsgS2NDb250ZXh0IH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vS2NDb250ZXh0JztcbmltcG9ydCB7IExPR0lOX0kxOE4gfSBmcm9tICdAa2V5Y2xvYWtpZnkvYW5ndWxhci9sb2dpbi90b2tlbnMvaTE4bic7XG5pbXBvcnQgeyBLQ19MT0dJTl9DT05URVhUIH0gZnJvbSAnQGtleWNsb2FraWZ5L2FuZ3VsYXIvbG9naW4vdG9rZW5zL2tjLWNvbnRleHQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtLY0NsYXNzRGlyZWN0aXZlXSxcbiAgICBzZWxlY3RvcjogJ2tjLWxvZ2luLW9hdXRoLWdyYW50JyxcbiAgICB0ZW1wbGF0ZVVybDogJ2xvZ2luLW9hdXRoLWdyYW50LmNvbXBvbmVudC5odG1sJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogQ29tcG9uZW50UmVmZXJlbmNlLFxuICAgICAgICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gTG9naW5PYXV0aEdyYW50Q29tcG9uZW50KVxuICAgICAgICB9XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBMb2dpbk9hdXRoR3JhbnRDb21wb25lbnQgZXh0ZW5kcyBDb21wb25lbnRSZWZlcmVuY2Uge1xuICAgIGtjQ29udGV4dCA9IGluamVjdDxFeHRyYWN0PEtjQ29udGV4dCwgeyBwYWdlSWQ6ICdsb2dpbi1vYXV0aC1ncmFudC5mdGwnIH0+PihLQ19MT0dJTl9DT05URVhUKTtcbiAgICBpMThuID0gaW5qZWN0PEkxOG4+KExPR0lOX0kxOE4pO1xuXG4gICAgZG9jdW1lbnRUaXRsZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIGJvZHlDbGFzc05hbWUgPSAnb2F1dGgnO1xuXG4gICAgZGlzcGxheVJlcXVpcmVkRmllbGRzID0gZmFsc2U7XG4gICAgZGlzcGxheUluZm8gPSBmYWxzZTtcbiAgICBkaXNwbGF5TWVzc2FnZSA9IGZhbHNlO1xuXG4gICAgaGVhZGVyTm9kZSA9IHZpZXdDaGlsZDxUZW1wbGF0ZVJlZjxIVE1MRWxlbWVudD4+KCdoZWFkZXJOb2RlJyk7XG4gICAgaW5mb05vZGUgPSB2aWV3Q2hpbGQ8VGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+PignaW5mb05vZGUnKTtcbiAgICBzb2NpYWxQcm92aWRlcnNOb2RlID0gdmlld0NoaWxkPFRlbXBsYXRlUmVmPEhUTUxFbGVtZW50Pj4oJ3NvY2lhbFByb3ZpZGVyc05vZGUnKTtcbn1cbiIsIkBsZXQgY2xpZW50ID0ga2NDb250ZXh0LmNsaWVudDtcbkBsZXQgb2F1dGggPSBrY0NvbnRleHQub2F1dGg7XG5AbGV0IHVybCA9IGtjQ29udGV4dC51cmw7XG5cbjxuZy10ZW1wbGF0ZSAjaGVhZGVyTm9kZT5cbiAgICBAbGV0IGNsaWVudCA9IGtjQ29udGV4dC5jbGllbnQ7XG4gICAgQGlmIChjbGllbnQuYXR0cmlidXRlc1snbG9nb1VyaSddKSB7XG4gICAgICAgIDxpbWdcbiAgICAgICAgICAgIGFsdD1cIlwiXG4gICAgICAgICAgICBbc3JjXT1cImNsaWVudC5hdHRyaWJ1dGVzWydsb2dvVXJpJ11cIlxuICAgICAgICAvPlxuICAgIH1cbiAgICA8cD5cbiAgICAgICAge3sgaTE4bi5tc2dTdHIoJ29hdXRoR3JhbnRUaXRsZScsIGNsaWVudC5uYW1lID8gaTE4bi5hZHZhbmNlZE1zZ1N0cihjbGllbnQubmFtZSkgOiBjbGllbnQuY2xpZW50SWQpIH19XG4gICAgPC9wPlxuPC9uZy10ZW1wbGF0ZT5cblxuPGRpdlxuICAgIGlkPVwia2Mtb2F1dGhcIlxuICAgIGNsYXNzPVwiY29udGVudC1hcmVhXCJcbj5cbiAgICA8aDM+e3sgaTE4bi5tc2dTdHIoJ29hdXRoR3JhbnRSZXF1ZXN0JykgfX08L2gzPlxuICAgIDx1bD5cbiAgICAgICAgQGZvciAoY2xpZW50U2NvcGUgb2Ygb2F1dGguY2xpZW50U2NvcGVzUmVxdWVzdGVkOyB0cmFjayBjbGllbnRTY29wZSkge1xuICAgICAgICAgICAgPGxpPlxuICAgICAgICAgICAgICAgIDxzcGFuPlxuICAgICAgICAgICAgICAgICAgICB7eyBpMThuLmFkdmFuY2VkTXNnU3RyKGNsaWVudFNjb3BlLmNvbnNlbnRTY3JlZW5UZXh0KSB9fVxuICAgICAgICAgICAgICAgICAgICBAaWYgKGNsaWVudFNjb3BlLmR5bmFtaWNTY29wZVBhcmFtZXRlcikge1xuICAgICAgICAgICAgICAgICAgICAgICAgOiA8Yj57eyBjbGllbnRTY29wZS5keW5hbWljU2NvcGVQYXJhbWV0ZXIgfX08L2I+XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICAgICA8L2xpPlxuICAgICAgICB9XG4gICAgPC91bD5cblxuICAgIEBpZiAoY2xpZW50LmF0dHJpYnV0ZXNbJ3BvbGljeVVyaSddIHx8IGNsaWVudC5hdHRyaWJ1dGVzWyd0b3NVcmknXSkge1xuICAgICAgICA8aDM+XG4gICAgICAgICAgICBAaWYgKGNsaWVudC5uYW1lKSB7XG4gICAgICAgICAgICAgICAge3sgaTE4bi5tc2dTdHIoJ29hdXRoR3JhbnRJbmZvcm1hdGlvbicsIGkxOG4uYWR2YW5jZWRNc2dTdHIoY2xpZW50Lm5hbWUpKSB9fVxuICAgICAgICAgICAgfSBAZWxzZSB7XG4gICAgICAgICAgICAgICAge3sgaTE4bi5tc2dTdHIoJ29hdXRoR3JhbnRJbmZvcm1hdGlvbicsIGNsaWVudC5jbGllbnRJZCkgfX1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIEBpZiAoY2xpZW50LmF0dHJpYnV0ZXNbJ3BvbGljeVVyaSddKSB7XG4gICAgICAgICAgICAgICAge3sgaTE4bi5tc2dTdHIoJ29hdXRoR3JhbnRSZXZpZXcnKSB9fVxuICAgICAgICAgICAgICAgIDxhXG4gICAgICAgICAgICAgICAgICAgIHRhcmdldD1cIl9ibGFua1wiXG4gICAgICAgICAgICAgICAgICAgIFtocmVmXT1cImNsaWVudC5hdHRyaWJ1dGVzWydwb2xpY3lVcmknXVwiXG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICB7eyBpMThuLm1zZ1N0cignb2F1dGhHcmFudFBvbGljeScpIH19XG4gICAgICAgICAgICAgICAgPC9hPlxuICAgICAgICAgICAgfVxuICAgICAgICA8L2gzPlxuICAgIH1cbiAgICA8Zm9ybVxuICAgICAgICBjbGFzcz1cImZvcm0tYWN0aW9uc1wiXG4gICAgICAgIG1ldGhvZD1cInBvc3RcIlxuICAgICAgICBbYWN0aW9uXT1cInVybC5vYXV0aEFjdGlvblwiXG4gICAgPlxuICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgIHR5cGU9XCJoaWRkZW5cIlxuICAgICAgICAgICAgbmFtZT1cImNvZGVcIlxuICAgICAgICAgICAgW3ZhbHVlXT1cIm9hdXRoLmNvZGVcIlxuICAgICAgICAvPlxuICAgICAgICA8ZGl2IFtrY0NsYXNzXT1cIidrY0Zvcm1Hcm91cENsYXNzJ1wiPlxuICAgICAgICAgICAgPGRpdiBpZD1cImtjLWZvcm0tb3B0aW9uc1wiPlxuICAgICAgICAgICAgICAgIDxkaXYgW2tjQ2xhc3NdPVwiJ2tjRm9ybU9wdGlvbnNXcmFwcGVyQ2xhc3MnXCI+PC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cblxuICAgICAgICAgICAgPGRpdiBpZD1cImtjLWZvcm0tYnV0dG9uc1wiPlxuICAgICAgICAgICAgICAgIDxkaXYgW2tjQ2xhc3NdPVwiJ2tjRm9ybUJ1dHRvbnNXcmFwcGVyQ2xhc3MnXCI+XG4gICAgICAgICAgICAgICAgICAgIDxpbnB1dFxuICAgICAgICAgICAgICAgICAgICAgICAgdHlwZT1cInN1Ym1pdFwiXG4gICAgICAgICAgICAgICAgICAgICAgICBba2NDbGFzc109XCJbJ2tjQnV0dG9uQ2xhc3MnLCAna2NCdXR0b25QcmltYXJ5Q2xhc3MnLCAna2NCdXR0b25MYXJnZUNsYXNzJ11cIlxuICAgICAgICAgICAgICAgICAgICAgICAgW3ZhbHVlXT1cImkxOG4ubXNnU3RyKCdkb1llcycpXCJcbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICAgPGlucHV0XG4gICAgICAgICAgICAgICAgICAgICAgICB0eXBlPVwic3VibWl0XCJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtrY0NsYXNzXT1cIlsna2NCdXR0b25DbGFzcycsICdrY0J1dHRvbkRlZmF1bHRDbGFzcycsICdrY0J1dHRvbkxhcmdlQ2xhc3MnXVwiXG4gICAgICAgICAgICAgICAgICAgICAgICBbdmFsdWVdPVwiaTE4bi5tc2dTdHIoJ2RvTm8nKVwiXG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgPC9mb3JtPlxuICAgIDxkaXYgY2xhc3M9XCJjbGVhcmZpeFwiPjwvZGl2PlxuPC9kaXY+XG4iXX0=
@@ -1,2 +0,0 @@
1
- export * from './login-oauth2-device-verify-user-code.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbG9naW4vcGFnZXMvbG9naW4tb2F1dGgyLWRldmljZS12ZXJpZnktdXNlci1jb2RlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0RBQWtELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xvZ2luLW9hdXRoMi1kZXZpY2UtdmVyaWZ5LXVzZXItY29kZS5jb21wb25lbnQnO1xuIl19
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Y2xvYWtpZnktYW5ndWxhci1sb2dpbi1wYWdlcy1sb2dpbi1vYXV0aDItZGV2aWNlLXZlcmlmeS11c2VyLWNvZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbG9naW4vcGFnZXMvbG9naW4tb2F1dGgyLWRldmljZS12ZXJpZnktdXNlci1jb2RlL2tleWNsb2FraWZ5LWFuZ3VsYXItbG9naW4tcGFnZXMtbG9naW4tb2F1dGgyLWRldmljZS12ZXJpZnktdXNlci1jb2RlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19