@duetds/components 6.8.2 → 6.8.4

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 (632) hide show
  1. package/hydrate/index.js +407 -86
  2. package/lib/cjs/duet-action-button.cjs.entry.js +11 -2
  3. package/lib/cjs/duet-alert.cjs.entry.js +14 -1
  4. package/lib/cjs/duet-badge.cjs.entry.js +1 -1
  5. package/lib/cjs/duet-breadcrumb.cjs.entry.js +1 -1
  6. package/lib/cjs/duet-breadcrumbs.cjs.entry.js +1 -1
  7. package/lib/cjs/duet-button_2.cjs.entry.js +9 -1
  8. package/lib/cjs/duet-caption_4.cjs.entry.js +15 -1
  9. package/lib/cjs/duet-card.cjs.entry.js +1 -1
  10. package/lib/cjs/duet-checkbox.cjs.entry.js +1 -1
  11. package/lib/cjs/duet-checkmark.cjs.entry.js +1 -1
  12. package/lib/cjs/duet-choice_2.cjs.entry.js +22 -4
  13. package/lib/cjs/duet-collapsible.cjs.entry.js +4 -2
  14. package/lib/cjs/duet-combobox.cjs.entry.js +1 -1
  15. package/lib/cjs/duet-contact-card.cjs.entry.js +1 -1
  16. package/lib/cjs/duet-cookie-consent.cjs.entry.js +1 -1
  17. package/lib/cjs/duet-date-picker.cjs.entry.js +15 -3
  18. package/lib/cjs/duet-divider_2.cjs.entry.js +1 -1
  19. package/lib/cjs/duet-editable-table_3.cjs.entry.js +1 -1
  20. package/lib/cjs/duet-empty-state.cjs.entry.js +1 -1
  21. package/lib/cjs/duet-fieldset.cjs.entry.js +1 -1
  22. package/lib/cjs/duet-footer.cjs.entry.js +14 -2
  23. package/lib/cjs/duet-grid_2.cjs.entry.js +1 -1
  24. package/lib/cjs/duet-header_2.cjs.entry.js +1 -1
  25. package/lib/cjs/duet-hero.cjs.entry.js +1 -1
  26. package/lib/cjs/duet-icon.cjs.entry.js +1 -1
  27. package/lib/cjs/duet-input_2.cjs.entry.js +1 -1
  28. package/lib/cjs/duet-layout.cjs.entry.js +1 -1
  29. package/lib/cjs/duet-list_2.cjs.entry.js +1 -1
  30. package/lib/cjs/duet-menu-bar-button.cjs.entry.js +2 -2
  31. package/lib/cjs/duet-menu-bar-dropdown-link.cjs.entry.js +11 -3
  32. package/lib/cjs/duet-menu-bar-dropdown.cjs.entry.js +17 -4
  33. package/lib/cjs/duet-menu-bar-link.cjs.entry.js +3 -3
  34. package/lib/cjs/duet-menu-bar.cjs.entry.js +7 -1
  35. package/lib/cjs/duet-modal.cjs.entry.js +12 -2
  36. package/lib/cjs/duet-multiselect.cjs.entry.js +1 -1
  37. package/lib/cjs/duet-nav.cjs.entry.js +1 -1
  38. package/lib/cjs/duet-notification_2.cjs.entry.js +1 -1
  39. package/lib/cjs/duet-number-input.cjs.entry.js +3 -3
  40. package/lib/cjs/duet-page-heading.cjs.entry.js +1 -1
  41. package/lib/cjs/duet-pagination_2.cjs.entry.js +6 -4
  42. package/lib/cjs/duet-progress.cjs.entry.js +1 -1
  43. package/lib/cjs/duet-radio_2.cjs.entry.js +1 -1
  44. package/lib/cjs/duet-range-slider.cjs.entry.js +1 -1
  45. package/lib/cjs/duet-scrollable_3.cjs.entry.js +2 -2
  46. package/lib/cjs/duet-section-layout.cjs.entry.js +1 -1
  47. package/lib/cjs/duet-select.cjs.entry.js +1 -1
  48. package/lib/cjs/duet-slideout-lang.cjs.entry.js +9 -2
  49. package/lib/cjs/duet-slideout-link.cjs.entry.js +3 -3
  50. package/lib/cjs/duet-slideout-panel-dropdown.cjs.entry.js +9 -3
  51. package/lib/cjs/duet-slideout-panel.cjs.entry.js +37 -9
  52. package/lib/cjs/duet-slideout.cjs.entry.js +48 -9
  53. package/lib/cjs/duet-step_2.cjs.entry.js +1 -1
  54. package/lib/cjs/duet-submenu-bar-dropdown-link.cjs.entry.js +13 -3
  55. package/lib/cjs/duet-submenu-bar-dropdown.cjs.entry.js +31 -5
  56. package/lib/cjs/duet-submenu-bar-link.cjs.entry.js +12 -3
  57. package/lib/cjs/duet-submenu-bar.cjs.entry.js +42 -4
  58. package/lib/cjs/duet-textarea.cjs.entry.js +1 -1
  59. package/lib/cjs/duet-toggle.cjs.entry.js +1 -1
  60. package/lib/cjs/duet-toolbar-dropdown-link.cjs.entry.js +11 -3
  61. package/lib/cjs/duet-toolbar-dropdown.cjs.entry.js +17 -4
  62. package/lib/cjs/duet-toolbar-link.cjs.entry.js +3 -3
  63. package/lib/cjs/duet-toolbar.cjs.entry.js +1 -1
  64. package/lib/cjs/duet-tooltip.cjs.entry.js +4 -1
  65. package/lib/cjs/duet-tray.cjs.entry.js +1 -1
  66. package/lib/cjs/duet-upload-aria-status.cjs.entry.js +1 -1
  67. package/lib/cjs/duet-visually-hidden.cjs.entry.js +1 -1
  68. package/lib/cjs/duet.cjs.js +2 -2
  69. package/lib/cjs/{focus-utils-65c3a6dd.js → focus-utils-1cfcd199.js} +1 -1
  70. package/lib/cjs/{index-5bd185a8.js → index-ab015402.js} +1 -1
  71. package/lib/cjs/loader.cjs.js +2 -2
  72. package/lib/collection/components/duet-action-button/duet-action-button.js +38 -3
  73. package/lib/collection/components/duet-alert/duet-alert.js +21 -4
  74. package/lib/collection/components/duet-button/duet-button.js +27 -12
  75. package/lib/collection/components/duet-caption/duet-caption.js +1 -1
  76. package/lib/collection/components/duet-card/duet-card.js +3 -3
  77. package/lib/collection/components/duet-checkbox/duet-checkbox.js +3 -3
  78. package/lib/collection/components/duet-choice/duet-choice.js +33 -11
  79. package/lib/collection/components/duet-choice-group/duet-choice-group.css +1 -1
  80. package/lib/collection/components/duet-collapsible/duet-collapsible.css +3 -0
  81. package/lib/collection/components/duet-collapsible/duet-collapsible.js +23 -3
  82. package/lib/collection/components/duet-combobox/duet-combobox.js +3 -3
  83. package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.js +1 -1
  84. package/lib/collection/components/duet-date-picker/duet-date-picker.js +23 -9
  85. package/lib/collection/components/duet-divider/duet-divider.js +1 -1
  86. package/lib/collection/components/duet-editable-table/duet-editable-table.js +5 -5
  87. package/lib/collection/components/duet-empty-state/duet-empty-state.js +1 -1
  88. package/lib/collection/components/duet-footer/duet-footer.js +26 -12
  89. package/lib/collection/components/duet-grid/duet-grid.js +3 -3
  90. package/lib/collection/components/duet-header/duet-header.js +15 -15
  91. package/lib/collection/components/duet-heading/duet-heading.js +1 -1
  92. package/lib/collection/components/duet-hero/duet-hero.js +5 -5
  93. package/lib/collection/components/duet-icon/duet-icon.js +1 -1
  94. package/lib/collection/components/duet-input/duet-input.js +8 -8
  95. package/lib/collection/components/duet-label/duet-label.js +2 -2
  96. package/lib/collection/components/duet-layout/duet-layout.js +1 -1
  97. package/lib/collection/components/duet-link/duet-link.js +20 -3
  98. package/lib/collection/components/duet-list/duet-list.js +4 -4
  99. package/lib/collection/components/duet-logo/duet-logo.js +1 -1
  100. package/lib/collection/components/duet-menu-bar/duet-menu-bar.js +17 -2
  101. package/lib/collection/components/duet-menu-bar-button/duet-menu-bar-button.css +7 -0
  102. package/lib/collection/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.css +7 -0
  103. package/lib/collection/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.js +41 -2
  104. package/lib/collection/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.css +7 -0
  105. package/lib/collection/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.js +9 -1
  106. package/lib/collection/components/duet-menu-bar-link/duet-menu-bar-link.css +7 -0
  107. package/lib/collection/components/duet-menu-bar-link/duet-menu-bar-link.js +1 -1
  108. package/lib/collection/components/duet-modal/duet-modal.js +19 -7
  109. package/lib/collection/components/duet-multiselect/duet-multiselect.js +5 -5
  110. package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.js +1 -1
  111. package/lib/collection/components/duet-number-input/duet-number-input.js +6 -6
  112. package/lib/collection/components/duet-pagination/duet-pagination.js +2 -2
  113. package/lib/collection/components/duet-paragraph/duet-paragraph.js +3 -3
  114. package/lib/collection/components/duet-radio/duet-radio.js +3 -3
  115. package/lib/collection/components/duet-range-slider/duet-range-slider.js +2 -2
  116. package/lib/collection/components/duet-range-stepper/duet-range-stepper.js +6 -4
  117. package/lib/collection/components/duet-select/duet-select.js +5 -5
  118. package/lib/collection/components/duet-slideout/duet-slideout.css +14 -0
  119. package/lib/collection/components/duet-slideout/duet-slideout.js +81 -7
  120. package/lib/collection/components/duet-slideout-lang/duet-slideout-lang.js +14 -2
  121. package/lib/collection/components/duet-slideout-link/duet-slideout-link.css +7 -0
  122. package/lib/collection/components/duet-slideout-link/duet-slideout-link.js +1 -1
  123. package/lib/collection/components/duet-slideout-panel/duet-slideout-panel.css +16 -0
  124. package/lib/collection/components/duet-slideout-panel/duet-slideout-panel.js +63 -8
  125. package/lib/collection/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.css +8 -1
  126. package/lib/collection/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.js +33 -1
  127. package/lib/collection/components/duet-spacer/duet-spacer.js +2 -2
  128. package/lib/collection/components/duet-spinner/duet-spinner.js +1 -1
  129. package/lib/collection/components/duet-step/duet-step.js +2 -2
  130. package/lib/collection/components/duet-stepper/duet-stepper.js +1 -1
  131. package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.css +7 -0
  132. package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.js +71 -2
  133. package/lib/collection/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.css +41 -8
  134. package/lib/collection/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.js +73 -3
  135. package/lib/collection/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.css +30 -0
  136. package/lib/collection/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.js +29 -1
  137. package/lib/collection/components/duet-submenu-bar-link/duet-submenu-bar-link.css +54 -0
  138. package/lib/collection/components/duet-submenu-bar-link/duet-submenu-bar-link.js +28 -1
  139. package/lib/collection/components/duet-tab-group/duet-tab-group.css +8 -0
  140. package/lib/collection/components/duet-tab-group/duet-tab-group.js +4 -4
  141. package/lib/collection/components/duet-textarea/duet-textarea.js +4 -4
  142. package/lib/collection/components/duet-toggle/duet-toggle.js +1 -1
  143. package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.css +7 -0
  144. package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.js +41 -2
  145. package/lib/collection/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.css +7 -0
  146. package/lib/collection/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.js +9 -1
  147. package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.css +7 -0
  148. package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.js +1 -1
  149. package/lib/collection/components/duet-tooltip/duet-tooltip.js +4 -1
  150. package/lib/collection/components/duet-upload/duet-upload.js +13 -13
  151. package/lib/dist-custom-elements/duet-action-button.js +1 -1
  152. package/lib/dist-custom-elements/duet-alert.js +1 -1
  153. package/lib/dist-custom-elements/duet-badge.js +1 -1
  154. package/lib/dist-custom-elements/duet-breadcrumb.js +2 -2
  155. package/lib/dist-custom-elements/duet-breadcrumbs.js +2 -2
  156. package/lib/dist-custom-elements/duet-button.js +1 -1
  157. package/lib/dist-custom-elements/duet-caption.js +1 -1
  158. package/lib/dist-custom-elements/duet-card.js +3 -3
  159. package/lib/dist-custom-elements/duet-checkbox.js +1 -1
  160. package/lib/dist-custom-elements/duet-checkmark.js +1 -1
  161. package/lib/dist-custom-elements/duet-choice-group.js +7 -7
  162. package/lib/dist-custom-elements/duet-choice.js +28 -9
  163. package/lib/dist-custom-elements/duet-collapsible.js +6 -3
  164. package/lib/dist-custom-elements/duet-combobox.js +2 -2
  165. package/lib/dist-custom-elements/duet-contact-card.js +8 -8
  166. package/lib/dist-custom-elements/duet-cookie-consent.js +6 -6
  167. package/lib/dist-custom-elements/duet-date-picker.js +26 -14
  168. package/lib/dist-custom-elements/duet-divider.js +1 -1
  169. package/lib/dist-custom-elements/duet-editable-table.js +1 -1
  170. package/lib/dist-custom-elements/duet-empty-state.js +1 -1
  171. package/lib/dist-custom-elements/duet-fieldset.js +1 -1
  172. package/lib/dist-custom-elements/duet-footer.js +20 -8
  173. package/lib/dist-custom-elements/duet-grid-item.js +1 -1
  174. package/lib/dist-custom-elements/duet-grid.js +1 -1
  175. package/lib/dist-custom-elements/duet-header.js +8 -8
  176. package/lib/dist-custom-elements/duet-heading.js +1 -1
  177. package/lib/dist-custom-elements/duet-hero.js +9 -9
  178. package/lib/dist-custom-elements/duet-icon.js +1 -1
  179. package/lib/dist-custom-elements/duet-input.js +1 -1
  180. package/lib/dist-custom-elements/duet-label.js +1 -1
  181. package/lib/dist-custom-elements/duet-layout.js +1 -1
  182. package/lib/dist-custom-elements/duet-link.js +1 -1
  183. package/lib/dist-custom-elements/duet-list-item.js +1 -1
  184. package/lib/dist-custom-elements/duet-list.js +1 -1
  185. package/lib/dist-custom-elements/duet-logo.js +1 -1
  186. package/lib/dist-custom-elements/duet-menu-bar-button.js +3 -3
  187. package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.js +12 -4
  188. package/lib/dist-custom-elements/duet-menu-bar-dropdown.js +20 -6
  189. package/lib/dist-custom-elements/duet-menu-bar-link.js +4 -4
  190. package/lib/dist-custom-elements/duet-menu-bar.js +9 -3
  191. package/lib/dist-custom-elements/duet-modal.js +20 -10
  192. package/lib/dist-custom-elements/duet-multiselect.js +8 -8
  193. package/lib/dist-custom-elements/duet-nav.js +1 -1
  194. package/lib/dist-custom-elements/duet-notification-drawer.js +4 -4
  195. package/lib/dist-custom-elements/duet-notification.js +2 -2
  196. package/lib/dist-custom-elements/duet-number-input.js +11 -11
  197. package/lib/dist-custom-elements/duet-page-heading.js +2 -2
  198. package/lib/dist-custom-elements/duet-pagination.js +7 -7
  199. package/lib/dist-custom-elements/duet-paragraph.js +1 -1
  200. package/lib/dist-custom-elements/duet-progress.js +1 -1
  201. package/lib/dist-custom-elements/duet-radio-group.js +6 -6
  202. package/lib/dist-custom-elements/duet-radio.js +1 -1
  203. package/lib/dist-custom-elements/duet-range-slider.js +2 -2
  204. package/lib/dist-custom-elements/duet-range-stepper.js +9 -7
  205. package/lib/dist-custom-elements/duet-scrollable.js +1 -1
  206. package/lib/dist-custom-elements/duet-section-layout.js +1 -1
  207. package/lib/dist-custom-elements/duet-select.js +1 -1
  208. package/lib/dist-custom-elements/duet-slideout-lang.js +14 -12
  209. package/lib/dist-custom-elements/duet-slideout-link.js +4 -4
  210. package/lib/dist-custom-elements/duet-slideout-panel-dropdown.js +12 -5
  211. package/lib/dist-custom-elements/duet-slideout-panel.js +41 -11
  212. package/lib/dist-custom-elements/duet-slideout.js +51 -11
  213. package/lib/dist-custom-elements/duet-spacer.js +1 -1
  214. package/lib/dist-custom-elements/duet-spinner.js +1 -1
  215. package/lib/dist-custom-elements/duet-step.js +4 -4
  216. package/lib/dist-custom-elements/duet-stepper.js +2 -2
  217. package/lib/dist-custom-elements/duet-submenu-bar-dropdown-link.js +15 -4
  218. package/lib/dist-custom-elements/duet-submenu-bar-dropdown.js +35 -7
  219. package/lib/dist-custom-elements/duet-submenu-bar-link.js +14 -4
  220. package/lib/dist-custom-elements/duet-submenu-bar.js +46 -6
  221. package/lib/dist-custom-elements/duet-tab-group.js +10 -10
  222. package/lib/dist-custom-elements/duet-tab.js +1 -1
  223. package/lib/dist-custom-elements/duet-table.js +1 -1
  224. package/lib/dist-custom-elements/duet-textarea.js +8 -8
  225. package/lib/dist-custom-elements/duet-toggle.js +2 -2
  226. package/lib/dist-custom-elements/duet-toolbar-dropdown-link.js +12 -4
  227. package/lib/dist-custom-elements/duet-toolbar-dropdown.js +20 -6
  228. package/lib/dist-custom-elements/duet-toolbar-link.js +4 -4
  229. package/lib/dist-custom-elements/duet-toolbar.js +1 -1
  230. package/lib/dist-custom-elements/duet-tooltip.js +1 -1
  231. package/lib/dist-custom-elements/duet-tray.js +3 -3
  232. package/lib/dist-custom-elements/duet-upload-aria-status.js +1 -1
  233. package/lib/dist-custom-elements/duet-upload.js +18 -18
  234. package/lib/dist-custom-elements/duet-visually-hidden.js +1 -1
  235. package/lib/dist-custom-elements/index.js +1 -1
  236. package/lib/dist-custom-elements/{p-a4002a4d.js → p-03f5e1df.js} +1 -1
  237. package/lib/dist-custom-elements/{p-6b444ad0.js → p-104dae34.js} +21 -7
  238. package/lib/dist-custom-elements/{p-df0799f0.js → p-139ccc08.js} +1 -1
  239. package/lib/dist-custom-elements/{p-a1c07138.js → p-14fe8052.js} +1 -1
  240. package/lib/dist-custom-elements/{p-b239c17f.js → p-17a5bfd6.js} +2 -2
  241. package/lib/dist-custom-elements/{p-5881ed64.js → p-1b6d9683.js} +1 -1
  242. package/lib/dist-custom-elements/{p-17f54d13.js → p-21ae30e5.js} +20 -6
  243. package/lib/dist-custom-elements/{p-c828fba6.js → p-258d095f.js} +1 -1
  244. package/lib/dist-custom-elements/{p-84465a50.js → p-2b8d110c.js} +1 -1
  245. package/lib/dist-custom-elements/{p-d0a59e71.js → p-43901e47.js} +1 -1
  246. package/lib/dist-custom-elements/{p-92a173c2.js → p-49026ea5.js} +1 -1
  247. package/lib/dist-custom-elements/{p-7ef0b13d.js → p-51be19a2.js} +1 -1
  248. package/lib/dist-custom-elements/{p-4040e9d1.js → p-5333970a.js} +1 -1
  249. package/lib/dist-custom-elements/{p-68b17599.js → p-6891c1b3.js} +2 -2
  250. package/lib/dist-custom-elements/{p-43f613b6.js → p-6c630da1.js} +1 -1
  251. package/lib/dist-custom-elements/{p-f070808d.js → p-7782af26.js} +2 -2
  252. package/lib/dist-custom-elements/{p-1e73f619.js → p-7cccb592.js} +6 -3
  253. package/lib/dist-custom-elements/{p-27004490.js → p-8a77e325.js} +1 -1
  254. package/lib/dist-custom-elements/{p-c6acb315.js → p-92135039.js} +2 -2
  255. package/lib/dist-custom-elements/{p-f2ee6981.js → p-a53cebf1.js} +1 -1
  256. package/lib/dist-custom-elements/{p-6c1ba2d9.js → p-a89fd096.js} +1 -1
  257. package/lib/dist-custom-elements/{p-4ebe6fca.js → p-a971f4cf.js} +7 -7
  258. package/lib/dist-custom-elements/{p-bd43e7e4.js → p-b2b89a56.js} +2 -2
  259. package/lib/dist-custom-elements/{p-f6dad5c3.js → p-bf71c608.js} +1 -1
  260. package/lib/dist-custom-elements/{p-015d1608.js → p-c05dc335.js} +1 -1
  261. package/lib/dist-custom-elements/{p-a3194fa3.js → p-c1d5b264.js} +8 -8
  262. package/lib/dist-custom-elements/{p-e76d5673.js → p-cd486ca1.js} +6 -6
  263. package/lib/dist-custom-elements/{p-7003023f.js → p-d3e697f4.js} +1 -1
  264. package/lib/dist-custom-elements/{p-2f7dd873.js → p-d4995343.js} +1 -1
  265. package/lib/dist-custom-elements/{p-35850774.js → p-e9e98c22.js} +1 -1
  266. package/lib/dist-custom-elements/{p-07f7b627.js → p-f41d4dba.js} +15 -5
  267. package/lib/dist-custom-elements/{p-b869fb52.js → p-fa93f54b.js} +15 -7
  268. package/lib/duet/duet.esm.js +1 -1
  269. package/lib/duet/duet.js +1 -1
  270. package/lib/duet/{p-7f7f4403.system.entry.js → p-006cfe82.system.entry.js} +1 -1
  271. package/lib/duet/{p-6c05e879.js → p-076452be.js} +1 -1
  272. package/lib/duet/p-0769bfaa.system.entry.js +4 -0
  273. package/lib/duet/{p-c46a5357.js → p-0a64a5a4.js} +1 -1
  274. package/lib/duet/{p-df278f38.system.entry.js → p-0a79b874.system.entry.js} +1 -1
  275. package/lib/duet/{p-f2f38e08.system.entry.js → p-0a96cc2c.system.entry.js} +1 -1
  276. package/lib/duet/{p-2c4f8685.system.entry.js → p-0aac4192.system.entry.js} +1 -1
  277. package/lib/duet/p-0ec18f3b.system.entry.js +4 -0
  278. package/lib/duet/p-0ec5260f.system.entry.js +4 -0
  279. package/lib/duet/p-0f5b0e9a.entry.js +4 -0
  280. package/lib/duet/{p-346a2bd3.system.entry.js → p-0f7ab746.system.entry.js} +1 -1
  281. package/lib/duet/p-141234e3.entry.js +4 -0
  282. package/lib/duet/{p-e3dfa3fd.system.entry.js → p-142e0dd6.system.entry.js} +1 -1
  283. package/lib/duet/{p-68e640b3.system.entry.js → p-15346bb7.system.entry.js} +1 -1
  284. package/lib/duet/p-1578385a.system.entry.js +4 -0
  285. package/lib/duet/p-1835986d.system.entry.js +4 -0
  286. package/lib/duet/p-19deb8bb.entry.js +4 -0
  287. package/lib/duet/{p-0c17cc73.entry.js → p-1bdce03c.entry.js} +1 -1
  288. package/lib/duet/{p-353cdb52.entry.js → p-1c731783.entry.js} +1 -1
  289. package/lib/duet/{p-6dd1beb2.entry.js → p-207ad310.entry.js} +1 -1
  290. package/lib/duet/{p-1a769d18.entry.js → p-21f94254.entry.js} +1 -1
  291. package/lib/duet/{p-a7886626.system.entry.js → p-23500651.system.entry.js} +1 -1
  292. package/lib/duet/{p-7204d1fd.system.entry.js → p-238517b4.system.entry.js} +1 -1
  293. package/lib/duet/{p-42160f39.entry.js → p-25bf58d2.entry.js} +1 -1
  294. package/lib/duet/p-271e6527.entry.js +4 -0
  295. package/lib/duet/p-28b0eafe.entry.js +4 -0
  296. package/lib/duet/{p-d174f424.entry.js → p-2b6e9c34.entry.js} +1 -1
  297. package/lib/duet/{p-b457649c.entry.js → p-2b998d32.entry.js} +1 -1
  298. package/lib/duet/p-2b9c8a7d.entry.js +4 -0
  299. package/lib/duet/{p-0de14da6.system.entry.js → p-2b9fb222.system.entry.js} +1 -1
  300. package/lib/duet/{p-05b8ca0a.system.entry.js → p-2dafbb00.system.entry.js} +1 -1
  301. package/lib/duet/p-322c2769.entry.js +4 -0
  302. package/lib/duet/{p-c3caf728.js → p-32ba724d.js} +1 -1
  303. package/lib/duet/{p-ffa1f02e.system.entry.js → p-33a2e92d.system.entry.js} +1 -1
  304. package/lib/duet/p-3405c2df.entry.js +4 -0
  305. package/lib/duet/p-345381c1.entry.js +4 -0
  306. package/lib/duet/{p-d48d67bc.entry.js → p-3490b163.entry.js} +1 -1
  307. package/lib/duet/p-350bad81.system.entry.js +4 -0
  308. package/lib/duet/{p-d114fc82.entry.js → p-369661b2.entry.js} +1 -1
  309. package/lib/duet/p-39f8bec2.entry.js +4 -0
  310. package/lib/duet/{p-2c8c2eb0.entry.js → p-3b197740.entry.js} +1 -1
  311. package/lib/duet/{p-374e2afa.system.entry.js → p-3d2339ae.system.entry.js} +1 -1
  312. package/lib/duet/{p-f49afb80.system.entry.js → p-433085d5.system.entry.js} +1 -1
  313. package/lib/duet/p-45c55f88.system.entry.js +4 -0
  314. package/lib/duet/p-464e267f.system.js +4 -0
  315. package/lib/duet/{p-41bac23d.entry.js → p-4de46382.entry.js} +1 -1
  316. package/lib/duet/p-514e2f71.entry.js +4 -0
  317. package/lib/duet/p-5252d291.system.entry.js +4 -0
  318. package/lib/duet/p-52a0bf60.system.entry.js +4 -0
  319. package/lib/duet/{p-4d16edd4.system.entry.js → p-53d28f2b.system.entry.js} +1 -1
  320. package/lib/duet/p-545ca91e.system.entry.js +4 -0
  321. package/lib/duet/p-57824291.entry.js +4 -0
  322. package/lib/duet/{p-ae043b1a.entry.js → p-599dfb21.entry.js} +1 -1
  323. package/lib/duet/p-5aaee74b.entry.js +4 -0
  324. package/lib/duet/{p-d2a65bd0.system.entry.js → p-5b0b828a.system.entry.js} +1 -1
  325. package/lib/duet/p-5d3c68ad.system.entry.js +4 -0
  326. package/lib/duet/p-5daa0d26.system.entry.js +4 -0
  327. package/lib/duet/p-5dedf71b.entry.js +4 -0
  328. package/lib/duet/{p-582f45a6.entry.js → p-5f1e31c7.entry.js} +1 -1
  329. package/lib/duet/{p-b0a272b8.system.entry.js → p-5f5fae98.system.entry.js} +1 -1
  330. package/lib/duet/p-6597319a.entry.js +4 -0
  331. package/lib/duet/{p-70703d59.system.entry.js → p-6aa662f0.system.entry.js} +1 -1
  332. package/lib/duet/p-6b7be36b.entry.js +4 -0
  333. package/lib/duet/{p-e0a55532.entry.js → p-6c171fd9.entry.js} +1 -1
  334. package/lib/duet/p-6d99c12c.entry.js +4 -0
  335. package/lib/duet/{p-4a0eabaa.system.entry.js → p-6f930a32.system.entry.js} +1 -1
  336. package/lib/duet/p-71eda242.entry.js +4 -0
  337. package/lib/duet/{p-61b2a984.entry.js → p-73e2201d.entry.js} +1 -1
  338. package/lib/duet/{p-e48b3cb6.system.entry.js → p-76dabced.system.entry.js} +1 -1
  339. package/lib/duet/{p-a2fba110.system.entry.js → p-783530af.system.entry.js} +1 -1
  340. package/lib/duet/{p-08577b4d.entry.js → p-78b89180.entry.js} +1 -1
  341. package/lib/duet/{p-06639fa9.system.js → p-7adef50f.system.js} +1 -1
  342. package/lib/duet/p-8025514b.system.entry.js +4 -0
  343. package/lib/duet/{p-9e0534d6.entry.js → p-8085ad32.entry.js} +1 -1
  344. package/lib/duet/{p-484cb1df.entry.js → p-83ac5c6e.entry.js} +1 -1
  345. package/lib/duet/p-85053e56.system.entry.js +4 -0
  346. package/lib/duet/{p-aba0c851.system.entry.js → p-8661ddb0.system.entry.js} +1 -1
  347. package/lib/duet/{p-898b51f5.entry.js → p-86799457.entry.js} +1 -1
  348. package/lib/duet/{p-ef058a21.system.js → p-8684b2af.system.js} +1 -1
  349. package/lib/duet/p-886f3df1.system.entry.js +4 -0
  350. package/lib/duet/{p-2ed52ca0.system.entry.js → p-88d3cc5a.system.entry.js} +1 -1
  351. package/lib/duet/{p-0f50db76.entry.js → p-8aba8575.entry.js} +1 -1
  352. package/lib/duet/{p-61f38e7c.entry.js → p-8ada2a8a.entry.js} +1 -1
  353. package/lib/duet/{p-3f59ba68.entry.js → p-8c20f50a.entry.js} +1 -1
  354. package/lib/duet/p-8dc321a1.entry.js +4 -0
  355. package/lib/duet/{p-5e3a7392.system.entry.js → p-8de9a81e.system.entry.js} +1 -1
  356. package/lib/duet/{p-0b36298e.system.entry.js → p-8f7a04bc.system.entry.js} +1 -1
  357. package/lib/duet/{p-b1a9298f.entry.js → p-8fcd5734.entry.js} +1 -1
  358. package/lib/duet/p-9116af4f.entry.js +4 -0
  359. package/lib/duet/p-94c6c463.entry.js +4 -0
  360. package/lib/duet/{p-4e21a0e1.entry.js → p-994c33e2.entry.js} +1 -1
  361. package/lib/duet/{p-7b98e5b6.system.entry.js → p-9c456965.system.entry.js} +1 -1
  362. package/lib/duet/p-9eaee650.system.entry.js +4 -0
  363. package/lib/duet/{p-0cc7ecde.system.entry.js → p-a05666f0.system.entry.js} +1 -1
  364. package/lib/duet/p-a08a9752.entry.js +4 -0
  365. package/lib/duet/p-a4042d5b.system.entry.js +4 -0
  366. package/lib/duet/{p-654e6734.system.entry.js → p-a4f9eacd.system.entry.js} +1 -1
  367. package/lib/duet/{p-77e68564.entry.js → p-a7b1f336.entry.js} +1 -1
  368. package/lib/duet/p-ac37e21d.entry.js +4 -0
  369. package/lib/duet/p-ad983011.entry.js +4 -0
  370. package/lib/duet/p-aee5400b.system.entry.js +4 -0
  371. package/lib/duet/p-af47bd24.system.entry.js +4 -0
  372. package/lib/duet/{p-06e42ed2.system.entry.js → p-b16848d3.system.entry.js} +1 -1
  373. package/lib/duet/{p-c99c31f7.entry.js → p-b2ebc2e1.entry.js} +1 -1
  374. package/lib/duet/{p-04e7a695.system.entry.js → p-b3e57f17.system.entry.js} +1 -1
  375. package/lib/duet/{p-b32e5d04.system.entry.js → p-b59904ae.system.entry.js} +1 -1
  376. package/lib/duet/{p-5f6f8b70.entry.js → p-c17ad6a4.entry.js} +1 -1
  377. package/lib/duet/p-c32df4f2.system.entry.js +4 -0
  378. package/lib/duet/{p-e0273afd.system.entry.js → p-c46b2038.system.entry.js} +1 -1
  379. package/lib/duet/{p-f426cd26.system.entry.js → p-c6787142.system.entry.js} +1 -1
  380. package/lib/duet/{p-3646032b.entry.js → p-c8892cfa.entry.js} +1 -1
  381. package/lib/duet/{p-5b5238f6.system.entry.js → p-c8b3d426.system.entry.js} +1 -1
  382. package/lib/duet/{p-2ef88161.system.js → p-c8dc599d.system.js} +1 -1
  383. package/lib/duet/{p-6791f183.system.entry.js → p-ca4539ce.system.entry.js} +2 -2
  384. package/lib/duet/{p-1183c748.entry.js → p-ca8a79e7.entry.js} +1 -1
  385. package/lib/duet/{p-5f4a75ea.system.entry.js → p-ccbff327.system.entry.js} +1 -1
  386. package/lib/duet/p-cf33e4a4.entry.js +4 -0
  387. package/lib/duet/{p-aa4d6d89.entry.js → p-d27f9702.entry.js} +1 -1
  388. package/lib/duet/p-d65b676f.entry.js +4 -0
  389. package/lib/duet/{p-dc399de0.system.entry.js → p-d8769dca.system.entry.js} +1 -1
  390. package/lib/duet/p-daf3ccef.system.entry.js +4 -0
  391. package/lib/duet/{p-29413090.system.entry.js → p-db98a514.system.entry.js} +1 -1
  392. package/lib/duet/{p-3d2b012c.entry.js → p-dc8c7e0b.entry.js} +1 -1
  393. package/lib/duet/p-e0651eca.system.entry.js +4 -0
  394. package/lib/duet/{p-48ee2f44.entry.js → p-e4b73cff.entry.js} +1 -1
  395. package/lib/duet/{p-cd515231.entry.js → p-e829bf10.entry.js} +1 -1
  396. package/lib/duet/{p-24e47e60.system.entry.js → p-ec5ae55d.system.entry.js} +1 -1
  397. package/lib/duet/p-ec9d77cf.system.entry.js +4 -0
  398. package/lib/duet/p-f0384acb.entry.js +4 -0
  399. package/lib/duet/{p-642ab531.system.entry.js → p-f06940f6.system.entry.js} +2 -2
  400. package/lib/duet/{p-9e71007b.system.entry.js → p-f0ba21c3.system.entry.js} +1 -1
  401. package/lib/duet/p-f5e7e0a7.system.entry.js +4 -0
  402. package/lib/duet/p-f6f5032b.entry.js +4 -0
  403. package/lib/duet/p-f738d8e5.entry.js +4 -0
  404. package/lib/duet/{p-308907c6.entry.js → p-faaa35cf.entry.js} +1 -1
  405. package/lib/duet/{p-69617b20.entry.js → p-fb1b340d.entry.js} +1 -1
  406. package/lib/duet/{p-7c95a58b.system.entry.js → p-fc318998.system.entry.js} +1 -1
  407. package/lib/duet/p-fcca01e2.entry.js +4 -0
  408. package/lib/duet/{p-1878784a.entry.js → p-ffba3249.entry.js} +1 -1
  409. package/lib/esm/duet-action-button.entry.js +12 -3
  410. package/lib/esm/duet-alert.entry.js +15 -2
  411. package/lib/esm/duet-badge.entry.js +1 -1
  412. package/lib/esm/duet-breadcrumb.entry.js +1 -1
  413. package/lib/esm/duet-breadcrumbs.entry.js +2 -2
  414. package/lib/esm/duet-button_2.entry.js +10 -2
  415. package/lib/esm/duet-caption_4.entry.js +16 -2
  416. package/lib/esm/duet-card.entry.js +1 -1
  417. package/lib/esm/duet-checkbox.entry.js +1 -1
  418. package/lib/esm/duet-checkmark.entry.js +1 -1
  419. package/lib/esm/duet-choice_2.entry.js +23 -5
  420. package/lib/esm/duet-collapsible.entry.js +4 -2
  421. package/lib/esm/duet-combobox.entry.js +2 -2
  422. package/lib/esm/duet-contact-card.entry.js +2 -2
  423. package/lib/esm/duet-cookie-consent.entry.js +1 -1
  424. package/lib/esm/duet-date-picker.entry.js +16 -4
  425. package/lib/esm/duet-divider_2.entry.js +1 -1
  426. package/lib/esm/duet-editable-table_3.entry.js +2 -2
  427. package/lib/esm/duet-empty-state.entry.js +1 -1
  428. package/lib/esm/duet-fieldset.entry.js +1 -1
  429. package/lib/esm/duet-footer.entry.js +15 -3
  430. package/lib/esm/duet-grid_2.entry.js +1 -1
  431. package/lib/esm/duet-header_2.entry.js +2 -2
  432. package/lib/esm/duet-hero.entry.js +2 -2
  433. package/lib/esm/duet-icon.entry.js +1 -1
  434. package/lib/esm/duet-input_2.entry.js +2 -2
  435. package/lib/esm/duet-layout.entry.js +1 -1
  436. package/lib/esm/duet-list_2.entry.js +1 -1
  437. package/lib/esm/duet-menu-bar-button.entry.js +2 -2
  438. package/lib/esm/duet-menu-bar-dropdown-link.entry.js +11 -3
  439. package/lib/esm/duet-menu-bar-dropdown.entry.js +17 -4
  440. package/lib/esm/duet-menu-bar-link.entry.js +3 -3
  441. package/lib/esm/duet-menu-bar.entry.js +7 -1
  442. package/lib/esm/duet-modal.entry.js +13 -3
  443. package/lib/esm/duet-multiselect.entry.js +2 -2
  444. package/lib/esm/duet-nav.entry.js +1 -1
  445. package/lib/esm/duet-notification_2.entry.js +2 -2
  446. package/lib/esm/duet-number-input.entry.js +4 -4
  447. package/lib/esm/duet-page-heading.entry.js +1 -1
  448. package/lib/esm/duet-pagination_2.entry.js +7 -5
  449. package/lib/esm/duet-progress.entry.js +2 -2
  450. package/lib/esm/duet-radio_2.entry.js +1 -1
  451. package/lib/esm/duet-range-slider.entry.js +1 -1
  452. package/lib/esm/duet-scrollable_3.entry.js +3 -3
  453. package/lib/esm/duet-section-layout.entry.js +1 -1
  454. package/lib/esm/duet-select.entry.js +1 -1
  455. package/lib/esm/duet-slideout-lang.entry.js +10 -3
  456. package/lib/esm/duet-slideout-link.entry.js +3 -3
  457. package/lib/esm/duet-slideout-panel-dropdown.entry.js +9 -3
  458. package/lib/esm/duet-slideout-panel.entry.js +38 -10
  459. package/lib/esm/duet-slideout.entry.js +48 -9
  460. package/lib/esm/duet-step_2.entry.js +1 -1
  461. package/lib/esm/duet-submenu-bar-dropdown-link.entry.js +13 -3
  462. package/lib/esm/duet-submenu-bar-dropdown.entry.js +31 -5
  463. package/lib/esm/duet-submenu-bar-link.entry.js +12 -3
  464. package/lib/esm/duet-submenu-bar.entry.js +42 -4
  465. package/lib/esm/duet-textarea.entry.js +1 -1
  466. package/lib/esm/duet-toggle.entry.js +1 -1
  467. package/lib/esm/duet-toolbar-dropdown-link.entry.js +11 -3
  468. package/lib/esm/duet-toolbar-dropdown.entry.js +17 -4
  469. package/lib/esm/duet-toolbar-link.entry.js +3 -3
  470. package/lib/esm/duet-toolbar.entry.js +1 -1
  471. package/lib/esm/duet-tooltip.entry.js +5 -2
  472. package/lib/esm/duet-tray.entry.js +2 -2
  473. package/lib/esm/duet-upload-aria-status.entry.js +1 -1
  474. package/lib/esm/duet-visually-hidden.entry.js +1 -1
  475. package/lib/esm/duet.js +3 -3
  476. package/lib/esm/{focus-utils-21a3a53d.js → focus-utils-5c277b1d.js} +1 -1
  477. package/lib/esm/{index-bcaee850.js → index-dc7d6b8d.js} +1 -1
  478. package/lib/esm/{language-utils-7b211f31.js → language-utils-6be16ff0.js} +1 -1
  479. package/lib/esm/loader.js +3 -3
  480. package/lib/esm-es5/duet-action-button.entry.js +1 -1
  481. package/lib/esm-es5/duet-alert.entry.js +2 -2
  482. package/lib/esm-es5/duet-badge.entry.js +1 -1
  483. package/lib/esm-es5/duet-breadcrumb.entry.js +1 -1
  484. package/lib/esm-es5/duet-breadcrumbs.entry.js +1 -1
  485. package/lib/esm-es5/duet-button_2.entry.js +1 -1
  486. package/lib/esm-es5/duet-caption_4.entry.js +1 -1
  487. package/lib/esm-es5/duet-card.entry.js +1 -1
  488. package/lib/esm-es5/duet-checkbox.entry.js +1 -1
  489. package/lib/esm-es5/duet-checkmark.entry.js +1 -1
  490. package/lib/esm-es5/duet-choice_2.entry.js +2 -2
  491. package/lib/esm-es5/duet-collapsible.entry.js +1 -1
  492. package/lib/esm-es5/duet-combobox.entry.js +1 -1
  493. package/lib/esm-es5/duet-contact-card.entry.js +1 -1
  494. package/lib/esm-es5/duet-cookie-consent.entry.js +1 -1
  495. package/lib/esm-es5/duet-date-picker.entry.js +1 -1
  496. package/lib/esm-es5/duet-divider_2.entry.js +1 -1
  497. package/lib/esm-es5/duet-editable-table_3.entry.js +1 -1
  498. package/lib/esm-es5/duet-empty-state.entry.js +1 -1
  499. package/lib/esm-es5/duet-fieldset.entry.js +1 -1
  500. package/lib/esm-es5/duet-footer.entry.js +2 -2
  501. package/lib/esm-es5/duet-grid_2.entry.js +2 -2
  502. package/lib/esm-es5/duet-header_2.entry.js +1 -1
  503. package/lib/esm-es5/duet-hero.entry.js +1 -1
  504. package/lib/esm-es5/duet-icon.entry.js +2 -2
  505. package/lib/esm-es5/duet-input_2.entry.js +1 -1
  506. package/lib/esm-es5/duet-layout.entry.js +1 -1
  507. package/lib/esm-es5/duet-list_2.entry.js +1 -1
  508. package/lib/esm-es5/duet-menu-bar-button.entry.js +2 -2
  509. package/lib/esm-es5/duet-menu-bar-dropdown-link.entry.js +1 -1
  510. package/lib/esm-es5/duet-menu-bar-dropdown.entry.js +2 -2
  511. package/lib/esm-es5/duet-menu-bar-link.entry.js +1 -1
  512. package/lib/esm-es5/duet-menu-bar.entry.js +1 -1
  513. package/lib/esm-es5/duet-modal.entry.js +1 -1
  514. package/lib/esm-es5/duet-multiselect.entry.js +1 -1
  515. package/lib/esm-es5/duet-nav.entry.js +1 -1
  516. package/lib/esm-es5/duet-notification_2.entry.js +1 -1
  517. package/lib/esm-es5/duet-number-input.entry.js +1 -1
  518. package/lib/esm-es5/duet-page-heading.entry.js +1 -1
  519. package/lib/esm-es5/duet-pagination_2.entry.js +1 -1
  520. package/lib/esm-es5/duet-progress.entry.js +1 -1
  521. package/lib/esm-es5/duet-radio_2.entry.js +1 -1
  522. package/lib/esm-es5/duet-range-slider.entry.js +1 -1
  523. package/lib/esm-es5/duet-scrollable_3.entry.js +2 -2
  524. package/lib/esm-es5/duet-section-layout.entry.js +1 -1
  525. package/lib/esm-es5/duet-select.entry.js +1 -1
  526. package/lib/esm-es5/duet-slideout-lang.entry.js +1 -1
  527. package/lib/esm-es5/duet-slideout-link.entry.js +1 -1
  528. package/lib/esm-es5/duet-slideout-panel-dropdown.entry.js +2 -2
  529. package/lib/esm-es5/duet-slideout-panel.entry.js +2 -2
  530. package/lib/esm-es5/duet-slideout.entry.js +2 -2
  531. package/lib/esm-es5/duet-step_2.entry.js +1 -1
  532. package/lib/esm-es5/duet-submenu-bar-dropdown-link.entry.js +1 -1
  533. package/lib/esm-es5/duet-submenu-bar-dropdown.entry.js +2 -2
  534. package/lib/esm-es5/duet-submenu-bar-link.entry.js +1 -1
  535. package/lib/esm-es5/duet-submenu-bar.entry.js +2 -2
  536. package/lib/esm-es5/duet-textarea.entry.js +1 -1
  537. package/lib/esm-es5/duet-toggle.entry.js +1 -1
  538. package/lib/esm-es5/duet-toolbar-dropdown-link.entry.js +1 -1
  539. package/lib/esm-es5/duet-toolbar-dropdown.entry.js +2 -2
  540. package/lib/esm-es5/duet-toolbar-link.entry.js +1 -1
  541. package/lib/esm-es5/duet-toolbar.entry.js +1 -1
  542. package/lib/esm-es5/duet-tooltip.entry.js +1 -1
  543. package/lib/esm-es5/duet-tray.entry.js +1 -1
  544. package/lib/esm-es5/duet-upload-aria-status.entry.js +1 -1
  545. package/lib/esm-es5/duet-visually-hidden.entry.js +1 -1
  546. package/lib/esm-es5/duet.js +1 -1
  547. package/lib/esm-es5/focus-utils-5c277b1d.js +4 -0
  548. package/lib/esm-es5/{index-bcaee850.js → index-dc7d6b8d.js} +1 -1
  549. package/lib/esm-es5/{language-utils-7b211f31.js → language-utils-6be16ff0.js} +1 -1
  550. package/lib/esm-es5/loader.js +1 -1
  551. package/lib/types/components/duet-action-button/duet-action-button.d.ts +6 -0
  552. package/lib/types/components/duet-alert/duet-alert.d.ts +4 -1
  553. package/lib/types/components/duet-button/duet-button.d.ts +3 -2
  554. package/lib/types/components/duet-choice/duet-choice.d.ts +6 -2
  555. package/lib/types/components/duet-collapsible/duet-collapsible.d.ts +4 -0
  556. package/lib/types/components/duet-date-picker/duet-date-picker.d.ts +3 -0
  557. package/lib/types/components/duet-footer/duet-footer.d.ts +3 -0
  558. package/lib/types/components/duet-link/duet-link.d.ts +3 -0
  559. package/lib/types/components/duet-menu-bar/duet-menu-bar.d.ts +3 -1
  560. package/lib/types/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.d.ts +6 -0
  561. package/lib/types/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.d.ts +1 -0
  562. package/lib/types/components/duet-modal/duet-modal.d.ts +2 -0
  563. package/lib/types/components/duet-range-stepper/duet-range-stepper.d.ts +0 -1
  564. package/lib/types/components/duet-slideout/duet-slideout.d.ts +13 -1
  565. package/lib/types/components/duet-slideout-lang/duet-slideout-lang.d.ts +4 -1
  566. package/lib/types/components/duet-slideout-panel/duet-slideout-panel.d.ts +9 -1
  567. package/lib/types/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.d.ts +5 -0
  568. package/lib/types/components/duet-submenu-bar/duet-submenu-bar.d.ts +11 -0
  569. package/lib/types/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.d.ts +10 -0
  570. package/lib/types/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.d.ts +9 -0
  571. package/lib/types/components/duet-submenu-bar-link/duet-submenu-bar-link.d.ts +5 -0
  572. package/lib/types/components/duet-toolbar-dropdown/duet-toolbar-dropdown.d.ts +6 -0
  573. package/lib/types/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.d.ts +1 -0
  574. package/lib/types/components/duet-tooltip/duet-tooltip.d.ts +1 -0
  575. package/lib/types/components.d.ts +68 -4
  576. package/package.json +5 -5
  577. package/lib/duet/p-02f78e7e.entry.js +0 -4
  578. package/lib/duet/p-0936046f.system.entry.js +0 -4
  579. package/lib/duet/p-095c84a5.system.entry.js +0 -4
  580. package/lib/duet/p-0bc5e109.entry.js +0 -4
  581. package/lib/duet/p-14f3c696.system.entry.js +0 -4
  582. package/lib/duet/p-151a48c3.entry.js +0 -4
  583. package/lib/duet/p-151ed5e0.system.entry.js +0 -4
  584. package/lib/duet/p-181d4b35.entry.js +0 -4
  585. package/lib/duet/p-1dcbe259.entry.js +0 -4
  586. package/lib/duet/p-1e65e29d.system.entry.js +0 -4
  587. package/lib/duet/p-2020fc25.system.entry.js +0 -4
  588. package/lib/duet/p-28d28436.system.entry.js +0 -4
  589. package/lib/duet/p-28fabb76.entry.js +0 -4
  590. package/lib/duet/p-3815cc9a.entry.js +0 -4
  591. package/lib/duet/p-3c4d9930.system.entry.js +0 -4
  592. package/lib/duet/p-3e428087.entry.js +0 -4
  593. package/lib/duet/p-40411d3b.system.entry.js +0 -4
  594. package/lib/duet/p-4176d5a4.entry.js +0 -4
  595. package/lib/duet/p-488a4d3f.entry.js +0 -4
  596. package/lib/duet/p-498b7d6a.system.entry.js +0 -4
  597. package/lib/duet/p-50e66d06.entry.js +0 -4
  598. package/lib/duet/p-5bc052a4.entry.js +0 -4
  599. package/lib/duet/p-5db96ea2.system.entry.js +0 -4
  600. package/lib/duet/p-5fa09cdb.entry.js +0 -4
  601. package/lib/duet/p-61785e0b.system.entry.js +0 -4
  602. package/lib/duet/p-658283be.system.entry.js +0 -4
  603. package/lib/duet/p-6d4d5fc6.entry.js +0 -4
  604. package/lib/duet/p-727d0488.entry.js +0 -4
  605. package/lib/duet/p-72988da1.entry.js +0 -4
  606. package/lib/duet/p-746ea729.entry.js +0 -4
  607. package/lib/duet/p-78f118fb.entry.js +0 -4
  608. package/lib/duet/p-803ceb21.system.entry.js +0 -4
  609. package/lib/duet/p-86e6814a.entry.js +0 -4
  610. package/lib/duet/p-8b0d3fae.system.entry.js +0 -4
  611. package/lib/duet/p-97eeacac.entry.js +0 -4
  612. package/lib/duet/p-9e886ecf.entry.js +0 -4
  613. package/lib/duet/p-a1eb24b8.system.entry.js +0 -4
  614. package/lib/duet/p-a5689603.system.entry.js +0 -4
  615. package/lib/duet/p-a7edccbb.entry.js +0 -4
  616. package/lib/duet/p-a8bb4f37.entry.js +0 -4
  617. package/lib/duet/p-aeea9d49.system.entry.js +0 -4
  618. package/lib/duet/p-b75cdfc6.entry.js +0 -4
  619. package/lib/duet/p-b8a5580a.entry.js +0 -4
  620. package/lib/duet/p-b9eec94d.entry.js +0 -4
  621. package/lib/duet/p-c4c035fe.entry.js +0 -4
  622. package/lib/duet/p-c7b12a60.system.js +0 -4
  623. package/lib/duet/p-c954e200.system.entry.js +0 -4
  624. package/lib/duet/p-d719bc5b.system.entry.js +0 -4
  625. package/lib/duet/p-d8ccc12d.entry.js +0 -4
  626. package/lib/duet/p-ea17eb88.entry.js +0 -4
  627. package/lib/duet/p-ec7a79f2.system.entry.js +0 -4
  628. package/lib/duet/p-f3089cd4.system.entry.js +0 -4
  629. package/lib/duet/p-f3c7ffda.system.entry.js +0 -4
  630. package/lib/duet/p-f550f63a.system.entry.js +0 -4
  631. package/lib/duet/p-f5623ee8.entry.js +0 -4
  632. package/lib/esm-es5/focus-utils-21a3a53d.js +0 -4
