@duetds/components 8.1.4 → 8.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (653) hide show
  1. package/hydrate/index.js +225 -131
  2. package/lib/cjs/duet-action-button.cjs.entry.js +3 -3
  3. package/lib/cjs/duet-alert.cjs.entry.js +1 -1
  4. package/lib/cjs/duet-badge.cjs.entry.js +3 -3
  5. package/lib/cjs/duet-banner.cjs.entry.js +7 -5
  6. package/lib/cjs/duet-breadcrumb.cjs.entry.js +1 -1
  7. package/lib/cjs/duet-breadcrumbs.cjs.entry.js +1 -1
  8. package/lib/cjs/duet-button_2.cjs.entry.js +6 -6
  9. package/lib/cjs/duet-callout.cjs.entry.js +4 -3
  10. package/lib/cjs/duet-caption_4.cjs.entry.js +3 -3
  11. package/lib/cjs/duet-card.cjs.entry.js +3 -3
  12. package/lib/cjs/duet-checkbox.cjs.entry.js +1 -1
  13. package/lib/cjs/duet-checkmark.cjs.entry.js +1 -1
  14. package/lib/cjs/duet-chip.cjs.entry.js +22 -3
  15. package/lib/cjs/duet-choice_2.cjs.entry.js +2 -2
  16. package/lib/cjs/duet-collapsible.cjs.entry.js +2 -2
  17. package/lib/cjs/duet-combobox.cjs.entry.js +1 -1
  18. package/lib/cjs/duet-contact-card.cjs.entry.js +1 -1
  19. package/lib/cjs/duet-cookie-consent.cjs.entry.js +1 -1
  20. package/lib/cjs/duet-date-picker.cjs.entry.js +2 -2
  21. package/lib/cjs/duet-divider_2.cjs.entry.js +3 -3
  22. package/lib/cjs/duet-editable-table_3.cjs.entry.js +3 -3
  23. package/lib/cjs/duet-empty-state.cjs.entry.js +1 -1
  24. package/lib/cjs/duet-fieldset.cjs.entry.js +1 -1
  25. package/lib/cjs/duet-file-chooser.cjs.entry.js +1 -1
  26. package/lib/cjs/duet-footer.cjs.entry.js +1 -1
  27. package/lib/cjs/duet-grid_2.cjs.entry.js +2 -2
  28. package/lib/cjs/duet-header_2.cjs.entry.js +3 -3
  29. package/lib/cjs/duet-hero.cjs.entry.js +3 -2
  30. package/lib/cjs/duet-icon.cjs.entry.js +5 -5
  31. package/lib/cjs/duet-input_2.cjs.entry.js +9 -5
  32. package/lib/cjs/duet-layout.cjs.entry.js +1 -1
  33. package/lib/cjs/duet-list_2.cjs.entry.js +1 -1
  34. package/lib/cjs/duet-menu-bar-button.cjs.entry.js +2 -2
  35. package/lib/cjs/duet-menu-bar-dropdown-link.cjs.entry.js +1 -1
  36. package/lib/cjs/duet-menu-bar-dropdown.cjs.entry.js +2 -2
  37. package/lib/cjs/duet-menu-bar-link.cjs.entry.js +2 -2
  38. package/lib/cjs/duet-menu-bar.cjs.entry.js +2 -2
  39. package/lib/cjs/duet-modal.cjs.entry.js +18 -5
  40. package/lib/cjs/duet-multiselect.cjs.entry.js +4 -2
  41. package/lib/cjs/duet-nav.cjs.entry.js +1 -1
  42. package/lib/cjs/duet-notification_2.cjs.entry.js +1 -1
  43. package/lib/cjs/duet-number-input.cjs.entry.js +1 -1
  44. package/lib/cjs/duet-page-heading.cjs.entry.js +1 -1
  45. package/lib/cjs/duet-pagination_2.cjs.entry.js +3 -3
  46. package/lib/cjs/duet-popup-menu-item.cjs.entry.js +4 -3
  47. package/lib/cjs/duet-popup-menu.cjs.entry.js +14 -13
  48. package/lib/cjs/duet-progress.cjs.entry.js +1 -1
  49. package/lib/cjs/duet-promo-card.cjs.entry.js +5 -4
  50. package/lib/cjs/duet-radio_2.cjs.entry.js +1 -1
  51. package/lib/cjs/duet-range-slider.cjs.entry.js +5 -3
  52. package/lib/cjs/duet-scrollable_3.cjs.entry.js +1 -1
  53. package/lib/cjs/duet-section-layout.cjs.entry.js +1 -1
  54. package/lib/cjs/duet-select.cjs.entry.js +4 -2
  55. package/lib/cjs/duet-shaped-image.cjs.entry.js +1 -1
  56. package/lib/cjs/duet-show-more.cjs.entry.js +1 -1
  57. package/lib/cjs/duet-slideout-lang.cjs.entry.js +1 -1
  58. package/lib/cjs/duet-slideout-link.cjs.entry.js +1 -1
  59. package/lib/cjs/duet-slideout-panel-dropdown.cjs.entry.js +1 -1
  60. package/lib/cjs/duet-slideout-panel.cjs.entry.js +4 -4
  61. package/lib/cjs/duet-slideout.cjs.entry.js +91 -99
  62. package/lib/cjs/duet-step_2.cjs.entry.js +1 -1
  63. package/lib/cjs/duet-submenu-bar-dropdown-link.cjs.entry.js +1 -1
  64. package/lib/cjs/duet-submenu-bar-dropdown.cjs.entry.js +2 -2
  65. package/lib/cjs/duet-submenu-bar-link.cjs.entry.js +2 -2
  66. package/lib/cjs/duet-submenu-bar.cjs.entry.js +2 -2
  67. package/lib/cjs/duet-textarea.cjs.entry.js +4 -2
  68. package/lib/cjs/duet-toggle.cjs.entry.js +4 -2
  69. package/lib/cjs/duet-toolbar-dropdown-link.cjs.entry.js +1 -1
  70. package/lib/cjs/duet-toolbar-dropdown.cjs.entry.js +1 -1
  71. package/lib/cjs/duet-toolbar-link.cjs.entry.js +1 -1
  72. package/lib/cjs/duet-toolbar.cjs.entry.js +1 -1
  73. package/lib/cjs/duet-tooltip-button_2.cjs.entry.js +2 -2
  74. package/lib/cjs/duet-tooltip.cjs.entry.js +12 -3
  75. package/lib/cjs/duet-tray.cjs.entry.js +2 -2
  76. package/lib/cjs/duet-upload-aria-status.cjs.entry.js +1 -1
  77. package/lib/cjs/duet-upload-item.cjs.entry.js +1 -1
  78. package/lib/cjs/duet-visually-hidden.cjs.entry.js +1 -1
  79. package/lib/cjs/duet.cjs.js +2 -2
  80. package/lib/cjs/{focus-utils-fd4fdee9.js → focus-utils-1780ee53.js} +1 -1
  81. package/lib/cjs/{index-6ea7b876.js → index-8595e0c1.js} +1 -1
  82. package/lib/cjs/loader.cjs.js +2 -2
  83. package/lib/cjs/slot-utils-6c81bd09.js +20 -0
  84. package/lib/cjs/{token-utils-a5356b00.js → token-utils-c672402d.js} +1 -1
  85. package/lib/cjs/{tokens-51cfbe11.js → tokens-c3eecae6.js} +1 -1
  86. package/lib/cjs/{tokens.module-ce5f9579.js → tokens.module-bc323a09.js} +1 -1
  87. package/lib/collection/common/focusable-component.js +1 -0
  88. package/lib/collection/common/opener-component.js +1 -0
  89. package/lib/collection/components/duet-badge/duet-badge.css +1 -0
  90. package/lib/collection/components/duet-badge/duet-badge.js +1 -1
  91. package/lib/collection/components/duet-banner/duet-banner.css +3 -0
  92. package/lib/collection/components/duet-banner/duet-banner.js +8 -1
  93. package/lib/collection/components/duet-button/duet-button.css +1 -0
  94. package/lib/collection/components/duet-button/duet-button.js +2 -2
  95. package/lib/collection/components/duet-callout/duet-callout.css +18 -1
  96. package/lib/collection/components/duet-callout/duet-callout.js +3 -2
  97. package/lib/collection/components/duet-chip/duet-chip.css +2 -2
  98. package/lib/collection/components/duet-chip/duet-chip.js +55 -1
  99. package/lib/collection/components/duet-hero/duet-hero.js +5 -4
  100. package/lib/collection/components/duet-icon/duet-icon.css +1 -0
  101. package/lib/collection/components/duet-icon/duet-icon.js +1 -1
  102. package/lib/collection/components/duet-input/duet-input.js +43 -1
  103. package/lib/collection/components/duet-label/duet-label.css +7 -0
  104. package/lib/collection/components/duet-label/duet-label.js +26 -0
  105. package/lib/collection/components/duet-modal/duet-modal.css +105 -16
  106. package/lib/collection/components/duet-modal/duet-modal.js +40 -3
  107. package/lib/collection/components/duet-multiselect/duet-multiselect.js +43 -1
  108. package/lib/collection/components/duet-popup-menu/duet-popup-menu.js +43 -14
  109. package/lib/collection/components/duet-popup-menu-item/duet-popup-menu-item.css +4 -0
  110. package/lib/collection/components/duet-popup-menu-item/duet-popup-menu-item.js +20 -1
  111. package/lib/collection/components/duet-promo-card/duet-promo-card.js +8 -1
  112. package/lib/collection/components/duet-range-slider/duet-range-slider.js +43 -1
  113. package/lib/collection/components/duet-select/duet-select.js +43 -1
  114. package/lib/collection/components/duet-slideout/duet-slideout.css +35 -0
  115. package/lib/collection/components/duet-slideout/duet-slideout.js +114 -123
  116. package/lib/collection/components/duet-textarea/duet-textarea.js +43 -1
  117. package/lib/collection/components/duet-toggle/duet-toggle.js +43 -1
  118. package/lib/collection/components/duet-tooltip/duet-tooltip.js +27 -1
  119. package/lib/collection/utils/slot-utils.js +16 -0
  120. package/lib/dist-custom-elements/duet-action-button.js +1 -1
  121. package/lib/dist-custom-elements/duet-alert.js +1 -1
  122. package/lib/dist-custom-elements/duet-badge.js +1 -1
  123. package/lib/dist-custom-elements/duet-banner.js +10 -14
  124. package/lib/dist-custom-elements/duet-breadcrumb.js +3 -3
  125. package/lib/dist-custom-elements/duet-breadcrumbs.js +1 -1
  126. package/lib/dist-custom-elements/duet-button.js +1 -1
  127. package/lib/dist-custom-elements/duet-callout.js +6 -11
  128. package/lib/dist-custom-elements/duet-caption.js +1 -1
  129. package/lib/dist-custom-elements/duet-card.js +4 -4
  130. package/lib/dist-custom-elements/duet-checkbox.js +1 -1
  131. package/lib/dist-custom-elements/duet-checkmark.js +1 -1
  132. package/lib/dist-custom-elements/duet-chip.js +25 -4
  133. package/lib/dist-custom-elements/duet-choice-group.js +8 -8
  134. package/lib/dist-custom-elements/duet-choice.js +5 -5
  135. package/lib/dist-custom-elements/duet-collapsible.js +3 -3
  136. package/lib/dist-custom-elements/duet-combobox.js +2 -2
  137. package/lib/dist-custom-elements/duet-contact-card.js +8 -8
  138. package/lib/dist-custom-elements/duet-cookie-consent.js +6 -6
  139. package/lib/dist-custom-elements/duet-date-picker.js +12 -12
  140. package/lib/dist-custom-elements/duet-divider.js +1 -1
  141. package/lib/dist-custom-elements/duet-editable-table.js +7 -7
  142. package/lib/dist-custom-elements/duet-empty-state.js +1 -1
  143. package/lib/dist-custom-elements/duet-fieldset.js +1 -1
  144. package/lib/dist-custom-elements/duet-file-chooser.js +2 -2
  145. package/lib/dist-custom-elements/duet-footer.js +4 -4
  146. package/lib/dist-custom-elements/duet-grid-item.js +1 -1
  147. package/lib/dist-custom-elements/duet-grid.js +1 -1
  148. package/lib/dist-custom-elements/duet-header.js +9 -9
  149. package/lib/dist-custom-elements/duet-heading.js +1 -1
  150. package/lib/dist-custom-elements/duet-hero.js +11 -10
  151. package/lib/dist-custom-elements/duet-icon.js +1 -1
  152. package/lib/dist-custom-elements/duet-input.js +1 -1
  153. package/lib/dist-custom-elements/duet-label.js +1 -1
  154. package/lib/dist-custom-elements/duet-layout.js +1 -1
  155. package/lib/dist-custom-elements/duet-link.js +1 -1
  156. package/lib/dist-custom-elements/duet-list-item.js +1 -1
  157. package/lib/dist-custom-elements/duet-list.js +1 -1
  158. package/lib/dist-custom-elements/duet-logo.js +1 -1
  159. package/lib/dist-custom-elements/duet-menu-bar-button.js +3 -3
  160. package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.js +2 -2
  161. package/lib/dist-custom-elements/duet-menu-bar-dropdown.js +3 -3
  162. package/lib/dist-custom-elements/duet-menu-bar-link.js +3 -3
  163. package/lib/dist-custom-elements/duet-menu-bar.js +3 -3
  164. package/lib/dist-custom-elements/duet-modal.js +24 -10
  165. package/lib/dist-custom-elements/duet-multiselect.js +14 -10
  166. package/lib/dist-custom-elements/duet-nav.js +1 -1
  167. package/lib/dist-custom-elements/duet-notification-drawer.js +4 -4
  168. package/lib/dist-custom-elements/duet-notification.js +2 -2
  169. package/lib/dist-custom-elements/duet-number-input.js +11 -11
  170. package/lib/dist-custom-elements/duet-page-heading.js +2 -2
  171. package/lib/dist-custom-elements/duet-pagination.js +14 -14
  172. package/lib/dist-custom-elements/duet-paragraph.js +1 -1
  173. package/lib/dist-custom-elements/duet-popup-menu-item.js +6 -4
  174. package/lib/dist-custom-elements/duet-popup-menu.js +15 -13
  175. package/lib/dist-custom-elements/duet-progress.js +1 -1
  176. package/lib/dist-custom-elements/duet-promo-card.js +6 -5
  177. package/lib/dist-custom-elements/duet-radio-group.js +8 -8
  178. package/lib/dist-custom-elements/duet-radio.js +1 -1
  179. package/lib/dist-custom-elements/duet-range-slider.js +8 -4
  180. package/lib/dist-custom-elements/duet-range-stepper.js +4 -4
  181. package/lib/dist-custom-elements/duet-scrollable.js +1 -1
  182. package/lib/dist-custom-elements/duet-section-layout.js +1 -1
  183. package/lib/dist-custom-elements/duet-select.js +1 -1
  184. package/lib/dist-custom-elements/duet-shaped-image.js +1 -1
  185. package/lib/dist-custom-elements/duet-show-more.js +5 -5
  186. package/lib/dist-custom-elements/duet-slideout-lang.js +2 -2
  187. package/lib/dist-custom-elements/duet-slideout-link.js +2 -2
  188. package/lib/dist-custom-elements/duet-slideout-panel-dropdown.js +2 -2
  189. package/lib/dist-custom-elements/duet-slideout-panel.js +3 -3
  190. package/lib/dist-custom-elements/duet-slideout.js +97 -103
  191. package/lib/dist-custom-elements/duet-spacer.js +1 -1
  192. package/lib/dist-custom-elements/duet-spinner.js +1 -1
  193. package/lib/dist-custom-elements/duet-step.js +4 -4
  194. package/lib/dist-custom-elements/duet-stepper.js +2 -2
  195. package/lib/dist-custom-elements/duet-submenu-bar-dropdown-link.js +2 -2
  196. package/lib/dist-custom-elements/duet-submenu-bar-dropdown.js +3 -3
  197. package/lib/dist-custom-elements/duet-submenu-bar-link.js +3 -3
  198. package/lib/dist-custom-elements/duet-submenu-bar.js +3 -3
  199. package/lib/dist-custom-elements/duet-tab-group.js +13 -13
  200. package/lib/dist-custom-elements/duet-tab.js +1 -1
  201. package/lib/dist-custom-elements/duet-table.js +1 -1
  202. package/lib/dist-custom-elements/duet-textarea.js +15 -11
  203. package/lib/dist-custom-elements/duet-toggle.js +7 -3
  204. package/lib/dist-custom-elements/duet-toolbar-dropdown-link.js +2 -2
  205. package/lib/dist-custom-elements/duet-toolbar-dropdown.js +2 -2
  206. package/lib/dist-custom-elements/duet-toolbar-link.js +2 -2
  207. package/lib/dist-custom-elements/duet-toolbar.js +1 -1
  208. package/lib/dist-custom-elements/duet-tooltip-button.js +1 -1
  209. package/lib/dist-custom-elements/duet-tooltip-popup.js +1 -1
  210. package/lib/dist-custom-elements/duet-tooltip.js +1 -1
  211. package/lib/dist-custom-elements/duet-tray.js +4 -4
  212. package/lib/dist-custom-elements/duet-upload-aria-status.js +1 -1
  213. package/lib/dist-custom-elements/duet-upload-item.js +1 -1
  214. package/lib/dist-custom-elements/duet-upload.js +18 -18
  215. package/lib/dist-custom-elements/duet-visually-hidden.js +1 -1
  216. package/lib/dist-custom-elements/index.js +1 -1
  217. package/lib/dist-custom-elements/{p-077e5396.js → p-0297efef.js} +10 -10
  218. package/lib/dist-custom-elements/{p-d18ca3d9.js → p-0aef3ad3.js} +2 -2
  219. package/lib/dist-custom-elements/{p-8aaaefdf.js → p-13916d96.js} +2 -2
  220. package/lib/dist-custom-elements/p-15d5aa46.js +60 -0
  221. package/lib/dist-custom-elements/p-188d76d4.js +205 -0
  222. package/lib/dist-custom-elements/{p-19fc0434.js → p-1b55b8aa.js} +1 -1
  223. package/lib/dist-custom-elements/{p-98dcc2eb.js → p-27efc5ff.js} +3 -3
  224. package/lib/dist-custom-elements/{p-5f8459bd.js → p-30fe9f1c.js} +13 -9
  225. package/lib/dist-custom-elements/{p-c9808777.js → p-3bb00966.js} +15 -11
  226. package/lib/dist-custom-elements/{p-9b14643e.js → p-4086f5d7.js} +2 -2
  227. package/lib/dist-custom-elements/{p-36cee998.js → p-5c8435c6.js} +5 -5
  228. package/lib/dist-custom-elements/{p-802e0cd4.js → p-63997028.js} +17 -7
  229. package/lib/dist-custom-elements/{p-9c5b3e92.js → p-679f9f84.js} +1 -1
  230. package/lib/dist-custom-elements/{p-59fdca12.js → p-6a6a112e.js} +2 -2
  231. package/lib/dist-custom-elements/{p-506c2666.js → p-7b59279f.js} +6 -3
  232. package/lib/dist-custom-elements/{p-f91938ae.js → p-80cc1a6e.js} +2 -2
  233. package/lib/dist-custom-elements/{p-1ed786bc.js → p-811f6b14.js} +1 -1
  234. package/lib/dist-custom-elements/{p-4091ca56.js → p-8313084c.js} +1 -1
  235. package/lib/dist-custom-elements/{p-18ec08ac.js → p-8371f4c9.js} +4 -4
  236. package/lib/dist-custom-elements/{p-482e780b.js → p-8aeece22.js} +2 -2
  237. package/lib/dist-custom-elements/{p-0d74f436.js → p-8f9c9ce8.js} +2 -2
  238. package/lib/dist-custom-elements/{p-2eb72ea1.js → p-929cc9d5.js} +1 -1
  239. package/lib/dist-custom-elements/{p-5b14ef9f.js → p-98aea896.js} +1 -1
  240. package/lib/dist-custom-elements/{p-d94a9d9c.js → p-9e103db0.js} +1 -1
  241. package/lib/dist-custom-elements/{p-ff50aff2.js → p-9f454015.js} +3 -3
  242. package/lib/dist-custom-elements/{p-91facf89.js → p-a5057e42.js} +2 -2
  243. package/lib/dist-custom-elements/p-bb24a019.js +18 -0
  244. package/lib/dist-custom-elements/{p-7a6cf439.js → p-d072d3f7.js} +8 -8
  245. package/lib/dist-custom-elements/{p-2941d90a.js → p-d07f9fcc.js} +1 -1
  246. package/lib/dist-custom-elements/{p-2b56c0d7.js → p-d37a3cec.js} +1 -1
  247. package/lib/{esm/tokens-04106a43.js → dist-custom-elements/p-d81ec707.js} +1 -1
  248. package/lib/dist-custom-elements/{p-57e61e85.js → p-d87fd2f0.js} +3 -3
  249. package/lib/dist-custom-elements/{p-7c5f9c80.js → p-dbaac77a.js} +5 -5
  250. package/lib/dist-custom-elements/{p-583ae9d7.js → p-e5e0a9d5.js} +2 -2
  251. package/lib/dist-custom-elements/{p-8c81a26f.js → p-e93fe17b.js} +2 -2
  252. package/lib/dist-custom-elements/{p-d68c9433.js → p-ee518783.js} +1 -1
  253. package/lib/dist-custom-elements/{p-e078836c.js → p-ef9c200e.js} +1 -1
  254. package/lib/dist-custom-elements/{p-bb59b14d.js → p-f992d96f.js} +2 -2
  255. package/lib/duet/duet.esm.js +1 -1
  256. package/lib/duet/duet.js +1 -1
  257. package/lib/duet/{p-4a2adee6.entry.js → p-00af1839.entry.js} +1 -1
  258. package/lib/duet/p-03504efc.entry.js +4 -0
  259. package/lib/duet/{p-4dc81aa3.system.entry.js → p-07639744.system.entry.js} +1 -1
  260. package/lib/duet/{p-b931d3fa.system.entry.js → p-0b1e9389.system.entry.js} +1 -1
  261. package/lib/duet/p-0b2e2097.system.entry.js +4 -0
  262. package/lib/duet/{p-e50ab4d3.system.entry.js → p-0c4251d2.system.entry.js} +1 -1
  263. package/lib/duet/{p-8ec9245a.entry.js → p-0d546b56.entry.js} +1 -1
  264. package/lib/duet/{p-620c416c.entry.js → p-0ee8f124.entry.js} +1 -1
  265. package/lib/duet/p-0f6f152d.entry.js +4 -0
  266. package/lib/duet/{p-b2af386a.system.entry.js → p-0fb3d28c.system.entry.js} +1 -1
  267. package/lib/duet/{p-2c34a804.entry.js → p-1069a865.entry.js} +1 -1
  268. package/lib/duet/{p-78777bcf.entry.js → p-10e05065.entry.js} +1 -1
  269. package/lib/duet/p-13241469.system.entry.js +4 -0
  270. package/lib/duet/{p-cbbe6410.entry.js → p-145de3e0.entry.js} +1 -1
  271. package/lib/duet/{p-e12b3d60.system.js → p-15fde8cc.system.js} +1 -1
  272. package/lib/duet/{p-07c3d88d.entry.js → p-189f31b8.entry.js} +1 -1
  273. package/lib/duet/p-1d3f4925.entry.js +4 -0
  274. package/lib/duet/p-1ebb5d23.entry.js +4 -0
  275. package/lib/duet/{p-1b46db77.entry.js → p-1fcccba8.entry.js} +1 -1
  276. package/lib/duet/{p-906c13df.entry.js → p-204a1ab8.entry.js} +1 -1
  277. package/lib/duet/{p-04c3f872.system.entry.js → p-2073966b.system.entry.js} +1 -1
  278. package/lib/duet/{p-60d0817e.system.entry.js → p-22df3386.system.entry.js} +1 -1
  279. package/lib/duet/{p-c34e419e.system.entry.js → p-23043e9e.system.entry.js} +1 -1
  280. package/lib/duet/{p-9bd338fd.system.js → p-23354cf7.system.js} +1 -1
  281. package/lib/duet/{p-7768931c.system.entry.js → p-26a30f41.system.entry.js} +1 -1
  282. package/lib/duet/{p-4175e48c.system.entry.js → p-26e6c296.system.entry.js} +1 -1
  283. package/lib/duet/{p-2590ca65.system.entry.js → p-2975e980.system.entry.js} +1 -1
  284. package/lib/duet/{p-a020bf81.system.entry.js → p-2f2a6fbf.system.entry.js} +1 -1
  285. package/lib/duet/{p-ce50e4c0.system.entry.js → p-3120a193.system.entry.js} +1 -1
  286. package/lib/duet/{p-2cc17967.system.entry.js → p-31215119.system.entry.js} +1 -1
  287. package/lib/duet/{p-d6938dce.entry.js → p-342a250d.entry.js} +1 -1
  288. package/lib/duet/{p-be3bf41a.system.entry.js → p-3809955c.system.entry.js} +1 -1
  289. package/lib/duet/{p-b7be1375.entry.js → p-39aac14c.entry.js} +1 -1
  290. package/lib/duet/{p-f1faaa0b.system.entry.js → p-3e7d63ff.system.entry.js} +1 -1
  291. package/lib/duet/{p-0360829b.entry.js → p-414cc15d.entry.js} +1 -1
  292. package/lib/duet/{p-f08a7552.system.entry.js → p-4350eaaa.system.entry.js} +1 -1
  293. package/lib/duet/{p-5d6e1173.entry.js → p-462326bc.entry.js} +1 -1
  294. package/lib/duet/p-46bc086c.system.entry.js +4 -0
  295. package/lib/duet/p-485f3748.system.entry.js +4 -0
  296. package/lib/duet/{p-c73db725.system.entry.js → p-508c6401.system.entry.js} +1 -1
  297. package/lib/duet/p-50ebc951.system.entry.js +4 -0
  298. package/lib/duet/{p-d26b9e1f.system.entry.js → p-51b802fe.system.entry.js} +1 -1
  299. package/lib/duet/{p-a9b6b8d5.entry.js → p-5224b8e7.entry.js} +1 -1
  300. package/lib/duet/{p-4b745f4d.entry.js → p-52811ee4.entry.js} +1 -1
  301. package/lib/duet/{p-c65851ca.entry.js → p-529b0ef8.entry.js} +1 -1
  302. package/lib/duet/{p-c45c621f.js → p-52bcdf36.js} +1 -1
  303. package/lib/duet/{p-8f504a32.system.entry.js → p-530dc869.system.entry.js} +2 -2
  304. package/lib/duet/{p-ea5bad4c.entry.js → p-531c259f.entry.js} +1 -1
  305. package/lib/duet/{p-c1e6dcf6.entry.js → p-57a29655.entry.js} +1 -1
  306. package/lib/duet/{p-2c139545.entry.js → p-57b54fc2.entry.js} +1 -1
  307. package/lib/duet/{p-63150ee3.system.entry.js → p-5983c4c1.system.entry.js} +1 -1
  308. package/lib/duet/{p-993f5974.entry.js → p-59d78e4a.entry.js} +1 -1
  309. package/lib/duet/p-5a5fb62b.system.entry.js +4 -0
  310. package/lib/duet/{p-3865240e.system.entry.js → p-5a8c6db7.system.entry.js} +1 -1
  311. package/lib/duet/{p-82461381.system.entry.js → p-5b2d1616.system.entry.js} +1 -1
  312. package/lib/duet/{p-711c2a2b.system.js → p-5b8477c2.system.js} +1 -1
  313. package/lib/duet/{p-fee4d237.system.entry.js → p-5bd11cd6.system.entry.js} +1 -1
  314. package/lib/duet/{p-1a8494b0.system.entry.js → p-5ed4cad9.system.entry.js} +1 -1
  315. package/lib/duet/{p-0142d94d.entry.js → p-600af4ae.entry.js} +1 -1
  316. package/lib/duet/{p-1e0df043.system.entry.js → p-6073f3e6.system.entry.js} +1 -1
  317. package/lib/duet/p-61a76b2b.system.js +4 -0
  318. package/lib/duet/p-61ab4c50.system.entry.js +4 -0
  319. package/lib/duet/{p-103ab767.system.entry.js → p-62a1697f.system.entry.js} +1 -1
  320. package/lib/duet/{p-42959a52.entry.js → p-62cd7e30.entry.js} +1 -1
  321. package/lib/duet/{p-64c8cce6.entry.js → p-62d30a58.entry.js} +1 -1
  322. package/lib/duet/{p-cf6c967a.entry.js → p-6374b7ea.entry.js} +1 -1
  323. package/lib/duet/{p-9f05508d.entry.js → p-641be297.entry.js} +1 -1
  324. package/lib/duet/{p-5b27ed7e.entry.js → p-64737ee3.entry.js} +1 -1
  325. package/lib/duet/{p-c9a6ad4d.entry.js → p-6484d791.entry.js} +1 -1
  326. package/lib/duet/{p-dc4697ce.system.entry.js → p-692d016e.system.entry.js} +1 -1
  327. package/lib/duet/{p-d206ba69.entry.js → p-697addd1.entry.js} +1 -1
  328. package/lib/duet/p-6e53e390.system.entry.js +4 -0
  329. package/lib/duet/{p-702810e3.system.entry.js → p-73ec169a.system.entry.js} +1 -1
  330. package/lib/duet/{p-9894f629.system.entry.js → p-7576d859.system.entry.js} +1 -1
  331. package/lib/duet/{p-582b7fa7.system.entry.js → p-7694b9fa.system.entry.js} +1 -1
  332. package/lib/duet/{p-6bad895a.system.entry.js → p-7b57105a.system.entry.js} +1 -1
  333. package/lib/duet/{p-9b8c4a19.entry.js → p-7bced88e.entry.js} +1 -1
  334. package/lib/duet/{p-441595f6.entry.js → p-7ceb2a64.entry.js} +1 -1
  335. package/lib/duet/p-7d4f3ee9.entry.js +4 -0
  336. package/lib/duet/{p-066f078b.entry.js → p-7f06df0d.entry.js} +1 -1
  337. package/lib/duet/{p-68967bb9.entry.js → p-7fed706e.entry.js} +1 -1
  338. package/lib/duet/{p-6f9e49da.system.entry.js → p-7ff65dc0.system.entry.js} +1 -1
  339. package/lib/duet/{p-60be4608.system.entry.js → p-802d6f86.system.entry.js} +1 -1
  340. package/lib/duet/p-81c39b69.js +4 -0
  341. package/lib/duet/{p-42f92e6f.entry.js → p-8214bafd.entry.js} +1 -1
  342. package/lib/duet/p-876456fd.entry.js +4 -0
  343. package/lib/duet/{p-d189500a.entry.js → p-87653f71.entry.js} +1 -1
  344. package/lib/duet/{p-722a4867.entry.js → p-877c5c97.entry.js} +1 -1
  345. package/lib/duet/p-89aa11c5.system.entry.js +4 -0
  346. package/lib/duet/p-8a08dc1c.system.entry.js +4 -0
  347. package/lib/duet/{p-95ca3440.system.entry.js → p-8b7288e6.system.entry.js} +1 -1
  348. package/lib/duet/{p-b627091f.system.entry.js → p-8c8752c1.system.entry.js} +1 -1
  349. package/lib/duet/{p-314d5b44.entry.js → p-8c9f4ffd.entry.js} +1 -1
  350. package/lib/duet/{p-67eee05e.system.entry.js → p-8ca7b2fa.system.entry.js} +1 -1
  351. package/lib/duet/{p-010986d1.system.entry.js → p-8dbc03c1.system.entry.js} +1 -1
  352. package/lib/duet/{p-f587e799.entry.js → p-90f13f5e.entry.js} +1 -1
  353. package/lib/duet/p-9333f3f2.entry.js +4 -0
  354. package/lib/duet/{p-45a16be3.system.js → p-95eca09b.system.js} +1 -1
  355. package/lib/duet/{p-5cbc1b17.entry.js → p-97c30079.entry.js} +1 -1
  356. package/lib/duet/p-99269e38.system.js +4 -0
  357. package/lib/duet/p-9a43d193.entry.js +4 -0
  358. package/lib/duet/{p-edd0d41d.system.entry.js → p-9a5fd97c.system.entry.js} +1 -1
  359. package/lib/duet/p-9a7c25f2.entry.js +4 -0
  360. package/lib/duet/{p-ee9d7b51.system.entry.js → p-9ad8c8d4.system.entry.js} +1 -1
  361. package/lib/duet/{p-3515cd72.system.entry.js → p-9d328100.system.entry.js} +1 -1
  362. package/lib/duet/{p-18322745.system.entry.js → p-9de27a8f.system.entry.js} +1 -1
  363. package/lib/duet/{p-e5c0b71a.js → p-9dff8650.js} +1 -1
  364. package/lib/duet/{p-1d11b3b6.entry.js → p-9f939b40.entry.js} +1 -1
  365. package/lib/duet/{p-ac6f456f.system.entry.js → p-9fd8cf3b.system.entry.js} +1 -1
  366. package/lib/duet/{p-eadbc1cf.entry.js → p-9fffb1b4.entry.js} +1 -1
  367. package/lib/duet/p-a13bb243.entry.js +4 -0
  368. package/lib/duet/{p-a075ba4d.entry.js → p-a37947f2.entry.js} +1 -1
  369. package/lib/duet/{p-ce0ffc6e.system.entry.js → p-a658fd46.system.entry.js} +1 -1
  370. package/lib/duet/{p-69ba8b52.entry.js → p-a6a7278c.entry.js} +1 -1
  371. package/lib/duet/{p-b2d010fa.entry.js → p-a71dfbc3.entry.js} +1 -1
  372. package/lib/duet/{p-252baa0d.entry.js → p-a7788ac6.entry.js} +1 -1
  373. package/lib/duet/{p-bdbe3e35.system.entry.js → p-a871d5b1.system.entry.js} +1 -1
  374. package/lib/duet/p-a904b928.entry.js +4 -0
  375. package/lib/duet/{p-f866c944.entry.js → p-a9fb2dad.entry.js} +1 -1
  376. package/lib/duet/{p-24edf4ed.entry.js → p-a9fee462.entry.js} +1 -1
  377. package/lib/duet/{p-d94c8c20.entry.js → p-aad8ab06.entry.js} +1 -1
  378. package/lib/duet/{p-db09c828.system.entry.js → p-ac10c490.system.entry.js} +1 -1
  379. package/lib/duet/{p-8ae84c52.entry.js → p-ac607868.entry.js} +1 -1
  380. package/lib/duet/{p-a09af712.system.entry.js → p-acad0f72.system.entry.js} +1 -1
  381. package/lib/duet/p-aefc858d.entry.js +4 -0
  382. package/lib/duet/{p-244387a0.entry.js → p-af1bc725.entry.js} +1 -1
  383. package/lib/duet/{p-6020800c.system.entry.js → p-af4af7bb.system.entry.js} +1 -1
  384. package/lib/duet/p-b099522e.system.entry.js +4 -0
  385. package/lib/duet/{p-2d366120.system.entry.js → p-b1afb239.system.entry.js} +1 -1
  386. package/lib/duet/{p-8e7dc4ed.system.entry.js → p-b1e84ea2.system.entry.js} +1 -1
  387. package/lib/duet/p-b2608fe2.system.entry.js +4 -0
  388. package/lib/duet/p-b2744aa5.entry.js +4 -0
  389. package/lib/duet/{p-1db3121f.system.entry.js → p-b3a4cb83.system.entry.js} +1 -1
  390. package/lib/duet/{p-84031069.entry.js → p-b4ebdbc3.entry.js} +1 -1
  391. package/lib/duet/{p-ab63306b.entry.js → p-b61c49de.entry.js} +1 -1
  392. package/lib/duet/p-bb24a019.js +4 -0
  393. package/lib/duet/{p-600f3cf8.system.entry.js → p-bb507da0.system.entry.js} +1 -1
  394. package/lib/duet/p-c233d99d.entry.js +4 -0
  395. package/lib/duet/{p-ecf9b56e.system.entry.js → p-c2552968.system.entry.js} +1 -1
  396. package/lib/duet/{p-d053b6be.system.entry.js → p-c521eae3.system.entry.js} +1 -1
  397. package/lib/duet/p-d20b8b82.entry.js +4 -0
  398. package/lib/duet/{p-86251661.system.entry.js → p-d241457a.system.entry.js} +1 -1
  399. package/lib/duet/{p-dba6c1ee.entry.js → p-d577a8d9.entry.js} +1 -1
  400. package/lib/duet/{p-90378229.system.entry.js → p-d6b7c83c.system.entry.js} +1 -1
  401. package/lib/duet/{p-5e849463.js → p-d81ec707.js} +1 -1
  402. package/lib/duet/{p-4fe09b26.system.entry.js → p-d9af65c8.system.entry.js} +1 -1
  403. package/lib/duet/{p-7130f6d6.system.entry.js → p-db73a673.system.entry.js} +1 -1
  404. package/lib/duet/{p-261014df.system.entry.js → p-def2db15.system.entry.js} +1 -1
  405. package/lib/duet/{p-426ba263.entry.js → p-e006f206.entry.js} +1 -1
  406. package/lib/duet/{p-98e033d1.entry.js → p-e108f77f.entry.js} +1 -1
  407. package/lib/duet/{p-21774475.system.js → p-e1868c94.system.js} +1 -1
  408. package/lib/duet/{p-954c7df4.system.entry.js → p-e4cec0cd.system.entry.js} +1 -1
  409. package/lib/duet/{p-77e1b69b.entry.js → p-e55b0091.entry.js} +1 -1
  410. package/lib/duet/{p-f781276f.system.entry.js → p-e634de62.system.entry.js} +1 -1
  411. package/lib/duet/{p-645a4cd3.system.entry.js → p-e87e976f.system.entry.js} +1 -1
  412. package/lib/duet/p-e9dc6d6c.entry.js +4 -0
  413. package/lib/duet/{p-53229ab4.system.entry.js → p-ebc55747.system.entry.js} +1 -1
  414. package/lib/duet/p-ecb2cbbf.entry.js +4 -0
  415. package/lib/duet/{p-a2541d8a.entry.js → p-efa1441d.entry.js} +1 -1
  416. package/lib/duet/p-f041d166.entry.js +4 -0
  417. package/lib/duet/{p-b9157c7e.js → p-f2aa1623.js} +1 -1
  418. package/lib/duet/{p-c6b5368b.entry.js → p-f4551b33.entry.js} +1 -1
  419. package/lib/duet/p-f52a6fc5.system.entry.js +4 -0
  420. package/lib/duet/p-f5909e7f.entry.js +4 -0
  421. package/lib/duet/{p-f7e4069c.entry.js → p-f603773e.entry.js} +1 -1
  422. package/lib/duet/{p-e4231291.system.entry.js → p-fd8935c8.system.entry.js} +1 -1
  423. package/lib/duet/{p-ab9b7324.system.entry.js → p-fef7a17b.system.entry.js} +1 -1
  424. package/lib/esm/duet-action-button.entry.js +3 -3
  425. package/lib/esm/duet-alert.entry.js +1 -1
  426. package/lib/esm/duet-badge.entry.js +3 -3
  427. package/lib/esm/duet-banner.entry.js +7 -5
  428. package/lib/esm/duet-breadcrumb.entry.js +1 -1
  429. package/lib/esm/duet-breadcrumbs.entry.js +1 -1
  430. package/lib/esm/duet-button_2.entry.js +6 -6
  431. package/lib/esm/duet-callout.entry.js +4 -3
  432. package/lib/esm/duet-caption_4.entry.js +3 -3
  433. package/lib/esm/duet-card.entry.js +3 -3
  434. package/lib/esm/duet-checkbox.entry.js +1 -1
  435. package/lib/esm/duet-checkmark.entry.js +1 -1
  436. package/lib/esm/duet-chip.entry.js +22 -3
  437. package/lib/esm/duet-choice_2.entry.js +2 -2
  438. package/lib/esm/duet-collapsible.entry.js +2 -2
  439. package/lib/esm/duet-combobox.entry.js +1 -1
  440. package/lib/esm/duet-contact-card.entry.js +1 -1
  441. package/lib/esm/duet-cookie-consent.entry.js +1 -1
  442. package/lib/esm/duet-date-picker.entry.js +2 -2
  443. package/lib/esm/duet-divider_2.entry.js +3 -3
  444. package/lib/esm/duet-editable-table_3.entry.js +3 -3
  445. package/lib/esm/duet-empty-state.entry.js +1 -1
  446. package/lib/esm/duet-fieldset.entry.js +1 -1
  447. package/lib/esm/duet-file-chooser.entry.js +1 -1
  448. package/lib/esm/duet-footer.entry.js +1 -1
  449. package/lib/esm/duet-grid_2.entry.js +2 -2
  450. package/lib/esm/duet-header_2.entry.js +3 -3
  451. package/lib/esm/duet-hero.entry.js +3 -2
  452. package/lib/esm/duet-icon.entry.js +5 -5
  453. package/lib/esm/duet-input_2.entry.js +9 -5
  454. package/lib/esm/duet-layout.entry.js +1 -1
  455. package/lib/esm/duet-list_2.entry.js +1 -1
  456. package/lib/esm/duet-menu-bar-button.entry.js +2 -2
  457. package/lib/esm/duet-menu-bar-dropdown-link.entry.js +1 -1
  458. package/lib/esm/duet-menu-bar-dropdown.entry.js +2 -2
  459. package/lib/esm/duet-menu-bar-link.entry.js +2 -2
  460. package/lib/esm/duet-menu-bar.entry.js +2 -2
  461. package/lib/esm/duet-modal.entry.js +18 -5
  462. package/lib/esm/duet-multiselect.entry.js +4 -2
  463. package/lib/esm/duet-nav.entry.js +1 -1
  464. package/lib/esm/duet-notification_2.entry.js +1 -1
  465. package/lib/esm/duet-number-input.entry.js +1 -1
  466. package/lib/esm/duet-page-heading.entry.js +1 -1
  467. package/lib/esm/duet-pagination_2.entry.js +3 -3
  468. package/lib/esm/duet-popup-menu-item.entry.js +4 -3
  469. package/lib/esm/duet-popup-menu.entry.js +14 -13
  470. package/lib/esm/duet-progress.entry.js +1 -1
  471. package/lib/esm/duet-promo-card.entry.js +5 -4
  472. package/lib/esm/duet-radio_2.entry.js +1 -1
  473. package/lib/esm/duet-range-slider.entry.js +5 -3
  474. package/lib/esm/duet-scrollable_3.entry.js +1 -1
  475. package/lib/esm/duet-section-layout.entry.js +1 -1
  476. package/lib/esm/duet-select.entry.js +4 -2
  477. package/lib/esm/duet-shaped-image.entry.js +1 -1
  478. package/lib/esm/duet-show-more.entry.js +1 -1
  479. package/lib/esm/duet-slideout-lang.entry.js +1 -1
  480. package/lib/esm/duet-slideout-link.entry.js +1 -1
  481. package/lib/esm/duet-slideout-panel-dropdown.entry.js +1 -1
  482. package/lib/esm/duet-slideout-panel.entry.js +4 -4
  483. package/lib/esm/duet-slideout.entry.js +92 -100
  484. package/lib/esm/duet-step_2.entry.js +1 -1
  485. package/lib/esm/duet-submenu-bar-dropdown-link.entry.js +1 -1
  486. package/lib/esm/duet-submenu-bar-dropdown.entry.js +2 -2
  487. package/lib/esm/duet-submenu-bar-link.entry.js +2 -2
  488. package/lib/esm/duet-submenu-bar.entry.js +2 -2
  489. package/lib/esm/duet-textarea.entry.js +4 -2
  490. package/lib/esm/duet-toggle.entry.js +4 -2
  491. package/lib/esm/duet-toolbar-dropdown-link.entry.js +1 -1
  492. package/lib/esm/duet-toolbar-dropdown.entry.js +1 -1
  493. package/lib/esm/duet-toolbar-link.entry.js +1 -1
  494. package/lib/esm/duet-toolbar.entry.js +1 -1
  495. package/lib/esm/duet-tooltip-button_2.entry.js +2 -2
  496. package/lib/esm/duet-tooltip.entry.js +12 -3
  497. package/lib/esm/duet-tray.entry.js +2 -2
  498. package/lib/esm/duet-upload-aria-status.entry.js +1 -1
  499. package/lib/esm/duet-upload-item.entry.js +1 -1
  500. package/lib/esm/duet-visually-hidden.entry.js +1 -1
  501. package/lib/esm/duet.js +3 -3
  502. package/lib/esm/{focus-utils-8f59f0fc.js → focus-utils-d168d36c.js} +1 -1
  503. package/lib/esm/{index-6a5abb95.js → index-5c989c52.js} +1 -1
  504. package/lib/esm/loader.js +3 -3
  505. package/lib/esm/slot-utils-07ba4363.js +18 -0
  506. package/lib/esm/{token-utils-ece867a8.js → token-utils-d09165bc.js} +1 -1
  507. package/lib/{dist-custom-elements/p-5e849463.js → esm/tokens-30d01e1d.js} +1 -1
  508. package/lib/esm/{tokens.module-7a2f9c49.js → tokens.module-c9866649.js} +1 -1
  509. package/lib/esm-es5/duet-action-button.entry.js +1 -1
  510. package/lib/esm-es5/duet-alert.entry.js +1 -1
  511. package/lib/esm-es5/duet-badge.entry.js +1 -1
  512. package/lib/esm-es5/duet-banner.entry.js +1 -1
  513. package/lib/esm-es5/duet-breadcrumb.entry.js +1 -1
  514. package/lib/esm-es5/duet-breadcrumbs.entry.js +1 -1
  515. package/lib/esm-es5/duet-button_2.entry.js +1 -1
  516. package/lib/esm-es5/duet-callout.entry.js +1 -1
  517. package/lib/esm-es5/duet-caption_4.entry.js +1 -1
  518. package/lib/esm-es5/duet-card.entry.js +1 -1
  519. package/lib/esm-es5/duet-checkbox.entry.js +1 -1
  520. package/lib/esm-es5/duet-checkmark.entry.js +1 -1
  521. package/lib/esm-es5/duet-chip.entry.js +1 -1
  522. package/lib/esm-es5/duet-choice_2.entry.js +1 -1
  523. package/lib/esm-es5/duet-collapsible.entry.js +1 -1
  524. package/lib/esm-es5/duet-combobox.entry.js +1 -1
  525. package/lib/esm-es5/duet-contact-card.entry.js +1 -1
  526. package/lib/esm-es5/duet-cookie-consent.entry.js +1 -1
  527. package/lib/esm-es5/duet-date-picker.entry.js +1 -1
  528. package/lib/esm-es5/duet-divider_2.entry.js +1 -1
  529. package/lib/esm-es5/duet-editable-table_3.entry.js +1 -1
  530. package/lib/esm-es5/duet-empty-state.entry.js +1 -1
  531. package/lib/esm-es5/duet-fieldset.entry.js +1 -1
  532. package/lib/esm-es5/duet-file-chooser.entry.js +2 -2
  533. package/lib/esm-es5/duet-footer.entry.js +1 -1
  534. package/lib/esm-es5/duet-grid_2.entry.js +1 -1
  535. package/lib/esm-es5/duet-header_2.entry.js +1 -1
  536. package/lib/esm-es5/duet-hero.entry.js +2 -2
  537. package/lib/esm-es5/duet-icon.entry.js +1 -1
  538. package/lib/esm-es5/duet-input_2.entry.js +1 -1
  539. package/lib/esm-es5/duet-layout.entry.js +1 -1
  540. package/lib/esm-es5/duet-list_2.entry.js +1 -1
  541. package/lib/esm-es5/duet-menu-bar-button.entry.js +1 -1
  542. package/lib/esm-es5/duet-menu-bar-dropdown-link.entry.js +1 -1
  543. package/lib/esm-es5/duet-menu-bar-dropdown.entry.js +1 -1
  544. package/lib/esm-es5/duet-menu-bar-link.entry.js +1 -1
  545. package/lib/esm-es5/duet-menu-bar.entry.js +1 -1
  546. package/lib/esm-es5/duet-modal.entry.js +2 -2
  547. package/lib/esm-es5/duet-multiselect.entry.js +1 -1
  548. package/lib/esm-es5/duet-nav.entry.js +1 -1
  549. package/lib/esm-es5/duet-notification_2.entry.js +1 -1
  550. package/lib/esm-es5/duet-number-input.entry.js +1 -1
  551. package/lib/esm-es5/duet-page-heading.entry.js +1 -1
  552. package/lib/esm-es5/duet-pagination_2.entry.js +1 -1
  553. package/lib/esm-es5/duet-popup-menu-item.entry.js +2 -2
  554. package/lib/esm-es5/duet-popup-menu.entry.js +2 -2
  555. package/lib/esm-es5/duet-progress.entry.js +1 -1
  556. package/lib/esm-es5/duet-promo-card.entry.js +1 -1
  557. package/lib/esm-es5/duet-radio_2.entry.js +1 -1
  558. package/lib/esm-es5/duet-range-slider.entry.js +1 -1
  559. package/lib/esm-es5/duet-scrollable_3.entry.js +1 -1
  560. package/lib/esm-es5/duet-section-layout.entry.js +1 -1
  561. package/lib/esm-es5/duet-select.entry.js +1 -1
  562. package/lib/esm-es5/duet-shaped-image.entry.js +1 -1
  563. package/lib/esm-es5/duet-show-more.entry.js +1 -1
  564. package/lib/esm-es5/duet-slideout-lang.entry.js +1 -1
  565. package/lib/esm-es5/duet-slideout-link.entry.js +1 -1
  566. package/lib/esm-es5/duet-slideout-panel-dropdown.entry.js +1 -1
  567. package/lib/esm-es5/duet-slideout-panel.entry.js +1 -1
  568. package/lib/esm-es5/duet-slideout.entry.js +1 -1
  569. package/lib/esm-es5/duet-step_2.entry.js +1 -1
  570. package/lib/esm-es5/duet-submenu-bar-dropdown-link.entry.js +1 -1
  571. package/lib/esm-es5/duet-submenu-bar-dropdown.entry.js +1 -1
  572. package/lib/esm-es5/duet-submenu-bar-link.entry.js +1 -1
  573. package/lib/esm-es5/duet-submenu-bar.entry.js +1 -1
  574. package/lib/esm-es5/duet-textarea.entry.js +1 -1
  575. package/lib/esm-es5/duet-toggle.entry.js +1 -1
  576. package/lib/esm-es5/duet-toolbar-dropdown-link.entry.js +1 -1
  577. package/lib/esm-es5/duet-toolbar-dropdown.entry.js +1 -1
  578. package/lib/esm-es5/duet-toolbar-link.entry.js +1 -1
  579. package/lib/esm-es5/duet-toolbar.entry.js +1 -1
  580. package/lib/esm-es5/duet-tooltip-button_2.entry.js +1 -1
  581. package/lib/esm-es5/duet-tooltip.entry.js +2 -2
  582. package/lib/esm-es5/duet-tray.entry.js +1 -1
  583. package/lib/esm-es5/duet-upload-aria-status.entry.js +1 -1
  584. package/lib/esm-es5/duet-upload-item.entry.js +1 -1
  585. package/lib/esm-es5/duet-visually-hidden.entry.js +1 -1
  586. package/lib/esm-es5/duet.js +1 -1
  587. package/lib/esm-es5/{focus-utils-8f59f0fc.js → focus-utils-d168d36c.js} +1 -1
  588. package/lib/esm-es5/{index-6a5abb95.js → index-5c989c52.js} +1 -1
  589. package/lib/esm-es5/loader.js +1 -1
  590. package/lib/esm-es5/slot-utils-07ba4363.js +4 -0
  591. package/lib/esm-es5/{token-utils-ece867a8.js → token-utils-d09165bc.js} +1 -1
  592. package/lib/esm-es5/{tokens-04106a43.js → tokens-30d01e1d.js} +1 -1
  593. package/lib/esm-es5/{tokens.module-7a2f9c49.js → tokens.module-c9866649.js} +1 -1
  594. package/lib/types/common/focusable-component.d.ts +4 -0
  595. package/lib/types/common/index.d.ts +2 -0
  596. package/lib/types/common/opener-component.d.ts +5 -0
  597. package/lib/types/common-types.d.ts +2 -0
  598. package/lib/types/components/duet-banner/duet-banner.d.ts +5 -0
  599. package/lib/types/components/duet-callout/duet-callout.d.ts +1 -1
  600. package/lib/types/components/duet-chip/duet-chip.d.ts +13 -1
  601. package/lib/types/components/duet-hero/duet-hero.d.ts +3 -3
  602. package/lib/types/components/duet-input/duet-input.d.ts +9 -1
  603. package/lib/types/components/duet-label/duet-label.d.ts +5 -1
  604. package/lib/types/components/duet-modal/duet-modal.d.ts +7 -0
  605. package/lib/types/components/duet-multiselect/duet-multiselect.d.ts +9 -1
  606. package/lib/types/components/duet-popup-menu/duet-popup-menu.d.ts +7 -3
  607. package/lib/types/components/duet-popup-menu-item/duet-popup-menu-item.d.ts +4 -0
  608. package/lib/types/components/duet-promo-card/duet-promo-card.d.ts +6 -0
  609. package/lib/types/components/duet-range-slider/duet-range-slider.d.ts +9 -1
  610. package/lib/types/components/duet-select/duet-select.d.ts +9 -1
  611. package/lib/types/components/duet-slideout/duet-slideout.d.ts +22 -18
  612. package/lib/types/components/duet-textarea/duet-textarea.d.ts +9 -1
  613. package/lib/types/components/duet-toggle/duet-toggle.d.ts +9 -1
  614. package/lib/types/components/duet-tooltip/duet-tooltip.d.ts +6 -0
  615. package/lib/types/components.d.ts +160 -6
  616. package/lib/types/utils/slot-utils.d.ts +2 -0
  617. package/package.json +7 -7
  618. package/lib/dist-custom-elements/p-88b5a225.js +0 -205
  619. package/lib/dist-custom-elements/p-b06b80ce.js +0 -60
  620. package/lib/duet/p-00f75643.system.entry.js +0 -4
  621. package/lib/duet/p-0660a9a6.entry.js +0 -4
  622. package/lib/duet/p-088ac559.entry.js +0 -4
  623. package/lib/duet/p-0b2ff6ce.system.entry.js +0 -4
  624. package/lib/duet/p-164be464.entry.js +0 -4
  625. package/lib/duet/p-180c61a0.entry.js +0 -4
  626. package/lib/duet/p-18aaa40c.entry.js +0 -4
  627. package/lib/duet/p-210adc0e.system.entry.js +0 -4
  628. package/lib/duet/p-23914c18.entry.js +0 -4
  629. package/lib/duet/p-2858bbdf.entry.js +0 -4
  630. package/lib/duet/p-38df728c.system.entry.js +0 -4
  631. package/lib/duet/p-41203a2d.entry.js +0 -4
  632. package/lib/duet/p-474f53fe.entry.js +0 -4
  633. package/lib/duet/p-4a130ebf.system.entry.js +0 -4
  634. package/lib/duet/p-4bfc3a15.entry.js +0 -4
  635. package/lib/duet/p-4d3ef5ea.system.entry.js +0 -4
  636. package/lib/duet/p-4e9b4950.entry.js +0 -4
  637. package/lib/duet/p-5373f6cf.system.entry.js +0 -4
  638. package/lib/duet/p-53e33daf.js +0 -4
  639. package/lib/duet/p-594ffed9.entry.js +0 -4
  640. package/lib/duet/p-5eaf9a5e.entry.js +0 -4
  641. package/lib/duet/p-64e16fb9.system.js +0 -4
  642. package/lib/duet/p-7ad157c2.entry.js +0 -4
  643. package/lib/duet/p-9eb39bd3.system.entry.js +0 -4
  644. package/lib/duet/p-ac09ef10.entry.js +0 -4
  645. package/lib/duet/p-bc7e75a7.entry.js +0 -4
  646. package/lib/duet/p-cd13fb8f.system.entry.js +0 -4
  647. package/lib/duet/p-d125d287.system.entry.js +0 -4
  648. package/lib/duet/p-d1a42e5b.system.entry.js +0 -4
  649. package/lib/duet/p-e0aa8284.system.entry.js +0 -4
  650. package/lib/duet/p-e0e5597f.entry.js +0 -4
  651. package/lib/duet/p-e836814b.entry.js +0 -4
  652. package/lib/duet/p-f81647e9.system.entry.js +0 -4
  653. package/lib/duet/p-fb6a8b36.entry.js +0 -4
