@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,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;
@@ -0,0 +1,179 @@
1
+ <script lang="ts">
2
+ import LogoutOtherSessions from '../components/LogoutOtherSessions.svelte';
3
+ import { useScript } from './LoginRecoveryAuthnCodeConfig.useScript';
4
+ import type { PageProps } from './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,6 @@
1
+ import type { PageProps } from './PageProps';
2
+ import type { I18n } from '../i18n';
3
+ import type { KcContext } from '../KcContext';
4
+ declare const LoginRecoveryAuthnCodeConfig: import("svelte").Component<PageProps<KcContext.LoginRecoveryAuthnCodeConfig, I18n>, {}, "">;
5
+ type LoginRecoveryAuthnCodeConfig = ReturnType<typeof LoginRecoveryAuthnCodeConfig>;
6
+ export default LoginRecoveryAuthnCodeConfig;
@@ -0,0 +1,10 @@
1
+ import type { Readable } from 'svelte/store';
2
+ type I18nLike = {
3
+ msgStr: (key: 'recovery-codes-download-file-header' | 'recovery-codes-download-file-description' | 'recovery-codes-download-file-date') => string;
4
+ isFetchingTranslations: boolean;
5
+ };
6
+ export declare function useScript(params: {
7
+ olRecoveryCodesListId: string;
8
+ i18n: Readable<I18nLike>;
9
+ }): void;
10
+ export {};
@@ -0,0 +1,141 @@
1
+ import { useInsertScriptTags } from '../../tools/useInsertScriptTags';
2
+ import { waitForElementMountedOnDom } from 'keycloakify/tools/waitForElementMountedOnDom';
3
+ import { onMount } from 'svelte';
4
+ export function useScript(params) {
5
+ const { olRecoveryCodesListId, i18n } = params;
6
+ onMount(() => {
7
+ const unsubscribe = i18n.subscribe(($i18n) => {
8
+ const { msgStr, isFetchingTranslations } = $i18n;
9
+ const { insertScriptTags } = useInsertScriptTags({
10
+ componentOrHookName: 'LoginRecoveryAuthnCodeConfig',
11
+ scriptTags: [
12
+ {
13
+ type: 'text/javascript',
14
+ textContent: () => `
15
+
16
+ /* copy recovery codes */
17
+ function copyRecoveryCodes() {
18
+ var tmpTextarea = document.createElement("textarea");
19
+ var codes = document.querySelectorAll("#${olRecoveryCodesListId} li");
20
+ for (i = 0; i < codes.length; i++) {
21
+ tmpTextarea.value = tmpTextarea.value + codes[i].innerText + "\\n";
22
+ }
23
+ document.body.appendChild(tmpTextarea);
24
+ tmpTextarea.select();
25
+ document.execCommand("copy");
26
+ document.body.removeChild(tmpTextarea);
27
+ }
28
+
29
+ var copyButton = document.getElementById("copyRecoveryCodes");
30
+ copyButton && copyButton.addEventListener("click", function () {
31
+ copyRecoveryCodes();
32
+ });
33
+
34
+ /* download recovery codes */
35
+ function formatCurrentDateTime() {
36
+ var dt = new Date();
37
+ var options = {
38
+ month: 'long',
39
+ day: 'numeric',
40
+ year: 'numeric',
41
+ hour: 'numeric',
42
+ minute: 'numeric',
43
+ timeZoneName: 'short'
44
+ };
45
+
46
+ return dt.toLocaleString('en-US', options);
47
+ }
48
+
49
+ function parseRecoveryCodeList() {
50
+ var recoveryCodes = document.querySelectorAll("#${olRecoveryCodesListId} li");
51
+ var recoveryCodeList = "";
52
+
53
+ for (var i = 0; i < recoveryCodes.length; i++) {
54
+ var recoveryCodeLiElement = recoveryCodes[i].innerText;
55
+ recoveryCodeList += recoveryCodeLiElement + "\\r\\n";
56
+ }
57
+
58
+ return recoveryCodeList;
59
+ }
60
+
61
+ function buildDownloadContent() {
62
+ var recoveryCodeList = parseRecoveryCodeList();
63
+ var dt = new Date();
64
+ var options = {
65
+ month: 'long',
66
+ day: 'numeric',
67
+ year: 'numeric',
68
+ hour: 'numeric',
69
+ minute: 'numeric',
70
+ timeZoneName: 'short'
71
+ };
72
+
73
+ return fileBodyContent =
74
+ ${JSON.stringify(msgStr('recovery-codes-download-file-header'))} + "\\n\\n" +
75
+ recoveryCodeList + "\\n" +
76
+ ${JSON.stringify(msgStr('recovery-codes-download-file-description'))} + "\\n\\n" +
77
+ ${JSON.stringify(msgStr('recovery-codes-download-file-date'))} + " " + formatCurrentDateTime();
78
+ }
79
+
80
+ function setUpDownloadLinkAndDownload(filename, text) {
81
+ var el = document.createElement('a');
82
+ el.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(text));
83
+ el.setAttribute('download', filename);
84
+ el.style.display = 'none';
85
+ document.body.appendChild(el);
86
+ el.click();
87
+ document.body.removeChild(el);
88
+ }
89
+
90
+ function downloadRecoveryCodes() {
91
+ setUpDownloadLinkAndDownload('kc-download-recovery-codes.txt', buildDownloadContent());
92
+ }
93
+
94
+ var downloadButton = document.getElementById("downloadRecoveryCodes");
95
+ downloadButton && downloadButton.addEventListener("click", downloadRecoveryCodes);
96
+
97
+ /* print recovery codes */
98
+ function buildPrintContent() {
99
+ var recoveryCodeListHTML = document.getElementById('${olRecoveryCodesListId}').innerHTML;
100
+ var styles =
101
+ \`@page { size: auto; margin-top: 0; }
102
+ body { width: 480px; }
103
+ div { list-style-type: none; font-family: monospace }
104
+ p:first-of-type { margin-top: 48px }\`;
105
+
106
+ return printFileContent =
107
+ "<html><style>" + styles + "</style><body>" +
108
+ "<title>kc-download-recovery-codes</title>" +
109
+ "<p>" + ${JSON.stringify(msgStr('recovery-codes-download-file-header'))} + "</p>" +
110
+ "<div>" + recoveryCodeListHTML + "</div>" +
111
+ "<p>" + ${JSON.stringify(msgStr('recovery-codes-download-file-description'))} + "</p>" +
112
+ "<p>" + ${JSON.stringify(msgStr('recovery-codes-download-file-date'))} + " " + formatCurrentDateTime() + "</p>" +
113
+ "</body></html>";
114
+ }
115
+
116
+ function printRecoveryCodes() {
117
+ var w = window.open();
118
+ w.document.write(buildPrintContent());
119
+ w.print();
120
+ w.close();
121
+ }
122
+
123
+ var printButton = document.getElementById("printRecoveryCodes");
124
+ printButton && printButton.addEventListener("click", printRecoveryCodes);
125
+ `,
126
+ },
127
+ ],
128
+ });
129
+ if (isFetchingTranslations) {
130
+ return;
131
+ }
132
+ (async () => {
133
+ await waitForElementMountedOnDom({
134
+ elementId: olRecoveryCodesListId,
135
+ });
136
+ insertScriptTags();
137
+ })();
138
+ });
139
+ return () => unsubscribe();
140
+ });
141
+ }
@@ -0,0 +1,94 @@
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-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,6 @@
1
+ import type { PageProps } from './PageProps';
2
+ import type { KcContext } from '../KcContext';
3
+ import type { I18n } from '../i18n';
4
+ declare const LoginRecoveryAuthnCodeInput: import("svelte").Component<PageProps<KcContext.LoginRecoveryAuthnCodeInput, I18n>, {}, "">;
5
+ type LoginRecoveryAuthnCodeInput = ReturnType<typeof LoginRecoveryAuthnCodeInput>;
6
+ export default LoginRecoveryAuthnCodeInput;