@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,287 @@
1
+ <script lang="ts">
2
+ import type { PageProps } from '@keycloakify/svelte/account/pages/PageProps';
3
+ import type { KcContext } from '../KcContext';
4
+ import type { I18n } from '../i18n';
5
+ import { getKcClsx } from 'keycloakify/account/lib/kcClsx';
6
+ import { kcSanitize } from 'keycloakify/lib/kcSanitize';
7
+ import { clsx } from 'keycloakify/tools/clsx';
8
+
9
+ const {
10
+ kcContext,
11
+ i18n,
12
+ doUseDefaultCss,
13
+ Template,
14
+ classes,
15
+ }: PageProps<Extract<KcContext, { pageId: 'totp.ftl' }>, I18n> = $props();
16
+
17
+ const { kcClsx } = getKcClsx({
18
+ doUseDefaultCss,
19
+ classes,
20
+ });
21
+
22
+ const { totp, mode, url, messagesPerField, stateChecker } = kcContext;
23
+
24
+ const { msg, msgStr, advancedMsg } = $i18n;
25
+ </script>
26
+
27
+ <Template
28
+ {kcContext}
29
+ {i18n}
30
+ {doUseDefaultCss}
31
+ {classes}
32
+ active="totp"
33
+ >
34
+ <div class="row">
35
+ <div class="col-md-10">
36
+ <h2>{@render msg('authenticatorTitle')()}</h2>
37
+ </div>
38
+ {#if totp.otpCredentials.length === 0}
39
+ <div class="subtitle col-md-2">
40
+ <span class="required">*</span>
41
+ {@render msg('requiredFields')()}
42
+ </div>
43
+ {/if}
44
+ </div>
45
+ {#if totp.enabled}
46
+ <table class="table table-bordered table-striped">
47
+ <thead>
48
+ {#if totp.otpCredentials.length > 1}
49
+ <tr>
50
+ <th colspan={4}>{@render msg('configureAuthenticators')()}</th>
51
+ </tr>
52
+ {:else}
53
+ <tr>
54
+ <th colspan={3}>{@render msg('configureAuthenticators')()}</th>
55
+ </tr>
56
+ {/if}
57
+ </thead>
58
+ <tbody>
59
+ {#each totp.otpCredentials as credential, index}
60
+ <tr>
61
+ <td class="provider">{@render msg('mobile')()}</td>
62
+ {#if totp.otpCredentials.length > 1}<td class="provider">{credential.id}</td>{/if}
63
+ <td class="provider">{credential.userLabel || ''}</td>
64
+ <td class="action">
65
+ <form
66
+ action={url.totpUrl}
67
+ method="post"
68
+ class="form-inline"
69
+ >
70
+ <input
71
+ type="hidden"
72
+ id="stateChecker"
73
+ name="stateChecker"
74
+ value={stateChecker}
75
+ />
76
+ <input
77
+ type="hidden"
78
+ id="submitAction"
79
+ name="submitAction"
80
+ value="Delete"
81
+ />
82
+ <input
83
+ type="hidden"
84
+ id="credentialId"
85
+ name="credentialId"
86
+ value={credential.id}
87
+ />
88
+ <button
89
+ id={`remove-mobile-${index}`}
90
+ class="btn btn-default"
91
+ aria-label="delete"
92
+ >
93
+ <i class="pficon pficon-delete"></i>
94
+ </button>
95
+ </form>
96
+ </td>
97
+ </tr>
98
+ {/each}
99
+ </tbody>
100
+ </table>
101
+ {/if}
102
+ {#if !totp.enabled}
103
+ <div>
104
+ <hr />
105
+ <ol id="kc-totp-settings">
106
+ <li>
107
+ <p>{@render msg('totpStep1')()}</p>
108
+
109
+ <ul id="kc-totp-supported-apps">
110
+ {#each totp.supportedApplications as app}
111
+ <li>{@render advancedMsg(app)()}</li>
112
+ {/each}
113
+ </ul>
114
+ </li>
115
+
116
+ {#if mode && mode == 'manual'}
117
+ <li>
118
+ <p>{@render msg('totpManualStep2')()}</p>
119
+ <p>
120
+ <span id="kc-totp-secret-key">{totp.totpSecretEncoded}</span>
121
+ </p>
122
+ <p>
123
+ <a
124
+ href={totp.qrUrl}
125
+ id="mode-barcode"
126
+ >
127
+ {@render msg('totpScanBarcode')()}
128
+ </a>
129
+ </p>
130
+ </li>
131
+ <li>
132
+ <p>{@render msg('totpManualStep3')()}</p>
133
+ <ul>
134
+ <li id="kc-totp-type">
135
+ {@render msg('totpType')()}: {@render msg(`totp.${totp.policy.type}`)()}
136
+ </li>
137
+ <li id="kc-totp-algorithm">
138
+ {@render msg('totpAlgorithm')()}: {totp.policy.getAlgorithmKey()}
139
+ </li>
140
+ <li id="kc-totp-digits">
141
+ {@render msg('totpDigits')()}: {totp.policy.digits}
142
+ </li>
143
+ {#if totp.policy.type === 'totp'}
144
+ <li id="kc-totp-period">
145
+ {@render msg('totpInterval')()}: {totp.policy.period}
146
+ </li>
147
+ {:else}
148
+ <li id="kc-totp-counter">
149
+ {@render msg('totpCounter')()}: {totp.policy.initialCounter}
150
+ </li>
151
+ {/if}
152
+ </ul>
153
+ </li>
154
+ {:else}
155
+ <li>
156
+ <p>{@render msg('totpStep2')()}</p>
157
+ <p>
158
+ <img
159
+ id="kc-totp-secret-qr-code"
160
+ src={`data:image/png;base64, ${totp.totpSecretQrCode}`}
161
+ alt="Figure: Barcode"
162
+ />
163
+ </p>
164
+ <p>
165
+ <a
166
+ href={totp.manualUrl}
167
+ id="mode-manual"
168
+ >
169
+ {@render msg('totpUnableToScan')()}
170
+ </a>
171
+ </p>
172
+ </li>
173
+ {/if}
174
+ <li>
175
+ <p>{@render msg('totpStep3')()}</p>
176
+ <p>{@render msg('totpStep3DeviceName')()}</p>
177
+ </li>
178
+ </ol>
179
+ <hr />
180
+ <form
181
+ action={url.totpUrl}
182
+ class={kcClsx('kcFormClass')}
183
+ id="kc-totp-settings-form"
184
+ method="post"
185
+ >
186
+ <input
187
+ type="hidden"
188
+ id="stateChecker"
189
+ name="stateChecker"
190
+ value={stateChecker}
191
+ />
192
+ <div class={kcClsx('kcFormGroupClass')}>
193
+ <div class="col-sm-2 col-md-2">
194
+ <label
195
+ for="totp"
196
+ class="control-label"
197
+ >
198
+ {@render msg('authenticatorCode')()}
199
+ </label>
200
+ <span class="required">*</span>
201
+ </div>
202
+ <div class="col-sm-10 col-md-10">
203
+ <input
204
+ type="text"
205
+ id="totp"
206
+ name="totp"
207
+ autocomplete="off"
208
+ class={kcClsx('kcInputClass')}
209
+ aria-invalid={messagesPerField.existsError('totp')}
210
+ />
211
+
212
+ {#if messagesPerField.existsError('totp')}
213
+ <span
214
+ id="input-error-otp-code"
215
+ class={kcClsx('kcInputErrorMessageClass')}
216
+ aria-live="polite">{@html kcSanitize(messagesPerField.get('totp'))}</span
217
+ >
218
+ {/if}
219
+ </div>
220
+ <input
221
+ type="hidden"
222
+ id="totpSecret"
223
+ name="totpSecret"
224
+ value={totp.totpSecret}
225
+ />
226
+ {#if mode}<input
227
+ type="hidden"
228
+ id="mode"
229
+ value={mode}
230
+ />{/if}
231
+ </div>
232
+
233
+ <div class={kcClsx('kcFormGroupClass')}>
234
+ <div class="col-sm-2 col-md-2">
235
+ <label
236
+ for="userLabel"
237
+ class={kcClsx('kcLabelClass')}
238
+ >
239
+ {@render msg('totpDeviceName')()}
240
+ </label>
241
+ {#if totp.otpCredentials.length >= 1}<span class="required">*</span>{/if}
242
+ </div>
243
+ <div class="col-sm-10 col-md-10">
244
+ <input
245
+ type="text"
246
+ id="userLabel"
247
+ name="userLabel"
248
+ autocomplete="off"
249
+ class={kcClsx('kcInputClass')}
250
+ aria-invalid={messagesPerField.existsError('userLabel')}
251
+ />
252
+ {#if messagesPerField.existsError('userLabel')}
253
+ <span
254
+ id="input-error-otp-label"
255
+ class={kcClsx('kcInputErrorMessageClass')}
256
+ aria-live="polite">{@html kcSanitize(messagesPerField.get('userLabel'))}</span
257
+ >
258
+ {/if}
259
+ </div>
260
+ </div>
261
+
262
+ <div
263
+ id="kc-form-buttons"
264
+ class={clsx(kcClsx('kcFormGroupClass'), 'text-right')}
265
+ >
266
+ <div class={kcClsx('kcInputWrapperClass')}>
267
+ <input
268
+ type="submit"
269
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass')}
270
+ id="saveTOTPBtn"
271
+ value={msgStr('doSave')}
272
+ />
273
+ <button
274
+ type="submit"
275
+ class={kcClsx('kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass', 'kcButtonLargeClass')}
276
+ id="cancelTOTPBtn"
277
+ name="submitAction"
278
+ value="Cancel"
279
+ >
280
+ {@render msg('doCancel')()}
281
+ </button>
282
+ </div>
283
+ </div>
284
+ </form>
285
+ </div>
286
+ {/if}
287
+ </Template>
@@ -0,0 +1,6 @@
1
+ declare namespace svelteHTML {
2
+ // enhance attributes
3
+ interface HTMLAttributes {
4
+ 'no-bottom-margin'?: boolean;
5
+ }
6
+ }
@@ -0,0 +1,135 @@
1
+ <script lang="ts">
2
+ import type { UserProfileFormFieldsProps } from '@keycloakify/svelte/login/components/UserProfileFormFieldsProps';
3
+ import type { PageProps } from '@keycloakify/svelte/login/pages/PageProps';
4
+ import type { Component } from 'svelte';
5
+ import type { I18n } from './i18n';
6
+ import type { KcContext } from './KcContext';
7
+
8
+ type DefaultPageProps = PageProps<KcContext, I18n> & {
9
+ UserProfileFormFields: Component<UserProfileFormFieldsProps>;
10
+ doMakeUserConfirmPassword: boolean;
11
+ };
12
+ const props: DefaultPageProps = $props();
13
+ const { kcContext: kcContext, ...rest } = props;
14
+ const loadComponent = () => {
15
+ switch (kcContext.pageId) {
16
+ case 'login.ftl':
17
+ return import('@keycloakify/svelte/login/pages/Login.svelte');
18
+
19
+ case 'register.ftl':
20
+ return import('@keycloakify/svelte/login/pages/Register.svelte');
21
+
22
+ case 'info.ftl':
23
+ return import('@keycloakify/svelte/login/pages/Info.svelte');
24
+
25
+ case 'error.ftl':
26
+ return import('@keycloakify/svelte/login/pages/Error.svelte');
27
+
28
+ case 'login-reset-password.ftl':
29
+ return import('@keycloakify/svelte/login/pages/LoginResetPassword.svelte');
30
+
31
+ case 'login-verify-email.ftl':
32
+ return import('@keycloakify/svelte/login/pages/LoginVerifyEmail.svelte');
33
+
34
+ case 'terms.ftl':
35
+ return import('@keycloakify/svelte/login/pages/Terms.svelte');
36
+
37
+ case 'login-oauth2-device-verify-user-code.ftl':
38
+ return import('@keycloakify/svelte/login/pages/LoginOauth2DeviceVerifyUserCode.svelte');
39
+
40
+ case 'login-oauth-grant.ftl':
41
+ return import('@keycloakify/svelte/login/pages/LoginOauthGrant.svelte');
42
+
43
+ case 'login-otp.ftl':
44
+ return import('@keycloakify/svelte/login/pages/LoginOtp.svelte');
45
+
46
+ case 'login-username.ftl':
47
+ return import('@keycloakify/svelte/login/pages/LoginUsername.svelte');
48
+
49
+ case 'webauthn-authenticate.ftl':
50
+ return import('@keycloakify/svelte/login/pages/WebauthnAuthenticate.svelte');
51
+
52
+ case 'webauthn-register.ftl':
53
+ return import('@keycloakify/svelte/login/pages/WebauthnRegister.svelte');
54
+
55
+ case 'login-password.ftl':
56
+ return import('@keycloakify/svelte/login/pages/LoginPassword.svelte');
57
+
58
+ case 'login-update-password.ftl':
59
+ return import('@keycloakify/svelte/login/pages/LoginUpdatePassword.svelte');
60
+
61
+ case 'login-update-profile.ftl':
62
+ return import('@keycloakify/svelte/login/pages/LoginUpdateProfile.svelte');
63
+
64
+ case 'login-idp-link-confirm.ftl':
65
+ return import('@keycloakify/svelte/login/pages/LoginIdpLinkConfirm.svelte');
66
+
67
+ case 'login-idp-link-email.ftl':
68
+ return import('@keycloakify/svelte/login/pages/LoginIdpLinkEmail.svelte');
69
+
70
+ case 'login-page-expired.ftl':
71
+ return import('@keycloakify/svelte/login/pages/LoginPageExpired.svelte');
72
+
73
+ case 'login-config-totp.ftl':
74
+ return import('@keycloakify/svelte/login/pages/LoginConfigTotp.svelte');
75
+
76
+ case 'logout-confirm.ftl':
77
+ return import('@keycloakify/svelte/login/pages/LogoutConfirm.svelte');
78
+
79
+ case 'idp-review-user-profile.ftl':
80
+ return import('@keycloakify/svelte/login/pages/IdpReviewUserProfile.svelte');
81
+
82
+ case 'update-email.ftl':
83
+ return import('@keycloakify/svelte/login/pages/UpdateEmail.svelte');
84
+
85
+ case 'select-authenticator.ftl':
86
+ return import('@keycloakify/svelte/login/pages/SelectAuthenticator.svelte');
87
+
88
+ case 'saml-post-form.ftl':
89
+ return import('@keycloakify/svelte/login/pages/SamlPostForm.svelte');
90
+
91
+ case 'delete-credential.ftl':
92
+ return import('@keycloakify/svelte/login/pages/DeleteCredential.svelte');
93
+
94
+ case 'code.ftl':
95
+ return import('@keycloakify/svelte/login/pages/Code.svelte');
96
+
97
+ case 'delete-account-confirm.ftl':
98
+ return import('@keycloakify/svelte/login/pages/DeleteAccountConfirm.svelte');
99
+
100
+ case 'frontchannel-logout.ftl':
101
+ return import('@keycloakify/svelte/login/pages/FrontchannelLogout.svelte');
102
+
103
+ case 'login-recovery-authn-code-config.ftl':
104
+ return import('@keycloakify/svelte/login/pages/LoginRecoveryAuthnCodeConfig.svelte');
105
+
106
+ case 'login-recovery-authn-code-input.ftl':
107
+ return import('@keycloakify/svelte/login/pages/LoginRecoveryAuthnCodeInput.svelte');
108
+
109
+ case 'login-reset-otp.ftl':
110
+ return import('@keycloakify/svelte/login/pages/LoginResetOtp.svelte');
111
+
112
+ case 'login-x509-info.ftl':
113
+ return import('@keycloakify/svelte/login/pages/LoginX509Info.svelte');
114
+
115
+ case 'webauthn-error.ftl':
116
+ return import('@keycloakify/svelte/login/pages/WebauthnError.svelte');
117
+
118
+ case 'login-passkeys-conditional-authenticate.ftl':
119
+ return import('@keycloakify/svelte/login/pages/LoginPasskeysConditionalAuthenticate.svelte');
120
+
121
+ case 'login-idp-link-confirm-override.ftl':
122
+ return import('@keycloakify/svelte/login/pages/LoginIdpLinkConfirmOverride.svelte');
123
+ }
124
+ };
125
+ const lazyComponent = loadComponent();
126
+ </script>
127
+
128
+ {#if lazyComponent}
129
+ {#await lazyComponent then { default: LazyComponent }}
130
+ <LazyComponent
131
+ kcContext={kcContext as never}
132
+ {...rest}
133
+ />
134
+ {/await}
135
+ {/if}
@@ -0,0 +1 @@
1
+ export type { ExtendKcContext, KcContext } from 'keycloakify/login/KcContext';
@@ -0,0 +1 @@
1
+ export * from './KcContext';
@@ -0,0 +1,223 @@
1
+ <script lang="ts">
2
+ import { useInitialize } from '@keycloakify/svelte/login/Template.useInitialize';
3
+ import type { TemplateProps } from '@keycloakify/svelte/login/TemplateProps';
4
+ import { useSetClassName } from '@keycloakify/svelte/tools/useSetClassName';
5
+ import { kcSanitize } from 'keycloakify/lib/kcSanitize';
6
+ import { getKcClsx } from 'keycloakify/login/lib/kcClsx';
7
+ import { clsx } from 'keycloakify/tools/clsx';
8
+ import { onMount } from 'svelte';
9
+ import type { I18n } from './i18n';
10
+ import type { KcContext } from './KcContext';
11
+
12
+ const {
13
+ displayInfo = false,
14
+ displayMessage = true,
15
+ displayRequiredFields = false,
16
+ headerNode,
17
+ socialProvidersNode = null,
18
+ infoNode = null,
19
+ documentTitle,
20
+ bodyClassName,
21
+ kcContext,
22
+ i18n,
23
+ doUseDefaultCss,
24
+ classes,
25
+ children,
26
+ }: TemplateProps<KcContext, I18n> = $props();
27
+ const { kcClsx } = getKcClsx({ doUseDefaultCss, classes });
28
+
29
+ const { msgStr, currentLanguage, enabledLanguages } = $i18n;
30
+
31
+ const { realm, auth, url, message, isAppInitiatedAction } = kcContext;
32
+ onMount(() => {
33
+ document.title = documentTitle ?? msgStr('loginTitle', kcContext.realm.displayName);
34
+ });
35
+ useSetClassName({
36
+ qualifiedName: 'html',
37
+ className: kcClsx('kcHtmlClass'),
38
+ });
39
+
40
+ useSetClassName({
41
+ qualifiedName: 'body',
42
+ className: bodyClassName ?? kcClsx('kcBodyClass'),
43
+ });
44
+ const { isReadyToRender } = useInitialize({ kcContext, doUseDefaultCss });
45
+ </script>
46
+
47
+ {#if $isReadyToRender}
48
+ <div class={kcClsx('kcLoginClass')}>
49
+ <div
50
+ id="kc-header"
51
+ class={kcClsx('kcHeaderClass')}
52
+ >
53
+ <div
54
+ id="kc-header-wrapper"
55
+ class={kcClsx('kcHeaderWrapperClass')}
56
+ >
57
+ {msgStr('loginTitleHtml', realm.displayNameHtml)}
58
+ </div>
59
+ </div>
60
+
61
+ <div class={kcClsx('kcFormCardClass')}>
62
+ <header class={kcClsx('kcFormHeaderClass')}>
63
+ {#if enabledLanguages.length > 1}
64
+ <div
65
+ class={kcClsx('kcLocaleMainClass')}
66
+ id="kc-locale"
67
+ >
68
+ <div
69
+ id="kc-locale-wrapper"
70
+ class={kcClsx('kcLocaleWrapperClass')}
71
+ >
72
+ <div
73
+ id="kc-locale-dropdown"
74
+ class={clsx('menu-button-links', kcClsx('kcLocaleDropDownClass'))}
75
+ >
76
+ <button
77
+ tabindex={1}
78
+ id="kc-current-locale-link"
79
+ aria-label={msgStr('languages')}
80
+ aria-haspopup="true"
81
+ aria-expanded="false"
82
+ aria-controls="language-switch1"
83
+ >
84
+ {currentLanguage.label}
85
+ </button>
86
+ <!-- svelte-ignore a11y_incorrect_aria_attribute_type -->
87
+ <ul
88
+ role="menu"
89
+ tabindex={-1}
90
+ aria-labelledby="kc-current-locale-link"
91
+ aria-activedescendant=""
92
+ id="language-switch1"
93
+ class={kcClsx('kcLocaleListClass')}
94
+ >
95
+ {#each enabledLanguages as enabledLanguage, i}
96
+ {@const { label, href } = enabledLanguage}
97
+ <li
98
+ class={kcClsx('kcLocaleListItemClass')}
99
+ role="none"
100
+ >
101
+ <a
102
+ role="menuitem"
103
+ id={`language-${i + 1}`}
104
+ class={kcClsx('kcLocaleItemClass')}
105
+ {href}
106
+ >
107
+ {label}
108
+ </a>
109
+ </li>
110
+ {/each}
111
+ </ul>
112
+ </div>
113
+ </div>
114
+ </div>
115
+ {/if}
116
+ {#snippet node()}
117
+ {#if !(auth !== undefined && auth.showUsername && !auth.showResetCredentials)}
118
+ <h1 id="kc-page-title">{@render headerNode?.()}</h1>
119
+ {:else}
120
+ <div
121
+ id="kc-username"
122
+ class={kcClsx('kcFormGroupClass')}
123
+ >
124
+ <!-- svelte-ignore a11y_label_has_associated_control -->
125
+ <label id="kc-attempted-username">{auth.attemptedUsername}</label>
126
+ <a
127
+ id="reset-login"
128
+ href={url.loginRestartFlowUrl}
129
+ aria-label={msgStr('restartLoginTooltip')}
130
+ >
131
+ <div class="kc-login-tooltip">
132
+ <i class={kcClsx('kcResetFlowIcon')}></i>
133
+ <span class="kc-tooltip-text">{msgStr('restartLoginTooltip')}</span>
134
+ </div>
135
+ </a>
136
+ </div>
137
+ {/if}
138
+ {/snippet}
139
+ {#if displayRequiredFields}
140
+ <div class={kcClsx('kcContentWrapperClass')}>
141
+ <div class={clsx(kcClsx('kcLabelWrapperClass'), 'subtitle')}>
142
+ <span class="subtitle">
143
+ <span class="required">*</span>
144
+ {msgStr('requiredFields')}
145
+ </span>
146
+ </div>
147
+ <div class="col-md-10">{@render node()}</div>
148
+ </div>
149
+ {:else}
150
+ {@render node()}
151
+ {/if}
152
+ </header>
153
+ <div id="kc-content">
154
+ <div id="kc-content-wrapper">
155
+ <!-- App-initiated actions should not see warning messages about the need to complete the action during login. -->
156
+ {#if displayMessage && message !== undefined && (message.type !== 'warning' || !isAppInitiatedAction)}
157
+ <div
158
+ class={clsx(
159
+ `alert-${message.type}`,
160
+ kcClsx('kcAlertClass'),
161
+ `pf-m-${message?.type === 'error' ? 'danger' : message.type}`,
162
+ )}
163
+ >
164
+ <div class="pf-c-alert__icon">
165
+ {#if message.type === 'success'}
166
+ <span class={kcClsx('kcFeedbackSuccessIcon')}></span>
167
+ {:else if message.type === 'warning'}
168
+ <span class={kcClsx('kcFeedbackWarningIcon')}></span>
169
+ {:else if message.type === 'error'}
170
+ <span class={kcClsx('kcFeedbackErrorIcon')}></span>
171
+ {:else if message.type === 'info'}
172
+ <span class={kcClsx('kcFeedbackInfoIcon')}></span>
173
+ {/if}
174
+ </div>
175
+ <span class={kcClsx('kcAlertTitleClass')}>{@html kcSanitize(message.summary)}</span>
176
+ </div>
177
+ {/if}
178
+ {@render children?.()}
179
+ {#if auth !== undefined && auth.showTryAnotherWayLink}
180
+ <form
181
+ id="kc-select-try-another-way-form"
182
+ action={url.loginAction}
183
+ method="post"
184
+ >
185
+ <div class={kcClsx('kcFormGroupClass')}>
186
+ <input
187
+ type="hidden"
188
+ name="tryAnotherWay"
189
+ value="on"
190
+ />
191
+ <!-- svelte-ignore a11y_invalid_attribute -->
192
+ <a
193
+ href="#"
194
+ id="try-another-way"
195
+ onclick={() => {
196
+ document.forms['kc-select-try-another-way-form' as never].submit();
197
+ return false;
198
+ }}
199
+ >
200
+ {msgStr('doTryAnotherWay')}
201
+ </a>
202
+ </div>
203
+ </form>
204
+ {/if}
205
+ {@render socialProvidersNode?.()}
206
+ {#if displayInfo}
207
+ <div
208
+ id="kc-info"
209
+ class={kcClsx('kcSignUpClass')}
210
+ >
211
+ <div
212
+ id="kc-info-wrapper"
213
+ class={kcClsx('kcInfoAreaWrapperClass')}
214
+ >
215
+ {@render infoNode?.()}
216
+ </div>
217
+ </div>
218
+ {/if}
219
+ </div>
220
+ </div>
221
+ </div>
222
+ </div>
223
+ {/if}