@@ -1,10 +1,10 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
 
7
- const duetSlideoutLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}.duet-slideout-link{position:relative;display:flex;gap:20px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:8px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:inherit;font-weight:inherit;line-height:1.25;color:inherit;text-align:left;text-decoration:none}.duet-slideout-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\"}.duet-slideout-link.active span{position:relative}.duet-slideout-link.active span::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:var(--active-height, 2px);content:\"\";background:rgb(0, 119, 179);transform:var(--active-translate-y, translateY(2px))}.duet-slideout-link.active.duet-theme-turva span::after{background:rgb(198, 12, 48)}.duet-slideout-link.small{font-size:1rem;font-weight:600}.duet-slideout-link.small span::after{--active-height:1px;--active-translate-y:1px}.duet-slideout-link.medium{font-size:1.25rem;font-weight:600}.duet-slideout-link.large{font-size:1.5rem;font-weight:800}.duet-slideout-link .label{display:flex;gap:0.5rem;align-items:center;justify-content:space-between;width:100%}slot[name=description]::slotted(*){display:block;padding:8px 0 0;font-size:1rem;font-size:1.25;font-weight:400;color:rgb(101, 119, 135)}.duet-theme-turva slot[name=description]::slotted(*){color:rgb(68, 68, 69)}";
7
+ const duetSlideoutLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}.duet-slideout-link{position:relative;display:flex;gap:20px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:8px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:inherit;font-weight:inherit;line-height:1.25;color:inherit;text-align:left;text-decoration:none}.duet-slideout-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\"}.duet-slideout-link:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-slideout-link:focus.duet-theme-turva{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-slideout-link.active span{position:relative}.duet-slideout-link.active span::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:var(--active-height, 2px);content:\"\";background:rgb(0, 119, 179);transform:var(--active-translate-y, translateY(2px))}.duet-slideout-link.active.duet-theme-turva span::after{background:rgb(198, 12, 48)}.duet-slideout-link.small{font-size:1rem;font-weight:600}.duet-slideout-link.small span::after{--active-height:1px;--active-translate-y:1px}.duet-slideout-link.medium{font-size:1.25rem;font-weight:600}.duet-slideout-link.large{font-size:1.5rem;font-weight:800}.duet-slideout-link .label{display:flex;gap:0.5rem;align-items:center;justify-content:space-between;width:100%}slot[name=description]::slotted(*){display:block;padding:8px 0 0;font-size:1rem;font-size:1.25;font-weight:400;color:rgb(101, 119, 135)}.duet-theme-turva slot[name=description]::slotted(*){color:rgb(68, 68, 69)}";
8
8
 
