@keycloakify/svelte 0.0.1-rc.1

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 (284) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +50 -0
  3. package/dist/account/DefaultPage.svelte +42 -0
  4. package/dist/account/DefaultPage.svelte.d.ts +6 -0
  5. package/dist/account/KcContext/KcContext.d.ts +1 -0
  6. package/dist/account/KcContext/KcContext.js +1 -0
  7. package/dist/account/KcContext/index.d.ts +1 -0
  8. package/dist/account/KcContext/index.js +1 -0
  9. package/dist/account/Template.svelte +143 -0
  10. package/dist/account/Template.svelte.d.ts +6 -0
  11. package/dist/account/Template.useInitialize.d.ts +12 -0
  12. package/dist/account/Template.useInitialize.js +19 -0
  13. package/dist/account/TemplateProps.d.ts +12 -0
  14. package/dist/account/TemplateProps.js +1 -0
  15. package/dist/account/i18n/i18n.d.ts +15 -0
  16. package/dist/account/i18n/i18n.js +1 -0
  17. package/dist/account/i18n/i18nBuilder.d.ts +18 -0
  18. package/dist/account/i18n/i18nBuilder.js +26 -0
  19. package/dist/account/i18n/index.d.ts +1 -0
  20. package/dist/account/i18n/index.js +1 -0
  21. package/dist/account/i18n/useI18n.d.ts +28 -0
  22. package/dist/account/i18n/useI18n.js +65 -0
  23. package/dist/account/index.d.ts +2 -0
  24. package/dist/account/index.js +1 -0
  25. package/dist/account/pages/Account.svelte +182 -0
  26. package/dist/account/pages/Account.svelte.d.ts +6 -0
  27. package/dist/account/pages/Applications.svelte +173 -0
  28. package/dist/account/pages/Applications.svelte.d.ts +6 -0
  29. package/dist/account/pages/FederatedIdentity.svelte +114 -0
  30. package/dist/account/pages/FederatedIdentity.svelte.d.ts +6 -0
  31. package/dist/account/pages/Log.svelte +68 -0
  32. package/dist/account/pages/Log.svelte.d.ts +6 -0
  33. package/dist/account/pages/PageProps.d.ts +10 -0
  34. package/dist/account/pages/PageProps.js +1 -0
  35. package/dist/account/pages/Password.svelte +233 -0
  36. package/dist/account/pages/Password.svelte.d.ts +6 -0
  37. package/dist/account/pages/Sessions.svelte +88 -0
  38. package/dist/account/pages/Sessions.svelte.d.ts +6 -0
  39. package/dist/account/pages/Totp.svelte +287 -0
  40. package/dist/account/pages/Totp.svelte.d.ts +6 -0
  41. package/dist/additional-svelte-typings.d.ts +6 -0
  42. package/dist/bin/197.index.js +13 -0
  43. package/dist/bin/381.index.js +13 -0
  44. package/dist/bin/504.index.js +13 -0
  45. package/dist/bin/87.index.js +13 -0
  46. package/dist/bin/main.js +230 -0
  47. package/dist/bin/package.json +3 -0
  48. package/dist/login/DefaultPage.svelte +135 -0
  49. package/dist/login/DefaultPage.svelte.d.ts +12 -0
  50. package/dist/login/KcContext/KcContext.d.ts +1 -0
  51. package/dist/login/KcContext/KcContext.js +1 -0
  52. package/dist/login/KcContext/index.d.ts +1 -0
  53. package/dist/login/KcContext/index.js +1 -0
  54. package/dist/login/Template.svelte +223 -0
  55. package/dist/login/Template.svelte.d.ts +6 -0
  56. package/dist/login/Template.useInitialize.d.ts +14 -0
  57. package/dist/login/Template.useInitialize.js +55 -0
  58. package/dist/login/TemplateProps.d.ts +20 -0
  59. package/dist/login/TemplateProps.js +1 -0
  60. package/dist/login/components/AddRemoveButtonsMultiValuedAttribute.svelte +57 -0
  61. package/dist/login/components/AddRemoveButtonsMultiValuedAttribute.svelte.d.ts +18 -0
  62. package/dist/login/components/FieldErrors.svelte +31 -0
  63. package/dist/login/components/FieldErrors.svelte.d.ts +12 -0
  64. package/dist/login/components/GroupLabel.svelte +68 -0
  65. package/dist/login/components/GroupLabel.svelte.d.ts +15 -0
  66. package/dist/login/components/InputFieldByType.svelte +58 -0
  67. package/dist/login/components/InputFieldByType.svelte.d.ts +4 -0
  68. package/dist/login/components/InputFieldByTypeProps.d.ts +16 -0
  69. package/dist/login/components/InputFieldByTypeProps.js +1 -0
  70. package/dist/login/components/InputTag.svelte +107 -0
  71. package/dist/login/components/InputTag.svelte.d.ts +7 -0
  72. package/dist/login/components/InputTagSelects.svelte +111 -0
  73. package/dist/login/components/InputTagSelects.svelte.d.ts +4 -0
  74. package/dist/login/components/LogoutOtherSessions.svelte +29 -0
  75. package/dist/login/components/LogoutOtherSessions.svelte.d.ts +10 -0
  76. package/dist/login/components/PasswordWrapper.svelte +43 -0
  77. package/dist/login/components/PasswordWrapper.svelte.d.ts +13 -0
  78. package/dist/login/components/SelectTag.svelte +72 -0
  79. package/dist/login/components/SelectTag.svelte.d.ts +4 -0
  80. package/dist/login/components/TermsAcceptance.svelte +56 -0
  81. package/dist/login/components/TermsAcceptance.svelte.d.ts +13 -0
  82. package/dist/login/components/TextareaTag.svelte +40 -0
  83. package/dist/login/components/TextareaTag.svelte.d.ts +4 -0
  84. package/dist/login/components/UserProfileFormFields.svelte +123 -0
  85. package/dist/login/components/UserProfileFormFields.svelte.d.ts +6 -0
  86. package/dist/login/components/UserProfileFormFieldsProps.d.ts +27 -0
  87. package/dist/login/components/UserProfileFormFieldsProps.js +2 -0
  88. package/dist/login/components/inputLabel.d.ts +3 -0
  89. package/dist/login/components/inputLabel.js +12 -0
  90. package/dist/login/i18n/i18n.d.ts +15 -0
  91. package/dist/login/i18n/i18n.js +1 -0
  92. package/dist/login/i18n/i18nBuilder.d.ts +18 -0
  93. package/dist/login/i18n/i18nBuilder.js +26 -0
  94. package/dist/login/i18n/index.d.ts +1 -0
  95. package/dist/login/i18n/index.js +1 -0
  96. package/dist/login/i18n/useI18n.d.ts +28 -0
  97. package/dist/login/i18n/useI18n.js +65 -0
  98. package/dist/login/index.d.ts +2 -0
  99. package/dist/login/index.js +1 -0
  100. package/dist/login/lib/useUserProfileForm.d.ts +66 -0
  101. package/dist/login/lib/useUserProfileForm.js +63 -0
  102. package/dist/login/pages/Code.svelte +46 -0
  103. package/dist/login/pages/Code.svelte.d.ts +6 -0
  104. package/dist/login/pages/DeleteAccountConfirm.svelte +77 -0
  105. package/dist/login/pages/DeleteAccountConfirm.svelte.d.ts +6 -0
  106. package/dist/login/pages/DeleteCredential.svelte +58 -0
  107. package/dist/login/pages/DeleteCredential.svelte.d.ts +6 -0
  108. package/dist/login/pages/Error.svelte +43 -0
  109. package/dist/login/pages/Error.svelte.d.ts +6 -0
  110. package/dist/login/pages/FrontchannelLogout.svelte +57 -0
  111. package/dist/login/pages/FrontchannelLogout.svelte.d.ts +6 -0
  112. package/dist/login/pages/IdpReviewUserProfile.svelte +80 -0
  113. package/dist/login/pages/IdpReviewUserProfile.svelte.d.ts +11 -0
  114. package/dist/login/pages/Info.svelte +66 -0
  115. package/dist/login/pages/Info.svelte.d.ts +6 -0
  116. package/dist/login/pages/Login.svelte +225 -0
  117. package/dist/login/pages/Login.svelte.d.ts +6 -0
  118. package/dist/login/pages/LoginConfigTotp.svelte +217 -0
  119. package/dist/login/pages/LoginConfigTotp.svelte.d.ts +6 -0
  120. package/dist/login/pages/LoginIdpLinkConfirm.svelte +60 -0
  121. package/dist/login/pages/LoginIdpLinkConfirm.svelte.d.ts +6 -0
  122. package/dist/login/pages/LoginIdpLinkConfirmOverride.svelte +59 -0
  123. package/dist/login/pages/LoginIdpLinkConfirmOverride.svelte.d.ts +6 -0
  124. package/dist/login/pages/LoginIdpLinkEmail.svelte +50 -0
  125. package/dist/login/pages/LoginIdpLinkEmail.svelte.d.ts +6 -0
  126. package/dist/login/pages/LoginOauth2DeviceVerifyUserCode.svelte +85 -0
  127. package/dist/login/pages/LoginOauth2DeviceVerifyUserCode.svelte.d.ts +6 -0
  128. package/dist/login/pages/LoginOauthGrant.svelte +126 -0
  129. package/dist/login/pages/LoginOauthGrant.svelte.d.ts +6 -0
  130. package/dist/login/pages/LoginOtp.svelte +128 -0
  131. package/dist/login/pages/LoginOtp.svelte.d.ts +6 -0
  132. package/dist/login/pages/LoginPageExpired.svelte +50 -0
  133. package/dist/login/pages/LoginPageExpired.svelte.d.ts +6 -0
  134. package/dist/login/pages/LoginPasskeysConditionalAuthenticate.svelte +240 -0
  135. package/dist/login/pages/LoginPasskeysConditionalAuthenticate.svelte.d.ts +6 -0
  136. package/dist/login/pages/LoginPasskeysConditionalAuthenticate.useScript.d.ts +21 -0
  137. package/dist/login/pages/LoginPasskeysConditionalAuthenticate.useScript.js +57 -0
  138. package/dist/login/pages/LoginPassword.svelte +120 -0
  139. package/dist/login/pages/LoginPassword.svelte.d.ts +6 -0
  140. package/dist/login/pages/LoginRecoveryAuthnCodeConfig.svelte +179 -0
  141. package/dist/login/pages/LoginRecoveryAuthnCodeConfig.svelte.d.ts +6 -0
  142. package/dist/login/pages/LoginRecoveryAuthnCodeConfig.useScript.d.ts +10 -0
  143. package/dist/login/pages/LoginRecoveryAuthnCodeConfig.useScript.js +141 -0
  144. package/dist/login/pages/LoginRecoveryAuthnCodeInput.svelte +94 -0
  145. package/dist/login/pages/LoginRecoveryAuthnCodeInput.svelte.d.ts +6 -0
  146. package/dist/login/pages/LoginResetOtp.svelte +86 -0
  147. package/dist/login/pages/LoginResetOtp.svelte.d.ts +6 -0
  148. package/dist/login/pages/LoginResetPassword.svelte +109 -0
  149. package/dist/login/pages/LoginResetPassword.svelte.d.ts +6 -0
  150. package/dist/login/pages/LoginUpdatePassword.svelte +149 -0
  151. package/dist/login/pages/LoginUpdatePassword.svelte.d.ts +6 -0
  152. package/dist/login/pages/LoginUpdateProfile.svelte +98 -0
  153. package/dist/login/pages/LoginUpdateProfile.svelte.d.ts +11 -0
  154. package/dist/login/pages/LoginUsername.svelte +182 -0
  155. package/dist/login/pages/LoginUsername.svelte.d.ts +6 -0
  156. package/dist/login/pages/LoginVerifyEmail.svelte +39 -0
  157. package/dist/login/pages/LoginVerifyEmail.svelte.d.ts +6 -0
  158. package/dist/login/pages/LoginX509Info.svelte +123 -0
  159. package/dist/login/pages/LoginX509Info.svelte.d.ts +6 -0
  160. package/dist/login/pages/LogoutConfirm.svelte +77 -0
  161. package/dist/login/pages/LogoutConfirm.svelte.d.ts +6 -0
  162. package/dist/login/pages/PageProps.d.ts +10 -0
  163. package/dist/login/pages/PageProps.js +1 -0
  164. package/dist/login/pages/Register.svelte +136 -0
  165. package/dist/login/pages/Register.svelte.d.ts +11 -0
  166. package/dist/login/pages/SamlPostForm.svelte +80 -0
  167. package/dist/login/pages/SamlPostForm.svelte.d.ts +6 -0
  168. package/dist/login/pages/SelectAuthenticator.svelte +63 -0
  169. package/dist/login/pages/SelectAuthenticator.svelte.d.ts +6 -0
  170. package/dist/login/pages/Terms.svelte +57 -0
  171. package/dist/login/pages/Terms.svelte.d.ts +6 -0
  172. package/dist/login/pages/UpdateEmail.svelte +104 -0
  173. package/dist/login/pages/UpdateEmail.svelte.d.ts +11 -0
  174. package/dist/login/pages/WebauthnAuthenticate.svelte +182 -0
  175. package/dist/login/pages/WebauthnAuthenticate.svelte.d.ts +6 -0
  176. package/dist/login/pages/WebauthnAuthenticate.useScript.d.ts +22 -0
  177. package/dist/login/pages/WebauthnAuthenticate.useScript.js +49 -0
  178. package/dist/login/pages/WebauthnError.svelte +86 -0
  179. package/dist/login/pages/WebauthnError.svelte.d.ts +6 -0
  180. package/dist/login/pages/WebauthnRegister.svelte +109 -0
  181. package/dist/login/pages/WebauthnRegister.svelte.d.ts +6 -0
  182. package/dist/login/pages/WebauthnRegister.useScript.d.ts +28 -0
  183. package/dist/login/pages/WebauthnRegister.useScript.js +57 -0
  184. package/dist/tools/useConst.d.ts +1 -0
  185. package/dist/tools/useConst.js +4 -0
  186. package/dist/tools/useInsertLinkTags.d.ts +12 -0
  187. package/dist/tools/useInsertLinkTags.js +62 -0
  188. package/dist/tools/useInsertScriptTags.d.ts +29 -0
  189. package/dist/tools/useInsertScriptTags.js +77 -0
  190. package/dist/tools/useReducer.d.ts +2 -0
  191. package/dist/tools/useReducer.js +7 -0
  192. package/dist/tools/useSetClassName.d.ts +4 -0
  193. package/dist/tools/useSetClassName.js +15 -0
  194. package/dist/tools/useState.d.ts +2 -0
  195. package/dist/tools/useState.js +7 -0
  196. package/package.json +468 -0
  197. package/src/account/DefaultPage.svelte +42 -0
  198. package/src/account/KcContext/KcContext.ts +1 -0
  199. package/src/account/KcContext/index.ts +1 -0
  200. package/src/account/Template.svelte +143 -0
  201. package/src/account/Template.useInitialize.ts +32 -0
  202. package/src/account/TemplateProps.ts +15 -0
  203. package/src/account/i18n/i18n.ts +18 -0
  204. package/src/account/i18n/i18nBuilder.ts +101 -0
  205. package/src/account/i18n/index.ts +1 -0
  206. package/src/account/i18n/useI18n.ts +140 -0
  207. package/src/account/index.ts +2 -0
  208. package/src/account/pages/Account.svelte +182 -0
  209. package/src/account/pages/Applications.svelte +173 -0
  210. package/src/account/pages/FederatedIdentity.svelte +114 -0
  211. package/src/account/pages/Log.svelte +68 -0
  212. package/src/account/pages/PageProps.ts +11 -0
  213. package/src/account/pages/Password.svelte +233 -0
  214. package/src/account/pages/Sessions.svelte +88 -0
  215. package/src/account/pages/Totp.svelte +287 -0
  216. package/src/additional-svelte-typings.d.ts +6 -0
  217. package/src/login/DefaultPage.svelte +135 -0
  218. package/src/login/KcContext/KcContext.ts +1 -0
  219. package/src/login/KcContext/index.ts +1 -0
  220. package/src/login/Template.svelte +223 -0
  221. package/src/login/Template.useInitialize.ts +72 -0
  222. package/src/login/TemplateProps.ts +23 -0
  223. package/src/login/components/AddRemoveButtonsMultiValuedAttribute.svelte +57 -0
  224. package/src/login/components/FieldErrors.svelte +31 -0
  225. package/src/login/components/GroupLabel.svelte +68 -0
  226. package/src/login/components/InputFieldByType.svelte +58 -0
  227. package/src/login/components/InputFieldByTypeProps.ts +15 -0
  228. package/src/login/components/InputTag.svelte +107 -0
  229. package/src/login/components/InputTagSelects.svelte +111 -0
  230. package/src/login/components/LogoutOtherSessions.svelte +29 -0
  231. package/src/login/components/PasswordWrapper.svelte +43 -0
  232. package/src/login/components/SelectTag.svelte +72 -0
  233. package/src/login/components/TermsAcceptance.svelte +56 -0
  234. package/src/login/components/TextareaTag.svelte +40 -0
  235. package/src/login/components/UserProfileFormFields.svelte +123 -0
  236. package/src/login/components/UserProfileFormFieldsProps.ts +25 -0
  237. package/src/login/components/inputLabel.ts +19 -0
  238. package/src/login/i18n/i18n.ts +18 -0
  239. package/src/login/i18n/i18nBuilder.ts +101 -0
  240. package/src/login/i18n/index.ts +1 -0
  241. package/src/login/i18n/useI18n.ts +140 -0
  242. package/src/login/index.ts +2 -0
  243. package/src/login/lib/useUserProfileForm.ts +166 -0
  244. package/src/login/pages/Code.svelte +46 -0
  245. package/src/login/pages/DeleteAccountConfirm.svelte +77 -0
  246. package/src/login/pages/DeleteCredential.svelte +58 -0
  247. package/src/login/pages/Error.svelte +43 -0
  248. package/src/login/pages/FrontchannelLogout.svelte +57 -0
  249. package/src/login/pages/IdpReviewUserProfile.svelte +80 -0
  250. package/src/login/pages/Info.svelte +66 -0
  251. package/src/login/pages/Login.svelte +225 -0
  252. package/src/login/pages/LoginConfigTotp.svelte +217 -0
  253. package/src/login/pages/LoginIdpLinkConfirm.svelte +60 -0
  254. package/src/login/pages/LoginIdpLinkConfirmOverride.svelte +59 -0
  255. package/src/login/pages/LoginIdpLinkEmail.svelte +50 -0
  256. package/src/login/pages/LoginOauth2DeviceVerifyUserCode.svelte +85 -0
  257. package/src/login/pages/LoginOauthGrant.svelte +126 -0
  258. package/src/login/pages/LoginOtp.svelte +128 -0
  259. package/src/login/pages/LoginPageExpired.svelte +50 -0
  260. package/src/login/pages/LoginPasskeysConditionalAuthenticate.svelte +240 -0
  261. package/src/login/pages/LoginPasskeysConditionalAuthenticate.useScript.ts +82 -0
  262. package/src/login/pages/LoginPassword.svelte +120 -0
  263. package/src/login/pages/LoginRecoveryAuthnCodeConfig.svelte +179 -0
  264. package/src/login/pages/LoginRecoveryAuthnCodeConfig.useScript.ts +157 -0
  265. package/src/login/pages/LoginRecoveryAuthnCodeInput.svelte +94 -0
  266. package/src/login/pages/LoginResetOtp.svelte +86 -0
  267. package/src/login/pages/LoginResetPassword.svelte +109 -0
  268. package/src/login/pages/LoginUpdatePassword.svelte +149 -0
  269. package/src/login/pages/LoginUpdateProfile.svelte +98 -0
  270. package/src/login/pages/LoginUsername.svelte +182 -0
  271. package/src/login/pages/LoginVerifyEmail.svelte +39 -0
  272. package/src/login/pages/LoginX509Info.svelte +123 -0
  273. package/src/login/pages/LogoutConfirm.svelte +77 -0
  274. package/src/login/pages/PageProps.ts +11 -0
  275. package/src/login/pages/Register.svelte +136 -0
  276. package/src/login/pages/SamlPostForm.svelte +80 -0
  277. package/src/login/pages/SelectAuthenticator.svelte +63 -0
  278. package/src/login/pages/Terms.svelte +57 -0
  279. package/src/login/pages/UpdateEmail.svelte +104 -0
  280. package/src/login/pages/WebauthnAuthenticate.svelte +182 -0
  281. package/src/login/pages/WebauthnAuthenticate.useScript.ts +74 -0
  282. package/src/login/pages/WebauthnError.svelte +86 -0
  283. package/src/login/pages/WebauthnRegister.svelte +109 -0
  284. package/src/login/pages/WebauthnRegister.useScript.ts +107 -0
