@duetds/components 8.0.6 → 8.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1247) hide show
  1. package/hydrate/index.d.ts +2 -2
  2. package/hydrate/index.js +19204 -17910
  3. package/lib/cjs/app-globals-aece069f.js +28 -0
  4. package/lib/cjs/{common-strings-86913e94.js → common-strings-22c70ef0.js} +6 -6
  5. package/lib/cjs/create-id-1f8c438f.js +13 -0
  6. package/lib/cjs/duet-action-button.cjs.entry.js +134 -134
  7. package/lib/cjs/duet-alert.cjs.entry.js +109 -106
  8. package/lib/cjs/duet-badge.cjs.entry.js +29 -29
  9. package/lib/cjs/duet-banner.cjs.entry.js +52 -52
  10. package/lib/cjs/duet-breadcrumb.cjs.entry.js +50 -41
  11. package/lib/cjs/duet-breadcrumbs.cjs.entry.js +51 -51
  12. package/lib/cjs/duet-button_2.cjs.entry.js +229 -229
  13. package/lib/cjs/duet-callout.cjs.entry.js +28 -28
  14. package/lib/cjs/duet-caption_4.cjs.entry.js +197 -187
  15. package/lib/cjs/duet-card.cjs.entry.js +100 -94
  16. package/lib/cjs/duet-checkbox.cjs.entry.js +85 -85
  17. package/lib/cjs/duet-checkmark.cjs.entry.js +23 -23
  18. package/lib/cjs/duet-chip.cjs.entry.js +189 -182
  19. package/lib/cjs/duet-choice_2.cjs.entry.js +395 -393
  20. package/lib/cjs/duet-collapsible.cjs.entry.js +105 -99
  21. package/lib/cjs/duet-combobox.cjs.entry.js +363 -363
  22. package/lib/cjs/duet-contact-card.cjs.entry.js +49 -49
  23. package/lib/cjs/duet-cookie-consent.cjs.entry.js +42 -35
  24. package/lib/cjs/duet-date-picker.cjs.entry.js +610 -610
  25. package/lib/cjs/duet-divider_2.cjs.entry.js +53 -53
  26. package/lib/cjs/duet-editable-table_3.cjs.entry.js +1248 -1248
  27. package/lib/cjs/duet-empty-state.cjs.entry.js +26 -26
  28. package/lib/cjs/duet-fieldset.cjs.entry.js +50 -50
  29. package/lib/cjs/duet-file-chooser.cjs.entry.js +44 -44
  30. package/lib/cjs/duet-footer.cjs.entry.js +121 -118
  31. package/lib/cjs/duet-grid_2.cjs.entry.js +185 -185
  32. package/lib/cjs/duet-header_2.cjs.entry.js +613 -611
  33. package/lib/cjs/duet-hero.cjs.entry.js +172 -172
  34. package/lib/cjs/duet-icon.cjs.entry.js +141 -141
  35. package/lib/cjs/duet-input_2.cjs.entry.js +347 -347
  36. package/lib/cjs/duet-layout.cjs.entry.js +51 -51
  37. package/lib/cjs/duet-list_2.cjs.entry.js +99 -99
  38. package/lib/cjs/duet-menu-bar-button.cjs.entry.js +70 -70
  39. package/lib/cjs/duet-menu-bar-dropdown-link.cjs.entry.js +45 -45
  40. package/lib/cjs/duet-menu-bar-dropdown.cjs.entry.js +94 -94
  41. package/lib/cjs/duet-menu-bar-link.cjs.entry.js +58 -58
  42. package/lib/cjs/duet-menu-bar.cjs.entry.js +116 -116
  43. package/lib/cjs/duet-modal.cjs.entry.js +189 -189
  44. package/lib/cjs/duet-multiselect.cjs.entry.js +207 -207
  45. package/lib/cjs/duet-nav.cjs.entry.js +20 -20
  46. package/lib/cjs/duet-notification_2.cjs.entry.js +145 -140
  47. package/lib/cjs/duet-number-input.cjs.entry.js +340 -338
  48. package/lib/cjs/duet-page-heading.cjs.entry.js +26 -26
  49. package/lib/cjs/duet-pagination_2.cjs.entry.js +512 -512
  50. package/lib/cjs/duet-popup-menu-item.cjs.entry.js +62 -62
  51. package/lib/cjs/duet-popup-menu.cjs.entry.js +148 -148
  52. package/lib/cjs/duet-progress.cjs.entry.js +54 -54
  53. package/lib/cjs/duet-promo-card.cjs.entry.js +40 -40
  54. package/lib/cjs/duet-radio_2.cjs.entry.js +197 -197
  55. package/lib/cjs/duet-range-slider.cjs.entry.js +112 -105
  56. package/lib/cjs/duet-scrollable_3.cjs.entry.js +387 -387
  57. package/lib/cjs/duet-section-layout.cjs.entry.js +21 -21
  58. package/lib/cjs/duet-select.cjs.entry.js +156 -156
  59. package/lib/cjs/duet-shaped-image.cjs.entry.js +28 -28
  60. package/lib/cjs/duet-show-more.cjs.entry.js +99 -99
  61. package/lib/cjs/duet-slideout-lang.cjs.entry.js +36 -36
  62. package/lib/cjs/duet-slideout-link.cjs.entry.js +33 -33
  63. package/lib/cjs/duet-slideout-panel-dropdown.cjs.entry.js +50 -50
  64. package/lib/cjs/duet-slideout-panel.cjs.entry.js +120 -120
  65. package/lib/cjs/duet-slideout.cjs.entry.js +196 -196
  66. package/lib/cjs/duet-step_2.cjs.entry.js +189 -185
  67. package/lib/cjs/duet-submenu-bar-dropdown-link.cjs.entry.js +37 -37
  68. package/lib/cjs/duet-submenu-bar-dropdown.cjs.entry.js +104 -104
  69. package/lib/cjs/duet-submenu-bar-link.cjs.entry.js +60 -60
  70. package/lib/cjs/duet-submenu-bar.cjs.entry.js +110 -110
  71. package/lib/cjs/duet-textarea.cjs.entry.js +160 -160
  72. package/lib/cjs/duet-toggle.cjs.entry.js +79 -72
  73. package/lib/cjs/duet-toolbar-dropdown-link.cjs.entry.js +36 -36
  74. package/lib/cjs/duet-toolbar-dropdown.cjs.entry.js +60 -60
  75. package/lib/cjs/duet-toolbar-link.cjs.entry.js +31 -31
  76. package/lib/cjs/duet-toolbar.cjs.entry.js +34 -34
  77. package/lib/cjs/duet-tooltip-button_2.cjs.entry.js +93 -80
  78. package/lib/cjs/duet-tooltip.cjs.entry.js +190 -188
  79. package/lib/cjs/duet-tray.cjs.entry.js +85 -82
  80. package/lib/cjs/duet-upload-aria-status.cjs.entry.js +65 -65
  81. package/lib/cjs/duet-upload-item.cjs.entry.js +81 -81
  82. package/lib/cjs/duet-visually-hidden.cjs.entry.js +12 -12
  83. package/lib/cjs/duet.cjs.js +4 -4
  84. package/lib/cjs/errorcodes.utils-a86b1f94.js +39 -0
  85. package/lib/cjs/focus-utils-d0b70745.js +21 -0
  86. package/lib/cjs/{index-2cce7b13.js → index-2dc54a15.js} +106 -45
  87. package/lib/cjs/input-utils-1096a2c5.js +56 -0
  88. package/lib/cjs/{is-internet-explorer-76c3b538.js → is-internet-explorer-e7f58ebc.js} +2 -2
  89. package/lib/cjs/{js-utils-b20cfc79.js → js-utils-92e24ba1.js} +27 -27
  90. package/lib/cjs/keyboard-utils-7248dd0a.js +69 -0
  91. package/lib/cjs/{language-utils-dc19e8b6.js → language-utils-e8a527e5.js} +74 -74
  92. package/lib/cjs/loader.cjs.js +3 -3
  93. package/lib/cjs/{slot-query-b7555763.js → slot-query-3259af5b.js} +1 -1
  94. package/lib/cjs/string-utils-053749ff.js +59 -0
  95. package/lib/cjs/teleport-e9d05bca.js +99 -0
  96. package/lib/cjs/themeable-component-83a2a0d4.js +15 -0
  97. package/lib/cjs/token-utils-84b3bca6.js +124 -0
  98. package/lib/cjs/watch-options-30a12622.js +61 -0
  99. package/lib/collection/collection-manifest.json +3 -3
  100. package/lib/collection/common/slot-query.js +3 -3
  101. package/lib/collection/common/themeable-component.js +6 -6
  102. package/lib/collection/common-strings.js +6 -6
  103. package/lib/collection/components/duet-action-button/duet-action-button.a11y.e2e.js +5 -5
  104. package/lib/collection/components/duet-action-button/duet-action-button.js +570 -569
  105. package/lib/collection/components/duet-alert/duet-alert.a11y.e2e.js +10 -10
  106. package/lib/collection/components/duet-alert/duet-alert.e2e.js +47 -47
  107. package/lib/collection/components/duet-alert/duet-alert.js +445 -441
  108. package/lib/collection/components/duet-badge/duet-badge.a11y.e2e.js +10 -10
  109. package/lib/collection/components/duet-badge/duet-badge.e2e.js +21 -21
  110. package/lib/collection/components/duet-badge/duet-badge.js +134 -134
  111. package/lib/collection/components/duet-banner/duet-banner.a11y.e2e.js +5 -5
  112. package/lib/collection/components/duet-banner/duet-banner.e2e.js +16 -16
  113. package/lib/collection/components/duet-banner/duet-banner.js +309 -309
  114. package/lib/collection/components/duet-breadcrumbs/duet-breadcrumb.js +172 -139
  115. package/lib/collection/components/duet-breadcrumbs/duet-breadcrumbs.a11y.e2e.js +5 -5
  116. package/lib/collection/components/duet-breadcrumbs/duet-breadcrumbs.e2e.js +6 -6
  117. package/lib/collection/components/duet-breadcrumbs/duet-breadcrumbs.js +112 -112
  118. package/lib/collection/components/duet-button/duet-button.a11y.e2e.js +30 -30
  119. package/lib/collection/components/duet-button/duet-button.e2e.js +187 -187
  120. package/lib/collection/components/duet-button/duet-button.js +1068 -1067
  121. package/lib/collection/components/duet-callout/duet-callout.a11y.e2e.js +5 -5
  122. package/lib/collection/components/duet-callout/duet-callout.e2e.js +15 -15
  123. package/lib/collection/components/duet-callout/duet-callout.js +88 -88
  124. package/lib/collection/components/duet-caption/duet-caption.a11y.e2e.js +5 -5
  125. package/lib/collection/components/duet-caption/duet-caption.e2e.js +20 -20
  126. package/lib/collection/components/duet-caption/duet-caption.js +131 -131
  127. package/lib/collection/components/duet-card/duet-card.a11y.e2e.js +10 -10
  128. package/lib/collection/components/duet-card/duet-card.e2e.js +85 -85
  129. package/lib/collection/components/duet-card/duet-card.js +498 -491
  130. package/lib/collection/components/duet-checkbox/duet-checkbox.a11y.e2e.js +10 -10
  131. package/lib/collection/components/duet-checkbox/duet-checkbox.e2e.js +103 -103
  132. package/lib/collection/components/duet-checkbox/duet-checkbox.js +553 -549
  133. package/lib/collection/components/duet-chip/duet-chip.a11y.e2e.js +10 -10
  134. package/lib/collection/components/duet-chip/duet-chip.e2e.js +40 -40
  135. package/lib/collection/components/duet-chip/duet-chip.js +494 -486
  136. package/lib/collection/components/duet-choice/duet-checkmark.js +136 -136
  137. package/lib/collection/components/duet-choice/duet-choice.a11y.e2e.js +25 -25
  138. package/lib/collection/components/duet-choice/duet-choice.e2e.js +171 -171
  139. package/lib/collection/components/duet-choice/duet-choice.js +1095 -1089
  140. package/lib/collection/components/duet-choice-group/duet-choice-group.a11y.e2e.js +5 -5
  141. package/lib/collection/components/duet-choice-group/duet-choice-group.e2e.js +63 -63
  142. package/lib/collection/components/duet-choice-group/duet-choice-group.js +456 -453
  143. package/lib/collection/components/duet-collapsible/duet-collapsible.a11y.e2e.js +10 -10
  144. package/lib/collection/components/duet-collapsible/duet-collapsible.e2e.js +87 -87
  145. package/lib/collection/components/duet-collapsible/duet-collapsible.js +370 -363
  146. package/lib/collection/components/duet-combobox/duet-combobox-select-single.js +2 -2
  147. package/lib/collection/components/duet-combobox/duet-combobox-select.js +8 -8
  148. package/lib/collection/components/duet-combobox/duet-combobox.a11y.e2e.js +5 -5
  149. package/lib/collection/components/duet-combobox/duet-combobox.e2e.js +115 -115
  150. package/lib/collection/components/duet-combobox/duet-combobox.js +670 -669
  151. package/lib/collection/components/duet-contact-card/duet-contact-card.a11y.e2e.js +5 -5
  152. package/lib/collection/components/duet-contact-card/duet-contact-card.js +255 -255
  153. package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.a11y.e2e.js +5 -5
  154. package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.e2e.js +16 -16
  155. package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.js +134 -127
  156. package/lib/collection/components/duet-date-picker/date-i18n.js +97 -97
  157. package/lib/collection/components/duet-date-picker/date-picker-day.js +9 -9
  158. package/lib/collection/components/duet-date-picker/date-picker-input.js +5 -5
  159. package/lib/collection/components/duet-date-picker/date-picker-month.js +16 -16
  160. package/lib/collection/components/duet-date-picker/date-utils.js +95 -95
  161. package/lib/collection/components/duet-date-picker/date-utils.spec.js +323 -323
  162. package/lib/collection/components/duet-date-picker/duet-date-picker.a11y.e2e.js +5 -5
  163. package/lib/collection/components/duet-date-picker/duet-date-picker.e2e.js +618 -618
  164. package/lib/collection/components/duet-date-picker/duet-date-picker.js +1049 -1044
  165. package/lib/collection/components/duet-date-picker/utils.js +29 -29
  166. package/lib/collection/components/duet-divider/duet-divider.a11y.e2e.js +5 -5
  167. package/lib/collection/components/duet-divider/duet-divider.e2e.js +24 -24
  168. package/lib/collection/components/duet-divider/duet-divider.js +112 -112
  169. package/lib/collection/components/duet-editable-table/duet-editable-table-tabledata.js +7 -7
  170. package/lib/collection/components/duet-editable-table/duet-editable-table.a11y.e2e.js +5 -5
  171. package/lib/collection/components/duet-editable-table/duet-editable-table.e2e.js +19 -19
  172. package/lib/collection/components/duet-editable-table/duet-editable-table.js +501 -498
  173. package/lib/collection/components/duet-empty-state/duet-empty-state.a11y.e2e.js +5 -5
  174. package/lib/collection/components/duet-empty-state/duet-empty-state.e2e.js +10 -10
  175. package/lib/collection/components/duet-empty-state/duet-empty-state.js +110 -110
  176. package/lib/collection/components/duet-fieldset/duet-fieldset.a11y.e2e.js +5 -5
  177. package/lib/collection/components/duet-fieldset/duet-fieldset.e2e.js +5 -5
  178. package/lib/collection/components/duet-fieldset/duet-fieldset.js +245 -245
  179. package/lib/collection/components/duet-file-chooser/duet-file-chooser.js +179 -179
  180. package/lib/collection/components/duet-footer/duet-footer.a11y.e2e.js +5 -5
  181. package/lib/collection/components/duet-footer/duet-footer.e2e.js +163 -163
  182. package/lib/collection/components/duet-footer/duet-footer.js +488 -485
  183. package/lib/collection/components/duet-grid/duet-grid.a11y.e2e.js +5 -5
  184. package/lib/collection/components/duet-grid/duet-grid.e2e.js +36 -36
  185. package/lib/collection/components/duet-grid/duet-grid.js +345 -342
  186. package/lib/collection/components/duet-grid-item/duet-grid-item.js +233 -230
  187. package/lib/collection/components/duet-header/duet-header-dropdown.js +12 -12
  188. package/lib/collection/components/duet-header/duet-header-icon.js +2 -2
  189. package/lib/collection/components/duet-header/duet-header.a11y.e2e.js +5 -5
  190. package/lib/collection/components/duet-header/duet-header.e2e.js +430 -430
  191. package/lib/collection/components/duet-header/duet-header.js +1300 -1296
  192. package/lib/collection/components/duet-heading/duet-heading.a11y.e2e.js +5 -5
  193. package/lib/collection/components/duet-heading/duet-heading.e2e.js +21 -21
  194. package/lib/collection/components/duet-heading/duet-heading.js +230 -230
  195. package/lib/collection/components/duet-hero/duet-hero.a11y.e2e.js +15 -15
  196. package/lib/collection/components/duet-hero/duet-hero.e2e.js +166 -166
  197. package/lib/collection/components/duet-hero/duet-hero.js +814 -814
  198. package/lib/collection/components/duet-icon/duet-icon.a11y.e2e.js +5 -5
  199. package/lib/collection/components/duet-icon/duet-icon.e2e.js +26 -26
  200. package/lib/collection/components/duet-icon/duet-icon.js +392 -392
  201. package/lib/collection/components/duet-icon/icon-utils.js +59 -59
  202. package/lib/collection/components/duet-icon/icon-utils.spec.js +76 -76
  203. package/lib/collection/components/duet-input/duet-input.a11y.e2e.js +20 -20
  204. package/lib/collection/components/duet-input/duet-input.e2e.js +195 -195
  205. package/lib/collection/components/duet-input/duet-input.js +1249 -1245
  206. package/lib/collection/components/duet-label/duet-label.a11y.e2e.js +5 -5
  207. package/lib/collection/components/duet-label/duet-label.e2e.js +26 -26
  208. package/lib/collection/components/duet-label/duet-label.js +134 -131
  209. package/lib/collection/components/duet-layout/duet-layout.a11y.e2e.js +5 -5
  210. package/lib/collection/components/duet-layout/duet-layout.e2e.js +26 -26
  211. package/lib/collection/components/duet-layout/duet-layout.js +207 -207
  212. package/lib/collection/components/duet-link/duet-link.a11y.e2e.js +15 -15
  213. package/lib/collection/components/duet-link/duet-link.e2e.js +47 -47
  214. package/lib/collection/components/duet-link/duet-link.js +446 -435
  215. package/lib/collection/components/duet-list/duet-list.a11y.e2e.js +11 -11
  216. package/lib/collection/components/duet-list/duet-list.e2e.js +50 -50
  217. package/lib/collection/components/duet-list/duet-list.js +292 -292
  218. package/lib/collection/components/duet-list-item/duet-list-item.js +81 -81
  219. package/lib/collection/components/duet-logo/duet-logo.a11y.e2e.js +5 -5
  220. package/lib/collection/components/duet-logo/duet-logo.e2e.js +36 -36
  221. package/lib/collection/components/duet-logo/duet-logo.js +293 -292
  222. package/lib/collection/components/duet-menu-bar/duet-menu-bar.a11y.e2e.js +5 -5
  223. package/lib/collection/components/duet-menu-bar/duet-menu-bar.js +261 -261
  224. package/lib/collection/components/duet-menu-bar-button/duet-menu-bar-button.js +347 -346
  225. package/lib/collection/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.js +224 -223
  226. package/lib/collection/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.js +133 -133
  227. package/lib/collection/components/duet-menu-bar-link/duet-menu-bar-link.js +170 -170
  228. package/lib/collection/components/duet-modal/duet-modal.a11y.e2e.js +10 -10
  229. package/lib/collection/components/duet-modal/duet-modal.e2e.js +78 -78
  230. package/lib/collection/components/duet-modal/duet-modal.js +687 -687
  231. package/lib/collection/components/duet-multiselect/duet-multiselect.a11y.e2e.js +5 -5
  232. package/lib/collection/components/duet-multiselect/duet-multiselect.e2e.js +87 -87
  233. package/lib/collection/components/duet-multiselect/duet-multiselect.js +654 -653
  234. package/lib/collection/components/duet-nav/duet-nav.js +56 -56
  235. package/lib/collection/components/duet-notification/duet-notification.a11y.e2e.js +5 -5
  236. package/lib/collection/components/duet-notification/duet-notification.e2e.js +6 -6
  237. package/lib/collection/components/duet-notification/duet-notification.js +260 -259
  238. package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.a11y.e2e.js +10 -10
  239. package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.e2e.js +141 -141
  240. package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.js +382 -383
  241. package/lib/collection/components/duet-number-input/duet-number-input-negative.e2e.js +26 -26
  242. package/lib/collection/components/duet-number-input/duet-number-input.a11y.e2e.js +5 -5
  243. package/lib/collection/components/duet-number-input/duet-number-input.e2e.js +232 -232
  244. package/lib/collection/components/duet-number-input/duet-number-input.js +1120 -1114
  245. package/lib/collection/components/duet-page-heading/duet-page-heading.a11y.e2e.js +5 -5
  246. package/lib/collection/components/duet-page-heading/duet-page-heading.js +104 -104
  247. package/lib/collection/components/duet-pagination/duet-pagination-utils.js +4 -4
  248. package/lib/collection/components/duet-pagination/duet-pagination.a11y.e2e.js +10 -10
  249. package/lib/collection/components/duet-pagination/duet-pagination.e2e.js +79 -79
  250. package/lib/collection/components/duet-pagination/duet-pagination.js +677 -677
  251. package/lib/collection/components/duet-paragraph/duet-paragraph.a11y.e2e.js +5 -5
  252. package/lib/collection/components/duet-paragraph/duet-paragraph.e2e.js +21 -21
  253. package/lib/collection/components/duet-paragraph/duet-paragraph.js +190 -190
  254. package/lib/collection/components/duet-popup-menu/duet-popup-menu.a11y.e2e.js +5 -5
  255. package/lib/collection/components/duet-popup-menu/duet-popup-menu.js +407 -407
  256. package/lib/collection/components/duet-popup-menu-item/duet-popup-menu-item.js +344 -343
  257. package/lib/collection/components/duet-progress/duet-progress.a11y.e2e.js +7 -7
  258. package/lib/collection/components/duet-progress/duet-progress.e2e.js +6 -6
  259. package/lib/collection/components/duet-progress/duet-progress.js +276 -273
  260. package/lib/collection/components/duet-promo-card/duet-promo-card.a11y.e2e.js +5 -5
  261. package/lib/collection/components/duet-promo-card/duet-promo-card.e2e.js +16 -16
  262. package/lib/collection/components/duet-promo-card/duet-promo-card.js +206 -206
  263. package/lib/collection/components/duet-radio/duet-radio.a11y.e2e.js +5 -5
  264. package/lib/collection/components/duet-radio/duet-radio.e2e.js +126 -126
  265. package/lib/collection/components/duet-radio/duet-radio.js +609 -605
  266. package/lib/collection/components/duet-radio-group/duet-radio-group.a11y.e2e.js +10 -10
  267. package/lib/collection/components/duet-radio-group/duet-radio-group.e2e.js +39 -39
  268. package/lib/collection/components/duet-radio-group/duet-radio-group.js +423 -420
  269. package/lib/collection/components/duet-range-slider/duet-range-slider.a11y.e2e.js +5 -5
  270. package/lib/collection/components/duet-range-slider/duet-range-slider.e2e.js +51 -51
  271. package/lib/collection/components/duet-range-slider/duet-range-slider.js +568 -557
  272. package/lib/collection/components/duet-range-stepper/duet-range-stepper.a11y.e2e.js +5 -5
  273. package/lib/collection/components/duet-range-stepper/duet-range-stepper.e2e.js +46 -46
  274. package/lib/collection/components/duet-range-stepper/duet-range-stepper.js +341 -341
  275. package/lib/collection/components/duet-range-stepper/duet-range-stepper.spec.js +17 -17
  276. package/lib/collection/components/duet-scrollable/duet-scrollable.a11y.e2e.js +5 -5
  277. package/lib/collection/components/duet-scrollable/duet-scrollable.e2e.js +6 -6
  278. package/lib/collection/components/duet-scrollable/duet-scrollable.js +294 -294
  279. package/lib/collection/components/duet-section-layout/duet-section-layout.a11y.e2e.js +5 -5
  280. package/lib/collection/components/duet-section-layout/duet-section-layout.e2e.js +16 -16
  281. package/lib/collection/components/duet-section-layout/duet-section-layout.js +75 -75
  282. package/lib/collection/components/duet-select/duet-select.a11y.e2e.js +10 -10
  283. package/lib/collection/components/duet-select/duet-select.e2e.js +201 -201
  284. package/lib/collection/components/duet-select/duet-select.js +722 -718
  285. package/lib/collection/components/duet-shaped-image/duet-shaped-image.a11y.e2e.js +5 -5
  286. package/lib/collection/components/duet-shaped-image/duet-shaped-image.js +143 -143
  287. package/lib/collection/components/duet-show-more/duet-show-more.a11y.e2e.js +5 -5
  288. package/lib/collection/components/duet-show-more/duet-show-more.js +436 -436
  289. package/lib/collection/components/duet-slideout/duet-slideout.a11y.e2e.js +5 -5
  290. package/lib/collection/components/duet-slideout/duet-slideout.css +4 -10
  291. package/lib/collection/components/duet-slideout/duet-slideout.js +408 -407
  292. package/lib/collection/components/duet-slideout-lang/duet-slideout-lang.js +75 -75
  293. package/lib/collection/components/duet-slideout-link/duet-slideout-link.js +215 -215
  294. package/lib/collection/components/duet-slideout-panel/duet-slideout-panel.js +282 -281
  295. package/lib/collection/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.js +177 -176
  296. package/lib/collection/components/duet-spacer/duet-spacer.a11y.e2e.js +5 -5
  297. package/lib/collection/components/duet-spacer/duet-spacer.e2e.js +21 -21
  298. package/lib/collection/components/duet-spacer/duet-spacer.js +110 -110
  299. package/lib/collection/components/duet-spinner/duet-spinner.a11y.e2e.js +5 -5
  300. package/lib/collection/components/duet-spinner/duet-spinner.e2e.js +23 -23
  301. package/lib/collection/components/duet-spinner/duet-spinner.js +131 -131
  302. package/lib/collection/components/duet-step/duet-step.e2e.js +83 -83
  303. package/lib/collection/components/duet-step/duet-step.js +299 -291
  304. package/lib/collection/components/duet-stepper/duet-stepper.a11y.e2e.js +8 -8
  305. package/lib/collection/components/duet-stepper/duet-stepper.e2e.js +49 -49
  306. package/lib/collection/components/duet-stepper/duet-stepper.js +243 -243
  307. package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.a11y.e2e.js +5 -5
  308. package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.js +218 -217
  309. package/lib/collection/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.js +235 -234
  310. package/lib/collection/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.js +162 -162
  311. package/lib/collection/components/duet-submenu-bar-link/duet-submenu-bar-link.js +154 -154
  312. package/lib/collection/components/duet-tab/duet-tab.e2e.js +10 -10
  313. package/lib/collection/components/duet-tab/duet-tab.js +162 -161
  314. package/lib/collection/components/duet-tab-group/duet-tab-group.a11y.e2e.js +5 -5
  315. package/lib/collection/components/duet-tab-group/duet-tab-group.e2e.js +60 -60
  316. package/lib/collection/components/duet-tab-group/duet-tab-group.js +636 -633
  317. package/lib/collection/components/duet-table/duet-table.a11y.e2e.js +5 -5
  318. package/lib/collection/components/duet-table/duet-table.e2e.js +25 -25
  319. package/lib/collection/components/duet-table/duet-table.js +284 -281
  320. package/lib/collection/components/duet-textarea/duet-textarea.a11y.e2e.js +10 -10
  321. package/lib/collection/components/duet-textarea/duet-textarea.e2e.js +193 -193
  322. package/lib/collection/components/duet-textarea/duet-textarea.js +849 -845
  323. package/lib/collection/components/duet-toggle/duet-toggle.a11y.e2e.js +5 -5
  324. package/lib/collection/components/duet-toggle/duet-toggle.e2e.js +66 -66
  325. package/lib/collection/components/duet-toggle/duet-toggle.js +475 -464
  326. package/lib/collection/components/duet-toolbar/duet-toolbar.a11y.e2e.js +5 -5
  327. package/lib/collection/components/duet-toolbar/duet-toolbar.js +105 -105
  328. package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.js +221 -220
  329. package/lib/collection/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.js +160 -160
  330. package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.js +156 -156
  331. package/lib/collection/components/duet-tooltip/duet-tooltip-button.js +172 -164
  332. package/lib/collection/components/duet-tooltip/duet-tooltip-popup.js +258 -251
  333. package/lib/collection/components/duet-tooltip/duet-tooltip.a11y.e2e.js +14 -14
  334. package/lib/collection/components/duet-tooltip/duet-tooltip.e2e.js +76 -76
  335. package/lib/collection/components/duet-tooltip/duet-tooltip.js +537 -529
  336. package/lib/collection/components/duet-tray/duet-tray.a11y.e2e.js +5 -5
  337. package/lib/collection/components/duet-tray/duet-tray.e2e.js +67 -67
  338. package/lib/collection/components/duet-tray/duet-tray.js +318 -315
  339. package/lib/collection/components/duet-upload/duet-upload.e2e.js +40 -40
  340. package/lib/collection/components/duet-upload/duet-upload.js +2282 -2276
  341. package/lib/collection/components/duet-upload/errorcodes.utils.js +22 -22
  342. package/lib/collection/components/duet-upload/mock.helpers.js +85 -85
  343. package/lib/collection/components/duet-upload/upload-editable-item-error.js +4 -4
  344. package/lib/collection/components/duet-upload/upload-editable-item-success.js +15 -15
  345. package/lib/collection/components/duet-upload/upload-item-category.js +2 -2
  346. package/lib/collection/components/duet-upload/upload-item-header.js +4 -4
  347. package/lib/collection/components/duet-upload/upload-validators.js +96 -96
  348. package/lib/collection/components/duet-upload/upload-validators.spec.js +35 -35
  349. package/lib/collection/components/duet-upload/upload.helpers.js +8 -8
  350. package/lib/collection/components/duet-upload/xhr.helpers.js +26 -26
  351. package/lib/collection/components/duet-upload-aria-status/duet-upload-aria-status.js +194 -194
  352. package/lib/collection/components/duet-upload-item/duet-upload-item.js +306 -306
  353. package/lib/collection/components/duet-visually-hidden/duet-visually-hidden.a11y.e2e.js +5 -5
  354. package/lib/collection/components/duet-visually-hidden/duet-visually-hidden.e2e.js +6 -6
  355. package/lib/collection/components/duet-visually-hidden/duet-visually-hidden.js +20 -20
  356. package/lib/collection/global/duet-global.js +1 -27
  357. package/lib/collection/global/log-wrapper.js +29 -29
  358. package/lib/collection/utils/axe-core-utils.js +24 -24
  359. package/lib/collection/utils/create-id.js +2 -2
  360. package/lib/collection/utils/create-id.spec.js +6 -6
  361. package/lib/collection/utils/fixture-utils.js +25 -25
  362. package/lib/collection/utils/focus-utils.js +7 -7
  363. package/lib/collection/utils/group-by.js +9 -9
  364. package/lib/collection/utils/input-utils.js +25 -25
  365. package/lib/collection/utils/is-internet-explorer.js +2 -2
  366. package/lib/collection/utils/js-utils.js +38 -38
  367. package/lib/collection/utils/js-utils.spec.js +14 -14
  368. package/lib/collection/utils/keyboard-utils.js +43 -12
  369. package/lib/collection/utils/language-utils.js +73 -73
  370. package/lib/collection/utils/language-utils.spec.js +151 -151
  371. package/lib/collection/utils/math.utils.js +59 -59
  372. package/lib/collection/utils/math.utils.spec.js +130 -130
  373. package/lib/collection/utils/picture-utils.js +2 -2
  374. package/lib/collection/utils/string-utils.js +31 -31
  375. package/lib/collection/utils/string-utils.spec.js +32 -32
  376. package/lib/collection/utils/teleport.js +77 -77
  377. package/lib/collection/utils/template-utils.js +18 -18
  378. package/lib/collection/utils/template-utils.spec.js +33 -33
  379. package/lib/collection/utils/test-utils.js +31 -31
  380. package/lib/collection/utils/token-utils.js +96 -96
  381. package/lib/collection/utils/token-utils.spec.js +170 -170
  382. package/lib/collection/utils/watch-options.js +44 -44
  383. package/lib/dist-custom-elements/duet-action-button.d.ts +2 -2
  384. package/lib/dist-custom-elements/duet-action-button.js +1 -1
  385. package/lib/dist-custom-elements/duet-alert.d.ts +2 -2
  386. package/lib/dist-custom-elements/duet-alert.js +1 -1
  387. package/lib/dist-custom-elements/duet-badge.d.ts +2 -2
  388. package/lib/dist-custom-elements/duet-badge.js +1 -1
  389. package/lib/dist-custom-elements/duet-banner.d.ts +2 -2
  390. package/lib/dist-custom-elements/duet-banner.js +96 -96
  391. package/lib/dist-custom-elements/duet-breadcrumb.d.ts +2 -2
  392. package/lib/dist-custom-elements/duet-breadcrumb.js +82 -66
  393. package/lib/dist-custom-elements/duet-breadcrumbs.d.ts +2 -2
  394. package/lib/dist-custom-elements/duet-breadcrumbs.js +68 -68
  395. package/lib/dist-custom-elements/duet-button.d.ts +2 -2
  396. package/lib/dist-custom-elements/duet-button.js +1 -1
  397. package/lib/dist-custom-elements/duet-callout.d.ts +2 -2
  398. package/lib/dist-custom-elements/duet-callout.js +57 -57
  399. package/lib/dist-custom-elements/duet-caption.d.ts +2 -2
  400. package/lib/dist-custom-elements/duet-caption.js +1 -1
  401. package/lib/dist-custom-elements/duet-card.d.ts +2 -2
  402. package/lib/dist-custom-elements/duet-card.js +144 -138
  403. package/lib/dist-custom-elements/duet-checkbox.d.ts +2 -2
  404. package/lib/dist-custom-elements/duet-checkbox.js +1 -1
  405. package/lib/dist-custom-elements/duet-checkmark.d.ts +2 -2
  406. package/lib/dist-custom-elements/duet-checkmark.js +1 -1
  407. package/lib/dist-custom-elements/duet-chip.d.ts +2 -2
  408. package/lib/dist-custom-elements/duet-chip.js +226 -219
  409. package/lib/dist-custom-elements/duet-choice-group.d.ts +2 -2
  410. package/lib/dist-custom-elements/duet-choice-group.js +189 -189
  411. package/lib/dist-custom-elements/duet-choice.d.ts +2 -2
  412. package/lib/dist-custom-elements/duet-choice.js +360 -358
  413. package/lib/dist-custom-elements/duet-collapsible.d.ts +2 -2
  414. package/lib/dist-custom-elements/duet-collapsible.js +137 -131
  415. package/lib/dist-custom-elements/duet-combobox.d.ts +2 -2
  416. package/lib/dist-custom-elements/duet-combobox.js +406 -406
  417. package/lib/dist-custom-elements/duet-contact-card.d.ts +2 -2
  418. package/lib/dist-custom-elements/duet-contact-card.js +116 -116
  419. package/lib/dist-custom-elements/duet-cookie-consent.d.ts +2 -2
  420. package/lib/dist-custom-elements/duet-cookie-consent.js +89 -82
  421. package/lib/dist-custom-elements/duet-date-picker.d.ts +2 -2
  422. package/lib/dist-custom-elements/duet-date-picker.js +728 -728
  423. package/lib/dist-custom-elements/duet-divider.d.ts +2 -2
  424. package/lib/dist-custom-elements/duet-divider.js +1 -1
  425. package/lib/dist-custom-elements/duet-editable-table.d.ts +2 -2
  426. package/lib/dist-custom-elements/duet-editable-table.js +231 -231
  427. package/lib/dist-custom-elements/duet-empty-state.d.ts +2 -2
  428. package/lib/dist-custom-elements/duet-empty-state.js +1 -1
  429. package/lib/dist-custom-elements/duet-fieldset.d.ts +2 -2
  430. package/lib/dist-custom-elements/duet-fieldset.js +1 -1
  431. package/lib/dist-custom-elements/duet-file-chooser.d.ts +2 -2
  432. package/lib/dist-custom-elements/duet-file-chooser.js +70 -70
  433. package/lib/dist-custom-elements/duet-footer.d.ts +2 -2
  434. package/lib/dist-custom-elements/duet-footer.js +170 -167
  435. package/lib/dist-custom-elements/duet-grid-item.d.ts +2 -2
  436. package/lib/dist-custom-elements/duet-grid-item.js +1 -1
  437. package/lib/dist-custom-elements/duet-grid.d.ts +2 -2
  438. package/lib/dist-custom-elements/duet-grid.js +1 -1
  439. package/lib/dist-custom-elements/duet-header.d.ts +2 -2
  440. package/lib/dist-custom-elements/duet-header.js +640 -638
  441. package/lib/dist-custom-elements/duet-heading.d.ts +2 -2
  442. package/lib/dist-custom-elements/duet-heading.js +1 -1
  443. package/lib/dist-custom-elements/duet-hero.d.ts +2 -2
  444. package/lib/dist-custom-elements/duet-hero.js +270 -270
  445. package/lib/dist-custom-elements/duet-icon.d.ts +2 -2
  446. package/lib/dist-custom-elements/duet-icon.js +1 -1
  447. package/lib/dist-custom-elements/duet-input.d.ts +2 -2
  448. package/lib/dist-custom-elements/duet-input.js +1 -1
  449. package/lib/dist-custom-elements/duet-label.d.ts +2 -2
  450. package/lib/dist-custom-elements/duet-label.js +1 -1
  451. package/lib/dist-custom-elements/duet-layout.d.ts +2 -2
  452. package/lib/dist-custom-elements/duet-layout.js +73 -73
  453. package/lib/dist-custom-elements/duet-link.d.ts +2 -2
  454. package/lib/dist-custom-elements/duet-link.js +1 -1
  455. package/lib/dist-custom-elements/duet-list-item.d.ts +2 -2
  456. package/lib/dist-custom-elements/duet-list-item.js +1 -1
  457. package/lib/dist-custom-elements/duet-list.d.ts +2 -2
  458. package/lib/dist-custom-elements/duet-list.js +1 -1
  459. package/lib/dist-custom-elements/duet-logo.d.ts +2 -2
  460. package/lib/dist-custom-elements/duet-logo.js +1 -1
  461. package/lib/dist-custom-elements/duet-menu-bar-button.d.ts +2 -2
  462. package/lib/dist-custom-elements/duet-menu-bar-button.js +106 -106
  463. package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.d.ts +2 -2
  464. package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.js +70 -70
  465. package/lib/dist-custom-elements/duet-menu-bar-dropdown.d.ts +2 -2
  466. package/lib/dist-custom-elements/duet-menu-bar-dropdown.js +121 -121
  467. package/lib/dist-custom-elements/duet-menu-bar-link.d.ts +2 -2
  468. package/lib/dist-custom-elements/duet-menu-bar-link.js +85 -85
  469. package/lib/dist-custom-elements/duet-menu-bar.d.ts +2 -2
  470. package/lib/dist-custom-elements/duet-menu-bar.js +145 -145
  471. package/lib/dist-custom-elements/duet-modal.d.ts +2 -2
  472. package/lib/dist-custom-elements/duet-modal.js +263 -263
  473. package/lib/dist-custom-elements/duet-multiselect.d.ts +2 -2
  474. package/lib/dist-custom-elements/duet-multiselect.js +300 -300
  475. package/lib/dist-custom-elements/duet-nav.d.ts +2 -2
  476. package/lib/dist-custom-elements/duet-nav.js +36 -36
  477. package/lib/dist-custom-elements/duet-notification-drawer.d.ts +2 -2
  478. package/lib/dist-custom-elements/duet-notification-drawer.js +145 -142
  479. package/lib/dist-custom-elements/duet-notification.d.ts +2 -2
  480. package/lib/dist-custom-elements/duet-notification.js +79 -76
  481. package/lib/dist-custom-elements/duet-number-input.d.ts +2 -2
  482. package/lib/dist-custom-elements/duet-number-input.js +451 -449
  483. package/lib/dist-custom-elements/duet-page-heading.d.ts +2 -2
  484. package/lib/dist-custom-elements/duet-page-heading.js +50 -50
  485. package/lib/dist-custom-elements/duet-pagination.d.ts +2 -2
  486. package/lib/dist-custom-elements/duet-pagination.js +450 -450
  487. package/lib/dist-custom-elements/duet-paragraph.d.ts +2 -2
  488. package/lib/dist-custom-elements/duet-paragraph.js +1 -1
  489. package/lib/dist-custom-elements/duet-popup-menu-item.d.ts +2 -2
  490. package/lib/dist-custom-elements/duet-popup-menu-item.js +95 -95
  491. package/lib/dist-custom-elements/duet-popup-menu.d.ts +2 -2
  492. package/lib/dist-custom-elements/duet-popup-menu.js +177 -177
  493. package/lib/dist-custom-elements/duet-progress.d.ts +2 -2
  494. package/lib/dist-custom-elements/duet-progress.js +1 -1
  495. package/lib/dist-custom-elements/duet-promo-card.d.ts +2 -2
  496. package/lib/dist-custom-elements/duet-promo-card.js +74 -74
  497. package/lib/dist-custom-elements/duet-radio-group.d.ts +2 -2
  498. package/lib/dist-custom-elements/duet-radio-group.js +183 -183
  499. package/lib/dist-custom-elements/duet-radio.d.ts +2 -2
  500. package/lib/dist-custom-elements/duet-radio.js +130 -130
  501. package/lib/dist-custom-elements/duet-range-slider.d.ts +2 -2
  502. package/lib/dist-custom-elements/duet-range-slider.js +153 -146
  503. package/lib/dist-custom-elements/duet-range-stepper.d.ts +2 -2
  504. package/lib/dist-custom-elements/duet-range-stepper.js +207 -207
  505. package/lib/dist-custom-elements/duet-scrollable.d.ts +2 -2
  506. package/lib/dist-custom-elements/duet-scrollable.js +1 -1
  507. package/lib/dist-custom-elements/duet-section-layout.d.ts +2 -2
  508. package/lib/dist-custom-elements/duet-section-layout.js +38 -38
  509. package/lib/dist-custom-elements/duet-select.d.ts +2 -2
  510. package/lib/dist-custom-elements/duet-select.js +1 -1
  511. package/lib/dist-custom-elements/duet-shaped-image.d.ts +2 -2
  512. package/lib/dist-custom-elements/duet-shaped-image.js +48 -48
  513. package/lib/dist-custom-elements/duet-show-more.d.ts +2 -2
  514. package/lib/dist-custom-elements/duet-show-more.js +152 -152
  515. package/lib/dist-custom-elements/duet-slideout-lang.d.ts +2 -2
  516. package/lib/dist-custom-elements/duet-slideout-lang.js +58 -58
  517. package/lib/dist-custom-elements/duet-slideout-link.d.ts +2 -2
  518. package/lib/dist-custom-elements/duet-slideout-link.js +63 -63
  519. package/lib/dist-custom-elements/duet-slideout-panel-dropdown.d.ts +2 -2
  520. package/lib/dist-custom-elements/duet-slideout-panel-dropdown.js +76 -76
  521. package/lib/dist-custom-elements/duet-slideout-panel.d.ts +2 -2
  522. package/lib/dist-custom-elements/duet-slideout-panel.js +149 -149
  523. package/lib/dist-custom-elements/duet-slideout.d.ts +2 -2
  524. package/lib/dist-custom-elements/duet-slideout.js +227 -227
  525. package/lib/dist-custom-elements/duet-spacer.d.ts +2 -2
  526. package/lib/dist-custom-elements/duet-spacer.js +1 -1
  527. package/lib/dist-custom-elements/duet-spinner.d.ts +2 -2
  528. package/lib/dist-custom-elements/duet-spinner.js +1 -1
  529. package/lib/dist-custom-elements/duet-step.d.ts +2 -2
  530. package/lib/dist-custom-elements/duet-step.js +123 -119
  531. package/lib/dist-custom-elements/duet-stepper.d.ts +2 -2
  532. package/lib/dist-custom-elements/duet-stepper.js +129 -129
  533. package/lib/dist-custom-elements/duet-submenu-bar-dropdown-link.d.ts +2 -2
  534. package/lib/dist-custom-elements/duet-submenu-bar-dropdown-link.js +64 -64
  535. package/lib/dist-custom-elements/duet-submenu-bar-dropdown.d.ts +2 -2
  536. package/lib/dist-custom-elements/duet-submenu-bar-dropdown.js +132 -132
  537. package/lib/dist-custom-elements/duet-submenu-bar-link.d.ts +2 -2
  538. package/lib/dist-custom-elements/duet-submenu-bar-link.js +86 -86
  539. package/lib/dist-custom-elements/duet-submenu-bar.d.ts +2 -2
  540. package/lib/dist-custom-elements/duet-submenu-bar.js +139 -139
  541. package/lib/dist-custom-elements/duet-tab-group.d.ts +2 -2
  542. package/lib/dist-custom-elements/duet-tab-group.js +312 -310
  543. package/lib/dist-custom-elements/duet-tab.d.ts +2 -2
  544. package/lib/dist-custom-elements/duet-tab.js +50 -52
  545. package/lib/dist-custom-elements/duet-table.d.ts +2 -2
  546. package/lib/dist-custom-elements/duet-table.js +1 -1
  547. package/lib/dist-custom-elements/duet-textarea.d.ts +2 -2
  548. package/lib/dist-custom-elements/duet-textarea.js +262 -262
  549. package/lib/dist-custom-elements/duet-toggle.d.ts +2 -2
  550. package/lib/dist-custom-elements/duet-toggle.js +120 -113
  551. package/lib/dist-custom-elements/duet-toolbar-dropdown-link.d.ts +2 -2
  552. package/lib/dist-custom-elements/duet-toolbar-dropdown-link.js +63 -63
  553. package/lib/dist-custom-elements/duet-toolbar-dropdown.d.ts +2 -2
  554. package/lib/dist-custom-elements/duet-toolbar-dropdown.js +88 -88
  555. package/lib/dist-custom-elements/duet-toolbar-link.d.ts +2 -2
  556. package/lib/dist-custom-elements/duet-toolbar-link.js +58 -58
  557. package/lib/dist-custom-elements/duet-toolbar.d.ts +2 -2
  558. package/lib/dist-custom-elements/duet-toolbar.js +52 -52
  559. package/lib/dist-custom-elements/duet-tooltip-button.d.ts +2 -2
  560. package/lib/dist-custom-elements/duet-tooltip-button.js +1 -1
  561. package/lib/dist-custom-elements/duet-tooltip-popup.d.ts +2 -2
  562. package/lib/dist-custom-elements/duet-tooltip-popup.js +1 -1
  563. package/lib/dist-custom-elements/duet-tooltip.d.ts +2 -2
  564. package/lib/dist-custom-elements/duet-tooltip.js +1 -1
  565. package/lib/dist-custom-elements/duet-tray.d.ts +2 -2
  566. package/lib/dist-custom-elements/duet-tray.js +122 -119
  567. package/lib/dist-custom-elements/duet-upload-aria-status.d.ts +2 -2
  568. package/lib/dist-custom-elements/duet-upload-aria-status.js +1 -1
  569. package/lib/dist-custom-elements/duet-upload-item.d.ts +2 -2
  570. package/lib/dist-custom-elements/duet-upload-item.js +1 -1
  571. package/lib/dist-custom-elements/duet-upload.d.ts +2 -2
  572. package/lib/dist-custom-elements/duet-upload.js +1163 -1163
  573. package/lib/dist-custom-elements/duet-visually-hidden.d.ts +2 -2
  574. package/lib/dist-custom-elements/duet-visually-hidden.js +1 -1
  575. package/lib/dist-custom-elements/index.js +15 -41
  576. package/lib/dist-custom-elements/{p-7247d0b2.js → p-04a295c6.js} +65 -43
  577. package/lib/dist-custom-elements/p-064f1578.js +273 -0
  578. package/lib/dist-custom-elements/{p-e4355989.js → p-0b123cad.js} +95 -88
  579. package/lib/dist-custom-elements/p-0e052642.js +55 -0
  580. package/lib/dist-custom-elements/p-0f8e290f.js +226 -0
  581. package/lib/dist-custom-elements/{p-d0987122.js → p-10a15ea1.js} +48 -48
  582. package/lib/{esm/slot-query-7877f18f.js → dist-custom-elements/p-11230037.js} +1 -1
  583. package/lib/dist-custom-elements/{p-2b1a35cd.js → p-1224c98d.js} +278 -278
  584. package/lib/dist-custom-elements/p-1b2fea2b.js +59 -0
  585. package/lib/dist-custom-elements/p-1e4ca38f.js +126 -0
  586. package/lib/dist-custom-elements/{p-bcfb9e03.js → p-24ae0332.js} +50 -50
  587. package/lib/dist-custom-elements/p-2613ae6a.js +265 -0
  588. package/lib/dist-custom-elements/{p-4883df66.js → p-2e36d5bf.js} +74 -74
  589. package/lib/dist-custom-elements/p-435c14fe.js +60 -0
  590. package/lib/dist-custom-elements/p-4391eb0d.js +110 -0
  591. package/lib/dist-custom-elements/p-43b89e38.js +9 -0
  592. package/lib/dist-custom-elements/p-47247d7e.js +465 -0
  593. package/lib/dist-custom-elements/{p-ba870310.js → p-490933fd.js} +47 -47
  594. package/lib/dist-custom-elements/{p-274d11e3.js → p-4ab776f4.js} +6 -6
  595. package/lib/dist-custom-elements/p-5788a98f.js +123 -0
  596. package/lib/dist-custom-elements/p-57a1cba9.js +117 -0
  597. package/lib/dist-custom-elements/p-5e1cd480.js +79 -0
  598. package/lib/dist-custom-elements/p-5e59e970.js +11 -0
  599. package/lib/dist-custom-elements/{p-9dd26401.js → p-618174a5.js} +128 -128
  600. package/lib/dist-custom-elements/{p-6c2e13f0.js → p-6222a43f.js} +56 -56
  601. package/lib/dist-custom-elements/{p-52014bb2.js → p-63ec7678.js} +37 -37
  602. package/lib/dist-custom-elements/{p-180c0d2d.js → p-65d472d7.js} +174 -174
  603. package/lib/dist-custom-elements/p-68bd36c7.js +38 -0
  604. package/lib/dist-custom-elements/p-76e8ab22.js +98 -0
  605. package/lib/dist-custom-elements/p-7d8a2628.js +57 -0
  606. package/lib/dist-custom-elements/p-8b89622f.js +177 -0
  607. package/lib/dist-custom-elements/p-8e357cfb.js +137 -0
  608. package/lib/dist-custom-elements/p-8f253845.js +51 -0
  609. package/lib/dist-custom-elements/{p-d49389d2.js → p-916e66c9.js} +171 -171
  610. package/lib/dist-custom-elements/p-994556c0.js +151 -0
  611. package/lib/dist-custom-elements/{p-3d8d557b.js → p-9e371678.js} +27 -27
  612. package/lib/dist-custom-elements/p-a58bd561.js +13 -0
  613. package/lib/dist-custom-elements/{p-c0af301d.js → p-adef0aaa.js} +64 -64
  614. package/lib/dist-custom-elements/p-b2e550a3.js +97 -0
  615. package/lib/dist-custom-elements/p-ba28f5ce.js +205 -0
  616. package/lib/dist-custom-elements/{p-21b815ae.js → p-beb5db77.js} +42 -42
  617. package/lib/dist-custom-elements/p-d0e52a83.js +76 -0
  618. package/lib/dist-custom-elements/p-df7874f9.js +53 -0
  619. package/lib/dist-custom-elements/{p-3ccd454b.js → p-e034dfea.js} +43 -43
  620. package/lib/dist-custom-elements/p-e929268c.js +62 -0
  621. package/lib/dist-custom-elements/p-eef66341.js +18 -0
  622. package/lib/dist-custom-elements/p-fc1fa737.js +206 -0
  623. package/lib/dist-custom-elements/p-ff591309.js +93 -0
  624. package/lib/duet/duet.esm.js +1 -1
  625. package/lib/duet/duet.js +15 -15
  626. package/lib/duet/{p-bfeeee67.system.entry.js → p-00da8ac7.system.entry.js} +2 -2
  627. package/lib/duet/{p-0c702d36.entry.js → p-023ee57b.entry.js} +1 -1
  628. package/lib/duet/{p-39078c27.system.entry.js → p-02f49953.system.entry.js} +2 -2
  629. package/lib/duet/{p-0558a17e.system.entry.js → p-060a790b.system.entry.js} +1 -1
  630. package/lib/duet/{p-80013513.system.entry.js → p-07ce89ff.system.entry.js} +1 -1
  631. package/lib/duet/{p-301ddafe.entry.js → p-07f5193f.entry.js} +1 -1
  632. package/lib/duet/{p-c801ebee.entry.js → p-094eedb8.entry.js} +1 -1
  633. package/lib/duet/{p-ac367891.entry.js → p-0981fdb2.entry.js} +1 -1
  634. package/lib/duet/{p-051488a0.system.entry.js → p-0a5966c8.system.entry.js} +1 -1
  635. package/lib/duet/p-0b16d4ca.system.entry.js +4 -0
  636. package/lib/duet/{p-445523a8.entry.js → p-0f162710.entry.js} +1 -1
  637. package/lib/duet/{p-6da4db52.system.entry.js → p-0f3f2906.system.entry.js} +1 -1
  638. package/lib/duet/{p-c4e79927.entry.js → p-11653c1e.entry.js} +1 -1
  639. package/lib/duet/p-1276c914.js +5 -0
  640. package/lib/duet/{p-59b9c68b.entry.js → p-16203527.entry.js} +1 -1
  641. package/lib/duet/{p-57afa4b8.system.entry.js → p-1753cb05.system.entry.js} +2 -2
  642. package/lib/duet/{p-032a613f.system.entry.js → p-176fa0e5.system.entry.js} +1 -1
  643. package/lib/duet/{p-e4aa049f.system.entry.js → p-1a44a9e5.system.entry.js} +1 -1
  644. package/lib/duet/p-1bd21f27.entry.js +4 -0
  645. package/lib/duet/{p-e90b5865.system.entry.js → p-1d772039.system.entry.js} +1 -1
  646. package/lib/duet/{p-0606cea3.entry.js → p-218eba4d.entry.js} +1 -1
  647. package/lib/duet/{p-8972381a.system.js → p-224f6c46.system.js} +1 -1
  648. package/lib/duet/{p-8eff5e91.system.entry.js → p-23eaa3b4.system.entry.js} +2 -2
  649. package/lib/duet/{p-a91c8a42.system.entry.js → p-24423276.system.entry.js} +1 -1
  650. package/lib/duet/{p-0d0101d9.system.entry.js → p-245dedef.system.entry.js} +1 -1
  651. package/lib/duet/{p-58a08a7b.system.entry.js → p-24f96782.system.entry.js} +1 -1
  652. package/lib/duet/p-259a297a.system.js +4 -0
  653. package/lib/duet/{p-1dadf501.entry.js → p-25c78304.entry.js} +1 -1
  654. package/lib/duet/p-26332d59.system.entry.js +4 -0
  655. package/lib/duet/{p-3639371a.system.entry.js → p-26de4395.system.entry.js} +1 -1
  656. package/lib/duet/{p-cef36d14.system.entry.js → p-27560f1b.system.entry.js} +1 -1
  657. package/lib/duet/{p-716329a7.system.entry.js → p-27c6aebd.system.entry.js} +1 -1
  658. package/lib/duet/{p-1a877bd1.system.entry.js → p-27d40494.system.entry.js} +1 -1
  659. package/lib/duet/p-2877f5d2.system.entry.js +4 -0
  660. package/lib/duet/p-2bb2b022.js +4 -0
  661. package/lib/duet/{p-95df823b.entry.js → p-2c67f7a8.entry.js} +1 -1
  662. package/lib/duet/p-2ddd31db.entry.js +4 -0
  663. package/lib/duet/{p-4883df66.js → p-2e36d5bf.js} +1 -1
  664. package/lib/duet/{p-ed961bc6.system.entry.js → p-2efce50b.system.entry.js} +1 -1
  665. package/lib/duet/{p-05e3a2cc.entry.js → p-3009021d.entry.js} +1 -1
  666. package/lib/duet/{p-4f770f51.system.entry.js → p-309546c3.system.entry.js} +1 -1
  667. package/lib/duet/p-3126ade6.entry.js +4 -0
  668. package/lib/duet/{p-089043d5.entry.js → p-31c8c180.entry.js} +1 -1
  669. package/lib/duet/{p-da9fe13c.system.entry.js → p-32aed830.system.entry.js} +1 -1
  670. package/lib/duet/{p-def3df7d.entry.js → p-3640cb93.entry.js} +1 -1
  671. package/lib/duet/{p-6f3f2e66.entry.js → p-3772cde9.entry.js} +1 -1
  672. package/lib/duet/p-37811477.system.entry.js +4 -0
  673. package/lib/duet/{p-e7a22d84.system.entry.js → p-37d0ea90.system.entry.js} +1 -1
  674. package/lib/duet/{p-50f4319b.system.entry.js → p-380ee907.system.entry.js} +1 -1
  675. package/lib/duet/{p-8aa7771f.entry.js → p-3aa3de10.entry.js} +1 -1
  676. package/lib/duet/{p-e6168195.entry.js → p-3efd29e1.entry.js} +1 -1
  677. package/lib/duet/{p-3fd4c411.entry.js → p-4196e4ba.entry.js} +1 -1
  678. package/lib/duet/p-43249fcf.system.entry.js +4 -0
  679. package/lib/duet/p-461d8a0b.entry.js +4 -0
  680. package/lib/duet/{p-b0ab2ead.system.entry.js → p-461fd4d8.system.entry.js} +1 -1
  681. package/lib/duet/{p-566668e1.entry.js → p-46cacf4b.entry.js} +1 -1
  682. package/lib/duet/p-470f5db7.entry.js +4 -0
  683. package/lib/duet/{p-f75a1805.system.entry.js → p-482cb8b5.system.entry.js} +1 -1
  684. package/lib/duet/{p-d4d7d607.system.entry.js → p-4d081cf5.system.entry.js} +1 -1
  685. package/lib/duet/{p-d02b92fa.entry.js → p-4da0332f.entry.js} +1 -1
  686. package/lib/duet/p-4dc4f2de.system.entry.js +4 -0
  687. package/lib/duet/{p-8bf363f4.system.entry.js → p-50108ac2.system.entry.js} +1 -1
  688. package/lib/duet/{p-9e2a2cf7.entry.js → p-507f463e.entry.js} +1 -1
  689. package/lib/duet/{p-79faf440.system.entry.js → p-52471579.system.entry.js} +1 -1
  690. package/lib/duet/p-530dd0b2.entry.js +4 -0
  691. package/lib/duet/p-538a7c32.system.entry.js +4 -0
  692. package/lib/duet/{p-3b0969dc.entry.js → p-548b740e.entry.js} +1 -1
  693. package/lib/duet/{p-a8878fd3.entry.js → p-55fbe6bc.entry.js} +1 -1
  694. package/lib/duet/p-5795b0d9.system.js +4 -0
  695. package/lib/duet/p-57f6f292.system.entry.js +4 -0
  696. package/lib/duet/p-582f1599.system.entry.js +4 -0
  697. package/lib/duet/{p-07401f31.entry.js → p-5aaf2889.entry.js} +1 -1
  698. package/lib/duet/{p-80d1a5d3.entry.js → p-5bab6421.entry.js} +1 -1
  699. package/lib/duet/{p-56bdad28.system.entry.js → p-5bb41296.system.entry.js} +1 -1
  700. package/lib/duet/{p-afd00506.entry.js → p-5be3bb6e.entry.js} +1 -1
  701. package/lib/duet/{p-d5a9cfac.entry.js → p-5e777157.entry.js} +1 -1
  702. package/lib/duet/p-5ef65fd9.entry.js +4 -0
  703. package/lib/duet/p-609aaedd.entry.js +4 -0
  704. package/lib/duet/{p-faa6ea94.system.entry.js → p-6399c03a.system.entry.js} +1 -1
  705. package/lib/duet/{p-b8db6e02.system.entry.js → p-63bdc921.system.entry.js} +1 -1
  706. package/lib/duet/p-644b687c.system.entry.js +4 -0
  707. package/lib/duet/p-68625c53.system.entry.js +4 -0
  708. package/lib/duet/{p-5c0de81a.system.entry.js → p-693ebab3.system.entry.js} +1 -1
  709. package/lib/duet/p-6a4fa614.entry.js +4 -0
  710. package/lib/duet/{p-30bd8807.entry.js → p-6b4c9fe2.entry.js} +1 -1
  711. package/lib/duet/p-6d839458.js +4 -0
  712. package/lib/duet/{p-2b70d58a.system.entry.js → p-7206856c.system.entry.js} +1 -1
  713. package/lib/duet/p-737f4f78.entry.js +4 -0
  714. package/lib/duet/p-75655f00.entry.js +4 -0
  715. package/lib/duet/{p-d02e3fe0.system.entry.js → p-77216458.system.entry.js} +1 -1
  716. package/lib/duet/{p-7a46b4ef.system.entry.js → p-773d5541.system.entry.js} +1 -1
  717. package/lib/duet/p-785b629e.entry.js +4 -0
  718. package/lib/duet/{p-98d01f1c.system.entry.js → p-78e18f90.system.entry.js} +1 -1
  719. package/lib/duet/{p-ff7a57a9.entry.js → p-7c3de686.entry.js} +1 -1
  720. package/lib/duet/{p-13915ce0.entry.js → p-7f2e3a82.entry.js} +1 -1
  721. package/lib/duet/{p-ed011021.system.entry.js → p-82b6d775.system.entry.js} +1 -1
  722. package/lib/duet/p-868deb49.entry.js +4 -0
  723. package/lib/duet/p-8693a1f3.entry.js +4 -0
  724. package/lib/duet/{p-c23bf76f.system.entry.js → p-87421fc1.system.entry.js} +1 -1
  725. package/lib/duet/p-89f7e363.system.entry.js +4 -0
  726. package/lib/duet/p-8bb9591d.system.js +4 -0
  727. package/lib/duet/{p-ded28a6e.system.entry.js → p-917d8b40.system.entry.js} +1 -1
  728. package/lib/duet/{p-ed8f7cac.entry.js → p-92d45100.entry.js} +1 -1
  729. package/lib/duet/p-93fd3aa5.system.entry.js +4 -0
  730. package/lib/duet/{p-6da7b933.entry.js → p-95f33440.entry.js} +1 -1
  731. package/lib/duet/{p-a0ecfa13.system.entry.js → p-9865ef30.system.entry.js} +1 -1
  732. package/lib/duet/p-9b877798.system.entry.js +4 -0
  733. package/lib/duet/{p-9cba7f04.system.entry.js → p-9ce2bf89.system.entry.js} +1 -1
  734. package/lib/duet/{p-fd1fb3f9.system.entry.js → p-9d6c89df.system.entry.js} +1 -1
  735. package/lib/duet/{p-77b43a95.entry.js → p-9f19cdc2.entry.js} +1 -1
  736. package/lib/duet/p-9fc19072.entry.js +4 -0
  737. package/lib/duet/{p-b46fa994.system.entry.js → p-a2a3b572.system.entry.js} +2 -2
  738. package/lib/duet/{p-ee796d5e.system.entry.js → p-a57b06db.system.entry.js} +1 -1
  739. package/lib/duet/p-a5f0d126.entry.js +4 -0
  740. package/lib/duet/{p-96f66e14.system.entry.js → p-a69a6b39.system.entry.js} +1 -1
  741. package/lib/duet/p-a931d71d.entry.js +4 -0
  742. package/lib/duet/{p-6205bcb4.entry.js → p-ab4e6587.entry.js} +1 -1
  743. package/lib/duet/{p-8ba72fa0.system.entry.js → p-abe0caff.system.entry.js} +1 -1
  744. package/lib/duet/{p-e3ffb537.system.entry.js → p-ac0a0c5f.system.entry.js} +1 -1
  745. package/lib/duet/{p-ccef6554.system.entry.js → p-b294d764.system.entry.js} +1 -1
  746. package/lib/duet/{p-c08928e1.system.entry.js → p-b32624a6.system.entry.js} +1 -1
  747. package/lib/duet/{p-e9be64de.system.entry.js → p-ba95cf16.system.entry.js} +1 -1
  748. package/lib/duet/{p-4630d3cb.entry.js → p-ba993fed.entry.js} +1 -1
  749. package/lib/duet/p-bb05780d.entry.js +4 -0
  750. package/lib/duet/{p-37af6296.system.entry.js → p-bca48b8e.system.entry.js} +1 -1
  751. package/lib/duet/p-bcee8104.entry.js +4 -0
  752. package/lib/duet/{p-c79a0641.entry.js → p-bd2b785a.entry.js} +1 -1
  753. package/lib/duet/p-bec206f3.entry.js +4 -0
  754. package/lib/duet/{p-501f62eb.system.entry.js → p-befd7146.system.entry.js} +1 -1
  755. package/lib/duet/{p-4aa91f55.entry.js → p-c13fcc8d.entry.js} +1 -1
  756. package/lib/duet/{p-0f1ec9c0.entry.js → p-c172f523.entry.js} +1 -1
  757. package/lib/duet/{p-e1d3c21e.entry.js → p-c17932bc.entry.js} +1 -1
  758. package/lib/duet/p-c23ab199.entry.js +4 -0
  759. package/lib/duet/{p-c5725fee.system.entry.js → p-c6296393.system.entry.js} +1 -1
  760. package/lib/duet/{p-35990684.entry.js → p-c71634ee.entry.js} +1 -1
  761. package/lib/duet/{p-33765ffd.entry.js → p-ca5dfafc.entry.js} +1 -1
  762. package/lib/duet/{p-68f3526e.entry.js → p-cab7ff29.entry.js} +1 -1
  763. package/lib/duet/{p-efdbddb5.system.js → p-cbfdaac4.system.js} +1 -1
  764. package/lib/duet/{p-113d90cb.system.entry.js → p-d0270ec7.system.entry.js} +1 -1
  765. package/lib/duet/p-d1ef0249.system.entry.js +4 -0
  766. package/lib/duet/{p-bdc59646.entry.js → p-d23f7bd1.entry.js} +1 -1
  767. package/lib/duet/p-d328922e.entry.js +4 -0
  768. package/lib/duet/p-d5271b57.entry.js +4 -0
  769. package/lib/duet/{p-1b3fde48.entry.js → p-d5c70827.entry.js} +1 -1
  770. package/lib/duet/{p-89b82e5a.entry.js → p-d832be12.entry.js} +1 -1
  771. package/lib/duet/{p-7671b7b7.system.js → p-da20db91.system.js} +1 -1
  772. package/lib/duet/p-db4ca364.js +4 -0
  773. package/lib/duet/p-db7ec3f2.system.entry.js +4 -0
  774. package/lib/duet/{p-604175d2.entry.js → p-dba55421.entry.js} +1 -1
  775. package/lib/duet/{p-a7e7c277.system.entry.js → p-de9c3476.system.entry.js} +1 -1
  776. package/lib/duet/p-df073faa.entry.js +4 -0
  777. package/lib/duet/p-df5f7376.entry.js +4 -0
  778. package/lib/duet/{p-dc63462c.entry.js → p-e3ba4d89.entry.js} +1 -1
  779. package/lib/duet/{p-64b323bf.entry.js → p-ef4a09e9.entry.js} +1 -1
  780. package/lib/duet/p-ef66a3c3.system.entry.js +4 -0
  781. package/lib/duet/p-f18c2892.system.js +5 -0
  782. package/lib/duet/{p-8855bd51.entry.js → p-f19b59f8.entry.js} +1 -1
  783. package/lib/duet/p-f1f5dfa4.system.entry.js +4 -0
  784. package/lib/duet/{p-fab7c1ed.entry.js → p-f20d29b8.entry.js} +1 -1
  785. package/lib/duet/{p-c3289020.system.entry.js → p-f2b556d7.system.entry.js} +1 -1
  786. package/lib/duet/p-f3efe8c2.system.entry.js +4 -0
  787. package/lib/duet/p-fabb616b.js +4 -0
  788. package/lib/duet/{p-1e9f1c45.entry.js → p-fb5877c4.entry.js} +1 -1
  789. package/lib/duet/p-fc366b12.system.entry.js +4 -0
  790. package/lib/duet/{p-54fbdedf.entry.js → p-fc788a9a.entry.js} +1 -1
  791. package/lib/duet/{p-bf3331ed.entry.js → p-fcfe83b1.entry.js} +1 -1
  792. package/lib/duet/{p-6ae7579a.system.entry.js → p-ffc50558.system.entry.js} +1 -1
  793. package/lib/esm/app-globals-45aa6d20.js +26 -0
  794. package/lib/esm/{common-strings-c0ac5a0b.js → common-strings-59db6973.js} +6 -6
  795. package/lib/esm/create-id-149a1b6d.js +11 -0
  796. package/lib/esm/duet-action-button.entry.js +134 -134
  797. package/lib/esm/duet-alert.entry.js +109 -106
  798. package/lib/esm/duet-badge.entry.js +29 -29
  799. package/lib/esm/duet-banner.entry.js +52 -52
  800. package/lib/esm/duet-breadcrumb.entry.js +50 -41
  801. package/lib/esm/duet-breadcrumbs.entry.js +51 -51
  802. package/lib/esm/duet-button_2.entry.js +229 -229
  803. package/lib/esm/duet-callout.entry.js +28 -28
  804. package/lib/esm/duet-caption_4.entry.js +197 -187
  805. package/lib/esm/duet-card.entry.js +100 -94
  806. package/lib/esm/duet-checkbox.entry.js +85 -85
  807. package/lib/esm/duet-checkmark.entry.js +23 -23
  808. package/lib/esm/duet-chip.entry.js +189 -182
  809. package/lib/esm/duet-choice_2.entry.js +395 -393
  810. package/lib/esm/duet-collapsible.entry.js +105 -99
  811. package/lib/esm/duet-combobox.entry.js +363 -363
  812. package/lib/esm/duet-contact-card.entry.js +49 -49
  813. package/lib/esm/duet-cookie-consent.entry.js +42 -35
  814. package/lib/esm/duet-date-picker.entry.js +610 -610
  815. package/lib/esm/duet-divider_2.entry.js +53 -53
  816. package/lib/esm/duet-editable-table_3.entry.js +1248 -1248
  817. package/lib/esm/duet-empty-state.entry.js +26 -26
  818. package/lib/esm/duet-fieldset.entry.js +50 -50
  819. package/lib/esm/duet-file-chooser.entry.js +44 -44
  820. package/lib/esm/duet-footer.entry.js +121 -118
  821. package/lib/esm/duet-grid_2.entry.js +185 -185
  822. package/lib/esm/duet-header_2.entry.js +613 -611
  823. package/lib/esm/duet-hero.entry.js +172 -172
  824. package/lib/esm/duet-icon.entry.js +141 -141
  825. package/lib/esm/duet-input_2.entry.js +347 -347
  826. package/lib/esm/duet-layout.entry.js +51 -51
  827. package/lib/esm/duet-list_2.entry.js +99 -99
  828. package/lib/esm/duet-menu-bar-button.entry.js +70 -70
  829. package/lib/esm/duet-menu-bar-dropdown-link.entry.js +45 -45
  830. package/lib/esm/duet-menu-bar-dropdown.entry.js +94 -94
  831. package/lib/esm/duet-menu-bar-link.entry.js +58 -58
  832. package/lib/esm/duet-menu-bar.entry.js +116 -116
  833. package/lib/esm/duet-modal.entry.js +189 -189
  834. package/lib/esm/duet-multiselect.entry.js +207 -207
  835. package/lib/esm/duet-nav.entry.js +20 -20
  836. package/lib/esm/duet-notification_2.entry.js +145 -140
  837. package/lib/esm/duet-number-input.entry.js +340 -338
  838. package/lib/esm/duet-page-heading.entry.js +26 -26
  839. package/lib/esm/duet-pagination_2.entry.js +512 -512
  840. package/lib/esm/duet-popup-menu-item.entry.js +62 -62
  841. package/lib/esm/duet-popup-menu.entry.js +148 -148
  842. package/lib/esm/duet-progress.entry.js +54 -54
  843. package/lib/esm/duet-promo-card.entry.js +40 -40
  844. package/lib/esm/duet-radio_2.entry.js +197 -197
  845. package/lib/esm/duet-range-slider.entry.js +112 -105
  846. package/lib/esm/duet-scrollable_3.entry.js +387 -387
  847. package/lib/esm/duet-section-layout.entry.js +21 -21
  848. package/lib/esm/duet-select.entry.js +156 -156
  849. package/lib/esm/duet-shaped-image.entry.js +28 -28
  850. package/lib/esm/duet-show-more.entry.js +99 -99
  851. package/lib/esm/duet-slideout-lang.entry.js +36 -36
  852. package/lib/esm/duet-slideout-link.entry.js +33 -33
  853. package/lib/esm/duet-slideout-panel-dropdown.entry.js +50 -50
  854. package/lib/esm/duet-slideout-panel.entry.js +120 -120
  855. package/lib/esm/duet-slideout.entry.js +196 -196
  856. package/lib/esm/duet-step_2.entry.js +189 -185
  857. package/lib/esm/duet-submenu-bar-dropdown-link.entry.js +37 -37
  858. package/lib/esm/duet-submenu-bar-dropdown.entry.js +104 -104
  859. package/lib/esm/duet-submenu-bar-link.entry.js +60 -60
  860. package/lib/esm/duet-submenu-bar.entry.js +110 -110
  861. package/lib/esm/duet-textarea.entry.js +160 -160
  862. package/lib/esm/duet-toggle.entry.js +79 -72
  863. package/lib/esm/duet-toolbar-dropdown-link.entry.js +36 -36
  864. package/lib/esm/duet-toolbar-dropdown.entry.js +60 -60
  865. package/lib/esm/duet-toolbar-link.entry.js +31 -31
  866. package/lib/esm/duet-toolbar.entry.js +34 -34
  867. package/lib/esm/duet-tooltip-button_2.entry.js +93 -80
  868. package/lib/esm/duet-tooltip.entry.js +190 -188
  869. package/lib/esm/duet-tray.entry.js +85 -82
  870. package/lib/esm/duet-upload-aria-status.entry.js +65 -65
  871. package/lib/esm/duet-upload-item.entry.js +81 -81
  872. package/lib/esm/duet-visually-hidden.entry.js +12 -12
  873. package/lib/esm/duet.js +5 -5
  874. package/lib/esm/errorcodes.utils-e681347c.js +36 -0
  875. package/lib/esm/focus-utils-23aad0c9.js +18 -0
  876. package/lib/esm/{index-b3bf9761.js → index-02e78bbf.js} +106 -45
  877. package/lib/esm/input-utils-85681162.js +53 -0
  878. package/lib/esm/is-internet-explorer-2c48f686.js +9 -0
  879. package/lib/esm/{js-utils-a35dcc8c.js → js-utils-9b9e0039.js} +27 -27
  880. package/lib/esm/keyboard-utils-eba88365.js +51 -0
  881. package/lib/esm/{language-utils-9ff76444.js → language-utils-00ca4c55.js} +74 -74
  882. package/lib/esm/loader.js +4 -4
  883. package/lib/{dist-custom-elements/p-f8c76b25.js → esm/slot-query-022710bb.js} +1 -1
  884. package/lib/esm/string-utils-ca039233.js +55 -0
  885. package/lib/esm/teleport-4462e8c1.js +97 -0
  886. package/lib/esm/themeable-component-724c0f7e.js +13 -0
  887. package/lib/esm/token-utils-b4bd3ec7.js +117 -0
  888. package/lib/esm/watch-options-e96ecd92.js +57 -0
  889. package/lib/esm-es5/app-globals-45aa6d20.js +4 -0
  890. package/lib/esm-es5/duet-action-button.entry.js +1 -1
  891. package/lib/esm-es5/duet-alert.entry.js +2 -2
  892. package/lib/esm-es5/duet-badge.entry.js +1 -1
  893. package/lib/esm-es5/duet-banner.entry.js +1 -1
  894. package/lib/esm-es5/duet-breadcrumb.entry.js +1 -1
  895. package/lib/esm-es5/duet-breadcrumbs.entry.js +1 -1
  896. package/lib/esm-es5/duet-button_2.entry.js +1 -1
  897. package/lib/esm-es5/duet-callout.entry.js +1 -1
  898. package/lib/esm-es5/duet-caption_4.entry.js +1 -1
  899. package/lib/esm-es5/duet-card.entry.js +1 -1
  900. package/lib/esm-es5/duet-checkbox.entry.js +1 -1
  901. package/lib/esm-es5/duet-checkmark.entry.js +1 -1
  902. package/lib/esm-es5/duet-chip.entry.js +2 -2
  903. package/lib/esm-es5/duet-choice_2.entry.js +1 -1
  904. package/lib/esm-es5/duet-collapsible.entry.js +2 -2
  905. package/lib/esm-es5/duet-combobox.entry.js +1 -1
  906. package/lib/esm-es5/duet-contact-card.entry.js +1 -1
  907. package/lib/esm-es5/duet-cookie-consent.entry.js +1 -1
  908. package/lib/esm-es5/duet-date-picker.entry.js +1 -1
  909. package/lib/esm-es5/duet-divider_2.entry.js +1 -1
  910. package/lib/esm-es5/duet-editable-table_3.entry.js +1 -1
  911. package/lib/esm-es5/duet-empty-state.entry.js +1 -1
  912. package/lib/esm-es5/duet-fieldset.entry.js +1 -1
  913. package/lib/esm-es5/duet-file-chooser.entry.js +1 -1
  914. package/lib/esm-es5/duet-footer.entry.js +1 -1
  915. package/lib/esm-es5/duet-grid_2.entry.js +1 -1
  916. package/lib/esm-es5/duet-header_2.entry.js +1 -1
  917. package/lib/esm-es5/duet-hero.entry.js +1 -1
  918. package/lib/esm-es5/duet-icon.entry.js +1 -1
  919. package/lib/esm-es5/duet-input_2.entry.js +1 -1
  920. package/lib/esm-es5/duet-layout.entry.js +1 -1
  921. package/lib/esm-es5/duet-list_2.entry.js +1 -1
  922. package/lib/esm-es5/duet-menu-bar-button.entry.js +1 -1
  923. package/lib/esm-es5/duet-menu-bar-dropdown-link.entry.js +1 -1
  924. package/lib/esm-es5/duet-menu-bar-dropdown.entry.js +1 -1
  925. package/lib/esm-es5/duet-menu-bar-link.entry.js +1 -1
  926. package/lib/esm-es5/duet-menu-bar.entry.js +1 -1
  927. package/lib/esm-es5/duet-modal.entry.js +1 -1
  928. package/lib/esm-es5/duet-multiselect.entry.js +1 -1
  929. package/lib/esm-es5/duet-nav.entry.js +1 -1
  930. package/lib/esm-es5/duet-notification_2.entry.js +2 -2
  931. package/lib/esm-es5/duet-number-input.entry.js +1 -1
  932. package/lib/esm-es5/duet-page-heading.entry.js +1 -1
  933. package/lib/esm-es5/duet-pagination_2.entry.js +1 -1
  934. package/lib/esm-es5/duet-popup-menu-item.entry.js +1 -1
  935. package/lib/esm-es5/duet-popup-menu.entry.js +1 -1
  936. package/lib/esm-es5/duet-progress.entry.js +1 -1
  937. package/lib/esm-es5/duet-promo-card.entry.js +1 -1
  938. package/lib/esm-es5/duet-radio_2.entry.js +1 -1
  939. package/lib/esm-es5/duet-range-slider.entry.js +1 -1
  940. package/lib/esm-es5/duet-scrollable_3.entry.js +2 -2
  941. package/lib/esm-es5/duet-section-layout.entry.js +1 -1
  942. package/lib/esm-es5/duet-select.entry.js +1 -1
  943. package/lib/esm-es5/duet-shaped-image.entry.js +1 -1
  944. package/lib/esm-es5/duet-show-more.entry.js +1 -1
  945. package/lib/esm-es5/duet-slideout-lang.entry.js +1 -1
  946. package/lib/esm-es5/duet-slideout-link.entry.js +1 -1
  947. package/lib/esm-es5/duet-slideout-panel-dropdown.entry.js +1 -1
  948. package/lib/esm-es5/duet-slideout-panel.entry.js +1 -1
  949. package/lib/esm-es5/duet-slideout.entry.js +2 -2
  950. package/lib/esm-es5/duet-step_2.entry.js +2 -2
  951. package/lib/esm-es5/duet-submenu-bar-dropdown-link.entry.js +1 -1
  952. package/lib/esm-es5/duet-submenu-bar-dropdown.entry.js +1 -1
  953. package/lib/esm-es5/duet-submenu-bar-link.entry.js +1 -1
  954. package/lib/esm-es5/duet-submenu-bar.entry.js +1 -1
  955. package/lib/esm-es5/duet-textarea.entry.js +1 -1
  956. package/lib/esm-es5/duet-toggle.entry.js +2 -2
  957. package/lib/esm-es5/duet-toolbar-dropdown-link.entry.js +1 -1
  958. package/lib/esm-es5/duet-toolbar-dropdown.entry.js +1 -1
  959. package/lib/esm-es5/duet-toolbar-link.entry.js +1 -1
  960. package/lib/esm-es5/duet-toolbar.entry.js +1 -1
  961. package/lib/esm-es5/duet-tooltip-button_2.entry.js +1 -1
  962. package/lib/esm-es5/duet-tooltip.entry.js +1 -1
  963. package/lib/esm-es5/duet-tray.entry.js +1 -1
  964. package/lib/esm-es5/duet-upload-aria-status.entry.js +1 -1
  965. package/lib/esm-es5/duet-upload-item.entry.js +1 -1
  966. package/lib/esm-es5/duet-visually-hidden.entry.js +1 -1
  967. package/lib/esm-es5/duet.js +1 -1
  968. package/lib/esm-es5/{errorcodes.utils-424b1197.js → errorcodes.utils-e681347c.js} +1 -1
  969. package/lib/esm-es5/focus-utils-23aad0c9.js +4 -0
  970. package/lib/esm-es5/index-02e78bbf.js +5 -0
  971. package/lib/esm-es5/keyboard-utils-eba88365.js +4 -0
  972. package/lib/esm-es5/{language-utils-9ff76444.js → language-utils-00ca4c55.js} +1 -1
  973. package/lib/esm-es5/loader.js +1 -1
  974. package/lib/types/common/a11y-component.d.ts +7 -7
  975. package/lib/types/common/form-components.d.ts +15 -15
  976. package/lib/types/common/themeable-component.d.ts +4 -4
  977. package/lib/types/common-types.d.ts +11 -0
  978. package/lib/types/components/duet-action-button/duet-action-button.d.ts +126 -126
  979. package/lib/types/components/duet-alert/duet-alert.d.ts +100 -100
  980. package/lib/types/components/duet-badge/duet-badge.d.ts +27 -27
  981. package/lib/types/components/duet-banner/duet-banner.d.ts +58 -58
  982. package/lib/types/components/duet-breadcrumbs/duet-breadcrumb.d.ts +38 -33
  983. package/lib/types/components/duet-breadcrumbs/duet-breadcrumbs.d.ts +23 -23
  984. package/lib/types/components/duet-button/duet-button.d.ts +219 -219
  985. package/lib/types/components/duet-callout/duet-callout.d.ts +19 -19
  986. package/lib/types/components/duet-caption/duet-caption.d.ts +26 -26
  987. package/lib/types/components/duet-card/duet-card.d.ts +121 -119
  988. package/lib/types/components/duet-checkbox/duet-checkbox.d.ts +132 -132
  989. package/lib/types/components/duet-chip/duet-chip.d.ts +111 -109
  990. package/lib/types/components/duet-choice/duet-checkmark.d.ts +27 -27
  991. package/lib/types/components/duet-choice/duet-choice.d.ts +259 -259
  992. package/lib/types/components/duet-choice-group/duet-choice-group.d.ts +103 -103
  993. package/lib/types/components/duet-collapsible/duet-collapsible.d.ts +90 -88
  994. package/lib/types/components/duet-combobox/duet-combobox-select-single.d.ts +3 -3
  995. package/lib/types/components/duet-combobox/duet-combobox-select.d.ts +8 -8
  996. package/lib/types/components/duet-combobox/duet-combobox.d.ts +135 -135
  997. package/lib/types/components/duet-contact-card/duet-contact-card.d.ts +60 -60
  998. package/lib/types/components/duet-cookie-consent/duet-cookie-consent.d.ts +31 -29
  999. package/lib/types/components/duet-date-picker/date-i18n.d.ts +13 -13
  1000. package/lib/types/components/duet-date-picker/date-picker-day.d.ts +9 -9
  1001. package/lib/types/components/duet-date-picker/date-picker-input.d.ts +28 -28
  1002. package/lib/types/components/duet-date-picker/date-picker-month.d.ts +12 -12
  1003. package/lib/types/components/duet-date-picker/duet-date-picker.d.ts +220 -220
  1004. package/lib/types/components/duet-divider/duet-divider.d.ts +26 -26
  1005. package/lib/types/components/duet-editable-table/duet-editable-table-tabledata.d.ts +3 -3
  1006. package/lib/types/components/duet-editable-table/duet-editable-table.d.ts +133 -133
  1007. package/lib/types/components/duet-empty-state/duet-empty-state.d.ts +22 -22
  1008. package/lib/types/components/duet-fieldset/duet-fieldset.d.ts +60 -60
  1009. package/lib/types/components/duet-file-chooser/duet-file-chooser.d.ts +35 -35
  1010. package/lib/types/components/duet-footer/duet-footer.d.ts +143 -143
  1011. package/lib/types/components/duet-grid/duet-grid.d.ts +73 -73
  1012. package/lib/types/components/duet-grid-item/duet-grid-item.d.ts +49 -49
  1013. package/lib/types/components/duet-header/duet-header-dropdown.d.ts +11 -11
  1014. package/lib/types/components/duet-header/duet-header-icon.d.ts +4 -4
  1015. package/lib/types/components/duet-header/duet-header.d.ts +347 -347
  1016. package/lib/types/components/duet-heading/duet-heading.d.ts +49 -49
  1017. package/lib/types/components/duet-hero/duet-hero.d.ts +198 -198
  1018. package/lib/types/components/duet-icon/duet-icon.d.ts +80 -81
  1019. package/lib/types/components/duet-input/duet-input.d.ts +279 -279
  1020. package/lib/types/components/duet-label/duet-label.d.ts +26 -26
  1021. package/lib/types/components/duet-layout/duet-layout.d.ts +48 -48
  1022. package/lib/types/components/duet-link/duet-link.d.ts +95 -94
  1023. package/lib/types/components/duet-list/duet-list.d.ts +60 -60
  1024. package/lib/types/components/duet-list-item/duet-list-item.d.ts +17 -17
  1025. package/lib/types/components/duet-logo/duet-logo.d.ts +59 -59
  1026. package/lib/types/components/duet-menu-bar/duet-menu-bar.d.ts +68 -68
  1027. package/lib/types/components/duet-menu-bar-button/duet-menu-bar-button.d.ts +85 -86
  1028. package/lib/types/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.d.ts +50 -51
  1029. package/lib/types/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.d.ts +36 -36
  1030. package/lib/types/components/duet-menu-bar-link/duet-menu-bar-link.d.ts +45 -46
  1031. package/lib/types/components/duet-modal/duet-modal.d.ts +155 -155
  1032. package/lib/types/components/duet-multiselect/duet-multiselect.d.ts +153 -153
  1033. package/lib/types/components/duet-nav/duet-nav.d.ts +20 -20
  1034. package/lib/types/components/duet-notification/duet-notification.d.ts +55 -55
  1035. package/lib/types/components/duet-notification-drawer/duet-notification-drawer.d.ts +83 -83
  1036. package/lib/types/components/duet-number-input/duet-number-input.d.ts +230 -230
  1037. package/lib/types/components/duet-page-heading/duet-page-heading.d.ts +25 -25
  1038. package/lib/types/components/duet-pagination/duet-pagination.d.ts +129 -129
  1039. package/lib/types/components/duet-paragraph/duet-paragraph.d.ts +38 -38
  1040. package/lib/types/components/duet-popup-menu/duet-popup-menu.d.ts +80 -80
  1041. package/lib/types/components/duet-popup-menu-item/duet-popup-menu-item.d.ts +73 -73
  1042. package/lib/types/components/duet-progress/duet-progress.d.ts +71 -71
  1043. package/lib/types/components/duet-promo-card/duet-promo-card.d.ts +42 -42
  1044. package/lib/types/components/duet-radio/duet-radio.d.ts +145 -145
  1045. package/lib/types/components/duet-radio-group/duet-radio-group.d.ts +93 -93
  1046. package/lib/types/components/duet-range-slider/duet-range-slider.d.ts +132 -130
  1047. package/lib/types/components/duet-range-stepper/duet-range-stepper.d.ts +68 -68
  1048. package/lib/types/components/duet-scrollable/duet-scrollable.d.ts +61 -61
  1049. package/lib/types/components/duet-section-layout/duet-section-layout.d.ts +17 -17
  1050. package/lib/types/components/duet-select/duet-select.d.ts +179 -179
  1051. package/lib/types/components/duet-shaped-image/duet-shaped-image.d.ts +30 -30
  1052. package/lib/types/components/duet-show-more/duet-show-more.d.ts +83 -83
  1053. package/lib/types/components/duet-slideout/duet-slideout.d.ts +86 -86
  1054. package/lib/types/components/duet-slideout-lang/duet-slideout-lang.d.ts +24 -24
  1055. package/lib/types/components/duet-slideout-link/duet-slideout-link.d.ts +55 -55
  1056. package/lib/types/components/duet-slideout-panel/duet-slideout-panel.d.ts +55 -55
  1057. package/lib/types/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.d.ts +39 -39
  1058. package/lib/types/components/duet-spacer/duet-spacer.d.ts +18 -18
  1059. package/lib/types/components/duet-spinner/duet-spinner.d.ts +30 -30
  1060. package/lib/types/components/duet-step/duet-step.d.ts +68 -66
  1061. package/lib/types/components/duet-stepper/duet-stepper.d.ts +47 -47
  1062. package/lib/types/components/duet-submenu-bar/duet-submenu-bar.d.ts +50 -50
  1063. package/lib/types/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.d.ts +48 -49
  1064. package/lib/types/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.d.ts +43 -43
  1065. package/lib/types/components/duet-submenu-bar-link/duet-submenu-bar-link.d.ts +40 -41
  1066. package/lib/types/components/duet-tab/duet-tab.d.ts +37 -37
  1067. package/lib/types/components/duet-tab-group/duet-tab-group.d.ts +132 -132
  1068. package/lib/types/components/duet-table/duet-table.d.ts +66 -66
  1069. package/lib/types/components/duet-textarea/duet-textarea.d.ts +200 -200
  1070. package/lib/types/components/duet-toggle/duet-toggle.d.ts +115 -113
  1071. package/lib/types/components/duet-toolbar/duet-toolbar.d.ts +30 -30
  1072. package/lib/types/components/duet-toolbar-dropdown/duet-toolbar-dropdown.d.ts +50 -50
  1073. package/lib/types/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.d.ts +43 -43
  1074. package/lib/types/components/duet-toolbar-link/duet-toolbar-link.d.ts +42 -42
  1075. package/lib/types/components/duet-tooltip/duet-tooltip-button.d.ts +21 -19
  1076. package/lib/types/components/duet-tooltip/duet-tooltip-popup.d.ts +33 -31
  1077. package/lib/types/components/duet-tooltip/duet-tooltip.d.ts +122 -122
  1078. package/lib/types/components/duet-tray/duet-tray.d.ts +84 -84
  1079. package/lib/types/components/duet-upload/duet-upload.d.ts +484 -484
  1080. package/lib/types/components/duet-upload/errorcodes.utils.d.ts +3 -3
  1081. package/lib/types/components/duet-upload/upload-editable-item-error.d.ts +2 -2
  1082. package/lib/types/components/duet-upload/upload-editable-item-inprogres.d.ts +2 -2
  1083. package/lib/types/components/duet-upload/upload-editable-item-pending.d.ts +1 -1
  1084. package/lib/types/components/duet-upload/upload-editable-item-success.d.ts +2 -2
  1085. package/lib/types/components/duet-upload/upload-item-header.d.ts +2 -2
  1086. package/lib/types/components/duet-upload/upload-validators.d.ts +4 -4
  1087. package/lib/types/components/duet-upload/xhr.helpers.d.ts +10 -10
  1088. package/lib/types/components/duet-upload-aria-status/duet-upload-aria-status.d.ts +40 -40
  1089. package/lib/types/components/duet-upload-item/duet-upload-item.d.ts +54 -54
  1090. package/lib/types/components/duet-visually-hidden/duet-visually-hidden.d.ts +6 -6
  1091. package/lib/types/components.d.ts +10 -4
  1092. package/lib/types/stencil-public-runtime.d.ts +8 -0
  1093. package/lib/types/utils/axe-core-utils.d.ts +3 -3
  1094. package/lib/types/utils/fixture-utils.d.ts +2 -2
  1095. package/lib/types/utils/focus-utils.d.ts +2 -2
  1096. package/lib/types/utils/keyboard-utils.d.ts +2 -0
  1097. package/lib/types/utils/language-utils.d.ts +10 -10
  1098. package/lib/types/utils/picture-utils.d.ts +10 -10
  1099. package/lib/types/utils/teleport.d.ts +20 -20
  1100. package/lib/types/utils/template-utils.d.ts +1 -1
  1101. package/lib/types/utils/test-utils.d.ts +2 -2
  1102. package/lib/types/utils/token-utils.d.ts +9 -9
  1103. package/package.json +6 -6
  1104. package/lib/cjs/app-globals-4ab83f59.js +0 -54
  1105. package/lib/cjs/create-id-167cd350.js +0 -13
  1106. package/lib/cjs/errorcodes.utils-8e928de5.js +0 -39
  1107. package/lib/cjs/focus-utils-aea9f4e1.js +0 -21
  1108. package/lib/cjs/input-utils-b4615782.js +0 -56
  1109. package/lib/cjs/keyboard-utils-02441bc5.js +0 -36
  1110. package/lib/cjs/string-utils-51a2f59f.js +0 -59
  1111. package/lib/cjs/teleport-af825e04.js +0 -99
  1112. package/lib/cjs/themeable-component-0be6d1f4.js +0 -15
  1113. package/lib/cjs/token-utils-dbfeff2e.js +0 -124
  1114. package/lib/cjs/watch-options-1773d69f.js +0 -61
  1115. package/lib/dist-custom-elements/p-03ac3eb3.js +0 -137
  1116. package/lib/dist-custom-elements/p-1a395a8d.js +0 -55
  1117. package/lib/dist-custom-elements/p-1ce55654.js +0 -265
  1118. package/lib/dist-custom-elements/p-1f56e02f.js +0 -174
  1119. package/lib/dist-custom-elements/p-24853ebf.js +0 -97
  1120. package/lib/dist-custom-elements/p-268171f7.js +0 -9
  1121. package/lib/dist-custom-elements/p-3049dfd5.js +0 -147
  1122. package/lib/dist-custom-elements/p-45f71a69.js +0 -11
  1123. package/lib/dist-custom-elements/p-4687ca41.js +0 -465
  1124. package/lib/dist-custom-elements/p-56ac3289.js +0 -20
  1125. package/lib/dist-custom-elements/p-5d8d9a52.js +0 -98
  1126. package/lib/dist-custom-elements/p-62e68de8.js +0 -38
  1127. package/lib/dist-custom-elements/p-64cd1abb.js +0 -93
  1128. package/lib/dist-custom-elements/p-665418f0.js +0 -205
  1129. package/lib/dist-custom-elements/p-759c725f.js +0 -226
  1130. package/lib/dist-custom-elements/p-77f2dbee.js +0 -53
  1131. package/lib/dist-custom-elements/p-80ec4336.js +0 -123
  1132. package/lib/dist-custom-elements/p-8be301dd.js +0 -62
  1133. package/lib/dist-custom-elements/p-9541f0b6.js +0 -59
  1134. package/lib/dist-custom-elements/p-a1371eee.js +0 -57
  1135. package/lib/dist-custom-elements/p-a3923b18.js +0 -126
  1136. package/lib/dist-custom-elements/p-c5032d3a.js +0 -18
  1137. package/lib/dist-custom-elements/p-d48735b6.js +0 -13
  1138. package/lib/dist-custom-elements/p-e19d1e27.js +0 -117
  1139. package/lib/dist-custom-elements/p-e6b07569.js +0 -271
  1140. package/lib/dist-custom-elements/p-e77f7fff.js +0 -60
  1141. package/lib/dist-custom-elements/p-f27e355b.js +0 -76
  1142. package/lib/dist-custom-elements/p-f46be918.js +0 -110
  1143. package/lib/dist-custom-elements/p-fd4877d1.js +0 -72
  1144. package/lib/dist-custom-elements/p-fe8a2205.js +0 -206
  1145. package/lib/duet/p-038ac494.system.entry.js +0 -4
  1146. package/lib/duet/p-08764d71.entry.js +0 -4
  1147. package/lib/duet/p-08f2114a.entry.js +0 -4
  1148. package/lib/duet/p-0a664ebb.entry.js +0 -4
  1149. package/lib/duet/p-0e89cbae.system.entry.js +0 -4
  1150. package/lib/duet/p-0fd024c9.system.js +0 -4
  1151. package/lib/duet/p-11571ab9.entry.js +0 -4
  1152. package/lib/duet/p-177c55aa.entry.js +0 -4
  1153. package/lib/duet/p-18e2e6c8.system.entry.js +0 -4
  1154. package/lib/duet/p-21f3a17a.system.js +0 -4
  1155. package/lib/duet/p-2c78c637.system.entry.js +0 -4
  1156. package/lib/duet/p-34b5285b.system.entry.js +0 -4
  1157. package/lib/duet/p-3b147393.entry.js +0 -4
  1158. package/lib/duet/p-463ddc2c.system.entry.js +0 -4
  1159. package/lib/duet/p-4669b0af.js +0 -4
  1160. package/lib/duet/p-486eec2d.entry.js +0 -4
  1161. package/lib/duet/p-4dc0fff9.entry.js +0 -4
  1162. package/lib/duet/p-50ec2074.entry.js +0 -4
  1163. package/lib/duet/p-52806dad.system.entry.js +0 -4
  1164. package/lib/duet/p-5311f96e.system.entry.js +0 -4
  1165. package/lib/duet/p-5ae9b74f.entry.js +0 -4
  1166. package/lib/duet/p-5c5012f6.system.entry.js +0 -4
  1167. package/lib/duet/p-5eb2a31f.system.entry.js +0 -4
  1168. package/lib/duet/p-61d39730.entry.js +0 -4
  1169. package/lib/duet/p-6c4c0279.js +0 -5
  1170. package/lib/duet/p-76b68b44.entry.js +0 -4
  1171. package/lib/duet/p-789365cb.system.entry.js +0 -4
  1172. package/lib/duet/p-7bca584a.entry.js +0 -4
  1173. package/lib/duet/p-7c36b779.entry.js +0 -4
  1174. package/lib/duet/p-7de467b8.entry.js +0 -4
  1175. package/lib/duet/p-7e1f37e2.entry.js +0 -4
  1176. package/lib/duet/p-821c350f.system.entry.js +0 -4
  1177. package/lib/duet/p-8d0d6e06.system.js +0 -4
  1178. package/lib/duet/p-995e1b11.system.entry.js +0 -4
  1179. package/lib/duet/p-9a613a25.system.entry.js +0 -4
  1180. package/lib/duet/p-9f835123.system.entry.js +0 -4
  1181. package/lib/duet/p-a0660ffa.system.js +0 -5
  1182. package/lib/duet/p-aa6d7d97.entry.js +0 -4
  1183. package/lib/duet/p-ac9f6601.entry.js +0 -4
  1184. package/lib/duet/p-b1db3006.js +0 -4
  1185. package/lib/duet/p-b3ae5641.system.entry.js +0 -4
  1186. package/lib/duet/p-c1bc9249.entry.js +0 -4
  1187. package/lib/duet/p-c36a1bb7.entry.js +0 -4
  1188. package/lib/duet/p-cc1909de.js +0 -4
  1189. package/lib/duet/p-d098d59c.system.entry.js +0 -4
  1190. package/lib/duet/p-d9353709.entry.js +0 -4
  1191. package/lib/duet/p-e1e89fd5.entry.js +0 -4
  1192. package/lib/duet/p-e491c098.system.entry.js +0 -4
  1193. package/lib/duet/p-e95d09bb.system.entry.js +0 -4
  1194. package/lib/duet/p-efa6152d.entry.js +0 -4
  1195. package/lib/duet/p-f58eb425.js +0 -4
  1196. package/lib/duet/p-fab6160a.entry.js +0 -4
  1197. package/lib/duet/p-fcbb30e1.entry.js +0 -4
  1198. package/lib/duet/p-ff09528c.system.entry.js +0 -4
  1199. package/lib/esm/app-globals-de2a5510.js +0 -52
  1200. package/lib/esm/create-id-2b0cd46d.js +0 -11
  1201. package/lib/esm/errorcodes.utils-424b1197.js +0 -36
  1202. package/lib/esm/focus-utils-74961919.js +0 -18
  1203. package/lib/esm/input-utils-a0225b92.js +0 -53
  1204. package/lib/esm/is-internet-explorer-032d4dae.js +0 -9
  1205. package/lib/esm/keyboard-utils-5746e126.js +0 -20
  1206. package/lib/esm/string-utils-59ad4cb2.js +0 -55
  1207. package/lib/esm/teleport-15747328.js +0 -97
  1208. package/lib/esm/themeable-component-fdce4fd7.js +0 -13
  1209. package/lib/esm/token-utils-46c8fe31.js +0 -117
  1210. package/lib/esm/watch-options-f189118b.js +0 -57
  1211. package/lib/esm-es5/app-globals-de2a5510.js +0 -4
  1212. package/lib/esm-es5/focus-utils-74961919.js +0 -4
  1213. package/lib/esm-es5/index-b3bf9761.js +0 -5
  1214. package/lib/esm-es5/keyboard-utils-5746e126.js +0 -4
  1215. /package/lib/duet/{p-1a395a8d.js → p-0e052642.js} +0 -0
  1216. /package/lib/duet/{p-f8c76b25.js → p-11230037.js} +0 -0
  1217. /package/lib/duet/{p-0b31864f.js → p-38320af8.js} +0 -0
  1218. /package/lib/duet/{p-c30a5f7c.system.js → p-41982d26.system.js} +0 -0
  1219. /package/lib/duet/{p-268171f7.js → p-43b89e38.js} +0 -0
  1220. /package/lib/duet/{p-274d11e3.js → p-4ab776f4.js} +0 -0
  1221. /package/lib/duet/{p-77b6e4ba.system.js → p-50f4bca2.system.js} +0 -0
  1222. /package/lib/duet/{p-45f71a69.js → p-5e59e970.js} +0 -0
  1223. /package/lib/duet/{p-75daef16.system.js → p-634e8787.system.js} +0 -0
  1224. /package/lib/duet/{p-719b38fe.system.js → p-67c653f9.system.js} +0 -0
  1225. /package/lib/duet/{p-b99c00fa.system.js → p-6ef75455.system.js} +0 -0
  1226. /package/lib/duet/{p-a1371eee.js → p-7d8a2628.js} +0 -0
  1227. /package/lib/duet/{p-ecf1f6cd.system.js → p-9e36548d.system.js} +0 -0
  1228. /package/lib/duet/{p-3d8d557b.js → p-9e371678.js} +0 -0
  1229. /package/lib/duet/{p-d48735b6.js → p-a58bd561.js} +0 -0
  1230. /package/lib/duet/{p-8e1da663.system.js → p-afad5fd3.system.js} +0 -0
  1231. /package/lib/duet/{p-24853ebf.js → p-b2e550a3.js} +0 -0
  1232. /package/lib/duet/{p-7c29d36a.system.js → p-b864159a.system.js} +0 -0
  1233. /package/lib/duet/{p-88a50491.system.js → p-d1cedaa1.system.js} +0 -0
  1234. /package/lib/duet/{p-77f2dbee.js → p-df7874f9.js} +0 -0
  1235. /package/lib/duet/{p-87dd7bf3.system.js → p-e12066c8.system.js} +0 -0
  1236. /package/lib/duet/{p-1a91e22a.system.js → p-e6b5a1c7.system.js} +0 -0
  1237. /package/lib/esm-es5/{common-strings-c0ac5a0b.js → common-strings-59db6973.js} +0 -0
  1238. /package/lib/esm-es5/{create-id-2b0cd46d.js → create-id-149a1b6d.js} +0 -0
  1239. /package/lib/esm-es5/{input-utils-a0225b92.js → input-utils-85681162.js} +0 -0
  1240. /package/lib/esm-es5/{is-internet-explorer-032d4dae.js → is-internet-explorer-2c48f686.js} +0 -0
  1241. /package/lib/esm-es5/{js-utils-a35dcc8c.js → js-utils-9b9e0039.js} +0 -0
  1242. /package/lib/esm-es5/{slot-query-7877f18f.js → slot-query-022710bb.js} +0 -0
  1243. /package/lib/esm-es5/{string-utils-59ad4cb2.js → string-utils-ca039233.js} +0 -0
  1244. /package/lib/esm-es5/{teleport-15747328.js → teleport-4462e8c1.js} +0 -0
  1245. /package/lib/esm-es5/{themeable-component-fdce4fd7.js → themeable-component-724c0f7e.js} +0 -0
  1246. /package/lib/esm-es5/{token-utils-46c8fe31.js → token-utils-b4bd3ec7.js} +0 -0
  1247. /package/lib/esm-es5/{watch-options-f189118b.js → watch-options-e96ecd92.js} +0 -0
