@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,225 @@
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
+ const {
11
+ kcContext,
12
+ i18n,
13
+ doUseDefaultCss,
14
+ Template,
15
+ classes,
16
+ }: PageProps<Extract<KcContext, { pageId: 'login.ftl' }>, I18n> = $props();
17
+ const { kcClsx } = getKcClsx({
18
+ doUseDefaultCss,
19
+ classes,
20
+ });
21
+
22
+ const { social, realm, url, usernameHidden, login, auth, registrationDisabled, messagesPerField } = kcContext;
23
+
24
+ const { msg, msgStr } = $i18n;
25
+
26
+ const [isLoginButtonDisabled, setIsLoginButtonDisabled] = useState(false);
27
+ </script>
28
+
29
+ <Template
30
+ {kcContext}
31
+ {i18n}
32
+ {doUseDefaultCss}
33
+ {classes}
34
+ displayMessage={!messagesPerField.existsError('username', 'password')}
35
+ displayInfo={realm.password && realm.registrationAllowed && !registrationDisabled}
36
+ >
37
+ {#snippet headerNode()}
38
+ {@render msg('loginAccountTitle')()}
39
+ {/snippet}
40
+
41
+ {#snippet infoNode()}
42
+ <div id="kc-registration-container">
43
+ <div id="kc-registration">
44
+ <span>
45
+ {@render msg('noAccount')()}{' '}
46
+ <a
47
+ tabindex={8}
48
+ href={url.registrationUrl}
49
+ >
50
+ {@render msg('doRegister')()}
51
+ </a>
52
+ </span>
53
+ </div>
54
+ </div>
55
+ {/snippet}
56
+ {#snippet socialProvidersNode()}
57
+ {@const providers = social?.providers}
58
+ {#if realm.password && !!providers && !!providers.length}
59
+ <div
60
+ id="kc-social-providers"
61
+ class={kcClsx('kcFormSocialAccountSectionClass')}
62
+ >
63
+ <hr />
64
+ <h2>{@render msg('identity-provider-login-label')()}</h2>
65
+ <ul class={kcClsx('kcFormSocialAccountListClass', providers.length > 3 && 'kcFormSocialAccountListGridClass')}>
66
+ {#each providers as p}
67
+ <li>
68
+ <a
69
+ id={`social-${p.alias}`}
70
+ class={kcClsx(
71
+ 'kcFormSocialAccountListButtonClass',
72
+ providers.length > 3 && 'kcFormSocialAccountGridItem',
73
+ )}
74
+ type="button"
75
+ href={p.loginUrl}
76
+ >
77
+ {#if p.iconClasses}
78
+ <i
79
+ class={clsx(kcClsx('kcCommonLogoIdP'), p.iconClasses)}
80
+ aria-hidden="true"
81
+ ></i>
82
+ {/if}
83
+ <span class={clsx(kcClsx('kcFormSocialAccountNameClass'), p.iconClasses && 'kc-social-icon-text')}
84
+ >{@html kcSanitize(p.displayName)}</span
85
+ >
86
+ </a>
87
+ </li>
88
+ {/each}
89
+ </ul>
90
+ </div>
91
+ {/if}
92
+ {/snippet}
93
+ <div id="kc-form">
94
+ <div id="kc-form-wrapper">
95
+ {#if realm.password}
96
+ <form
97
+ id="kc-form-login"
98
+ onsubmit={() => {
99
+ setIsLoginButtonDisabled(true);
100
+ return true;
101
+ }}
102
+ action={url.loginAction}
103
+ method="post"
104
+ >
105
+ {#if !usernameHidden}
106
+ <div class={kcClsx('kcFormGroupClass')}>
107
+ <label
108
+ for="username"
109
+ class={kcClsx('kcLabelClass')}
110
+ >
111
+ {@render (!realm.loginWithEmailAllowed
112
+ ? msg('username')
113
+ : !realm.registrationEmailAsUsername
114
+ ? msg('usernameOrEmail')
115
+ : msg('email'))()}
116
+ </label>
117
+ <!-- svelte-ignore a11y_autofocus -->
118
+ <input
119
+ tabindex={2}
120
+ id="username"
121
+ class={kcClsx('kcInputClass')}
122
+ name="username"
123
+ value={login.username ?? ''}
124
+ type="text"
125
+ autofocus
126
+ autocomplete="username"
127
+ aria-invalid={messagesPerField.existsError('username', 'password')}
128
+ />
129
+ {#if messagesPerField.existsError('username', 'password')}
130
+ <span
131
+ id="input-error"
132
+ class={kcClsx('kcInputErrorMessageClass')}
133
+ aria-live="polite">{@html kcSanitize(messagesPerField.getFirstError('username', 'password'))}</span
134
+ >
135
+ {/if}
136
+ </div>
137
+ {/if}
138
+
139
+ <div class={kcClsx('kcFormGroupClass')}>
140
+ <label
141
+ for="password"
142
+ class={kcClsx('kcLabelClass')}
143
+ >
144
+ {@render msg('password')()}
145
+ </label>
146
+ <PasswordWrapper
147
+ {kcClsx}
148
+ {i18n}
149
+ passwordInputId="password"
150
+ >
151
+ <input
152
+ tabindex={3}
153
+ id="password"
154
+ class={kcClsx('kcInputClass')}
155
+ name="password"
156
+ type="password"
157
+ autocomplete="current-password"
158
+ aria-invalid={messagesPerField.existsError('username', 'password')}
159
+ />
160
+ </PasswordWrapper>
161
+ {#if usernameHidden && messagesPerField.existsError('username', 'password')}
162
+ <span
163
+ id="input-error"
164
+ class={kcClsx('kcInputErrorMessageClass')}
165
+ aria-live="polite">{@html kcSanitize(messagesPerField.getFirstError('username', 'password'))}</span
166
+ >
167
+ {/if}
168
+ </div>
169
+
170
+ <div class={kcClsx('kcFormGroupClass', 'kcFormSettingClass')}>
171
+ <div id="kc-form-options">
172
+ {#if realm.rememberMe && !usernameHidden}
173
+ <div class="checkbox">
174
+ <label>
175
+ <input
176
+ tabindex={5}
177
+ id="rememberMe"
178
+ name="rememberMe"
179
+ type="checkbox"
180
+ checked={!!login.rememberMe}
181
+ />{' '}
182
+ {@render msg('rememberMe')()}
183
+ </label>
184
+ </div>
185
+ {/if}
186
+ </div>
187
+ <div class={kcClsx('kcFormOptionsWrapperClass')}>
188
+ {#if realm.resetPasswordAllowed}
189
+ <span>
190
+ <a
191
+ tabindex={6}
192
+ href={url.loginResetCredentialsUrl}
193
+ >
194
+ {@render msg('doForgotPassword')()}
195
+ </a>
196
+ </span>
197
+ {/if}
198
+ </div>
199
+ </div>
200
+
201
+ <div
202
+ id="kc-form-buttons"
203
+ class={kcClsx('kcFormGroupClass')}
204
+ >
205
+ <input
206
+ type="hidden"
207
+ id="id-hidden-input"
208
+ name="credentialId"
209
+ value={auth.selectedCredential}
210
+ />
211
+ <input
212
+ tabindex={7}
213
+ disabled={$isLoginButtonDisabled}
214
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
215
+ name="login"
216
+ id="kc-login"
217
+ type="submit"
218
+ value={msgStr('doLogIn')}
219
+ />
220
+ </div>
221
+ </form>
222
+ {/if}
223
+ </div>
224
+ </div>
225
+ </Template>
@@ -0,0 +1,217 @@
1
+ <script lang="ts">
2
+ import LogoutOtherSessions from '@keycloakify/svelte/login/components/LogoutOtherSessions.svelte';
3
+ import type { PageProps } from '@keycloakify/svelte/login/pages/PageProps';
4
+ import { kcSanitize } from 'keycloakify/lib/kcSanitize';
5
+ import { getKcClsx } from 'keycloakify/login/lib/kcClsx';
6
+ import type { KcContext } from '../KcContext';
7
+ import type { I18n } from '../i18n';
8
+
9
+ const {
10
+ Template,
11
+ kcContext,
12
+ i18n,
13
+ doUseDefaultCss,
14
+ classes,
15
+ }: PageProps<Extract<KcContext, { pageId: 'login-config-totp.ftl' }>, I18n> = $props();
16
+
17
+ const { kcClsx } = getKcClsx({
18
+ doUseDefaultCss,
19
+ classes,
20
+ });
21
+
22
+ const { url, isAppInitiatedAction, totp, mode, messagesPerField } = kcContext;
23
+
24
+ const { msg, msgStr, advancedMsg } = $i18n;
25
+ </script>
26
+
27
+ <Template
28
+ {kcContext}
29
+ {i18n}
30
+ {doUseDefaultCss}
31
+ {classes}
32
+ displayMessage={!messagesPerField.existsError('totp', 'userLabel')}
33
+ >
34
+ {#snippet headerNode()}
35
+ {@render msg('loginTotpTitle')()}
36
+ {/snippet}
37
+ <ol id="kc-totp-settings">
38
+ <li>
39
+ <p>{@render msg('loginTotpStep1')()}</p>
40
+
41
+ <ul id="kc-totp-supported-apps">
42
+ {#each totp.supportedApplications as app}
43
+ <li>{@render advancedMsg(app)()}</li>
44
+ {/each}
45
+ </ul>
46
+ </li>
47
+ {#if mode === 'manual'}
48
+ <li>
49
+ <p>{@render msg('loginTotpManualStep2')()}</p>
50
+ <p>
51
+ <span id="kc-totp-secret-key">{totp.totpSecretEncoded}</span>
52
+ </p>
53
+ <p>
54
+ <a
55
+ href={totp.qrUrl}
56
+ id="mode-barcode"
57
+ >
58
+ {@render msg('loginTotpScanBarcode')()}
59
+ </a>
60
+ </p>
61
+ </li>
62
+ <li>
63
+ <p>{@render msg('loginTotpManualStep3')()}</p>
64
+ <ul>
65
+ <li id="kc-totp-type">
66
+ {@render msg('loginTotpType')()}: {@render msg(`loginTotp.${totp.policy.type}`)()}
67
+ </li>
68
+ <li id="kc-totp-algorithm">
69
+ {@render msg('loginTotpAlgorithm')()}: {totp.policy.getAlgorithmKey()}
70
+ </li>
71
+ <li id="kc-totp-digits">
72
+ {@render msg('loginTotpDigits')()}: {totp.policy.digits}
73
+ </li>
74
+ {#if totp.policy.type === 'totp'}
75
+ <li id="kc-totp-period">
76
+ {@render msg('loginTotpInterval')()}: {totp.policy.period}
77
+ </li>
78
+ {:else}
79
+ <li id="kc-totp-counter">
80
+ {@render msg('loginTotpCounter')()}: {totp.policy.initialCounter}
81
+ </li>
82
+ {/if}
83
+ </ul>
84
+ </li>
85
+ {:else}
86
+ <li>
87
+ <p>{@render msg('loginTotpStep2')()}</p>
88
+ <img
89
+ id="kc-totp-secret-qr-code"
90
+ src={`data:image/png;base64, ${totp.totpSecretQrCode}`}
91
+ alt="Figure: Barcode"
92
+ />
93
+ <br />
94
+ <p>
95
+ <a
96
+ href={totp.manualUrl}
97
+ id="mode-manual"
98
+ >
99
+ {@render msg('loginTotpUnableToScan')()}
100
+ </a>
101
+ </p>
102
+ </li>
103
+ {/if}
104
+ <li>
105
+ <p>{@render msg('loginTotpStep3')()}</p>
106
+ <p>{@render msg('loginTotpStep3DeviceName')()}</p>
107
+ </li>
108
+ </ol>
109
+ <form
110
+ action={url.loginAction}
111
+ class={kcClsx('kcFormClass')}
112
+ id="kc-totp-settings-form"
113
+ method="post"
114
+ >
115
+ <div class={kcClsx('kcFormGroupClass')}>
116
+ <div class={kcClsx('kcInputWrapperClass')}>
117
+ <label
118
+ for="totp"
119
+ class={kcClsx('kcLabelClass')}
120
+ >
121
+ {@render msg('authenticatorCode')()}
122
+ </label>{' '}
123
+ <span class="required">*</span>
124
+ </div>
125
+ <div class={kcClsx('kcInputWrapperClass')}>
126
+ <input
127
+ type="text"
128
+ id="totp"
129
+ name="totp"
130
+ autocomplete="off"
131
+ class={kcClsx('kcInputClass')}
132
+ aria-invalid={messagesPerField.existsError('totp')}
133
+ />
134
+
135
+ {#if messagesPerField.existsError('totp')}
136
+ <span
137
+ id="input-error-otp-code"
138
+ class={kcClsx('kcInputErrorMessageClass')}
139
+ aria-live="polite">{@html kcSanitize(messagesPerField.get('totp'))}</span
140
+ >
141
+ {/if}
142
+ </div>
143
+ <input
144
+ type="hidden"
145
+ id="totpSecret"
146
+ name="totpSecret"
147
+ value={totp.totpSecret}
148
+ />
149
+ {#if mode}<input
150
+ type="hidden"
151
+ id="mode"
152
+ value={mode}
153
+ />{/if}
154
+ </div>
155
+
156
+ <div class={kcClsx('kcFormGroupClass')}>
157
+ <div class={kcClsx('kcInputWrapperClass')}>
158
+ <label
159
+ for="userLabel"
160
+ class={kcClsx('kcLabelClass')}
161
+ >
162
+ {@render msg('loginTotpDeviceName')()}
163
+ </label>{' '}
164
+ {#if totp.otpCredentials.length >= 1}<span class="required">*</span>{/if}
165
+ </div>
166
+ <div class={kcClsx('kcInputWrapperClass')}>
167
+ <input
168
+ type="text"
169
+ id="userLabel"
170
+ name="userLabel"
171
+ autocomplete="off"
172
+ class={kcClsx('kcInputClass')}
173
+ aria-invalid={messagesPerField.existsError('userLabel')}
174
+ />
175
+ {#if messagesPerField.existsError('userLabel')}
176
+ <span
177
+ id="input-error-otp-label"
178
+ class={kcClsx('kcInputErrorMessageClass')}
179
+ aria-live="polite">{@html kcSanitize(messagesPerField.get('userLabel'))}</span
180
+ >
181
+ {/if}
182
+ </div>
183
+ </div>
184
+
185
+ <div class={kcClsx('kcFormGroupClass')}>
186
+ <LogoutOtherSessions
187
+ {kcClsx}
188
+ {i18n}
189
+ />
190
+ </div>
191
+
192
+ {#if isAppInitiatedAction}
193
+ <input
194
+ type="submit"
195
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass')}
196
+ id="saveTOTPBtn"
197
+ value={msgStr('doSubmit')}
198
+ />
199
+ <button
200
+ type="submit"
201
+ class={kcClsx('kcButtonClass', 'kcButtonDefaultClass', 'kcButtonLargeClass', 'kcButtonLargeClass')}
202
+ id="cancelTOTPBtn"
203
+ name="cancel-aia"
204
+ value="true"
205
+ >
206
+ {@render msg('doCancel')()}
207
+ </button>
208
+ {:else}
209
+ <input
210
+ type="submit"
211
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass')}
212
+ id="saveTOTPBtn"
213
+ value={msgStr('doSubmit')}
214
+ />
215
+ {/if}
216
+ </form>
217
+ </Template>
@@ -0,0 +1,60 @@
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-idp-link-confirm.ftl' }>, I18n> = $props();
14
+
15
+ const { kcClsx } = getKcClsx({
16
+ doUseDefaultCss,
17
+ classes,
18
+ });
19
+
20
+ const { url, idpAlias } = kcContext;
21
+
22
+ const { msg } = $i18n;
23
+ </script>
24
+
25
+ <Template
26
+ {kcContext}
27
+ {i18n}
28
+ {doUseDefaultCss}
29
+ {classes}
30
+ >
31
+ {#snippet headerNode()}
32
+ {@render msg('confirmLinkIdpTitle')()}
33
+ {/snippet}
34
+ <form
35
+ id="kc-register-form"
36
+ action={url.loginAction}
37
+ method="post"
38
+ >
39
+ <div class={kcClsx('kcFormGroupClass')}>
40
+ <button
41
+ type="submit"
42
+ class={kcClsx('kcButtonClass', 'kcButtonDefaultClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
43
+ name="submitAction"
44
+ id="updateProfile"
45
+ value="updateProfile"
46
+ >
47
+ {@render msg('confirmLinkIdpReviewProfile')()}
48
+ </button>
49
+ <button
50
+ type="submit"
51
+ class={kcClsx('kcButtonClass', 'kcButtonDefaultClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
52
+ name="submitAction"
53
+ id="linkAccount"
54
+ value="linkAccount"
55
+ >
56
+ {@render msg('confirmLinkIdpContinue', idpAlias)()}
57
+ </button>
58
+ </div>
59
+ </form>
60
+ </Template>
@@ -0,0 +1,59 @@
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-idp-link-confirm-override.ftl' }>, I18n> = $props();
14
+
15
+ const { kcClsx } = getKcClsx({
16
+ doUseDefaultCss,
17
+ classes,
18
+ });
19
+
20
+ const { url, idpDisplayName } = kcContext;
21
+
22
+ const { msg } = $i18n;
23
+ </script>
24
+
25
+ <Template
26
+ {kcContext}
27
+ {i18n}
28
+ {doUseDefaultCss}
29
+ {classes}
30
+ >
31
+ {#snippet headerNode()}
32
+ {@render msg('confirmOverrideIdpTitle')()}
33
+ {/snippet}
34
+
35
+ <form
36
+ id="kc-register-form"
37
+ action={url.loginAction}
38
+ method="post"
39
+ >
40
+ {@render msg('pageExpiredMsg1')()}{' '}
41
+ <a
42
+ id="loginRestartLink"
43
+ href={url.loginRestartFlowUrl}
44
+ >
45
+ {@render msg('doClickHere')()}
46
+ </a>
47
+ <br />
48
+ <br />
49
+ <button
50
+ type="submit"
51
+ class={kcClsx('kcButtonClass', 'kcButtonDefaultClass', 'kcButtonBlockClass', 'kcButtonLargeClass')}
52
+ name="submitAction"
53
+ id="confirmOverride"
54
+ value="confirmOverride"
55
+ >
56
+ {@render msg('confirmOverrideIdpContinue', idpDisplayName)()}
57
+ </button>
58
+ </form>
59
+ </Template>
@@ -0,0 +1,50 @@
1
+ <script lang="ts">
2
+ import type { PageProps } from '@keycloakify/svelte/login/pages/PageProps';
3
+ import type { KcContext } from '../KcContext';
4
+ import type { I18n } from '../i18n';
5
+
6
+ const {
7
+ Template,
8
+ kcContext,
9
+ i18n,
10
+ doUseDefaultCss,
11
+ classes,
12
+ }: PageProps<Extract<KcContext, { pageId: 'login-idp-link-email.ftl' }>, I18n> = $props();
13
+
14
+ const { url, realm, brokerContext, idpAlias } = kcContext;
15
+
16
+ const { msg } = $i18n;
17
+ </script>
18
+
19
+ <Template
20
+ {kcContext}
21
+ {i18n}
22
+ {doUseDefaultCss}
23
+ {classes}
24
+ displayMessage={false}
25
+ >
26
+ {#snippet headerNode()}
27
+ {@render msg('emailLinkIdpTitle', idpAlias)()}
28
+ {/snippet}
29
+
30
+ <p
31
+ id="instruction1"
32
+ class="instruction"
33
+ >
34
+ {@render msg('emailLinkIdp1', idpAlias, brokerContext.username, realm.displayName)()}
35
+ </p>
36
+ <p
37
+ id="instruction2"
38
+ class="instruction"
39
+ >
40
+ {@render msg('emailLinkIdp2')()} <a href={url.loginAction}>{@render msg('doClickHere')()}</a>
41
+ {@render msg('emailLinkIdp3')()}
42
+ </p>
43
+ <p
44
+ id="instruction3"
45
+ class="instruction"
46
+ >
47
+ {@render msg('emailLinkIdp4')()} <a href={url.loginAction}>{@render msg('doClickHere')()}</a>
48
+ {@render msg('emailLinkIdp5')()}
49
+ </p>
50
+ </Template>
@@ -0,0 +1,85 @@
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-oauth2-device-verify-user-code.ftl' }>, I18n> = $props();
14
+
15
+ const { url } = kcContext;
16
+
17
+ const { msg, msgStr } = $i18n;
18
+
19
+ const { kcClsx } = getKcClsx({
20
+ doUseDefaultCss,
21
+ classes,
22
+ });
23
+ </script>
24
+
25
+ <Template
26
+ {kcContext}
27
+ {i18n}
28
+ {doUseDefaultCss}
29
+ {classes}
30
+ >
31
+ {#snippet headerNode()}
32
+ {@render msg('oauth2DeviceVerificationTitle')()}
33
+ {/snippet}
34
+ <form
35
+ id="kc-user-verify-device-user-code-form"
36
+ class={kcClsx('kcFormClass')}
37
+ action={url.oauth2DeviceVerificationAction}
38
+ method="post"
39
+ >
40
+ <div class={kcClsx('kcFormGroupClass')}>
41
+ <div class={kcClsx('kcLabelWrapperClass')}>
42
+ <label
43
+ for="device-user-code"
44
+ class={kcClsx('kcLabelClass')}
45
+ >
46
+ {@render msg('verifyOAuth2DeviceUserCode')()}
47
+ </label>
48
+ </div>
49
+
50
+ <div class={kcClsx('kcInputWrapperClass')}>
51
+ <!-- svelte-ignore a11y_autofocus -->
52
+ <input
53
+ id="device-user-code"
54
+ name="device_user_code"
55
+ autocomplete="off"
56
+ type="text"
57
+ class={kcClsx('kcInputClass')}
58
+ autofocus
59
+ />
60
+ </div>
61
+ </div>
62
+
63
+ <div class={kcClsx('kcFormGroupClass')}>
64
+ <div
65
+ id="kc-form-options"
66
+ class={kcClsx('kcFormOptionsClass')}
67
+ >
68
+ <div class={kcClsx('kcFormOptionsWrapperClass')}></div>
69
+ </div>
70
+
71
+ <div
72
+ id="kc-form-buttons"
73
+ class={kcClsx('kcFormButtonsClass')}
74
+ >
75
+ <div class={kcClsx('kcFormButtonsWrapperClass')}>
76
+ <input
77
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass')}
78
+ type="submit"
79
+ value={msgStr('doSubmit')}
80
+ />
81
+ </div>
82
+ </div>
83
+ </div>
84
+ </form>
85
+ </Template>