9
9
  const DuetSlideoutLink = class {
10
10
  constructor(hostRef) {
@@ -35,7 +35,7 @@ const DuetSlideoutLink = class {
35
35
  "duet-theme-turva": this.theme === "turva",
36
36
  active: this.active,
37
37
  [this.size]: true,
38
- }, href: this.href, role: this.menuItem && "menuitem", lang: this.targetLanguage, hreflang: this.targetLanguage, "aria-label": this.accessibleLabel }, this.icon && (h("duet-icon", { name: this.icon, color: "secondary", size: this.menuItem ? "x-small" : "medium", margin: "none" })), h("div", { class: "label" }, h("span", null, h("slot", null), h("slot", { name: "description" })), this.caret && (h("duet-icon", { name: "action-arrow-right", color: "secondary", size: "x-small", margin: "none" }))))));
38
+ }, href: this.href, "aria-current": this.active ? "true" : "false", lang: this.targetLanguage, hreflang: this.targetLanguage, "aria-label": this.accessibleLabel }, this.icon && (h("duet-icon", { name: this.icon, color: "secondary", size: this.menuItem ? "x-small" : "medium", margin: "none" })), h("div", { class: "label" }, h("span", null, h("slot", null), h("slot", { name: "description" })), this.caret && (h("duet-icon", { name: "action-arrow-right", color: "secondary", size: "x-small", margin: "none" }))))));
39
39
  }