@@ -12,16 +12,16 @@ import { Build, Fragment, h, Host, } from "@stencil/core";
12
12
  import { disableBodyScroll, enableBodyScroll } from "body-scroll-lock/lib/bodyScrollLock.es6.js";
13
13
  import { DuetStringsExternalDefaults } from "../../common-strings";
14
14
  import { inheritGlobalTheme } from "../../common/themeable-component";
15
- import { isArrowDownKey, isArrowLeftKey, isArrowRightKey, isArrowUpKey, isEscapeKey, isSpaceKey, } from "../../utils/keyboard-utils";
15
+ import { isArrowDownKey, isArrowLeftKey, isArrowRightKey, isArrowUpKey, isEscapeKey, isSpaceKey, subscribeTabbingChange, unsubscribeTabbingChange, } from "../../utils/keyboard-utils";
16
16
  import { connectLanguageChangeObserver, disconnectLanguageChangeObserver, getLanguage, getLocaleString, } from "../../utils/language-utils";
17
17
  import { parsePossibleJSON } from "../../utils/string-utils";
18
18
  import { DuetHeaderDropdown } from "./duet-header-dropdown";
19
19
  import { DuetHeaderHamburger } from "./duet-header-hamburger";
20
20
  import { DuetHeaderIcon } from "./duet-header-icon";
