@ebrains/components 0.9.3-beta → 1.1.0

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 (659) hide show
  1. package/README.md +4 -2
  2. package/dist/cjs/{analytics-d8fb3fdd.js → analytics-28713bf7.js} +2 -2
  3. package/dist/cjs/color-primary-palette_6.cjs.entry.js +15 -15
  4. package/dist/cjs/components-section.cjs.entry.js +24 -18
  5. package/dist/cjs/components.cjs.js +2 -2
  6. package/dist/cjs/correct-use-of-colors.cjs.entry.js +2 -2
  7. package/dist/cjs/docs-palettes.cjs.entry.js +2 -2
  8. package/dist/cjs/docs-tokens.cjs.entry.js +2 -2
  9. package/dist/cjs/eds-accordion.cjs.entry.js +5 -5
  10. package/dist/cjs/eds-alert.cjs.entry.js +4 -4
  11. package/dist/cjs/eds-app-root.cjs.entry.js +2 -2
  12. package/dist/cjs/eds-avatar_28.cjs.entry.js +2711 -0
  13. package/dist/cjs/eds-breadcrumb.cjs.entry.js +145 -0
  14. package/dist/cjs/eds-card-desc_2.cjs.entry.js +4 -5
  15. package/dist/cjs/eds-card-generic.cjs.entry.js +4 -4
  16. package/dist/cjs/eds-card-project.cjs.entry.js +136 -8
  17. package/dist/cjs/eds-card-section.cjs.entry.js +1 -1
  18. package/dist/cjs/eds-card-tags.cjs.entry.js +2 -2
  19. package/dist/cjs/eds-card-tool.cjs.entry.js +3 -3
  20. package/dist/cjs/eds-code-block.cjs.entry.js +2 -2
  21. package/dist/cjs/eds-cookies-preference.cjs.entry.js +2 -2
  22. package/dist/cjs/eds-feedback.cjs.entry.js +7 -2
  23. package/dist/cjs/eds-frame.cjs.entry.js +3 -3
  24. package/dist/cjs/eds-gauge.cjs.entry.js +60 -0
  25. package/dist/cjs/eds-icon-arrow-diagonal.cjs.entry.js +2 -2
  26. package/dist/cjs/eds-icon-arrow-right.cjs.entry.js +2 -2
  27. package/dist/cjs/eds-icon-bluesky.cjs.entry.js +2 -2
  28. package/dist/cjs/eds-icon-bookmark.cjs.entry.js +2 -2
  29. package/dist/cjs/eds-icon-chevron-down.cjs.entry.js +2 -2
  30. package/dist/cjs/eds-icon-chevron-left.cjs.entry.js +2 -2
  31. package/dist/cjs/eds-icon-chevron-right.cjs.entry.js +2 -2
  32. package/dist/cjs/eds-icon-chevron-up.cjs.entry.js +2 -2
  33. package/dist/cjs/eds-icon-close.cjs.entry.js +2 -2
  34. package/dist/cjs/eds-icon-copy.cjs.entry.js +2 -2
  35. package/dist/cjs/eds-icon-eu.cjs.entry.js +2 -2
  36. package/dist/cjs/eds-icon-external.cjs.entry.js +2 -2
  37. package/dist/cjs/eds-icon-facebook.cjs.entry.js +2 -2
  38. package/dist/cjs/eds-icon-gitlab.cjs.entry.js +2 -2
  39. package/dist/cjs/eds-icon-linkedin.cjs.entry.js +2 -2
  40. package/dist/cjs/eds-icon-loader.cjs.entry.js +2 -2
  41. package/dist/cjs/eds-icon-mastodon.cjs.entry.js +2 -2
  42. package/dist/cjs/eds-icon-menu.cjs.entry.js +2 -2
  43. package/dist/cjs/eds-icon-minus.cjs.entry.js +2 -2
  44. package/dist/cjs/eds-icon-more.cjs.entry.js +2 -2
  45. package/dist/cjs/eds-icon-paper.cjs.entry.js +2 -2
  46. package/dist/cjs/eds-icon-plus.cjs.entry.js +2 -2
  47. package/dist/cjs/eds-icon-portal.cjs.entry.js +2 -2
  48. package/dist/cjs/eds-icon-private.cjs.entry.js +2 -2
  49. package/dist/cjs/eds-icon-public.cjs.entry.js +2 -2
  50. package/dist/cjs/eds-icon-search.cjs.entry.js +2 -2
  51. package/dist/cjs/eds-icon-star.cjs.entry.js +2 -2
  52. package/dist/cjs/eds-icon-success.cjs.entry.js +2 -2
  53. package/dist/cjs/eds-icon-thumbs-down.cjs.entry.js +2 -2
  54. package/dist/cjs/eds-icon-thumbs-up.cjs.entry.js +2 -2
  55. package/dist/cjs/eds-icon-tutorial.cjs.entry.js +2 -2
  56. package/dist/cjs/eds-icon-twitter.cjs.entry.js +2 -2
  57. package/dist/cjs/eds-icon-unknown.cjs.entry.js +2 -2
  58. package/dist/cjs/eds-icon-updown.cjs.entry.js +2 -2
  59. package/dist/cjs/eds-icon-user.cjs.entry.js +2 -2
  60. package/dist/cjs/eds-icon-youtube.cjs.entry.js +2 -2
  61. package/dist/cjs/eds-matomo-notice.cjs.entry.js +10 -8
  62. package/dist/cjs/eds-pie.cjs.entry.js +106 -0
  63. package/dist/cjs/eds-progress-bar.cjs.entry.js +32 -5
  64. package/dist/cjs/eds-rating.cjs.entry.js +2 -2
  65. package/dist/cjs/eds-section-core_2.cjs.entry.js +4 -4
  66. package/dist/cjs/eds-spinner.cjs.entry.js +2 -2
  67. package/dist/cjs/eds-splash-screen.cjs.entry.js +60 -0
  68. package/dist/cjs/eds-switch.cjs.entry.js +14 -6
  69. package/dist/cjs/eds-timeline.cjs.entry.js +3 -3
  70. package/dist/cjs/eds-toast-manager.cjs.entry.js +33 -4
  71. package/dist/cjs/eds-toast.cjs.entry.js +5 -4
  72. package/dist/cjs/eds-tooltip.cjs.entry.js +7 -84
  73. package/dist/cjs/eds-trl.cjs.entry.js +2 -2
  74. package/dist/cjs/incorrect-use-of-colors.cjs.entry.js +2 -2
  75. package/dist/cjs/{index-2f63169d.js → index-88c8039f.js} +53 -311
  76. package/dist/cjs/loader.cjs.js +2 -2
  77. package/dist/cjs/logo-space.cjs.entry.js +2 -2
  78. package/dist/cjs/logo-variations-horizontal_2.cjs.entry.js +3 -3
  79. package/dist/cjs/logo-variations-tabs.cjs.entry.js +2 -2
  80. package/dist/cjs/logo-wrong-usage.cjs.entry.js +2 -2
  81. package/dist/cjs/svg-repository.cjs.entry.js +2 -2
  82. package/dist/cjs/token-list_3.cjs.entry.js +4 -4
  83. package/dist/cjs/token-ratios.cjs.entry.js +2 -2
  84. package/dist/cjs/token-spacing.cjs.entry.js +16 -0
  85. package/dist/cjs/token-typography.cjs.entry.js +2 -2
  86. package/dist/collection/collection-manifest.json +4 -4
  87. package/dist/collection/components/eds-accordion/eds-accordion.css +0 -8
  88. package/dist/collection/components/eds-accordion/eds-accordion.js +2 -2
  89. package/dist/collection/components/eds-alert/eds-alert.css +1 -575
  90. package/dist/collection/components/eds-alert/eds-alert.js +2 -2
  91. package/dist/collection/components/eds-alert/eds-alert.stories.js +3 -1
  92. package/dist/collection/components/eds-avatar/eds-avatar.css +40 -25
  93. package/dist/collection/components/eds-avatar/eds-avatar.js +11 -21
  94. package/dist/collection/components/eds-avatar/eds-avatar.stories.js +5 -2
  95. package/dist/collection/components/eds-block-break/eds-block-break.css +2 -27
  96. package/dist/collection/components/eds-block-break/eds-block-break.js +9 -14
  97. package/dist/collection/components/eds-breadcrump/eds-breadcrump.js +1 -1
  98. package/dist/collection/components/eds-button/eds-button.css +318 -8312
  99. package/dist/collection/components/eds-button/eds-button.js +5 -59
  100. package/dist/collection/components/eds-button/eds-button.stories.js +4 -1
  101. package/dist/collection/components/eds-cards/eds-card-composer/eds-card-desc/eds-card-desc.css +5 -7
  102. package/dist/collection/components/eds-cards/eds-card-composer/eds-card-desc/eds-card-desc.js +1 -20
  103. package/dist/collection/components/eds-cards/eds-card-composer/eds-card-tags/eds-card-tags.js +1 -1
  104. package/dist/collection/components/eds-cards/eds-card-composer/eds-card-title/eds-card-title.js +1 -1
  105. package/dist/collection/components/eds-cards/eds-card-generic/eds-card-generic.css +10 -1
  106. package/dist/collection/components/eds-cards/eds-card-generic/eds-card-generic.js +1 -1
  107. package/dist/collection/components/eds-cards/eds-card-project/eds-card-project.js +1 -1
  108. package/dist/collection/components/eds-cards/eds-card-tool/eds-card-tool.js +1 -1
  109. package/dist/collection/components/eds-charts/eds-gauge/eds-gauge.css +58 -0
  110. package/dist/collection/components/eds-charts/eds-gauge/eds-gauge.js +172 -0
  111. package/dist/collection/components/eds-charts/eds-gauge/eds-gauge.stories.js +57 -0
  112. package/dist/collection/components/eds-charts/eds-pie/eds-pie.css +135 -0
  113. package/dist/collection/components/eds-charts/eds-pie/eds-pie.js +229 -0
  114. package/dist/collection/components/eds-charts/eds-pie/eds-pie.stories.js +76 -0
  115. package/dist/collection/components/eds-code-block/eds-code-block.js +1 -1
  116. package/dist/collection/components/eds-dropdown/eds-dropdown.js +2 -2
  117. package/dist/collection/components/eds-icons/chevron/eds-icon-chevron-down/eds-icon-chevron-down.js +1 -1
  118. package/dist/collection/components/eds-icons/chevron/eds-icon-chevron-left/eds-icon-chevron-left.js +1 -1
  119. package/dist/collection/components/eds-icons/chevron/eds-icon-chevron-right/eds-icon-chevron-right.js +1 -1
  120. package/dist/collection/components/eds-icons/chevron/eds-icon-chevron-up/eds-icon-chevron-up.js +1 -1
  121. package/dist/collection/components/eds-icons/eds-icon-arrow-diagonal/eds-icon-arrow-diagonal.js +1 -1
  122. package/dist/collection/components/eds-icons/eds-icon-arrow-right/eds-icon-arrow-right.js +1 -1
  123. package/dist/collection/components/eds-icons/eds-icon-bookmark/eds-icon-bookmark.js +1 -1
  124. package/dist/collection/components/eds-icons/eds-icon-close/eds-icon-close.js +1 -1
  125. package/dist/collection/components/eds-icons/eds-icon-copy/eds-icon-copy.js +1 -1
  126. package/dist/collection/components/eds-icons/eds-icon-eu/eds-icon-eu.js +1 -1
  127. package/dist/collection/components/eds-icons/eds-icon-external/eds-icon-external.js +1 -1
  128. package/dist/collection/components/eds-icons/eds-icon-gitlab/eds-icon-gitlab.js +1 -1
  129. package/dist/collection/components/eds-icons/eds-icon-loader/eds-icon-loader.js +1 -1
  130. package/dist/collection/components/eds-icons/eds-icon-menu/eds-icon-menu.js +1 -1
  131. package/dist/collection/components/eds-icons/eds-icon-minus/eds-icon-minus.js +1 -1
  132. package/dist/collection/components/eds-icons/eds-icon-more/eds-icon-more.js +1 -1
  133. package/dist/collection/components/eds-icons/eds-icon-paper/eds-icon-paper.js +1 -1
  134. package/dist/collection/components/eds-icons/eds-icon-plus/eds-icon-plus.js +1 -1
  135. package/dist/collection/components/eds-icons/eds-icon-portal/eds-icon-portal.js +1 -1
  136. package/dist/collection/components/eds-icons/eds-icon-private/eds-icon-private.js +1 -1
  137. package/dist/collection/components/eds-icons/eds-icon-public/eds-icon-public.js +1 -1
  138. package/dist/collection/components/eds-icons/eds-icon-search/eds-icon-search.js +1 -1
  139. package/dist/collection/components/eds-icons/eds-icon-star/eds-icon-star.js +1 -1
  140. package/dist/collection/components/eds-icons/eds-icon-success/eds-icon-success.js +1 -1
  141. package/dist/collection/components/eds-icons/eds-icon-thumbs-down/eds-icon-thumbs-down.js +1 -1
  142. package/dist/collection/components/eds-icons/eds-icon-thumbs-up/eds-icon-thumbs-up.js +1 -1
  143. package/dist/collection/components/eds-icons/eds-icon-tutorial/eds-icon-tutorial.js +1 -1
  144. package/dist/collection/components/eds-icons/eds-icon-unknown/eds-icon-unknown.js +1 -1
  145. package/dist/collection/components/eds-icons/eds-icon-updown/eds-icon-updown.js +1 -1
  146. package/dist/collection/components/eds-icons/eds-icon-user/eds-icon-user.js +1 -1
  147. package/dist/collection/components/eds-icons/social/eds-icon-bluesky/eds-icon-bluesky.js +1 -1
  148. package/dist/collection/components/eds-icons/social/eds-icon-facebook/eds-icon-facebook.js +1 -1
  149. package/dist/collection/components/eds-icons/social/eds-icon-linkedin/eds-icon-linkedin.js +1 -1
  150. package/dist/collection/components/eds-icons/social/eds-icon-mastodon/eds-icon-mastodon.js +1 -1
  151. package/dist/collection/components/eds-icons/social/eds-icon-twitter/eds-icon-twitter.js +1 -1
  152. package/dist/collection/components/eds-icons/social/eds-icon-youtube/eds-icon-youtube.js +1 -1
  153. package/dist/collection/components/eds-img/eds-img.js +2 -2
  154. package/dist/collection/components/eds-input-elements/eds-input/eds-input.js +2 -2
  155. package/dist/collection/components/eds-input-elements/eds-input-footer/eds-input-footer.js +1 -1
  156. package/dist/collection/components/eds-input-elements/eds-input-label/eds-input-label.js +1 -1
  157. package/dist/collection/components/eds-input-elements/eds-input-range/eds-input-range.js +1 -1
  158. package/dist/collection/components/eds-input-elements/eds-input-search/eds-input-search.js +1 -1
  159. package/dist/collection/components/eds-input-elements/eds-input-select/eds-input-select.js +33 -156
  160. package/dist/collection/components/eds-input-field/eds-input-field.js +42 -15
  161. package/dist/collection/components/eds-link/eds-link.css +384 -6247
  162. package/dist/collection/components/eds-link/eds-link.js +2 -1
  163. package/dist/collection/components/eds-logo/eds-logo.js +1 -1
  164. package/dist/collection/components/eds-modal/eds-modal.js +2 -2
  165. package/dist/collection/components/eds-pagination/eds-pagination.js +1 -1
  166. package/dist/collection/components/eds-progress-bar/eds-progress-bar.css +96 -61
  167. package/dist/collection/components/eds-progress-bar/eds-progress-bar.js +48 -3
  168. package/dist/collection/components/eds-progress-bar/eds-progress-bar.stories.js +3 -4
  169. package/dist/collection/components/eds-rating/eds-rating.js +1 -1
  170. package/dist/collection/components/eds-section/eds-section-core/eds-section-core.js +5 -1
  171. package/dist/collection/components/eds-section/eds-section-heading/eds-section-heading.js +2 -2
  172. package/dist/collection/components/eds-spinner/eds-spinner.js +1 -1
  173. package/dist/collection/components/eds-switch/eds-switch.css +13 -2
  174. package/dist/collection/components/eds-switch/eds-switch.js +13 -5
  175. package/dist/collection/components/eds-table/eds-table.css +5 -0
  176. package/dist/collection/components/eds-table/eds-table.js +171 -22
  177. package/dist/collection/components/eds-table/eds-table.stories.js +1 -11
  178. package/dist/collection/components/eds-tag/eds-tag.css +22 -12
  179. package/dist/collection/components/eds-tag/eds-tag.js +1 -1
  180. package/dist/collection/components/eds-timeline/eds-timeline.css +46 -7755
  181. package/dist/collection/components/eds-timeline/eds-timeline.js +4 -1
  182. package/dist/collection/components/eds-toast/eds-toast.js +7 -7
  183. package/dist/collection/components/eds-tooltip/eds-tooltip.css +89 -93
  184. package/dist/collection/components/eds-tooltip/eds-tooltip.js +6 -120
  185. package/dist/collection/components/eds-tooltip/eds-tooltip.stories.js +5 -3
  186. package/dist/collection/components/eds-trl/eds-trl.js +1 -1
  187. package/dist/collection/eds-docs-ui/colors/color-palette/primary.js +1 -1
  188. package/dist/collection/eds-docs-ui/colors/color-palette/secondary.js +1 -1
  189. package/dist/collection/eds-docs-ui/colors/color-palette/support.js +1 -1
  190. package/dist/collection/eds-docs-ui/colors/gradient-palette/primary.js +1 -1
  191. package/dist/collection/eds-docs-ui/colors/gradient-palette/secondary.js +7 -7
  192. package/dist/collection/eds-docs-ui/colors/gradient-palette/support.js +3 -3
  193. package/dist/collection/eds-docs-ui/colors/use-of-colors/correct-use-of-colors.js +1 -1
  194. package/dist/collection/eds-docs-ui/colors/use-of-colors/incorrect-use-of-colors.js +1 -1
  195. package/dist/collection/eds-docs-ui/components-section/components-section.js +1 -1
  196. package/dist/collection/eds-docs-ui/components-section/functional/angular.js +1 -1
  197. package/dist/collection/eds-docs-ui/components-section/functional/installation.js +1 -1
  198. package/dist/collection/eds-docs-ui/components-section/functional/overview.js +2 -2
  199. package/dist/collection/eds-docs-ui/components-section/functional/react.js +1 -1
  200. package/dist/collection/eds-docs-ui/design-tokens/docs-tokens/docs-tokens.js +1 -1
  201. package/dist/collection/eds-docs-ui/design-tokens/token-list/token-list.js +1 -1
  202. package/dist/collection/eds-docs-ui/design-tokens/token-radii/token-radii.js +1 -1
  203. package/dist/collection/eds-docs-ui/design-tokens/token-ratios/token-ratios.js +1 -1
  204. package/dist/collection/eds-docs-ui/design-tokens/token-shadows/token-shadows.js +1 -1
  205. package/dist/collection/eds-docs-ui/design-tokens/token-spacing/token-spacing.js +1 -1
  206. package/dist/collection/eds-docs-ui/design-tokens/token-typography/token-typography.js +1 -1
  207. package/dist/collection/eds-docs-ui/docs-palettes/docs-palettes.js +1 -1
  208. package/dist/collection/eds-docs-ui/logo/logo-space/logo-space.js +1 -1
  209. package/dist/collection/eds-docs-ui/logo/logo-variations/horizontal/logo-variations-horizontal.js +1 -1
  210. package/dist/collection/eds-docs-ui/logo/logo-variations/vertical/logo-variations-vertical.js +1 -1
  211. package/dist/collection/eds-docs-ui/logo/logo-variations-tabs/logo-variations.js +1 -1
  212. package/dist/collection/eds-docs-ui/logo/logo-wrong-usage/logo-wrong-usage.js +1 -1
  213. package/dist/collection/eds-docs-ui/svg-repository/svg-repository.js +1 -1
  214. package/dist/collection/shared-ui/eds-cookies-preference/eds-cookies-preference.js +1 -1
  215. package/dist/collection/shared-ui/eds-feedback/eds-feedback.js +24 -1
  216. package/dist/collection/shared-ui/eds-feedback/eds-feedback.stories.js +9 -1
  217. package/dist/collection/shared-ui/eds-footer/eds-footer.css +4 -0
  218. package/dist/collection/shared-ui/eds-footer/eds-footer.js +46 -2
  219. package/dist/collection/shared-ui/eds-footer/eds-footer.stories.js +16 -3
  220. package/dist/collection/shared-ui/eds-form/eds-form.js +74 -10
  221. package/dist/collection/shared-ui/eds-frame/eds-frame.css +147 -115
  222. package/dist/collection/shared-ui/eds-frame/eds-frame.js +1 -1
  223. package/dist/collection/shared-ui/eds-fullscreen-menu/eds-fullscreen-menu.css +149 -117
  224. package/dist/collection/shared-ui/eds-fullscreen-menu/eds-fullscreen-menu.js +1 -1
  225. package/dist/collection/shared-ui/eds-header/eds-header.css +178 -132
  226. package/dist/collection/shared-ui/eds-header/eds-header.js +21 -40
  227. package/dist/collection/shared-ui/eds-header/eds-header.stories.js +6 -5
  228. package/dist/collection/shared-ui/eds-matomo-notice/eds-matomo-notice.js +8 -6
  229. package/dist/collection/shared-ui/eds-matomo-notice/eds-matomo-notice.stories.js +1 -0
  230. package/dist/collection/shared-ui/eds-social-networks/eds-social-networks.js +1 -1
  231. package/dist/collection/{components → shared-ui}/eds-steps/eds-steps.css +2 -35
  232. package/dist/collection/{components → shared-ui}/eds-steps/eds-steps.js +4 -4
  233. package/dist/collection/{components → shared-ui}/eds-steps/eds-steps.stories.js +1 -1
  234. package/dist/collection/shared-ui/eds-steps-v2/eds-steps-v2.css +14 -121
  235. package/dist/collection/shared-ui/eds-steps-v2/eds-steps-v2.js +20 -2
  236. package/dist/collection/shared-ui/eds-steps-v2/eds-steps-v2.stories.js +1 -1
  237. package/dist/collection/shared-ui/eds-tabs/eds-tabs.css +268 -7686
  238. package/dist/collection/shared-ui/eds-tabs/eds-tabs.js +10 -10
  239. package/dist/collection/shared-ui/eds-tabs/eds-tabs.stories.js +20 -10
  240. package/dist/collection/shared-ui/eds-toast-manager/eds-toast-manager.js +1 -1
  241. package/dist/collection/shared-ui/eds-user/eds-user.css +36 -7758
  242. package/dist/collection/shared-ui/eds-user/eds-user.js +1 -1
  243. package/dist/collection/shared-ui/examples/eds-app-root/eds-app-root.js +1 -1
  244. package/dist/collection/utils/analytics.js +2 -2
  245. package/dist/collection/utils/color.js +8 -8
  246. package/dist/components/analytics.js +2 -2
  247. package/dist/components/components-section.js +23 -17
  248. package/dist/components/components.css +36 -515
  249. package/dist/components/components.esm.js +1 -1
  250. package/dist/components/correct-use-of-colors.js +1 -1
  251. package/dist/components/docs-palettes.js +1 -1
  252. package/dist/components/docs-tokens.js +1 -1
  253. package/dist/components/eds-accordion2.js +3 -3
  254. package/dist/components/eds-alert2.js +3 -3
  255. package/dist/components/eds-app-root.js +2 -20
  256. package/dist/components/eds-avatar2.js +4 -15
  257. package/dist/components/eds-block-break2.js +4 -4
  258. package/dist/components/eds-breadcrumb.js +1 -1
  259. package/dist/components/eds-button2.js +6 -60
  260. package/dist/components/eds-card-desc2.js +2 -4
  261. package/dist/components/eds-card-generic2.js +2 -2
  262. package/dist/components/eds-card-project.js +131 -2
  263. package/dist/components/eds-card-tags.js +1 -1
  264. package/dist/components/eds-card-title2.js +1 -1
  265. package/dist/components/eds-card-tool.js +1 -1
  266. package/dist/components/eds-code-block2.js +1 -1
  267. package/dist/components/eds-cookies-preference.js +1 -1
  268. package/dist/components/eds-dropdown2.js +2 -2
  269. package/dist/components/eds-feedback.js +7 -1
  270. package/dist/components/eds-footer2.js +7 -3
  271. package/dist/components/eds-form.js +29 -9
  272. package/dist/components/eds-frame.js +2 -2
  273. package/dist/components/eds-fullscreen-menu.js +1 -1
  274. package/dist/components/{eds-login.d.ts → eds-gauge.d.ts} +4 -4
  275. package/dist/components/eds-gauge.js +81 -0
  276. package/dist/components/eds-header.js +15 -34
  277. package/dist/components/eds-icon-arrow-diagonal.js +1 -1
  278. package/dist/components/eds-icon-arrow-right.js +1 -1
  279. package/dist/components/eds-icon-bluesky.js +1 -1
  280. package/dist/components/eds-icon-bookmark.js +1 -1
  281. package/dist/components/eds-icon-chevron-down.js +1 -1
  282. package/dist/components/eds-icon-chevron-left.js +1 -1
  283. package/dist/components/eds-icon-chevron-right.js +1 -1
  284. package/dist/components/eds-icon-chevron-up.js +1 -1
  285. package/dist/components/eds-icon-close.js +1 -1
  286. package/dist/components/eds-icon-copy.js +1 -1
  287. package/dist/components/eds-icon-eu.js +1 -1
  288. package/dist/components/eds-icon-external.js +1 -1
  289. package/dist/components/eds-icon-facebook.js +1 -1
  290. package/dist/components/eds-icon-gitlab.js +1 -1
  291. package/dist/components/eds-icon-linkedin.js +1 -1
  292. package/dist/components/eds-icon-loader.js +1 -1
  293. package/dist/components/eds-icon-mastodon.js +1 -1
  294. package/dist/components/eds-icon-menu.js +1 -1
  295. package/dist/components/eds-icon-minus.js +1 -1
  296. package/dist/components/eds-icon-more.js +1 -1
  297. package/dist/components/eds-icon-paper.js +1 -1
  298. package/dist/components/eds-icon-plus.js +1 -1
  299. package/dist/components/eds-icon-portal.js +1 -1
  300. package/dist/components/eds-icon-private.js +1 -1
  301. package/dist/components/eds-icon-public.js +1 -1
  302. package/dist/components/eds-icon-search.js +1 -1
  303. package/dist/components/eds-icon-star.js +1 -1
  304. package/dist/components/eds-icon-success.js +1 -1
  305. package/dist/components/eds-icon-thumbs-down.js +1 -1
  306. package/dist/components/eds-icon-thumbs-up.js +1 -1
  307. package/dist/components/eds-icon-tutorial.js +1 -1
  308. package/dist/components/eds-icon-twitter.js +1 -1
  309. package/dist/components/eds-icon-unknown.js +1 -1
  310. package/dist/components/eds-icon-updown.js +1 -1
  311. package/dist/components/eds-icon-user.js +1 -1
  312. package/dist/components/eds-icon-youtube.js +1 -1
  313. package/dist/components/eds-img2.js +2 -2
  314. package/dist/components/eds-input-field2.js +26 -16
  315. package/dist/components/eds-input-footer2.js +1 -1
  316. package/dist/components/eds-input-label2.js +1 -1
  317. package/dist/components/eds-input-range2.js +1 -1
  318. package/dist/components/eds-input-search2.js +1 -1
  319. package/dist/components/eds-input-select2.js +12 -84
  320. package/dist/components/eds-input2.js +2 -2
  321. package/dist/components/eds-link2.js +3 -2
  322. package/dist/components/eds-logo2.js +1 -1
  323. package/dist/components/eds-matomo-notice2.js +8 -6
  324. package/dist/components/eds-modal.js +2 -2
  325. package/dist/components/eds-pagination2.js +1 -1
  326. package/dist/components/{eds-card-wrapper.d.ts → eds-pie.d.ts} +4 -4
  327. package/dist/components/eds-pie.js +127 -0
  328. package/dist/components/eds-progress-bar2.js +32 -4
  329. package/dist/components/eds-rating2.js +1 -1
  330. package/dist/components/eds-section-core2.js +3 -2
  331. package/dist/components/eds-section-heading2.js +2 -2
  332. package/dist/components/eds-social-networks2.js +1 -1
  333. package/dist/components/eds-spinner2.js +1 -1
  334. package/dist/components/eds-steps-v2.js +5 -3
  335. package/dist/components/eds-steps2.js +3 -3
  336. package/dist/components/eds-switch.js +13 -5
  337. package/dist/components/eds-table2.js +85 -25
  338. package/dist/components/eds-tabs.js +11 -11
  339. package/dist/components/eds-tag2.js +2 -2
  340. package/dist/components/eds-timeline.js +2 -2
  341. package/dist/components/eds-toast-manager.js +31 -2
  342. package/dist/components/eds-toast2.js +4 -3
  343. package/dist/components/eds-tooltip.js +7 -88
  344. package/dist/components/eds-trl.js +1 -1
  345. package/dist/components/eds-user.js +10 -4
  346. package/dist/components/incorrect-use-of-colors.js +1 -1
  347. package/dist/components/logo-space.js +1 -1
  348. package/dist/components/logo-variations-horizontal2.js +1 -1
  349. package/dist/components/logo-variations-tabs.js +1 -1
  350. package/dist/components/logo-variations-vertical2.js +1 -1
  351. package/dist/components/logo-wrong-usage.js +1 -1
  352. package/dist/components/p-019555e2.entry.js +1 -0
  353. package/dist/components/p-023bc47c.entry.js +1 -0
  354. package/dist/components/p-0ed92872.entry.js +1 -0
  355. package/dist/components/{p-892362e0.entry.js → p-10db551c.entry.js} +1 -1
  356. package/dist/components/p-11efb1d1.entry.js +1 -0
  357. package/dist/components/p-14679a86.entry.js +1 -0
  358. package/dist/components/p-158c95bc.entry.js +1 -0
  359. package/dist/components/{p-e089797c.entry.js → p-1661f33c.entry.js} +1 -1
  360. package/dist/components/p-177103fd.entry.js +1 -0
  361. package/dist/components/p-17d39d66.entry.js +1 -0
  362. package/dist/components/p-19d586e6.entry.js +1 -0
  363. package/dist/components/p-1de8401b.entry.js +1 -0
  364. package/dist/components/{p-7a550385.entry.js → p-1f5c19b9.entry.js} +1 -1
  365. package/dist/components/p-223ba66e.entry.js +1 -0
  366. package/dist/components/{p-751497f4.entry.js → p-24dab785.entry.js} +1 -1
  367. package/dist/components/p-2810d568.entry.js +1 -0
  368. package/dist/components/p-28ae3f3a.js +2 -0
  369. package/dist/components/p-2c571550.entry.js +1 -0
  370. package/dist/components/p-321a950b.entry.js +1 -0
  371. package/dist/components/p-326d9e55.entry.js +1 -0
  372. package/dist/components/p-36d6134f.entry.js +1 -0
  373. package/dist/components/p-38c9aee7.entry.js +1 -0
  374. package/dist/components/p-42295abe.entry.js +1 -0
  375. package/dist/components/p-424e91b3.entry.js +1 -0
  376. package/dist/components/p-43cff423.entry.js +1 -0
  377. package/dist/components/p-45f21238.entry.js +1 -0
  378. package/dist/components/{p-75d37c48.entry.js → p-46a6ab04.entry.js} +1 -1
  379. package/dist/components/p-4bdf1589.entry.js +1 -0
  380. package/dist/components/p-4dcdd4d9.entry.js +1 -0
  381. package/dist/components/p-4fad9296.entry.js +1 -0
  382. package/dist/components/p-50f43dfd.entry.js +1 -0
  383. package/dist/components/p-563d56c0.entry.js +1 -0
  384. package/dist/components/p-5827fd52.entry.js +1 -0
  385. package/dist/components/p-590fb0e7.entry.js +1 -0
  386. package/dist/components/p-5c5dfc4a.entry.js +1 -0
  387. package/dist/components/p-66f4cdd9.entry.js +1 -0
  388. package/dist/components/{p-0b99fd3c.entry.js → p-682f7376.entry.js} +1 -1
  389. package/dist/components/p-6907a47c.entry.js +1 -0
  390. package/dist/components/p-6dc6f729.entry.js +1 -0
  391. package/dist/components/p-6f9ab63c.entry.js +1 -0
  392. package/dist/components/p-7502b8b4.entry.js +1 -0
  393. package/dist/components/p-750e3ec8.entry.js +1 -0
  394. package/dist/components/p-7f31622d.entry.js +1 -0
  395. package/dist/components/p-8c0b0121.entry.js +1 -0
  396. package/dist/components/p-95518776.entry.js +1 -0
  397. package/dist/components/p-99d9bb29.entry.js +1 -0
  398. package/dist/components/p-9a4b5746.entry.js +1 -0
  399. package/dist/components/p-9c823b5e.entry.js +1 -0
  400. package/dist/components/p-9d64d1fd.entry.js +1 -0
  401. package/dist/components/{p-29ad9c73.entry.js → p-a4f552b2.entry.js} +1 -1
  402. package/dist/components/p-ab4447f6.entry.js +1 -0
  403. package/dist/components/{p-b8ba7e5c.entry.js → p-adbd0d7b.entry.js} +1 -1
  404. package/dist/components/p-b073d78f.entry.js +1 -0
  405. package/dist/components/{p-7db75d62.entry.js → p-b4abff90.entry.js} +1 -1
  406. package/dist/components/{p-67c72c20.entry.js → p-b50fc0d7.entry.js} +1 -1
  407. package/dist/components/{p-037975af.entry.js → p-b5e64725.entry.js} +1 -1
  408. package/dist/components/p-b630e51a.entry.js +1 -0
  409. package/dist/components/p-bb9af709.entry.js +1 -0
  410. package/dist/components/p-c91b4eec.entry.js +1 -0
  411. package/dist/components/{p-688e07d6.entry.js → p-cde3d7a4.entry.js} +1 -1
  412. package/dist/components/p-cfccddc3.entry.js +1 -0
  413. package/dist/components/{p-c4db0829.entry.js → p-d05a09df.entry.js} +1 -1
  414. package/dist/components/p-d0b1e963.entry.js +1 -0
  415. package/dist/components/p-d15065c3.js +1 -0
  416. package/dist/components/p-d25364db.entry.js +1 -0
  417. package/dist/components/p-d3bb444a.entry.js +1 -0
  418. package/dist/components/p-d4f239d7.entry.js +1 -0
  419. package/dist/components/p-deb9bbed.entry.js +1 -0
  420. package/dist/components/p-df772a35.entry.js +1 -0
  421. package/dist/components/p-e5113509.entry.js +1 -0
  422. package/dist/components/p-e6a0b8c2.entry.js +1 -0
  423. package/dist/components/p-e8f0d7fc.entry.js +1 -0
  424. package/dist/components/{p-e2b00067.entry.js → p-eac593ee.entry.js} +1 -1
  425. package/dist/components/p-f189be4f.entry.js +1 -0
  426. package/dist/components/p-f221eca2.entry.js +1 -0
  427. package/dist/components/p-f2416727.entry.js +1 -0
  428. package/dist/components/{p-7ac9881e.entry.js → p-f2c23162.entry.js} +1 -1
  429. package/dist/components/{p-d83d2815.entry.js → p-f7716080.entry.js} +1 -1
  430. package/dist/components/p-fc4edb18.entry.js +1 -0
  431. package/dist/components/p-fd85675b.entry.js +1 -0
  432. package/dist/components/{p-55e3683c.entry.js → p-fe167c78.entry.js} +2 -2
  433. package/dist/components/p-ffccfeb6.entry.js +1 -0
  434. package/dist/components/primary.js +1 -1
  435. package/dist/components/primary2.js +1 -1
  436. package/dist/components/secondary.js +1 -1
  437. package/dist/components/secondary2.js +7 -7
  438. package/dist/components/support.js +1 -1
  439. package/dist/components/support2.js +3 -3
  440. package/dist/components/svg-repository.js +1 -1
  441. package/dist/components/token-list2.js +1 -1
  442. package/dist/components/token-radii2.js +1 -1
  443. package/dist/components/token-ratios.js +1 -1
  444. package/dist/components/token-shadows2.js +1 -1
  445. package/dist/components/token-spacing.js +1 -1
  446. package/dist/components/token-typography.js +1 -1
  447. package/dist/esm/{analytics-44b1416b.js → analytics-d99780e3.js} +2 -2
  448. package/dist/esm/color-primary-palette_6.entry.js +15 -15
  449. package/dist/esm/components-section.entry.js +24 -18
  450. package/dist/esm/components.js +3 -3
  451. package/dist/esm/correct-use-of-colors.entry.js +2 -2
  452. package/dist/esm/docs-palettes.entry.js +2 -2
  453. package/dist/esm/docs-tokens.entry.js +2 -2
  454. package/dist/esm/eds-accordion.entry.js +5 -5
  455. package/dist/esm/eds-alert.entry.js +4 -4
  456. package/dist/esm/eds-app-root.entry.js +2 -2
  457. package/dist/esm/eds-avatar_28.entry.js +2680 -0
  458. package/dist/esm/eds-breadcrumb.entry.js +141 -0
  459. package/dist/esm/eds-card-desc_2.entry.js +4 -5
  460. package/dist/esm/eds-card-generic.entry.js +4 -4
  461. package/dist/esm/eds-card-project.entry.js +133 -5
  462. package/dist/esm/eds-card-section.entry.js +1 -1
  463. package/dist/esm/eds-card-tags.entry.js +2 -2
  464. package/dist/esm/eds-card-tool.entry.js +3 -3
  465. package/dist/esm/eds-code-block.entry.js +2 -2
  466. package/dist/esm/eds-cookies-preference.entry.js +2 -2
  467. package/dist/esm/eds-feedback.entry.js +7 -2
  468. package/dist/esm/eds-frame.entry.js +3 -3
  469. package/dist/esm/eds-gauge.entry.js +56 -0
  470. package/dist/esm/eds-icon-arrow-diagonal.entry.js +2 -2
  471. package/dist/esm/eds-icon-arrow-right.entry.js +2 -2
  472. package/dist/esm/eds-icon-bluesky.entry.js +2 -2
  473. package/dist/esm/eds-icon-bookmark.entry.js +2 -2
  474. package/dist/esm/eds-icon-chevron-down.entry.js +2 -2
  475. package/dist/esm/eds-icon-chevron-left.entry.js +2 -2
  476. package/dist/esm/eds-icon-chevron-right.entry.js +2 -2
  477. package/dist/esm/eds-icon-chevron-up.entry.js +2 -2
  478. package/dist/esm/eds-icon-close.entry.js +2 -2
  479. package/dist/esm/eds-icon-copy.entry.js +2 -2
  480. package/dist/esm/eds-icon-eu.entry.js +2 -2
  481. package/dist/esm/eds-icon-external.entry.js +2 -2
  482. package/dist/esm/eds-icon-facebook.entry.js +2 -2
  483. package/dist/esm/eds-icon-gitlab.entry.js +2 -2
  484. package/dist/esm/eds-icon-linkedin.entry.js +2 -2
  485. package/dist/esm/eds-icon-loader.entry.js +2 -2
  486. package/dist/esm/eds-icon-mastodon.entry.js +2 -2
  487. package/dist/esm/eds-icon-menu.entry.js +2 -2
  488. package/dist/esm/eds-icon-minus.entry.js +2 -2
  489. package/dist/esm/eds-icon-more.entry.js +2 -2
  490. package/dist/esm/eds-icon-paper.entry.js +2 -2
  491. package/dist/esm/eds-icon-plus.entry.js +2 -2
  492. package/dist/esm/eds-icon-portal.entry.js +2 -2
  493. package/dist/esm/eds-icon-private.entry.js +2 -2
  494. package/dist/esm/eds-icon-public.entry.js +2 -2
  495. package/dist/esm/eds-icon-search.entry.js +2 -2
  496. package/dist/esm/eds-icon-star.entry.js +2 -2
  497. package/dist/esm/eds-icon-success.entry.js +2 -2
  498. package/dist/esm/eds-icon-thumbs-down.entry.js +2 -2
  499. package/dist/esm/eds-icon-thumbs-up.entry.js +2 -2
  500. package/dist/esm/eds-icon-tutorial.entry.js +2 -2
  501. package/dist/esm/eds-icon-twitter.entry.js +2 -2
  502. package/dist/esm/eds-icon-unknown.entry.js +2 -2
  503. package/dist/esm/eds-icon-updown.entry.js +2 -2
  504. package/dist/esm/eds-icon-user.entry.js +2 -2
  505. package/dist/esm/eds-icon-youtube.entry.js +2 -2
  506. package/dist/esm/eds-matomo-notice.entry.js +10 -8
  507. package/dist/esm/eds-pie.entry.js +102 -0
  508. package/dist/esm/eds-progress-bar.entry.js +32 -5
  509. package/dist/esm/eds-rating.entry.js +2 -2
  510. package/dist/esm/eds-section-core_2.entry.js +4 -4
  511. package/dist/esm/eds-spinner.entry.js +2 -2
  512. package/dist/esm/eds-splash-screen.entry.js +56 -0
  513. package/dist/esm/eds-switch.entry.js +14 -6
  514. package/dist/esm/eds-timeline.entry.js +3 -3
  515. package/dist/esm/eds-toast-manager.entry.js +32 -3
  516. package/dist/esm/eds-toast.entry.js +5 -4
  517. package/dist/esm/eds-tooltip.entry.js +7 -84
  518. package/dist/esm/eds-trl.entry.js +2 -2
  519. package/dist/esm/incorrect-use-of-colors.entry.js +2 -2
  520. package/dist/esm/{index-8a71b9a7.js → index-fdb33359.js} +53 -311
  521. package/dist/esm/loader.js +3 -3
  522. package/dist/esm/logo-space.entry.js +2 -2
  523. package/dist/esm/logo-variations-horizontal_2.entry.js +3 -3
  524. package/dist/esm/logo-variations-tabs.entry.js +2 -2
  525. package/dist/esm/logo-wrong-usage.entry.js +2 -2
  526. package/dist/esm/svg-repository.entry.js +2 -2
  527. package/dist/esm/token-list_3.entry.js +4 -4
  528. package/dist/esm/token-ratios.entry.js +2 -2
  529. package/dist/esm/token-spacing.entry.js +12 -0
  530. package/dist/esm/token-typography.entry.js +2 -2
  531. package/dist/hydrate/index.js +941 -2935
  532. package/dist/hydrate/index.mjs +941 -2935
  533. package/dist/types/components/eds-avatar/eds-avatar.d.ts +3 -4
  534. package/dist/types/components/eds-avatar/eds-avatar.stories.d.ts +2 -1
  535. package/dist/types/components/eds-block-break/eds-block-break.d.ts +2 -7
  536. package/dist/types/components/eds-button/eds-button.d.ts +0 -1
  537. package/dist/types/components/eds-cards/eds-card-composer/eds-card-desc/eds-card-desc.d.ts +0 -5
  538. package/dist/types/components/eds-charts/eds-gauge/eds-gauge.d.ts +14 -0
  539. package/dist/types/components/eds-charts/eds-gauge/eds-gauge.stories.d.ts +52 -0
  540. package/dist/types/components/eds-charts/eds-pie/eds-pie.d.ts +28 -0
  541. package/dist/types/components/eds-charts/eds-pie/eds-pie.stories.d.ts +60 -0
  542. package/dist/types/components/eds-input-elements/eds-input-select/eds-input-select.d.ts +18 -116
  543. package/dist/types/components/eds-input-field/eds-input-field.d.ts +6 -0
  544. package/dist/types/components/eds-progress-bar/eds-progress-bar.d.ts +3 -3
  545. package/dist/types/components/eds-progress-bar/eds-progress-bar.stories.d.ts +3 -0
  546. package/dist/types/components/eds-section/eds-section-core/eds-section-core.d.ts +3 -0
  547. package/dist/types/components/eds-switch/eds-switch.d.ts +2 -1
  548. package/dist/types/components/eds-table/eds-table.d.ts +69 -0
  549. package/dist/types/components/eds-table/eds-table.stories.d.ts +0 -8
  550. package/dist/types/components/eds-timeline/eds-timeline.d.ts +3 -0
  551. package/dist/types/components/eds-toast/eds-toast.d.ts +3 -2
  552. package/dist/types/components/eds-tooltip/eds-tooltip.d.ts +2 -36
  553. package/dist/types/components.d.ts +259 -241
  554. package/dist/types/shared-ui/eds-feedback/eds-feedback.d.ts +4 -0
  555. package/dist/types/shared-ui/eds-feedback/eds-feedback.stories.d.ts +8 -4
  556. package/dist/types/shared-ui/eds-footer/eds-footer.d.ts +10 -0
  557. package/dist/types/shared-ui/eds-footer/eds-footer.stories.d.ts +10 -0
  558. package/dist/types/shared-ui/eds-form/eds-form.d.ts +4 -1
  559. package/dist/types/shared-ui/eds-header/eds-header.d.ts +5 -24
  560. package/dist/types/shared-ui/eds-header/eds-header.stories.d.ts +6 -3
  561. package/dist/types/shared-ui/eds-matomo-notice/eds-matomo-notice.d.ts +0 -1
  562. package/dist/types/shared-ui/eds-steps-v2/eds-steps-v2.d.ts +2 -0
  563. package/dist/types/shared-ui/eds-tabs/eds-tabs.stories.d.ts +0 -1
  564. package/package.json +14 -4
  565. package/dist/cjs/color-c00146a8.js +0 -134
  566. package/dist/cjs/eds-avatar_27.cjs.entry.js +0 -2404
  567. package/dist/cjs/eds-card-wrapper.cjs.entry.js +0 -32
  568. package/dist/cjs/eds-login_2.cjs.entry.js +0 -2100
  569. package/dist/cjs/eds-pagination_2.cjs.entry.js +0 -403
  570. package/dist/cjs/eds-tabs.cjs.entry.js +0 -130
  571. package/dist/cjs/toastManager-4e9535f3.js +0 -33
  572. package/dist/collection/components/eds-cards/eds-card-composer/eds-card-wrapper/eds-card-wrapper.js +0 -86
  573. package/dist/collection/shared-ui/eds-login/eds-login.js +0 -190
  574. package/dist/components/color.js +0 -132
  575. package/dist/components/eds-card-wrapper.js +0 -49
  576. package/dist/components/eds-login.js +0 -6
  577. package/dist/components/eds-login2.js +0 -2076
  578. package/dist/components/p-05549a74.entry.js +0 -1
  579. package/dist/components/p-05b272e5.entry.js +0 -1
  580. package/dist/components/p-0e378e0e.entry.js +0 -1
  581. package/dist/components/p-13efafb9.js +0 -1
  582. package/dist/components/p-1ec25dc2.entry.js +0 -1
  583. package/dist/components/p-202f78cc.entry.js +0 -1
  584. package/dist/components/p-22b76c3c.entry.js +0 -1
  585. package/dist/components/p-22f9e720.js +0 -1
  586. package/dist/components/p-24300934.entry.js +0 -1
  587. package/dist/components/p-25f1cc6c.entry.js +0 -1
  588. package/dist/components/p-31ca07fd.entry.js +0 -1
  589. package/dist/components/p-342bc3d8.entry.js +0 -1
  590. package/dist/components/p-35068b80.entry.js +0 -1
  591. package/dist/components/p-3950debe.entry.js +0 -1
  592. package/dist/components/p-3d74d4b1.entry.js +0 -1
  593. package/dist/components/p-42f19373.entry.js +0 -1
  594. package/dist/components/p-4ecaedbc.entry.js +0 -1
  595. package/dist/components/p-5055eb25.entry.js +0 -1
  596. package/dist/components/p-5646902d.entry.js +0 -1
  597. package/dist/components/p-5ff68e7d.entry.js +0 -1
  598. package/dist/components/p-63cc5d3d.entry.js +0 -1
  599. package/dist/components/p-6506cf52.entry.js +0 -1
  600. package/dist/components/p-6aa17003.entry.js +0 -1
  601. package/dist/components/p-6e273e0f.entry.js +0 -1
  602. package/dist/components/p-6fcb754e.entry.js +0 -1
  603. package/dist/components/p-70c9af1e.entry.js +0 -1
  604. package/dist/components/p-7180a36b.entry.js +0 -1
  605. package/dist/components/p-7351cad3.entry.js +0 -1
  606. package/dist/components/p-75cc9f9e.entry.js +0 -1
  607. package/dist/components/p-7a31c31f.entry.js +0 -1
  608. package/dist/components/p-7cb60f9c.entry.js +0 -1
  609. package/dist/components/p-888c3471.entry.js +0 -1
  610. package/dist/components/p-8a4d9b9b.entry.js +0 -1
  611. package/dist/components/p-8b7f5204.entry.js +0 -1
  612. package/dist/components/p-8db820ef.entry.js +0 -1
  613. package/dist/components/p-aa2e6fec.entry.js +0 -1
  614. package/dist/components/p-ae4f5e3a.entry.js +0 -1
  615. package/dist/components/p-b024183c.entry.js +0 -1
  616. package/dist/components/p-b115c3f1.entry.js +0 -1
  617. package/dist/components/p-b3a3ae59.entry.js +0 -1
  618. package/dist/components/p-b4595a9e.entry.js +0 -1
  619. package/dist/components/p-b817dceb.entry.js +0 -1
  620. package/dist/components/p-b8ca2127.entry.js +0 -1
  621. package/dist/components/p-ba6cc102.entry.js +0 -1
  622. package/dist/components/p-c51b5f04.entry.js +0 -1
  623. package/dist/components/p-c5a7d2b1.entry.js +0 -1
  624. package/dist/components/p-c5c782e7.entry.js +0 -1
  625. package/dist/components/p-c5f98369.entry.js +0 -1
  626. package/dist/components/p-c604063d.entry.js +0 -1
  627. package/dist/components/p-c9a19e93.entry.js +0 -1
  628. package/dist/components/p-cccacbd3.js +0 -2
  629. package/dist/components/p-d164a75d.entry.js +0 -1
  630. package/dist/components/p-d4c920fa.entry.js +0 -1
  631. package/dist/components/p-d82cc261.entry.js +0 -1
  632. package/dist/components/p-da6e49a9.entry.js +0 -1
  633. package/dist/components/p-dcd4de1f.entry.js +0 -1
  634. package/dist/components/p-e8a2d709.entry.js +0 -1
  635. package/dist/components/p-ea942740.entry.js +0 -1
  636. package/dist/components/p-eb0b93d5.js +0 -1
  637. package/dist/components/p-ece20356.entry.js +0 -1
  638. package/dist/components/p-ed6fd4b8.entry.js +0 -1
  639. package/dist/components/p-f3822d6b.entry.js +0 -1
  640. package/dist/components/p-f539febe.entry.js +0 -1
  641. package/dist/components/p-f7f4b247.entry.js +0 -1
  642. package/dist/components/p-fdbfa776.entry.js +0 -1
  643. package/dist/components/p-fe27f4a9.entry.js +0 -1
  644. package/dist/components/toastManager.js +0 -31
  645. package/dist/esm/color-2554aad6.js +0 -132
  646. package/dist/esm/eds-avatar_27.entry.js +0 -2374
  647. package/dist/esm/eds-card-wrapper.entry.js +0 -28
  648. package/dist/esm/eds-login_2.entry.js +0 -2095
  649. package/dist/esm/eds-pagination_2.entry.js +0 -398
  650. package/dist/esm/eds-tabs.entry.js +0 -126
  651. package/dist/esm/toastManager-d9eee791.js +0 -31
  652. package/dist/types/components/eds-cards/eds-card-composer/eds-card-wrapper/eds-card-wrapper.d.ts +0 -23
  653. package/dist/types/shared-ui/eds-login/eds-login.d.ts +0 -67
  654. /package/dist/collection/components/eds-section/eds-section-core/{eds-section-core.stories.js → eds-section-core.donotstories.js} +0 -0
  655. /package/dist/collection/components/eds-timeline/{eds-timeline.stories.js → eds-timeline.donot-stories.js} +0 -0
  656. /package/dist/types/components/eds-section/eds-section-core/{eds-section-core.stories.d.ts → eds-section-core.donotstories.d.ts} +0 -0
  657. /package/dist/types/components/eds-timeline/{eds-timeline.stories.d.ts → eds-timeline.donot-stories.d.ts} +0 -0
  658. /package/dist/types/{components → shared-ui}/eds-steps/eds-steps.d.ts +0 -0
  659. /package/dist/types/{components → shared-ui}/eds-steps/eds-steps.stories.d.ts +0 -0