40
40
  get element() { return getElement(this); }
41
41
  };
@@ -1,10 +1,10 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
 
7
- const duetSlideoutPanelDropdownCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}:host slot:not([name=label])::slotted(*){position:relative;top:-0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot:not([name=label])::slotted(*){top:0;opacity:1}.duet-slideout-panel-dropdown{position:relative;width:100%;height:100%}.duet-slideout-panel-dropdown button{position:relative;display:flex;gap:20px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:8px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1.25rem;font-weight:800;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none;cursor:pointer}.duet-slideout-panel-dropdown button .label{position:relative;display:flex;gap:0.5rem;align-items:center;justify-content:center}.duet-slideout-panel-dropdown button.active .label::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:calc(100% - 18px);height:1px;content:\"\";background:rgb(0, 119, 179);transform:translateY(1px)}.duet-slideout-panel-dropdown .items{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-height:1000px;padding:0 20px 8px 44px;overflow-y:auto;visibility:visible;transition:max-height 0.3s ease-in, padding-bottom 0.3s ease-in;-ms-overflow-style:none;scrollbar-width:none}.duet-slideout-panel-dropdown .items::-webkit-scrollbar{display:none}.duet-slideout-panel-dropdown .items.hidden{max-height:0;padding:0;overflow:hidden;visibility:hidden;transition:max-height 0.3s ease-out, padding-bottom 0.3s ease-out}.duet-slideout-panel-dropdown.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-slideout-panel-dropdown.duet-theme-turva button.active .label::after{background:rgb(198, 12, 48)}slot{--active-height:1px;--active-translate-y:translateY(1px);font-size:1rem;font-weight:400;color:rgb(0, 41, 77)}.duet-theme-turva slot{color:rgb(23, 28, 58)}slot[name=label]{font-size:1rem;font-weight:600}";
7
+ const duetSlideoutPanelDropdownCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}:host slot:not([name=label])::slotted(*){position:relative;top:-0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot:not([name=label])::slotted(*){top:0;opacity:1}.duet-slideout-panel-dropdown{position:relative;width:100%;height:100%}.duet-slideout-panel-dropdown button{position:relative;display:flex;gap:20px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:8px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1.25rem;font-weight:800;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none;cursor:pointer}.duet-slideout-panel-dropdown button .label{position:relative;display:flex;gap:0.5rem;align-items:center;justify-content:center}.duet-slideout-panel-dropdown button:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-slideout-panel-dropdown button.active .label::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:calc(100% - 18px);height:1px;content:\"\";background:rgb(0, 119, 179);transform:translateY(1px)}.duet-slideout-panel-dropdown .items{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-height:1000px;padding:4px 20px 8px 44px;overflow-y:auto;visibility:visible;transition:max-height 0.3s ease-in, padding-bottom 0.3s ease-in;-ms-overflow-style:none;scrollbar-width:none}.duet-slideout-panel-dropdown .items::-webkit-scrollbar{display:none}.duet-slideout-panel-dropdown .items.hidden{max-height:0;padding:0;overflow:hidden;visibility:hidden;transition:max-height 0.3s ease-out, padding-bottom 0.3s ease-out}.duet-slideout-panel-dropdown.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-slideout-panel-dropdown.duet-theme-turva button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-slideout-panel-dropdown.duet-theme-turva button.active .label::after{background:rgb(198, 12, 48)}slot{--active-height:1px;--active-translate-y:translateY(1px);font-size:1rem;font-weight:400;color:rgb(0, 41, 77)}.duet-theme-turva slot{color:rgb(23, 28, 58)}slot[name=label]{font-size:1rem;font-weight:600}";
8
8
 
9
9
  const DuetSlideoutPanelDropdown = class {
10
10
  constructor(hostRef) {
@@ -33,6 +33,12 @@ const DuetSlideoutPanelDropdown = class {
33
33
  link.menuItem = true;
34
34
  });
35
35
  }
36
+ /**
37
+ * Sets focus. Use this method instead of the global focus().
38
+ */
39
+ async setFocus(options) {
40
+ this.button.focus(options);
41
+ }
36
42
  /**
37
43
  * render() function
38
44
  * Always the last one in the class.
@@ -42,7 +48,7 @@ const DuetSlideoutPanelDropdown = class {
42
48
  "duet-slideout-panel-dropdown": true,
43
49
  "duet-theme-turva": this.theme === "turva",
44
50
  active: this.open,
45
- } }, h("button", { "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
51
+ } }, h("button", { ref: element => (this.button = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", "aria-current": this.active ? "true" : "false", id: "button", type: "button", class: {
46
52
  active: this.active,
47
53
  }, onClick: this.onClick }, this.icon && h("duet-icon", { name: this.icon, size: "medium", margin: "none", color: "secondary" }), h("div", { class: "label" }, h("slot", { name: "label" }), h("duet-icon", { class: "caret", name: "action-arrow-down-small", margin: "none", size: "xx-small", color: "secondary" }))), h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
48
54
  items: true,
@@ -1,23 +1,28 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
- import { F as FocusGuard } from './focus-utils-21a3a53d.js';
7
- import { g as getLocaleString } from './language-utils-7b211f31.js';
6
+ import { F as FocusGuard } from './focus-utils-5c277b1d.js';
7
+ import { g as getLanguage, c as connectLanguageChangeObserver, d as disconnectLanguageChangeObserver, a as getLocaleString } from './language-utils-6be16ff0.js';
8
8
  import { g as getColorByName } from './token-utils-b531747a.js';
9
9
  import './string-utils-5954f458.js';
10
10
  import './tokens.module-d3321092.js';
11
11
 
12
- const duetSlideoutPanelCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}:host slot:not([name=label])::slotted(*){position:relative;top:0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot:not([name=label])::slotted(*){top:0;opacity:1}.duet-slideout-panel{position:relative;height:100%}.duet-slideout-panel .link{position:relative;display:flex;gap:20px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:8px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1.5rem;font-weight:800;line-height:1.25;color:rgb(0, 41, 77);text-align:left;text-decoration:none;cursor:pointer}.duet-slideout-panel .link .label{display:flex;gap:0.5rem;align-items:center;justify-content:space-between;width:100%}.duet-slideout-panel .link .label-text.small{font-size:1rem;font-weight:600}.duet-slideout-panel .link .label-text.medium{font-size:1.25rem;font-weight:600}.duet-slideout-panel .link .label-text.large{font-size:1.5rem;font-weight:800}.duet-slideout-panel .link.active .label-text{position:relative}.duet-slideout-panel .link.active .label-text.small::after{height:1px;transform:translateY(1px)}.duet-slideout-panel .link.active .label-text::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:2px;content:\"\";background:rgb(0, 119, 179);transform:translateY(2px)}.duet-slideout-panel .dialog{position:fixed;top:0;left:0;z-index:600;width:100%;height:100%;overflow-y:auto;visibility:visible}.duet-slideout-panel .dialog.hidden{visibility:hidden}.duet-slideout-panel .dialog.hidden .top .back,.duet-slideout-panel .dialog.hidden .top span{opacity:0}.duet-slideout-panel .top{display:flex;align-items:center;justify-content:space-between;padding:4px}.duet-slideout-panel .top .back{opacity:1;transition:top 0.3s ease-in, opacity 0.3s ease-in}.duet-slideout-panel .top duet-icon{padding:16px}.duet-slideout-panel .top span{font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.5;color:rgb(0, 41, 77);opacity:1;transition:top 0.3s ease-in, opacity 0.3s ease-in}.duet-slideout-panel .items{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:1rem 16px;overflow-y:auto;color:rgb(0, 41, 77)}.duet-slideout-panel.duet-theme-turva .link{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-slideout-panel.duet-theme-turva .link.active .label-text::after{background:rgb(198, 12, 48)}.duet-slideout-panel.duet-theme-turva .top span{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}slot:not([name=label]){--active-height:1px;--active-translate-y:translateY(1px);font-size:1rem;font-weight:600;color:rgb(0, 41, 77)}.duet-theme-turva slot:not([name=label]){color:rgb(23, 28, 58)}";
12
+ const duetSlideoutPanelCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}:host slot:not([name=label])::slotted(*){position:relative;top:0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot:not([name=label])::slotted(*){top:0;opacity:1}.duet-slideout-panel{position:relative;height:100%}.duet-slideout-panel .link{position:relative;display:flex;gap:20px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:8px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1.5rem;font-weight:800;line-height:1.25;color:rgb(0, 41, 77);text-align:left;text-decoration:none;cursor:pointer}.duet-slideout-panel .link .label{display:flex;gap:0.5rem;align-items:center;justify-content:space-between;width:100%}.duet-slideout-panel .link .label-text.small{font-size:1rem;font-weight:600}.duet-slideout-panel .link .label-text.medium{font-size:1.25rem;font-weight:600}.duet-slideout-panel .link .label-text.large{font-size:1.5rem;font-weight:800}.duet-slideout-panel .link:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-slideout-panel .link.active .label-text{position:relative}.duet-slideout-panel .link.active .label-text.small::after{height:1px;transform:translateY(1px)}.duet-slideout-panel .link.active .label-text::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:2px;content:\"\";background:rgb(0, 119, 179);transform:translateY(2px)}.duet-slideout-panel .dialog{position:fixed;top:0;left:0;z-index:600;width:100%;height:100%;overflow-y:auto;visibility:visible}.duet-slideout-panel .dialog.hidden{visibility:hidden}.duet-slideout-panel .dialog.hidden .top .back,.duet-slideout-panel .dialog.hidden .top span{opacity:0}.duet-slideout-panel .top{display:flex;align-items:center;justify-content:space-between;padding:4px}.duet-slideout-panel .top .back{opacity:1;transition:top 0.3s ease-in, opacity 0.3s ease-in}.duet-slideout-panel .top .back:focus,.duet-slideout-panel .top .close:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-slideout-panel .top duet-icon{padding:16px}.duet-slideout-panel .top span{font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.5;color:rgb(0, 41, 77);opacity:1;transition:top 0.3s ease-in, opacity 0.3s ease-in}.duet-slideout-panel .items{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:1rem 16px;overflow-y:auto;color:rgb(0, 41, 77)}.duet-slideout-panel.duet-theme-turva .link{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-slideout-panel.duet-theme-turva .link:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-slideout-panel.duet-theme-turva .link.active .label-text::after{background:rgb(198, 12, 48)}.duet-slideout-panel.duet-theme-turva .top .back:focus,.duet-slideout-panel.duet-theme-turva .top .close:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-slideout-panel.duet-theme-turva .top span{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}slot:not([name=label]){--active-height:1px;--active-translate-y:translateY(1px);font-size:1rem;font-weight:600;color:rgb(0, 41, 77)}.duet-theme-turva slot:not([name=label]){color:rgb(23, 28, 58)}";
13
13
 
14
14
  const DuetSlideoutPanel = class {
15
15
  constructor(hostRef) {
16
16
  registerInstance(this, hostRef);
17
17
  this.exitLangObject = {
18
- en: "Exit the dialog",
19
- fi: "Poistu dialogista",
20
- sv: "Stäng dialogrutan",
18
+ en: "Exit the menu",
19
+ fi: "Poistu valikosta",
20
+ sv: "Avsluta menyn",
21
+ };
22
+ this.backLangObject = {
23
+ en: "Back to main menu",
24
+ fi: "Takaisin päävalikkoon",
25
+ sv: "Tillbaka till huvudmenyn",
21
26
  };
22
27
  this.updateLabel = () => {
23
28
  const labelSlotElement = this.element.querySelector("[slot='label']");
@@ -46,6 +51,7 @@ const DuetSlideoutPanel = class {
46
51
  }
47
52
  };
48
53
  this.label = undefined;
54
+ this.language = getLanguage();
49
55
  this.theme = "";
50
56
  this.active = false;
51
57
  this.open = false;
@@ -60,6 +66,27 @@ const DuetSlideoutPanel = class {
60
66
  inheritGlobalTheme(this);
61
67
  this.updateLabel();
62
68
  }
69
+ connectedCallback() {
70
+ connectLanguageChangeObserver(this);
71
+ }
72
+ disconnectedCallback() {
73
+ disconnectLanguageChangeObserver(this);
74
+ }
75
+ /**
76
+ * Sets focus. Use this method instead of the global focus().
77
+ */
78
+ async setFocus(options) {
79
+ if (this.open) {
80
+ setTimeout(() => {
81
+ this.closeButton.focus(options);
82
+ }, 200);
83
+ }
84
+ else {
85
+ setTimeout(() => {
86
+ this.openButton.focus(options);
87
+ }, 200);
88
+ }
89
+ }
63
90
  /**
64
91
  * render() function
65
92
  * Always the last one in the class.
@@ -74,19 +101,20 @@ const DuetSlideoutPanel = class {
74
101
  background: getColorByName(defaultBackgroundColor, this.theme),
75
102
  };
76
103
  const exitTranslation = getLocaleString(this.exitLangObject);
104
+ const backTranslation = getLocaleString(this.backLangObject);
77
105
  return (h(Host, null, h("div", { class: {
78
106
  "duet-slideout-panel": true,
79
107
  "duet-theme-turva": this.theme === "turva",
80
108
  active: this.open,
81
- } }, h("button", { ref: element => (this.openButton = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
109
+ } }, h("button", { ref: element => (this.openButton = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", "aria-current": this.active ? "true" : "false", id: "button", type: "button", class: {
82
110
  link: true,
83
111
  active: this.active,
84
112
  }, onClick: this.onToggleClick }, this.icon && h("duet-icon", { name: this.icon, size: "medium", margin: "none", color: "secondary" }), h("div", { class: "label" }, h("span", { class: { "label-text": true, [this.labelSize]: true } }, h("slot", { name: "label" })), h("duet-icon", { class: "caret", name: "action-arrow-right", margin: "none", size: "x-small", color: "secondary" }))), h("div", { class: {
85
113
  dialog: true,
86
114
  hidden: !this.open,
87
- }, style: styles }, h(FocusGuard, { moveFocusTo: this.closeButton }), h("div", { class: "top" }, h("button", { ref: element => (this.closeButton = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", type: "button", class: {
115
+ }, style: styles }, h(FocusGuard, { moveFocusTo: this.closeButton }), h("div", { class: "top" }, h("button", { ref: element => (this.closeButton = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", "aria-label": `${backTranslation}`, type: "button", class: {
88
116
  back: true,
89
- }, onClick: this.onToggleClick }, h("duet-icon", { class: "caret", name: "action-arrow-left", margin: "none", size: "small", color: "secondary" })), h("span", null, this.label.innerHTML), h("button", { type: "button", onClick: this.onCloseClick, "aria-label": `${exitTranslation}` }, h("duet-icon", { name: "navigation-close", size: "small", margin: "none", color: "secondary" }))), h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
117
+ }, onClick: this.onToggleClick }, h("duet-icon", { class: "caret", name: "action-arrow-left", margin: "none", size: "small", color: "secondary" })), h("span", null, this.label.innerHTML), h("button", { class: "close", type: "button", onClick: this.onCloseClick, "aria-label": `${exitTranslation}` }, h("duet-icon", { name: "navigation-close", size: "small", margin: "none", color: "secondary" }))), h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
90
118
  items: true,
91
119
  } }, h("slot", null)), h(FocusGuard, { moveFocusTo: this.closeButton })))));
92
120
  }
@@ -1,18 +1,26 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
- import { F as FocusGuard } from './focus-utils-21a3a53d.js';
6
+ import { F as FocusGuard } from './focus-utils-5c277b1d.js';
7
+ import { f as isEscapeKey } from './keyboard-utils-d237bd5a.js';
8
+ import { g as getLanguage, c as connectLanguageChangeObserver, d as disconnectLanguageChangeObserver, a as getLocaleString } from './language-utils-6be16ff0.js';
7
9
  import { g as getColorByName } from './token-utils-b531747a.js';
10
+ import './string-utils-5954f458.js';
8
11
  import './tokens.module-d3321092.js';
9
12
 
10
- const duetSlideoutCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}:host slot:not([name=toggle])::slotted(*){position:relative;visibility:hidden;opacity:0}:host([open]) slot:not([name=toggle])::slotted(*){visibility:visible;opacity:1}.duet-slideout{display:flex;align-items:center;height:100%}.duet-slideout .desktop-bg{display:none}@media (min-width: 62em){.duet-slideout .desktop-bg{position:fixed;top:0;left:0;z-index:400;display:block;width:100%;height:100%;visibility:hidden;background:rgba(0, 41, 77, 0.6);opacity:0;transition:600ms ease}.duet-slideout .desktop-bg:not(.hidden){visibility:visible;opacity:1;transition:600ms ease}}@media (min-width: 62em){.duet-slideout.duet-theme-turva .desktop-bg{background:rgba(23, 28, 58, 0.6)}}.duet-slideout .dialog{position:fixed;top:0;bottom:0;left:0;z-index:400;width:100%;height:100%;overflow-y:auto;box-shadow:0 3px 6px 0 rgba(0, 41, 77, 0.1) inset}@media (min-width: 62em){.duet-slideout .dialog{right:0;left:auto;width:500px;transition:right 300ms ease;transition-delay:0s}}.duet-slideout .dialog .top{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-end;padding:4px}.duet-slideout .dialog .top button{cursor:pointer}.duet-slideout .dialog .top duet-icon{padding:16px}.duet-slideout .dialog .items{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;width:100%;padding:0 1.5rem}.duet-slideout .dialog.hidden{pointer-events:none;visibility:hidden}@media (min-width: 62em){.duet-slideout .dialog.hidden{right:-500px;transition:300ms ease}}.duet-slideout.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-slideout.duet-theme-turva button.active{color:rgb(198, 12, 48)}.duet-slideout.duet-theme-turva button.active::after{background:rgb(198, 12, 48)}::slotted(*){width:100%}slot{color:rgb(0, 41, 77)}.duet-theme-turva slot{color:rgb(23, 28, 58)}slot[name=toggle]{color:inherit}";
13
+ const duetSlideoutCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}:host slot:not([name=toggle])::slotted(*){position:relative;visibility:hidden;opacity:0}:host([open]) slot:not([name=toggle])::slotted(*){visibility:visible;opacity:1}:host(:not([open])) ::slotted(duet-slideout-panel){display:none}.duet-slideout{display:flex;align-items:center;height:100%}.duet-slideout .desktop-bg{display:none}@media (min-width: 62em){.duet-slideout .desktop-bg{position:fixed;top:0;left:0;z-index:400;display:block;width:100%;height:100%;visibility:hidden;background:rgba(0, 41, 77, 0.6);opacity:0;transition:600ms ease}.duet-slideout .desktop-bg:not(.hidden){visibility:visible;opacity:1;transition:600ms ease}}@media (min-width: 62em){.duet-slideout.duet-theme-turva .desktop-bg{background:rgba(23, 28, 58, 0.6)}}.duet-slideout .dialog{position:fixed;top:0;bottom:0;left:0;z-index:400;width:100%;height:100%;overflow-y:auto;box-shadow:0 3px 6px 0 rgba(0, 41, 77, 0.1) inset}@media (min-width: 62em){.duet-slideout .dialog{right:0;left:auto;width:500px;transition:right 300ms ease;transition-delay:0s}}.duet-slideout .dialog .top{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-end;padding:4px}.duet-slideout .dialog .top button{cursor:pointer}.duet-slideout .dialog .top button:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-slideout .dialog .top duet-icon{padding:16px}.duet-slideout .dialog .items{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;width:100%;padding:0 1.5rem}.duet-slideout .dialog.hidden{pointer-events:none;visibility:hidden}@media (min-width: 62em){.duet-slideout .dialog.hidden{right:-500px;transition:300ms ease}}.duet-slideout.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-slideout.duet-theme-turva button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-slideout.duet-theme-turva button.active{color:rgb(198, 12, 48)}.duet-slideout.duet-theme-turva button.active::after{background:rgb(198, 12, 48)}.duet-slideout .dialog .top button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}::slotted(*){width:100%}slot{color:rgb(0, 41, 77)}.duet-theme-turva slot{color:rgb(23, 28, 58)}slot[name=toggle]{color:inherit}";
11
14
 
12
15
  const DuetSlideout = class {
13
16
  constructor(hostRef) {
14
17
  registerInstance(this, hostRef);
15
18
  this.duetSlideoutEvent = createEvent(this, "duetSlideoutEvent", 7);
19
+ this.exitLangObject = {
20
+ en: "Exit the menu",
21
+ fi: "Poistu valikosta",
22
+ sv: "Avsluta menyn",
23
+ };
16
24
  this.toggleMenu = (e) => {
17
25
  const toggle = !this.open;
18
26
  this.open = toggle;
@@ -23,9 +31,15 @@ const DuetSlideout = class {
23
31
  component: "duet-slideout",
24
32
  });
25
33
  if (toggle) {
26
- setTimeout(() => {
27
- this.closeButton.focus();
28
- }, 200);
34
+ const openPanel = this.element.querySelector("duet-slideout-panel[open]");
35
+ if (openPanel) {
36
+ openPanel.setFocus();
37
+ }
38
+ else {
39
+ setTimeout(() => {
40
+ this.closeButton.focus();
41
+ }, 200);
42
+ }
29
43
  }
30
44
  else {
31
45
  setTimeout(() => {
@@ -36,6 +50,7 @@ const DuetSlideout = class {
36
50
  this.onClick = (e) => {
37
51
  this.toggleMenu(e);
38
52
  };
53
+ this.language = getLanguage();
39
54
  this.theme = "";
40
55
  this.open = false;
41
56
  this.backgroundColor = "gray-lightest";
@@ -59,8 +74,8 @@ const DuetSlideout = class {
59
74
  this.openButton = this.element.querySelector(":scope > [slot='toggle']");
60
75
  }
61
76
  if (this.openButton) {
62
- this.openButton.setAttribute("aria-haspopup", "dialog");
63
- this.openButton.setAttribute("aria-expanded", "false");
77
+ this.openButton.accessiblePopup = "true";
78
+ this.openButton.accessibleExpanded = false;
64
79
  this.openButton.addEventListener("click", e => {
65
80
  e.stopPropagation();
66
81
  e.preventDefault();
@@ -69,6 +84,29 @@ const DuetSlideout = class {
69
84
  this.openButton = this.openButton;
70
85
  }
71
86
  }
87
+ connectedCallback() {
88
+ connectLanguageChangeObserver(this);
89
+ }
90
+ disconnectedCallback() {
91
+ disconnectLanguageChangeObserver(this);
92
+ }
93
+ /**
94
+ * Component event handling.
95
+ */
96
+ handleKeyUp(ev) {
97
+ // When Esc is pressed
98
+ if (isEscapeKey(ev)) {
99
+ if (this.open) {
100
+ this.toggleMenu(ev);
101
+ }
102
+ }
103
+ }
104
+ /**
105
+ * Sets focus. Use this method instead of the global focus().
106
+ */
107
+ async setFocus(options) {
108
+ this.openButton.focus(options);
109
+ }
72
110
  /**
73
111
  * render() function
74
112
  * Always the last one in the class.
@@ -77,6 +115,7 @@ const DuetSlideout = class {
77
115
  const styles = {
78
116
  background: getColorByName(this.backgroundColor, this.theme),
79
117
  };
118
+ const exitTranslation = getLocaleString(this.exitLangObject);
80
119
  return (h(Host, null, h("div", { class: { "duet-slideout": true, "duet-theme-turva": this.theme === "turva" } }, h("slot", { name: "toggle" }), h("div", { class: {
81
120
  "desktop-bg": true,
82
121
  hidden: !this.open,
@@ -85,7 +124,7 @@ const DuetSlideout = class {
85
124
  } }), h("div", { tabindex: "-1", role: "dialog", id: "dialog", "aria-labelledby": "button", "aria-modal": "true", "aria-flowto": "menubar", class: {
86
125
  dialog: true,
87
126
  hidden: !this.open,
88
- }, style: styles }, h(FocusGuard, { moveFocusTo: this.closeButton }), h("div", { class: "top" }, h("button", { ref: element => (this.closeButton = element), "aria-haspopup": "dialog", "aria-controls": "dialog", "aria-expanded": this.open ? "true" : "false", type: "button", class: {
127
+ }, style: styles }, h(FocusGuard, { moveFocusTo: this.closeButton }), h("div", { class: "top" }, h("button", { ref: element => (this.closeButton = element), "aria-haspopup": "dialog", "aria-controls": "dialog", "aria-expanded": this.open ? "true" : "false", "aria-label": `${exitTranslation}`, type: "button", class: {
89
128
  "slideout-close": true,
90
129
  active: this.open,
91
130
  }, onClick: this.onClick }, h("duet-icon", { name: "navigation-close", size: "small", margin: "none", color: "secondary" }))), h("div", { id: "menubar", role: "menubar", class: {
@@ -1,7 +1,7 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, c as createEvent, h, g as getElement, H as Host } from './index-bcaee850.js';
4
+ import { r as registerInstance, c as createEvent, h, g as getElement, H as Host } from './index-dc7d6b8d.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
  import { c as createID } from './create-id-981107da.js';
7
7
  import { i as isKeyboardClick } from './keyboard-utils-d237bd5a.js';
@@ -1,15 +1,17 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
+ import { f as isEscapeKey } from './keyboard-utils-d237bd5a.js';
6
7
 
7
- const duetSubmenuBarDropdownLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}.duet-submenu-bar-dropdown-link{display:flex;flex-direction:row;gap:0.5rem;align-items:center;justify-content:flex-start;height:100%;padding:8px 20px 8px 60px;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}@media (min-width: 62em){.duet-submenu-bar-dropdown-link{padding:0.675rem 16px;font-size:0.875rem}}.duet-submenu-bar-dropdown-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}@media (min-width: 62em){.duet-submenu-bar-dropdown-link:hover{color:rgb(0, 77, 128);background:rgb(243, 249, 252)}.duet-submenu-bar-dropdown-link:hover.duet-theme-turva{color:rgb(148, 9, 37);background:rgb(245, 245, 247)}}.duet-submenu-bar-dropdown-link.highlight{color:rgb(0, 119, 179)}.duet-submenu-bar-dropdown-link.highlight.duet-theme-turva{color:rgb(148, 9, 37)}";
8
+ const duetSubmenuBarDropdownLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}.duet-submenu-bar-dropdown-link{display:flex;flex-direction:row;gap:0.5rem;align-items:center;justify-content:flex-start;height:100%;padding:8px 20px 8px 60px;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}@media (min-width: 62em){.duet-submenu-bar-dropdown-link{padding:0.675rem 16px;font-size:0.875rem}}.duet-submenu-bar-dropdown-link:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-submenu-bar-dropdown-link:focus.duet-theme-turva{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-submenu-bar-dropdown-link.active .label{position:relative}.duet-submenu-bar-dropdown-link.active .label::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transform:1px}@media (min-width: 62em){.duet-submenu-bar-dropdown-link.active .label::after{display:none}}.duet-submenu-bar-dropdown-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-submenu-bar-dropdown-link.duet-theme-turva.active .label::after{background:rgb(198, 12, 48)}@media (min-width: 62em){.duet-submenu-bar-dropdown-link:hover{color:rgb(0, 77, 128);background:rgb(243, 249, 252)}.duet-submenu-bar-dropdown-link:hover.duet-theme-turva{color:rgb(148, 9, 37);background:rgb(245, 245, 247)}}.duet-submenu-bar-dropdown-link.highlight{color:rgb(0, 119, 179)}.duet-submenu-bar-dropdown-link.highlight.duet-theme-turva{color:rgb(148, 9, 37)}";
8
9
 
9
10
  const DuetSubmenuBarDropdownLink = class {
10
11
  constructor(hostRef) {
11
12
  registerInstance(this, hostRef);
12
13
  this.theme = "";
14
+ this.active = false;
13
15
  this.href = "#";
14
16
  this.icon = undefined;
15
17
  this.caret = false;
@@ -21,6 +23,13 @@ const DuetSubmenuBarDropdownLink = class {
21
23
  componentWillLoad() {
22
24
  inheritGlobalTheme(this);
23
25
  }
26
+ handleEscape(e) {
27
+ if (isEscapeKey(e)) {
28
+ const dropdown = this.element.closest("duet-submenu-bar-dropdown");
29
+ dropdown.open = false;
30
+ dropdown.setFocus();
31
+ }
32
+ }
24
33
  /**
25
34
  * render() function
26
35
  * Always the last one in the class.
@@ -30,7 +39,8 @@ const DuetSubmenuBarDropdownLink = class {
30
39
  "duet-submenu-bar-dropdown-link": true,
31
40
  "duet-theme-turva": this.theme === "turva",
32
41
  highlight: this.highlight,
33
- }, href: this.href, role: "menuitem" }, this.icon && h("duet-icon", { name: this.icon, size: "x-small", margin: "none", color: "currentColor" }), h("slot", null), this.caret && h("duet-icon", { name: "action-arrow-right-small", size: "xxx-small", margin: "none" }))));
42
+ active: this.active,
43
+ }, "aria-current": this.active ? "true" : "false", href: this.href, onKeyUp: e => this.handleEscape(e) }, this.icon && h("duet-icon", { name: this.icon, size: "x-small", margin: "none", color: "currentColor" }), h("span", { class: "label" }, h("slot", null)), this.caret && h("duet-icon", { name: "action-arrow-right-small", size: "xxx-small", margin: "none" }))));
34
44
  }
35
45
  get element() { return getElement(this); }
36
46
  };
@@ -1,11 +1,12 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
5
  import { m as media_query_large } from './tokens-0963dc8b.js';
6
6
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
7
+ import { f as isEscapeKey } from './keyboard-utils-d237bd5a.js';
7
8
 
8
- const duetSubmenuBarDropdownCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}@media (min-width: 62em){:host{width:auto}}.duet-submenu-bar-dropdown{position:relative;height:100%}.duet-submenu-bar-dropdown button{position:relative;display:flex;flex-direction:row;gap:16px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:12px 1.5rem;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none;cursor:pointer}@media (min-width: 62em){.duet-submenu-bar-dropdown button{flex-direction:column;gap:5px;align-items:center;justify-content:center;width:auto;font-size:0.875rem;color:rgb(0, 77, 128)}}.duet-submenu-bar-dropdown button .label{display:flex;gap:5px;align-items:center;justify-content:center}.duet-submenu-bar-dropdown button.active .caret{transform:rotate(180deg)}@media (min-width: 62em){.duet-submenu-bar-dropdown button .caret{position:absolute;right:12px}.duet-submenu-bar-dropdown button:hover{color:rgb(0, 41, 77);background:rgb(230, 242, 248)}.duet-submenu-bar-dropdown button:hover.active{color:rgb(0, 119, 179)}.duet-submenu-bar-dropdown button.active{color:rgb(0, 119, 179)}.duet-theme-turva .duet-submenu-bar-dropdown button.active{color:rgb(198, 12, 48)}.duet-submenu-bar-dropdown button.active::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transition:300ms ease;transform:translateY(1px)}.duet-theme-turva .duet-submenu-bar-dropdown button.active::after{background:rgb(198, 12, 48)}}.duet-submenu-bar-dropdown .items{display:flex;flex-direction:column;align-items:center;justify-content:center;max-height:1000px;padding:0 0 16px;overflow-y:auto;color:rgb(0, 41, 77);visibility:visible;transition:max-height 0.3s ease-in, padding 0.3s ease-in;-ms-overflow-style:none;scrollbar-width:none}.duet-submenu-bar-dropdown .items::-webkit-scrollbar{display:none}@media (min-width: 62em){.duet-submenu-bar-dropdown .items{position:absolute;top:102%;z-index:600;min-width:320px;padding:0;background:rgb(255, 255, 255);border-radius:0 0 4px 4px;box-shadow:0 6px 6px 0 rgba(0, 41, 77, 0.1);transition:none}}.duet-submenu-bar-dropdown .items.hidden{max-height:0;padding:0;overflow:hidden;visibility:hidden;transition:max-height 0.3s ease-in, padding 0.3s ease-in}.duet-submenu-bar-dropdown.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}@media (min-width: 62em){.duet-submenu-bar-dropdown.duet-theme-turva button:hover{background:rgb(228, 228, 230)}}@media (min-width: 62em){.duet-submenu-bar-dropdown.duet-theme-turva button.active{color:rgb(148, 9, 37)}}.duet-submenu-bar-dropdown.duet-theme-turva button.active::after{background:rgb(148, 9, 37)}@media (min-width: 62em){.duet-submenu-bar-dropdown.duet-theme-turva .items{background:rgb(255, 255, 255)}}";
9
+ const duetSubmenuBarDropdownCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}@media (min-width: 62em){:host{width:auto}}.duet-submenu-bar-dropdown{position:relative;height:100%}.duet-submenu-bar-dropdown button{position:relative;display:flex;flex-direction:row;gap:16px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:12px 1.5rem;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none;cursor:pointer}@media (min-width: 62em){.duet-submenu-bar-dropdown button{flex-direction:column;gap:5px;align-items:center;justify-content:center;width:auto;font-size:0.875rem;color:rgb(0, 77, 128)}}.duet-submenu-bar-dropdown button .label{display:flex;gap:5px;align-items:center;justify-content:center}.duet-submenu-bar-dropdown button:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-submenu-bar-dropdown button.open .caret{transform:rotate(180deg)}.duet-submenu-bar-dropdown button.active .label-text{position:relative}.duet-submenu-bar-dropdown button.active .label-text::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transform:1px}@media (min-width: 62em){.duet-submenu-bar-dropdown button.active .label-text::after{display:none}}@media (min-width: 62em){.duet-submenu-bar-dropdown button .caret{position:absolute;right:12px}.duet-submenu-bar-dropdown button:hover{color:rgb(0, 41, 77);background:rgb(230, 242, 248)}.duet-submenu-bar-dropdown button:hover.active{color:rgb(0, 41, 77)}.duet-theme-turva .duet-submenu-bar-dropdown button:hover.active{color:rgb(23, 28, 58)}.duet-submenu-bar-dropdown button.active{color:rgb(0, 119, 179)}.duet-theme-turva .duet-submenu-bar-dropdown button.active{color:rgb(198, 12, 48)}.duet-submenu-bar-dropdown button.active::after,.duet-submenu-bar-dropdown button.open::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transition:300ms ease;transform:translateY(1px)}.duet-theme-turva .duet-submenu-bar-dropdown button.active::after,.duet-theme-turva .duet-submenu-bar-dropdown button.open::after{background:rgb(198, 12, 48)}}.duet-submenu-bar-dropdown .items{display:flex;flex-direction:column;align-items:center;justify-content:center;max-height:1000px;padding:4px 0 16px;overflow-y:auto;color:rgb(0, 41, 77);visibility:visible;transition:max-height 0.3s ease-in, padding 0.3s ease-in;-ms-overflow-style:none;scrollbar-width:none}.duet-submenu-bar-dropdown .items::-webkit-scrollbar{display:none}@media (min-width: 62em){.duet-submenu-bar-dropdown .items{position:absolute;top:102%;z-index:600;min-width:320px;padding:4px 0 0;background:rgb(255, 255, 255);border-radius:0 0 4px 4px;box-shadow:0 6px 6px 0 rgba(0, 41, 77, 0.1);transition:none}}.duet-submenu-bar-dropdown .items.hidden{max-height:0;padding:0;overflow:hidden;visibility:hidden;transition:max-height 0.3s ease-in, padding 0.3s ease-in}.duet-submenu-bar-dropdown.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-submenu-bar-dropdown.duet-theme-turva button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}@media (min-width: 62em){.duet-submenu-bar-dropdown.duet-theme-turva button:hover{background:rgb(228, 228, 230)}}.duet-submenu-bar-dropdown.duet-theme-turva button.active .label-text::after,.duet-submenu-bar-dropdown.duet-theme-turva button.open .label-text::after{background:rgb(198, 12, 48)}@media (min-width: 62em){.duet-submenu-bar-dropdown.duet-theme-turva button.active,.duet-submenu-bar-dropdown.duet-theme-turva button.open{color:rgb(148, 9, 37)}}.duet-submenu-bar-dropdown.duet-theme-turva button.active::after,.duet-submenu-bar-dropdown.duet-theme-turva button.open::after{background:rgb(148, 9, 37)}@media (min-width: 62em){.duet-submenu-bar-dropdown.duet-theme-turva .items{background:rgb(255, 255, 255)}}";
9
10
 
10
11
  const DuetSubmenuBarDropdown = class {
11
12
  constructor(hostRef) {
@@ -28,6 +29,7 @@ const DuetSubmenuBarDropdown = class {
28
29
  };
29
30
  this.iconSize = "small";
30
31
  this.theme = "";
32
+ this.active = false;
31
33
  this.open = false;
32
34
  this.icon = undefined;
33
35
  }
@@ -63,14 +65,38 @@ const DuetSubmenuBarDropdown = class {
63
65
  }
64
66
  this.boundMqlFunctions = [];
65
67
  }
68
+ handleEscape(e) {
69
+ if (isEscapeKey(e)) {
70
+ if (this.open) {
71
+ this.open = false;
72
+ }
73
+ else {
74
+ const dropdown = this.element.closest("duet-submenu-bar");
75
+ dropdown.open = false;
76
+ dropdown.setFocus();
77
+ }
78
+ }
79
+ }
80
+ /**
81
+ * Sets focus. Use this method instead of the global focus().
82
+ */
83
+ async setFocus(options) {
84
+ this.button.focus(options);
85
+ }
66
86
  /**
67
87
  * render() function
68
88
  * Always the last one in the class.
69
89
  */
70
90
  render() {
71
- return (h(Host, null, h("div", { class: { "duet-submenu-bar-dropdown": true, "duet-theme-turva": this.theme === "turva", active: this.open } }, h("button", { "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
72
- active: this.open,
73
- }, onClick: this.onClick }, this.icon && (h("duet-icon", { theme: this.theme, name: this.icon, size: this.iconSize, margin: "none", color: "currentColor" })), h("div", { class: "label" }, h("slot", { name: "label" }), h("duet-icon", { class: "caret", theme: this.theme, name: "action-arrow-down-small", margin: "none", size: "xxx-small", color: "currentColor" }))), h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
91
+ return (h(Host, null, h("div", { class: {
92
+ "duet-submenu-bar-dropdown": true,
93
+ "duet-theme-turva": this.theme === "turva",
94
+ open: this.open,
95
+ active: this.active,
96
+ } }, h("button", { ref: element => (this.button = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", "aria-current": this.active ? "true" : "false", id: "button", type: "button", class: {
97
+ open: this.open,
98
+ active: this.active,
99
+ }, onClick: this.onClick, onKeyUp: e => this.handleEscape(e) }, this.icon && (h("duet-icon", { theme: this.theme, name: this.icon, size: this.iconSize, margin: "none", color: "currentColor" })), h("div", { class: "label" }, h("span", { class: "label-text" }, h("slot", { name: "label" })), h("duet-icon", { class: "caret", theme: this.theme, name: "action-arrow-down-small", margin: "none", size: "xxx-small", color: "currentColor" }))), h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
74
100
  items: true,
75
101
  hidden: !this.open,
76
102
  } }, h("slot", null)))));
@@ -1,11 +1,12 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
5
  import { m as media_query_large } from './tokens-0963dc8b.js';
6
6
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
7
+ import { f as isEscapeKey } from './keyboard-utils-d237bd5a.js';
7
8
 
8
- const duetSubmenuBarLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}@media (min-width: 62em){:host{width:auto}}.duet-submenu-bar-link{display:flex;flex-direction:row;gap:16px;align-items:center;justify-content:flex-start;height:100%;padding:12px 1.5rem;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}@media (min-width: 62em){.duet-submenu-bar-link{flex-direction:column;gap:5px;align-items:center;justify-content:center;font-size:0.875rem;color:rgb(0, 77, 128)}}.duet-submenu-bar-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}@media (min-width: 62em){.duet-submenu-bar-link:hover{color:rgb(0, 41, 77);background:rgb(230, 242, 248)}.duet-submenu-bar-link:hover.duet-theme-turva{color:rgb(23, 28, 58);background:rgb(228, 228, 230)}}";
9
+ const duetSubmenuBarLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}@media (min-width: 62em){:host{width:auto}}.duet-submenu-bar-link{display:flex;flex-direction:row;gap:16px;align-items:center;justify-content:flex-start;height:100%;padding:12px 1.5rem;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}@media (min-width: 62em){.duet-submenu-bar-link{flex-direction:column;gap:5px;align-items:center;justify-content:center;font-size:0.875rem;color:rgb(0, 77, 128)}}.duet-submenu-bar-link:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-submenu-bar-link:focus.duet-theme-turva{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}@media (min-width: 62em){.duet-submenu-bar-link.active{color:rgb(0, 119, 179)}.duet-theme-turva .duet-submenu-bar-link.active{color:rgb(198, 12, 48)}}.duet-submenu-bar-link.active .label{position:relative}.duet-submenu-bar-link.active .label::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transform:1px}@media (min-width: 62em){.duet-submenu-bar-link.active .label::after{display:none}.duet-submenu-bar-link.active::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transition:300ms ease;transform:translateY(1px)}}.duet-submenu-bar-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-submenu-bar-link.duet-theme-turva.active .label::after{background:rgb(198, 12, 48)}.duet-submenu-bar-link.duet-theme-turva.active::after{background:rgb(198, 12, 48)}@media (min-width: 62em){.duet-submenu-bar-link:hover{color:rgb(0, 41, 77);background:rgb(230, 242, 248)}.duet-submenu-bar-link:hover.duet-theme-turva{color:rgb(23, 28, 58);background:rgb(228, 228, 230)}}";
9
10
 