21
21
  const createEvent = (ev, data) => ({
22
- component: "duet-header",
23
- data,
24
- originalEvent: ev,
22
+ component: "duet-header",
23
+ data,
24
+ originalEvent: ev,
25
25
  });
26
26
  /**
27
27
  * @slot utility - A slot for utilities, such as a notification drawer or shopping basket.
@@ -29,1327 +29,1331 @@ const createEvent = (ev, data) => ({
29
29
  * @part header - piercing selector for styling the header element.
30
30
  */
31
31
  export class DuetHeader {
32
- constructor() {
33
- var _a;
34
- /**
35
- * Own Properties
36
- */
37
- this.subMenuItemRefs = {};
38
- this.subMenuButtonRefs = {};
39
- this.hasLanguageChanged = false;
40
- this.mql = [window.matchMedia(media_query_large.replace(/'/g, ""))];
41
- this.boundMqlFunctions = [];
42
- this.handleClick = (event, moveFocusToButton = false) => {
43
- if (event.data.analyticsId) {
44
- this.duetAnalytics.emit({
45
- component: "duet-header",
46
- analyticsId: event.data.analyticsId,
47
- });
48
- }
49
- this.duetChange.emit(event);
50
- this.closeMenus(moveFocusToButton);
51
- this.closeMobileNavigation(moveFocusToButton);
52
- };
53
- this.handleSessionClick = (ev) => {
54
- const e = createEvent(ev, this.processedSession);
55
- this.handleClick(e);
56
- this.duetSessionClick.emit(e);
57
- };
58
- this.handleSessionItemClick = (ev, item) => {
59
- const e = createEvent(ev, item);
60
- this.handleClick(e);
61
- this.duetSessionClick.emit(e);
62
- };
63
- this.handleSearchClick = (ev) => {
64
- const e = createEvent(ev, this.processedSearch);
65
- this.handleClick(e);
66
- this.duetSearchClick.emit(e);
67
- };
68
- this.handleUserClick = (ev) => {
69
- const e = createEvent(ev, this.processedUser);
70
- this.handleClick(e);
71
- this.duetUserClick.emit(e);
72
- };
73
- this.handleBackClick = (ev) => {
74
- const e = createEvent(ev, this.processedBack);
75
- this.handleClick(e);
76
- this.duetBackClick.emit(e);
77
- };
78
- this.handleSkipClick = (ev) => {
79
- const { skipLabel } = this.accessibleI18nLabels;
80
- const e = createEvent(ev, { href: this.skipToId, label: skipLabel });
81
- this.handleClick(e);
82
- this.duetSkipClick.emit(e);
83
- };
84
- this.handleLogoClick = (ev) => {
85
- const e = createEvent(ev, { href: this.logoHref, label: "logo" });
86
- this.handleClick(e);
87
- this.duetLogoClick.emit(e);
88
- };
89
- this.handleArrowKeys = ev => {
90
- let button;
91
- if (isArrowLeftKey(ev) || isArrowUpKey(ev)) {
92
- button = ev.target.previousElementSibling;
93
- }
94
- else if (isArrowRightKey(ev) || isArrowDownKey(ev)) {
95
- button = ev.target.nextElementSibling;
96
- }
97
- if (button) {
98
- ev.preventDefault();
99
- button.focus();
100
- }
101
- };
102
- this.toggleMenu = (ev, type, id, active) => {
103
- let el;
104
- ev.preventDefault();
105
- ev.stopPropagation();
106
- if (active === true && !this.openMenu) {
107
- const closedActives = this.closedActives ? [...this.closedActives] : [];
108
- const index = closedActives.findIndex(i => i === id);
109
- if (index > -1) {
110
- closedActives.splice(index, 1);
111
- this.closedActives = [...closedActives];
112
- }
113
- else {
114
- this.closedActives = [...closedActives, id];
115
- }
116
- }
117
- else {
118
- this.openMenu = this.openMenu === id ? null : id;
119
- }
120
- // For language menu
121
- if (type === "language") {
122
- this.isContactOpen = false;
123
- this.isLanguageOpen = !this.isLanguageOpen;
124
- this.isSegmentOpen = false;
125
- this.isSessionOpen = false;
126
- el = this.languageItemsEl;
127
- }
128
- // For session menu
129
- if (type === "session") {
130
- this.isContactOpen = false;
131
- this.isLanguageOpen = false;
132
- this.isSegmentOpen = false;
133
- this.isSessionOpen = !this.isSessionOpen;
134
- el = this.sessionItemsEl;
135
- }
136
- // For contact menu
137
- else if (type === "contact") {
138
- this.isLanguageOpen = false;
139
- this.isContactOpen = !this.isContactOpen;
140
- this.isSegmentOpen = false;
141
- this.isSessionOpen = false;
142
- el = this.contactItemsEl;
143
- }
144
- // For mobile menu
145
- else if (type === "mobile") {
32
+ constructor() {
33
+ var _a;
34
+ /**
35
+ * Own Properties
36
+ */
37
+ this.subMenuItemRefs = {};
38
+ this.subMenuButtonRefs = {};
39
+ this.hasLanguageChanged = false;
40
+ this.mql = [window.matchMedia(media_query_large.replace(/'/g, ""))];
41
+ this.boundMqlFunctions = [];
42
+ this.handleClick = (event, moveFocusToButton = false) => {
43
+ if (event.data.analyticsId) {
44
+ this.duetAnalytics.emit({
45
+ component: "duet-header",
46
+ analyticsId: event.data.analyticsId,
47
+ });
48
+ }
49
+ this.duetChange.emit(event);
50
+ this.closeMenus(moveFocusToButton);
51
+ this.closeMobileNavigation(moveFocusToButton);
52
+ };
53
+ this.handleSessionClick = (ev) => {
54
+ const e = createEvent(ev, this.processedSession);
55
+ this.handleClick(e);
56
+ this.duetSessionClick.emit(e);
57
+ };
58
+ this.handleSessionItemClick = (ev, item) => {
59
+ const e = createEvent(ev, item);
60
+ this.handleClick(e);
61
+ this.duetSessionClick.emit(e);
62
+ };
63
+ this.handleSearchClick = (ev) => {
64
+ const e = createEvent(ev, this.processedSearch);
65
+ this.handleClick(e);
66
+ this.duetSearchClick.emit(e);
67
+ };
68
+ this.handleUserClick = (ev) => {
69
+ const e = createEvent(ev, this.processedUser);
70
+ this.handleClick(e);
71
+ this.duetUserClick.emit(e);
72
+ };
73
+ this.handleBackClick = (ev) => {
74
+ const e = createEvent(ev, this.processedBack);
75
+ this.handleClick(e);
76
+ this.duetBackClick.emit(e);
77
+ };
78
+ this.handleSkipClick = (ev) => {
79
+ const { skipLabel } = this.accessibleI18nLabels;
80
+ const e = createEvent(ev, { href: this.skipToId, label: skipLabel });
81
+ this.handleClick(e);
82
+ this.duetSkipClick.emit(e);
83
+ };
84
+ this.handleLogoClick = (ev) => {
85
+ const e = createEvent(ev, { href: this.logoHref, label: "logo" });
86
+ this.handleClick(e);
87
+ this.duetLogoClick.emit(e);
88
+ };
89
+ this.handleArrowKeys = ev => {
90
+ let button;
91
+ if (isArrowLeftKey(ev) || isArrowUpKey(ev)) {
92
+ button = ev.target.previousElementSibling;
93
+ }
94
+ else if (isArrowRightKey(ev) || isArrowDownKey(ev)) {
95
+ button = ev.target.nextElementSibling;
96
+ }
97
+ if (button) {
98
+ ev.preventDefault();
99
+ button.focus();
100
+ }
101
+ };
102
+ this.toggleMenu = (ev, type, id, active) => {
103
+ let el;
104
+ ev.preventDefault();
105
+ ev.stopPropagation();
106
+ if (active === true && !this.openMenu) {
107
+ const closedActives = this.closedActives ? [...this.closedActives] : [];
108
+ const index = closedActives.findIndex(i => i === id);
109
+ if (index > -1) {
110
+ closedActives.splice(index, 1);
111
+ this.closedActives = [...closedActives];
112
+ }
113
+ else {
114
+ this.closedActives = [...closedActives, id];
115
+ }
116
+ }
117
+ else {
118
+ this.openMenu = this.openMenu === id ? null : id;
119
+ }
120
+ // For language menu
121
+ if (type === "language") {
122
+ this.isContactOpen = false;
123
+ this.isLanguageOpen = !this.isLanguageOpen;
124
+ this.isSegmentOpen = false;
125
+ this.isSessionOpen = false;
126
+ el = this.languageItemsEl;
127
+ }
128
+ // For session menu
129
+ if (type === "session") {
130
+ this.isContactOpen = false;
131
+ this.isLanguageOpen = false;
132
+ this.isSegmentOpen = false;
133
+ this.isSessionOpen = !this.isSessionOpen;
134
+ el = this.sessionItemsEl;
135
+ }
136
+ // For contact menu
137
+ else if (type === "contact") {
138
+ this.isLanguageOpen = false;
139
+ this.isContactOpen = !this.isContactOpen;
140
+ this.isSegmentOpen = false;
141
+ this.isSessionOpen = false;
142
+ el = this.contactItemsEl;
143
+ }
144
+ // For mobile menu
145
+ else if (type === "mobile") {
146
+ this.isContactOpen = false;
147
+ this.isLanguageOpen = false;
148
+ this.isSegmentOpen = false;
149
+ this.isSessionOpen = false;
150
+ el = this.navigationEl;
151
+ const toggle = !this.isSlideOutOpen;
152
+ this.isSlideOutOpen = toggle;
153
+ this.duetMobileNavToggle.emit({ originalEvent: ev, open: toggle });
154
+ if (this.isSlideOutOpen) {
155
+ disableBodyScroll(this.navigationEl, { reserveScrollBarGap: true });
156
+ }
157
+ else {
158
+ enableBodyScroll(this.navigationEl);
159
+ }
160
+ }
161
+ else if (type === "sub") {
162
+ this.isContactOpen = false;
163
+ this.isLanguageOpen = false;
164
+ this.isSegmentOpen = false;
165
+ this.isSessionOpen = false;
166
+ el = this.subMenuItemRefs[id];
167
+ }
168
+ else if (type === "segment") {
169
+ this.isContactOpen = false;
170
+ this.isLanguageOpen = false;
171
+ this.isSessionOpen = false;
172
+ this.isSegmentOpen = !this.isSegmentOpen;
173
+ el = this.segmentItemsEl;
174
+ }
175
+ if (this.isSlideOutOpen ||
176
+ this.isLanguageOpen ||
177
+ this.isContactOpen ||
178
+ this.isSegmentOpen ||
179
+ this.isSessionOpen ||
180
+ this.openMenu) {
181
+ const drawer = this.element.querySelector("duet-notification-drawer");
182
+ if (drawer) {
183
+ drawer.close(false);
184
+ }
185
+ // Focus in the new menu when opened to make them more accessible
186
+ setTimeout(() => {
187
+ el.querySelector("a").focus();
188
+ }, 300);
189
+ }
190
+ };
191
+ this.emitDuetEvent = (ev, data) => {
192
+ this.duetEvent.emit({
193
+ component: "duet-header",
194
+ data,
195
+ originalEvent: ev,
196
+ });
197
+ };
146
198
  this.isContactOpen = false;
147
199
  this.isLanguageOpen = false;
148
- this.isSegmentOpen = false;
149
200
  this.isSessionOpen = false;
150
- el = this.navigationEl;
151
- const toggle = !this.isSlideOutOpen;
152
- this.isSlideOutOpen = toggle;
153
- this.duetMobileNavToggle.emit({ originalEvent: ev, open: toggle });
154
- if (this.isSlideOutOpen) {
155
- disableBodyScroll(this.navigationEl, { reserveScrollBarGap: true });
156
- }
157
- else {
158
- enableBodyScroll(this.navigationEl);
159
- }
160
- }
161
- else if (type === "sub") {
162
- this.isContactOpen = false;
163
- this.isLanguageOpen = false;
201
+ this.isSlideOutOpen = false;
164
202
  this.isSegmentOpen = false;
165
- this.isSessionOpen = false;
166
- el = this.subMenuItemRefs[id];
167
- }
168
- else if (type === "segment") {
169
- this.isContactOpen = false;
170
- this.isLanguageOpen = false;
171
- this.isSessionOpen = false;
172
- this.isSegmentOpen = !this.isSegmentOpen;
173
- el = this.segmentItemsEl;
174
- }
175
- if (this.isSlideOutOpen ||
176
- this.isLanguageOpen ||
177
- this.isContactOpen ||
178
- this.isSegmentOpen ||
179
- this.isSessionOpen ||
180
- this.openMenu) {
181
- const drawer = this.element.querySelector("duet-notification-drawer");
182
- if (drawer) {
183
- drawer.close(false);
184
- }
185
- // Focus in the new menu when opened to make them more accessible
186
- setTimeout(() => {
187
- el.querySelector("a").focus();
188
- }, 300);
189
- }
190
- };
191
- this.emitDuetEvent = (ev, data) => {
192
- this.duetEvent.emit({
193
- component: "duet-header",
194
- data,
195
- originalEvent: ev,
196
- });
197
- };
198
- this.isContactOpen = false;
199
- this.isLanguageOpen = false;
200
- this.isSessionOpen = false;
201
- this.isSlideOutOpen = false;
202
- this.isSegmentOpen = false;
203
- this.openMenu = null;
204
- this.closedActives = null;
205
- this.processedItems = null;
206
- this.processedLanguageItems = null;
207
- this.processedContactItems = null;
208
- this.processedSession = null;
209
- this.processedSearch = null;
210
- this.processedUser = null;
211
- this.processedBack = null;
212
- this.renderDesktopNav = Build.isServer ? true : (_a = this.mql[0]) === null || _a === void 0 ? void 0 : _a.matches;
213
- this.theme = "";
214
- this.language = getLanguage();
215
- this.accessibleI18nLabelsDefaults = {
216
- fi: {
217
- skipLabel: "Siirry pääsisältöön",
218
- changeLanguage: "Vaihda kieltä",
219
- activeLanguage: "Suomi valittuna",
220
- },
221
- sv: {
222
- skipLabel: "Gå till huvudinnehåll",
223
- changeLanguage: "Ändra Språk",
224
- activeLanguage: "Svenska valt",
225
- },
226
- en: {
227
- skipLabel: "Skip to main content",
228
- changeLanguage: "Change language",
229
- activeLanguage: "English selected",
230
- },
231
- };
232
- this.accessibleI18nLabels = getLocaleString(this.accessibleI18nLabelsDefaults);
233
- this.accessibleLabelExternalDefaults = DuetStringsExternalDefaults;
234
- this.accessibleLabelExternal = getLocaleString(this.accessibleLabelExternalDefaults);
235
- this.accessibleLabelDefaults = {
236
- fi: "Valikko",
237
- sv: "Meny",
238
- en: "Menu",
239
- };
240
- this.accessibleLabel = getLocaleString(this.accessibleLabelDefaults);
241
- this.user = undefined;
242
- this.logoHref = "/";
243
- this.currentHref = "/";
244
- this.skipToId = "";
245
- this.items = undefined;
246
- this.region = "";
247
- this.session = undefined;
248
- this.search = undefined;
249
- this.back = undefined;
250
- this.contact = "";
251
- this.contactItems = undefined;
252
- this.languageItems = undefined;
253
- }
254
- /**
255
- * Component lifecycle events.
256
- */
257
- componentWillLoad() {
258
- inheritGlobalTheme(this);
259
- this.refresh();
260
- }
261
- connectedCallback() {
262
- for (let i = 0; i < this.mql.length; i++) {
263
- // addEventListener is not available in Stencil hydrate
264
- if (this.mql[i].addEventListener) {
265
- const bound = this.refresh.bind(this);
266
- this.mql[i].addEventListener("change", bound);
267
- this.boundMqlFunctions[i] = bound;
268
- }
269
- }
270
- connectLanguageChangeObserver(this, [
271
- { prop: "accessibleLabel", defaults: "accessibleLabelDefaults" },
272
- { prop: "accessibleI18nLabels", defaults: "accessibleI18nLabelsDefaults" },
273
- { prop: "accessibleLabelExternal", defaults: "accessibleLabelExternalDefaults" },
274
- ]);
275
- }
276
- disconnectedCallback() {
277
- if (this.navigationEl) {
278
- enableBodyScroll(this.navigationEl);
279
- }
280
- for (let i = 0; i < this.mql.length; i++) {
281
- // addEventListener is not available in Stencil hydrate
282
- if (this.mql[i].removeEventListener) {
283
- this.mql[i].removeEventListener("change", this.boundMqlFunctions[i]);
284
- }
203
+ this.openMenu = null;
204
+ this.closedActives = null;
205
+ this.processedItems = null;
206
+ this.processedLanguageItems = null;
207
+ this.processedContactItems = null;
208
+ this.processedSession = null;
209
+ this.processedSearch = null;
210
+ this.processedUser = null;
211
+ this.processedBack = null;
212
+ this.renderDesktopNav = Build.isServer ? true : (_a = this.mql[0]) === null || _a === void 0 ? void 0 : _a.matches;
213
+ this.theme = "";
214
+ this.language = getLanguage();
215
+ this.accessibleI18nLabelsDefaults = {
216
+ fi: {
217
+ skipLabel: "Siirry pääsisältöön",
218
+ changeLanguage: "Vaihda kieltä",
219
+ activeLanguage: "Suomi valittuna",
220
+ },
221
+ sv: {
222
+ skipLabel: "Gå till huvudinnehåll",
223
+ changeLanguage: "Ändra Språk",
224
+ activeLanguage: "Svenska valt",
225
+ },
226
+ en: {
227
+ skipLabel: "Skip to main content",
228
+ changeLanguage: "Change language",
229
+ activeLanguage: "English selected",
230
+ },
231
+ };
232
+ this.accessibleI18nLabels = getLocaleString(this.accessibleI18nLabelsDefaults);
233
+ this.accessibleLabelExternalDefaults = DuetStringsExternalDefaults;
234
+ this.accessibleLabelExternal = getLocaleString(this.accessibleLabelExternalDefaults);
235
+ this.accessibleLabelDefaults = {
236
+ fi: "Valikko",
237
+ sv: "Meny",
238
+ en: "Menu",
239
+ };
240
+ this.accessibleLabel = getLocaleString(this.accessibleLabelDefaults);
241
+ this.user = undefined;
242
+ this.logoHref = "/";
243
+ this.currentHref = "/";
244
+ this.skipToId = "";
245
+ this.items = undefined;
246
+ this.region = "";
247
+ this.session = undefined;
248
+ this.search = undefined;
249
+ this.back = undefined;
250
+ this.contact = "";
251
+ this.contactItems = undefined;
252
+ this.languageItems = undefined;
285
253
  }
286
- this.boundMqlFunctions = [];
287
- disconnectLanguageChangeObserver(this);
288
- }
289
- /**
290
- * Component event handling.
291
- */
292
- handleKeyUp(ev) {
293
- // When Esc is pressed
294
- if (isEscapeKey(ev)) {
295
- this.closeMenus(true);
296
- this.closeMobileNavigation(true);
254
+ /**
255
+ * Component lifecycle events.
256
+ */
257
+ componentWillLoad() {
258
+ inheritGlobalTheme(this);
259
+ this.refresh();
297
260
  }
298
- }
299
- handleKeyDown(ev) {
300
- if (this.isContactOpen || this.isLanguageOpen || this.isSegmentOpen) {
301
- const activeElement = this.element.shadowRoot.activeElement;
302
- // When Space is pressed
303
- if (isSpaceKey(ev) && activeElement) {
304
- ev.preventDefault();
305
- ev.stopPropagation();
306
- if (this.isContactOpen) {
307
- this.closeMenus();
261
+ connectedCallback() {
262
+ for (let i = 0; i < this.mql.length; i++) {
263
+ // addEventListener is not available in Stencil hydrate
264
+ if (this.mql[i].addEventListener) {
265
+ const bound = this.refresh.bind(this);
266
+ this.mql[i].addEventListener("change", bound);
267
+ this.boundMqlFunctions[i] = bound;
268
+ }
308
269
  }
309
- else if (this.isLanguageOpen) {
310
- this.closeMenus(true);
270
+ connectLanguageChangeObserver(this, [
271
+ { prop: "accessibleLabel", defaults: "accessibleLabelDefaults" },
272
+ { prop: "accessibleI18nLabels", defaults: "accessibleI18nLabelsDefaults" },
273
+ { prop: "accessibleLabelExternal", defaults: "accessibleLabelExternalDefaults" },
274
+ ]);
275
+ subscribeTabbingChange(this);
276
+ }
277
+ disconnectedCallback() {
278
+ if (this.navigationEl) {
279
+ enableBodyScroll(this.navigationEl);
311
280
  }
312
- else if (this.isSegmentOpen) {
313
- this.closeMenus();
281
+ for (let i = 0; i < this.mql.length; i++) {
282
+ // addEventListener is not available in Stencil hydrate
283
+ if (this.mql[i].removeEventListener) {
284
+ this.mql[i].removeEventListener("change", this.boundMqlFunctions[i]);
285
+ }
314
286
  }
315
- else if (this.openMenu) {
316
- this.closeMenus();
287
+ this.boundMqlFunctions = [];
288
+ disconnectLanguageChangeObserver(this);
289
+ unsubscribeTabbingChange(this);
290
+ }
291
+ /**
292
+ * Component event handling.
293
+ */
294
+ handleKeyUp(ev) {
295
+ // When Esc is pressed
296
+ if (isEscapeKey(ev)) {
297
+ this.closeMenus(true);
298
+ this.closeMobileNavigation(true);
317
299
  }
318
- activeElement.click();
319
- }
320
300
  }
321
- }
322
- handleDocumentClick() {
323
- this.closeMenus();
324
- this.closeMobileNavigation();
325
- }
326
- handleLanguageClick(ev, data) {
327
- this.language = data.country;
328
- this.hasLanguageChanged = true;
329
- const e = createEvent(ev, data);
330
- this.handleClick(e, true);
331
- this.duetLanguageSelect.emit(e);
332
- }
333
- handleContactClick(ev, data) {
334
- const e = createEvent(ev, data);
335
- this.handleClick(e);
336
- this.duetContactClick.emit(e);
337
- }
338
- handleItemClick(ev, data) {
339
- const e = createEvent(ev, data);
340
- this.handleClick(e);
341
- this.duetItemClick.emit(e);
342
- }
343
- /**
344
- * Local methods.
345
- */
346
- async refresh() {
347
- var _a, _b;
348
- if (this.renderDesktopNav !== Build.isServer ? true : (_a = this.mql[0]) === null || _a === void 0 ? void 0 : _a.matches) {
349
- this.renderDesktopNav = Build.isServer ? true : (_b = this.mql[0]) === null || _b === void 0 ? void 0 : _b.matches;
350
- this.openMenu = null;
351
- if (this.isSlideOutOpen) {
352
- this.toggleMenu(document.createEvent("UIEvents"), "mobile");
353
- }
301
+ handleKeyDown(ev) {
302
+ if (this.isContactOpen || this.isLanguageOpen || this.isSegmentOpen) {
303
+ const activeElement = this.element.shadowRoot.activeElement;
304
+ // When Space is pressed
305
+ if (isSpaceKey(ev) && activeElement) {
306
+ ev.preventDefault();
307
+ ev.stopPropagation();
308
+ if (this.isContactOpen) {
309
+ this.closeMenus();
310
+ }
311
+ else if (this.isLanguageOpen) {
312
+ this.closeMenus(true);
313
+ }
314
+ else if (this.isSegmentOpen) {
315
+ this.closeMenus();
316
+ }
317
+ else if (this.openMenu) {
318
+ this.closeMenus();
319
+ }
320
+ activeElement.click();
321
+ }
322
+ }
354
323
  }
355
- this.processedItems = parsePossibleJSON(this.items);
356
- this.processedLanguageItems = parsePossibleJSON(this.languageItems);
357
- this.processedContactItems = parsePossibleJSON(this.contactItems);
358
- this.processedSession = parsePossibleJSON(this.session);
359
- this.processedSearch = parsePossibleJSON(this.search);
360
- this.processedUser = parsePossibleJSON(this.user);
361
- this.processedBack = parsePossibleJSON(this.back);
362
- }
363
- /**
364
- * Closes mobile menu in header when called.
365
- */
366
- async closeMobileNavigation(moveFocusToButton = false) {
367
- if (this.isSlideOutOpen) {
368
- this.isSlideOutOpen = false;
369
- enableBodyScroll(this.navigationEl);
370
- if (moveFocusToButton) {
371
- this.navigationElButton.focus({
372
- preventScroll: true,
373
- });
374
- }
324
+ handleDocumentClick() {
325
+ this.closeMenus();
326
+ this.closeMobileNavigation();
375
327
  }
376
- }
377
- /**
378
- * Closes all dropdown menus in header when called.
379
- */
380
- async closeMenus(moveFocusToButton = false) {
381
- if (this.isContactOpen || this.isLanguageOpen || this.isSegmentOpen || this.isSessionOpen || this.openMenu) {
382
- if (this.isContactOpen && moveFocusToButton) {
383
- this.contactItemsButtonEl.focus({
384
- preventScroll: true,
385
- });
386
- }
387
- if (this.isLanguageOpen && moveFocusToButton) {
388
- this.languageItemsButtonEl.focus({
389
- preventScroll: true,
390
- });
391
- }
392
- if (this.isSegmentOpen && moveFocusToButton) {
393
- this.segmentItemsButtonEl.focus({
394
- preventScroll: true,
395
- });
396
- }
397
- if (this.isSessionOpen && moveFocusToButton) {
398
- this.sessionItemsButtonEl.focus({
399
- preventScroll: true,
400
- });
401
- }
402
- if (this.openMenu && moveFocusToButton) {
403
- this.subMenuButtonRefs[this.openMenu].focus({
404
- preventScroll: true,
405
- });
406
- }
407
- this.isContactOpen = false;
408
- this.isLanguageOpen = false;
409
- this.isSegmentOpen = false;
410
- this.isSessionOpen = false;
411
- this.openMenu = null;
328
+ handleLanguageClick(ev, data) {
329
+ this.language = data.country;
330
+ this.hasLanguageChanged = true;
331
+ const e = createEvent(ev, data);
332
+ this.handleClick(e, true);
333
+ this.duetLanguageSelect.emit(e);
412
334
  }
413
- }
414
- /**
415
- * Sets focus on the specified `duet-header`. Use this method instead of the global
416
- * `header.focus()`.
417
- */
418
- async setFocus(options) {
419
- this.logoEl.setFocus(options);
420
- }
421
- /**
422
- * render() function
423
- * Always the last one in the class.
424
- */
425
- render() {
426
- const { skipLabel, changeLanguage, activeLanguage } = this.accessibleI18nLabels;
427
- const skipToLabel = () => this.skipToId ? (h("a", { href: this.skipToId, class: "duet-header-skip", onClick: this.handleSkipClick }, skipLabel)) : null;
428
- const logo = () => (h("duet-logo", { href: this.logoHref, size: "medium", ref: el => (this.logoEl = el), language: this.language, theme: this.theme, onClick: this.handleLogoClick }));
429
- const largeLogo = () => (h("duet-logo", { href: this.logoHref, size: "large", ref: el => (this.logoEl = el), language: this.language, theme: this.theme, onClick: this.handleLogoClick }));
430
- const contactDropdown = () => this.contact && this.processedContactItems ? (h(DuetHeaderDropdown, { id: "duet-header-contact", label: this.contact, icon: contactDropdownIcon.svg, active: this.isContactOpen, isOpen: this.isContactOpen, badge: false, toggleRef: el => (this.contactItemsButtonEl = el), itemsRef: el => (this.contactItemsEl = el), onToggle: event => this.toggleMenu(event, "contact") }, this.processedContactItems.map(item => (h("a", { role: "menuitem", href: item.href || "#", id: item.id, onClick: event => this.handleContactClick(event, item), onKeyDown: ev => this.handleArrowKeys(ev), target: item.external ? "_blank" : "_self" }, item.label, Build.isBrowser && item.external && (h(Fragment, null, h("duet-visually-hidden", null, ", ", this.accessibleLabelExternal), h("span", { class: "duet-header-link-external" }, h("duet-icon", { name: "action-new-window-small", size: "xx-small", margin: "none", color: this.theme === "turva" ? "primary-turva" : "primary" }))))))))) : null;
431
- const languageDropdown = () => this.language && this.processedLanguageItems ? (h(DuetHeaderDropdown, { id: "duet-header-language", label: this.language, icon: languageIcon.svg, accessibleText: `${changeLanguage}${this.hasLanguageChanged ? `, ${activeLanguage}` : ""}`, active: this.isLanguageOpen, isOpen: this.isLanguageOpen, badge: false, toggleRef: el => (this.languageItemsButtonEl = el), itemsRef: el => (this.languageItemsEl = el), onToggle: event => this.toggleMenu(event, "language") }, this.processedLanguageItems.map(item => (h("a", { class: { active: this.language === item.country }, "aria-selected": this.language === item.country, role: "menuitem", id: item.id, lang: item.country, href: item.href || "#", onClick: event => this.handleLanguageClick(event, item), onKeyDown: this.handleArrowKeys }, item.label))))) : null;
432
- const processedUserWithLink = () => this.processedUser && this.processedUser.href ? (h("a", { href: this.processedUser.href || "#", id: this.processedUser.id, class: "duet-header-user duet-header-button", onClick: this.handleUserClick }, h(DuetHeaderIcon, { icon: userIcon.svg }), h("span", { class: "duet-header-user-label" }, this.processedUser.label))) : null;
433
- const processedUserWithoutLink = () => this.processedUser && !this.processedUser.href ? (h("span", { id: this.processedUser.id, class: "duet-header-user duet-header-button duet-header-no-action" }, h(DuetHeaderIcon, { icon: userIcon.svg }), h("span", { class: "duet-header-user-label" }, this.processedUser.label))) : null;
434
- const processedSession = () => this.processedSession ? (h("a", { href: this.processedSession.href || "#", id: this.processedSession.id, class: "duet-header-logout duet-header-button", onClick: this.handleSessionClick }, h(DuetHeaderIcon, { class: "desktop", icon: this.processedSession.type === "logout" ? logoutIcon.svg : loginIcon.svg, iconSize: "x-small" }), h(DuetHeaderIcon, { class: "mobile", icon: this.processedSession.type === "logout" ? logoutIcon.svg : loginIcon.svg, iconSize: "small" }), h("span", { class: "duet-header-button-label" }, this.processedSession.label))) : null;
435
- const processedSessionDropdown = () => this.processedSession && this.processedSession.sessionItems ? (h(DuetHeaderDropdown, { className: "duet-header-session", id: "duet-header-session", label: this.processedSession.label, icon: this.processedSession.type === "logout" ? logoutIcon.svg : loginIcon.svg, active: this.isSessionOpen, isOpen: this.isSessionOpen, badge: false, toggleRef: el => (this.sessionItemsButtonEl = el), itemsRef: el => (this.sessionItemsEl = el), onToggle: event => this.toggleMenu(event, "session") }, this.processedSession.sessionItems.map((sessionItem, index) => (h(Fragment, null, sessionItem.label && h("span", { class: "duet-header-session-label" }, sessionItem.label), h("duet-spacer", { size: "small", "aria-hidden": "true" }), sessionItem.items.map(item => (h("a", { role: "menuitem", "aria-label": sessionItem.label ? `${sessionItem.label} ${item.label}` : item.label, id: item.id, href: item.href || "#", onClick: event => this.handleSessionItemClick(event, item), onKeyDown: this.handleArrowKeys }, item.label))), index !== this.processedSession.sessionItems.length - 1 && (h(Fragment, null, h("duet-spacer", { size: "x-small", "aria-hidden": "true" }), h("duet-divider", { margin: "none", "aria-hidden": "true" })))))))) : null;
436
- const processedSearch = () => this.processedSearch ? (h("a", { href: this.processedSearch.href || "#", id: this.processedSearch.id, class: "duet-header-search duet-header-button", onClick: this.handleSearchClick }, h(DuetHeaderIcon, { icon: searchIcon.svg }), h("span", { class: "duet-header-button-label" }, this.processedSearch.label))) : null;
437
- // Back variation
438
- if (this.processedBack) {
439
- return (h(Host, { class: "duet-header-back-variation" }, h("div", { class: "duet-header-reserved-space" }, h("header", { class: {
440
- "duet-header": true,
441
- "duet-theme-turva": this.theme === "turva",
442
- "duet-header-back": true,
443
- "duet-header-inactive": true,
444
- }, part: "header" }, h("div", { class: "duet-header-top" }, skipToLabel(), h("duet-button", { url: this.processedBack.href, id: this.processedBack.id, theme: this.theme, variation: "plain", color: this.theme === "turva" ? "secondary-turva" : "secondary", icon: "navigation-arrow-left", iconSize: "large", onClick: this.handleBackClick }, this.processedBack.label), logo(), h("slot", { name: "logo-utility" }))))));
335
+ handleContactClick(ev, data) {
336
+ const e = createEvent(ev, data);
337
+ this.handleClick(e);
338
+ this.duetContactClick.emit(e);
445
339
  }
446
- const itemsHaveSubItems = this.processedItems && this.processedItems.some(item => item.items && item.items.length > 0);
447
- const isSecondLevelActive = this.processedItems &&
448
- this.processedItems.some(item => item.items && item.items.some(secondLevelItem => secondLevelItem.active === true));
449
- const isThirdLevelActive = this.processedItems &&
450
- this.processedItems.some(item => item.items &&
451
- item.items.some(secondLevelItem => secondLevelItem.items && secondLevelItem.items.some(thirdLevelItem => thirdLevelItem.active === true)));
452
- const defaultVariationContent = (h("div", { class: {
453
- "duet-header-reserved-space": true,
454
- "duet-with-links": !!this.processedItems,
455
- "duet-header-second-level-active": isSecondLevelActive,
456
- "duet-header-third-level-active": isThirdLevelActive,
457
- "duet-header-items-have-sub-items": itemsHaveSubItems,
458
- } }, h("header", { class: {
459
- "duet-header": true,
460
- "duet-theme-turva": this.theme === "turva",
461
- "duet-header-inactive": !this.processedItems,
462
- }, part: "header" }, h("div", { class: "duet-header-top" }, skipToLabel(), logo(), h("slot", { name: "logo-utility" }, this.region && h("div", { class: "duet-header-region" }, this.region)), (this.processedItems ||
463
- languageDropdown() ||
464
- contactDropdown() ||
465
- this.processedSession ||
466
- this.processedUser) && (h("button", { ref: el => (this.navigationElButton = el), class: { "duet-header-toggle": true, active: this.isSlideOutOpen }, onClick: event => this.toggleMenu(event, "mobile"), type: "button", "aria-controls": "duet-header-bottom", "aria-expanded": this.isSlideOutOpen ? "true" : "false" }, h("duet-visually-hidden", null, this.accessibleLabel), h(DuetHeaderHamburger, null)))), h("div", { ref: el => (this.navigationEl = el), id: "duet-header-bottom", class: {
467
- "duet-header-bottom": true,
468
- active: this.isSlideOutOpen,
469
- inactive: !this.processedItems,
470
- } }, h("nav", { class: "duet-header-items", role: "navigation" }, this.processedItems &&
471
- this.processedItems.map((item, itemIndex) => (h("div", { class: "duet-header-item-container" }, h("a", { class: {
472
- "duet-header-first-level": true,
473
- "duet-header-item": true,
474
- active: (!itemsHaveSubItems && this.currentHref === item.href) ||
475
- (item.active === true &&
476
- !this.openMenu &&
477
- this.closedActives &&
478
- this.closedActives.length === 1) ||
479
- (item.active === true &&
480
- !this.openMenu &&
481
- item.items &&
482
- !item.items.some(s => s.active === true)),
483
- }, href: item.href || "#", id: item.id || `header-item-${itemIndex}`, onClick: event => this.handleItemClick(event, item), onMouseEnter: event => this.emitDuetEvent(event, item), onTouchStart: event => this.emitDuetEvent(event, item) }, item.label, item.badge && h("div", { class: "duet-header-badge" })), item.items &&
484
- item.items
485
- .filter(secondLevelitem => secondLevelitem.items && secondLevelitem.items.length > 0)
486
- .map((secondLevelItem, secondLevelItemIndex) => {
487
- const id = secondLevelItem.id || `header-item-${itemIndex}-${secondLevelItemIndex}`;
488
- const active = (!this.openMenu &&
489
- secondLevelItem.active === true &&
490
- !(this.closedActives && !!this.closedActives.find(i => i === id))) ||
491
- this.openMenu === id;
492
- const activeBar = active && !(secondLevelItem.items && secondLevelItem.items.some(s => s.active === true));
493
- return (h(DuetHeaderDropdown, { id: id, className: "duet-header-second-level", label: secondLevelItem.label, icon: `${secondLevelItem.icon}.svg`, active: activeBar, isOpen: active, badge: secondLevelItem.badge, toggleRef: el => (this.subMenuButtonRefs[id] = el), itemsRef: el => (this.subMenuItemRefs[id] = el), onToggle: event => this.toggleMenu(event, "sub", id, secondLevelItem.active === true) }, h("div", { class: "duet-header-third-level" }, secondLevelItem.items &&
494
- secondLevelItem.items.map(thirdLevelItem => (h("a", { class: {
495
- "duet-header-item": true,
496
- active: thirdLevelItem.active === true,
497
- }, role: "menuitem", href: thirdLevelItem.href || "#", id: thirdLevelItem.id, onClick: event => this.handleItemClick(event, thirdLevelItem), onKeyDown: ev => this.handleArrowKeys(ev), onMouseEnter: event => this.emitDuetEvent(event, thirdLevelItem), onTouchStart: event => this.emitDuetEvent(event, thirdLevelItem), target: thirdLevelItem.external ? "_blank" : "_self" }, thirdLevelItem.icon && (h("div", { class: "duet-header-icon" }, h("duet-icon", { margin: "none", size: "medium", name: thirdLevelItem.icon, color: "currentColor" }))), h("span", null, thirdLevelItem.label), thirdLevelItem.badge && h("div", { class: "duet-header-badge" })))))));
498
- }))))), h("div", { class: "duet-header-bottom-utils" }, h("slot", { name: "utility" })), h("div", { class: "duet-header-utils" }, !itemsHaveSubItems && contactDropdown(), languageDropdown(), !itemsHaveSubItems && (h(Fragment, null, processedUserWithLink(), processedUserWithoutLink())), processedSearch(), processedSession())))));
499
- // multi level variation
500
- if (itemsHaveSubItems) {
501
- const activeSegment = this.processedItems.find(item => item.active);
502
- const isThirdLevelActive = this.processedItems &&
503
- this.processedItems.some(item => item.items &&
504
- item.items.some(secondLevelItem => secondLevelItem.items && secondLevelItem.items.some(thirdLevelItem => thirdLevelItem.active === true)));
505
- const segmentId = "duet-header-segment";
506
- return (h(Host, { class: "duet-header-multi-level-variation" }, h("div", { class: {
507
- "duet-header-multi-level": true,
508
- "duet-header-multi-level-third-level-is-open": isThirdLevelActive,
509
- } }, h("header", { class: {
510
- "duet-header": true,
511
- "duet-theme-turva": this.theme === "turva",
512
- "duet-header-inactive": !this.processedItems,
513
- }, part: "header" }, h("div", { class: "duet-header-top" }, skipToLabel(), h("div", { class: "logo-and-segment" }, h("div", null, largeLogo()), this.processedItems && (h(DuetHeaderDropdown, { id: segmentId, label: activeSegment.label, active: this.isSegmentOpen, isOpen: this.isSegmentOpen, badge: false, toggleRef: el => (this.segmentItemsButtonEl = el), itemsRef: el => (this.segmentItemsEl = el), onToggle: event => this.toggleMenu(event, "segment") }, this.processedItems.map(item => (h("a", { class: { active: activeSegment === item }, role: "menuitem", href: item.href || "#", id: item.id, onClick: event => this.handleItemClick(event, item), onKeyDown: ev => this.handleArrowKeys(ev), onMouseEnter: event => this.emitDuetEvent(event, item), onTouchStart: event => this.emitDuetEvent(event, item), target: item.external ? "_blank" : "_self" }, item.icon && (h("div", { class: "duet-header-icon" }, h("duet-icon", { margin: "none", size: "x-small", name: item.icon, color: "currentColor" }))), h("span", null, item.label), item.badge && h("div", { class: "duet-header-badge" }))))))), h("nav", { class: "duet-header-multi-level-nav" }, activeSegment.items &&
514
- activeSegment.items
515
- .filter(secondLevelItem => secondLevelItem.items && secondLevelItem.items.length > 0)
516
- .map((secondLevelItem, secondLevelItemIndex) => {
517
- const id = secondLevelItem.id || `segment-item-${secondLevelItemIndex}`;
518
- return (h(DuetHeaderDropdown, { id: id, label: secondLevelItem.label, active: (!this.openMenu && secondLevelItem.active === true) || this.openMenu === id, isOpen: this.openMenu === id, badge: secondLevelItem.badge, toggleRef: el => (this.subMenuButtonRefs[id] = el), itemsRef: el => (this.subMenuItemRefs[id] = el), onToggle: event => this.toggleMenu(event, "sub", id) }, secondLevelItem.items &&
519
- secondLevelItem.items.map(thirdLevelItem => (h("a", { class: { active: thirdLevelItem.active }, role: "menuitem", href: thirdLevelItem.href || "#", id: thirdLevelItem.id, onClick: event => this.handleItemClick(event, thirdLevelItem), onKeyDown: ev => this.handleArrowKeys(ev), onMouseEnter: event => this.emitDuetEvent(event, thirdLevelItem), onTouchStart: event => this.emitDuetEvent(event, thirdLevelItem), target: thirdLevelItem.external ? "_blank" : "_self" }, thirdLevelItem.icon && (h("div", { class: "duet-header-icon" }, h("duet-icon", { margin: "none", size: "medium", name: thirdLevelItem.icon, color: "currentColor" }))), h("span", null, thirdLevelItem.label), thirdLevelItem.badge && h("div", { class: "duet-header-badge" }))))));
520
- })), h("div", { class: "duet-header-multi-level-utils" }, processedSearch(), languageDropdown(), processedSessionDropdown() != null ? processedSessionDropdown() : processedSession()), h("slot", { name: "utility" })))), defaultVariationContent));
340
+ handleItemClick(ev, data) {
341
+ const e = createEvent(ev, data);
342
+ this.handleClick(e);
343
+ this.duetItemClick.emit(e);
521
344
  }
522
- // Default variation
523
- return (h(Host, { class: {
524
- "duet-header-default-variation": true,
525
- } }, defaultVariationContent));
526
- }
527
- static get is() { return "duet-header"; }
528
- static get encapsulation() { return "shadow"; }
529
- static get originalStyleUrls() {
530
- return {
531
- "$": ["duet-header.scss"]
532
- };
533
- }
534
- static get styleUrls() {
535
- return {
536
- "$": ["duet-header.css"]
537
- };
538
- }
539
- static get properties() {
540
- return {
541
- "theme": {
542
- "type": "string",
543
- "mutable": true,
544
- "complexType": {
545
- "original": "DuetTheme",
546
- "resolved": "\"\" | \"default\" | \"turva\"",
547
- "references": {
548
- "DuetTheme": {
549
- "location": "import",
550
- "path": "../../common-types",
551
- "id": "src/common-types.d.ts::DuetTheme"
552
- }
553
- }
554
- },
555
- "required": false,
556
- "optional": false,
557
- "docs": {
558
- "tags": [],
559
- "text": "Theme of the header."
560
- },
561
- "attribute": "theme",
562
- "reflect": false,
563
- "defaultValue": "\"\""
564
- },
565
- "language": {
566
- "type": "string",
567
- "mutable": true,
568
- "complexType": {
569
- "original": "DuetLanguage",
570
- "resolved": "\"en\" | \"fi\" | \"sv\"",
571
- "references": {
572
- "DuetLanguage": {
573
- "location": "import",
574
- "path": "../../common-types",
575
- "id": "src/common-types.d.ts::DuetLanguage"
576
- }
577
- }
578
- },
579
- "required": false,
580
- "optional": false,
581
- "docs": {
582
- "tags": [{
583
- "name": "deprecated",
584
- "text": "this is now handled via the html lang tag, and is no longer used - kept to avoid breaking changes and ease unit testing"
585
- }, {
586
- "name": "default",
587
- "text": "\"fi\""
588
- }],
589
- "text": "The currently active language. This setting also changes the logo to match\nthe chosen language."
590
- },
591
- "attribute": "language",
592
- "reflect": false,
593
- "defaultValue": "getLanguage()"
594
- },
595
- "accessibleI18nLabelsDefaults": {
596
- "type": "string",
597
- "mutable": false,
598
- "complexType": {
599
- "original": "| string\n | Record<DuetLanguage, I18nText>",
600
- "resolved": "string | { fi: I18nText; en: I18nText; sv: I18nText; }",
601
- "references": {
602
- "Record": {
603
- "location": "global",
604
- "id": "global::Record"
605
- },
606
- "DuetLanguage": {
607
- "location": "import",
608
- "path": "../../common-types",
609
- "id": "src/common-types.d.ts::DuetLanguage"
610
- },
611
- "I18nText": {
612
- "location": "local",
613
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
614
- "id": "src/components/duet-header/duet-header.tsx::I18nText"
615
- }
616
- }
617
- },
618
- "required": false,
619
- "optional": false,
620
- "docs": {
621
- "tags": [{
622
- "name": "default",
623
- "text": "{\nfi: {\nskipLabel: \"Siirry p\u00E4\u00E4sis\u00E4lt\u00F6\u00F6n\",\nchangeLanguage: \"Vaihda kielt\u00E4\",\nactiveLanguage: \"Suomi valittuna\",\n},\nsv: {\nskipLabel: \"Hoppa till huvudinneh\u00E5ll\",\nchangeLanguage: \"\u00C4ndra Spr\u00E5k\",\nactiveLanguage: \"Svenska valt\",\n},\nen: {\nskipLabel: \"Skip to main content\",\nchangeLanguage: \"Change language\",\nactiveLanguage: \"English selected\",\n},\n}"
624
- }],
625
- "text": "Default strings for accessibleI18nLabels"
626
- },
627
- "attribute": "accessible-labels-default",
628
- "reflect": false,
629
- "defaultValue": "{\n fi: {\n skipLabel: \"Siirry p\u00E4\u00E4sis\u00E4lt\u00F6\u00F6n\",\n changeLanguage: \"Vaihda kielt\u00E4\",\n activeLanguage: \"Suomi valittuna\",\n },\n sv: {\n skipLabel: \"G\u00E5 till huvudinneh\u00E5ll\",\n changeLanguage: \"\u00C4ndra Spr\u00E5k\",\n activeLanguage: \"Svenska valt\",\n },\n en: {\n skipLabel: \"Skip to main content\",\n changeLanguage: \"Change language\",\n activeLanguage: \"English selected\",\n },\n }"
630
- },
631
- "accessibleI18nLabels": {
632
- "type": "unknown",
633
- "mutable": true,
634
- "complexType": {
635
- "original": "I18nText",
636
- "resolved": "I18nText",
637
- "references": {
638
- "I18nText": {
639
- "location": "local",
640
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
641
- "id": "src/components/duet-header/duet-header.tsx::I18nText"
642
- }
643
- }
644
- },
645
- "required": false,
646
- "optional": false,
647
- "docs": {
648
- "tags": [{
649
- "name": "default",
650
- "text": "{\nfi: {\nskipLabel: \"Siirry p\u00E4\u00E4sis\u00E4lt\u00F6\u00F6n\",\nchangeLanguage: \"Vaihda kielt\u00E4\",\nactiveLanguage: \"Suomi valittuna\",\n},\nsv: {\nskipLabel: \"Hoppa till huvudinneh\u00E5ll\",\nchangeLanguage: \"\u00C4ndra Spr\u00E5k\",\nactiveLanguage: \"Svenska valt\",\n},\nen: {\nskipLabel: \"Skip to main content\",\nchangeLanguage: \"Change language\",\nactiveLanguage: \"English selected\",\n},\n}"
651
- }],
652
- "text": "Adds i18n translations of all internally used textStrings"
653
- },
654
- "defaultValue": "getLocaleString(\n this.accessibleI18nLabelsDefaults\n )"
655
- },
656
- "accessibleLabelExternalDefaults": {
657
- "type": "string",
658
- "mutable": false,
659
- "complexType": {
660
- "original": "DuetLangObject | string",
661
- "resolved": "DuetLangObject | string",
662
- "references": {
663
- "DuetLangObject": {
664
- "location": "import",
665
- "path": "../../utils/language-utils",
666
- "id": "src/utils/language-utils.ts::DuetLangObject"
667
- }
668
- }
669
- },
670
- "required": false,
671
- "optional": false,
672
- "docs": {
673
- "tags": [{
674
- "name": "default",
675
- "text": "{fi: \"Avautuu uuteen ikkunaan\",sv: \"\u00D6ppnas i nytt f\u00F6nster\",en: \"Opens in a new window\"}"
676
- }],
677
- "text": "Property to change accessibleLabelExternal defaults on the component.\nnormally you would handle these strings on an application level and override accessibleLabelExternal when needed"
678
- },
679
- "attribute": "accessible-label-external-default",
680
- "reflect": false,
681
- "defaultValue": "DuetStringsExternalDefaults"
682
- },
683
- "accessibleLabelExternal": {
684
- "type": "string",
685
- "mutable": true,
686
- "complexType": {
687
- "original": "string",
688
- "resolved": "string",
689
- "references": {}
690
- },
691
- "required": false,
692
- "optional": false,
693
- "docs": {
694
- "tags": [{
695
- "name": "default",
696
- "text": "{fi: \"Avautuu uuteen ikkunaan\",sv: \"\u00D6ppnas i nytt f\u00F6nster\",en: \"Opens in a new window\"}"
697
- }],
698
- "text": "Adds accessible label for tooltip that is shown in external link (url & external have both been set)"
699
- },
700
- "attribute": "accessible-label-external",
701
- "reflect": false,
702
- "defaultValue": "getLocaleString(this.accessibleLabelExternalDefaults)"
703
- },
704
- "accessibleLabelDefaults": {
705
- "type": "string",
706
- "mutable": false,
707
- "complexType": {
708
- "original": "DuetLangObject | string",
709
- "resolved": "DuetLangObject | string",
710
- "references": {
711
- "DuetLangObject": {
712
- "location": "import",
713
- "path": "../../utils/language-utils",
714
- "id": "src/utils/language-utils.ts::DuetLangObject"
715
- }
716
- }
717
- },
718
- "required": false,
719
- "optional": false,
720
- "docs": {
721
- "tags": [],
722
- "text": "Property to change accessibleLabel defaults on the component.\nnormally you would handle these strings on an application level and override accessibleLabel when needed"
723
- },
724
- "attribute": "accessible-label-default",
725
- "reflect": false,
726
- "defaultValue": "{\n fi: \"Valikko\",\n sv: \"Meny\",\n en: \"Menu\",\n }"
727
- },
728
- "accessibleLabel": {
729
- "type": "string",
730
- "mutable": true,
731
- "complexType": {
732
- "original": "string",
733
- "resolved": "string",
734
- "references": {}
735
- },
736
- "required": false,
737
- "optional": false,
738
- "docs": {
739
- "tags": [{
740
- "name": "default",
741
- "text": "{\nfi: \"Valikko\",\nsv: \"Meny\",\nen: \"Menu\",\n}"
742
- }],
743
- "text": "Accessible label that is shown for screen reader users in the mobile\nnavigation toggle. Not visible for normal users."
744
- },
745
- "attribute": "accessible-label",
746
- "reflect": false,
747
- "defaultValue": "getLocaleString(this.accessibleLabelDefaults)"
748
- },
749
- "user": {
750
- "type": "any",
751
- "mutable": false,
752
- "complexType": {
753
- "original": "any",
754
- "resolved": "any",
755
- "references": {}
756
- },
757
- "required": false,
758
- "optional": false,
759
- "docs": {
760
- "tags": [],
761
- "text": "An object that includes mandatory \"label\" and \"href\" fields for the user\nprofile link. Additionally, you can pass an \"id\" that is added as an HTML\nidentifier for the element. If nothing is passed, user won\u2019t be shown.\nNote: not available in multilevel headers."
762
- },
763
- "attribute": "user",
764
- "reflect": false
765
- },
766
- "logoHref": {
767
- "type": "string",
768
- "mutable": false,
769
- "complexType": {
770
- "original": "string",
771
- "resolved": "string",
772
- "references": {}
773
- },
774
- "required": false,
775
- "optional": false,
776
- "docs": {
777
- "tags": [],
778
- "text": "URL that the logo link points to."
779
- },
780
- "attribute": "logo-href",
781
- "reflect": false,
782
- "defaultValue": "\"/\""
783
- },
784
- "currentHref": {
785
- "type": "string",
786
- "mutable": true,
787
- "complexType": {
788
- "original": "string",
789
- "resolved": "string",
790
- "references": {}
791
- },
792
- "required": false,
793
- "optional": false,
794
- "docs": {
795
- "tags": [],
796
- "text": "The href of the current page item that is shown as \u201Cactive\u201D.\nNote: not available in multilevel headers."
797
- },
798
- "attribute": "current-href",
799
- "reflect": false,
800
- "defaultValue": "\"/\""
801
- },
802
- "skipToId": {
803
- "type": "string",
804
- "mutable": false,
805
- "complexType": {
806
- "original": "string",
807
- "resolved": "string",
808
- "references": {}
809
- },
810
- "required": false,
811
- "optional": false,
812
- "docs": {
813
- "tags": [],
814
- "text": "The ID of the element where \"skip to content\" link should take the user.\nIf empty, the functionality won\u2019t be rendered in the DOM."
815
- },
816
- "attribute": "skip-to-id",
817
- "reflect": false,
818
- "defaultValue": "\"\""
819
- },
820
- "items": {
821
- "type": "any",
822
- "mutable": false,
823
- "complexType": {
824
- "original": "any",
825
- "resolved": "any",
826
- "references": {}
827
- },
828
- "required": false,
829
- "optional": false,
830
- "docs": {
831
- "tags": [],
832
- "text": "An array of items for the main navigation. Items have to include mandatory\n\"label\" and \"href\" fields to work. Additionally, you can pass an \"id\" that is\nadded as an HTML identifier for the element, \"active\" boolean that makes item active,\n\"badge\" boolean to add notification badge next to the item and\n\"items\" array consisting of sub items that are allowed up to three levels.\nTwo and three level menus are deprecated and you should instead use\nNav component to create multilevel navigations."
833
- },
834
- "attribute": "items",
835
- "reflect": false
836
- },
837
- "region": {
838
- "type": "string",
839
- "mutable": false,
840
- "complexType": {
841
- "original": "string",
842
- "resolved": "string",
843
- "references": {}
844
- },
845
- "required": false,
846
- "optional": false,
847
- "docs": {
848
- "tags": [],
849
- "text": "Region that is shown next to the logo. If empty, region will be hidden.\nNote: not available in multilevel header."
850
- },
851
- "attribute": "region",
852
- "reflect": false,
853
- "defaultValue": "\"\""
854
- },
855
- "session": {
856
- "type": "any",
857
- "mutable": false,
858
- "complexType": {
859
- "original": "any",
860
- "resolved": "any",
861
- "references": {}
862
- },
863
- "required": false,
864
- "optional": false,
865
- "docs": {
866
- "tags": [],
867
- "text": "An object that includes mandatory \"label\", \"href\" and \"type\" fields for the\nsession login/logout link. Additionally, you can pass an \"id\" that is added\nas an HTML identifier for the element.\nIf nothing is passed, this link won\u2019t be shown."
868
- },
869
- "attribute": "session",
870
- "reflect": false
871
- },
872
- "search": {
873
- "type": "any",
874
- "mutable": false,
875
- "complexType": {
876
- "original": "any",
877
- "resolved": "any",
878
- "references": {}
879
- },
880
- "required": false,
881
- "optional": false,
882
- "docs": {
883
- "tags": [],
884
- "text": "An object that includes mandatory \"label\" and \"href\" fields for the\nsearch link. Additionally, you can pass an \"id\" that is added\nas an HTML identifier for the element. If nothing is passed, this link won\u2019t\nbe shown."
885
- },
886
- "attribute": "search",
887
- "reflect": false
888
- },
889
- "back": {
890
- "type": "any",
891
- "mutable": false,
892
- "complexType": {
893
- "original": "any",
894
- "resolved": "any",
895
- "references": {}
896
- },
897
- "required": false,
898
- "optional": false,
899
- "docs": {
900
- "tags": [],
901
- "text": "An object that includes mandatory \"label\" and \"href\" fields for the back link.\nAdditionally, you can pass an \"id\" that is added as an HTML identifier for the\nelement. If nothing is passed, back link won\u2019t be shown. **NOTE: The back link\nshould be ONLY used in combination with language and logoHref props.**"
902
- },
903
- "attribute": "back",
904
- "reflect": false
905
- },
906
- "contact": {
907
- "type": "string",
908
- "mutable": false,
909
- "complexType": {
910
- "original": "string",
911
- "resolved": "string",
912
- "references": {}
913
- },
914
- "required": false,
915
- "optional": false,
916
- "docs": {
917
- "tags": [],
918
- "text": "Label of the contact menu. If empty, contact menu will be hidden.\nNote: not available in multilevel headers."
919
- },
920
- "attribute": "contact",
921
- "reflect": false,
922
- "defaultValue": "\"\""
923
- },
924
- "contactItems": {
925
- "type": "any",
926
- "mutable": false,
927
- "complexType": {
928
- "original": "any",
929
- "resolved": "any",
930
- "references": {}
931
- },
932
- "required": false,
933
- "optional": false,
934
- "docs": {
935
- "tags": [],
936
- "text": "An array of items for the contact menu. \"label\" and \"href\" are mandatory.\nAdditionally, you can pass an \"id\" that is added as an HTML identifier for\nthe element, and pass an \"external\" flag if the link is to open in a new window."
937
- },
938
- "attribute": "contact-items",
939
- "reflect": false
940
- },
941
- "languageItems": {
942
- "type": "any",
943
- "mutable": false,
944
- "complexType": {
945
- "original": "any",
946
- "resolved": "any",
947
- "references": {}
948
- },
949
- "required": false,
950
- "optional": false,
951
- "docs": {
952
- "tags": [],
953
- "text": "An array of items for the language menu. If empty, the language menu will\nbe hidden. \"label\", \"country\" and \"href\" are mandatory. Additionally you\ncan pass an \"id\" that is added as an HTML identifier for the element."
954
- },
955
- "attribute": "language-items",
956
- "reflect": false
957
- }
958
- };
959
- }
960
- static get states() {
961
- return {
962
- "isContactOpen": {},
963
- "isLanguageOpen": {},
964
- "isSessionOpen": {},
965
- "isSlideOutOpen": {},
966
- "isSegmentOpen": {},
967
- "openMenu": {},
968
- "closedActives": {},
969
- "processedItems": {},
970
- "processedLanguageItems": {},
971
- "processedContactItems": {},
972
- "processedSession": {},
973
- "processedSearch": {},
974
- "processedUser": {},
975
- "processedBack": {},
976
- "renderDesktopNav": {}
977
- };
978
- }
979
- static get events() {
980
- return [{
981
- "method": "duetChange",
982
- "name": "duetChange",
983
- "bubbles": false,
984
- "cancelable": true,
985
- "composed": true,
986
- "docs": {
987
- "tags": [{
988
- "name": "deprecated",
989
- "text": "in favour of more specific events like duetLogoClick.\nCallback for when a user is about to navigate to another page. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
990
- }],
991
- "text": ""
992
- },
993
- "complexType": {
994
- "original": "DuetHeaderChangeEvent",
995
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
996
- "references": {
997
- "DuetHeaderChangeEvent": {
998
- "location": "local",
999
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1000
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1001
- }
1002
- }
1003
- }
1004
- }, {
1005
- "method": "duetSessionClick",
1006
- "name": "duetSessionClick",
1007
- "bubbles": true,
1008
- "cancelable": true,
1009
- "composed": true,
1010
- "docs": {
1011
- "tags": [],
1012
- "text": "Event for when a user has clicked the session link. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1013
- },
1014
- "complexType": {
1015
- "original": "DuetHeaderChangeEvent",
1016
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1017
- "references": {
1018
- "DuetHeaderChangeEvent": {
1019
- "location": "local",
1020
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1021
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1022
- }
1023
- }
1024
- }
1025
- }, {
1026
- "method": "duetSearchClick",
1027
- "name": "duetSearchClick",
1028
- "bubbles": true,
1029
- "cancelable": true,
1030
- "composed": true,
1031
- "docs": {
1032
- "tags": [],
1033
- "text": "Event for when a user has clicked the search link. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1034
- },
1035
- "complexType": {
1036
- "original": "DuetHeaderChangeEvent",
1037
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1038
- "references": {
1039
- "DuetHeaderChangeEvent": {
1040
- "location": "local",
1041
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1042
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1043
- }
1044
- }
1045
- }
1046
- }, {
1047
- "method": "duetUserClick",
1048
- "name": "duetUserClick",
1049
- "bubbles": true,
1050
- "cancelable": true,
1051
- "composed": true,
1052
- "docs": {
1053
- "tags": [],
1054
- "text": "Event raised when a user has clicked the user link. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1055
- },
1056
- "complexType": {
1057
- "original": "DuetHeaderChangeEvent",
1058
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1059
- "references": {
1060
- "DuetHeaderChangeEvent": {
1061
- "location": "local",
1062
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1063
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1064
- }
1065
- }
1066
- }
1067
- }, {
1068
- "method": "duetLanguageSelect",
1069
- "name": "duetLanguageSelect",
1070
- "bubbles": true,
1071
- "cancelable": true,
1072
- "composed": true,
1073
- "docs": {
1074
- "tags": [],
1075
- "text": "Event raised when a user has selected a language from the language dropdown. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1076
- },
1077
- "complexType": {
1078
- "original": "DuetHeaderChangeEvent",
1079
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1080
- "references": {
1081
- "DuetHeaderChangeEvent": {
1082
- "location": "local",
1083
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1084
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
345
+ /**
346
+ * Local methods.
347
+ */
348
+ async refresh() {
349
+ var _a, _b;
350
+ if (this.renderDesktopNav !== Build.isServer ? true : (_a = this.mql[0]) === null || _a === void 0 ? void 0 : _a.matches) {
351
+ this.renderDesktopNav = Build.isServer ? true : (_b = this.mql[0]) === null || _b === void 0 ? void 0 : _b.matches;
352
+ this.openMenu = null;
353
+ if (this.isSlideOutOpen) {
354
+ this.toggleMenu(document.createEvent("UIEvents"), "mobile");
1085
355
  }
1086
- }
1087
356
  }
1088
- }, {
1089
- "method": "duetLogoClick",
1090
- "name": "duetLogoClick",
1091
- "bubbles": true,
1092
- "cancelable": true,
1093
- "composed": true,
1094
- "docs": {
1095
- "tags": [],
1096
- "text": "Event raised when a user has clicked the logo. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1097
- },
1098
- "complexType": {
1099
- "original": "DuetHeaderChangeEvent",
1100
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1101
- "references": {
1102
- "DuetHeaderChangeEvent": {
1103
- "location": "local",
1104
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1105
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
357
+ this.processedItems = parsePossibleJSON(this.items);
358
+ this.processedLanguageItems = parsePossibleJSON(this.languageItems);
359
+ this.processedContactItems = parsePossibleJSON(this.contactItems);
360
+ this.processedSession = parsePossibleJSON(this.session);
361
+ this.processedSearch = parsePossibleJSON(this.search);
362
+ this.processedUser = parsePossibleJSON(this.user);
363
+ this.processedBack = parsePossibleJSON(this.back);
364
+ }
365
+ /**
366
+ * Closes mobile menu in header when called.
367
+ */
368
+ async closeMobileNavigation(moveFocusToButton = false) {
369
+ if (this.isSlideOutOpen) {
370
+ this.isSlideOutOpen = false;
371
+ enableBodyScroll(this.navigationEl);
372
+ if (moveFocusToButton) {
373
+ this.navigationElButton.focus({
374
+ preventScroll: true,
375
+ });
1106
376
  }
1107
- }
1108
377
  }
1109
- }, {
1110
- "method": "duetBackClick",
1111
- "name": "duetBackClick",
1112
- "bubbles": true,
1113
- "cancelable": true,
1114
- "composed": true,
1115
- "docs": {
1116
- "tags": [],
1117
- "text": "Event raised when a user has clicked the back button. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1118
- },
1119
- "complexType": {
1120
- "original": "DuetHeaderChangeEvent",
1121
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1122
- "references": {
1123
- "DuetHeaderChangeEvent": {
1124
- "location": "local",
1125
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1126
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
378
+ }
379
+ /**
380
+ * Closes all dropdown menus in header when called.
381
+ */
382
+ async closeMenus(moveFocusToButton = false) {
383
+ if (this.isContactOpen || this.isLanguageOpen || this.isSegmentOpen || this.isSessionOpen || this.openMenu) {
384
+ if (this.isContactOpen && moveFocusToButton) {
385
+ this.contactItemsButtonEl.focus({
386
+ preventScroll: true,
387
+ });
1127
388
  }
1128
- }
1129
- }
1130
- }, {
1131
- "method": "duetContactClick",
1132
- "name": "duetContactClick",
1133
- "bubbles": true,
1134
- "cancelable": true,
1135
- "composed": true,
1136
- "docs": {
1137
- "tags": [],
1138
- "text": "Event raised when a user has clicked an option from the contact dropdown. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1139
- },
1140
- "complexType": {
1141
- "original": "DuetHeaderChangeEvent",
1142
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1143
- "references": {
1144
- "DuetHeaderChangeEvent": {
1145
- "location": "local",
1146
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1147
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
389
+ if (this.isLanguageOpen && moveFocusToButton) {
390
+ this.languageItemsButtonEl.focus({
391
+ preventScroll: true,
392
+ });
1148
393
  }
1149
- }
1150
- }
1151
- }, {
1152
- "method": "duetItemClick",
1153
- "name": "duetItemClick",
1154
- "bubbles": true,
1155
- "cancelable": true,
1156
- "composed": true,
1157
- "docs": {
1158
- "tags": [],
1159
- "text": "Event raised when a user has clicked a menu item. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1160
- },
1161
- "complexType": {
1162
- "original": "DuetHeaderChangeEvent",
1163
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1164
- "references": {
1165
- "DuetHeaderChangeEvent": {
1166
- "location": "local",
1167
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1168
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
394
+ if (this.isSegmentOpen && moveFocusToButton) {
395
+ this.segmentItemsButtonEl.focus({
396
+ preventScroll: true,
397
+ });
1169
398
  }
1170
- }
1171
- }
1172
- }, {
1173
- "method": "duetSkipClick",
1174
- "name": "duetSkipClick",
1175
- "bubbles": true,
1176
- "cancelable": true,
1177
- "composed": true,
1178
- "docs": {
1179
- "tags": [],
1180
- "text": "Event raised when a user has clicked the \"skip to content\" button. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1181
- },
1182
- "complexType": {
1183
- "original": "DuetHeaderChangeEvent",
1184
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1185
- "references": {
1186
- "DuetHeaderChangeEvent": {
1187
- "location": "local",
1188
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1189
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
399
+ if (this.isSessionOpen && moveFocusToButton) {
400
+ this.sessionItemsButtonEl.focus({
401
+ preventScroll: true,
402
+ });
1190
403
  }
1191
- }
1192
- }
1193
- }, {
1194
- "method": "duetAnalytics",
1195
- "name": "duetAnalytics",
1196
- "bubbles": true,
1197
- "cancelable": true,
1198
- "composed": true,
1199
- "docs": {
1200
- "tags": [],
1201
- "text": "Event raised when an items with an associated analytics ID is clicked. Analytics ID can be\naccessed via **event.detail.analyticsId**"
1202
- },
1203
- "complexType": {
1204
- "original": "DuetHeaderAnalyticsEvent",
1205
- "resolved": "{ analyticsId: string; component: \"duet-header\"; }",
1206
- "references": {
1207
- "DuetHeaderAnalyticsEvent": {
1208
- "location": "local",
1209
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1210
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderAnalyticsEvent"
404
+ if (this.openMenu && moveFocusToButton) {
405
+ this.subMenuButtonRefs[this.openMenu].focus({
406
+ preventScroll: true,
407
+ });
1211
408
  }
1212
- }
409
+ this.isContactOpen = false;
410
+ this.isLanguageOpen = false;
411
+ this.isSegmentOpen = false;
412
+ this.isSessionOpen = false;
413
+ this.openMenu = null;
1213
414
  }
1214
- }, {
1215
- "method": "duetMobileNavToggle",
1216
- "name": "duetMobileNavToggle",
1217
- "bubbles": true,
1218
- "cancelable": true,
1219
- "composed": true,
1220
- "docs": {
1221
- "tags": [],
1222
- "text": "Event raised mobile navigation is toggled. **event.detail.open** shows the current status of the navigation."
1223
- },
1224
- "complexType": {
1225
- "original": "DuetHeaderMobileNavToggleEvent",
1226
- "resolved": "{ originalEvent: Event; open: boolean; }",
1227
- "references": {
1228
- "DuetHeaderMobileNavToggleEvent": {
1229
- "location": "local",
1230
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1231
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderMobileNavToggleEvent"
1232
- }
1233
- }
415
+ }
416
+ /**
417
+ * Sets focus on the specified `duet-header`. Use this method instead of the global
418
+ * `header.focus()`.
419
+ */
420
+ async setFocus(options) {
421
+ this.logoEl.setFocus(options);
422
+ }
423
+ /**
424
+ * render() function
425
+ * Always the last one in the class.
426
+ */
427
+ render() {
428
+ const { skipLabel, changeLanguage, activeLanguage } = this.accessibleI18nLabels;
429
+ const skipToLabel = () => this.skipToId ? (h("a", { href: this.skipToId, class: "duet-header-skip", onClick: this.handleSkipClick }, skipLabel)) : null;
430
+ const logo = () => (h("duet-logo", { href: this.logoHref, size: "medium", ref: el => (this.logoEl = el), language: this.language, theme: this.theme, onClick: this.handleLogoClick }));
431
+ const largeLogo = () => (h("duet-logo", { href: this.logoHref, size: "large", ref: el => (this.logoEl = el), language: this.language, theme: this.theme, onClick: this.handleLogoClick }));
432
+ const contactDropdown = () => this.contact && this.processedContactItems ? (h(DuetHeaderDropdown, { id: "duet-header-contact", label: this.contact, icon: contactDropdownIcon.svg, active: this.isContactOpen, isOpen: this.isContactOpen, badge: false, toggleRef: el => (this.contactItemsButtonEl = el), itemsRef: el => (this.contactItemsEl = el), onToggle: event => this.toggleMenu(event, "contact") }, this.processedContactItems.map(item => (h("a", { role: "menuitem", href: item.href || "#", id: item.id, onClick: event => this.handleContactClick(event, item), onKeyDown: ev => this.handleArrowKeys(ev), target: item.external ? "_blank" : "_self" }, item.label, Build.isBrowser && item.external && (h(Fragment, null, h("duet-visually-hidden", null, ", ", this.accessibleLabelExternal), h("span", { class: "duet-header-link-external" }, h("duet-icon", { name: "action-new-window-small", size: "xx-small", margin: "none", color: this.theme === "turva" ? "primary-turva" : "primary" }))))))))) : null;
433
+ const languageDropdown = () => this.language && this.processedLanguageItems ? (h(DuetHeaderDropdown, { id: "duet-header-language", label: this.language, icon: languageIcon.svg, accessibleText: `${changeLanguage}${this.hasLanguageChanged ? `, ${activeLanguage}` : ""}`, active: this.isLanguageOpen, isOpen: this.isLanguageOpen, badge: false, toggleRef: el => (this.languageItemsButtonEl = el), itemsRef: el => (this.languageItemsEl = el), onToggle: event => this.toggleMenu(event, "language") }, this.processedLanguageItems.map(item => (h("a", { class: { active: this.language === item.country }, "aria-selected": this.language === item.country, role: "menuitem", id: item.id, lang: item.country, href: item.href || "#", onClick: event => this.handleLanguageClick(event, item), onKeyDown: this.handleArrowKeys }, item.label))))) : null;
434
+ const processedUserWithLink = () => this.processedUser && this.processedUser.href ? (h("a", { href: this.processedUser.href || "#", id: this.processedUser.id, class: "duet-header-user duet-header-button", onClick: this.handleUserClick }, h(DuetHeaderIcon, { icon: userIcon.svg }), h("span", { class: "duet-header-user-label" }, this.processedUser.label))) : null;
435
+ const processedUserWithoutLink = () => this.processedUser && !this.processedUser.href ? (h("span", { id: this.processedUser.id, class: "duet-header-user duet-header-button duet-header-no-action" }, h(DuetHeaderIcon, { icon: userIcon.svg }), h("span", { class: "duet-header-user-label" }, this.processedUser.label))) : null;
436
+ const processedSession = () => this.processedSession ? (h("a", { href: this.processedSession.href || "#", id: this.processedSession.id, class: "duet-header-logout duet-header-button", onClick: this.handleSessionClick }, h(DuetHeaderIcon, { class: "desktop", icon: this.processedSession.type === "logout" ? logoutIcon.svg : loginIcon.svg, iconSize: "x-small" }), h(DuetHeaderIcon, { class: "mobile", icon: this.processedSession.type === "logout" ? logoutIcon.svg : loginIcon.svg, iconSize: "small" }), h("span", { class: "duet-header-button-label" }, this.processedSession.label))) : null;
437
+ const processedSessionDropdown = () => this.processedSession && this.processedSession.sessionItems ? (h(DuetHeaderDropdown, { className: "duet-header-session", id: "duet-header-session", label: this.processedSession.label, icon: this.processedSession.type === "logout" ? logoutIcon.svg : loginIcon.svg, active: this.isSessionOpen, isOpen: this.isSessionOpen, badge: false, toggleRef: el => (this.sessionItemsButtonEl = el), itemsRef: el => (this.sessionItemsEl = el), onToggle: event => this.toggleMenu(event, "session") }, this.processedSession.sessionItems.map((sessionItem, index) => (h(Fragment, null, sessionItem.label && h("span", { class: "duet-header-session-label" }, sessionItem.label), h("duet-spacer", { size: "small", "aria-hidden": "true" }), sessionItem.items.map(item => (h("a", { role: "menuitem", "aria-label": sessionItem.label ? `${sessionItem.label} ${item.label}` : item.label, id: item.id, href: item.href || "#", onClick: event => this.handleSessionItemClick(event, item), onKeyDown: this.handleArrowKeys }, item.label))), index !== this.processedSession.sessionItems.length - 1 && (h(Fragment, null, h("duet-spacer", { size: "x-small", "aria-hidden": "true" }), h("duet-divider", { margin: "none", "aria-hidden": "true" })))))))) : null;
438
+ const processedSearch = () => this.processedSearch ? (h("a", { href: this.processedSearch.href || "#", id: this.processedSearch.id, class: "duet-header-search duet-header-button", onClick: this.handleSearchClick }, h(DuetHeaderIcon, { icon: searchIcon.svg }), h("span", { class: "duet-header-button-label" }, this.processedSearch.label))) : null;
439
+ // Back variation
440
+ if (this.processedBack) {
441
+ return (h(Host, { class: "duet-header-back-variation" }, h("div", { class: "duet-header-reserved-space" }, h("header", { class: {
442
+ "duet-header": true,
443
+ "duet-theme-turva": this.theme === "turva",
444
+ "duet-header-back": true,
445
+ "duet-header-inactive": true,
446
+ }, part: "header" }, h("div", { class: "duet-header-top" }, skipToLabel(), h("duet-button", { url: this.processedBack.href, id: this.processedBack.id, theme: this.theme, variation: "plain", color: this.theme === "turva" ? "secondary-turva" : "secondary", icon: "navigation-arrow-left", iconSize: "large", onClick: this.handleBackClick }, this.processedBack.label), logo(), h("slot", { name: "logo-utility" }))))));
1234
447
  }
1235
- }, {
1236
- "method": "duetEvent",
1237
- "name": "duetEvent",
1238
- "bubbles": true,
1239
- "cancelable": true,
1240
- "composed": true,
1241
- "docs": {
1242
- "tags": [],
1243
- "text": "General event stream for the following events:\nitem: onMouseEnter, onTouchDown;\nmenuItem: onMouseEnter, onTouchDown;.\nYou can prevent\nthe default browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via\n**event.detail.data**."
1244
- },
1245
- "complexType": {
1246
- "original": "DuetHeaderChangeEvent",
1247
- "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1248
- "references": {
1249
- "DuetHeaderChangeEvent": {
1250
- "location": "local",
1251
- "path": "/Users/laaksju3/duetds/packages/components/src/components/duet-header/duet-header.tsx",
1252
- "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1253
- }
1254
- }
448
+ const itemsHaveSubItems = this.processedItems && this.processedItems.some(item => item.items && item.items.length > 0);
449
+ const isSecondLevelActive = this.processedItems &&
450
+ this.processedItems.some(item => item.items && item.items.some(secondLevelItem => secondLevelItem.active === true));
451
+ const isThirdLevelActive = this.processedItems &&
452
+ this.processedItems.some(item => item.items &&
453
+ item.items.some(secondLevelItem => secondLevelItem.items && secondLevelItem.items.some(thirdLevelItem => thirdLevelItem.active === true)));
454
+ const defaultVariationContent = (h("div", { class: {
455
+ "duet-header-reserved-space": true,
456
+ "duet-with-links": !!this.processedItems,
457
+ "duet-header-second-level-active": isSecondLevelActive,
458
+ "duet-header-third-level-active": isThirdLevelActive,
459
+ "duet-header-items-have-sub-items": itemsHaveSubItems,
460
+ } }, h("header", { class: {
461
+ "duet-header": true,
462
+ "duet-theme-turva": this.theme === "turva",
463
+ "duet-header-inactive": !this.processedItems,
464
+ }, part: "header" }, h("div", { class: "duet-header-top" }, skipToLabel(), logo(), h("slot", { name: "logo-utility" }, this.region && h("div", { class: "duet-header-region" }, this.region)), (this.processedItems ||
465
+ languageDropdown() ||
466
+ contactDropdown() ||
467
+ this.processedSession ||
468
+ this.processedUser) && (h("button", { ref: el => (this.navigationElButton = el), class: { "duet-header-toggle": true, active: this.isSlideOutOpen }, onClick: event => this.toggleMenu(event, "mobile"), type: "button", "aria-controls": "duet-header-bottom", "aria-expanded": this.isSlideOutOpen ? "true" : "false" }, h("duet-visually-hidden", null, this.accessibleLabel), h(DuetHeaderHamburger, null)))), h("div", { ref: el => (this.navigationEl = el), id: "duet-header-bottom", class: {
469
+ "duet-header-bottom": true,
470
+ active: this.isSlideOutOpen,
471
+ inactive: !this.processedItems,
472
+ } }, h("nav", { class: "duet-header-items", role: "navigation" }, this.processedItems &&
473
+ this.processedItems.map((item, itemIndex) => (h("div", { class: "duet-header-item-container" }, h("a", { class: {
474
+ "duet-header-first-level": true,
475
+ "duet-header-item": true,
476
+ active: (!itemsHaveSubItems && this.currentHref === item.href) ||
477
+ (item.active === true &&
478
+ !this.openMenu &&
479
+ this.closedActives &&
480
+ this.closedActives.length === 1) ||
481
+ (item.active === true &&
482
+ !this.openMenu &&
483
+ item.items &&
484
+ !item.items.some(s => s.active === true)),
485
+ }, href: item.href || "#", id: item.id || `header-item-${itemIndex}`, onClick: event => this.handleItemClick(event, item), onMouseEnter: event => this.emitDuetEvent(event, item), onTouchStart: event => this.emitDuetEvent(event, item) }, item.label, item.badge && h("div", { class: "duet-header-badge" })), item.items &&
486
+ item.items
487
+ .filter(secondLevelitem => secondLevelitem.items && secondLevelitem.items.length > 0)
488
+ .map((secondLevelItem, secondLevelItemIndex) => {
489
+ const id = secondLevelItem.id || `header-item-${itemIndex}-${secondLevelItemIndex}`;
490
+ const active = (!this.openMenu &&
491
+ secondLevelItem.active === true &&
492
+ !(this.closedActives && !!this.closedActives.find(i => i === id))) ||
493
+ this.openMenu === id;
494
+ const activeBar = active && !(secondLevelItem.items && secondLevelItem.items.some(s => s.active === true));
495
+ return (h(DuetHeaderDropdown, { id: id, className: "duet-header-second-level", label: secondLevelItem.label, icon: `${secondLevelItem.icon}.svg`, active: activeBar, isOpen: active, badge: secondLevelItem.badge, toggleRef: el => (this.subMenuButtonRefs[id] = el), itemsRef: el => (this.subMenuItemRefs[id] = el), onToggle: event => this.toggleMenu(event, "sub", id, secondLevelItem.active === true) }, h("div", { class: "duet-header-third-level" }, secondLevelItem.items &&
496
+ secondLevelItem.items.map(thirdLevelItem => (h("a", { class: {
497
+ "duet-header-item": true,
498
+ active: thirdLevelItem.active === true,
499
+ }, role: "menuitem", href: thirdLevelItem.href || "#", id: thirdLevelItem.id, onClick: event => this.handleItemClick(event, thirdLevelItem), onKeyDown: ev => this.handleArrowKeys(ev), onMouseEnter: event => this.emitDuetEvent(event, thirdLevelItem), onTouchStart: event => this.emitDuetEvent(event, thirdLevelItem), target: thirdLevelItem.external ? "_blank" : "_self" }, thirdLevelItem.icon && (h("div", { class: "duet-header-icon" }, h("duet-icon", { margin: "none", size: "medium", name: thirdLevelItem.icon, color: "currentColor" }))), h("span", null, thirdLevelItem.label), thirdLevelItem.badge && h("div", { class: "duet-header-badge" })))))));
500
+ }))))), h("div", { class: "duet-header-bottom-utils" }, h("slot", { name: "utility" })), h("div", { class: "duet-header-utils" }, !itemsHaveSubItems && contactDropdown(), languageDropdown(), !itemsHaveSubItems && (h(Fragment, null, processedUserWithLink(), processedUserWithoutLink())), processedSearch(), processedSession())))));
501
+ // multi level variation
502
+ if (itemsHaveSubItems) {
503
+ const activeSegment = this.processedItems.find(item => item.active);
504
+ const isThirdLevelActive = this.processedItems &&
505
+ this.processedItems.some(item => item.items &&
506
+ item.items.some(secondLevelItem => secondLevelItem.items && secondLevelItem.items.some(thirdLevelItem => thirdLevelItem.active === true)));
507
+ const segmentId = "duet-header-segment";
508
+ return (h(Host, { class: "duet-header-multi-level-variation" }, h("div", { class: {
509
+ "duet-header-multi-level": true,
510
+ "duet-header-multi-level-third-level-is-open": isThirdLevelActive,
511
+ } }, h("header", { class: {
512
+ "duet-header": true,
513
+ "duet-theme-turva": this.theme === "turva",
514
+ "duet-header-inactive": !this.processedItems,
515
+ }, part: "header" }, h("div", { class: "duet-header-top" }, skipToLabel(), h("div", { class: "logo-and-segment" }, h("div", null, largeLogo()), this.processedItems && (h(DuetHeaderDropdown, { id: segmentId, label: activeSegment.label, active: this.isSegmentOpen, isOpen: this.isSegmentOpen, badge: false, toggleRef: el => (this.segmentItemsButtonEl = el), itemsRef: el => (this.segmentItemsEl = el), onToggle: event => this.toggleMenu(event, "segment") }, this.processedItems.map(item => (h("a", { class: { active: activeSegment === item }, role: "menuitem", href: item.href || "#", id: item.id, onClick: event => this.handleItemClick(event, item), onKeyDown: ev => this.handleArrowKeys(ev), onMouseEnter: event => this.emitDuetEvent(event, item), onTouchStart: event => this.emitDuetEvent(event, item), target: item.external ? "_blank" : "_self" }, item.icon && (h("div", { class: "duet-header-icon" }, h("duet-icon", { margin: "none", size: "x-small", name: item.icon, color: "currentColor" }))), h("span", null, item.label), item.badge && h("div", { class: "duet-header-badge" }))))))), h("nav", { class: "duet-header-multi-level-nav" }, activeSegment.items &&
516
+ activeSegment.items
517
+ .filter(secondLevelItem => secondLevelItem.items && secondLevelItem.items.length > 0)
518
+ .map((secondLevelItem, secondLevelItemIndex) => {
519
+ const id = secondLevelItem.id || `segment-item-${secondLevelItemIndex}`;
520
+ return (h(DuetHeaderDropdown, { id: id, label: secondLevelItem.label, active: (!this.openMenu && secondLevelItem.active === true) || this.openMenu === id, isOpen: this.openMenu === id, badge: secondLevelItem.badge, toggleRef: el => (this.subMenuButtonRefs[id] = el), itemsRef: el => (this.subMenuItemRefs[id] = el), onToggle: event => this.toggleMenu(event, "sub", id) }, secondLevelItem.items &&
521
+ secondLevelItem.items.map(thirdLevelItem => (h("a", { class: { active: thirdLevelItem.active }, role: "menuitem", href: thirdLevelItem.href || "#", id: thirdLevelItem.id, onClick: event => this.handleItemClick(event, thirdLevelItem), onKeyDown: ev => this.handleArrowKeys(ev), onMouseEnter: event => this.emitDuetEvent(event, thirdLevelItem), onTouchStart: event => this.emitDuetEvent(event, thirdLevelItem), target: thirdLevelItem.external ? "_blank" : "_self" }, thirdLevelItem.icon && (h("div", { class: "duet-header-icon" }, h("duet-icon", { margin: "none", size: "medium", name: thirdLevelItem.icon, color: "currentColor" }))), h("span", null, thirdLevelItem.label), thirdLevelItem.badge && h("div", { class: "duet-header-badge" }))))));
522
+ })), h("div", { class: "duet-header-multi-level-utils" }, processedSearch(), languageDropdown(), processedSessionDropdown() != null ? processedSessionDropdown() : processedSession()), h("slot", { name: "utility" })))), defaultVariationContent));
1255
523
  }
1256
- }];
1257
- }
1258
- static get methods() {
1259
- return {
1260
- "closeMenus": {
1261
- "complexType": {
1262
- "signature": "(moveFocusToButton?: boolean) => Promise<void>",
1263
- "parameters": [{
1264
- "tags": [],
1265
- "text": ""
1266
- }],
1267
- "references": {
1268
- "Promise": {
1269
- "location": "global",
1270
- "id": "global::Promise"
524
+ // Default variation
525
+ return (h(Host, { class: {
526
+ "duet-header-default-variation": true,
527
+ } }, defaultVariationContent));
528
+ }
529
+ static get is() { return "duet-header"; }
530
+ static get encapsulation() { return "shadow"; }
531
+ static get originalStyleUrls() {
532
+ return {
533
+ "$": ["duet-header.scss"]
534
+ };
535
+ }
536
+ static get styleUrls() {
537
+ return {
538
+ "$": ["duet-header.css"]
539
+ };
540
+ }
541
+ static get properties() {
542
+ return {
543
+ "theme": {
544
+ "type": "string",
545
+ "mutable": true,
546
+ "complexType": {
547
+ "original": "DuetTheme",
548
+ "resolved": "\"\" | \"default\" | \"turva\"",
549
+ "references": {
550
+ "DuetTheme": {
551
+ "location": "import",
552
+ "path": "../../common-types",
553
+ "id": "src/common-types.d.ts::DuetTheme"
554
+ }
555
+ }
556
+ },
557
+ "required": false,
558
+ "optional": false,
559
+ "docs": {
560
+ "tags": [],
561
+ "text": "Theme of the header."
562
+ },
563
+ "attribute": "theme",
564
+ "reflect": false,
565
+ "defaultValue": "\"\""
566
+ },
567
+ "language": {
568
+ "type": "string",
569
+ "mutable": true,
570
+ "complexType": {
571
+ "original": "DuetLanguage",
572
+ "resolved": "\"en\" | \"fi\" | \"sv\"",
573
+ "references": {
574
+ "DuetLanguage": {
575
+ "location": "import",
576
+ "path": "../../common-types",
577
+ "id": "src/common-types.d.ts::DuetLanguage"
578
+ }
579
+ }
580
+ },
581
+ "required": false,
582
+ "optional": false,
583
+ "docs": {
584
+ "tags": [{
585
+ "name": "deprecated",
586
+ "text": "this is now handled via the html lang tag, and is no longer used - kept to avoid breaking changes and ease unit testing"
587
+ }, {
588
+ "name": "default",
589
+ "text": "\"fi\""
590
+ }],
591
+ "text": "The currently active language. This setting also changes the logo to match\nthe chosen language."
592
+ },
593
+ "attribute": "language",
594
+ "reflect": false,
595
+ "defaultValue": "getLanguage()"
596
+ },
597
+ "accessibleI18nLabelsDefaults": {
598
+ "type": "string",
599
+ "mutable": false,
600
+ "complexType": {
601
+ "original": "| string\n | Record<DuetLanguage, I18nText>",
602
+ "resolved": "string | { fi: I18nText; en: I18nText; sv: I18nText; }",
603
+ "references": {
604
+ "Record": {
605
+ "location": "global",
606
+ "id": "global::Record"
607
+ },
608
+ "DuetLanguage": {
609
+ "location": "import",
610
+ "path": "../../common-types",
611
+ "id": "src/common-types.d.ts::DuetLanguage"
612
+ },
613
+ "I18nText": {
614
+ "location": "local",
615
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
616
+ "id": "src/components/duet-header/duet-header.tsx::I18nText"
617
+ }
618
+ }
619
+ },
620
+ "required": false,
621
+ "optional": false,
622
+ "docs": {
623
+ "tags": [{
624
+ "name": "default",
625
+ "text": "{\nfi: {\nskipLabel: \"Siirry p\u00E4\u00E4sis\u00E4lt\u00F6\u00F6n\",\nchangeLanguage: \"Vaihda kielt\u00E4\",\nactiveLanguage: \"Suomi valittuna\",\n},\nsv: {\nskipLabel: \"Hoppa till huvudinneh\u00E5ll\",\nchangeLanguage: \"\u00C4ndra Spr\u00E5k\",\nactiveLanguage: \"Svenska valt\",\n},\nen: {\nskipLabel: \"Skip to main content\",\nchangeLanguage: \"Change language\",\nactiveLanguage: \"English selected\",\n},\n}"
626
+ }],
627
+ "text": "Default strings for accessibleI18nLabels"
628
+ },
629
+ "attribute": "accessible-labels-default",
630
+ "reflect": false,
631
+ "defaultValue": "{\n fi: {\n skipLabel: \"Siirry p\u00E4\u00E4sis\u00E4lt\u00F6\u00F6n\",\n changeLanguage: \"Vaihda kielt\u00E4\",\n activeLanguage: \"Suomi valittuna\",\n },\n sv: {\n skipLabel: \"G\u00E5 till huvudinneh\u00E5ll\",\n changeLanguage: \"\u00C4ndra Spr\u00E5k\",\n activeLanguage: \"Svenska valt\",\n },\n en: {\n skipLabel: \"Skip to main content\",\n changeLanguage: \"Change language\",\n activeLanguage: \"English selected\",\n },\n }"
632
+ },
633
+ "accessibleI18nLabels": {
634
+ "type": "unknown",
635
+ "mutable": true,
636
+ "complexType": {
637
+ "original": "I18nText",
638
+ "resolved": "I18nText",
639
+ "references": {
640
+ "I18nText": {
641
+ "location": "local",
642
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
643
+ "id": "src/components/duet-header/duet-header.tsx::I18nText"
644
+ }
645
+ }
646
+ },
647
+ "required": false,
648
+ "optional": false,
649
+ "docs": {
650
+ "tags": [{
651
+ "name": "default",
652
+ "text": "{\nfi: {\nskipLabel: \"Siirry p\u00E4\u00E4sis\u00E4lt\u00F6\u00F6n\",\nchangeLanguage: \"Vaihda kielt\u00E4\",\nactiveLanguage: \"Suomi valittuna\",\n},\nsv: {\nskipLabel: \"Hoppa till huvudinneh\u00E5ll\",\nchangeLanguage: \"\u00C4ndra Spr\u00E5k\",\nactiveLanguage: \"Svenska valt\",\n},\nen: {\nskipLabel: \"Skip to main content\",\nchangeLanguage: \"Change language\",\nactiveLanguage: \"English selected\",\n},\n}"
653
+ }],
654
+ "text": "Adds i18n translations of all internally used textStrings"
655
+ },
656
+ "defaultValue": "getLocaleString(\n this.accessibleI18nLabelsDefaults\n )"
657
+ },
658
+ "accessibleLabelExternalDefaults": {
659
+ "type": "string",
660
+ "mutable": false,
661
+ "complexType": {
662
+ "original": "DuetLangObject | string",
663
+ "resolved": "DuetLangObject | string",
664
+ "references": {
665
+ "DuetLangObject": {
666
+ "location": "import",
667
+ "path": "../../utils/language-utils",
668
+ "id": "src/utils/language-utils.ts::DuetLangObject"
669
+ }
670
+ }
671
+ },
672
+ "required": false,
673
+ "optional": false,
674
+ "docs": {
675
+ "tags": [{
676
+ "name": "default",
677
+ "text": "{fi: \"Avautuu uuteen ikkunaan\",sv: \"\u00D6ppnas i nytt f\u00F6nster\",en: \"Opens in a new window\"}"
678
+ }],
679
+ "text": "Property to change accessibleLabelExternal defaults on the component.\nnormally you would handle these strings on an application level and override accessibleLabelExternal when needed"
680
+ },
681
+ "attribute": "accessible-label-external-default",
682
+ "reflect": false,
683
+ "defaultValue": "DuetStringsExternalDefaults"
684
+ },
685
+ "accessibleLabelExternal": {
686
+ "type": "string",
687
+ "mutable": true,
688
+ "complexType": {
689
+ "original": "string",
690
+ "resolved": "string",
691
+ "references": {}
692
+ },
693
+ "required": false,
694
+ "optional": false,
695
+ "docs": {
696
+ "tags": [{
697
+ "name": "default",
698
+ "text": "{fi: \"Avautuu uuteen ikkunaan\",sv: \"\u00D6ppnas i nytt f\u00F6nster\",en: \"Opens in a new window\"}"
699
+ }],
700
+ "text": "Adds accessible label for tooltip that is shown in external link (url & external have both been set)"
701
+ },
702
+ "attribute": "accessible-label-external",
703
+ "reflect": false,
704
+ "defaultValue": "getLocaleString(this.accessibleLabelExternalDefaults)"
705
+ },
706
+ "accessibleLabelDefaults": {
707
+ "type": "string",
708
+ "mutable": false,
709
+ "complexType": {
710
+ "original": "DuetLangObject | string",
711
+ "resolved": "DuetLangObject | string",
712
+ "references": {
713
+ "DuetLangObject": {
714
+ "location": "import",
715
+ "path": "../../utils/language-utils",
716
+ "id": "src/utils/language-utils.ts::DuetLangObject"
717
+ }
718
+ }
719
+ },
720
+ "required": false,
721
+ "optional": false,
722
+ "docs": {
723
+ "tags": [],
724
+ "text": "Property to change accessibleLabel defaults on the component.\nnormally you would handle these strings on an application level and override accessibleLabel when needed"
725
+ },
726
+ "attribute": "accessible-label-default",
727
+ "reflect": false,
728
+ "defaultValue": "{\n fi: \"Valikko\",\n sv: \"Meny\",\n en: \"Menu\",\n }"
729
+ },
730
+ "accessibleLabel": {
731
+ "type": "string",
732
+ "mutable": true,
733
+ "complexType": {
734
+ "original": "string",
735
+ "resolved": "string",
736
+ "references": {}
737
+ },
738
+ "required": false,
739
+ "optional": false,
740
+ "docs": {
741
+ "tags": [{
742
+ "name": "default",
743
+ "text": "{\nfi: \"Valikko\",\nsv: \"Meny\",\nen: \"Menu\",\n}"
744
+ }],
745
+ "text": "Accessible label that is shown for screen reader users in the mobile\nnavigation toggle. Not visible for normal users."
746
+ },
747
+ "attribute": "accessible-label",
748
+ "reflect": false,
749
+ "defaultValue": "getLocaleString(this.accessibleLabelDefaults)"
750
+ },
751
+ "user": {
752
+ "type": "any",
753
+ "mutable": false,
754
+ "complexType": {
755
+ "original": "any",
756
+ "resolved": "any",
757
+ "references": {}
758
+ },
759
+ "required": false,
760
+ "optional": false,
761
+ "docs": {
762
+ "tags": [],
763
+ "text": "An object that includes mandatory \"label\" and \"href\" fields for the user\nprofile link. Additionally, you can pass an \"id\" that is added as an HTML\nidentifier for the element. If nothing is passed, user won\u2019t be shown.\nNote: not available in multilevel headers."
764
+ },
765
+ "attribute": "user",
766
+ "reflect": false
767
+ },
768
+ "logoHref": {
769
+ "type": "string",
770
+ "mutable": false,
771
+ "complexType": {
772
+ "original": "string",
773
+ "resolved": "string",
774
+ "references": {}
775
+ },
776
+ "required": false,
777
+ "optional": false,
778
+ "docs": {
779
+ "tags": [],
780
+ "text": "URL that the logo link points to."
781
+ },
782
+ "attribute": "logo-href",
783
+ "reflect": false,
784
+ "defaultValue": "\"/\""
785
+ },
786
+ "currentHref": {
787
+ "type": "string",
788
+ "mutable": true,
789
+ "complexType": {
790
+ "original": "string",
791
+ "resolved": "string",
792
+ "references": {}
793
+ },
794
+ "required": false,
795
+ "optional": false,
796
+ "docs": {
797
+ "tags": [],
798
+ "text": "The href of the current page item that is shown as \u201Cactive\u201D.\nNote: not available in multilevel headers."
799
+ },
800
+ "attribute": "current-href",
801
+ "reflect": false,
802
+ "defaultValue": "\"/\""
803
+ },
804
+ "skipToId": {
805
+ "type": "string",
806
+ "mutable": false,
807
+ "complexType": {
808
+ "original": "string",
809
+ "resolved": "string",
810
+ "references": {}
811
+ },
812
+ "required": false,
813
+ "optional": false,
814
+ "docs": {
815
+ "tags": [],
816
+ "text": "The ID of the element where \"skip to content\" link should take the user.\nIf empty, the functionality won\u2019t be rendered in the DOM."
817
+ },
818
+ "attribute": "skip-to-id",
819
+ "reflect": false,
820
+ "defaultValue": "\"\""
821
+ },
822
+ "items": {
823
+ "type": "any",
824
+ "mutable": false,
825
+ "complexType": {
826
+ "original": "any",
827
+ "resolved": "any",
828
+ "references": {}
829
+ },
830
+ "required": false,
831
+ "optional": false,
832
+ "docs": {
833
+ "tags": [],
834
+ "text": "An array of items for the main navigation. Items have to include mandatory\n\"label\" and \"href\" fields to work. Additionally, you can pass an \"id\" that is\nadded as an HTML identifier for the element, \"active\" boolean that makes item active,\n\"badge\" boolean to add notification badge next to the item and\n\"items\" array consisting of sub items that are allowed up to three levels.\nTwo and three level menus are deprecated and you should instead use\nNav component to create multilevel navigations."
835
+ },
836
+ "attribute": "items",
837
+ "reflect": false
838
+ },
839
+ "region": {
840
+ "type": "string",
841
+ "mutable": false,
842
+ "complexType": {
843
+ "original": "string",
844
+ "resolved": "string",
845
+ "references": {}
846
+ },
847
+ "required": false,
848
+ "optional": false,
849
+ "docs": {
850
+ "tags": [],
851
+ "text": "Region that is shown next to the logo. If empty, region will be hidden.\nNote: not available in multilevel header."
852
+ },
853
+ "attribute": "region",
854
+ "reflect": false,
855
+ "defaultValue": "\"\""
856
+ },
857
+ "session": {
858
+ "type": "any",
859
+ "mutable": false,
860
+ "complexType": {
861
+ "original": "any",
862
+ "resolved": "any",
863
+ "references": {}
864
+ },
865
+ "required": false,
866
+ "optional": false,
867
+ "docs": {
868
+ "tags": [],
869
+ "text": "An object that includes mandatory \"label\", \"href\" and \"type\" fields for the\nsession login/logout link. Additionally, you can pass an \"id\" that is added\nas an HTML identifier for the element.\nIf nothing is passed, this link won\u2019t be shown."
870
+ },
871
+ "attribute": "session",
872
+ "reflect": false
873
+ },
874
+ "search": {
875
+ "type": "any",
876
+ "mutable": false,
877
+ "complexType": {
878
+ "original": "any",
879
+ "resolved": "any",
880
+ "references": {}
881
+ },
882
+ "required": false,
883
+ "optional": false,
884
+ "docs": {
885
+ "tags": [],
886
+ "text": "An object that includes mandatory \"label\" and \"href\" fields for the\nsearch link. Additionally, you can pass an \"id\" that is added\nas an HTML identifier for the element. If nothing is passed, this link won\u2019t\nbe shown."
887
+ },
888
+ "attribute": "search",
889
+ "reflect": false
890
+ },
891
+ "back": {
892
+ "type": "any",
893
+ "mutable": false,
894
+ "complexType": {
895
+ "original": "any",
896
+ "resolved": "any",
897
+ "references": {}
898
+ },
899
+ "required": false,
900
+ "optional": false,
901
+ "docs": {
902
+ "tags": [],
903
+ "text": "An object that includes mandatory \"label\" and \"href\" fields for the back link.\nAdditionally, you can pass an \"id\" that is added as an HTML identifier for the\nelement. If nothing is passed, back link won\u2019t be shown. **NOTE: The back link\nshould be ONLY used in combination with language and logoHref props.**"
904
+ },
905
+ "attribute": "back",
906
+ "reflect": false
907
+ },
908
+ "contact": {
909
+ "type": "string",
910
+ "mutable": false,
911
+ "complexType": {
912
+ "original": "string",
913
+ "resolved": "string",
914
+ "references": {}
915
+ },
916
+ "required": false,
917
+ "optional": false,
918
+ "docs": {
919
+ "tags": [],
920
+ "text": "Label of the contact menu. If empty, contact menu will be hidden.\nNote: not available in multilevel headers."
921
+ },
922
+ "attribute": "contact",
923
+ "reflect": false,
924
+ "defaultValue": "\"\""
925
+ },
926
+ "contactItems": {
927
+ "type": "any",
928
+ "mutable": false,
929
+ "complexType": {
930
+ "original": "any",
931
+ "resolved": "any",
932
+ "references": {}
933
+ },
934
+ "required": false,
935
+ "optional": false,
936
+ "docs": {
937
+ "tags": [],
938
+ "text": "An array of items for the contact menu. \"label\" and \"href\" are mandatory.\nAdditionally, you can pass an \"id\" that is added as an HTML identifier for\nthe element, and pass an \"external\" flag if the link is to open in a new window."
939
+ },
940
+ "attribute": "contact-items",
941
+ "reflect": false
942
+ },
943
+ "languageItems": {
944
+ "type": "any",
945
+ "mutable": false,
946
+ "complexType": {
947
+ "original": "any",
948
+ "resolved": "any",
949
+ "references": {}
950
+ },
951
+ "required": false,
952
+ "optional": false,
953
+ "docs": {
954
+ "tags": [],
955
+ "text": "An array of items for the language menu. If empty, the language menu will\nbe hidden. \"label\", \"country\" and \"href\" are mandatory. Additionally you\ncan pass an \"id\" that is added as an HTML identifier for the element."
956
+ },
957
+ "attribute": "language-items",
958
+ "reflect": false
1271
959
  }
1272
- },
1273
- "return": "Promise<void>"
1274
- },
1275
- "docs": {
1276
- "text": "Closes all dropdown menus in header when called.",
1277
- "tags": []
1278
- }
1279
- },
1280
- "setFocus": {
1281
- "complexType": {
1282
- "signature": "(options?: FocusOptions) => Promise<void>",
1283
- "parameters": [{
1284
- "tags": [],
1285
- "text": ""
1286
- }],
1287
- "references": {
1288
- "Promise": {
1289
- "location": "global",
1290
- "id": "global::Promise"
960
+ };
961
+ }
962
+ static get states() {
963
+ return {
964
+ "isContactOpen": {},
965
+ "isLanguageOpen": {},
966
+ "isSessionOpen": {},
967
+ "isSlideOutOpen": {},
968
+ "isSegmentOpen": {},
969
+ "openMenu": {},
970
+ "closedActives": {},
971
+ "processedItems": {},
972
+ "processedLanguageItems": {},
973
+ "processedContactItems": {},
974
+ "processedSession": {},
975
+ "processedSearch": {},
976
+ "processedUser": {},
977
+ "processedBack": {},
978
+ "renderDesktopNav": {}
979
+ };
980
+ }
981
+ static get events() {
982
+ return [{
983
+ "method": "duetChange",
984
+ "name": "duetChange",
985
+ "bubbles": false,
986
+ "cancelable": true,
987
+ "composed": true,
988
+ "docs": {
989
+ "tags": [{
990
+ "name": "deprecated",
991
+ "text": "in favour of more specific events like duetLogoClick.\nCallback for when a user is about to navigate to another page. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
992
+ }],
993
+ "text": ""
994
+ },
995
+ "complexType": {
996
+ "original": "DuetHeaderChangeEvent",
997
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
998
+ "references": {
999
+ "DuetHeaderChangeEvent": {
1000
+ "location": "local",
1001
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1002
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1003
+ }
1004
+ }
1005
+ }
1006
+ }, {
1007
+ "method": "duetSessionClick",
1008
+ "name": "duetSessionClick",
1009
+ "bubbles": true,
1010
+ "cancelable": true,
1011
+ "composed": true,
1012
+ "docs": {
1013
+ "tags": [],
1014
+ "text": "Event for when a user has clicked the session link. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1015
+ },
1016
+ "complexType": {
1017
+ "original": "DuetHeaderChangeEvent",
1018
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1019
+ "references": {
1020
+ "DuetHeaderChangeEvent": {
1021
+ "location": "local",
1022
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1023
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1024
+ }
1025
+ }
1026
+ }
1027
+ }, {
1028
+ "method": "duetSearchClick",
1029
+ "name": "duetSearchClick",
1030
+ "bubbles": true,
1031
+ "cancelable": true,
1032
+ "composed": true,
1033
+ "docs": {
1034
+ "tags": [],
1035
+ "text": "Event for when a user has clicked the search link. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1036
+ },
1037
+ "complexType": {
1038
+ "original": "DuetHeaderChangeEvent",
1039
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1040
+ "references": {
1041
+ "DuetHeaderChangeEvent": {
1042
+ "location": "local",
1043
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1044
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1045
+ }
1046
+ }
1047
+ }
1048
+ }, {
1049
+ "method": "duetUserClick",
1050
+ "name": "duetUserClick",
1051
+ "bubbles": true,
1052
+ "cancelable": true,
1053
+ "composed": true,
1054
+ "docs": {
1055
+ "tags": [],
1056
+ "text": "Event raised when a user has clicked the user link. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1057
+ },
1058
+ "complexType": {
1059
+ "original": "DuetHeaderChangeEvent",
1060
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1061
+ "references": {
1062
+ "DuetHeaderChangeEvent": {
1063
+ "location": "local",
1064
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1065
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1066
+ }
1067
+ }
1068
+ }
1069
+ }, {
1070
+ "method": "duetLanguageSelect",
1071
+ "name": "duetLanguageSelect",
1072
+ "bubbles": true,
1073
+ "cancelable": true,
1074
+ "composed": true,
1075
+ "docs": {
1076
+ "tags": [],
1077
+ "text": "Event raised when a user has selected a language from the language dropdown. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1078
+ },
1079
+ "complexType": {
1080
+ "original": "DuetHeaderChangeEvent",
1081
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1082
+ "references": {
1083
+ "DuetHeaderChangeEvent": {
1084
+ "location": "local",
1085
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1086
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1087
+ }
1088
+ }
1089
+ }
1090
+ }, {
1091
+ "method": "duetLogoClick",
1092
+ "name": "duetLogoClick",
1093
+ "bubbles": true,
1094
+ "cancelable": true,
1095
+ "composed": true,
1096
+ "docs": {
1097
+ "tags": [],
1098
+ "text": "Event raised when a user has clicked the logo. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1099
+ },
1100
+ "complexType": {
1101
+ "original": "DuetHeaderChangeEvent",
1102
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1103
+ "references": {
1104
+ "DuetHeaderChangeEvent": {
1105
+ "location": "local",
1106
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1107
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1108
+ }
1109
+ }
1110
+ }
1111
+ }, {
1112
+ "method": "duetBackClick",
1113
+ "name": "duetBackClick",
1114
+ "bubbles": true,
1115
+ "cancelable": true,
1116
+ "composed": true,
1117
+ "docs": {
1118
+ "tags": [],
1119
+ "text": "Event raised when a user has clicked the back button. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1120
+ },
1121
+ "complexType": {
1122
+ "original": "DuetHeaderChangeEvent",
1123
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1124
+ "references": {
1125
+ "DuetHeaderChangeEvent": {
1126
+ "location": "local",
1127
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1128
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1129
+ }
1130
+ }
1131
+ }
1132
+ }, {
1133
+ "method": "duetContactClick",
1134
+ "name": "duetContactClick",
1135
+ "bubbles": true,
1136
+ "cancelable": true,
1137
+ "composed": true,
1138
+ "docs": {
1139
+ "tags": [],
1140
+ "text": "Event raised when a user has clicked an option from the contact dropdown. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1141
+ },
1142
+ "complexType": {
1143
+ "original": "DuetHeaderChangeEvent",
1144
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1145
+ "references": {
1146
+ "DuetHeaderChangeEvent": {
1147
+ "location": "local",
1148
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1149
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1150
+ }
1151
+ }
1152
+ }
1153
+ }, {
1154
+ "method": "duetItemClick",
1155
+ "name": "duetItemClick",
1156
+ "bubbles": true,
1157
+ "cancelable": true,
1158
+ "composed": true,
1159
+ "docs": {
1160
+ "tags": [],
1161
+ "text": "Event raised when a user has clicked a menu item. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1162
+ },
1163
+ "complexType": {
1164
+ "original": "DuetHeaderChangeEvent",
1165
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1166
+ "references": {
1167
+ "DuetHeaderChangeEvent": {
1168
+ "location": "local",
1169
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1170
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1171
+ }
1172
+ }
1173
+ }
1174
+ }, {
1175
+ "method": "duetSkipClick",
1176
+ "name": "duetSkipClick",
1177
+ "bubbles": true,
1178
+ "cancelable": true,
1179
+ "composed": true,
1180
+ "docs": {
1181
+ "tags": [],
1182
+ "text": "Event raised when a user has clicked the \"skip to content\" button. You can prevent the\ndefault browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via **event.detail.data**."
1183
+ },
1184
+ "complexType": {
1185
+ "original": "DuetHeaderChangeEvent",
1186
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1187
+ "references": {
1188
+ "DuetHeaderChangeEvent": {
1189
+ "location": "local",
1190
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1191
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1192
+ }
1193
+ }
1194
+ }
1195
+ }, {
1196
+ "method": "duetAnalytics",
1197
+ "name": "duetAnalytics",
1198
+ "bubbles": true,
1199
+ "cancelable": true,
1200
+ "composed": true,
1201
+ "docs": {
1202
+ "tags": [],
1203
+ "text": "Event raised when an items with an associated analytics ID is clicked. Analytics ID can be\naccessed via **event.detail.analyticsId**"
1204
+ },
1205
+ "complexType": {
1206
+ "original": "DuetHeaderAnalyticsEvent",
1207
+ "resolved": "{ analyticsId: string; component: \"duet-header\"; }",
1208
+ "references": {
1209
+ "DuetHeaderAnalyticsEvent": {
1210
+ "location": "local",
1211
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1212
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderAnalyticsEvent"
1213
+ }
1214
+ }
1215
+ }
1216
+ }, {
1217
+ "method": "duetMobileNavToggle",
1218
+ "name": "duetMobileNavToggle",
1219
+ "bubbles": true,
1220
+ "cancelable": true,
1221
+ "composed": true,
1222
+ "docs": {
1223
+ "tags": [],
1224
+ "text": "Event raised mobile navigation is toggled. **event.detail.open** shows the current status of the navigation."
1225
+ },
1226
+ "complexType": {
1227
+ "original": "DuetHeaderMobileNavToggleEvent",
1228
+ "resolved": "{ originalEvent: Event; open: boolean; }",
1229
+ "references": {
1230
+ "DuetHeaderMobileNavToggleEvent": {
1231
+ "location": "local",
1232
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1233
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderMobileNavToggleEvent"
1234
+ }
1235
+ }
1236
+ }
1237
+ }, {
1238
+ "method": "duetEvent",
1239
+ "name": "duetEvent",
1240
+ "bubbles": true,
1241
+ "cancelable": true,
1242
+ "composed": true,
1243
+ "docs": {
1244
+ "tags": [],
1245
+ "text": "General event stream for the following events:\nitem: onMouseEnter, onTouchDown;\nmenuItem: onMouseEnter, onTouchDown;.\nYou can prevent\nthe default browser functionality by calling **event.detail.originalEvent.preventDefault()**\ninside your listener. Additionally, the passed data is available via\n**event.detail.data**."
1246
+ },
1247
+ "complexType": {
1248
+ "original": "DuetHeaderChangeEvent",
1249
+ "resolved": "{ originalEvent: Event; data: DuetHeaderItem | DuetHeaderLanguageItem | DuetHeaderSession; component: \"duet-header\"; }",
1250
+ "references": {
1251
+ "DuetHeaderChangeEvent": {
1252
+ "location": "local",
1253
+ "path": "/Users/mgibas/workspace/duet/packages/components/src/components/duet-header/duet-header.tsx",
1254
+ "id": "src/components/duet-header/duet-header.tsx::DuetHeaderChangeEvent"
1255
+ }
1256
+ }
1257
+ }
1258
+ }];
1259
+ }
1260
+ static get methods() {
1261
+ return {
1262
+ "closeMenus": {
1263
+ "complexType": {
1264
+ "signature": "(moveFocusToButton?: boolean) => Promise<void>",
1265
+ "parameters": [{
1266
+ "name": "moveFocusToButton",
1267
+ "type": "boolean",
1268
+ "docs": ""
1269
+ }],
1270
+ "references": {
1271
+ "Promise": {
1272
+ "location": "global",
1273
+ "id": "global::Promise"
1274
+ }
1275
+ },
1276
+ "return": "Promise<void>"
1277
+ },
1278
+ "docs": {
1279
+ "text": "Closes all dropdown menus in header when called.",
1280
+ "tags": []
1281
+ }
1291
1282
  },
1292
- "FocusOptions": {
1293
- "location": "global",
1294
- "id": "global::FocusOptions"
1283
+ "setFocus": {
1284
+ "complexType": {
1285
+ "signature": "(options?: FocusOptions) => Promise<void>",
1286
+ "parameters": [{
1287
+ "name": "options",
1288
+ "type": "FocusOptions",
1289
+ "docs": ""
1290
+ }],
1291
+ "references": {
1292
+ "Promise": {
1293
+ "location": "global",
1294
+ "id": "global::Promise"
1295
+ },
1296
+ "FocusOptions": {
1297
+ "location": "global",
1298
+ "id": "global::FocusOptions"
1299
+ }
1300
+ },
1301
+ "return": "Promise<void>"
1302
+ },
1303
+ "docs": {
1304
+ "text": "Sets focus on the specified `duet-header`. Use this method instead of the global\n`header.focus()`.",
1305
+ "tags": []
1306
+ }
1295
1307
  }
1296
- },
1297
- "return": "Promise<void>"
1298
- },
1299
- "docs": {
1300
- "text": "Sets focus on the specified `duet-header`. Use this method instead of the global\n`header.focus()`.",
1301
- "tags": []
1302
- }
1303
- }
1304
- };
1305
- }
1306
- static get elementRef() { return "element"; }
1307
- static get watchers() {
1308
- return [{
1309
- "propName": "user",
1310
- "methodName": "refresh"
1311
- }, {
1312
- "propName": "items",
1313
- "methodName": "refresh"
1314
- }, {
1315
- "propName": "session",
1316
- "methodName": "refresh"
1317
- }, {
1318
- "propName": "back",
1319
- "methodName": "refresh"
1320
- }, {
1321
- "propName": "contactItems",
1322
- "methodName": "refresh"
1323
- }, {
1324
- "propName": "languageItems",
1325
- "methodName": "refresh"
1326
- }];
1327
- }
1328
- static get listeners() {
1329
- return [{
1330
- "name": "keyup",
1331
- "method": "handleKeyUp",
1332
- "target": "window",
1333
- "capture": false,
1334
- "passive": false
1335
- }, {
1336
- "name": "keydown",
1337
- "method": "handleKeyDown",
1338
- "target": "window",
1339
- "capture": false,
1340
- "passive": false
1341
- }, {
1342
- "name": "focus",
1343
- "method": "handleDocumentClick",
1344
- "target": "document",
1345
- "capture": false,
1346
- "passive": false
1347
- }, {
1348
- "name": "click",
1349
- "method": "handleDocumentClick",
1350
- "target": "document",
1351
- "capture": false,
1352
- "passive": false
1353
- }];
1354
- }
1308
+ };
1309
+ }
1310
+ static get elementRef() { return "element"; }
1311
+ static get watchers() {
1312
+ return [{
1313
+ "propName": "user",
1314
+ "methodName": "refresh"
1315
+ }, {
1316
+ "propName": "items",
1317
+ "methodName": "refresh"
1318
+ }, {
1319
+ "propName": "session",
1320
+ "methodName": "refresh"
1321
+ }, {
1322
+ "propName": "back",
1323
+ "methodName": "refresh"
1324
+ }, {
1325
+ "propName": "contactItems",
1326
+ "methodName": "refresh"
1327
+ }, {
1328
+ "propName": "languageItems",
1329
+ "methodName": "refresh"
1330
+ }];
1331
+ }
1332
+ static get listeners() {
1333
+ return [{
1334
+ "name": "keyup",
1335
+ "method": "handleKeyUp",
1336
+ "target": "window",
1337
+ "capture": false,
1338
+ "passive": false
1339
+ }, {
1340
+ "name": "keydown",
1341
+ "method": "handleKeyDown",
1342
+ "target": "window",
1343
+ "capture": false,
1344
+ "passive": false
1345
+ }, {
1346
+ "name": "focus",
1347
+ "method": "handleDocumentClick",
1348
+ "target": "document",
1349
+ "capture": false,
1350
+ "passive": false
1351
+ }, {
1352
+ "name": "click",
1353
+ "method": "handleDocumentClick",
1354
+ "target": "document",
1355
+ "capture": false,
1356
+ "passive": false
1357
+ }];
1358
+ }
1355
1359
  }