@@ -148,6 +148,8 @@ export class DuetMultiselect {
148
148
  this.items = undefined;
149
149
  this.disabled = false;
150
150
  this.label = "label";
151
+ this.labelColor = undefined;
152
+ this.labelWeight = undefined;
151
153
  this.accessibleDescribedBy = undefined;
152
154
  this.tooltip = "";
153
155
  this.tooltipDirection = "auto";
@@ -201,7 +203,7 @@ export class DuetMultiselect {
201
203
  "duet-theme-turva": this.theme === "turva",
202
204
  "duet-input-top-caption-shown": this.isCaptionVisible,
203
205
  "has-error": !!this.error,
204
- }, onKeyDown: (e) => this.onMultiselectKeyDown(e) }, h("duet-label", { theme: this.theme === "turva" ? "turva" : "default", class: { "duet-has-tooltip": !!this.tooltip }, id: this.labelId, for: this.identifier }, this.label), this.tooltip && (h("duet-tooltip", { class: "duet-multiselect-tooltip", direction: this.tooltipDirection, accessibleInputLabel: this.label }, this.tooltip)), this.caption && (h("duet-caption", { id: this.topCaptionId, size: "medium" }, this.caption)), h("div", { class: "duet-multiselect-wrapper" }, h("button", { id: this.identifier, ref: el => (this.multiselectElement = el), class: { "duet-multiselect": true, "duet-multiselect-active": this.checkboxesVisible }, tabindex: "0", onClick: () => this.toggleCheckboxes(), onFocus: e => this.onFocus(e), onBlur: e => this.onBlur(e), role: "combobox", "aria-expanded": this.checkboxesVisible ? "true" : "false", "aria-haspopup": "listbox", "aria-labelledby": this.labelId, "aria-describedby": this.getDescribedBy(), "aria-owns": `${this.identifier}-checkboxes`, onKeyDown: (e) => this.onMultiselectInputKeyDown(e), disabled: this.disabled }, h("span", { role: "textbox", "aria-readonly": "true", "aria-multiline": "false", "aria-autocomplete": "none", "aria-controls": `${this.identifier}-checkboxes`, "aria-label": this.placeholderLabel[this.language], class: "duet-multiselect-label" }, this.placeholder), this.value && this.value.length > 0 && (h("span", { class: "duet-multiselect-badge" }, this.value.length, h("duet-visually-hidden", null, this.selectedLangObject[this.language], ", ", this.value.map(item => item.label).join(", ")))), h("svg", { class: { "duet-multiselect-icon": true, "duet-multiselect-icon--rotate": this.checkboxesVisible }, fill: "currentColor", viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg" }, h("path", { d: "m12 18.999c-.4 0-.776-.156-1.059-.438l-10.721-10.72c-.142-.142-.22-.33-.22-.531 0-.2.078-.389.22-.53.142-.142.33-.22.53-.22s.389.078.53.22l10.72 10.719 10.72-10.719c.142-.142.33-.22.53-.22s.389.078.53.22c.142.142.22.33.22.53s-.078.389-.22.53l-10.72 10.72c-.282.283-.659.439-1.06.439z" }))), h("div", { id: `${this.identifier}-checkboxes`, role: "listbox", class: {
206
+ }, onKeyDown: (e) => this.onMultiselectKeyDown(e) }, h("duet-label", { theme: this.theme === "turva" ? "turva" : "default", class: { "duet-has-tooltip": !!this.tooltip }, color: this.labelColor, weight: this.labelWeight, id: this.labelId, for: this.identifier }, this.label), this.tooltip && (h("duet-tooltip", { class: "duet-multiselect-tooltip", direction: this.tooltipDirection, accessibleInputLabel: this.label }, this.tooltip)), this.caption && (h("duet-caption", { id: this.topCaptionId, size: "medium" }, this.caption)), h("div", { class: "duet-multiselect-wrapper" }, h("button", { id: this.identifier, ref: el => (this.multiselectElement = el), class: { "duet-multiselect": true, "duet-multiselect-active": this.checkboxesVisible }, tabindex: "0", onClick: () => this.toggleCheckboxes(), onFocus: e => this.onFocus(e), onBlur: e => this.onBlur(e), role: "combobox", "aria-expanded": this.checkboxesVisible ? "true" : "false", "aria-haspopup": "listbox", "aria-labelledby": this.labelId, "aria-describedby": this.getDescribedBy(), "aria-owns": `${this.identifier}-checkboxes`, onKeyDown: (e) => this.onMultiselectInputKeyDown(e), disabled: this.disabled }, h("span", { role: "textbox", "aria-readonly": "true", "aria-multiline": "false", "aria-autocomplete": "none", "aria-controls": `${this.identifier}-checkboxes`, "aria-label": this.placeholderLabel[this.language], class: "duet-multiselect-label" }, this.placeholder), this.value && this.value.length > 0 && (h("span", { class: "duet-multiselect-badge" }, this.value.length, h("duet-visually-hidden", null, this.selectedLangObject[this.language], ", ", this.value.map(item => item.label).join(", ")))), h("svg", { class: { "duet-multiselect-icon": true, "duet-multiselect-icon--rotate": this.checkboxesVisible }, fill: "currentColor", viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg" }, h("path", { d: "m12 18.999c-.4 0-.776-.156-1.059-.438l-10.721-10.72c-.142-.142-.22-.33-.22-.531 0-.2.078-.389.22-.53.142-.142.33-.22.53-.22s.389.078.53.22l10.72 10.719 10.72-10.719c.142-.142.33-.22.53-.22s.389.078.53.22c.142.142.22.33.22.53s-.078.389-.22.53l-10.72 10.72c-.282.283-.659.439-1.06.439z" }))), h("div", { id: `${this.identifier}-checkboxes`, role: "listbox", class: {
205
207
  "duet-multiselect-checkboxes": true,
206
208
  "duet-multiselect-checkboxes-active": this.checkboxesVisible,
207
209
  }, "aria-activedescendant": this.activeDescendant, "aria-multiselectable": "true" }, this.processedItems && this.allControls && (h("div", { class: "duet-multiselect-all-control-buttons" }, h("button", { class: "duet-multiselect-select-all", onClick: this.handleSelectAllClick, id: this.getOptionIdentifier(-2), onKeyDown: (e) => this.onCheckboxKeyDown(e, -2) }, this.selectAllLabel[this.language]), h("button", { class: "duet-multiselect-clear-all", onClick: this.handleClearAllClick, id: this.getOptionIdentifier(-1), onKeyDown: (e) => this.onCheckboxKeyDown(e, -1) }, this.clearAllLabel[this.language]))), this.processedItems &&
@@ -496,6 +498,46 @@ export class DuetMultiselect {
496
498
  "reflect": false,
497
499
  "defaultValue": "\"label\""
498
500
  },
501
+ "labelColor": {
502
+ "type": "string",
503
+ "mutable": true,
504
+ "complexType": {
505
+ "original": "string",
506
+ "resolved": "string",
507
+ "references": {}
508
+ },
509
+ "required": false,
510
+ "optional": false,
511
+ "docs": {
512
+ "tags": [],
513
+ "text": "Color of the label."
514
+ },
515
+ "attribute": "label-color",
516
+ "reflect": false
517
+ },
518
+ "labelWeight": {
519
+ "type": "string",
520
+ "mutable": true,
521
+ "complexType": {
522
+ "original": "DuetTextFontWeight",
523
+ "resolved": "\"normal\" | \"semi-bold\"",
524
+ "references": {
525
+ "DuetTextFontWeight": {
526
+ "location": "import",
527
+ "path": "../../common-types",
528
+ "id": "src/common-types.d.ts::DuetTextFontWeight"
529
+ }
530
+ }
531
+ },
532
+ "required": false,
533
+ "optional": false,
534
+ "docs": {
535
+ "tags": [],
536
+ "text": "Font weight of the label."
537
+ },
538
+ "attribute": "label-weight",
539
+ "reflect": false
540
+ },
499
541
  "accessibleDescribedBy": {
500
542
  "type": "string",
501
543
  "mutable": false,
@@ -4,6 +4,7 @@
4
4
  import { computePosition, flip, offset } from "@floating-ui/dom";
5
5
  import { Build, h, Host } from "@stencil/core";
6
6
  import { inheritGlobalTheme } from "../../common/themeable-component";
7
+ import { focusElement } from "../../utils/focus-utils";
7
8
  import { isArrowDownKey, isArrowUpKey, isEscapeKey, isTabKey } from "../../utils/keyboard-utils";
8
9
  import { Teleport } from "../../utils/teleport";
9
10
  export class DuetPopupMenu {
@@ -12,7 +13,7 @@ export class DuetPopupMenu {
12
13
  if (!this.controller) {
13
14
  return;
14
15
  }
15
- const coordinates = await computePosition(this.controller, this.element, {
16
+ const coordinates = await computePosition(this.controller, this.menuElement, {
16
17
  middleware: [offset({ mainAxis: this.mainAxisOffset, crossAxis: this.crossAxisOffset }), flip()],
17
18
  placement: this.placement,
18
19
  strategy: this.position,
@@ -24,6 +25,7 @@ export class DuetPopupMenu {
24
25
  this.menuY = undefined;
25
26
  this.menuX = undefined;
26
27
  this.accessibleLabel = undefined;
28
+ this.accessibleRole = "menu";
27
29
  this.theme = "";
28
30
  this.controller = undefined;
29
31
  this.placement = "bottom-start";
@@ -81,7 +83,7 @@ export class DuetPopupMenu {
81
83
  }
82
84
  }
83
85
  }
84
- if (isTabKey(evt)) {
86
+ if (isTabKey(evt) && this.accessibleRole === "menu") {
85
87
  evt.preventDefault();
86
88
  this.hide();
87
89
  }
@@ -105,7 +107,9 @@ export class DuetPopupMenu {
105
107
  async show() {
106
108
  this.open = true;
107
109
  this.teleport.go();
108
- this.itemElements[0].setFocus();
110
+ if (this.accessibleRole === "menu") {
111
+ this.itemElements[0].setFocus();
112
+ }
109
113
  this.duetToggle.emit({ open: this.open, component: "duet-popup-menu" });
110
114
  this.updatePlacement();
111
115
  }
@@ -115,7 +119,9 @@ export class DuetPopupMenu {
115
119
  async hide() {
116
120
  this.open = false;
117
121
  this.duetToggle.emit({ open: this.open, component: "duet-popup-menu" });
118
- this.focusController();
122
+ if (this.accessibleRole === "menu") {
123
+ this.focusController();
124
+ }
119
125
  this.teleport.resume(200);
120
126
  }
121
127
  /**
@@ -131,16 +137,11 @@ export class DuetPopupMenu {
131
137
  }
132
138
  focusController() {
133
139
  if (this.controller) {
134
- if ("setFocus" in this.controller) {
135
- this.controller.setFocus();
136
- }
137
- else {
138
- this.controller.focus();
139
- }
140
+ focusElement(this.controller);
140
141
  }
141
142
  }
142
143
  get itemElements() {
143
- return Array.from(this.element.querySelectorAll(":scope > duet-popup-menu-item"));
144
+ return Array.from(this.element.querySelectorAll(":scope duet-popup-menu-item"));
144
145
  }
145
146
  async getFocusedItemIndex() {
146
147
  const items = this.itemElements;
@@ -156,7 +157,7 @@ export class DuetPopupMenu {
156
157
  top: `${this.menuY}px`,
157
158
  left: `${this.menuX}px`,
158
159
  };
159
- return (h(Host, { class: this.position }, h("div", { style: positionStyles, class: { open: this.open, "duet-popup-menu-list": true, "duet-theme-turva": this.theme === "turva" }, role: "menu", "aria-label": this.accessibleLabel }, h("slot", null))));
160
+ return (h(Host, { class: this.position }, h("div", { ref: element => (this.menuElement = element), style: positionStyles, class: { open: this.open, "duet-popup-menu-list": true, "duet-theme-turva": this.theme === "turva" }, role: this.accessibleRole, "aria-label": this.accessibleLabel }, h("slot", null))));
160
161
  }
161
162
  static get is() { return "duet-popup-menu"; }
162
163
  static get encapsulation() { return "shadow"; }
@@ -189,6 +190,24 @@ export class DuetPopupMenu {
189
190
  "attribute": "accessible-label",
190
191
  "reflect": false
191
192
  },
193
+ "accessibleRole": {
194
+ "type": "string",
195
+ "mutable": false,
196
+ "complexType": {
197
+ "original": "\"menu\" | \"list\"",
198
+ "resolved": "\"list\" | \"menu\"",
199
+ "references": {}
200
+ },
201
+ "required": false,
202
+ "optional": false,
203
+ "docs": {
204
+ "tags": [],
205
+ "text": "Accessible role."
206
+ },
207
+ "attribute": "accessible-role",
208
+ "reflect": false,
209
+ "defaultValue": "\"menu\""
210
+ },
192
211
  "theme": {
193
212
  "type": "string",
194
213
  "mutable": true,
@@ -217,12 +236,22 @@ export class DuetPopupMenu {
217
236
  "type": "unknown",
218
237
  "mutable": false,
219
238
  "complexType": {
220
- "original": "HTMLElement | (HTMLElement & { setFocus(): void })",
221
- "resolved": "HTMLElement | HTMLElement & { setFocus(): void; }",
239
+ "original": "HTMLElement & FocusableComponent & OpenerComponent",
240
+ "resolved": "HTMLElement & FocusableComponent & OpenerComponent",
222
241
  "references": {
223
242
  "HTMLElement": {
224
243
  "location": "global",
225
244
  "id": "global::HTMLElement"
245
+ },
246
+ "FocusableComponent": {
247
+ "location": "import",
248
+ "path": "../../common",
249
+ "id": "src/common/index.ts::FocusableComponent"
250
+ },
251
+ "OpenerComponent": {
252
+ "location": "import",
253
+ "path": "../../common",
254
+ "id": "src/common/index.ts::OpenerComponent"
226
255
  }
227
256
  }
228
257
  },
@@ -50,6 +50,10 @@
50
50
  .duet-theme-turva .duet-popup-menu-item:focus, .duet-popup-menu-item:focus.duet-theme-turva {
51
51
  box-shadow: 0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px #171c3a;
52
52
  }
53
+ .duet-popup-menu-item.duet-theme-turva {
54
+ font-family: "turva-sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
55
+ color: rgb(23, 28, 58);
56
+ }
53
57
  .duet-popup-menu-item.active {
54
58
  background: rgb(243, 249, 252);
55
59
  }
@@ -26,6 +26,7 @@ export class DuetPopupMenuItem {
26
26
  };
27
27
  this.focus = false;
28
28
  this.accessibleLabel = undefined;
29
+ this.accessibleRole = "menuitem";
29
30
  this.theme = "";
30
31
  this.url = undefined;
31
32
  this.external = false;
@@ -61,7 +62,7 @@ export class DuetPopupMenuItem {
61
62
  active: this.active,
62
63
  "duet-theme-turva": this.theme === "turva",
63
64
  };
64
- return (h(Host, null, h(TagName, { ref: element => (this.itemElement = element), tabIndex: -1, onFocus: this.onFocus, onBlur: this.onBlur, role: "menuitem", "aria-label": this.accessibleLabel, class: classes, value: this.value, href: this.url, target: this.external ? "_blank" : undefined, rel: this.external ? "noopener" : undefined }, this.leadingIcon && (h("duet-icon", { name: this.leadingIcon, size: "x-small", color: this.leadingIconColor ? this.leadingIconColor : "currentColor", class: "duet-popup-menu-item-leading", margin: "none" })), h("span", { class: "duet-popup-menu-item-label" }, h("slot", null)), this.trailingIcon && (h("duet-icon", { name: this.trailingIcon, size: "x-small", color: "currentColor", class: "duet-popup-menu-item-trailing", margin: "none" })), this.trailingText && h("span", { class: "duet-popup-menu-item-trailing" }, this.trailingText))));
65
+ return (h(Host, null, h(TagName, { ref: element => (this.itemElement = element), tabIndex: this.accessibleRole === "menuitem" ? -1 : 0, onFocus: this.onFocus, onBlur: this.onBlur, role: `${TagName === "a" ? "link" : "button"} ${this.accessibleRole}`, "aria-label": this.accessibleLabel, class: classes, value: this.value, href: this.url, target: this.external ? "_blank" : undefined, rel: this.external ? "noopener" : undefined }, this.leadingIcon && (h("duet-icon", { name: this.leadingIcon, size: "x-small", color: this.leadingIconColor ? this.leadingIconColor : "currentColor", class: "duet-popup-menu-item-leading", margin: "none" })), h("span", { class: "duet-popup-menu-item-label" }, h("slot", null)), this.trailingIcon && (h("duet-icon", { name: this.trailingIcon, size: "x-small", color: "currentColor", class: "duet-popup-menu-item-trailing", margin: "none" })), this.trailingText && h("span", { class: "duet-popup-menu-item-trailing" }, this.trailingText))));
65
66
  }
66
67
  static get is() { return "duet-popup-menu-item"; }
67
68
  static get encapsulation() { return "shadow"; }
@@ -94,6 +95,24 @@ export class DuetPopupMenuItem {
94
95
  "attribute": "accessible-label",
95
96
  "reflect": false
96
97
  },
98
+ "accessibleRole": {
99
+ "type": "string",
100
+ "mutable": false,
101
+ "complexType": {
102
+ "original": "\"menuitem\" | \"listitem\"",
103
+ "resolved": "\"listitem\" | \"menuitem\"",
104
+ "references": {}
105
+ },
106
+ "required": false,
107
+ "optional": false,
108
+ "docs": {
109
+ "tags": [],
110
+ "text": "Accessible role."
111
+ },
112
+ "attribute": "accessible-role",
113
+ "reflect": false,
114
+ "defaultValue": "\"menuitem\""
115
+ },
97
116
  "theme": {
98
117
  "type": "string",
99
118
  "mutable": true,
@@ -3,7 +3,14 @@
3
3
  */
4
4
  import { h, Host } from "@stencil/core";
5
5
  import { inheritGlobalTheme } from "../../common/themeable-component";
6
+ import { slotElementCheck } from "../../utils/slot-utils";
6
7
  import { getColorByName } from "../../utils/token-utils";
8
+ /**
9
+ * @slot pre-heading - Slot for pre-heading content.
10
+ * @slot heading - Slot for heading content. Only span should be used in this slot.
11
+ * @slot description - Slot for description content. Only span should be used in this slot.
12
+ * @slot action - Slot for action button.
13
+ */
7
14
  export class DuetPromoCard {
8
15
  constructor() {
9
16
  this.theme = "";
@@ -38,7 +45,7 @@ export class DuetPromoCard {
38
45
  "duet-promo-card": true,
39
46
  "duet-theme-turva": this.theme === "turva",
40
47
  "no-bg-color": !this.backgroundColor,
41
- }, style: bannerStyles }, h(TagName, { href: this.url, class: "content-wrapper" }, h("img", { class: "image", src: this.image, alt: "", role: "presentation" }), h("div", { class: "content" }, this.hasPreHeadingSlot && (h("div", { class: "pre-heading" }, h("slot", { name: "pre-heading" }))), this.hasHeadingSlot && (h("div", { class: "heading" }, h("duet-heading", { theme: this.theme, level: this.headingLevel, "visual-level": "h3", margin: "none", color: this.textColor }, h("div", null, h("slot", { name: "heading" }))))), this.hasDescriptionSlot && (h("div", { class: "description" }, h("duet-paragraph", { theme: this.theme, margin: "none", color: this.textColor }, h("div", null, h("slot", { name: "description" }))))), this.hasActionSlot && (h("div", { class: "action" }, h("slot", { name: "action" }))))))));
48
+ }, style: bannerStyles }, h(TagName, { href: this.url, class: "content-wrapper" }, h("img", { class: "image", src: this.image, alt: "", role: "presentation" }), h("div", { class: "content" }, this.hasPreHeadingSlot && (h("div", { class: "pre-heading" }, h("slot", { name: "pre-heading" }))), this.hasHeadingSlot && (h("div", { class: "heading" }, h("duet-heading", { theme: this.theme, level: this.headingLevel, "visual-level": "h3", margin: "none", color: this.textColor }, h("span", null, h("slot", { name: "heading", onSlotchange: ev => slotElementCheck(ev, this, "span") }))))), this.hasDescriptionSlot && (h("div", { class: "description" }, h("duet-paragraph", { theme: this.theme, margin: "none", color: this.textColor }, h("span", null, h("slot", { name: "description", onSlotchange: ev => slotElementCheck(ev, this, "span") }))))), this.hasActionSlot && (h("div", { class: "action" }, h("slot", { name: "action" }))))))));
42
49
  }
43
50
  static get is() { return "duet-promo-card"; }
44
51
  static get encapsulation() { return "shadow"; }
@@ -64,6 +64,8 @@ export class DuetRangeSlider {
64
64
  this.accessibleDescribedBy = undefined;
65
65
  this.min = 0;
66
66
  this.label = "label";
67
+ this.labelColor = undefined;
68
+ this.labelWeight = undefined;
67
69
  this.labelHidden = false;
68
70
  this.unit = "";
69
71
  this.max = 100;
@@ -118,7 +120,7 @@ export class DuetRangeSlider {
118
120
  "duet-theme-turva": this.theme === "turva",
119
121
  "duet-ie": isInternetExplorer(),
120
122
  "duet-range-disabled": this.disabled,
121
- } }, h("duet-label", { theme: theme, margin: "small", for: identifier }, this.label), h("output", { "aria-hidden": "true", htmlFor: identifier, class: "duet-output" }, this.value.toLocaleString(this.locale), this.unit), h("input", { onInput: this.onInput, onChange: this.onChange, ref: input => (this.nativeInput = input), type: "range", min: this.min, max: this.max, step: this.step, value: this.value, style: rangeStyles, "aria-valuemin": this.min, "aria-valuemax": this.max, "aria-valuenow": this.value, "aria-valuetext": `${this.value} ${this.unit}`, "aria-controls": this.accessibleControls, "aria-activedescendant": this.accessibleActiveDescendant, "aria-owns": this.accessibleOwns, "aria-describedby": this.accessibleDescribedBy, id: identifier, name: this.name, disabled: this.disabled, required: this.required, class: "duet-range" }))));
123
+ } }, h("duet-label", { theme: theme, color: this.labelColor, weight: this.labelWeight, margin: "small", for: identifier }, this.label), h("output", { "aria-hidden": "true", htmlFor: identifier, class: "duet-output" }, this.value.toLocaleString(this.locale), this.unit), h("input", { onInput: this.onInput, onChange: this.onChange, ref: input => (this.nativeInput = input), type: "range", min: this.min, max: this.max, step: this.step, value: this.value, style: rangeStyles, "aria-valuemin": this.min, "aria-valuemax": this.max, "aria-valuenow": this.value, "aria-valuetext": `${this.value} ${this.unit}`, "aria-controls": this.accessibleControls, "aria-activedescendant": this.accessibleActiveDescendant, "aria-owns": this.accessibleOwns, "aria-describedby": this.accessibleDescribedBy, id: identifier, name: this.name, disabled: this.disabled, required: this.required, class: "duet-range" }))));
122
124
  }