10
11
  const DuetSubmenuBarLink = class {
11
12
  constructor(hostRef) {
@@ -25,6 +26,7 @@ const DuetSubmenuBarLink = class {
25
26
  };
26
27
  this.iconSize = "small";
27
28
  this.theme = "";
29
+ this.active = false;
28
30
  this.href = "#";
29
31
  this.icon = undefined;
30
32
  }
@@ -54,12 +56,19 @@ const DuetSubmenuBarLink = class {
54
56
  }
55
57
  this.boundMqlFunctions = [];
56
58
  }
59
+ handleEscape(e) {
60
+ if (isEscapeKey(e)) {
61
+ const dropdown = this.element.closest("duet-submenu-bar");
62
+ dropdown.open = false;
63
+ dropdown.setFocus();
64
+ }
65
+ }
57
66
  /**
58
67
  * render() function
59
68
  * Always the last one in the class.
60
69
  */
61
70
  render() {
62
- return (h(Host, null, h("a", { class: { "duet-submenu-bar-link": true, "duet-theme-turva": this.theme === "turva" }, href: this.href, role: "menuitem" }, this.icon && (h("duet-icon", { theme: this.theme, name: this.icon, size: this.iconSize, margin: "none", color: "currentColor" })), h("slot", null))));
71
+ return (h(Host, null, h("a", { class: { "duet-submenu-bar-link": true, "duet-theme-turva": this.theme === "turva", active: this.active }, href: this.href, onKeyUp: e => this.handleEscape(e), "aria-current": this.active ? "true" : "false" }, this.icon && (h("duet-icon", { theme: this.theme, name: this.icon, size: this.iconSize, margin: "none", color: "currentColor" })), h("span", { class: "label" }, h("slot", null)))));
63
72
  }