@@ -1,2076 +0,0 @@
1
- import { proxyCustomElement, HTMLElement, createEvent, h } from '@stencil/core/internal/client';
2
- import { t as toast } from './toastManager.js';
3
- import { d as defineCustomElement$2 } from './eds-button2.js';
4
- import { d as defineCustomElement$1 } from './eds-icon-wrapper2.js';
5
-
6
- /*
7
- * Copyright 2016 Red Hat, Inc. and/or its affiliates
8
- * and other contributors as indicated by the @author tags.
9
- *
10
- * Licensed under the Apache License, Version 2.0 (the "License");
11
- * you may not use this file except in compliance with the License.
12
- * You may obtain a copy of the License at
13
- *
14
- * http://www.apache.org/licenses/LICENSE-2.0
15
- *
16
- * Unless required by applicable law or agreed to in writing, software
17
- * distributed under the License is distributed on an "AS IS" BASIS,
18
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19
- * See the License for the specific language governing permissions and
20
- * limitations under the License.
21
- */
22
- function Keycloak (config) {
23
- if (!(this instanceof Keycloak)) {
24
- throw new Error("The 'Keycloak' constructor must be invoked with 'new'.")
25
- }
26
-
27
- if (typeof config !== 'string' && !isObject(config)) {
28
- throw new Error("The 'Keycloak' constructor must be provided with a configuration object, or a URL to a JSON configuration file.");
29
- }
30
-
31
- if (isObject(config)) {
32
- const requiredProperties = 'oidcProvider' in config
33
- ? ['clientId']
34
- : ['url', 'realm', 'clientId'];
35
-
36
- for (const property of requiredProperties) {
37
- if (!config[property]) {
38
- throw new Error(`The configuration object is missing the required '${property}' property.`);
39
- }
40
- }
41
- }
42
-
43
- var kc = this;
44
- var adapter;
45
- var refreshQueue = [];
46
- var callbackStorage;
47
-
48
- var loginIframe = {
49
- enable: true,
50
- callbackList: [],
51
- interval: 5
52
- };
53
-
54
- kc.didInitialize = false;
55
-
56
- var useNonce = true;
57
- var logInfo = createLogger(console.info);
58
- var logWarn = createLogger(console.warn);
59
-
60
- if (!globalThis.isSecureContext) {
61
- logWarn(
62
- "[KEYCLOAK] Keycloak JS must be used in a 'secure context' to function properly as it relies on browser APIs that are otherwise not available.\n" +
63
- "Continuing to run your application insecurely will lead to unexpected behavior and breakage.\n\n" +
64
- "For more information see: https://developer.mozilla.org/en-US/docs/Web/Security/Secure_Contexts"
65
- );
66
- }
67
-
68
- kc.init = function (initOptions = {}) {
69
- if (kc.didInitialize) {
70
- throw new Error("A 'Keycloak' instance can only be initialized once.");
71
- }
72
-
73
- kc.didInitialize = true;
74
-
75
- kc.authenticated = false;
76
-
77
- callbackStorage = createCallbackStorage();
78
- var adapters = ['default', 'cordova', 'cordova-native'];
79
-
80
- if (adapters.indexOf(initOptions.adapter) > -1) {
81
- adapter = loadAdapter(initOptions.adapter);
82
- } else if (typeof initOptions.adapter === "object") {
83
- adapter = initOptions.adapter;
84
- } else {
85
- if (window.Cordova || window.cordova) {
86
- adapter = loadAdapter('cordova');
87
- } else {
88
- adapter = loadAdapter();
89
- }
90
- }
91
-
92
- if (typeof initOptions.useNonce !== 'undefined') {
93
- useNonce = initOptions.useNonce;
94
- }
95
-
96
- if (typeof initOptions.checkLoginIframe !== 'undefined') {
97
- loginIframe.enable = initOptions.checkLoginIframe;
98
- }
99
-
100
- if (initOptions.checkLoginIframeInterval) {
101
- loginIframe.interval = initOptions.checkLoginIframeInterval;
102
- }
103
-
104
- if (initOptions.onLoad === 'login-required') {
105
- kc.loginRequired = true;
106
- }
107
-
108
- if (initOptions.responseMode) {
109
- if (initOptions.responseMode === 'query' || initOptions.responseMode === 'fragment') {
110
- kc.responseMode = initOptions.responseMode;
111
- } else {
112
- throw 'Invalid value for responseMode';
113
- }
114
- }
115
-
116
- if (initOptions.flow) {
117
- switch (initOptions.flow) {
118
- case 'standard':
119
- kc.responseType = 'code';
120
- break;
121
- case 'implicit':
122
- kc.responseType = 'id_token token';
123
- break;
124
- case 'hybrid':
125
- kc.responseType = 'code id_token token';
126
- break;
127
- default:
128
- throw 'Invalid value for flow';
129
- }
130
- kc.flow = initOptions.flow;
131
- }
132
-
133
- if (initOptions.timeSkew != null) {
134
- kc.timeSkew = initOptions.timeSkew;
135
- }
136
-
137
- if(initOptions.redirectUri) {
138
- kc.redirectUri = initOptions.redirectUri;
139
- }
140
-
141
- if (initOptions.silentCheckSsoRedirectUri) {
142
- kc.silentCheckSsoRedirectUri = initOptions.silentCheckSsoRedirectUri;
143
- }
144
-
145
- if (typeof initOptions.silentCheckSsoFallback === 'boolean') {
146
- kc.silentCheckSsoFallback = initOptions.silentCheckSsoFallback;
147
- } else {
148
- kc.silentCheckSsoFallback = true;
149
- }
150
-
151
- if (typeof initOptions.pkceMethod !== "undefined") {
152
- if (initOptions.pkceMethod !== "S256" && initOptions.pkceMethod !== false) {
153
- throw new TypeError(`Invalid value for pkceMethod', expected 'S256' or false but got ${initOptions.pkceMethod}.`);
154
- }
155
-
156
- kc.pkceMethod = initOptions.pkceMethod;
157
- } else {
158
- kc.pkceMethod = "S256";
159
- }
160
-
161
- if (typeof initOptions.enableLogging === 'boolean') {
162
- kc.enableLogging = initOptions.enableLogging;
163
- } else {
164
- kc.enableLogging = false;
165
- }
166
-
167
- if (initOptions.logoutMethod === 'POST') {
168
- kc.logoutMethod = 'POST';
169
- } else {
170
- kc.logoutMethod = 'GET';
171
- }
172
-
173
- if (typeof initOptions.scope === 'string') {
174
- kc.scope = initOptions.scope;
175
- }
176
-
177
- if (typeof initOptions.acrValues === 'string') {
178
- kc.acrValues = initOptions.acrValues;
179
- }
180
-
181
- if (typeof initOptions.messageReceiveTimeout === 'number' && initOptions.messageReceiveTimeout > 0) {
182
- kc.messageReceiveTimeout = initOptions.messageReceiveTimeout;
183
- } else {
184
- kc.messageReceiveTimeout = 10000;
185
- }
186
-
187
- if (!kc.responseMode) {
188
- kc.responseMode = 'fragment';
189
- }
190
- if (!kc.responseType) {
191
- kc.responseType = 'code';
192
- kc.flow = 'standard';
193
- }
194
-
195
- var promise = createPromise();
196
-
197
- var initPromise = createPromise();
198
- initPromise.promise.then(function() {
199
- kc.onReady && kc.onReady(kc.authenticated);
200
- promise.setSuccess(kc.authenticated);
201
- }).catch(function(error) {
202
- promise.setError(error);
203
- });
204
-
205
- var configPromise = loadConfig();
206
-
207
- function onLoad() {
208
- var doLogin = function(prompt) {
209
- if (!prompt) {
210
- options.prompt = 'none';
211
- }
212
-
213
- if (initOptions.locale) {
214
- options.locale = initOptions.locale;
215
- }
216
- kc.login(options).then(function () {
217
- initPromise.setSuccess();
218
- }).catch(function (error) {
219
- initPromise.setError(error);
220
- });
221
- };
222
-
223
- var checkSsoSilently = async function() {
224
- var ifrm = document.createElement("iframe");
225
- var src = await kc.createLoginUrl({prompt: 'none', redirectUri: kc.silentCheckSsoRedirectUri});
226
- ifrm.setAttribute("src", src);
227
- ifrm.setAttribute("sandbox", "allow-storage-access-by-user-activation allow-scripts allow-same-origin");
228
- ifrm.setAttribute("title", "keycloak-silent-check-sso");
229
- ifrm.style.display = "none";
230
- document.body.appendChild(ifrm);
231
-
232
- var messageCallback = function(event) {
233
- if (event.origin !== window.location.origin || ifrm.contentWindow !== event.source) {
234
- return;
235
- }
236
-
237
- var oauth = parseCallback(event.data);
238
- processCallback(oauth, initPromise);
239
-
240
- document.body.removeChild(ifrm);
241
- window.removeEventListener("message", messageCallback);
242
- };
243
-
244
- window.addEventListener("message", messageCallback);
245
- };
246
-
247
- var options = {};
248
- switch (initOptions.onLoad) {
249
- case 'check-sso':
250
- if (loginIframe.enable) {
251
- setupCheckLoginIframe().then(function() {
252
- checkLoginIframe().then(function (unchanged) {
253
- if (!unchanged) {
254
- kc.silentCheckSsoRedirectUri ? checkSsoSilently() : doLogin(false);
255
- } else {
256
- initPromise.setSuccess();
257
- }
258
- }).catch(function (error) {
259
- initPromise.setError(error);
260
- });
261
- });
262
- } else {
263
- kc.silentCheckSsoRedirectUri ? checkSsoSilently() : doLogin(false);
264
- }
265
- break;
266
- case 'login-required':
267
- doLogin(true);
268
- break;
269
- default:
270
- throw 'Invalid value for onLoad';
271
- }
272
- }
273
-
274
- function processInit() {
275
- var callback = parseCallback(window.location.href);
276
-
277
- if (callback) {
278
- window.history.replaceState(window.history.state, null, callback.newUrl);
279
- }
280
-
281
- if (callback && callback.valid) {
282
- return setupCheckLoginIframe().then(function() {
283
- processCallback(callback, initPromise);
284
- }).catch(function (error) {
285
- initPromise.setError(error);
286
- });
287
- }
288
-
289
- if (initOptions.token && initOptions.refreshToken) {
290
- setToken(initOptions.token, initOptions.refreshToken, initOptions.idToken);
291
-
292
- if (loginIframe.enable) {
293
- setupCheckLoginIframe().then(function() {
294
- checkLoginIframe().then(function (unchanged) {
295
- if (unchanged) {
296
- kc.onAuthSuccess && kc.onAuthSuccess();
297
- initPromise.setSuccess();
298
- scheduleCheckIframe();
299
- } else {
300
- initPromise.setSuccess();
301
- }
302
- }).catch(function (error) {
303
- initPromise.setError(error);
304
- });
305
- });
306
- } else {
307
- kc.updateToken(-1).then(function() {
308
- kc.onAuthSuccess && kc.onAuthSuccess();
309
- initPromise.setSuccess();
310
- }).catch(function(error) {
311
- kc.onAuthError && kc.onAuthError();
312
- if (initOptions.onLoad) {
313
- onLoad();
314
- } else {
315
- initPromise.setError(error);
316
- }
317
- });
318
- }
319
- } else if (initOptions.onLoad) {
320
- onLoad();
321
- } else {
322
- initPromise.setSuccess();
323
- }
324
- }
325
-
326
- configPromise.then(function () {
327
- check3pCookiesSupported()
328
- .then(processInit)
329
- .catch(function (error) {
330
- promise.setError(error);
331
- });
332
- });
333
- configPromise.catch(function (error) {
334
- promise.setError(error);
335
- });
336
-
337
- return promise.promise;
338
- };
339
-
340
- kc.login = function (options) {
341
- return adapter.login(options);
342
- };
343
-
344
- function generateRandomData(len) {
345
- if (typeof crypto === "undefined" || typeof crypto.getRandomValues === "undefined") {
346
- throw new Error("Web Crypto API is not available.");
347
- }
348
-
349
- return crypto.getRandomValues(new Uint8Array(len));
350
- }
351
-
352
- function generateCodeVerifier(len) {
353
- return generateRandomString(len, 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789');
354
- }
355
-
356
- function generateRandomString(len, alphabet){
357
- var randomData = generateRandomData(len);
358
- var chars = new Array(len);
359
- for (var i = 0; i < len; i++) {
360
- chars[i] = alphabet.charCodeAt(randomData[i] % alphabet.length);
361
- }
362
- return String.fromCharCode.apply(null, chars);
363
- }
364
-
365
- async function generatePkceChallenge(pkceMethod, codeVerifier) {
366
- if (pkceMethod !== "S256") {
367
- throw new TypeError(`Invalid value for 'pkceMethod', expected 'S256' but got '${pkceMethod}'.`);
368
- }
369
-
370
- // hash codeVerifier, then encode as url-safe base64 without padding
371
- const hashBytes = new Uint8Array(await sha256Digest(codeVerifier));
372
- const encodedHash = bytesToBase64(hashBytes)
373
- .replace(/\+/g, '-')
374
- .replace(/\//g, '_')
375
- .replace(/\=/g, '');
376
-
377
- return encodedHash;
378
- }
379
-
380
- function buildClaimsParameter(requestedAcr){
381
- var claims = {
382
- id_token: {
383
- acr: requestedAcr
384
- }
385
- };
386
- return JSON.stringify(claims);
387
- }
388
-
389
- kc.createLoginUrl = async function(options) {
390
- var state = createUUID();
391
- var nonce = createUUID();
392
-
393
- var redirectUri = adapter.redirectUri(options);
394
-
395
- var callbackState = {
396
- state: state,
397
- nonce: nonce,
398
- redirectUri: encodeURIComponent(redirectUri),
399
- loginOptions: options
400
- };
401
-
402
- if (options && options.prompt) {
403
- callbackState.prompt = options.prompt;
404
- }
405
-
406
- var baseUrl;
407
- if (options && options.action == 'register') {
408
- baseUrl = kc.endpoints.register();
409
- } else {
410
- baseUrl = kc.endpoints.authorize();
411
- }
412
-
413
- var scope = options && options.scope || kc.scope;
414
- if (!scope) {
415
- // if scope is not set, default to "openid"
416
- scope = "openid";
417
- } else if (scope.indexOf("openid") === -1) {
418
- // if openid scope is missing, prefix the given scopes with it
419
- scope = "openid " + scope;
420
- }
421
-
422
- var url = baseUrl
423
- + '?client_id=' + encodeURIComponent(kc.clientId)
424
- + '&redirect_uri=' + encodeURIComponent(redirectUri)
425
- + '&state=' + encodeURIComponent(state)
426
- + '&response_mode=' + encodeURIComponent(kc.responseMode)
427
- + '&response_type=' + encodeURIComponent(kc.responseType)
428
- + '&scope=' + encodeURIComponent(scope);
429
- if (useNonce) {
430
- url = url + '&nonce=' + encodeURIComponent(nonce);
431
- }
432
-
433
- if (options && options.prompt) {
434
- url += '&prompt=' + encodeURIComponent(options.prompt);
435
- }
436
-
437
- if (options && typeof options.maxAge === 'number') {
438
- url += '&max_age=' + encodeURIComponent(options.maxAge);
439
- }
440
-
441
- if (options && options.loginHint) {
442
- url += '&login_hint=' + encodeURIComponent(options.loginHint);
443
- }
444
-
445
- if (options && options.idpHint) {
446
- url += '&kc_idp_hint=' + encodeURIComponent(options.idpHint);
447
- }
448
-
449
- if (options && options.action && options.action != 'register') {
450
- url += '&kc_action=' + encodeURIComponent(options.action);
451
- }
452
-
453
- if (options && options.locale) {
454
- url += '&ui_locales=' + encodeURIComponent(options.locale);
455
- }
456
-
457
- if (options && options.acr) {
458
- var claimsParameter = buildClaimsParameter(options.acr);
459
- url += '&claims=' + encodeURIComponent(claimsParameter);
460
- }
461
-
462
- if ((options && options.acrValues) || kc.acrValues) {
463
- url += '&acr_values=' + encodeURIComponent(options.acrValues || kc.acrValues);
464
- }
465
-
466
- if (kc.pkceMethod) {
467
- try {
468
- const codeVerifier = generateCodeVerifier(96);
469
- const pkceChallenge = await generatePkceChallenge(kc.pkceMethod, codeVerifier);
470
-
471
- callbackState.pkceCodeVerifier = codeVerifier;
472
-
473
- url += '&code_challenge=' + pkceChallenge;
474
- url += '&code_challenge_method=' + kc.pkceMethod;
475
- } catch (error) {
476
- throw new Error("Failed to generate PKCE challenge.", { cause: error });
477
- }
478
- }
479
-
480
- callbackStorage.add(callbackState);
481
-
482
- return url;
483
- };
484
-
485
- kc.logout = function(options) {
486
- return adapter.logout(options);
487
- };
488
-
489
- kc.createLogoutUrl = function(options) {
490
-
491
- const logoutMethod = options?.logoutMethod ?? kc.logoutMethod;
492
- if (logoutMethod === 'POST') {
493
- return kc.endpoints.logout();
494
- }
495
-
496
- var url = kc.endpoints.logout()
497
- + '?client_id=' + encodeURIComponent(kc.clientId)
498
- + '&post_logout_redirect_uri=' + encodeURIComponent(adapter.redirectUri(options, false));
499
-
500
- if (kc.idToken) {
501
- url += '&id_token_hint=' + encodeURIComponent(kc.idToken);
502
- }
503
-
504
- return url;
505
- };
506
-
507
- kc.register = function (options) {
508
- return adapter.register(options);
509
- };
510
-
511
- kc.createRegisterUrl = async function(options) {
512
- if (!options) {
513
- options = {};
514
- }
515
- options.action = 'register';
516
- return await kc.createLoginUrl(options);
517
- };
518
-
519
- kc.createAccountUrl = function(options) {
520
- var realm = getRealmUrl();
521
- var url = undefined;
522
- if (typeof realm !== 'undefined') {
523
- url = realm
524
- + '/account'
525
- + '?referrer=' + encodeURIComponent(kc.clientId)
526
- + '&referrer_uri=' + encodeURIComponent(adapter.redirectUri(options));
527
- }
528
- return url;
529
- };
530
-
531
- kc.accountManagement = function() {
532
- return adapter.accountManagement();
533
- };
534
-
535
- kc.hasRealmRole = function (role) {
536
- var access = kc.realmAccess;
537
- return !!access && access.roles.indexOf(role) >= 0;
538
- };
539
-
540
- kc.hasResourceRole = function(role, resource) {
541
- if (!kc.resourceAccess) {
542
- return false;
543
- }
544
-
545
- var access = kc.resourceAccess[resource || kc.clientId];
546
- return !!access && access.roles.indexOf(role) >= 0;
547
- };
548
-
549
- kc.loadUserProfile = function() {
550
- var url = getRealmUrl() + '/account';
551
- var req = new XMLHttpRequest();
552
- req.open('GET', url, true);
553
- req.setRequestHeader('Accept', 'application/json');
554
- req.setRequestHeader('Authorization', 'bearer ' + kc.token);
555
-
556
- var promise = createPromise();
557
-
558
- req.onreadystatechange = function () {
559
- if (req.readyState == 4) {
560
- if (req.status == 200) {
561
- kc.profile = JSON.parse(req.responseText);
562
- promise.setSuccess(kc.profile);
563
- } else {
564
- promise.setError();
565
- }
566
- }
567
- };
568
-
569
- req.send();
570
-
571
- return promise.promise;
572
- };
573
-
574
- kc.loadUserInfo = function() {
575
- var url = kc.endpoints.userinfo();
576
- var req = new XMLHttpRequest();
577
- req.open('GET', url, true);
578
- req.setRequestHeader('Accept', 'application/json');
579
- req.setRequestHeader('Authorization', 'bearer ' + kc.token);
580
-
581
- var promise = createPromise();
582
-
583
- req.onreadystatechange = function () {
584
- if (req.readyState == 4) {
585
- if (req.status == 200) {
586
- kc.userInfo = JSON.parse(req.responseText);
587
- promise.setSuccess(kc.userInfo);
588
- } else {
589
- promise.setError();
590
- }
591
- }
592
- };
593
-
594
- req.send();
595
-
596
- return promise.promise;
597
- };
598
-
599
- kc.isTokenExpired = function(minValidity) {
600
- if (!kc.tokenParsed || (!kc.refreshToken && kc.flow != 'implicit' )) {
601
- throw 'Not authenticated';
602
- }
603
-
604
- if (kc.timeSkew == null) {
605
- logInfo('[KEYCLOAK] Unable to determine if token is expired as timeskew is not set');
606
- return true;
607
- }
608
-
609
- var expiresIn = kc.tokenParsed['exp'] - Math.ceil(new Date().getTime() / 1000) + kc.timeSkew;
610
- if (minValidity) {
611
- if (isNaN(minValidity)) {
612
- throw 'Invalid minValidity';
613
- }
614
- expiresIn -= minValidity;
615
- }
616
- return expiresIn < 0;
617
- };
618
-
619
- kc.updateToken = function(minValidity) {
620
- var promise = createPromise();
621
-
622
- if (!kc.refreshToken) {
623
- promise.setError();
624
- return promise.promise;
625
- }
626
-
627
- minValidity = minValidity || 5;
628
-
629
- var exec = function() {
630
- var refreshToken = false;
631
- if (minValidity == -1) {
632
- refreshToken = true;
633
- logInfo('[KEYCLOAK] Refreshing token: forced refresh');
634
- } else if (!kc.tokenParsed || kc.isTokenExpired(minValidity)) {
635
- refreshToken = true;
636
- logInfo('[KEYCLOAK] Refreshing token: token expired');
637
- }
638
-
639
- if (!refreshToken) {
640
- promise.setSuccess(false);
641
- } else {
642
- var params = 'grant_type=refresh_token&' + 'refresh_token=' + kc.refreshToken;
643
- var url = kc.endpoints.token();
644
-
645
- refreshQueue.push(promise);
646
-
647
- if (refreshQueue.length == 1) {
648
- var req = new XMLHttpRequest();
649
- req.open('POST', url, true);
650
- req.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
651
- req.withCredentials = true;
652
-
653
- params += '&client_id=' + encodeURIComponent(kc.clientId);
654
-
655
- var timeLocal = new Date().getTime();
656
-
657
- req.onreadystatechange = function () {
658
- if (req.readyState == 4) {
659
- if (req.status == 200) {
660
- logInfo('[KEYCLOAK] Token refreshed');
661
-
662
- timeLocal = (timeLocal + new Date().getTime()) / 2;
663
-
664
- var tokenResponse = JSON.parse(req.responseText);
665
-
666
- setToken(tokenResponse['access_token'], tokenResponse['refresh_token'], tokenResponse['id_token'], timeLocal);
667
-
668
- kc.onAuthRefreshSuccess && kc.onAuthRefreshSuccess();
669
- for (var p = refreshQueue.pop(); p != null; p = refreshQueue.pop()) {
670
- p.setSuccess(true);
671
- }
672
- } else {
673
- logWarn('[KEYCLOAK] Failed to refresh token');
674
-
675
- if (req.status == 400) {
676
- kc.clearToken();
677
- }
678
-
679
- kc.onAuthRefreshError && kc.onAuthRefreshError();
680
- for (var p = refreshQueue.pop(); p != null; p = refreshQueue.pop()) {
681
- p.setError("Failed to refresh token: An unexpected HTTP error occurred while attempting to refresh the token.");
682
- }
683
- }
684
- }
685
- };
686
-
687
- req.send(params);
688
- }
689
- }
690
- };
691
-
692
- if (loginIframe.enable) {
693
- var iframePromise = checkLoginIframe();
694
- iframePromise.then(function() {
695
- exec();
696
- }).catch(function(error) {
697
- promise.setError(error);
698
- });
699
- } else {
700
- exec();
701
- }
702
-
703
- return promise.promise;
704
- };
705
-
706
- kc.clearToken = function() {
707
- if (kc.token) {
708
- setToken(null, null, null);
709
- kc.onAuthLogout && kc.onAuthLogout();
710
- if (kc.loginRequired) {
711
- kc.login();
712
- }
713
- }
714
- };
715
-
716
- function getRealmUrl() {
717
- if (typeof kc.authServerUrl !== 'undefined') {
718
- if (kc.authServerUrl.charAt(kc.authServerUrl.length - 1) == '/') {
719
- return kc.authServerUrl + 'realms/' + encodeURIComponent(kc.realm);
720
- } else {
721
- return kc.authServerUrl + '/realms/' + encodeURIComponent(kc.realm);
722
- }
723
- } else {
724
- return undefined;
725
- }
726
- }
727
-
728
- function getOrigin() {
729
- if (!window.location.origin) {
730
- return window.location.protocol + "//" + window.location.hostname + (window.location.port ? ':' + window.location.port: '');
731
- } else {
732
- return window.location.origin;
733
- }
734
- }
735
-
736
- function processCallback(oauth, promise) {
737
- var code = oauth.code;
738
- var error = oauth.error;
739
- var prompt = oauth.prompt;
740
-
741
- var timeLocal = new Date().getTime();
742
-
743
- if (oauth['kc_action_status']) {
744
- kc.onActionUpdate && kc.onActionUpdate(oauth['kc_action_status'], oauth['kc_action']);
745
- }
746
-
747
- if (error) {
748
- if (prompt != 'none') {
749
- if (oauth.error_description && oauth.error_description === "authentication_expired") {
750
- kc.login(oauth.loginOptions);
751
- } else {
752
- var errorData = { error: error, error_description: oauth.error_description };
753
- kc.onAuthError && kc.onAuthError(errorData);
754
- promise && promise.setError(errorData);
755
- }
756
- } else {
757
- promise && promise.setSuccess();
758
- }
759
- return;
760
- } else if ((kc.flow != 'standard') && (oauth.access_token || oauth.id_token)) {
761
- authSuccess(oauth.access_token, null, oauth.id_token, true);
762
- }
763
-
764
- if ((kc.flow != 'implicit') && code) {
765
- var params = 'code=' + code + '&grant_type=authorization_code';
766
- var url = kc.endpoints.token();
767
-
768
- var req = new XMLHttpRequest();
769
- req.open('POST', url, true);
770
- req.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
771
-
772
- params += '&client_id=' + encodeURIComponent(kc.clientId);
773
- params += '&redirect_uri=' + oauth.redirectUri;
774
-
775
- if (oauth.pkceCodeVerifier) {
776
- params += '&code_verifier=' + oauth.pkceCodeVerifier;
777
- }
778
-
779
- req.withCredentials = true;
780
-
781
- req.onreadystatechange = function() {
782
- if (req.readyState == 4) {
783
- if (req.status == 200) {
784
-
785
- var tokenResponse = JSON.parse(req.responseText);
786
- authSuccess(tokenResponse['access_token'], tokenResponse['refresh_token'], tokenResponse['id_token'], kc.flow === 'standard');
787
- scheduleCheckIframe();
788
- } else {
789
- kc.onAuthError && kc.onAuthError();
790
- promise && promise.setError();
791
- }
792
- }
793
- };
794
-
795
- req.send(params);
796
- }
797
-
798
- function authSuccess(accessToken, refreshToken, idToken, fulfillPromise) {
799
- timeLocal = (timeLocal + new Date().getTime()) / 2;
800
-
801
- setToken(accessToken, refreshToken, idToken, timeLocal);
802
-
803
- if (useNonce && (kc.idTokenParsed && kc.idTokenParsed.nonce != oauth.storedNonce)) {
804
- logInfo('[KEYCLOAK] Invalid nonce, clearing token');
805
- kc.clearToken();
806
- promise && promise.setError();
807
- } else {
808
- if (fulfillPromise) {
809
- kc.onAuthSuccess && kc.onAuthSuccess();
810
- promise && promise.setSuccess();
811
- }
812
- }
813
- }
814
-
815
- }
816
-
817
- function loadConfig() {
818
- var promise = createPromise();
819
- var configUrl;
820
-
821
- if (typeof config === 'string') {
822
- configUrl = config;
823
- }
824
-
825
- function setupOidcEndoints(oidcConfiguration) {
826
- if (! oidcConfiguration) {
827
- kc.endpoints = {
828
- authorize: function() {
829
- return getRealmUrl() + '/protocol/openid-connect/auth';
830
- },
831
- token: function() {
832
- return getRealmUrl() + '/protocol/openid-connect/token';
833
- },
834
- logout: function() {
835
- return getRealmUrl() + '/protocol/openid-connect/logout';
836
- },
837
- checkSessionIframe: function() {
838
- return getRealmUrl() + '/protocol/openid-connect/login-status-iframe.html';
839
- },
840
- thirdPartyCookiesIframe: function() {
841
- return getRealmUrl() + '/protocol/openid-connect/3p-cookies/step1.html';
842
- },
843
- register: function() {
844
- return getRealmUrl() + '/protocol/openid-connect/registrations';
845
- },
846
- userinfo: function() {
847
- return getRealmUrl() + '/protocol/openid-connect/userinfo';
848
- }
849
- };
850
- } else {
851
- kc.endpoints = {
852
- authorize: function() {
853
- return oidcConfiguration.authorization_endpoint;
854
- },
855
- token: function() {
856
- return oidcConfiguration.token_endpoint;
857
- },
858
- logout: function() {
859
- if (!oidcConfiguration.end_session_endpoint) {
860
- throw "Not supported by the OIDC server";
861
- }
862
- return oidcConfiguration.end_session_endpoint;
863
- },
864
- checkSessionIframe: function() {
865
- if (!oidcConfiguration.check_session_iframe) {
866
- throw "Not supported by the OIDC server";
867
- }
868
- return oidcConfiguration.check_session_iframe;
869
- },
870
- register: function() {
871
- throw 'Redirection to "Register user" page not supported in standard OIDC mode';
872
- },
873
- userinfo: function() {
874
- if (!oidcConfiguration.userinfo_endpoint) {
875
- throw "Not supported by the OIDC server";
876
- }
877
- return oidcConfiguration.userinfo_endpoint;
878
- }
879
- };
880
- }
881
- }
882
-
883
- if (configUrl) {
884
- var req = new XMLHttpRequest();
885
- req.open('GET', configUrl, true);
886
- req.setRequestHeader('Accept', 'application/json');
887
-
888
- req.onreadystatechange = function () {
889
- if (req.readyState == 4) {
890
- if (req.status == 200 || fileLoaded(req)) {
891
- var config = JSON.parse(req.responseText);
892
-
893
- kc.authServerUrl = config['auth-server-url'];
894
- kc.realm = config['realm'];
895
- kc.clientId = config['resource'];
896
- setupOidcEndoints(null);
897
- promise.setSuccess();
898
- } else {
899
- promise.setError();
900
- }
901
- }
902
- };
903
-
904
- req.send();
905
- } else {
906
- kc.clientId = config.clientId;
907
-
908
- var oidcProvider = config['oidcProvider'];
909
- if (!oidcProvider) {
910
- kc.authServerUrl = config.url;
911
- kc.realm = config.realm;
912
- setupOidcEndoints(null);
913
- promise.setSuccess();
914
- } else {
915
- if (typeof oidcProvider === 'string') {
916
- var oidcProviderConfigUrl;
917
- if (oidcProvider.charAt(oidcProvider.length - 1) == '/') {
918
- oidcProviderConfigUrl = oidcProvider + '.well-known/openid-configuration';
919
- } else {
920
- oidcProviderConfigUrl = oidcProvider + '/.well-known/openid-configuration';
921
- }
922
- var req = new XMLHttpRequest();
923
- req.open('GET', oidcProviderConfigUrl, true);
924
- req.setRequestHeader('Accept', 'application/json');
925
-
926
- req.onreadystatechange = function () {
927
- if (req.readyState == 4) {
928
- if (req.status == 200 || fileLoaded(req)) {
929
- var oidcProviderConfig = JSON.parse(req.responseText);
930
- setupOidcEndoints(oidcProviderConfig);
931
- promise.setSuccess();
932
- } else {
933
- promise.setError();
934
- }
935
- }
936
- };
937
-
938
- req.send();
939
- } else {
940
- setupOidcEndoints(oidcProvider);
941
- promise.setSuccess();
942
- }
943
- }
944
- }
945
-
946
- return promise.promise;
947
- }
948
-
949
- function fileLoaded(xhr) {
950
- return xhr.status == 0 && xhr.responseText && xhr.responseURL.startsWith('file:');
951
- }
952
-
953
- function setToken(token, refreshToken, idToken, timeLocal) {
954
- if (kc.tokenTimeoutHandle) {
955
- clearTimeout(kc.tokenTimeoutHandle);
956
- kc.tokenTimeoutHandle = null;
957
- }
958
-
959
- if (refreshToken) {
960
- kc.refreshToken = refreshToken;
961
- kc.refreshTokenParsed = decodeToken(refreshToken);
962
- } else {
963
- delete kc.refreshToken;
964
- delete kc.refreshTokenParsed;
965
- }
966
-
967
- if (idToken) {
968
- kc.idToken = idToken;
969
- kc.idTokenParsed = decodeToken(idToken);
970
- } else {
971
- delete kc.idToken;
972
- delete kc.idTokenParsed;
973
- }
974
-
975
- if (token) {
976
- kc.token = token;
977
- kc.tokenParsed = decodeToken(token);
978
- kc.sessionId = kc.tokenParsed.sid;
979
- kc.authenticated = true;
980
- kc.subject = kc.tokenParsed.sub;
981
- kc.realmAccess = kc.tokenParsed.realm_access;
982
- kc.resourceAccess = kc.tokenParsed.resource_access;
983
-
984
- if (timeLocal) {
985
- kc.timeSkew = Math.floor(timeLocal / 1000) - kc.tokenParsed.iat;
986
- }
987
-
988
- if (kc.timeSkew != null) {
989
- logInfo('[KEYCLOAK] Estimated time difference between browser and server is ' + kc.timeSkew + ' seconds');
990
-
991
- if (kc.onTokenExpired) {
992
- var expiresIn = (kc.tokenParsed['exp'] - (new Date().getTime() / 1000) + kc.timeSkew) * 1000;
993
- logInfo('[KEYCLOAK] Token expires in ' + Math.round(expiresIn / 1000) + ' s');
994
- if (expiresIn <= 0) {
995
- kc.onTokenExpired();
996
- } else {
997
- kc.tokenTimeoutHandle = setTimeout(kc.onTokenExpired, expiresIn);
998
- }
999
- }
1000
- }
1001
- } else {
1002
- delete kc.token;
1003
- delete kc.tokenParsed;
1004
- delete kc.subject;
1005
- delete kc.realmAccess;
1006
- delete kc.resourceAccess;
1007
-
1008
- kc.authenticated = false;
1009
- }
1010
- }
1011
-
1012
- function createUUID() {
1013
- if (typeof crypto === "undefined" || typeof crypto.randomUUID === "undefined") {
1014
- throw new Error("Web Crypto API is not available.");
1015
- }
1016
-
1017
- return crypto.randomUUID();
1018
- }
1019
-
1020
- function parseCallback(url) {
1021
- var oauth = parseCallbackUrl(url);
1022
- if (!oauth) {
1023
- return;
1024
- }
1025
-
1026
- var oauthState = callbackStorage.get(oauth.state);
1027
-
1028
- if (oauthState) {
1029
- oauth.valid = true;
1030
- oauth.redirectUri = oauthState.redirectUri;
1031
- oauth.storedNonce = oauthState.nonce;
1032
- oauth.prompt = oauthState.prompt;
1033
- oauth.pkceCodeVerifier = oauthState.pkceCodeVerifier;
1034
- oauth.loginOptions = oauthState.loginOptions;
1035
- }
1036
-
1037
- return oauth;
1038
- }
1039
-
1040
- function parseCallbackUrl(url) {
1041
- var supportedParams;
1042
- switch (kc.flow) {
1043
- case 'standard':
1044
- supportedParams = ['code', 'state', 'session_state', 'kc_action_status', 'kc_action', 'iss'];
1045
- break;
1046
- case 'implicit':
1047
- supportedParams = ['access_token', 'token_type', 'id_token', 'state', 'session_state', 'expires_in', 'kc_action_status', 'kc_action', 'iss'];
1048
- break;
1049
- case 'hybrid':
1050
- supportedParams = ['access_token', 'token_type', 'id_token', 'code', 'state', 'session_state', 'expires_in', 'kc_action_status', 'kc_action', 'iss'];
1051
- break;
1052
- }
1053
-
1054
- supportedParams.push('error');
1055
- supportedParams.push('error_description');
1056
- supportedParams.push('error_uri');
1057
-
1058
- var queryIndex = url.indexOf('?');
1059
- var fragmentIndex = url.indexOf('#');
1060
-
1061
- var newUrl;
1062
- var parsed;
1063
-
1064
- if (kc.responseMode === 'query' && queryIndex !== -1) {
1065
- newUrl = url.substring(0, queryIndex);
1066
- parsed = parseCallbackParams(url.substring(queryIndex + 1, fragmentIndex !== -1 ? fragmentIndex : url.length), supportedParams);
1067
- if (parsed.paramsString !== '') {
1068
- newUrl += '?' + parsed.paramsString;
1069
- }
1070
- if (fragmentIndex !== -1) {
1071
- newUrl += url.substring(fragmentIndex);
1072
- }
1073
- } else if (kc.responseMode === 'fragment' && fragmentIndex !== -1) {
1074
- newUrl = url.substring(0, fragmentIndex);
1075
- parsed = parseCallbackParams(url.substring(fragmentIndex + 1), supportedParams);
1076
- if (parsed.paramsString !== '') {
1077
- newUrl += '#' + parsed.paramsString;
1078
- }
1079
- }
1080
-
1081
- if (parsed && parsed.oauthParams) {
1082
- if (kc.flow === 'standard' || kc.flow === 'hybrid') {
1083
- if ((parsed.oauthParams.code || parsed.oauthParams.error) && parsed.oauthParams.state) {
1084
- parsed.oauthParams.newUrl = newUrl;
1085
- return parsed.oauthParams;
1086
- }
1087
- } else if (kc.flow === 'implicit') {
1088
- if ((parsed.oauthParams.access_token || parsed.oauthParams.error) && parsed.oauthParams.state) {
1089
- parsed.oauthParams.newUrl = newUrl;
1090
- return parsed.oauthParams;
1091
- }
1092
- }
1093
- }
1094
- }
1095
-
1096
- function parseCallbackParams(paramsString, supportedParams) {
1097
- var p = paramsString.split('&');
1098
- var result = {
1099
- paramsString: '',
1100
- oauthParams: {}
1101
- };
1102
- for (var i = 0; i < p.length; i++) {
1103
- var split = p[i].indexOf("=");
1104
- var key = p[i].slice(0, split);
1105
- if (supportedParams.indexOf(key) !== -1) {
1106
- result.oauthParams[key] = p[i].slice(split + 1);
1107
- } else {
1108
- if (result.paramsString !== '') {
1109
- result.paramsString += '&';
1110
- }
1111
- result.paramsString += p[i];
1112
- }
1113
- }
1114
- return result;
1115
- }
1116
-
1117
- function createPromise() {
1118
- // Need to create a native Promise which also preserves the
1119
- // interface of the custom promise type previously used by the API
1120
- var p = {
1121
- setSuccess: function(result) {
1122
- p.resolve(result);
1123
- },
1124
-
1125
- setError: function(result) {
1126
- p.reject(result);
1127
- }
1128
- };
1129
- p.promise = new Promise(function(resolve, reject) {
1130
- p.resolve = resolve;
1131
- p.reject = reject;
1132
- });
1133
-
1134
- return p;
1135
- }
1136
-
1137
- // Function to extend existing native Promise with timeout
1138
- function applyTimeoutToPromise(promise, timeout, errorMessage) {
1139
- var timeoutHandle = null;
1140
- var timeoutPromise = new Promise(function (resolve, reject) {
1141
- timeoutHandle = setTimeout(function () {
1142
- reject({ "error": errorMessage || "Promise is not settled within timeout of " + timeout + "ms" });
1143
- }, timeout);
1144
- });
1145
-
1146
- return Promise.race([promise, timeoutPromise]).finally(function () {
1147
- clearTimeout(timeoutHandle);
1148
- });
1149
- }
1150
-
1151
- function setupCheckLoginIframe() {
1152
- var promise = createPromise();
1153
-
1154
- if (!loginIframe.enable) {
1155
- promise.setSuccess();
1156
- return promise.promise;
1157
- }
1158
-
1159
- if (loginIframe.iframe) {
1160
- promise.setSuccess();
1161
- return promise.promise;
1162
- }
1163
-
1164
- var iframe = document.createElement('iframe');
1165
- loginIframe.iframe = iframe;
1166
-
1167
- iframe.onload = function() {
1168
- var authUrl = kc.endpoints.authorize();
1169
- if (authUrl.charAt(0) === '/') {
1170
- loginIframe.iframeOrigin = getOrigin();
1171
- } else {
1172
- loginIframe.iframeOrigin = authUrl.substring(0, authUrl.indexOf('/', 8));
1173
- }
1174
- promise.setSuccess();
1175
- };
1176
-
1177
- var src = kc.endpoints.checkSessionIframe();
1178
- iframe.setAttribute('src', src );
1179
- iframe.setAttribute('sandbox', 'allow-storage-access-by-user-activation allow-scripts allow-same-origin');
1180
- iframe.setAttribute('title', 'keycloak-session-iframe' );
1181
- iframe.style.display = 'none';
1182
- document.body.appendChild(iframe);
1183
-
1184
- var messageCallback = function(event) {
1185
- if ((event.origin !== loginIframe.iframeOrigin) || (loginIframe.iframe.contentWindow !== event.source)) {
1186
- return;
1187
- }
1188
-
1189
- if (!(event.data == 'unchanged' || event.data == 'changed' || event.data == 'error')) {
1190
- return;
1191
- }
1192
-
1193
-
1194
- if (event.data != 'unchanged') {
1195
- kc.clearToken();
1196
- }
1197
-
1198
- var callbacks = loginIframe.callbackList.splice(0, loginIframe.callbackList.length);
1199
-
1200
- for (var i = callbacks.length - 1; i >= 0; --i) {
1201
- var promise = callbacks[i];
1202
- if (event.data == 'error') {
1203
- promise.setError();
1204
- } else {
1205
- promise.setSuccess(event.data == 'unchanged');
1206
- }
1207
- }
1208
- };
1209
-
1210
- window.addEventListener('message', messageCallback, false);
1211
-
1212
- return promise.promise;
1213
- }
1214
-
1215
- function scheduleCheckIframe() {
1216
- if (loginIframe.enable) {
1217
- if (kc.token) {
1218
- setTimeout(function() {
1219
- checkLoginIframe().then(function(unchanged) {
1220
- if (unchanged) {
1221
- scheduleCheckIframe();
1222
- }
1223
- });
1224
- }, loginIframe.interval * 1000);
1225
- }
1226
- }
1227
- }
1228
-
1229
- function checkLoginIframe() {
1230
- var promise = createPromise();
1231
-
1232
- if (loginIframe.iframe && loginIframe.iframeOrigin ) {
1233
- var msg = kc.clientId + ' ' + (kc.sessionId ? kc.sessionId : '');
1234
- loginIframe.callbackList.push(promise);
1235
- var origin = loginIframe.iframeOrigin;
1236
- if (loginIframe.callbackList.length == 1) {
1237
- loginIframe.iframe.contentWindow.postMessage(msg, origin);
1238
- }
1239
- } else {
1240
- promise.setSuccess();
1241
- }
1242
-
1243
- return promise.promise;
1244
- }
1245
-
1246
- function check3pCookiesSupported() {
1247
- var promise = createPromise();
1248
-
1249
- if ((loginIframe.enable || kc.silentCheckSsoRedirectUri) && typeof kc.endpoints.thirdPartyCookiesIframe === 'function') {
1250
- var iframe = document.createElement('iframe');
1251
- iframe.setAttribute('src', kc.endpoints.thirdPartyCookiesIframe());
1252
- iframe.setAttribute('sandbox', 'allow-storage-access-by-user-activation allow-scripts allow-same-origin');
1253
- iframe.setAttribute('title', 'keycloak-3p-check-iframe' );
1254
- iframe.style.display = 'none';
1255
- document.body.appendChild(iframe);
1256
-
1257
- var messageCallback = function(event) {
1258
- if (iframe.contentWindow !== event.source) {
1259
- return;
1260
- }
1261
-
1262
- if (event.data !== "supported" && event.data !== "unsupported") {
1263
- return;
1264
- } else if (event.data === "unsupported") {
1265
- logWarn(
1266
- "[KEYCLOAK] Your browser is blocking access to 3rd-party cookies, this means:\n\n" +
1267
- " - It is not possible to retrieve tokens without redirecting to the Keycloak server (a.k.a. no support for silent authentication).\n" +
1268
- " - It is not possible to automatically detect changes to the session status (such as the user logging out in another tab).\n\n" +
1269
- "For more information see: https://www.keycloak.org/securing-apps/javascript-adapter#_modern_browsers"
1270
- );
1271
-
1272
- loginIframe.enable = false;
1273
- if (kc.silentCheckSsoFallback) {
1274
- kc.silentCheckSsoRedirectUri = false;
1275
- }
1276
- }
1277
-
1278
- document.body.removeChild(iframe);
1279
- window.removeEventListener("message", messageCallback);
1280
- promise.setSuccess();
1281
- };
1282
-
1283
- window.addEventListener('message', messageCallback, false);
1284
- } else {
1285
- promise.setSuccess();
1286
- }
1287
-
1288
- return applyTimeoutToPromise(promise.promise, kc.messageReceiveTimeout, "Timeout when waiting for 3rd party check iframe message.");
1289
- }
1290
-
1291
- function loadAdapter(type) {
1292
- if (!type || type == 'default') {
1293
- return {
1294
- login: async function(options) {
1295
- window.location.assign(await kc.createLoginUrl(options));
1296
- return createPromise().promise;
1297
- },
1298
-
1299
- logout: async function(options) {
1300
-
1301
- const logoutMethod = options?.logoutMethod ?? kc.logoutMethod;
1302
- if (logoutMethod === "GET") {
1303
- window.location.replace(kc.createLogoutUrl(options));
1304
- return;
1305
- }
1306
-
1307
- // Create form to send POST request.
1308
- const form = document.createElement("form");
1309
-
1310
- form.setAttribute("method", "POST");
1311
- form.setAttribute("action", kc.createLogoutUrl(options));
1312
- form.style.display = "none";
1313
-
1314
- // Add data to form as hidden input fields.
1315
- const data = {
1316
- id_token_hint: kc.idToken,
1317
- client_id: kc.clientId,
1318
- post_logout_redirect_uri: adapter.redirectUri(options, false)
1319
- };
1320
-
1321
- for (const [name, value] of Object.entries(data)) {
1322
- const input = document.createElement("input");
1323
-
1324
- input.setAttribute("type", "hidden");
1325
- input.setAttribute("name", name);
1326
- input.setAttribute("value", value);
1327
-
1328
- form.appendChild(input);
1329
- }
1330
-
1331
- // Append form to page and submit it to perform logout and redirect.
1332
- document.body.appendChild(form);
1333
- form.submit();
1334
- },
1335
-
1336
- register: async function(options) {
1337
- window.location.assign(await kc.createRegisterUrl(options));
1338
- return createPromise().promise;
1339
- },
1340
-
1341
- accountManagement : function() {
1342
- var accountUrl = kc.createAccountUrl();
1343
- if (typeof accountUrl !== 'undefined') {
1344
- window.location.href = accountUrl;
1345
- } else {
1346
- throw "Not supported by the OIDC server";
1347
- }
1348
- return createPromise().promise;
1349
- },
1350
-
1351
- redirectUri: function(options, encodeHash) {
1352
-
1353
- if (options && options.redirectUri) {
1354
- return options.redirectUri;
1355
- } else if (kc.redirectUri) {
1356
- return kc.redirectUri;
1357
- } else {
1358
- return location.href;
1359
- }
1360
- }
1361
- };
1362
- }
1363
-
1364
- if (type == 'cordova') {
1365
- loginIframe.enable = false;
1366
- var cordovaOpenWindowWrapper = function(loginUrl, target, options) {
1367
- if (window.cordova && window.cordova.InAppBrowser) {
1368
- // Use inappbrowser for IOS and Android if available
1369
- return window.cordova.InAppBrowser.open(loginUrl, target, options);
1370
- } else {
1371
- return window.open(loginUrl, target, options);
1372
- }
1373
- };
1374
-
1375
- var shallowCloneCordovaOptions = function (userOptions) {
1376
- if (userOptions && userOptions.cordovaOptions) {
1377
- return Object.keys(userOptions.cordovaOptions).reduce(function (options, optionName) {
1378
- options[optionName] = userOptions.cordovaOptions[optionName];
1379
- return options;
1380
- }, {});
1381
- } else {
1382
- return {};
1383
- }
1384
- };
1385
-
1386
- var formatCordovaOptions = function (cordovaOptions) {
1387
- return Object.keys(cordovaOptions).reduce(function (options, optionName) {
1388
- options.push(optionName+"="+cordovaOptions[optionName]);
1389
- return options;
1390
- }, []).join(",");
1391
- };
1392
-
1393
- var createCordovaOptions = function (userOptions) {
1394
- var cordovaOptions = shallowCloneCordovaOptions(userOptions);
1395
- cordovaOptions.location = 'no';
1396
- if (userOptions && userOptions.prompt == 'none') {
1397
- cordovaOptions.hidden = 'yes';
1398
- }
1399
- return formatCordovaOptions(cordovaOptions);
1400
- };
1401
-
1402
- var getCordovaRedirectUri = function() {
1403
- return kc.redirectUri || 'http://localhost';
1404
- };
1405
-
1406
- return {
1407
- login: async function(options) {
1408
- var promise = createPromise();
1409
-
1410
- var cordovaOptions = createCordovaOptions(options);
1411
- var loginUrl = await kc.createLoginUrl(options);
1412
- var ref = cordovaOpenWindowWrapper(loginUrl, '_blank', cordovaOptions);
1413
- var completed = false;
1414
-
1415
- var closed = false;
1416
- var closeBrowser = function() {
1417
- closed = true;
1418
- ref.close();
1419
- };
1420
-
1421
- ref.addEventListener('loadstart', function(event) {
1422
- if (event.url.indexOf(getCordovaRedirectUri()) == 0) {
1423
- var callback = parseCallback(event.url);
1424
- processCallback(callback, promise);
1425
- closeBrowser();
1426
- completed = true;
1427
- }
1428
- });
1429
-
1430
- ref.addEventListener('loaderror', function(event) {
1431
- if (!completed) {
1432
- if (event.url.indexOf(getCordovaRedirectUri()) == 0) {
1433
- var callback = parseCallback(event.url);
1434
- processCallback(callback, promise);
1435
- closeBrowser();
1436
- completed = true;
1437
- } else {
1438
- promise.setError();
1439
- closeBrowser();
1440
- }
1441
- }
1442
- });
1443
-
1444
- ref.addEventListener('exit', function(event) {
1445
- if (!closed) {
1446
- promise.setError({
1447
- reason: "closed_by_user"
1448
- });
1449
- }
1450
- });
1451
-
1452
- return promise.promise;
1453
- },
1454
-
1455
- logout: function(options) {
1456
- var promise = createPromise();
1457
-
1458
- var logoutUrl = kc.createLogoutUrl(options);
1459
- var ref = cordovaOpenWindowWrapper(logoutUrl, '_blank', 'location=no,hidden=yes,clearcache=yes');
1460
-
1461
- var error;
1462
-
1463
- ref.addEventListener('loadstart', function(event) {
1464
- if (event.url.indexOf(getCordovaRedirectUri()) == 0) {
1465
- ref.close();
1466
- }
1467
- });
1468
-
1469
- ref.addEventListener('loaderror', function(event) {
1470
- if (event.url.indexOf(getCordovaRedirectUri()) == 0) {
1471
- ref.close();
1472
- } else {
1473
- error = true;
1474
- ref.close();
1475
- }
1476
- });
1477
-
1478
- ref.addEventListener('exit', function(event) {
1479
- if (error) {
1480
- promise.setError();
1481
- } else {
1482
- kc.clearToken();
1483
- promise.setSuccess();
1484
- }
1485
- });
1486
-
1487
- return promise.promise;
1488
- },
1489
-
1490
- register : async function(options) {
1491
- var promise = createPromise();
1492
- var registerUrl = await kc.createRegisterUrl();
1493
- var cordovaOptions = createCordovaOptions(options);
1494
- var ref = cordovaOpenWindowWrapper(registerUrl, '_blank', cordovaOptions);
1495
- ref.addEventListener('loadstart', function(event) {
1496
- if (event.url.indexOf(getCordovaRedirectUri()) == 0) {
1497
- ref.close();
1498
- var oauth = parseCallback(event.url);
1499
- processCallback(oauth, promise);
1500
- }
1501
- });
1502
- return promise.promise;
1503
- },
1504
-
1505
- accountManagement : function() {
1506
- var accountUrl = kc.createAccountUrl();
1507
- if (typeof accountUrl !== 'undefined') {
1508
- var ref = cordovaOpenWindowWrapper(accountUrl, '_blank', 'location=no');
1509
- ref.addEventListener('loadstart', function(event) {
1510
- if (event.url.indexOf(getCordovaRedirectUri()) == 0) {
1511
- ref.close();
1512
- }
1513
- });
1514
- } else {
1515
- throw "Not supported by the OIDC server";
1516
- }
1517
- },
1518
-
1519
- redirectUri: function(options) {
1520
- return getCordovaRedirectUri();
1521
- }
1522
- }
1523
- }
1524
-
1525
- if (type == 'cordova-native') {
1526
- loginIframe.enable = false;
1527
-
1528
- return {
1529
- login: async function(options) {
1530
- var promise = createPromise();
1531
- var loginUrl = await kc.createLoginUrl(options);
1532
-
1533
- universalLinks.subscribe('keycloak', function(event) {
1534
- universalLinks.unsubscribe('keycloak');
1535
- window.cordova.plugins.browsertab.close();
1536
- var oauth = parseCallback(event.url);
1537
- processCallback(oauth, promise);
1538
- });
1539
-
1540
- window.cordova.plugins.browsertab.openUrl(loginUrl);
1541
- return promise.promise;
1542
- },
1543
-
1544
- logout: function(options) {
1545
- var promise = createPromise();
1546
- var logoutUrl = kc.createLogoutUrl(options);
1547
-
1548
- universalLinks.subscribe('keycloak', function(event) {
1549
- universalLinks.unsubscribe('keycloak');
1550
- window.cordova.plugins.browsertab.close();
1551
- kc.clearToken();
1552
- promise.setSuccess();
1553
- });
1554
-
1555
- window.cordova.plugins.browsertab.openUrl(logoutUrl);
1556
- return promise.promise;
1557
- },
1558
-
1559
- register : async function(options) {
1560
- var promise = createPromise();
1561
- var registerUrl = await kc.createRegisterUrl(options);
1562
- universalLinks.subscribe('keycloak' , function(event) {
1563
- universalLinks.unsubscribe('keycloak');
1564
- window.cordova.plugins.browsertab.close();
1565
- var oauth = parseCallback(event.url);
1566
- processCallback(oauth, promise);
1567
- });
1568
- window.cordova.plugins.browsertab.openUrl(registerUrl);
1569
- return promise.promise;
1570
-
1571
- },
1572
-
1573
- accountManagement : function() {
1574
- var accountUrl = kc.createAccountUrl();
1575
- if (typeof accountUrl !== 'undefined') {
1576
- window.cordova.plugins.browsertab.openUrl(accountUrl);
1577
- } else {
1578
- throw "Not supported by the OIDC server";
1579
- }
1580
- },
1581
-
1582
- redirectUri: function(options) {
1583
- if (options && options.redirectUri) {
1584
- return options.redirectUri;
1585
- } else if (kc.redirectUri) {
1586
- return kc.redirectUri;
1587
- } else {
1588
- return "http://localhost";
1589
- }
1590
- }
1591
- }
1592
- }
1593
-
1594
- throw 'invalid adapter type: ' + type;
1595
- }
1596
-
1597
- const STORAGE_KEY_PREFIX = 'kc-callback-';
1598
-
1599
- var LocalStorage = function() {
1600
- if (!(this instanceof LocalStorage)) {
1601
- return new LocalStorage();
1602
- }
1603
-
1604
- localStorage.setItem('kc-test', 'test');
1605
- localStorage.removeItem('kc-test');
1606
-
1607
- var cs = this;
1608
-
1609
- /**
1610
- * Clears all values from local storage that are no longer valid.
1611
- */
1612
- function clearInvalidValues() {
1613
- const currentTime = Date.now();
1614
-
1615
- for (const [key, value] of getStoredEntries()) {
1616
- // Attempt to parse the expiry time from the value.
1617
- const expiry = parseExpiry(value);
1618
-
1619
- // Discard the value if it is malformed or expired.
1620
- if (expiry === null || expiry < currentTime) {
1621
- localStorage.removeItem(key);
1622
- }
1623
- }
1624
- }
1625
-
1626
- /**
1627
- * Clears all known values from local storage.
1628
- */
1629
- function clearAllValues() {
1630
- for (const [key] of getStoredEntries()) {
1631
- localStorage.removeItem(key);
1632
- }
1633
- }
1634
-
1635
- /**
1636
- * Gets all entries stored in local storage that are known to be managed by this class.
1637
- * @returns {Array<[string, unknown]>} An array of key-value pairs.
1638
- */
1639
- function getStoredEntries() {
1640
- return Object.entries(localStorage).filter(([key]) => key.startsWith(STORAGE_KEY_PREFIX));
1641
- }
1642
-
1643
- /**
1644
- * Parses the expiry time from a value stored in local storage.
1645
- * @param {unknown} value
1646
- * @returns {number | null} The expiry time in milliseconds, or `null` if the value is malformed.
1647
- */
1648
- function parseExpiry(value) {
1649
- let parsedValue;
1650
-
1651
- // Attempt to parse the value as JSON.
1652
- try {
1653
- parsedValue = JSON.parse(value);
1654
- } catch (error) {
1655
- return null;
1656
- }
1657
-
1658
- // Attempt to extract the 'expires' property.
1659
- if (isObject(parsedValue) && 'expires' in parsedValue && typeof parsedValue.expires === 'number') {
1660
- return parsedValue.expires;
1661
- }
1662
-
1663
- return null;
1664
- }
1665
-
1666
- cs.get = function(state) {
1667
- if (!state) {
1668
- return;
1669
- }
1670
-
1671
- var key = STORAGE_KEY_PREFIX + state;
1672
- var value = localStorage.getItem(key);
1673
- if (value) {
1674
- localStorage.removeItem(key);
1675
- value = JSON.parse(value);
1676
- }
1677
-
1678
- clearInvalidValues();
1679
- return value;
1680
- };
1681
-
1682
- cs.add = function(state) {
1683
- clearInvalidValues();
1684
-
1685
- const key = STORAGE_KEY_PREFIX + state.state;
1686
- const value = JSON.stringify({
1687
- ...state,
1688
- // Set the expiry time to 1 hour from now.
1689
- expires: Date.now() + (60 * 60 * 1000)
1690
- });
1691
-
1692
- try {
1693
- localStorage.setItem(key, value);
1694
- } catch (error) {
1695
- // If the storage is full, clear all known values and try again.
1696
- clearAllValues();
1697
- localStorage.setItem(key, value);
1698
- }
1699
- };
1700
- };
1701
-
1702
- var CookieStorage = function() {
1703
- if (!(this instanceof CookieStorage)) {
1704
- return new CookieStorage();
1705
- }
1706
-
1707
- var cs = this;
1708
-
1709
- cs.get = function(state) {
1710
- if (!state) {
1711
- return;
1712
- }
1713
-
1714
- var value = getCookie(STORAGE_KEY_PREFIX + state);
1715
- setCookie(STORAGE_KEY_PREFIX + state, '', cookieExpiration(-100));
1716
- if (value) {
1717
- return JSON.parse(value);
1718
- }
1719
- };
1720
-
1721
- cs.add = function(state) {
1722
- setCookie(STORAGE_KEY_PREFIX + state.state, JSON.stringify(state), cookieExpiration(60));
1723
- };
1724
-
1725
- cs.removeItem = function(key) {
1726
- setCookie(key, '', cookieExpiration(-100));
1727
- };
1728
-
1729
- var cookieExpiration = function (minutes) {
1730
- var exp = new Date();
1731
- exp.setTime(exp.getTime() + (minutes*60*1000));
1732
- return exp;
1733
- };
1734
-
1735
- var getCookie = function (key) {
1736
- var name = key + '=';
1737
- var ca = document.cookie.split(';');
1738
- for (var i = 0; i < ca.length; i++) {
1739
- var c = ca[i];
1740
- while (c.charAt(0) == ' ') {
1741
- c = c.substring(1);
1742
- }
1743
- if (c.indexOf(name) == 0) {
1744
- return c.substring(name.length, c.length);
1745
- }
1746
- }
1747
- return '';
1748
- };
1749
-
1750
- var setCookie = function (key, value, expirationDate) {
1751
- var cookie = key + '=' + value + '; '
1752
- + 'expires=' + expirationDate.toUTCString() + '; ';
1753
- document.cookie = cookie;
1754
- };
1755
- };
1756
-
1757
- function createCallbackStorage() {
1758
- try {
1759
- return new LocalStorage();
1760
- } catch (err) {
1761
- }
1762
-
1763
- return new CookieStorage();
1764
- }
1765
-
1766
- function createLogger(fn) {
1767
- return function() {
1768
- if (kc.enableLogging) {
1769
- fn.apply(console, Array.prototype.slice.call(arguments));
1770
- }
1771
- };
1772
- }
1773
- }
1774
-
1775
- /**
1776
- * @param {ArrayBuffer} bytes
1777
- * @see https://developer.mozilla.org/en-US/docs/Glossary/Base64#the_unicode_problem
1778
- */
1779
- function bytesToBase64(bytes) {
1780
- const binString = String.fromCodePoint(...bytes);
1781
- return btoa(binString);
1782
- }
1783
-
1784
- /**
1785
- * @param {string} message
1786
- * @see https://developer.mozilla.org/en-US/docs/Web/API/SubtleCrypto/digest#basic_example
1787
- */
1788
- async function sha256Digest(message) {
1789
- const encoder = new TextEncoder();
1790
- const data = encoder.encode(message);
1791
-
1792
- if (typeof crypto === "undefined" || typeof crypto.subtle === "undefined") {
1793
- throw new Error("Web Crypto API is not available.");
1794
- }
1795
-
1796
- return await crypto.subtle.digest("SHA-256", data);
1797
- }
1798
-
1799
- /**
1800
- * @param {string} token
1801
- */
1802
- function decodeToken(token) {
1803
- const [header, payload] = token.split(".");
1804
-
1805
- if (typeof payload !== "string") {
1806
- throw new Error("Unable to decode token, payload not found.");
1807
- }
1808
-
1809
- let decoded;
1810
-
1811
- try {
1812
- decoded = base64UrlDecode(payload);
1813
- } catch (error) {
1814
- throw new Error("Unable to decode token, payload is not a valid Base64URL value.", { cause: error });
1815
- }
1816
-
1817
- try {
1818
- return JSON.parse(decoded);
1819
- } catch (error) {
1820
- throw new Error("Unable to decode token, payload is not a valid JSON value.", { cause: error });
1821
- }
1822
- }
1823
-
1824
- /**
1825
- * @param {string} input
1826
- */
1827
- function base64UrlDecode(input) {
1828
- let output = input
1829
- .replaceAll("-", "+")
1830
- .replaceAll("_", "/");
1831
-
1832
- switch (output.length % 4) {
1833
- case 0:
1834
- break;
1835
- case 2:
1836
- output += "==";
1837
- break;
1838
- case 3:
1839
- output += "=";
1840
- break;
1841
- default:
1842
- throw new Error("Input is not of the correct length.");
1843
- }
1844
-
1845
- try {
1846
- return b64DecodeUnicode(output);
1847
- } catch (error) {
1848
- return atob(output);
1849
- }
1850
- }
1851
-
1852
- /**
1853
- * @param {string} input
1854
- */
1855
- function b64DecodeUnicode(input) {
1856
- return decodeURIComponent(atob(input).replace(/(.)/g, (m, p) => {
1857
- let code = p.charCodeAt(0).toString(16).toUpperCase();
1858
-
1859
- if (code.length < 2) {
1860
- code = "0" + code;
1861
- }
1862
-
1863
- return "%" + code;
1864
- }));
1865
- }
1866
-
1867
- /**
1868
- * Check if the input is an object that can be operated on.
1869
- * @param {unknown} input
1870
- */
1871
- function isObject(input) {
1872
- return typeof input === 'object' && input !== null;
1873
- }
1874
-
1875
- let keycloak = null;
1876
- let keycloakInitPromise = null;
1877
- // Initialize Keycloak with an optional silent check
1878
- function initKeycloak(config, silentCheck = true) {
1879
- // If already initializing or initialized, return the cached promise
1880
- if (keycloakInitPromise) {
1881
- // eslint-disable-next-line
1882
- console.log('Keycloak already initialized, returning from cache');
1883
- return keycloakInitPromise;
1884
- }
1885
- if (!keycloak) {
1886
- keycloak = new Keycloak({
1887
- url: config.url,
1888
- realm: config.realm,
1889
- clientId: config.clientId
1890
- });
1891
- }
1892
- keycloakInitPromise = keycloak
1893
- .init({
1894
- onLoad: silentCheck ? 'check-sso' : 'login-required',
1895
- checkLoginIframe: false
1896
- //silentCheckSsoRedirectUri: `${window.location.origin}/silent-check-sso.html`, // Ensure this file is set up
1897
- })
1898
- .then((authenticated) => authenticated)
1899
- .catch((error) => {
1900
- // eslint-disable-next-line
1901
- console.error('Failed to initialize Keycloak:', error);
1902
- return false;
1903
- });
1904
- return keycloakInitPromise;
1905
- }
1906
- function getUser() {
1907
- if ((keycloak === null || keycloak === void 0 ? void 0 : keycloak.authenticated) && (keycloak === null || keycloak === void 0 ? void 0 : keycloak.idTokenParsed)) {
1908
- return {
1909
- fullname: keycloak.idTokenParsed.name,
1910
- email: keycloak.idTokenParsed.email,
1911
- lastname: keycloak.idTokenParsed.family_name,
1912
- firstname: keycloak.idTokenParsed.given_name,
1913
- username: keycloak.idTokenParsed.preferred_username,
1914
- background: 'grey', // Optional custom value
1915
- token: keycloak.token,
1916
- sub: keycloak.idTokenParsed.sub
1917
- };
1918
- }
1919
- return {};
1920
- }
1921
- // Log in the user
1922
- function login() {
1923
- if (keycloak) {
1924
- keycloak.login();
1925
- }
1926
- else {
1927
- throw new Error('Keycloak is not initialized.');
1928
- }
1929
- }
1930
- // Log out the user
1931
- function logout() {
1932
- if (keycloak) {
1933
- keycloak.logout();
1934
- }
1935
- else {
1936
- throw new Error('Keycloak is not initialized.');
1937
- }
1938
- }
1939
- // Check if the user is authenticated
1940
- function isAuthenticated() {
1941
- return !!(keycloak === null || keycloak === void 0 ? void 0 : keycloak.authenticated);
1942
- }
1943
- async function checkServerAvailability(url) {
1944
- try {
1945
- const response = await fetch(url, { method: 'HEAD', mode: 'no-cors' });
1946
- return response.ok || response.type === 'opaque';
1947
- }
1948
- catch (_a) {
1949
- return false;
1950
- }
1951
- }
1952
-
1953
- const EdsLogin = /*@__PURE__*/ proxyCustomElement(class EdsLogin extends HTMLElement {
1954
- constructor() {
1955
- super();
1956
- this.__registerHost();
1957
- this.__attachShadow();
1958
- this.keycloak = createEvent(this, "keycloak", 7);
1959
- this.auth = createEvent(this, "auth", 7);
1960
- /**
1961
- * Handles user login by invoking the Keycloak `login` function.
1962
- * Only triggers login if the user is not already authenticated.
1963
- */
1964
- this.handleLogin = async () => {
1965
- if (!this.authenticated) {
1966
- try {
1967
- await login();
1968
- }
1969
- catch (error) {
1970
- toast.show(error.message, 'error');
1971
- }
1972
- }
1973
- };
1974
- /**
1975
- * Handles user logout by invoking the Keycloak `logout` function.
1976
- * Resets the `authenticated` state to `false` after logout.
1977
- */
1978
- this.handleLogout = async () => {
1979
- try {
1980
- await logout();
1981
- }
1982
- catch (error) {
1983
- toast.show(error.message, 'error');
1984
- }
1985
- this.authenticated = false;
1986
- this.user = null;
1987
- };
1988
- this.keycloakUrl = undefined;
1989
- this.keycloakRealm = undefined;
1990
- this.keycloakClientId = undefined;
1991
- this.authenticated = false;
1992
- this.user = null;
1993
- this.serverAvailable = false;
1994
- }
1995
- /**
1996
- * Lifecycle method that runs when the component is about to load.
1997
- * It initializes authentication by calling the `initAuth` method.
1998
- */
1999
- async componentWillLoad() {
2000
- // Check if required props are provided (optional check)
2001
- if (!this.keycloakUrl || !this.keycloakRealm || !this.keycloakClientId) {
2002
- // eslint-disable-next-line
2003
- console.error('Keycloak configuration props are missing.');
2004
- return;
2005
- }
2006
- this.serverAvailable = await checkServerAvailability(`${this.keycloakUrl}/realms/${this.keycloakRealm}`);
2007
- if (!this.serverAvailable) {
2008
- toast.show('Keycloak server is unavailable.', 'error');
2009
- return; // Do not proceed further
2010
- }
2011
- await this.initAuth();
2012
- }
2013
- /**
2014
- * Initializes the Keycloak authentication by configuring Keycloak with the provided props.
2015
- * Sets the `authenticated` state and `user` data if the user is authenticated.
2016
- * Emits `authStatusChanged` event with the authentication status.
2017
- */
2018
- async initAuth() {
2019
- try {
2020
- const res = await initKeycloak({
2021
- url: this.keycloakUrl,
2022
- realm: this.keycloakRealm,
2023
- clientId: this.keycloakClientId
2024
- }, true);
2025
- this.keycloak.emit({
2026
- init: res
2027
- });
2028
- if (isAuthenticated()) {
2029
- this.user = getUser();
2030
- this.authenticated = true;
2031
- this.auth.emit({
2032
- authenticated: this.authenticated,
2033
- user: this.user
2034
- }); // Emit auth status change
2035
- }
2036
- }
2037
- catch (error) {
2038
- toast.show(error.message, 'error');
2039
- }
2040
- }
2041
- render() {
2042
- return (h("div", { key: '041846174aaad541acce03588a087793d10daa1e', class: "block" }, !this.authenticated && (h("eds-button", { key: '360a84ec79a15c9293e3898b77df649c469d9529', label: "Login", intent: "primary", "extra-class": "text-default", "aria-label": "Login", triggerClick: this.handleLogin.bind(this) }))));
2043
- }
2044
- }, [1, "eds-login", {
2045
- "keycloakUrl": [1, "keycloak-url"],
2046
- "keycloakRealm": [1, "keycloak-realm"],
2047
- "keycloakClientId": [1, "keycloak-client-id"],
2048
- "authenticated": [32],
2049
- "user": [32],
2050
- "serverAvailable": [32]
2051
- }]);
2052
- function defineCustomElement() {
2053
- if (typeof customElements === "undefined") {
2054
- return;
2055
- }
2056
- const components = ["eds-login", "eds-button", "eds-icon-wrapper"];
2057
- components.forEach(tagName => { switch (tagName) {
2058
- case "eds-login":
2059
- if (!customElements.get(tagName)) {
2060
- customElements.define(tagName, EdsLogin);
2061
- }
2062
- break;
2063
- case "eds-button":
2064
- if (!customElements.get(tagName)) {
2065
- defineCustomElement$2();
2066
- }
2067
- break;
2068
- case "eds-icon-wrapper":
2069
- if (!customElements.get(tagName)) {
2070
- defineCustomElement$1();
2071
- }
2072
- break;
2073
- } });
2074
- }
2075
-
2076
- export { EdsLogin as E, defineCustomElement as d };