@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,114 @@
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
+
6
+ const {
7
+ kcContext,
8
+ i18n,
9
+ doUseDefaultCss,
10
+ Template,
11
+ classes,
12
+ }: PageProps<Extract<KcContext, { pageId: 'federatedIdentity.ftl' }>, I18n> = $props();
13
+
14
+ const { url, federatedIdentity, stateChecker } = kcContext;
15
+ const { msg } = $i18n;
16
+ </script>
17
+
18
+ <Template
19
+ {kcContext}
20
+ {i18n}
21
+ {doUseDefaultCss}
22
+ {classes}
23
+ active="social"
24
+ >
25
+ <div class="main-layout social">
26
+ <div class="row">
27
+ <div class="col-md-10">
28
+ <h2>{@render msg('federatedIdentitiesHtmlTitle')()}</h2>
29
+ </div>
30
+ </div>
31
+ <div id="federated-identities">
32
+ {#each federatedIdentity.identities as identity}
33
+ <div class="row margin-bottom">
34
+ <div class="col-sm-2 col-md-2">
35
+ <label
36
+ for={identity.providerId}
37
+ class="control-label"
38
+ >
39
+ {identity.displayName}
40
+ </label>
41
+ </div>
42
+ <div class="col-sm-5 col-md-5">
43
+ <input
44
+ disabled
45
+ class="form-control"
46
+ value={identity.userName}
47
+ />
48
+ </div>
49
+ <div class="col-sm-5 col-md-5">
50
+ {#if identity.connected}
51
+ {#if federatedIdentity.removeLinkPossible}
52
+ <form
53
+ action={url.socialUrl}
54
+ method="post"
55
+ class="form-inline"
56
+ >
57
+ <input
58
+ type="hidden"
59
+ name="stateChecker"
60
+ value={stateChecker}
61
+ />
62
+ <input
63
+ type="hidden"
64
+ name="action"
65
+ value="remove"
66
+ />
67
+ <input
68
+ type="hidden"
69
+ name="providerId"
70
+ value={identity.providerId}
71
+ />
72
+ <button
73
+ id={`remove-link-${identity.providerId}`}
74
+ class="btn btn-default"
75
+ >
76
+ {@render msg('doRemove')()}
77
+ </button>
78
+ </form>
79
+ {/if}
80
+ {:else}
81
+ <form
82
+ action={url.socialUrl}
83
+ method="post"
84
+ class="form-inline"
85
+ >
86
+ <input
87
+ type="hidden"
88
+ name="stateChecker"
89
+ value={stateChecker}
90
+ />
91
+ <input
92
+ type="hidden"
93
+ name="action"
94
+ value="add"
95
+ />
96
+ <input
97
+ type="hidden"
98
+ name="providerId"
99
+ value={identity.providerId}
100
+ />
101
+ <button
102
+ id={`add-link-${identity.providerId}`}
103
+ class="btn btn-default"
104
+ >
105
+ {@render msg('doAdd')()}
106
+ </button>
107
+ </form>
108
+ {/if}
109
+ </div>
110
+ </div>
111
+ {/each}
112
+ </div>
113
+ </div>
114
+ </Template>
@@ -0,0 +1,68 @@
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
+
7
+ const {
8
+ kcContext,
9
+ i18n,
10
+ doUseDefaultCss,
11
+ Template,
12
+ classes,
13
+ }: PageProps<Extract<KcContext, { pageId: 'log.ftl' }>, I18n> = $props();
14
+
15
+ const { kcClsx } = getKcClsx({
16
+ doUseDefaultCss,
17
+ classes,
18
+ });
19
+
20
+ const { log } = kcContext;
21
+
22
+ const { msg } = $i18n;
23
+ </script>
24
+
25
+ <Template
26
+ {kcContext}
27
+ {i18n}
28
+ {doUseDefaultCss}
29
+ {classes}
30
+ active="log"
31
+ >
32
+ <div class={kcClsx('kcContentWrapperClass')}>
33
+ <div class="col-md-10">
34
+ <h2>{@render msg('accountLogHtmlTitle')()}</h2>
35
+ </div>
36
+
37
+ <table class="table table-striped table-bordered">
38
+ <thead>
39
+ <tr>
40
+ <td>{@render msg('date')()}</td>
41
+ <td>{@render msg('event')()}</td>
42
+ <td>{@render msg('ip')()}</td>
43
+ <td>{@render msg('client')()}</td>
44
+ <td>{@render msg('details')()}</td>
45
+ </tr>
46
+ </thead>
47
+
48
+ <tbody>
49
+ {#each log.events as event}
50
+ <tr>
51
+ <td>{event.date ? new Date(event.date).toLocaleString() : ''}</td>
52
+ <td>{event.event}</td>
53
+ <td>{event.ipAddress}</td>
54
+ <td>{event.client || ''}</td>
55
+ <td>
56
+ {#each event.details as detail, detailIndex}
57
+ <span>
58
+ {`${detail.key} = ${detail.value}`}
59
+ {#if detailIndex < event.details.length - 1},&nbsp;{/if}
60
+ </span>
61
+ {/each}
62
+ </td>
63
+ </tr>
64
+ {/each}
65
+ </tbody>
66
+ </table>
67
+ </div>
68
+ </Template>
@@ -0,0 +1,11 @@
1
+ import { type ClassKey, type TemplateProps } from '@keycloakify/svelte/account/TemplateProps';
2
+ import type { Component } from 'svelte';
3
+ import type { Readable } from 'svelte/store';
4
+
5
+ export type PageProps<NarrowedKcContext, I18n> = {
6
+ Template: Component<TemplateProps<NarrowedKcContext, I18n>>;
7
+ kcContext: NarrowedKcContext;
8
+ i18n: Readable<I18n>;
9
+ doUseDefaultCss: boolean;
10
+ classes?: Partial<Record<ClassKey, string>>;
11
+ };
@@ -0,0 +1,233 @@
1
+ <script lang="ts">
2
+ import type { PageProps } from '@keycloakify/svelte/account/pages/PageProps';
3
+ import { useState } from '@keycloakify/svelte/tools/useState';
4
+ import { getKcClsx } from 'keycloakify/account/lib/kcClsx';
5
+ import { clsx } from 'keycloakify/tools/clsx';
6
+ import type { KcContext } from '../KcContext';
7
+ import type { I18n } from '../i18n';
8
+
9
+ const {
10
+ kcContext,
11
+ i18n,
12
+ doUseDefaultCss,
13
+ Template,
14
+ ...props
15
+ }: PageProps<Extract<KcContext, { pageId: 'password.ftl' }>, I18n> = $props();
16
+
17
+ const classes = {
18
+ ...props.classes,
19
+ kcBodyClass: clsx(props.classes?.kcBodyClass, 'password'),
20
+ };
21
+
22
+ const { kcClsx } = getKcClsx({
23
+ doUseDefaultCss,
24
+ classes,
25
+ });
26
+ const { url, password, account, stateChecker } = kcContext;
27
+
28
+ const { msgStr, msg } = $i18n;
29
+
30
+ const [currentPassword, setCurrentPassword] = useState('');
31
+ const [newPassword, setNewPassword] = useState('');
32
+ const [newPasswordConfirm, setNewPasswordConfirm] = useState('');
33
+ const [newPasswordError, setNewPasswordError] = useState('');
34
+ const [newPasswordConfirmError, setNewPasswordConfirmError] = useState('');
35
+ const [hasNewPasswordBlurred, setHasNewPasswordBlurred] = useState(false);
36
+ const [hasNewPasswordConfirmBlurred, setHasNewPasswordConfirmBlurred] = useState(false);
37
+
38
+ const checkNewPassword = (newPassword: string, $currentPassword: string) => {
39
+ if (!password.passwordSet) {
40
+ return;
41
+ }
42
+
43
+ if (newPassword === $currentPassword) {
44
+ setNewPasswordError(msgStr('newPasswordSameAsOld'));
45
+ } else {
46
+ setNewPasswordError('');
47
+ }
48
+ };
49
+
50
+ const checkNewPasswordConfirm = (newPasswordConfirm: string, $newPassword: string) => {
51
+ if (newPasswordConfirm === '') {
52
+ return;
53
+ }
54
+
55
+ if ($newPassword !== newPasswordConfirm) {
56
+ setNewPasswordConfirmError(msgStr('passwordConfirmNotMatch'));
57
+ } else {
58
+ setNewPasswordConfirmError('');
59
+ }
60
+ };
61
+ </script>
62
+
63
+ <!-- check message reactivity -->
64
+ <Template
65
+ kcContext={{
66
+ ...kcContext,
67
+ message: (() => {
68
+ if ($newPasswordError !== '') {
69
+ return {
70
+ type: 'error',
71
+ summary: $newPasswordError,
72
+ };
73
+ }
74
+
75
+ if ($newPasswordConfirmError !== '') {
76
+ return {
77
+ type: 'error',
78
+ summary: $newPasswordConfirmError,
79
+ };
80
+ }
81
+
82
+ return kcContext.message;
83
+ })(),
84
+ }}
85
+ {i18n}
86
+ {doUseDefaultCss}
87
+ {classes}
88
+ active="password"
89
+ >
90
+ <div class="row">
91
+ <div class="col-md-10">
92
+ <h2>{@render msg('changePasswordHtmlTitle')()}</h2>
93
+ </div>
94
+ <div class="col-md-2 subtitle">
95
+ <span class="subtitle">{@render msg('allFieldsRequired')()}</span>
96
+ </div>
97
+ </div>
98
+
99
+ <form
100
+ action={url.passwordUrl}
101
+ class="form-horizontal"
102
+ method="post"
103
+ >
104
+ <input
105
+ type="text"
106
+ id="username"
107
+ name="username"
108
+ value={account.username ?? ''}
109
+ autocomplete="username"
110
+ readonly
111
+ style:display={'none'}
112
+ />
113
+
114
+ {#if password.passwordSet}
115
+ <div class="form-group">
116
+ <div class="col-sm-2 col-md-2">
117
+ <label
118
+ for="password"
119
+ class="control-label"
120
+ >
121
+ {@render msg('password')()}
122
+ </label>
123
+ </div>
124
+ <div class="col-sm-10 col-md-10">
125
+ <!-- svelte-ignore a11y_autofocus -->
126
+ <input
127
+ type="password"
128
+ class="form-control"
129
+ id="password"
130
+ name="password"
131
+ autofocus
132
+ autocomplete="current-password"
133
+ value={$currentPassword}
134
+ onchange={(event) => setCurrentPassword(event.currentTarget.value)}
135
+ />
136
+ </div>
137
+ </div>
138
+ {/if}
139
+
140
+ <input
141
+ type="hidden"
142
+ id="stateChecker"
143
+ name="stateChecker"
144
+ value={stateChecker}
145
+ />
146
+
147
+ <div class="form-group">
148
+ <div class="col-sm-2 col-md-2">
149
+ <label
150
+ for="password-new"
151
+ class="control-label"
152
+ >
153
+ {@render msg('passwordNew')()}
154
+ </label>
155
+ </div>
156
+ <div class="col-sm-10 col-md-10">
157
+ <input
158
+ type="password"
159
+ class="form-control"
160
+ id="password-new"
161
+ name="password-new"
162
+ autocomplete="new-password"
163
+ value={$newPassword}
164
+ onchange={(event) => {
165
+ const newPassword = event.currentTarget.value;
166
+
167
+ setNewPassword(newPassword);
168
+ if ($hasNewPasswordBlurred) {
169
+ checkNewPassword(newPassword, $currentPassword);
170
+ }
171
+ }}
172
+ onblur={() => {
173
+ setHasNewPasswordBlurred(true);
174
+ checkNewPassword($newPassword, $currentPassword);
175
+ }}
176
+ />
177
+ </div>
178
+ </div>
179
+
180
+ <div class="form-group">
181
+ <div class="col-sm-2 col-md-2">
182
+ <label
183
+ for="password-confirm"
184
+ class="control-label two-lines"
185
+ >
186
+ {@render msg('passwordConfirm')()}
187
+ </label>
188
+ </div>
189
+
190
+ <div class="col-sm-10 col-md-10">
191
+ <input
192
+ type="password"
193
+ class="form-control"
194
+ id="password-confirm"
195
+ name="password-confirm"
196
+ autocomplete="new-password"
197
+ value={$newPasswordConfirm}
198
+ onchange={(event) => {
199
+ const newPasswordConfirm = event.currentTarget.value;
200
+
201
+ setNewPasswordConfirm(newPasswordConfirm);
202
+ if ($hasNewPasswordConfirmBlurred) {
203
+ checkNewPasswordConfirm(newPasswordConfirm, $newPassword);
204
+ }
205
+ }}
206
+ onblur={() => {
207
+ setHasNewPasswordConfirmBlurred(true);
208
+ checkNewPasswordConfirm($newPasswordConfirm, $newPassword);
209
+ }}
210
+ />
211
+ </div>
212
+ </div>
213
+
214
+ <div class="form-group">
215
+ <div
216
+ id="kc-form-buttons"
217
+ class="col-md-offset-2 col-md-10 submit"
218
+ >
219
+ <div>
220
+ <button
221
+ disabled={$newPasswordError !== '' || $newPasswordConfirmError !== ''}
222
+ type="submit"
223
+ class={kcClsx('kcButtonClass', 'kcButtonPrimaryClass', 'kcButtonLargeClass')}
224
+ name="submitAction"
225
+ value="Save"
226
+ >
227
+ {@render msg('doSave')()}
228
+ </button>
229
+ </div>
230
+ </div>
231
+ </div>
232
+ </form>
233
+ </Template>
@@ -0,0 +1,88 @@
1
+ <script lang="ts">
2
+ import type { PageProps } from '@keycloakify/svelte/account/pages/PageProps';
3
+ import { getKcClsx } from 'keycloakify/account/lib/kcClsx';
4
+ import type { KcContext } from '../KcContext';
5
+ import type { I18n } from '../i18n';
6
+
7
+ const {
8
+ kcContext,
9
+ i18n,
10
+ doUseDefaultCss,
11
+ Template,
12
+ classes,
13
+ }: PageProps<Extract<KcContext, { pageId: 'sessions.ftl' }>, I18n> = $props();
14
+
15
+ const { kcClsx } = getKcClsx({
16
+ doUseDefaultCss,
17
+ classes,
18
+ });
19
+
20
+ const { url, stateChecker, sessions } = kcContext;
21
+
22
+ const { msg } = $i18n;
23
+ </script>
24
+
25
+ <Template
26
+ {kcContext}
27
+ {i18n}
28
+ {doUseDefaultCss}
29
+ {classes}
30
+ active="sessions"
31
+ >
32
+ <div class={kcClsx('kcContentWrapperClass')}>
33
+ <div class="col-md-10">
34
+ <h2>{@render msg('sessionsHtmlTitle')()}</h2>
35
+ </div>
36
+ </div>
37
+
38
+ <table class="table table-striped table-bordered">
39
+ <thead>
40
+ <tr>
41
+ <th>{@render msg('ip')()}</th>
42
+ <th>{@render msg('started')()}</th>
43
+ <th>{@render msg('lastAccess')()}</th>
44
+ <th>{@render msg('expires')()}</th>
45
+ <th>{@render msg('clients')()}</th>
46
+ </tr>
47
+ </thead>
48
+
49
+ <!-- svelte-ignore a11y_no_redundant_roles -->
50
+ <tbody role="rowgroup">
51
+ {#each sessions.sessions as session}
52
+ <tr>
53
+ <td>{session.ipAddress}</td>
54
+ <td>{session?.started}</td>
55
+ <td>{session?.lastAccess}</td>
56
+ <td>{session?.expires}</td>
57
+ <td>
58
+ {#each session.clients as client}
59
+ <div>
60
+ {client}
61
+ <br />
62
+ </div>
63
+ {/each}
64
+ </td>
65
+ </tr>
66
+ {/each}
67
+ </tbody>
68
+ </table>
69
+
70
+ <form
71
+ action={url.sessionsUrl}
72
+ method="post"
73
+ >
74
+ <input
75
+ type="hidden"
76
+ id="stateChecker"
77
+ name="stateChecker"
78
+ value={stateChecker}
79
+ />
80
+ <button
81
+ id="logout-all-sessions"
82
+ type="submit"
83
+ class={kcClsx('kcButtonDefaultClass', 'kcButtonClass')}
84
+ >
85
+ {@render msg('doLogOutAllSessions')()}
86
+ </button>
87
+ </form>
88
+ </Template>