64
73
  get element() { return getElement(this); }
65
74
  };
@@ -1,17 +1,29 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
+ import { m as media_query_large } from './tokens-0963dc8b.js';
5
6
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
7
 
7
- const duetSubmenuBarCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%}:host slot::slotted(duet-submenu-bar-link),:host slot::slotted(duet-submenu-bar-dropdown){position:relative;top:-0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot::slotted(duet-submenu-bar-link),:host([open]) slot::slotted(duet-submenu-bar-dropdown){top:0;opacity:1}@media (min-width: 62em){:host slot::slotted(duet-submenu-bar-link),:host slot::slotted(duet-submenu-bar-dropdown){position:relative;top:auto;opacity:1;transition:none}}.duet-submenu-bar{position:relative;background:rgb(243, 249, 252)}@media (min-width: 62em){.duet-submenu-bar{border-bottom:1px solid rgb(205, 229, 241)}}.duet-submenu-bar button{display:flex;align-items:center;justify-content:center;width:100%;padding:12px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77)}.duet-submenu-bar button.active .caret{transform:rotate(180deg)}.duet-submenu-bar button .label{position:relative;display:flex;gap:8px;align-items:center;justify-content:center}@media (min-width: 62em){.duet-submenu-bar button{display:none}}.duet-submenu-bar .items{position:absolute;z-index:399;width:100%;max-height:1000px;visibility:visible;background:rgb(243, 249, 252);border-bottom:1px solid rgb(207, 210, 212);transition:300ms ease}.duet-submenu-bar .items.hidden{max-height:0;overflow:hidden;visibility:hidden;border-bottom:0 solid rgb(207, 210, 212);transition:300ms ease}@media (min-width: 62em){.duet-submenu-bar .items,.duet-submenu-bar .items.hidden{position:static;z-index:auto;display:flex;flex-direction:row;align-items:center;justify-content:center;max-height:unset;overflow:visible;visibility:visible;border:0;transition:none}}.duet-submenu-bar.duet-theme-turva{background:rgb(245, 245, 247);border-bottom:1px solid rgb(228, 228, 230)}.duet-submenu-bar.duet-theme-turva .items{background:rgb(245, 245, 247)}";
8
+ const duetSubmenuBarCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%}:host slot::slotted(duet-submenu-bar-link),:host slot::slotted(duet-submenu-bar-dropdown){position:relative;top:-0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot::slotted(duet-submenu-bar-link),:host([open]) slot::slotted(duet-submenu-bar-dropdown){top:0;opacity:1}@media (min-width: 62em){:host slot::slotted(duet-submenu-bar-link),:host slot::slotted(duet-submenu-bar-dropdown){position:relative;top:auto;opacity:1;transition:none}}.duet-submenu-bar{position:relative;background:rgb(243, 249, 252)}@media (min-width: 62em){.duet-submenu-bar{border-bottom:1px solid rgb(205, 229, 241)}}.duet-submenu-bar button{display:flex;align-items:center;justify-content:center;width:100%;padding:12px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77)}.duet-submenu-bar button:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-submenu-bar button.active .caret{transform:rotate(180deg)}.duet-submenu-bar button .label{position:relative;display:flex;gap:8px;align-items:center;justify-content:center}@media (min-width: 62em){.duet-submenu-bar button{display:none}}.duet-submenu-bar .items{position:absolute;z-index:399;width:100%;max-height:1000px;visibility:visible;background:rgb(243, 249, 252);border-bottom:1px solid rgb(207, 210, 212);transition:300ms ease}.duet-submenu-bar .items.hidden{max-height:0;overflow:hidden;visibility:hidden;border-bottom:0 solid rgb(207, 210, 212);transition:300ms ease}@media (min-width: 62em){.duet-submenu-bar .items,.duet-submenu-bar .items.hidden{position:static;z-index:auto;display:flex;flex-direction:row;align-items:center;justify-content:center;max-height:unset;overflow:visible;visibility:visible;border:0;transition:none}}.duet-submenu-bar.duet-theme-turva{background:rgb(245, 245, 247);border-bottom:1px solid rgb(228, 228, 230)}.duet-submenu-bar.duet-theme-turva button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-submenu-bar.duet-theme-turva .items{background:rgb(245, 245, 247)}";
8
9
 
