@keycloakify/svelte 0.0.1-rc.6 → 0.1.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 (196) hide show
  1. package/README.md +1 -1
  2. package/keycloakify-svelte/account/DefaultPage.svelte +42 -0
  3. package/keycloakify-svelte/account/DefaultPage.svelte.d.ts +6 -0
  4. package/keycloakify-svelte/account/KcContext/KcContext.d.ts +1 -0
  5. package/keycloakify-svelte/account/KcContext/KcContext.js +1 -0
  6. package/keycloakify-svelte/account/KcContext/index.d.ts +1 -0
  7. package/keycloakify-svelte/account/KcContext/index.js +1 -0
  8. package/keycloakify-svelte/account/Template.svelte +143 -0
  9. package/keycloakify-svelte/account/Template.svelte.d.ts +6 -0
  10. package/keycloakify-svelte/account/Template.useInitialize.d.ts +12 -0
  11. package/keycloakify-svelte/account/Template.useInitialize.js +19 -0
  12. package/keycloakify-svelte/account/TemplateProps.d.ts +12 -0
  13. package/keycloakify-svelte/account/TemplateProps.js +1 -0
  14. package/keycloakify-svelte/account/i18n/i18n.d.ts +15 -0
  15. package/keycloakify-svelte/account/i18n/i18n.js +1 -0
  16. package/keycloakify-svelte/account/i18n/i18nBuilder.d.ts +18 -0
  17. package/keycloakify-svelte/account/i18n/i18nBuilder.js +26 -0
  18. package/keycloakify-svelte/account/i18n/index.d.ts +1 -0
  19. package/keycloakify-svelte/account/i18n/index.js +1 -0
  20. package/keycloakify-svelte/account/i18n/useI18n.d.ts +28 -0
  21. package/keycloakify-svelte/account/i18n/useI18n.js +65 -0
  22. package/keycloakify-svelte/account/index.d.ts +2 -0
  23. package/keycloakify-svelte/account/index.js +1 -0
  24. package/keycloakify-svelte/account/pages/Account.svelte +182 -0
  25. package/keycloakify-svelte/account/pages/Account.svelte.d.ts +6 -0
  26. package/keycloakify-svelte/account/pages/Applications.svelte +173 -0
  27. package/keycloakify-svelte/account/pages/Applications.svelte.d.ts +6 -0
  28. package/keycloakify-svelte/account/pages/FederatedIdentity.svelte +114 -0
  29. package/keycloakify-svelte/account/pages/FederatedIdentity.svelte.d.ts +6 -0
  30. package/keycloakify-svelte/account/pages/Log.svelte +68 -0
  31. package/keycloakify-svelte/account/pages/Log.svelte.d.ts +6 -0
  32. package/keycloakify-svelte/account/pages/PageProps.d.ts +10 -0
  33. package/keycloakify-svelte/account/pages/PageProps.js +1 -0
  34. package/keycloakify-svelte/account/pages/Password.svelte +233 -0
  35. package/keycloakify-svelte/account/pages/Password.svelte.d.ts +6 -0
  36. package/keycloakify-svelte/account/pages/Sessions.svelte +88 -0
  37. package/keycloakify-svelte/account/pages/Sessions.svelte.d.ts +6 -0
  38. package/keycloakify-svelte/account/pages/Totp.svelte +287 -0
  39. package/keycloakify-svelte/account/pages/Totp.svelte.d.ts +6 -0
  40. package/keycloakify-svelte/additional-svelte-typings.d.ts +6 -0
  41. package/keycloakify-svelte/bin/200.index.js +399 -0
  42. package/keycloakify-svelte/bin/266.index.js +964 -0
  43. package/keycloakify-svelte/bin/279.index.js +4298 -0
  44. package/keycloakify-svelte/bin/709.index.js +494 -0
  45. package/keycloakify-svelte/bin/818.index.js +1037 -0
  46. package/keycloakify-svelte/bin/index.js +2454 -0
  47. package/keycloakify-svelte/bin/package.json +3 -0
  48. package/keycloakify-svelte/login/DefaultPage.svelte +135 -0
  49. package/keycloakify-svelte/login/DefaultPage.svelte.d.ts +12 -0
  50. package/keycloakify-svelte/login/KcContext/KcContext.d.ts +1 -0
  51. package/keycloakify-svelte/login/KcContext/KcContext.js +1 -0
  52. package/keycloakify-svelte/login/KcContext/index.d.ts +1 -0
  53. package/keycloakify-svelte/login/KcContext/index.js +1 -0
  54. package/keycloakify-svelte/login/Template.svelte +223 -0
  55. package/keycloakify-svelte/login/Template.svelte.d.ts +6 -0
  56. package/keycloakify-svelte/login/Template.useInitialize.d.ts +14 -0
  57. package/keycloakify-svelte/login/Template.useInitialize.js +55 -0
  58. package/keycloakify-svelte/login/TemplateProps.d.ts +20 -0
  59. package/keycloakify-svelte/login/TemplateProps.js +1 -0
  60. package/keycloakify-svelte/login/components/AddRemoveButtonsMultiValuedAttribute.svelte +57 -0
  61. package/keycloakify-svelte/login/components/AddRemoveButtonsMultiValuedAttribute.svelte.d.ts +18 -0
  62. package/keycloakify-svelte/login/components/FieldErrors.svelte +31 -0
  63. package/keycloakify-svelte/login/components/FieldErrors.svelte.d.ts +12 -0
  64. package/keycloakify-svelte/login/components/GroupLabel.svelte +68 -0
  65. package/keycloakify-svelte/login/components/GroupLabel.svelte.d.ts +15 -0
  66. package/keycloakify-svelte/login/components/InputFieldByType.svelte +58 -0
  67. package/keycloakify-svelte/login/components/InputFieldByType.svelte.d.ts +4 -0
  68. package/keycloakify-svelte/login/components/InputFieldByTypeProps.d.ts +16 -0
  69. package/keycloakify-svelte/login/components/InputFieldByTypeProps.js +1 -0
  70. package/keycloakify-svelte/login/components/InputTag.svelte +107 -0
  71. package/keycloakify-svelte/login/components/InputTag.svelte.d.ts +7 -0
  72. package/keycloakify-svelte/login/components/InputTagSelects.svelte +111 -0
  73. package/keycloakify-svelte/login/components/InputTagSelects.svelte.d.ts +4 -0
  74. package/keycloakify-svelte/login/components/LogoutOtherSessions.svelte +29 -0
  75. package/keycloakify-svelte/login/components/LogoutOtherSessions.svelte.d.ts +10 -0
  76. package/keycloakify-svelte/login/components/PasswordWrapper.svelte +43 -0
  77. package/keycloakify-svelte/login/components/PasswordWrapper.svelte.d.ts +13 -0
  78. package/keycloakify-svelte/login/components/SelectTag.svelte +72 -0
  79. package/keycloakify-svelte/login/components/SelectTag.svelte.d.ts +4 -0
  80. package/keycloakify-svelte/login/components/TermsAcceptance.svelte +56 -0
  81. package/keycloakify-svelte/login/components/TermsAcceptance.svelte.d.ts +13 -0
  82. package/keycloakify-svelte/login/components/TextareaTag.svelte +40 -0
  83. package/keycloakify-svelte/login/components/TextareaTag.svelte.d.ts +4 -0
  84. package/keycloakify-svelte/login/components/UserProfileFormFields.svelte +123 -0
  85. package/keycloakify-svelte/login/components/UserProfileFormFields.svelte.d.ts +6 -0
  86. package/keycloakify-svelte/login/components/UserProfileFormFieldsProps.d.ts +27 -0
  87. package/keycloakify-svelte/login/components/UserProfileFormFieldsProps.js +2 -0
  88. package/keycloakify-svelte/login/components/inputLabel.d.ts +3 -0
  89. package/keycloakify-svelte/login/components/inputLabel.js +12 -0
  90. package/keycloakify-svelte/login/i18n/i18n.d.ts +15 -0
  91. package/keycloakify-svelte/login/i18n/i18n.js +1 -0
  92. package/keycloakify-svelte/login/i18n/i18nBuilder.d.ts +18 -0
  93. package/keycloakify-svelte/login/i18n/i18nBuilder.js +26 -0
  94. package/keycloakify-svelte/login/i18n/index.d.ts +1 -0
  95. package/keycloakify-svelte/login/i18n/index.js +1 -0
  96. package/keycloakify-svelte/login/i18n/useI18n.d.ts +28 -0
  97. package/keycloakify-svelte/login/i18n/useI18n.js +65 -0
  98. package/keycloakify-svelte/login/index.d.ts +2 -0
  99. package/keycloakify-svelte/login/index.js +1 -0
  100. package/keycloakify-svelte/login/lib/useUserProfileForm.d.ts +66 -0
  101. package/keycloakify-svelte/login/lib/useUserProfileForm.js +63 -0
  102. package/keycloakify-svelte/login/pages/Code.svelte +46 -0
  103. package/keycloakify-svelte/login/pages/Code.svelte.d.ts +6 -0
  104. package/keycloakify-svelte/login/pages/DeleteAccountConfirm.svelte +77 -0
  105. package/keycloakify-svelte/login/pages/DeleteAccountConfirm.svelte.d.ts +6 -0
  106. package/keycloakify-svelte/login/pages/DeleteCredential.svelte +58 -0
  107. package/keycloakify-svelte/login/pages/DeleteCredential.svelte.d.ts +6 -0
  108. package/keycloakify-svelte/login/pages/Error.svelte +43 -0
  109. package/keycloakify-svelte/login/pages/Error.svelte.d.ts +6 -0
  110. package/keycloakify-svelte/login/pages/FrontchannelLogout.svelte +57 -0
  111. package/keycloakify-svelte/login/pages/FrontchannelLogout.svelte.d.ts +6 -0
  112. package/keycloakify-svelte/login/pages/IdpReviewUserProfile.svelte +80 -0
  113. package/keycloakify-svelte/login/pages/IdpReviewUserProfile.svelte.d.ts +11 -0
  114. package/keycloakify-svelte/login/pages/Info.svelte +66 -0
  115. package/keycloakify-svelte/login/pages/Info.svelte.d.ts +6 -0
  116. package/keycloakify-svelte/login/pages/Login.svelte +225 -0
  117. package/keycloakify-svelte/login/pages/Login.svelte.d.ts +6 -0
  118. package/keycloakify-svelte/login/pages/LoginConfigTotp.svelte +217 -0
  119. package/keycloakify-svelte/login/pages/LoginConfigTotp.svelte.d.ts +6 -0
  120. package/keycloakify-svelte/login/pages/LoginIdpLinkConfirm.svelte +60 -0
  121. package/keycloakify-svelte/login/pages/LoginIdpLinkConfirm.svelte.d.ts +6 -0
  122. package/keycloakify-svelte/login/pages/LoginIdpLinkConfirmOverride.svelte +59 -0
  123. package/keycloakify-svelte/login/pages/LoginIdpLinkConfirmOverride.svelte.d.ts +6 -0
  124. package/keycloakify-svelte/login/pages/LoginIdpLinkEmail.svelte +50 -0
  125. package/keycloakify-svelte/login/pages/LoginIdpLinkEmail.svelte.d.ts +6 -0
  126. package/keycloakify-svelte/login/pages/LoginOauth2DeviceVerifyUserCode.svelte +85 -0
  127. package/keycloakify-svelte/login/pages/LoginOauth2DeviceVerifyUserCode.svelte.d.ts +6 -0
  128. package/keycloakify-svelte/login/pages/LoginOauthGrant.svelte +126 -0
  129. package/keycloakify-svelte/login/pages/LoginOauthGrant.svelte.d.ts +6 -0
  130. package/keycloakify-svelte/login/pages/LoginOtp.svelte +128 -0
  131. package/keycloakify-svelte/login/pages/LoginOtp.svelte.d.ts +6 -0
  132. package/keycloakify-svelte/login/pages/LoginPageExpired.svelte +50 -0
  133. package/keycloakify-svelte/login/pages/LoginPageExpired.svelte.d.ts +6 -0
  134. package/keycloakify-svelte/login/pages/LoginPasskeysConditionalAuthenticate.svelte +240 -0
  135. package/keycloakify-svelte/login/pages/LoginPasskeysConditionalAuthenticate.svelte.d.ts +6 -0
  136. package/keycloakify-svelte/login/pages/LoginPasskeysConditionalAuthenticate.useScript.d.ts +21 -0
  137. package/keycloakify-svelte/login/pages/LoginPasskeysConditionalAuthenticate.useScript.js +57 -0
  138. package/keycloakify-svelte/login/pages/LoginPassword.svelte +120 -0
  139. package/keycloakify-svelte/login/pages/LoginPassword.svelte.d.ts +6 -0
  140. package/keycloakify-svelte/login/pages/LoginRecoveryAuthnCodeConfig.svelte +179 -0
  141. package/keycloakify-svelte/login/pages/LoginRecoveryAuthnCodeConfig.svelte.d.ts +6 -0
  142. package/keycloakify-svelte/login/pages/LoginRecoveryAuthnCodeConfig.useScript.d.ts +10 -0
  143. package/keycloakify-svelte/login/pages/LoginRecoveryAuthnCodeConfig.useScript.js +141 -0
  144. package/keycloakify-svelte/login/pages/LoginRecoveryAuthnCodeInput.svelte +94 -0
  145. package/keycloakify-svelte/login/pages/LoginRecoveryAuthnCodeInput.svelte.d.ts +6 -0
  146. package/keycloakify-svelte/login/pages/LoginResetOtp.svelte +86 -0
  147. package/keycloakify-svelte/login/pages/LoginResetOtp.svelte.d.ts +6 -0
  148. package/keycloakify-svelte/login/pages/LoginResetPassword.svelte +109 -0
  149. package/keycloakify-svelte/login/pages/LoginResetPassword.svelte.d.ts +6 -0
  150. package/keycloakify-svelte/login/pages/LoginUpdatePassword.svelte +149 -0
  151. package/keycloakify-svelte/login/pages/LoginUpdatePassword.svelte.d.ts +6 -0
  152. package/keycloakify-svelte/login/pages/LoginUpdateProfile.svelte +98 -0
  153. package/keycloakify-svelte/login/pages/LoginUpdateProfile.svelte.d.ts +11 -0
  154. package/keycloakify-svelte/login/pages/LoginUsername.svelte +182 -0
  155. package/keycloakify-svelte/login/pages/LoginUsername.svelte.d.ts +6 -0
  156. package/keycloakify-svelte/login/pages/LoginVerifyEmail.svelte +39 -0
  157. package/keycloakify-svelte/login/pages/LoginVerifyEmail.svelte.d.ts +6 -0
  158. package/keycloakify-svelte/login/pages/LoginX509Info.svelte +123 -0
  159. package/keycloakify-svelte/login/pages/LoginX509Info.svelte.d.ts +6 -0
  160. package/keycloakify-svelte/login/pages/LogoutConfirm.svelte +77 -0
  161. package/keycloakify-svelte/login/pages/LogoutConfirm.svelte.d.ts +6 -0
  162. package/keycloakify-svelte/login/pages/PageProps.d.ts +10 -0
  163. package/keycloakify-svelte/login/pages/PageProps.js +1 -0
  164. package/keycloakify-svelte/login/pages/Register.svelte +136 -0
  165. package/keycloakify-svelte/login/pages/Register.svelte.d.ts +11 -0
  166. package/keycloakify-svelte/login/pages/SamlPostForm.svelte +80 -0
  167. package/keycloakify-svelte/login/pages/SamlPostForm.svelte.d.ts +6 -0
  168. package/keycloakify-svelte/login/pages/SelectAuthenticator.svelte +63 -0
  169. package/keycloakify-svelte/login/pages/SelectAuthenticator.svelte.d.ts +6 -0
  170. package/keycloakify-svelte/login/pages/Terms.svelte +57 -0
  171. package/keycloakify-svelte/login/pages/Terms.svelte.d.ts +6 -0
  172. package/keycloakify-svelte/login/pages/UpdateEmail.svelte +104 -0
  173. package/keycloakify-svelte/login/pages/UpdateEmail.svelte.d.ts +11 -0
  174. package/keycloakify-svelte/login/pages/WebauthnAuthenticate.svelte +182 -0
  175. package/keycloakify-svelte/login/pages/WebauthnAuthenticate.svelte.d.ts +6 -0
  176. package/keycloakify-svelte/login/pages/WebauthnAuthenticate.useScript.d.ts +22 -0
  177. package/keycloakify-svelte/login/pages/WebauthnAuthenticate.useScript.js +49 -0
  178. package/keycloakify-svelte/login/pages/WebauthnError.svelte +86 -0
  179. package/keycloakify-svelte/login/pages/WebauthnError.svelte.d.ts +6 -0
  180. package/keycloakify-svelte/login/pages/WebauthnRegister.svelte +109 -0
  181. package/keycloakify-svelte/login/pages/WebauthnRegister.svelte.d.ts +6 -0
  182. package/keycloakify-svelte/login/pages/WebauthnRegister.useScript.d.ts +28 -0
  183. package/keycloakify-svelte/login/pages/WebauthnRegister.useScript.js +57 -0
  184. package/keycloakify-svelte/tools/useConst.d.ts +1 -0
  185. package/keycloakify-svelte/tools/useConst.js +4 -0
  186. package/keycloakify-svelte/tools/useInsertLinkTags.d.ts +12 -0
  187. package/keycloakify-svelte/tools/useInsertLinkTags.js +62 -0
  188. package/keycloakify-svelte/tools/useInsertScriptTags.d.ts +29 -0
  189. package/keycloakify-svelte/tools/useInsertScriptTags.js +77 -0
  190. package/keycloakify-svelte/tools/useReducer.d.ts +2 -0
  191. package/keycloakify-svelte/tools/useReducer.js +7 -0
  192. package/keycloakify-svelte/tools/useSetClassName.d.ts +4 -0
  193. package/keycloakify-svelte/tools/useSetClassName.js +15 -0
  194. package/keycloakify-svelte/tools/useState.d.ts +2 -0
  195. package/keycloakify-svelte/tools/useState.js +7 -0
  196. package/package.json +6 -3
