@keycloakify/angular 0.0.1-rc.17 → 0.0.1-rc.19
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.
- package/account/containers/template/template.component.d.ts +18 -5
- package/account/pages/account/account.component.d.ts +3 -2
- package/account/pages/applications/applications.component.d.ts +3 -2
- package/account/pages/federatedIdentity/federatedIdentity.component.d.ts +3 -2
- package/account/pages/log/log.component.d.ts +3 -2
- package/account/pages/password/password.component.d.ts +3 -2
- package/account/pages/sessions/sessions.component.d.ts +3 -2
- package/account/pages/totp/totp.component.d.ts +3 -2
- package/esm2022/account/containers/template/template.component.mjs +42 -9
- package/esm2022/account/directives/kc-class/kc-class.directive.mjs +3 -3
- package/esm2022/account/pages/account/account.component.mjs +8 -7
- package/esm2022/account/pages/applications/applications.component.mjs +8 -7
- package/esm2022/account/pages/federatedIdentity/federatedIdentity.component.mjs +8 -7
- package/esm2022/account/pages/log/log.component.mjs +8 -7
- package/esm2022/account/pages/password/password.component.mjs +9 -7
- package/esm2022/account/pages/sessions/sessions.component.mjs +8 -7
- package/esm2022/account/pages/totp/totp.component.mjs +8 -7
- package/esm2022/account/providers/keycloakify-angular/keycloakify-angular.providers.mjs +2 -1
- package/esm2022/account/services/account-resource-injector/account-resource-injector.service.mjs +3 -3
- package/esm2022/account/services/i18n/i18n.service.mjs +3 -3
- package/esm2022/lib/directives/attributes/attributes.directive.mjs +3 -3
- package/esm2022/lib/pipes/input-type/input-type.pipe.mjs +3 -3
- package/esm2022/lib/pipes/is-array-with-empty-object/is-array-with-empty-object.pipe.mjs +3 -3
- package/esm2022/lib/pipes/kc-sanitize/kc-sanitize.pipe.mjs +3 -3
- package/esm2022/lib/pipes/to-array/to-array.pipe.mjs +3 -3
- package/esm2022/lib/pipes/to-number/to-number.pipe.mjs +3 -3
- package/esm2022/lib/services/resource-injector/resource-injector.service.mjs +3 -3
- package/esm2022/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.mjs +5 -5
- package/esm2022/login/components/field-errors/field-errors.component.mjs +6 -6
- package/esm2022/login/components/group-label/group-label.component.mjs +3 -3
- package/esm2022/login/components/input-field-by-type/input-field-by-type.component.mjs +6 -6
- package/esm2022/login/components/input-tag/input-tag.component.mjs +6 -6
- package/esm2022/login/components/input-tag-selects/input-tag-selects.component.mjs +3 -3
- package/esm2022/login/components/logout-other-sessions/logout-other-sessions.component.mjs +3 -3
- package/esm2022/login/components/password-wrapper/password-wrapper.component.mjs +6 -6
- package/esm2022/login/components/select-tag/select-tag.component.mjs +3 -3
- package/esm2022/login/components/textarea-tag/textarea-tag.component.mjs +3 -3
- package/esm2022/login/components/user-profile-form-fields/user-profile-form-fields.component.mjs +6 -6
- package/esm2022/login/containers/template/template.component.mjs +83 -15
- package/esm2022/login/directives/kc-class/kc-class.directive.mjs +5 -5
- package/esm2022/login/pages/code/code.component.mjs +16 -10
- package/esm2022/login/pages/delete-account-confirm/delete-account-confirm.component.mjs +14 -8
- package/esm2022/login/pages/delete-credential/delete-credential.component.mjs +12 -11
- package/esm2022/login/pages/error/error.component.mjs +16 -10
- package/esm2022/login/pages/frontchannel-logout/frontchannel-logout.component.mjs +14 -12
- package/esm2022/login/pages/idp-review-user-profile/idp-review-user-profile.component.mjs +14 -13
- package/esm2022/login/pages/info/info.component.mjs +13 -12
- package/esm2022/login/pages/login/login.component.mjs +15 -14
- package/esm2022/login/pages/login-config-totp/login-config-totp.component.mjs +14 -13
- package/esm2022/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.mjs +13 -16
- package/esm2022/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.mjs +13 -16
- package/esm2022/login/pages/login-idp-link-email/login-idp-link-email.component.mjs +12 -15
- package/esm2022/login/pages/login-oauth-grant/login-oauth-grant.component.mjs +13 -15
- package/esm2022/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.mjs +12 -11
- package/esm2022/login/pages/login-otp/login-otp.component.mjs +13 -12
- package/esm2022/login/pages/login-page-expired/login-page-expired.component.mjs +12 -11
- package/esm2022/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.mjs +13 -8
- package/esm2022/login/pages/login-password/login-password.component.mjs +15 -13
- package/esm2022/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.mjs +14 -13
- package/esm2022/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.mjs +14 -13
- package/esm2022/login/pages/login-reset-otp/login-reset-otp.component.mjs +13 -12
- package/esm2022/login/pages/login-reset-password/login-reset-password.component.mjs +13 -12
- package/esm2022/login/pages/login-update-password/login-update-password.component.mjs +13 -12
- package/esm2022/login/pages/login-update-profile/login-update-profile.component.mjs +13 -12
- package/esm2022/login/pages/login-username/login-username.component.mjs +14 -13
- package/esm2022/login/pages/login-verify-email/login-verify-email.component.mjs +12 -11
- package/esm2022/login/pages/login-x509-info/login-x509-info.component.mjs +12 -11
- package/esm2022/login/pages/logout-confirm/logout-confirm.component.mjs +12 -15
- package/esm2022/login/pages/register/register.component.mjs +16 -15
- package/esm2022/login/pages/saml-post-form/saml-post-form.component.mjs +16 -17
- package/esm2022/login/pages/select-authenticator/select-authenticator.component.mjs +13 -12
- package/esm2022/login/pages/terms/terms.component.mjs +12 -11
- package/esm2022/login/pages/update-email/update-email.component.mjs +14 -17
- package/esm2022/login/pages/webauthn-authenticate/webauthn-authenticate.component.mjs +12 -11
- package/esm2022/login/pages/webauthn-error/webauthn-error.component.mjs +13 -12
- package/esm2022/login/pages/webauthn-register/webauthn-register.component.mjs +12 -11
- package/esm2022/login/providers/keycloakify-angular/keycloakify-angular.providers.mjs +2 -1
- package/esm2022/login/services/i18n/i18n.service.mjs +3 -3
- package/esm2022/login/services/login-resource-injector/login-resource-injector.service.mjs +3 -3
- package/esm2022/login/services/submit/submit.service.mjs +4 -4
- package/esm2022/login/services/user-profile-form/user-profile-form.service.mjs +3 -3
- package/fesm2022/keycloakify-angular-account-containers-template.mjs +42 -9
- package/fesm2022/keycloakify-angular-account-containers-template.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-account-directives-kc-class.mjs +3 -3
- package/fesm2022/keycloakify-angular-account-pages-account.mjs +7 -6
- package/fesm2022/keycloakify-angular-account-pages-account.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-account-pages-applications.mjs +7 -6
- package/fesm2022/keycloakify-angular-account-pages-applications.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-account-pages-federatedIdentity.mjs +7 -6
- package/fesm2022/keycloakify-angular-account-pages-federatedIdentity.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-account-pages-log.mjs +7 -6
- package/fesm2022/keycloakify-angular-account-pages-log.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-account-pages-password.mjs +8 -6
- package/fesm2022/keycloakify-angular-account-pages-password.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-account-pages-sessions.mjs +7 -6
- package/fesm2022/keycloakify-angular-account-pages-sessions.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-account-pages-totp.mjs +7 -6
- package/fesm2022/keycloakify-angular-account-pages-totp.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-account-providers-keycloakify-angular.mjs +1 -0
- package/fesm2022/keycloakify-angular-account-providers-keycloakify-angular.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-account-services-account-resource-injector.mjs +3 -3
- package/fesm2022/keycloakify-angular-account-services-i18n.mjs +3 -3
- package/fesm2022/keycloakify-angular-lib-directives-attributes.mjs +3 -3
- package/fesm2022/keycloakify-angular-lib-pipes-input-type.mjs +3 -3
- package/fesm2022/keycloakify-angular-lib-pipes-is-array-with-empty-object.mjs +3 -3
- package/fesm2022/keycloakify-angular-lib-pipes-kc-sanitize.mjs +3 -3
- package/fesm2022/keycloakify-angular-lib-pipes-to-array.mjs +3 -3
- package/fesm2022/keycloakify-angular-lib-pipes-to-number.mjs +3 -3
- package/fesm2022/keycloakify-angular-lib-services-resource-injector.mjs +3 -3
- package/fesm2022/keycloakify-angular-login-components-add-remove-buttons-multi-valued-attribute.mjs +4 -4
- package/fesm2022/keycloakify-angular-login-components-add-remove-buttons-multi-valued-attribute.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-components-field-errors.mjs +5 -5
- package/fesm2022/keycloakify-angular-login-components-field-errors.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-components-group-label.mjs +3 -3
- package/fesm2022/keycloakify-angular-login-components-input-field-by-type.mjs +5 -5
- package/fesm2022/keycloakify-angular-login-components-input-field-by-type.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-components-input-tag-selects.mjs +3 -3
- package/fesm2022/keycloakify-angular-login-components-input-tag.mjs +5 -5
- package/fesm2022/keycloakify-angular-login-components-input-tag.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-components-logout-other-sessions.mjs +3 -3
- package/fesm2022/keycloakify-angular-login-components-password-wrapper.mjs +5 -5
- package/fesm2022/keycloakify-angular-login-components-password-wrapper.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-components-select-tag.mjs +3 -3
- package/fesm2022/keycloakify-angular-login-components-textarea-tag.mjs +3 -3
- package/fesm2022/keycloakify-angular-login-components-user-profile-form-fields.mjs +5 -5
- package/fesm2022/keycloakify-angular-login-components-user-profile-form-fields.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-containers-template.mjs +83 -15
- package/fesm2022/keycloakify-angular-login-containers-template.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-directives-kc-class.mjs +4 -4
- package/fesm2022/keycloakify-angular-login-directives-kc-class.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-code.mjs +15 -9
- package/fesm2022/keycloakify-angular-login-pages-code.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-delete-account-confirm.mjs +13 -7
- package/fesm2022/keycloakify-angular-login-pages-delete-account-confirm.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-delete-credential.mjs +11 -10
- package/fesm2022/keycloakify-angular-login-pages-delete-credential.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-error.mjs +15 -9
- package/fesm2022/keycloakify-angular-login-pages-error.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-frontchannel-logout.mjs +13 -11
- package/fesm2022/keycloakify-angular-login-pages-frontchannel-logout.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-idp-review-user-profile.mjs +13 -12
- package/fesm2022/keycloakify-angular-login-pages-idp-review-user-profile.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-info.mjs +12 -11
- package/fesm2022/keycloakify-angular-login-pages-info.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-config-totp.mjs +13 -12
- package/fesm2022/keycloakify-angular-login-pages-login-config-totp.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm-override.mjs +12 -15
- package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm-override.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm.mjs +12 -15
- package/fesm2022/keycloakify-angular-login-pages-login-idp-link-confirm.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-idp-link-email.mjs +11 -14
- package/fesm2022/keycloakify-angular-login-pages-login-idp-link-email.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-oauth-grant.mjs +12 -14
- package/fesm2022/keycloakify-angular-login-pages-login-oauth-grant.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-oauth2-device-verify-user-code.mjs +11 -10
- package/fesm2022/keycloakify-angular-login-pages-login-oauth2-device-verify-user-code.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-otp.mjs +12 -11
- package/fesm2022/keycloakify-angular-login-pages-login-otp.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-page-expired.mjs +11 -10
- package/fesm2022/keycloakify-angular-login-pages-login-page-expired.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-passkeys-conditional-authenticate.mjs +12 -7
- package/fesm2022/keycloakify-angular-login-pages-login-passkeys-conditional-authenticate.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-password.mjs +14 -12
- package/fesm2022/keycloakify-angular-login-pages-login-password.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-config.mjs +13 -12
- package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-config.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-input.mjs +13 -12
- package/fesm2022/keycloakify-angular-login-pages-login-recovery-authn-code-input.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-reset-otp.mjs +12 -11
- package/fesm2022/keycloakify-angular-login-pages-login-reset-otp.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-reset-password.mjs +12 -11
- package/fesm2022/keycloakify-angular-login-pages-login-reset-password.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-update-password.mjs +12 -11
- package/fesm2022/keycloakify-angular-login-pages-login-update-password.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-update-profile.mjs +12 -11
- package/fesm2022/keycloakify-angular-login-pages-login-update-profile.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-username.mjs +13 -12
- package/fesm2022/keycloakify-angular-login-pages-login-username.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-verify-email.mjs +11 -10
- package/fesm2022/keycloakify-angular-login-pages-login-verify-email.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login-x509-info.mjs +11 -10
- package/fesm2022/keycloakify-angular-login-pages-login-x509-info.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-login.mjs +14 -13
- package/fesm2022/keycloakify-angular-login-pages-login.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-logout-confirm.mjs +11 -14
- package/fesm2022/keycloakify-angular-login-pages-logout-confirm.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-register.mjs +15 -14
- package/fesm2022/keycloakify-angular-login-pages-register.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-saml-post-form.mjs +15 -16
- package/fesm2022/keycloakify-angular-login-pages-saml-post-form.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-select-authenticator.mjs +12 -11
- package/fesm2022/keycloakify-angular-login-pages-select-authenticator.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-terms.mjs +11 -10
- package/fesm2022/keycloakify-angular-login-pages-terms.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-update-email.mjs +13 -16
- package/fesm2022/keycloakify-angular-login-pages-update-email.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-webauthn-authenticate.mjs +11 -10
- package/fesm2022/keycloakify-angular-login-pages-webauthn-authenticate.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-webauthn-error.mjs +12 -11
- package/fesm2022/keycloakify-angular-login-pages-webauthn-error.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-pages-webauthn-register.mjs +11 -10
- package/fesm2022/keycloakify-angular-login-pages-webauthn-register.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-providers-keycloakify-angular.mjs +1 -0
- package/fesm2022/keycloakify-angular-login-providers-keycloakify-angular.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-services-i18n.mjs +3 -3
- package/fesm2022/keycloakify-angular-login-services-login-resource-injector.mjs +3 -3
- package/fesm2022/keycloakify-angular-login-services-submit.mjs +3 -3
- package/fesm2022/keycloakify-angular-login-services-submit.mjs.map +1 -1
- package/fesm2022/keycloakify-angular-login-services-user-profile-form.mjs +3 -3
- package/login/containers/template/template.component.d.ts +25 -9
- package/login/directives/kc-class/kc-class.directive.d.ts +1 -1
- package/login/pages/code/code.component.d.ts +12 -3
- package/login/pages/delete-account-confirm/delete-account-confirm.component.d.ts +11 -2
- package/login/pages/delete-credential/delete-credential.component.d.ts +9 -5
- package/login/pages/error/error.component.d.ts +11 -2
- package/login/pages/frontchannel-logout/frontchannel-logout.component.d.ts +9 -5
- package/login/pages/idp-review-user-profile/idp-review-user-profile.component.d.ts +10 -7
- package/login/pages/info/info.component.d.ts +9 -5
- package/login/pages/login/login.component.d.ts +10 -6
- package/login/pages/login-config-totp/login-config-totp.component.d.ts +9 -5
- package/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.d.ts +8 -7
- package/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.d.ts +8 -7
- package/login/pages/login-idp-link-email/login-idp-link-email.component.d.ts +8 -7
- package/login/pages/login-oauth-grant/login-oauth-grant.component.d.ts +8 -7
- package/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.d.ts +9 -5
- package/login/pages/login-otp/login-otp.component.d.ts +9 -5
- package/login/pages/login-page-expired/login-page-expired.component.d.ts +9 -5
- package/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.d.ts +11 -3
- package/login/pages/login-password/login-password.component.d.ts +10 -5
- package/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.d.ts +9 -5
- package/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.d.ts +9 -5
- package/login/pages/login-reset-otp/login-reset-otp.component.d.ts +9 -5
- package/login/pages/login-reset-password/login-reset-password.component.d.ts +9 -5
- package/login/pages/login-update-password/login-update-password.component.d.ts +9 -5
- package/login/pages/login-update-profile/login-update-profile.component.d.ts +9 -6
- package/login/pages/login-username/login-username.component.d.ts +10 -6
- package/login/pages/login-verify-email/login-verify-email.component.d.ts +9 -5
- package/login/pages/login-x509-info/login-x509-info.component.d.ts +9 -5
- package/login/pages/logout-confirm/logout-confirm.component.d.ts +8 -7
- package/login/pages/register/register.component.d.ts +11 -8
- package/login/pages/saml-post-form/saml-post-form.component.d.ts +10 -7
- package/login/pages/select-authenticator/select-authenticator.component.d.ts +9 -5
- package/login/pages/terms/terms.component.d.ts +9 -5
- package/login/pages/update-email/update-email.component.d.ts +9 -9
- package/login/pages/webauthn-authenticate/webauthn-authenticate.component.d.ts +10 -6
- package/login/pages/webauthn-error/webauthn-error.component.d.ts +9 -5
- package/login/pages/webauthn-register/webauthn-register.component.d.ts +10 -6
- package/package.json +8 -8
- package/src/account/containers/template/template.component.html +16 -11
- package/src/account/containers/template/template.component.ts +54 -7
- package/src/account/pages/account/account.component.html +139 -143
- package/src/account/pages/account/account.component.ts +4 -3
- package/src/account/pages/applications/applications.component.html +128 -136
- package/src/account/pages/applications/applications.component.ts +4 -3
- package/src/account/pages/federatedIdentity/federatedIdentity.component.html +84 -88
- package/src/account/pages/federatedIdentity/federatedIdentity.component.ts +4 -3
- package/src/account/pages/log/log.component.html +35 -39
- package/src/account/pages/log/log.component.ts +4 -3
- package/src/account/pages/password/password.component.html +109 -113
- package/src/account/pages/password/password.component.ts +6 -3
- package/src/account/pages/sessions/sessions.component.html +52 -56
- package/src/account/pages/sessions/sessions.component.ts +4 -3
- package/src/account/pages/totp/totp.component.html +234 -238
- package/src/account/pages/totp/totp.component.ts +4 -3
- package/src/account/providers/keycloakify-angular/keycloakify-angular.providers.ts +1 -0
- package/src/login/components/add-remove-buttons-multi-valued-attribute/add-remove-buttons-multi-valued-attribute.component.html +2 -2
- package/src/login/components/field-errors/field-errors.component.html +1 -1
- package/src/login/components/input-field-by-type/input-field-by-type.component.html +6 -6
- package/src/login/components/input-tag/input-tag.component.html +2 -2
- package/src/login/components/password-wrapper/password-wrapper.component.html +2 -2
- package/src/login/components/user-profile-form-fields/user-profile-form-fields.component.html +7 -11
- package/src/login/containers/template/template.component.html +29 -15
- package/src/login/containers/template/template.component.ts +100 -12
- package/src/login/directives/kc-class/kc-class.directive.ts +1 -2
- package/src/login/pages/code/code.component.html +19 -23
- package/src/login/pages/code/code.component.ts +18 -6
- package/src/login/pages/delete-account-confirm/delete-account-confirm.component.html +41 -45
- package/src/login/pages/delete-account-confirm/delete-account-confirm.component.ts +16 -4
- package/src/login/pages/delete-credential/delete-credential.component.html +29 -31
- package/src/login/pages/delete-credential/delete-credential.component.ts +16 -9
- package/src/login/pages/error/error.component.html +20 -22
- package/src/login/pages/error/error.component.ts +17 -5
- package/src/login/pages/frontchannel-logout/frontchannel-logout.component.html +25 -34
- package/src/login/pages/frontchannel-logout/frontchannel-logout.component.ts +17 -9
- package/src/login/pages/idp-review-user-profile/idp-review-user-profile.component.html +29 -38
- package/src/login/pages/idp-review-user-profile/idp-review-user-profile.component.ts +18 -12
- package/src/login/pages/info/info.component.html +39 -48
- package/src/login/pages/info/info.component.ts +17 -10
- package/src/login/pages/login/login.component.html +184 -194
- package/src/login/pages/login/login.component.ts +20 -12
- package/src/login/pages/login-config-totp/login-config-totp.component.html +181 -190
- package/src/login/pages/login-config-totp/login-config-totp.component.ts +16 -10
- package/src/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.html +27 -37
- package/src/login/pages/login-idp-link-confirm/login-idp-link-confirm.component.ts +15 -14
- package/src/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.html +26 -36
- package/src/login/pages/login-idp-link-confirm-override/login-idp-link-confirm-override.component.ts +15 -14
- package/src/login/pages/login-idp-link-email/login-idp-link-email.component.html +24 -34
- package/src/login/pages/login-idp-link-email/login-idp-link-email.component.ts +15 -14
- package/src/login/pages/login-oauth-grant/login-oauth-grant.component.html +75 -84
- package/src/login/pages/login-oauth-grant/login-oauth-grant.component.ts +15 -14
- package/src/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.html +49 -58
- package/src/login/pages/login-oauth2-device-verify-user-code/login-oauth2-device-verify-user-code.component.ts +15 -9
- package/src/login/pages/login-otp/login-otp.component.html +89 -98
- package/src/login/pages/login-otp/login-otp.component.ts +16 -9
- package/src/login/pages/login-page-expired/login-page-expired.component.html +26 -33
- package/src/login/pages/login-page-expired/login-page-expired.component.ts +15 -9
- package/src/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.html +181 -188
- package/src/login/pages/login-passkeys-conditional-authenticate/login-passkeys-conditional-authenticate.component.ts +15 -5
- package/src/login/pages/login-password/login-password.component.html +73 -80
- package/src/login/pages/login-password/login-password.component.ts +17 -9
- package/src/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.html +136 -145
- package/src/login/pages/login-recovery-authn-code-config/login-recovery-authn-code-config.component.ts +17 -9
- package/src/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.html +60 -68
- package/src/login/pages/login-recovery-authn-code-input/login-recovery-authn-code-input.component.ts +16 -9
- package/src/login/pages/login-reset-otp/login-reset-otp.component.html +53 -60
- package/src/login/pages/login-reset-otp/login-reset-otp.component.ts +15 -8
- package/src/login/pages/login-reset-password/login-reset-password.component.html +77 -86
- package/src/login/pages/login-reset-password/login-reset-password.component.ts +16 -9
- package/src/login/pages/login-update-password/login-update-password.component.html +98 -108
- package/src/login/pages/login-update-password/login-update-password.component.ts +15 -8
- package/src/login/pages/login-update-profile/login-update-profile.component.html +44 -53
- package/src/login/pages/login-update-profile/login-update-profile.component.ts +17 -10
- package/src/login/pages/login-username/login-username.component.html +138 -148
- package/src/login/pages/login-username/login-username.component.ts +16 -9
- package/src/login/pages/login-verify-email/login-verify-email.component.html +17 -25
- package/src/login/pages/login-verify-email/login-verify-email.component.ts +15 -9
- package/src/login/pages/login-x509-info/login-x509-info.component.html +85 -94
- package/src/login/pages/login-x509-info/login-x509-info.component.ts +15 -9
- package/src/login/pages/logout-confirm/logout-confirm.component.html +39 -49
- package/src/login/pages/logout-confirm/logout-confirm.component.ts +15 -14
- package/src/login/pages/register/register.component.html +100 -110
- package/src/login/pages/register/register.component.ts +19 -12
- package/src/login/pages/saml-post-form/saml-post-form.component.html +39 -48
- package/src/login/pages/saml-post-form/saml-post-form.component.ts +19 -13
- package/src/login/pages/select-authenticator/select-authenticator.component.html +36 -44
- package/src/login/pages/select-authenticator/select-authenticator.component.ts +16 -9
- package/src/login/pages/terms/terms.component.html +25 -34
- package/src/login/pages/terms/terms.component.ts +16 -9
- package/src/login/pages/update-email/update-email.component.html +44 -53
- package/src/login/pages/update-email/update-email.component.ts +16 -15
- package/src/login/pages/webauthn-authenticate/webauthn-authenticate.component.html +134 -145
- package/src/login/pages/webauthn-authenticate/webauthn-authenticate.component.ts +16 -9
- package/src/login/pages/webauthn-error/webauthn-error.component.html +45 -55
- package/src/login/pages/webauthn-error/webauthn-error.component.ts +16 -9
- package/src/login/pages/webauthn-register/webauthn-register.component.html +65 -75
- package/src/login/pages/webauthn-register/webauthn-register.component.ts +16 -9
- package/src/login/providers/keycloakify-angular/keycloakify-angular.providers.ts +1 -0
- package/src/login/services/submit/submit.service.ts +1 -1
- package/src/tsconfig.lib.json +0 -12
- package/src/tsconfig.lib.prod.json +0 -10
package/src/login/components/user-profile-form-fields/user-profile-form-fields.component.html
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
@let formFieldStates = formState().formFieldStates;
|
|
2
2
|
|
|
3
3
|
@for (fieldState of formFieldStates; track fieldState.attribute) {
|
|
4
|
-
<kc-group-label [attribute]="fieldState.attribute"
|
|
4
|
+
<kc-group-label [attribute]="fieldState.attribute" />
|
|
5
5
|
|
|
6
6
|
@if (beforeField) {
|
|
7
7
|
<ng-container
|
|
@@ -11,8 +11,7 @@
|
|
|
11
11
|
valueOrValues: fieldState.valueOrValues,
|
|
12
12
|
displayableErrors: fieldState.displayableErrors
|
|
13
13
|
}"
|
|
14
|
-
|
|
15
|
-
</ng-container>
|
|
14
|
+
/>
|
|
16
15
|
}
|
|
17
16
|
|
|
18
17
|
<div
|
|
@@ -34,9 +33,9 @@
|
|
|
34
33
|
<div [kcClass]="'kcInputWrapperClass'">
|
|
35
34
|
@if (fieldState.attribute.annotations.inputHelperTextBefore) {
|
|
36
35
|
<div
|
|
36
|
+
aria-live="polite"
|
|
37
37
|
[kcClass]="'kcInputHelperTextBeforeClass'"
|
|
38
38
|
[id]="'form-help-text-before-' + fieldState.attribute.name"
|
|
39
|
-
aria-live="polite"
|
|
40
39
|
>
|
|
41
40
|
{{ i18n.advancedMsgStr(fieldState.attribute.annotations.inputHelperTextBefore) }}
|
|
42
41
|
</div>
|
|
@@ -47,19 +46,17 @@
|
|
|
47
46
|
[valueOrValues]="fieldState.valueOrValues"
|
|
48
47
|
[displayableErrors]="fieldState.displayableErrors"
|
|
49
48
|
(dispatchFormAction)="onDispatch($event)"
|
|
50
|
-
|
|
51
|
-
</kc-input-field-by-type>
|
|
49
|
+
/>
|
|
52
50
|
|
|
53
51
|
<kc-field-errors
|
|
54
52
|
[attribute]="fieldState.attribute"
|
|
55
53
|
[displayableErrors]="fieldState.displayableErrors"
|
|
56
|
-
|
|
57
|
-
</kc-field-errors>
|
|
54
|
+
/>
|
|
58
55
|
@if (fieldState.attribute.annotations.inputHelperTextAfter) {
|
|
59
56
|
<div
|
|
57
|
+
aria-live="polite"
|
|
60
58
|
[kcClass]="'kcInputHelperTextAfterClass'"
|
|
61
59
|
[id]="'form-help-text-after-' + fieldState.attribute.name"
|
|
62
|
-
aria-live="polite"
|
|
63
60
|
>
|
|
64
61
|
{{ i18n.advancedMsgStr(fieldState.attribute.annotations.inputHelperTextAfter) }}
|
|
65
62
|
</div>
|
|
@@ -73,8 +70,7 @@
|
|
|
73
70
|
valueOrValues: fieldState.valueOrValues,
|
|
74
71
|
displayableErrors: fieldState.displayableErrors
|
|
75
72
|
}"
|
|
76
|
-
|
|
77
|
-
</ng-container>
|
|
73
|
+
/>
|
|
78
74
|
}
|
|
79
75
|
<!-- NOTE: Downloading of html5DataAnnotations scripts is done in the useUserProfileForm hook -->
|
|
80
76
|
</div>
|
|
@@ -33,16 +33,16 @@
|
|
|
33
33
|
>
|
|
34
34
|
<div
|
|
35
35
|
id="kc-locale-dropdown"
|
|
36
|
-
[kcClass]="'kcLocaleDropDownClass'"
|
|
37
36
|
class="menu-button-links"
|
|
37
|
+
[kcClass]="'kcLocaleDropDownClass'"
|
|
38
38
|
>
|
|
39
39
|
<button
|
|
40
40
|
tabindex="1"
|
|
41
41
|
id="kc-current-locale-link"
|
|
42
|
-
[attr.aria-label]="i18n.msgStr('languages')"
|
|
43
42
|
aria-haspopup="true"
|
|
44
43
|
aria-expanded="false"
|
|
45
44
|
aria-controls="language-switch1"
|
|
45
|
+
[attr.aria-label]="i18n.msgStr('languages')"
|
|
46
46
|
>
|
|
47
47
|
{{ i18n.currentLanguage.label }}
|
|
48
48
|
</button>
|
|
@@ -56,8 +56,8 @@
|
|
|
56
56
|
>
|
|
57
57
|
@for (entry of i18n.enabledLanguages; track entry; let idx = $index) {
|
|
58
58
|
<li
|
|
59
|
-
[kcClass]="'kcLocaleListItemClass'"
|
|
60
59
|
role="none"
|
|
60
|
+
[kcClass]="'kcLocaleListItemClass'"
|
|
61
61
|
>
|
|
62
62
|
<a
|
|
63
63
|
role="menuitem"
|
|
@@ -80,7 +80,10 @@
|
|
|
80
80
|
<ng-template #node>
|
|
81
81
|
@if (auth && !auth.showUsername && !auth.showResetCredentials) {
|
|
82
82
|
<h1 id="kc-page-title">
|
|
83
|
-
|
|
83
|
+
@let header = headerNode && headerNode();
|
|
84
|
+
@if (header) {
|
|
85
|
+
<ng-container [ngTemplateOutlet]="header" />
|
|
86
|
+
}
|
|
84
87
|
</h1>
|
|
85
88
|
} @else {
|
|
86
89
|
<div
|
|
@@ -104,11 +107,11 @@
|
|
|
104
107
|
}
|
|
105
108
|
</ng-template>
|
|
106
109
|
|
|
107
|
-
@if (displayRequiredFields
|
|
110
|
+
@if (displayRequiredFields) {
|
|
108
111
|
<div [kcClass]="'kcContentWrapperClass'">
|
|
109
112
|
<div
|
|
110
|
-
[kcClass]="'kcLabelWrapperClass'"
|
|
111
113
|
class="subtitle"
|
|
114
|
+
[kcClass]="'kcLabelWrapperClass'"
|
|
112
115
|
>
|
|
113
116
|
<span class="subtitle">
|
|
114
117
|
<span class="required">*</span>
|
|
@@ -116,18 +119,18 @@
|
|
|
116
119
|
</span>
|
|
117
120
|
</div>
|
|
118
121
|
<div class="col-md-10">
|
|
119
|
-
<ng-container [ngTemplateOutlet]="node"
|
|
122
|
+
<ng-container [ngTemplateOutlet]="node" />
|
|
120
123
|
</div>
|
|
121
124
|
</div>
|
|
122
125
|
} @else {
|
|
123
|
-
<ng-container [ngTemplateOutlet]="node"
|
|
126
|
+
<ng-container [ngTemplateOutlet]="node" />
|
|
124
127
|
}
|
|
125
128
|
</header>
|
|
126
129
|
|
|
127
130
|
<div id="kc-content">
|
|
128
131
|
<div id="kc-content-wrapper">
|
|
129
132
|
<!-- Message display -->
|
|
130
|
-
@if (displayMessage
|
|
133
|
+
@if (displayMessage && message && (message.type !== 'warning' || !isAppInitiatedAction)) {
|
|
131
134
|
<div
|
|
132
135
|
[kcClass]="'kcAlertClass'"
|
|
133
136
|
[ngClass]="message.type === 'error' ? 'pf-m-danger' : 'pf-m-' + message.type"
|
|
@@ -156,12 +159,18 @@
|
|
|
156
159
|
</div>
|
|
157
160
|
}
|
|
158
161
|
<!-- Content -->
|
|
159
|
-
|
|
162
|
+
@let pageRef = page();
|
|
163
|
+
@if (!!pageRef) {
|
|
164
|
+
<kc-dynamic-page-injector
|
|
165
|
+
[page]="pageRef"
|
|
166
|
+
(componentCreated)="onComponentCreated($event)"
|
|
167
|
+
/>
|
|
168
|
+
}
|
|
160
169
|
@if (!!auth && auth?.showTryAnotherWayLink) {
|
|
161
170
|
<form
|
|
162
171
|
id="kc-select-try-another-way-form"
|
|
163
|
-
[action]="url?.loginAction"
|
|
164
172
|
method="post"
|
|
173
|
+
[action]="url?.loginAction"
|
|
165
174
|
>
|
|
166
175
|
<div [kcClass]="'kcFormGroupClass'">
|
|
167
176
|
<div [kcClass]="'kcFormGroupClass'">
|
|
@@ -180,10 +189,12 @@
|
|
|
180
189
|
</div>
|
|
181
190
|
</form>
|
|
182
191
|
}
|
|
183
|
-
|
|
184
|
-
|
|
192
|
+
@let socialProviders = socialProvidersNode && socialProvidersNode();
|
|
193
|
+
@if (socialProviders) {
|
|
194
|
+
<ng-container [ngTemplateOutlet]="socialProviders" />
|
|
195
|
+
}
|
|
185
196
|
<!-- Info display -->
|
|
186
|
-
@if (displayInfo
|
|
197
|
+
@if (displayInfo) {
|
|
187
198
|
<div
|
|
188
199
|
id="kc-info"
|
|
189
200
|
[kcClass]="'kcSignUpClass'"
|
|
@@ -192,7 +203,10 @@
|
|
|
192
203
|
id="kc-info-wrapper"
|
|
193
204
|
[kcClass]="'kcInfoAreaWrapperClass'"
|
|
194
205
|
>
|
|
195
|
-
|
|
206
|
+
@let info = infoNode && infoNode();
|
|
207
|
+
@if (info) {
|
|
208
|
+
<ng-container [ngTemplateOutlet]="info" />
|
|
209
|
+
}
|
|
196
210
|
</div>
|
|
197
211
|
</div>
|
|
198
212
|
}
|
|
@@ -1,24 +1,67 @@
|
|
|
1
1
|
import { AsyncPipe, NgTemplateOutlet } from '@angular/common';
|
|
2
|
-
import {
|
|
2
|
+
import {
|
|
3
|
+
ChangeDetectionStrategy,
|
|
4
|
+
ChangeDetectorRef,
|
|
5
|
+
Component,
|
|
6
|
+
computed,
|
|
7
|
+
effect,
|
|
8
|
+
forwardRef,
|
|
9
|
+
inject,
|
|
10
|
+
input,
|
|
11
|
+
OnInit,
|
|
12
|
+
output,
|
|
13
|
+
Renderer2,
|
|
14
|
+
Signal,
|
|
15
|
+
TemplateRef,
|
|
16
|
+
Type,
|
|
17
|
+
ViewContainerRef
|
|
18
|
+
} from '@angular/core';
|
|
3
19
|
import { Meta, Title } from '@angular/platform-browser';
|
|
4
20
|
import { KcSanitizePipe } from '@keycloakify/angular/lib/pipes/kc-sanitize';
|
|
5
21
|
import { USE_DEFAULT_CSS } from '@keycloakify/angular/lib/tokens/use-default-css';
|
|
6
22
|
import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
|
|
7
23
|
import { KcClassDirective } from '@keycloakify/angular/login/directives/kc-class';
|
|
24
|
+
import type { I18n } from '../../i18n';
|
|
25
|
+
import { KcContext } from '../../KcContext';
|
|
8
26
|
import { LoginResourceInjectorService } from '@keycloakify/angular/login/services/login-resource-injector';
|
|
9
27
|
import { LOGIN_CLASSES } from '@keycloakify/angular/login/tokens/classes';
|
|
10
28
|
import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
|
|
11
29
|
import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
|
|
12
30
|
import { type ClassKey, getKcClsx } from 'keycloakify/login/lib/kcClsx';
|
|
13
31
|
import { Observable } from 'rxjs';
|
|
14
|
-
import type { I18n } from '../../i18n';
|
|
15
|
-
import { KcContext } from '../../KcContext';
|
|
16
32
|
|
|
17
33
|
@Component({
|
|
18
|
-
selector: 'kc-
|
|
34
|
+
selector: 'kc-dynamic-page-injector',
|
|
35
|
+
standalone: true,
|
|
36
|
+
template: ``
|
|
37
|
+
})
|
|
38
|
+
export class DynamicPageInjectorComponent {
|
|
39
|
+
page = input<Type<unknown>>();
|
|
40
|
+
userProfileFormFields = input<Type<unknown>>();
|
|
41
|
+
componentCreated = output<object>();
|
|
42
|
+
#vcr = inject<ViewContainerRef>(ViewContainerRef);
|
|
43
|
+
constructor() {
|
|
44
|
+
effect(
|
|
45
|
+
() => {
|
|
46
|
+
const page = this.page();
|
|
47
|
+
const userProfileFormFields = this.userProfileFormFields();
|
|
48
|
+
if (!page) return;
|
|
49
|
+
const compRef = this.#vcr.createComponent(page);
|
|
50
|
+
if ('userProfileFormFields' in compRef && userProfileFormFields) {
|
|
51
|
+
compRef.setInput('userProfileFormFields', userProfileFormFields);
|
|
52
|
+
}
|
|
53
|
+
this.componentCreated.emit(compRef.instance as object);
|
|
54
|
+
},
|
|
55
|
+
{ allowSignalWrites: true }
|
|
56
|
+
);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
@Component({
|
|
61
|
+
selector: 'kc-root',
|
|
19
62
|
templateUrl: './template.component.html',
|
|
20
63
|
standalone: true,
|
|
21
|
-
imports: [AsyncPipe, KcSanitizePipe, NgTemplateOutlet, KcClassDirective],
|
|
64
|
+
imports: [AsyncPipe, KcSanitizePipe, NgTemplateOutlet, KcClassDirective, DynamicPageInjectorComponent],
|
|
22
65
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
23
66
|
providers: [
|
|
24
67
|
{
|
|
@@ -30,6 +73,7 @@ import { KcContext } from '../../KcContext';
|
|
|
30
73
|
export class TemplateComponent extends ComponentReference implements OnInit {
|
|
31
74
|
i18n = inject<I18n>(LOGIN_I18N);
|
|
32
75
|
renderer = inject(Renderer2);
|
|
76
|
+
#cdr = inject(ChangeDetectorRef);
|
|
33
77
|
meta = inject(Meta);
|
|
34
78
|
title = inject(Title);
|
|
35
79
|
kcContext = inject<KcContext>(KC_LOGIN_CONTEXT);
|
|
@@ -37,17 +81,24 @@ export class TemplateComponent extends ComponentReference implements OnInit {
|
|
|
37
81
|
override classes = inject<Partial<Record<ClassKey, string>>>(LOGIN_CLASSES);
|
|
38
82
|
loginResourceInjectorService = inject(LoginResourceInjectorService);
|
|
39
83
|
|
|
40
|
-
displayInfo =
|
|
41
|
-
displayMessage =
|
|
42
|
-
displayRequiredFields =
|
|
43
|
-
documentTitle
|
|
44
|
-
bodyClassName
|
|
84
|
+
displayInfo = false;
|
|
85
|
+
displayMessage = true;
|
|
86
|
+
displayRequiredFields = false;
|
|
87
|
+
documentTitle: string | undefined;
|
|
88
|
+
bodyClassName: string | undefined;
|
|
45
89
|
|
|
46
90
|
isReadyToRender$: Observable<boolean>;
|
|
47
91
|
|
|
92
|
+
page = input<Type<unknown>>();
|
|
93
|
+
userProfileFormFields = input<Type<unknown>>();
|
|
94
|
+
headerNode: Signal<TemplateRef<HTMLElement>> | undefined;
|
|
95
|
+
infoNode: Signal<TemplateRef<HTMLElement>> | undefined;
|
|
96
|
+
socialProvidersNode: Signal<TemplateRef<HTMLElement>> | undefined;
|
|
97
|
+
|
|
48
98
|
constructor() {
|
|
49
99
|
super();
|
|
50
|
-
|
|
100
|
+
|
|
101
|
+
this.title.setTitle(this.documentTitle ?? this.i18n.msgStr('loginTitle', this.kcContext.realm.displayName));
|
|
51
102
|
this.isReadyToRender$ = this.loginResourceInjectorService.injectResource(this.doUseDefaultCss);
|
|
52
103
|
}
|
|
53
104
|
|
|
@@ -60,7 +111,7 @@ export class TemplateComponent extends ComponentReference implements OnInit {
|
|
|
60
111
|
doUseDefaultCss: this.doUseDefaultCss,
|
|
61
112
|
classes: this.classes
|
|
62
113
|
}).kcClsx;
|
|
63
|
-
const kcBodyClass = this.bodyClassName
|
|
114
|
+
const kcBodyClass = this.bodyClassName ?? kcClsx('kcBodyClass');
|
|
64
115
|
const kcHtmlClass = kcClsx('kcHtmlClass');
|
|
65
116
|
const kcBodyClasses = kcBodyClass.split(/\s+/);
|
|
66
117
|
const kcHtmlClasses = kcHtmlClass.split(/\s+/);
|
|
@@ -75,4 +126,41 @@ export class TemplateComponent extends ComponentReference implements OnInit {
|
|
|
75
126
|
tryAnotherWay() {
|
|
76
127
|
document.forms['kc-select-try-another-way-form' as never].submit();
|
|
77
128
|
}
|
|
129
|
+
|
|
130
|
+
onComponentCreated(compRef: object) {
|
|
131
|
+
if ('displayInfo' in compRef && compRef.displayInfo) {
|
|
132
|
+
this.displayInfo = compRef.displayInfo as boolean;
|
|
133
|
+
}
|
|
134
|
+
if ('displayMessage' in compRef && compRef.displayMessage) {
|
|
135
|
+
this.displayMessage = compRef.displayMessage as boolean;
|
|
136
|
+
}
|
|
137
|
+
if ('displayRequiredFields' in compRef && compRef.displayRequiredFields) {
|
|
138
|
+
this.displayRequiredFields = compRef.displayRequiredFields as boolean;
|
|
139
|
+
}
|
|
140
|
+
if ('documentTitle' in compRef && compRef.documentTitle) {
|
|
141
|
+
this.documentTitle = compRef.documentTitle as string;
|
|
142
|
+
}
|
|
143
|
+
if ('bodyClassName' in compRef && compRef.bodyClassName) {
|
|
144
|
+
this.bodyClassName = compRef.bodyClassName as string;
|
|
145
|
+
}
|
|
146
|
+
if ('headerNode' in compRef && compRef.headerNode) {
|
|
147
|
+
this.headerNode = computed(() => {
|
|
148
|
+
const headerNode = (compRef.headerNode as Signal<TemplateRef<HTMLElement>>)();
|
|
149
|
+
return headerNode;
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
if ('infoNode' in compRef && compRef.infoNode) {
|
|
153
|
+
this.infoNode = computed(() => {
|
|
154
|
+
const infoNode = (compRef.infoNode as Signal<TemplateRef<HTMLElement>>)();
|
|
155
|
+
return infoNode;
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
if ('socialProvidersNode' in compRef && compRef.socialProvidersNode) {
|
|
159
|
+
this.socialProvidersNode = computed(() => {
|
|
160
|
+
const socialProvidersNode = (compRef.socialProvidersNode as Signal<TemplateRef<HTMLElement>>)();
|
|
161
|
+
return socialProvidersNode;
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
this.#cdr.markForCheck();
|
|
165
|
+
}
|
|
78
166
|
}
|
|
@@ -10,9 +10,8 @@ import {
|
|
|
10
10
|
Renderer2,
|
|
11
11
|
ɵstringify as stringify
|
|
12
12
|
} from '@angular/core';
|
|
13
|
-
import type { ClassKey } from 'keycloakify/login/lib/kcClsx';
|
|
14
|
-
import { getKcClsx } from 'keycloakify/login/lib/kcClsx';
|
|
15
13
|
import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
|
|
14
|
+
import { type ClassKey, getKcClsx } from 'keycloakify/login/lib/kcClsx';
|
|
16
15
|
|
|
17
16
|
interface CssClassState {
|
|
18
17
|
// PERF: could use a bit mask to represent state as all fields are boolean flags
|
|
@@ -1,26 +1,22 @@
|
|
|
1
1
|
@let code = kcContext.code;
|
|
2
2
|
|
|
3
|
-
<
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
</ng-container>
|
|
3
|
+
<ng-template #headerNode>
|
|
4
|
+
@if (code.success) {
|
|
5
|
+
{{ i18n.msgStr('codeSuccessTitle') }}
|
|
6
|
+
} @else {
|
|
7
|
+
{{ i18n.msgStr('codeErrorTitle', code.error) }}
|
|
8
|
+
}
|
|
9
|
+
</ng-template>
|
|
11
10
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
</div>
|
|
25
|
-
</ng-container>
|
|
26
|
-
</kc-login-template>
|
|
11
|
+
<div id="kc-code">
|
|
12
|
+
@if (code.success) {
|
|
13
|
+
<p>{{ i18n.msgStr('copyCodeInstruction') }}</p>
|
|
14
|
+
<input
|
|
15
|
+
id="code"
|
|
16
|
+
[kcClass]="'kcTextareaClass'"
|
|
17
|
+
[defaultValue]="code.code"
|
|
18
|
+
/>
|
|
19
|
+
} @else {
|
|
20
|
+
<p id="error">{{ code.error }}</p>
|
|
21
|
+
}
|
|
22
|
+
</div>
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, forwardRef, inject } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, forwardRef, inject, TemplateRef, viewChild } from '@angular/core';
|
|
2
2
|
import { USE_DEFAULT_CSS } from '@keycloakify/angular/lib/tokens/use-default-css';
|
|
3
|
-
import { LOGIN_CLASSES } from '@keycloakify/angular/login/tokens/classes';
|
|
4
|
-
import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
|
|
5
3
|
import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
|
|
6
4
|
import { TemplateComponent } from '@keycloakify/angular/login/containers/template';
|
|
7
5
|
import { KcClassDirective } from '@keycloakify/angular/login/directives/kc-class';
|
|
8
|
-
import type {
|
|
6
|
+
import type { I18n } from '../../i18n';
|
|
9
7
|
import type { KcContext } from '../../KcContext';
|
|
8
|
+
import { LOGIN_CLASSES } from '@keycloakify/angular/login/tokens/classes';
|
|
10
9
|
import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
|
|
11
|
-
import
|
|
10
|
+
import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
|
|
11
|
+
import type { ClassKey } from 'keycloakify/login/lib/kcClsx';
|
|
12
12
|
|
|
13
13
|
@Component({
|
|
14
14
|
standalone: true,
|
|
15
15
|
imports: [TemplateComponent, KcClassDirective],
|
|
16
|
-
selector: 'kc-
|
|
16
|
+
selector: 'kc-code',
|
|
17
17
|
templateUrl: 'code.component.html',
|
|
18
18
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
19
19
|
providers: [
|
|
@@ -26,6 +26,18 @@ import type { I18n } from '../../i18n';
|
|
|
26
26
|
export class CodeComponent extends ComponentReference {
|
|
27
27
|
kcContext = inject<Extract<KcContext, { pageId: 'code.ftl' }>>(KC_LOGIN_CONTEXT);
|
|
28
28
|
i18n = inject<I18n>(LOGIN_I18N);
|
|
29
|
+
|
|
29
30
|
override doUseDefaultCss = inject<boolean>(USE_DEFAULT_CSS);
|
|
30
31
|
override classes = inject<Partial<Record<ClassKey, string>>>(LOGIN_CLASSES);
|
|
32
|
+
|
|
33
|
+
documentTitle: string | undefined;
|
|
34
|
+
bodyClassName: string | undefined;
|
|
35
|
+
|
|
36
|
+
displayRequiredFields = false;
|
|
37
|
+
displayInfo = false;
|
|
38
|
+
displayMessage = false;
|
|
39
|
+
|
|
40
|
+
headerNode? = viewChild<TemplateRef<HTMLElement>>('headerNode');
|
|
41
|
+
infoNode? = viewChild<TemplateRef<HTMLElement>>('infoNode');
|
|
42
|
+
socialProvidersNode? = viewChild<TemplateRef<HTMLElement>>('socialProvidersNode');
|
|
31
43
|
}
|
|
@@ -1,48 +1,44 @@
|
|
|
1
1
|
@let url = kcContext.url;
|
|
2
2
|
@let triggered_from_aia = kcContext.triggered_from_aia;
|
|
3
|
-
<
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
3
|
+
<ng-template #headerNode>
|
|
4
|
+
{{ i18n.msgStr('deleteAccountConfirm') }}
|
|
5
|
+
</ng-template>
|
|
6
|
+
<form
|
|
7
|
+
method="post"
|
|
8
|
+
class="form-actions"
|
|
9
|
+
[action]="url.loginAction"
|
|
10
|
+
>
|
|
11
|
+
<div
|
|
12
|
+
class="alert alert-warning"
|
|
13
|
+
style="margin-top: 0; margin-bottom: 30px"
|
|
14
|
+
>
|
|
15
|
+
<span class="pficon pficon-warning-triangle-o"></span>
|
|
16
|
+
{{ i18n.msgStr('irreversibleAction') }}
|
|
17
|
+
</div>
|
|
18
|
+
<p>{{ i18n.msgStr('deletingImplies') }}</p>
|
|
19
|
+
<ul style="color: #72767b; list-style: disc; list-style-position: inside">
|
|
20
|
+
<li>{{ i18n.msgStr('loggingOutImmediately') }}</li>
|
|
21
|
+
<li>{{ i18n.msgStr('errasingData') }}</li>
|
|
22
|
+
</ul>
|
|
23
|
+
<p class="delete-account-text">
|
|
24
|
+
{{ i18n.msgStr('finalDeletionConfirmation') }}
|
|
25
|
+
</p>
|
|
26
|
+
<div id="kc-form-buttons">
|
|
27
|
+
<input
|
|
28
|
+
type="submit"
|
|
29
|
+
[kcClass]="['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass']"
|
|
30
|
+
[value]="i18n.msgStr('doConfirmDelete')"
|
|
31
|
+
/>
|
|
32
|
+
@if (triggered_from_aia) {
|
|
33
|
+
<button
|
|
34
|
+
style="margin-left: calc(100% - 220px)"
|
|
35
|
+
type="submit"
|
|
36
|
+
name="cancel-aia"
|
|
37
|
+
value="true"
|
|
38
|
+
[kcClass]="['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass']"
|
|
16
39
|
>
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
<li>{{ i18n.msgStr('loggingOutImmediately') }}</li>
|
|
23
|
-
<li>{{ i18n.msgStr('errasingData') }}</li>
|
|
24
|
-
</ul>
|
|
25
|
-
<p class="delete-account-text">
|
|
26
|
-
{{ i18n.msgStr('finalDeletionConfirmation') }}
|
|
27
|
-
</p>
|
|
28
|
-
<div id="kc-form-buttons">
|
|
29
|
-
<input
|
|
30
|
-
[kcClass]="['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass']"
|
|
31
|
-
type="submit"
|
|
32
|
-
[value]="i18n.msgStr('doConfirmDelete')"
|
|
33
|
-
/>
|
|
34
|
-
@if (triggered_from_aia) {
|
|
35
|
-
<button
|
|
36
|
-
[kcClass]="['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass']"
|
|
37
|
-
style="margin-left: calc(100% - 220px)"
|
|
38
|
-
type="submit"
|
|
39
|
-
name="cancel-aia"
|
|
40
|
-
value="true"
|
|
41
|
-
>
|
|
42
|
-
{{ i18n.msgStr('doCancel') }}
|
|
43
|
-
</button>
|
|
44
|
-
}
|
|
45
|
-
</div>
|
|
46
|
-
</form>
|
|
47
|
-
</ng-container>
|
|
48
|
-
</kc-login-template>
|
|
40
|
+
{{ i18n.msgStr('doCancel') }}
|
|
41
|
+
</button>
|
|
42
|
+
}
|
|
43
|
+
</div>
|
|
44
|
+
</form>
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, forwardRef, inject } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, forwardRef, inject, TemplateRef, viewChild } from '@angular/core';
|
|
2
2
|
import { USE_DEFAULT_CSS } from '@keycloakify/angular/lib/tokens/use-default-css';
|
|
3
3
|
import { ComponentReference } from '@keycloakify/angular/login/classes/component-reference';
|
|
4
4
|
import { TemplateComponent } from '@keycloakify/angular/login/containers/template';
|
|
5
5
|
import { KcClassDirective } from '@keycloakify/angular/login/directives/kc-class';
|
|
6
|
+
import type { I18n } from '../../i18n';
|
|
7
|
+
import type { KcContext } from '../../KcContext';
|
|
6
8
|
import { LOGIN_CLASSES } from '@keycloakify/angular/login/tokens/classes';
|
|
7
9
|
import { LOGIN_I18N } from '@keycloakify/angular/login/tokens/i18n';
|
|
8
10
|
import { KC_LOGIN_CONTEXT } from '@keycloakify/angular/login/tokens/kc-context';
|
|
9
11
|
import type { ClassKey } from 'keycloakify/login/lib/kcClsx';
|
|
10
|
-
import type { I18n } from '../../i18n';
|
|
11
|
-
import type { KcContext } from '../../KcContext';
|
|
12
12
|
|
|
13
13
|
@Component({
|
|
14
14
|
standalone: true,
|
|
15
15
|
imports: [TemplateComponent, KcClassDirective],
|
|
16
|
-
selector: 'kc-
|
|
16
|
+
selector: 'kc-delete-account-confirm',
|
|
17
17
|
templateUrl: 'delete-account-confirm.component.html',
|
|
18
18
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
19
19
|
providers: [
|
|
@@ -26,6 +26,18 @@ import type { KcContext } from '../../KcContext';
|
|
|
26
26
|
export class DeleteAccountConfirmComponent extends ComponentReference {
|
|
27
27
|
kcContext = inject<Extract<KcContext, { pageId: 'delete-account-confirm.ftl' }>>(KC_LOGIN_CONTEXT);
|
|
28
28
|
i18n = inject<I18n>(LOGIN_I18N);
|
|
29
|
+
|
|
29
30
|
override doUseDefaultCss = inject<boolean>(USE_DEFAULT_CSS);
|
|
30
31
|
override classes = inject<Partial<Record<ClassKey, string>>>(LOGIN_CLASSES);
|
|
32
|
+
|
|
33
|
+
documentTitle: string | undefined;
|
|
34
|
+
bodyClassName: string | undefined;
|
|
35
|
+
|
|
36
|
+
displayRequiredFields = false;
|
|
37
|
+
displayInfo = false;
|
|
38
|
+
displayMessage = false;
|
|
39
|
+
|
|
40
|
+
headerNode? = viewChild<TemplateRef<HTMLElement>>('headerNode');
|
|
41
|
+
infoNode? = viewChild<TemplateRef<HTMLElement>>('infoNode');
|
|
42
|
+
socialProvidersNode? = viewChild<TemplateRef<HTMLElement>>('socialProvidersNode');
|
|
31
43
|
}
|
|
@@ -1,35 +1,33 @@
|
|
|
1
1
|
@let url = kcContext.url;
|
|
2
2
|
@let credentialLabel = kcContext.credentialLabel;
|
|
3
|
-
<
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
<
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
</div>
|
|
3
|
+
<ng-template #headerNode>
|
|
4
|
+
{{ i18n.msgStr('deleteCredentialTitle', credentialLabel) }}
|
|
5
|
+
</ng-template>
|
|
6
|
+
<ng-container content>
|
|
7
|
+
<div id="kc-delete-text">
|
|
8
|
+
{{ i18n.msgStr('deleteCredentialMessage', credentialLabel) }}
|
|
9
|
+
</div>
|
|
11
10
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
11
|
+
<form
|
|
12
|
+
class="form-actions"
|
|
13
|
+
method="post"
|
|
14
|
+
[action]="url.loginAction"
|
|
15
|
+
>
|
|
16
|
+
<input
|
|
17
|
+
name="accept"
|
|
18
|
+
id="kc-accept"
|
|
19
|
+
type="submit"
|
|
20
|
+
[kcClass]="['kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass']"
|
|
21
|
+
[value]="i18n.msgStr('doConfirmDelete')"
|
|
22
|
+
/>
|
|
24
23
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
</kc-login-template>
|
|
24
|
+
<input
|
|
25
|
+
name="cancel-aia"
|
|
26
|
+
id="kc-decline"
|
|
27
|
+
type="submit"
|
|
28
|
+
[kcClass]="['kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass']"
|
|
29
|
+
[value]="i18n.msgStr('doCancel')"
|
|
30
|
+
/>
|
|
31
|
+
</form>
|
|
32
|
+
<div class="clearfix"></div>
|
|
33
|
+
</ng-container>
|