9
10
  const DuetSubmenuBar = class {
10
11
  constructor(hostRef) {
11
12
  registerInstance(this, hostRef);
13
+ this.mql = [window.matchMedia(media_query_large.replace(/'/g, ""))];
14
+ this.boundMqlFunctions = [];
15
+ this.changeAriaProperties = () => {
16
+ if (this.mql[0].matches) {
17
+ this.mobile = false;
18
+ }
19
+ else {
20
+ this.mobile = true;
21
+ }
22
+ };
12
23
  this.onClick = () => {
13
24
  this.open = !this.open;
14
25
  };
26
+ this.mobile = true;
15
27
  this.theme = "";
16
28
  this.open = false;
17
29
  }
@@ -21,14 +33,40 @@ const DuetSubmenuBar = class {
21
33
  componentWillLoad() {
22
34
  inheritGlobalTheme(this);
23
35
  }
36
+ connectedCallback() {
37
+ this.changeAriaProperties();
38
+ for (let i = 0; i < this.mql.length; i++) {
39
+ // addEventListener is not available in Stencil hydrate
40
+ if (this.mql[i].addEventListener) {
41
+ const bound = this.changeAriaProperties.bind(this);
42
+ this.mql[i].addEventListener("change", bound);
43
+ this.boundMqlFunctions[i] = bound;
44
+ }
45
+ }
46
+ }
47
+ disconnectedCallback() {
48
+ for (let i = 0; i < this.mql.length; i++) {
49
+ // removeEventListener is not available in Stencil hydrate
50
+ if (this.mql[i].removeEventListener) {
51
+ this.mql[i].removeEventListener("change", this.boundMqlFunctions[i]);
52
+ }
53
+ }
54
+ this.boundMqlFunctions = [];
55
+ }
56
+ /**
57
+ * Sets focus. Use this method instead of the global focus().
58
+ */
59
+ async setFocus(options) {
60
+ this.button.focus(options);
61
+ }
24
62
  /**
25
63
  * render() function
26
64
  * Always the last one in the class.
27
65
  */
28
66
  render() {
29
- return (h(Host, null, h("div", { class: { "duet-submenu-bar": true, "duet-theme-turva": this.theme === "turva" }, role: "menubar" }, h("button", { "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
67
+ return (h(Host, null, h("div", { class: { "duet-submenu-bar": true, "duet-theme-turva": this.theme === "turva" }, role: this.mobile ? null : "menubar" }, h("button", { ref: element => (this.button = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
30
68
  active: this.open,
31
- }, onClick: this.onClick }, h("div", { class: "label" }, h("slot", { name: "label" }), h("duet-icon", { theme: this.theme, class: "caret", name: "action-arrow-down-small", margin: "none", size: "xxx-small", color: "currentColor" }))), h("div", { role: "menu", id: "menu", "aria-labelledby": "button", "aria-expanded": this.open ? "true" : "false", class: {
69
+ }, onClick: this.onClick }, h("div", { class: "label" }, h("slot", { name: "label" }), h("duet-icon", { theme: this.theme, class: "caret", name: "action-arrow-down-small", margin: "none", size: "xxx-small", color: "currentColor" }))), h("div", { role: this.mobile ? "menu" : null, id: "menu", "aria-labelledby": this.mobile ? "button" : null, "aria-expanded": this.mobile ? (this.open ? "true" : "false") : null, class: {
32
70
  items: true,
33
71
  hidden: !this.open,
34
72
  } }, h("slot", null)))));
@@ -1,7 +1,7 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
  import { c as createID } from './create-id-981107da.js';
7
7
  import { c as cleanValue } from './input-utils-de45e099.js';
@@ -1,7 +1,7 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-bcaee850.js';
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-dc7d6b8d.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
  import { c as createID } from './create-id-981107da.js';
7
7