@@ -0,0 +1,128 @@
1
+ <script lang="ts">
2
+ import type { PageProps } from './PageProps';
3
+ import { kcSanitize } from 'keycloakify/lib/kcSanitize';
4
+ import { getKcClsx } from 'keycloakify/login/lib/kcClsx';
5
+ import type { KcContext } from '../KcContext';
6
+ import type { I18n } from '../i18n';
7
+
8
+ const {
9
+ Template,
10
+ kcContext,
11
+ i18n,
12
+ doUseDefaultCss,
13
+ classes,
14
+ }: PageProps<Extract<KcContext, { pageId: 'login-otp.ftl' }>, I18n> = $props();
15
+
16
+ const { kcClsx } = getKcClsx({
17
+ doUseDefaultCss,
18
+ classes,
19
+ });
20
+
21
+ const { otpLogin, url, messagesPerField } = kcContext;
22
+
23
+ const { msg, msgStr } = $i18n;
24
+ </script>
25
+
26
+ <Template
27
+ {kcContext}
28
+ {i18n}
29
+ {doUseDefaultCss}
30
+ {classes}
31
+ displayMessage={!messagesPerField.existsError('totp')}
32
+ >
33
+ {#snippet headerNode()}
34
+ {@render msg('doLogIn')()}
35
+ {/snippet}
36
+ <form
37
+ id="kc-otp-login-form"
38
+ class={kcClsx('kcFormClass')}
39
+ action={url.loginAction}
40
+ method="post"
41
+ >
42
+ {#if otpLogin.userOtpCredentials.length > 1}
43
+ <div class={kcClsx('kcFormGroupClass')}>
44
+ <div class={kcClsx('kcInputWrapperClass')}>
45
+ {#each otpLogin.userOtpCredentials as otpCredential, index}
46
+ <input
47
+ id={`kc-otp-credential-${index}`}
48
+ class={kcClsx('kcLoginOTPListInputClass')}
49
+ type="radio"
50
+ name="selectedCredentialId"
51
+ value={otpCredential.id}
52
+ checked={otpCredential.id === otpLogin.selectedCredentialId}
53
+ />
54
+ <!-- svelte-ignore a11y_no_noninteractive_tabindex -->
55
+ <label
56
+ for={`kc-otp-credential-${index}`}
57
+ class={kcClsx('kcLoginOTPListClass')}
58
+ tabindex={index}
59
+ >
60
+ <span class={kcClsx('kcLoginOTPListItemHeaderClass')}>
61
+ <span class={kcClsx('kcLoginOTPListItemIconBodyClass')}>
62
+ <i
63
+ class={kcClsx('kcLoginOTPListItemIconClass')}
64
+ aria-hidden="true"
65
+ ></i>
66
+ </span>
67
+ <span class={kcClsx('kcLoginOTPListItemTitleClass')}>{otpCredential.userLabel}</span>
68
+ </span>
69
+ </label>
70
+ {/each}
71
+ </div>
72
+ </div>
73
+ {/if}
74
+
75
+ <div class={kcClsx('kcFormGroupClass')}>
76
+ <div class={kcClsx('kcLabelWrapperClass')}>
77
+ <label
78
+ for="otp"
79
+ class={kcClsx('kcLabelClass')}
80
+ >
81
+ {@render msg('loginOtpOneTime')()}
82
+ </label>
83
+ </div>
84
+ <div class={kcClsx('kcInputWrapperClass')}>
85
+ <!-- svelte-ignore a11y_autofocus -->
86
+ <input
87
+ id="otp"
88
+ name="otp"
89
+ autocomplete="off"
90
+ type="text"
91
+ class={kcClsx('kcInputClass')}
92
+ autofocus
93
+ aria-invalid={messagesPerField.existsError('totp')}
94
+ />
95
+ {#if messagesPerField.existsError('totp')}
96
+ <span
97
+ id="input-error-otp-code"
98
+ class={kcClsx('kcInputErrorMessageClass')}
99
+ aria-live="polite"
100
+ >
101
+ {@html kcSanitize(messagesPerField.get('totp'))}
102
+ </span>
103
+ {/if}
104
+ </div>
105
+ </div>
106
+
107
+ <div class={kcClsx('kcFormGroupClass')}>
108
+ <div
109
+ id="kc-form-options"
110
+ class={kcClsx('kcFormOptionsClass')}
111
+ >
112
+ <div class={kcClsx('kcFormOptionsWrapperClass')}></div>
113
+ </div>
114
+ <div
115
+ id="kc-form-buttons"
116
+ class={kcClsx('kcFormButtonsClass')}
117
+ >
118
+ <input
119
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
120
+ name="login"
121
+ id="kc-login"
122
+ type="submit"
123
+ value={msgStr('doLogIn')}
124
+ />
125
+ </div>
126
+ </div>
127
+ </form>
128
+ </Template>
@@ -0,0 +1,6 @@
1
+ import type { PageProps } from './PageProps';
2
+ import type { KcContext } from '../KcContext';
3
+ import type { I18n } from '../i18n';
4
+ declare const LoginOtp: import("svelte").Component<PageProps<KcContext.LoginOtp, I18n>, {}, "">;
5
+ type LoginOtp = ReturnType<typeof LoginOtp>;
6
+ export default LoginOtp;
@@ -0,0 +1,50 @@
1
+ <script lang="ts">
2
+ import type { PageProps } from './PageProps';
3
+ import type { KcContext } from '../KcContext';
4
+ import type { I18n } from '../i18n';
5
+
6
+ const {
7
+ Template,
8
+ kcContext,
9
+ i18n,
10
+ doUseDefaultCss,
11
+ classes,
12
+ }: PageProps<Extract<KcContext, { pageId: 'login-page-expired.ftl' }>, I18n> = $props();
13
+
14
+ const { url } = kcContext;
15
+
16
+ const { msg } = $i18n;
17
+ </script>
18
+
19
+ <Template
20
+ {kcContext}
21
+ {i18n}
22
+ {doUseDefaultCss}
23
+ {classes}
24
+ >
25
+ {#snippet headerNode()}
26
+ {@render msg('pageExpiredTitle')()}
27
+ {/snippet}
28
+
29
+ <p
30
+ id="instruction1"
31
+ class="instruction"
32
+ >
33
+ {@render msg('pageExpiredMsg1')()}
34
+ <a
35
+ id="loginRestartLink"
36
+ href={url.loginRestartFlowUrl}
37
+ >
38
+ {@render msg('doClickHere')()}
39
+ </a>{' '}
40
+ .<br />
41
+ {@render msg('pageExpiredMsg2')()}{' '}
42
+ <a
43
+ id="loginContinueLink"
44
+ href={url.loginAction}
45
+ >
46
+ {@render msg('doClickHere')()}
47
+ </a>{' '}
48
+ .
49
+ </p>
50
+ </Template>
@@ -0,0 +1,6 @@
1
+ import type { PageProps } from './PageProps';
2
+ import type { KcContext } from '../KcContext';
3
+ import type { I18n } from '../i18n';
4
+ declare const LoginPageExpired: import("svelte").Component<PageProps<KcContext.LoginPageExpired, I18n>, {}, "">;
5
+ type LoginPageExpired = ReturnType<typeof LoginPageExpired>;
6
+ export default LoginPageExpired;
@@ -0,0 +1,240 @@
1
+ <script lang="ts">
2
+ import { useScript } from './LoginPasskeysConditionalAuthenticate.useScript';
3
+ import type { PageProps } from './PageProps';
4
+ import { type ClassKey, getKcClsx } from 'keycloakify/login/lib/kcClsx';
5
+ import { clsx } from 'keycloakify/tools/clsx';
6
+ import type { CxArg } from 'keycloakify/tools/clsx_withTransform';
7
+ import type { KcContext } from '../KcContext';
8
+ import type { I18n } from '../i18n';
9
+
10
+ const {
11
+ Template,
12
+ kcContext,
13
+ i18n,
14
+ doUseDefaultCss,
15
+ classes,
16
+ }: PageProps<Extract<KcContext, { pageId: 'login-passkeys-conditional-authenticate.ftl' }>, I18n> = $props();
17
+
18
+ const {
19
+ messagesPerField,
20
+ login,
21
+ url,
22
+ usernameHidden,
23
+ shouldDisplayAuthenticators,
24
+ authenticators,
25
+ registrationDisabled,
26
+ realm,
27
+ } = kcContext;
28
+
29
+ const { msg, msgStr, advancedMsg } = $i18n;
30
+
31
+ const { kcClsx } = getKcClsx({
32
+ doUseDefaultCss,
33
+ classes,
34
+ });
35
+
36
+ const authButtonId = 'authenticateWebAuthnButton';
37
+
38
+ useScript({ authButtonId, kcContext, i18n });
39
+ </script>
40
+
41
+ <Template
42
+ {kcContext}
43
+ {i18n}
44
+ {doUseDefaultCss}
45
+ {classes}
46
+ >
47
+ {#snippet headerNode()}
48
+ {@render msg('passkey-login-title')()}
49
+ {/snippet}
50
+ {#snippet infoNode()}
51
+ {#if realm.registrationAllowed && !registrationDisabled}
52
+ <div id="kc-registration">
53
+ <span>
54
+ {@render msg('noAccount')()}
55
+ <a
56
+ tabindex={6}
57
+ href={url.registrationUrl}
58
+ >
59
+ {@render msg('doRegister')()}
60
+ </a>
61
+ </span>
62
+ </div>
63
+ {/if}
64
+ {/snippet}
65
+ <form
66
+ id="webauth"
67
+ action={url.loginAction}
68
+ method="post"
69
+ >
70
+ <input
71
+ type="hidden"
72
+ id="clientDataJSON"
73
+ name="clientDataJSON"
74
+ />
75
+ <input
76
+ type="hidden"
77
+ id="authenticatorData"
78
+ name="authenticatorData"
79
+ />
80
+ <input
81
+ type="hidden"
82
+ id="signature"
83
+ name="signature"
84
+ />
85
+ <input
86
+ type="hidden"
87
+ id="credentialId"
88
+ name="credentialId"
89
+ />
90
+ <input
91
+ type="hidden"
92
+ id="userHandle"
93
+ name="userHandle"
94
+ />
95
+ <input
96
+ type="hidden"
97
+ id="error"
98
+ name="error"
99
+ />
100
+ </form>
101
+ <div
102
+ class={kcClsx('kcFormGroupClass')}
103
+ no-bottom-margin={true}
104
+ style:margin-bottom={'0'}
105
+ >
106
+ {#if authenticators !== undefined && Object.keys(authenticators).length !== 0}
107
+ <form
108
+ id="authn_select"
109
+ class={kcClsx('kcFormClass')}
110
+ >
111
+ {#each authenticators.authenticators as authenticator}
112
+ <input
113
+ type="hidden"
114
+ name="authn_use_chk"
115
+ readOnly
116
+ value={authenticator.credentialId}
117
+ />
118
+ {/each}
119
+ </form>
120
+ {#if shouldDisplayAuthenticators}
121
+ {#if authenticators.authenticators.length > 1}
122
+ <p class={kcClsx('kcSelectAuthListItemTitle')}>{msg('passkey-available-authenticators')}</p>
123
+ {/if}
124
+ <div class={kcClsx('kcFormClass')}>
125
+ {#each authenticators.authenticators as authenticator, i}
126
+ <div
127
+ id={`kc-webauthn-authenticator-item-${i}`}
128
+ class={kcClsx('kcSelectAuthListItemClass')}
129
+ >
130
+ <i
131
+ class={clsx(
132
+ (() => {
133
+ const klass = kcClsx(authenticator.transports.iconClass as CxArg<ClassKey>);
134
+ if (klass === authenticator.transports.iconClass) {
135
+ return kcClsx('kcWebAuthnDefaultIcon');
136
+ }
137
+ return klass;
138
+ })(),
139
+ kcClsx('kcSelectAuthListItemIconPropertyClass'),
140
+ )}
141
+ ></i>
142
+ <div class={kcClsx('kcSelectAuthListItemBodyClass')}>
143
+ <div
144
+ id={`kc-webauthn-authenticator-label-${i}`}
145
+ class={kcClsx('kcSelectAuthListItemHeadingClass')}
146
+ >
147
+ {advancedMsg(authenticator.label)}
148
+ </div>
149
+ {#if authenticator.transports !== undefined && authenticator.transports.displayNameProperties !== undefined && authenticator.transports.displayNameProperties.length !== 0}
150
+ <div
151
+ id={`kc-webauthn-authenticator-transport-${i}`}
152
+ class={kcClsx('kcSelectAuthListItemDescriptionClass')}
153
+ >
154
+ {#each authenticator.transports.displayNameProperties as nameProperty, i}
155
+ <span> {advancedMsg(nameProperty)} </span>
156
+ {#if i !== authenticator.transports.displayNameProperties.length - 1}
157
+ <span>, </span>{/if}
158
+ {/each}
159
+ </div>
160
+ {/if}
161
+ <div class={kcClsx('kcSelectAuthListItemDescriptionClass')}>
162
+ <span id={`kc-webauthn-authenticator-createdlabel-${i}`}>{msg('passkey-createdAt-label')}</span>
163
+ <span id={`kc-webauthn-authenticator-created-${i}`}>{authenticator.createdAt}</span>
164
+ </div>
165
+ </div>
166
+ <div class={kcClsx('kcSelectAuthListItemFillClass')}></div>
167
+ </div>
168
+ {/each}
169
+ </div>
170
+ {/if}
171
+ {/if}
172
+ <div id="kc-form">
173
+ <div id="kc-form-wrapper">
174
+ {#if realm.password}
175
+ <form
176
+ id="kc-form-login"
177
+ action={url.loginAction}
178
+ method="post"
179
+ style:display={'none'}
180
+ onsubmit={(event) => {
181
+ try {
182
+ event.currentTarget.login.disabled = true;
183
+ } catch (e) {
184
+ console.error(e);
185
+ }
186
+
187
+ return true;
188
+ }}
189
+ >
190
+ {#if !usernameHidden}
191
+ <div class={kcClsx('kcFormGroupClass')}>
192
+ <label
193
+ for="username"
194
+ class={kcClsx('kcLabelClass')}
195
+ >
196
+ {msg('passkey-autofill-select')}
197
+ </label>
198
+ <!-- svelte-ignore a11y_autofocus -->
199
+ <input
200
+ tabindex={1}
201
+ id="username"
202
+ aria-invalid={messagesPerField.existsError('username')}
203
+ class={kcClsx('kcInputClass')}
204
+ name="username"
205
+ value={login.username ?? ''}
206
+ autocomplete="username webauthn"
207
+ type="text"
208
+ autofocus
209
+ />
210
+ {#if messagesPerField.existsError('username')}
211
+ <span
212
+ id="input-error-username"
213
+ class={kcClsx('kcInputErrorMessageClass')}
214
+ aria-live="polite"
215
+ >
216
+ {messagesPerField.get('username')}
217
+ </span>
218
+ {/if}
219
+ </div>
220
+ {/if}
221
+ </form>
222
+ {/if}
223
+ <div
224
+ id="kc-form-passkey-button"
225
+ class={kcClsx('kcFormButtonsClass')}
226
+ style:display={'none'}
227
+ >
228
+ <!-- svelte-ignore a11y_autofocus -->
229
+ <input
230
+ id={authButtonId}
231
+ type="button"
232
+ autofocus
233
+ value={msgStr('passkey-doAuthenticate')}
234
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
235
+ />
236
+ </div>
237
+ </div>
238
+ </div>
239
+ </div>
240
+ </Template>
@@ -0,0 +1,6 @@
1
+ import type { PageProps } from './PageProps';
2
+ import type { KcContext } from '../KcContext';
3
+ import type { I18n } from '../i18n';
4
+ declare const LoginPasskeysConditionalAuthenticate: import("svelte").Component<PageProps<KcContext.LoginPasskeysConditionalAuthenticate, I18n>, {}, "">;
5
+ type LoginPasskeysConditionalAuthenticate = ReturnType<typeof LoginPasskeysConditionalAuthenticate>;
6
+ export default LoginPasskeysConditionalAuthenticate;
@@ -0,0 +1,21 @@
1
+ import type { Readable } from 'svelte/store';
2
+ type KcContextLike = {
3
+ url: {
4
+ resourcesPath: string;
5
+ };
6
+ isUserIdentified: boolean | 'true' | 'false';
7
+ challenge: string;
8
+ userVerification: string;
9
+ rpId: string;
10
+ createTimeout: number | string;
11
+ };
12
+ type I18nLike = {
13
+ msgStr: (key: 'webauthn-unsupported-browser-text' | 'passkey-unsupported-browser-text') => string;
14
+ isFetchingTranslations: boolean;
15
+ };
16
+ export declare function useScript(params: {
17
+ authButtonId: string;
18
+ kcContext: KcContextLike;
19
+ i18n: Readable<I18nLike>;
20
+ }): void;
21
+ export {};
@@ -0,0 +1,57 @@
1
+ import { useInsertScriptTags } from '../../tools/useInsertScriptTags';
2
+ import { assert } from 'keycloakify/tools/assert';
3
+ import { waitForElementMountedOnDom } from 'keycloakify/tools/waitForElementMountedOnDom';
4
+ import { onMount } from 'svelte';
5
+ assert();
6
+ assert();
7
+ export function useScript(params) {
8
+ const { authButtonId, kcContext, i18n } = params;
9
+ const { url, isUserIdentified, challenge, userVerification, rpId, createTimeout } = kcContext;
10
+ onMount(() => {
11
+ const unsubscribe = i18n.subscribe(($i18n) => {
12
+ const { msgStr, isFetchingTranslations } = $i18n;
13
+ const { insertScriptTags } = useInsertScriptTags({
14
+ componentOrHookName: 'LoginRecoveryAuthnCodeConfig',
15
+ scriptTags: [
16
+ {
17
+ type: 'module',
18
+ textContent: () => `
19
+ import { authenticateByWebAuthn } from "${url.resourcesPath}/js/webauthnAuthenticate.js";
20
+ import { initAuthenticate } from "${url.resourcesPath}/js/passkeysConditionalAuth.js";
21
+
22
+ const authButton = document.getElementById("${authButtonId}");
23
+ const input = {
24
+ isUserIdentified : ${isUserIdentified},
25
+ challenge : ${JSON.stringify(challenge)},
26
+ userVerification : ${JSON.stringify(userVerification)},
27
+ rpId : ${JSON.stringify(rpId)},
28
+ createTimeout : ${createTimeout}
29
+ };
30
+ authButton.addEventListener("click", () => {
31
+ authenticateByWebAuthn({
32
+ ...input,
33
+ errmsg : ${JSON.stringify(msgStr('webauthn-unsupported-browser-text'))}
34
+ });
35
+ });
36
+
37
+ initAuthenticate({
38
+ ...input,
39
+ errmsg : ${JSON.stringify(msgStr('passkey-unsupported-browser-text'))}
40
+ });
41
+ `,
42
+ },
43
+ ],
44
+ });
45
+ if (isFetchingTranslations) {
46
+ return;
47
+ }
48
+ (async () => {
49
+ await waitForElementMountedOnDom({
50
+ elementId: authButtonId,
51
+ });
52
+ insertScriptTags();
53
+ })();
54
+ });
55
+ return () => unsubscribe();
56
+ });
57
+ }
@@ -0,0 +1,120 @@
1
+ <script lang="ts">
2
+ import PasswordWrapper from '../components/PasswordWrapper.svelte';
3
+ import type { PageProps } from './PageProps';
4
+ import { useState } from '../../tools/useState';
5
+ import { kcSanitize } from 'keycloakify/lib/kcSanitize';
6
+ import { getKcClsx } from 'keycloakify/login/lib/kcClsx';
7
+ import { clsx } from 'keycloakify/tools/clsx';
8
+ import type { I18n } from '../i18n';
9
+ import type { KcContext } from '../KcContext';
10
+
11
+ const {
12
+ Template,
13
+ kcContext,
14
+ i18n,
15
+ doUseDefaultCss,
16
+ classes,
17
+ }: PageProps<Extract<KcContext, { pageId: 'login-password.ftl' }>, I18n> = $props();
18
+
19
+ const { kcClsx } = getKcClsx({
20
+ doUseDefaultCss,
21
+ classes,
22
+ });
23
+
24
+ const { realm, url, messagesPerField } = kcContext;
25
+
26
+ const { msg, msgStr } = $i18n;
27
+
28
+ const [isLoginButtonDisabled, setIsLoginButtonDisabled] = useState(false);
29
+ </script>
30
+
31
+ <Template
32
+ {kcContext}
33
+ {i18n}
34
+ {doUseDefaultCss}
35
+ {classes}
36
+ displayMessage={!messagesPerField.existsError('password')}
37
+ >
38
+ {#snippet headerNode()}
39
+ {@render msg('doLogIn')()}
40
+ {/snippet}
41
+
42
+ <div id="kc-form">
43
+ <div id="kc-form-wrapper">
44
+ <form
45
+ id="kc-form-login"
46
+ onsubmit={() => {
47
+ setIsLoginButtonDisabled(true);
48
+ return true;
49
+ }}
50
+ action={url.loginAction}
51
+ method="post"
52
+ >
53
+ <div class={clsx(kcClsx('kcFormGroupClass'), 'no-bottom-margin')}>
54
+ <hr />
55
+ <label
56
+ for="password"
57
+ class={kcClsx('kcLabelClass')}
58
+ >
59
+ {@render msg('password')()}
60
+ </label>
61
+
62
+ <PasswordWrapper
63
+ {kcClsx}
64
+ {i18n}
65
+ passwordInputId="password"
66
+ >
67
+ <!-- svelte-ignore a11y_autofocus -->
68
+ <input
69
+ tabindex={2}
70
+ id="password"
71
+ class={kcClsx('kcInputClass')}
72
+ name="password"
73
+ type="password"
74
+ autofocus
75
+ autocomplete="on"
76
+ aria-invalid={messagesPerField.existsError('username', 'password')}
77
+ />
78
+ </PasswordWrapper>
79
+
80
+ {#if messagesPerField.existsError('password')}
81
+ <span
82
+ id="input-error-password"
83
+ class={kcClsx('kcInputErrorMessageClass')}
84
+ aria-live="polite">{@html kcSanitize(messagesPerField.get('password'))}</span
85
+ >
86
+ {/if}
87
+ </div>
88
+ <div class={kcClsx('kcFormGroupClass', 'kcFormSettingClass')}>
89
+ <div id="kc-form-options"></div>
90
+ <div class={kcClsx('kcFormOptionsWrapperClass')}>
91
+ {#if realm.resetPasswordAllowed}
92
+ <span>
93
+ <a
94
+ tabindex={5}
95
+ href={url.loginResetCredentialsUrl}
96
+ >
97
+ {@render msg('doForgotPassword')()}
98
+ </a>
99
+ </span>
100
+ {/if}
101
+ </div>
102
+ </div>
103
+ <div
104
+ id="kc-form-buttons"
105
+ class={kcClsx('kcFormGroupClass')}
106
+ >
107
+ <input
108
+ tabindex={4}
109
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
110
+ name="login"
111
+ id="kc-login"
112
+ type="submit"
113
+ value={msgStr('doLogIn')}
114
+ disabled={$isLoginButtonDisabled}
115
+ />
116
+ </div>
117
+ </form>
118
+ </div>
119
+ </div>
120
+ </Template>
@@ -0,0 +1,6 @@
1
+ import type { PageProps } from './PageProps';
2
+ import type { I18n } from '../i18n';
3
+ import type { KcContext } from '../KcContext';
4
+ declare const LoginPassword: import("svelte").Component<PageProps<KcContext.LoginPassword, I18n>, {}, "">;
5
+ type LoginPassword = ReturnType<typeof LoginPassword>;
6
+ export default LoginPassword;