@@ -0,0 +1,120 @@
1
+ <script lang="ts">
2
+ import PasswordWrapper from '@keycloakify/svelte/login/components/PasswordWrapper.svelte';
3
+ import type { PageProps } from '@keycloakify/svelte/login/pages/PageProps';
4
+ import { useState } from '@keycloakify/svelte/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,179 @@
1
+ <script lang="ts">
2
+ import LogoutOtherSessions from '@keycloakify/svelte/login/components/LogoutOtherSessions.svelte';
3
+ import { useScript } from '@keycloakify/svelte/login/pages/LoginRecoveryAuthnCodeConfig.useScript';
4
+ import type { PageProps } from '@keycloakify/svelte/login/pages/PageProps';
5
+ import { getKcClsx } from 'keycloakify/login/lib/kcClsx';
6
+ import { clsx } from 'keycloakify/tools/clsx';
7
+ import type { I18n } from '../i18n';
8
+ import type { KcContext } from '../KcContext';
9
+
10
+ const {
11
+ Template,
12
+ kcContext,
13
+ i18n,
14
+ doUseDefaultCss,
15
+ classes,
16
+ }: PageProps<Extract<KcContext, { pageId: 'login-recovery-authn-code-config.ftl' }>, I18n> = $props();
17
+
18
+ const { kcClsx } = getKcClsx({
19
+ doUseDefaultCss,
20
+ classes,
21
+ });
22
+
23
+ const { recoveryAuthnCodesConfigBean, isAppInitiatedAction } = kcContext;
24
+
25
+ const { msg, msgStr } = $i18n;
26
+
27
+ const olRecoveryCodesListId = 'kc-recovery-codes-list';
28
+
29
+ useScript({ olRecoveryCodesListId, i18n });
30
+ </script>
31
+
32
+ <Template
33
+ {kcContext}
34
+ {i18n}
35
+ {doUseDefaultCss}
36
+ {classes}
37
+ >
38
+ {#snippet headerNode()}
39
+ {@render msg('recovery-code-config-header')()}
40
+ {/snippet}
41
+ <div
42
+ class={clsx('pf-c-alert', 'pf-m-warning', 'pf-m-inline', kcClsx('kcRecoveryCodesWarning'))}
43
+ aria-label="Warning alert"
44
+ >
45
+ <div class="pf-c-alert__icon">
46
+ <i
47
+ class="pficon-warning-triangle-o"
48
+ aria-hidden="true"
49
+ ></i>
50
+ </div>
51
+ <h4 class="pf-c-alert__title">
52
+ <span class="pf-screen-reader">Warning alert:</span>
53
+ {@render msg('recovery-code-config-warning-title')()}
54
+ </h4>
55
+ <div class="pf-c-alert__description">
56
+ <p>{@render msg('recovery-code-config-warning-message')()}</p>
57
+ </div>
58
+ </div>
59
+
60
+ <ol
61
+ id={olRecoveryCodesListId}
62
+ class={kcClsx('kcRecoveryCodesList')}
63
+ >
64
+ {#each recoveryAuthnCodesConfigBean.generatedRecoveryAuthnCodesList as code, index}
65
+ <li>
66
+ <span>{index + 1}:</span>
67
+ {code.slice(0, 4)}-{code.slice(4, 8)}-{code.slice(8)}
68
+ </li>
69
+ {/each}
70
+ </ol>
71
+
72
+ <!-- actions -->
73
+ <div class={kcClsx('kcRecoveryCodesActions')}>
74
+ <button
75
+ id="printRecoveryCodes"
76
+ class={clsx('pf-c-button', 'pf-m-link')}
77
+ type="button"
78
+ >
79
+ <i
80
+ class="pficon-print"
81
+ aria-hidden="true"
82
+ ></i>
83
+ {@render msg('recovery-codes-print')()}
84
+ </button>
85
+ <button
86
+ id="downloadRecoveryCodes"
87
+ class={clsx('pf-c-button', 'pf-m-link')}
88
+ type="button"
89
+ >
90
+ <i
91
+ class="pficon-save"
92
+ aria-hidden="true"
93
+ ></i>
94
+ {@render msg('recovery-codes-download')()}
95
+ </button>
96
+ <button
97
+ id="copyRecoveryCodes"
98
+ class={clsx('pf-c-button', 'pf-m-link')}
99
+ type="button"
100
+ >
101
+ <i
102
+ class="pficon-blueprint"
103
+ aria-hidden="true"
104
+ ></i>
105
+ {@render msg('recovery-codes-copy')()}
106
+ </button>
107
+ </div>
108
+
109
+ <!-- confirmation checkbox -->
110
+ <div class={kcClsx('kcFormOptionsClass')}>
111
+ <input
112
+ class={kcClsx('kcCheckInputClass')}
113
+ type="checkbox"
114
+ id="kcRecoveryCodesConfirmationCheck"
115
+ name="kcRecoveryCodesConfirmationCheck"
116
+ onchange={(event) => {
117
+ //@ts-expect-error: This is inherited from the original code
118
+ document.getElementById('saveRecoveryAuthnCodesBtn').disabled = !event.currentTarget.checked;
119
+ }}
120
+ />
121
+ <label for="kcRecoveryCodesConfirmationCheck">{@render msg('recovery-codes-confirmation-message')()}</label>
122
+ </div>
123
+
124
+ <form
125
+ action={kcContext.url.loginAction}
126
+ class={kcClsx('kcFormGroupClass')}
127
+ id="kc-recovery-codes-settings-form"
128
+ method="post"
129
+ >
130
+ <input
131
+ type="hidden"
132
+ name="generatedRecoveryAuthnCodes"
133
+ value={recoveryAuthnCodesConfigBean.generatedRecoveryAuthnCodesAsString}
134
+ />
135
+ <input
136
+ type="hidden"
137
+ name="generatedAt"
138
+ value={recoveryAuthnCodesConfigBean.generatedAt}
139
+ />
140
+ <input
141
+ type="hidden"
142
+ id="userLabel"
143
+ name="userLabel"
144
+ value={msgStr('recovery-codes-label-default')}
145
+ />
146
+
147
+ <LogoutOtherSessions
148
+ {kcClsx}
149
+ {i18n}
150
+ />
151
+
152
+ {#if isAppInitiatedAction}
153
+ <input
154
+ type="submit"
155
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass')}
156
+ id="saveRecoveryAuthnCodesBtn"
157
+ value={msgStr('recovery-codes-action-complete')}
158
+ disabled
159
+ />
160
+ <button
161
+ type="submit"
162
+ class={kcClsx('kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass')}
163
+ id="cancelRecoveryAuthnCodesBtn"
164
+ name="cancel-aia"
165
+ value="true"
166
+ >
167
+ {@render msg('recovery-codes-action-cancel')()}
168
+ </button>
169
+ {:else}
170
+ <input
171
+ type="submit"
172
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
173
+ id="saveRecoveryAuthnCodesBtn"
174
+ value={msgStr('recovery-codes-action-complete')}
175
+ disabled
176
+ />
177
+ {/if}
178
+ </form>
179
+ </Template>
@@ -0,0 +1,157 @@
1
+ import { useInsertScriptTags } from '@keycloakify/svelte/tools/useInsertScriptTags';
2
+ import { waitForElementMountedOnDom } from 'keycloakify/tools/waitForElementMountedOnDom';
3
+ import { onMount } from 'svelte';
4
+ import type { Readable } from 'svelte/store';
5
+
6
+ type I18nLike = {
7
+ msgStr: (
8
+ key:
9
+ | 'recovery-codes-download-file-header'
10
+ | 'recovery-codes-download-file-description'
11
+ | 'recovery-codes-download-file-date',
12
+ ) => string;
13
+ isFetchingTranslations: boolean;
14
+ };
15
+
16
+ export function useScript(params: { olRecoveryCodesListId: string; i18n: Readable<I18nLike> }) {
17
+ const { olRecoveryCodesListId, i18n } = params;
18
+
19
+ onMount(() => {
20
+ const unsubscribe = i18n.subscribe(($i18n) => {
21
+ const { msgStr, isFetchingTranslations } = $i18n;
22
+
23
+ const { insertScriptTags } = useInsertScriptTags({
24
+ componentOrHookName: 'LoginRecoveryAuthnCodeConfig',
25
+ scriptTags: [
26
+ {
27
+ type: 'text/javascript',
28
+ textContent: () => `
29
+
30
+ /* copy recovery codes */
31
+ function copyRecoveryCodes() {
32
+ var tmpTextarea = document.createElement("textarea");
33
+ var codes = document.querySelectorAll("#${olRecoveryCodesListId} li");
34
+ for (i = 0; i < codes.length; i++) {
35
+ tmpTextarea.value = tmpTextarea.value + codes[i].innerText + "\\n";
36
+ }
37
+ document.body.appendChild(tmpTextarea);
38
+ tmpTextarea.select();
39
+ document.execCommand("copy");
40
+ document.body.removeChild(tmpTextarea);
41
+ }
42
+
43
+ var copyButton = document.getElementById("copyRecoveryCodes");
44
+ copyButton && copyButton.addEventListener("click", function () {
45
+ copyRecoveryCodes();
46
+ });
47
+
48
+ /* download recovery codes */
49
+ function formatCurrentDateTime() {
50
+ var dt = new Date();
51
+ var options = {
52
+ month: 'long',
53
+ day: 'numeric',
54
+ year: 'numeric',
55
+ hour: 'numeric',
56
+ minute: 'numeric',
57
+ timeZoneName: 'short'
58
+ };
59
+
60
+ return dt.toLocaleString('en-US', options);
61
+ }
62
+
63
+ function parseRecoveryCodeList() {
64
+ var recoveryCodes = document.querySelectorAll("#${olRecoveryCodesListId} li");
65
+ var recoveryCodeList = "";
66
+
67
+ for (var i = 0; i < recoveryCodes.length; i++) {
68
+ var recoveryCodeLiElement = recoveryCodes[i].innerText;
69
+ recoveryCodeList += recoveryCodeLiElement + "\\r\\n";
70
+ }
71
+
72
+ return recoveryCodeList;
73
+ }
74
+
75
+ function buildDownloadContent() {
76
+ var recoveryCodeList = parseRecoveryCodeList();
77
+ var dt = new Date();
78
+ var options = {
79
+ month: 'long',
80
+ day: 'numeric',
81
+ year: 'numeric',
82
+ hour: 'numeric',
83
+ minute: 'numeric',
84
+ timeZoneName: 'short'
85
+ };
86
+
87
+ return fileBodyContent =
88
+ ${JSON.stringify(msgStr('recovery-codes-download-file-header'))} + "\\n\\n" +
89
+ recoveryCodeList + "\\n" +
90
+ ${JSON.stringify(msgStr('recovery-codes-download-file-description'))} + "\\n\\n" +
91
+ ${JSON.stringify(msgStr('recovery-codes-download-file-date'))} + " " + formatCurrentDateTime();
92
+ }
93
+
94
+ function setUpDownloadLinkAndDownload(filename, text) {
95
+ var el = document.createElement('a');
96
+ el.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(text));
97
+ el.setAttribute('download', filename);
98
+ el.style.display = 'none';
99
+ document.body.appendChild(el);
100
+ el.click();
101
+ document.body.removeChild(el);
102
+ }
103
+
104
+ function downloadRecoveryCodes() {
105
+ setUpDownloadLinkAndDownload('kc-download-recovery-codes.txt', buildDownloadContent());
106
+ }
107
+
108
+ var downloadButton = document.getElementById("downloadRecoveryCodes");
109
+ downloadButton && downloadButton.addEventListener("click", downloadRecoveryCodes);
110
+
111
+ /* print recovery codes */
112
+ function buildPrintContent() {
113
+ var recoveryCodeListHTML = document.getElementById('${olRecoveryCodesListId}').innerHTML;
114
+ var styles =
115
+ \`@page { size: auto; margin-top: 0; }
116
+ body { width: 480px; }
117
+ div { list-style-type: none; font-family: monospace }
118
+ p:first-of-type { margin-top: 48px }\`;
119
+
120
+ return printFileContent =
121
+ "<html><style>" + styles + "</style><body>" +
122
+ "<title>kc-download-recovery-codes</title>" +
123
+ "<p>" + ${JSON.stringify(msgStr('recovery-codes-download-file-header'))} + "</p>" +
124
+ "<div>" + recoveryCodeListHTML + "</div>" +
125
+ "<p>" + ${JSON.stringify(msgStr('recovery-codes-download-file-description'))} + "</p>" +
126
+ "<p>" + ${JSON.stringify(msgStr('recovery-codes-download-file-date'))} + " " + formatCurrentDateTime() + "</p>" +
127
+ "</body></html>";
128
+ }
129
+
130
+ function printRecoveryCodes() {
131
+ var w = window.open();
132
+ w.document.write(buildPrintContent());
133
+ w.print();
134
+ w.close();
135
+ }
136
+
137
+ var printButton = document.getElementById("printRecoveryCodes");
138
+ printButton && printButton.addEventListener("click", printRecoveryCodes);
139
+ `,
140
+ },
141
+ ],
142
+ });
143
+ if (isFetchingTranslations) {
144
+ return;
145
+ }
146
+
147
+ (async () => {
148
+ await waitForElementMountedOnDom({
149
+ elementId: olRecoveryCodesListId,
150
+ });
151
+
152
+ insertScriptTags();
153
+ })();
154
+ });
155
+ return () => unsubscribe();
156
+ });
157
+ }
@@ -0,0 +1,94 @@
1
+ <script lang="ts">
2
+ import type { PageProps } from '@keycloakify/svelte/login/pages/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-recovery-authn-code-input.ftl' }>, I18n> = $props();
15
+
16
+ const { kcClsx } = getKcClsx({
17
+ doUseDefaultCss,
18
+ classes,
19
+ });
20
+
21
+ const { url, messagesPerField, recoveryAuthnCodesInputBean } = kcContext;
22
+
23
+ const { msg, msgStr } = $i18n;
24
+ </script>
25
+
26
+ <Template
27
+ {kcContext}
28
+ {i18n}
29
+ {doUseDefaultCss}
30
+ {classes}
31
+ displayMessage={!messagesPerField.existsError('recoveryCodeInput')}
32
+ >
33
+ {#snippet headerNode()}
34
+ {@render msg('auth-recovery-code-header')()}
35
+ {/snippet}
36
+ <form
37
+ id="kc-recovery-code-login-form"
38
+ class={kcClsx('kcFormClass')}
39
+ action={url.loginAction}
40
+ method="post"
41
+ >
42
+ <div class={kcClsx('kcFormGroupClass')}>
43
+ <div class={kcClsx('kcLabelWrapperClass')}>
44
+ <label
45
+ for="recoveryCodeInput"
46
+ class={kcClsx('kcLabelClass')}
47
+ >
48
+ {@render msg('auth-recovery-code-prompt', `${recoveryAuthnCodesInputBean.codeNumber}`)()}
49
+ </label>
50
+ </div>
51
+ <div class={kcClsx('kcInputWrapperClass')}>
52
+ <!-- svelte-ignore a11y_autofocus -->
53
+ <input
54
+ tabindex={1}
55
+ id="recoveryCodeInput"
56
+ name="recoveryCodeInput"
57
+ aria-invalid={messagesPerField.existsError('recoveryCodeInput')}
58
+ autocomplete="off"
59
+ type="text"
60
+ class={kcClsx('kcInputClass')}
61
+ autofocus
62
+ />
63
+ {#if messagesPerField.existsError('recoveryCodeInput')}
64
+ <span
65
+ id="input-error"
66
+ class={kcClsx('kcInputErrorMessageClass')}
67
+ aria-live="polite">{@html kcSanitize(messagesPerField.get('recoveryCodeInput'))}</span
68
+ >
69
+ {/if}
70
+ </div>
71
+ </div>
72
+
73
+ <div class={kcClsx('kcFormGroupClass')}>
74
+ <div
75
+ id="kc-form-options"
76
+ class={kcClsx('kcFormOptionsWrapperClass')}
77
+ >
78
+ <div class={kcClsx('kcFormOptionsWrapperClass')}></div>
79
+ </div>
80
+ <div
81
+ id="kc-form-buttons"
82
+ class={kcClsx('kcFormButtonsClass')}
83
+ >
84
+ <input
85
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
86
+ name="login"
87
+ id="kc-login"
88
+ type="submit"
89
+ value={msgStr('doLogIn')}
90
+ />
91
+ </div>
92
+ </div>
93
+ </form>
94
+ </Template>
@@ -0,0 +1,86 @@
1
+ <script lang="ts">
2
+ import type { PageProps } from '@keycloakify/svelte/login/pages/PageProps';
3
+ import { getKcClsx } from 'keycloakify/login/lib/kcClsx';
4
+ import type { KcContext } from '../KcContext';
5
+ import type { I18n } from '../i18n';
6
+
7
+ const {
8
+ Template,
9
+ kcContext,
10
+ i18n,
11
+ doUseDefaultCss,
12
+ classes,
13
+ }: PageProps<Extract<KcContext, { pageId: 'login-reset-otp.ftl' }>, I18n> = $props();
14
+
15
+ const { kcClsx } = getKcClsx({
16
+ doUseDefaultCss,
17
+ classes,
18
+ });
19
+
20
+ const { url, messagesPerField, configuredOtpCredentials } = kcContext;
21
+
22
+ const { msg, msgStr } = $i18n;
23
+ </script>
24
+
25
+ <Template
26
+ {kcContext}
27
+ {i18n}
28
+ {doUseDefaultCss}
29
+ {classes}
30
+ displayMessage={!messagesPerField.existsError('totp')}
31
+ >
32
+ {#snippet headerNode()}
33
+ {@render msg('doLogIn')()}
34
+ {/snippet}
35
+ <form
36
+ id="kc-otp-reset-form"
37
+ class={kcClsx('kcFormClass')}
38
+ action={url.loginAction}
39
+ method="post"
40
+ >
41
+ <div class={kcClsx('kcInputWrapperClass')}>
42
+ <div class={kcClsx('kcInfoAreaWrapperClass')}>
43
+ <p id="kc-otp-reset-form-description">{msg('otp-reset-description')}</p>
44
+ {#each configuredOtpCredentials.userOtpCredentials as otpCredential, index}
45
+ <input
46
+ id={`kc-otp-credential-${index}`}
47
+ class={kcClsx('kcLoginOTPListInputClass')}
48
+ type="radio"
49
+ name="selectedCredentialId"
50
+ value={otpCredential.id}
51
+ checked={otpCredential.id === configuredOtpCredentials.selectedCredentialId}
52
+ />
53
+ <!-- svelte-ignore a11y_no_noninteractive_tabindex -->
54
+ <label
55
+ for={`kc-otp-credential-${index}`}
56
+ class={kcClsx('kcLoginOTPListClass')}
57
+ tabindex={index}
58
+ >
59
+ <span class={kcClsx('kcLoginOTPListItemHeaderClass')}>
60
+ <span class={kcClsx('kcLoginOTPListItemIconBodyClass')}>
61
+ <i
62
+ class={kcClsx('kcLoginOTPListItemIconClass')}
63
+ aria-hidden="true"
64
+ ></i>
65
+ </span>
66
+ <span class={kcClsx('kcLoginOTPListItemTitleClass')}>{otpCredential.userLabel}</span>
67
+ </span>
68
+ </label>
69
+ {/each}
70
+ <div class={kcClsx('kcFormGroupClass')}>
71
+ <div
72
+ id="kc-form-buttons"
73
+ class={kcClsx('kcFormButtonsClass')}
74
+ >
75
+ <input
76
+ id="kc-otp-reset-form-submit"
77
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
78
+ type="submit"
79
+ value={msgStr('doSubmit')}
80
+ />
81
+ </div>
82
+ </div>
83
+ </div>
84
+ </div>
85
+ </form>
86
+ </Template>