123
125
  static get is() { return "duet-range-slider"; }
124
126
  static get encapsulation() { return "scoped"; }
@@ -374,6 +376,46 @@ export class DuetRangeSlider {
374
376
  "reflect": false,
375
377
  "defaultValue": "\"label\""
376
378
  },
379
+ "labelColor": {
380
+ "type": "string",
381
+ "mutable": true,
382
+ "complexType": {
383
+ "original": "string",
384
+ "resolved": "string",
385
+ "references": {}
386
+ },
387
+ "required": false,
388
+ "optional": false,
389
+ "docs": {
390
+ "tags": [],
391
+ "text": "Color of the label."
392
+ },
393
+ "attribute": "label-color",
394
+ "reflect": false
395
+ },
396
+ "labelWeight": {
397
+ "type": "string",
398
+ "mutable": true,
399
+ "complexType": {
400
+ "original": "DuetTextFontWeight",
401
+ "resolved": "\"normal\" | \"semi-bold\"",
402
+ "references": {
403
+ "DuetTextFontWeight": {
404
+ "location": "import",
405
+ "path": "../../common-types",
406
+ "id": "src/common-types.d.ts::DuetTextFontWeight"
407
+ }
408
+ }
409
+ },
410
+ "required": false,
411
+ "optional": false,
412
+ "docs": {
413
+ "tags": [],
414
+ "text": "Font weight of the label."
415
+ },
416
+ "attribute": "label-weight",
417
+ "reflect": false
418
+ },
377
419
  "labelHidden": {
378
420
  "type": "boolean",
379
421
  "mutable": false,
@@ -91,6 +91,8 @@ export class DuetSelect {
91
91
  this.disabled = false;
92
92
  this.required = false;
93
93
  this.label = "label";
94
+ this.labelColor = undefined;
95
+ this.labelWeight = undefined;
94
96
  this.role = undefined;
95
97
  this.tooltip = "";
96
98
  this.tooltipDirection = "auto";
@@ -157,7 +159,7 @@ export class DuetSelect {
157
159
  [`duet-select-variation-${this.variation}`]: true,
158
160
  "duet-input-top-caption-shown": this.isCaptionVisible,
159
161
  "has-error": !!this.error,
160
- } }, h("duet-label", { theme: this.theme === "turva" ? "turva" : "default", class: { "duet-has-tooltip": !!this.tooltip }, id: this.labelId, for: identifier }, this.label), this.tooltip && (h("duet-tooltip", { direction: this.tooltipDirection, accessibleInputLabel: this.label }, this.tooltip)), this.caption && (h("duet-caption", { id: this.topCaptionId, size: "medium" }, this.caption)), h("div", { class: "duet-select-wrapper" }, this.placeholder && this.echoPlaceholder && this.value && (h("duet-caption", { id: this.topCaptionPlaceholderId, class: "duet-select-placeholder", size: "small" }, this.placeholder)), h("select", { ref: select => (this.nativeSelect = select), disabled: this.disabled, name: this.name, id: identifier, role: this.role, "aria-labelledby": this.labelId, "aria-describedby": this.getDescribedBy(), "aria-controls": this.accessibleControls, "aria-activedescendant": this.accessibleActiveDescendant, "aria-owns": this.accessibleOwns, onFocus: this.onFocus, onBlur: this.onBlur, onChange: this.onChange, required: this.required }, this.placeholder && (h("option", { disabled: true, selected: true, value: "" }, this.placeholder)), !this.processedItems ? (h("option", null, "Virhe valintoja ladattaessa. P\u00E4ivit\u00E4 sivu ja kokeile uusiksi.")) : (this.processedItems.map(item => {
162
+ } }, h("duet-label", { theme: this.theme === "turva" ? "turva" : "default", class: { "duet-has-tooltip": !!this.tooltip }, color: this.labelColor, weight: this.labelWeight, id: this.labelId, for: identifier }, this.label), this.tooltip && (h("duet-tooltip", { direction: this.tooltipDirection, accessibleInputLabel: this.label }, this.tooltip)), this.caption && (h("duet-caption", { id: this.topCaptionId, size: "medium" }, this.caption)), h("div", { class: "duet-select-wrapper" }, this.placeholder && this.echoPlaceholder && this.value && (h("duet-caption", { id: this.topCaptionPlaceholderId, class: "duet-select-placeholder", size: "small" }, this.placeholder)), h("select", { ref: select => (this.nativeSelect = select), disabled: this.disabled, name: this.name, id: identifier, role: this.role, "aria-labelledby": this.labelId, "aria-describedby": this.getDescribedBy(), "aria-controls": this.accessibleControls, "aria-activedescendant": this.accessibleActiveDescendant, "aria-owns": this.accessibleOwns, onFocus: this.onFocus, onBlur: this.onBlur, onChange: this.onChange, required: this.required }, this.placeholder && (h("option", { disabled: true, selected: true, value: "" }, this.placeholder)), !this.processedItems ? (h("option", null, "Virhe valintoja ladattaessa. P\u00E4ivit\u00E4 sivu ja kokeile uusiksi.")) : (this.processedItems.map(item => {
161
163
  return isOptionGroup(item) ? this.renderOptionGroup(item) : this.renderOption(item);
162
164
  }))), h("div", { class: {
163
165
  "duet-select": true,
@@ -571,6 +573,46 @@ export class DuetSelect {
571
573
  "reflect": false,
572
574
  "defaultValue": "\"label\""
573
575
  },
576
+ "labelColor": {
577
+ "type": "string",
578
+ "mutable": true,
579
+ "complexType": {
580
+ "original": "string",
581
+ "resolved": "string",
582
+ "references": {}
583
+ },
584
+ "required": false,
585
+ "optional": false,
586
+ "docs": {
587
+ "tags": [],
588
+ "text": "Color of the label."
589
+ },
590
+ "attribute": "label-color",
591
+ "reflect": false
592
+ },
593
+ "labelWeight": {
594
+ "type": "string",
595
+ "mutable": true,
596
+ "complexType": {
597
+ "original": "DuetTextFontWeight",
598
+ "resolved": "\"normal\" | \"semi-bold\"",
599
+ "references": {
600
+ "DuetTextFontWeight": {
601
+ "location": "import",
602
+ "path": "../../common-types",
603
+ "id": "src/common-types.d.ts::DuetTextFontWeight"
604
+ }
605
+ }
606
+ },
607
+ "required": false,
608
+ "optional": false,
609
+ "docs": {
610
+ "tags": [],
611
+ "text": "Font weight of the label."
612
+ },
613
+ "attribute": "label-weight",
614
+ "reflect": false
615
+ },
574
616
  "role": {
575
617
  "type": "string",
576
618
  "mutable": false,
@@ -44,6 +44,15 @@
44
44
  display: flex;
45
45
  align-items: center;
46
46
  height: 100%;
47
+ font-family: "localtapiola-sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
48
+ font-size: 1rem;
49
+ font-weight: 400;
50
+ line-height: 1.5;
51
+ color: rgb(0, 41, 77);
52
+ }
53
+ .duet-slideout.duet-theme-turva {
54
+ font-family: "turva-sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
55
+ color: rgb(23, 28, 58);
47
56
  }
48
57
  .duet-slideout .desktop-bg {
49
58
  display: none;
@@ -95,6 +104,17 @@
95
104
  transition-delay: 0s;
96
105
  }
97
106
  }
107
+ .duet-slideout .dialog .top-container.has-sticky-header-slot {
108
+ position: sticky;
109
+ top: 0;
110
+ z-index: 200;
111
+ }
112
+ .duet-slideout .dialog .top-container.has-sticky-header-slot .top {
113
+ background: rgb(243, 249, 252);
114
+ }
115
+ .duet-slideout .dialog .top-container.has-sticky-header-slot .sticky-header {
116
+ display: block;
117
+ }
98
118
  .duet-slideout .dialog .top {
99
119
  position: relative;
100
120
  z-index: 1;
@@ -113,6 +133,14 @@
113
133
  .duet-slideout .dialog .top duet-icon {
114
134
  padding: 16px;
115
135
  }
136
+ .duet-slideout .dialog .sticky-header {
137
+ display: none;
138
+ width: 100%;
139
+ padding: 0 1.5rem;
140
+ margin-bottom: 20px;
141
+ background: rgb(243, 249, 252);
142
+ border-bottom: 1px solid rgb(225, 227, 230);
143
+ }
116
144
  .duet-slideout .dialog .items {
117
145
  display: flex;
118
146
  flex-direction: column;
@@ -147,6 +175,13 @@
147
175
  .duet-slideout.duet-theme-turva button.active::after {
148
176
  background: rgb(198, 12, 48);
149
177
  }
178
+ .duet-slideout.duet-theme-turva .has-sticky-header-slot .top {
179
+ background: rgb(245, 245, 247);
180
+ }
181
+ .duet-slideout.duet-theme-turva .has-sticky-header-slot .sticky-header {
182
+ background: rgb(245, 245, 247);
183
+ border-bottom: 1px solid rgb(228, 228, 230);
184
+ }
150
185
  .duet-slideout.duet-theme-turva .dialog .top button:focus {
151
186
  box-shadow: 0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px #171c3a;
152
187
  }