@duetds/components 8.5.4 → 8.6.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 (608) hide show
  1. package/hydrate/index.js +303 -137
  2. package/lib/cjs/duet-action-button.cjs.entry.js +1 -1
  3. package/lib/cjs/duet-alert.cjs.entry.js +2 -2
  4. package/lib/cjs/duet-badge.cjs.entry.js +1 -1
  5. package/lib/cjs/duet-banner.cjs.entry.js +2 -2
  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 +1 -1
  9. package/lib/cjs/duet-callout.cjs.entry.js +2 -2
  10. package/lib/cjs/duet-caption_4.cjs.entry.js +1 -1
  11. package/lib/cjs/duet-card.cjs.entry.js +1 -1
  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 +10 -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 +261 -128
  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 +3 -3
  21. package/lib/cjs/duet-divider_2.cjs.entry.js +1 -1
  22. package/lib/cjs/duet-editable-table_3.cjs.entry.js +1 -1
  23. package/lib/cjs/duet-empty-state.cjs.entry.js +1 -1
  24. package/lib/cjs/duet-fieldset.cjs.entry.js +2 -2
  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 +1 -1
  28. package/lib/cjs/duet-header_2.cjs.entry.js +1 -1
  29. package/lib/cjs/duet-hero.cjs.entry.js +2 -2
  30. package/lib/cjs/duet-icon.cjs.entry.js +1 -1
  31. package/lib/cjs/duet-input_2.cjs.entry.js +40 -4
  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 +1 -1
  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 +1 -1
  37. package/lib/cjs/duet-menu-bar-item.cjs.entry.js +1 -1
  38. package/lib/cjs/duet-menu-bar-link.cjs.entry.js +1 -1
  39. package/lib/cjs/duet-menu-bar.cjs.entry.js +1 -1
  40. package/lib/cjs/duet-modal.cjs.entry.js +15 -5
  41. package/lib/cjs/duet-multiselect.cjs.entry.js +2 -2
  42. package/lib/cjs/duet-nav.cjs.entry.js +1 -1
  43. package/lib/cjs/duet-notification_2.cjs.entry.js +1 -1
  44. package/lib/cjs/duet-number-input.cjs.entry.js +2 -22
  45. package/lib/cjs/duet-overlay.cjs.entry.js +1 -1
  46. package/lib/cjs/duet-page-heading.cjs.entry.js +1 -1
  47. package/lib/cjs/duet-pagination_2.cjs.entry.js +1 -1
  48. package/lib/cjs/duet-popup-menu-item.cjs.entry.js +1 -1
  49. package/lib/cjs/duet-popup-menu.cjs.entry.js +2 -2
  50. package/lib/cjs/duet-progress.cjs.entry.js +2 -2
  51. package/lib/cjs/duet-promo-card.cjs.entry.js +2 -2
  52. package/lib/cjs/duet-radio_2.cjs.entry.js +2 -2
  53. package/lib/cjs/duet-range-slider.cjs.entry.js +1 -1
  54. package/lib/cjs/duet-scrollable_3.cjs.entry.js +2 -2
  55. package/lib/cjs/duet-section-layout.cjs.entry.js +1 -1
  56. package/lib/cjs/duet-select.cjs.entry.js +2 -2
  57. package/lib/cjs/duet-shaped-image.cjs.entry.js +1 -1
  58. package/lib/cjs/duet-show-more.cjs.entry.js +1 -1
  59. package/lib/cjs/duet-slideout-lang.cjs.entry.js +1 -1
  60. package/lib/cjs/duet-slideout-link.cjs.entry.js +1 -1
  61. package/lib/cjs/duet-slideout-panel-dropdown.cjs.entry.js +1 -1
  62. package/lib/cjs/duet-slideout-panel.cjs.entry.js +3 -3
  63. package/lib/cjs/duet-slideout.cjs.entry.js +3 -3
  64. package/lib/cjs/duet-step_2.cjs.entry.js +1 -1
  65. package/lib/cjs/duet-submenu-bar-dropdown-link.cjs.entry.js +1 -1
  66. package/lib/cjs/duet-submenu-bar-dropdown.cjs.entry.js +1 -1
  67. package/lib/cjs/duet-submenu-bar-item.cjs.entry.js +1 -1
  68. package/lib/cjs/duet-submenu-bar-link.cjs.entry.js +1 -1
  69. package/lib/cjs/duet-submenu-bar.cjs.entry.js +1 -1
  70. package/lib/cjs/duet-textarea.cjs.entry.js +2 -2
  71. package/lib/cjs/duet-toggle.cjs.entry.js +1 -1
  72. package/lib/cjs/duet-toolbar-dropdown-link.cjs.entry.js +1 -1
  73. package/lib/cjs/duet-toolbar-dropdown.cjs.entry.js +1 -1
  74. package/lib/cjs/duet-toolbar-item.cjs.entry.js +1 -1
  75. package/lib/cjs/duet-toolbar-link.cjs.entry.js +1 -1
  76. package/lib/cjs/duet-toolbar.cjs.entry.js +1 -1
  77. package/lib/cjs/duet-tooltip-button_2.cjs.entry.js +2 -2
  78. package/lib/cjs/duet-tooltip.cjs.entry.js +1 -1
  79. package/lib/cjs/duet-tray.cjs.entry.js +1 -1
  80. package/lib/cjs/duet-upload-aria-status.cjs.entry.js +1 -1
  81. package/lib/cjs/duet-upload-item.cjs.entry.js +2 -2
  82. package/lib/cjs/duet-visually-hidden.cjs.entry.js +1 -1
  83. package/lib/cjs/duet.cjs.js +2 -2
  84. package/lib/cjs/{focus-utils-44e2723d.js → focus-utils-56f2d983.js} +1 -1
  85. package/lib/cjs/{index-bf510b90.js → index-b77ebc31.js} +1 -1
  86. package/lib/cjs/loader.cjs.js +2 -2
  87. package/lib/cjs/{slot-utils-f5073417.js → slot-utils-03a40c78.js} +3 -1
  88. package/lib/collection/components/duet-chip/duet-chip.css +7 -0
  89. package/lib/collection/components/duet-chip/duet-chip.js +29 -2
  90. package/lib/collection/components/duet-combobox/duet-combobox-select-single.js +2 -2
  91. package/lib/collection/components/duet-combobox/duet-combobox.css +10 -2
  92. package/lib/collection/components/duet-combobox/duet-combobox.e2e.js +81 -51
  93. package/lib/collection/components/duet-combobox/duet-combobox.js +321 -142
  94. package/lib/collection/components/duet-input/duet-input.css +29 -0
  95. package/lib/collection/components/duet-input/duet-input.js +159 -3
  96. package/lib/collection/components/duet-modal/duet-modal.js +12 -2
  97. package/lib/collection/components/duet-progress/duet-progress.css +10 -10
  98. package/lib/collection/components/duet-upload-item/duet-upload-item.js +1 -1
  99. package/lib/collection/utils/math.utils.js +0 -20
  100. package/lib/collection/utils/slot-utils.js +3 -1
  101. package/lib/dist-custom-elements/duet-action-button.js +1 -1
  102. package/lib/dist-custom-elements/duet-alert.js +1 -1
  103. package/lib/dist-custom-elements/duet-badge.js +1 -1
  104. package/lib/dist-custom-elements/duet-banner.js +4 -4
  105. package/lib/dist-custom-elements/duet-breadcrumb.js +4 -4
  106. package/lib/dist-custom-elements/duet-breadcrumbs.js +1 -1
  107. package/lib/dist-custom-elements/duet-button.js +1 -1
  108. package/lib/dist-custom-elements/duet-callout.js +3 -3
  109. package/lib/dist-custom-elements/duet-caption.js +1 -1
  110. package/lib/dist-custom-elements/duet-card.js +4 -4
  111. package/lib/dist-custom-elements/duet-checkbox.js +1 -1
  112. package/lib/dist-custom-elements/duet-checkmark.js +1 -1
  113. package/lib/dist-custom-elements/duet-chip.js +1 -273
  114. package/lib/dist-custom-elements/duet-choice-group.js +9 -9
  115. package/lib/dist-custom-elements/duet-choice.js +6 -6
  116. package/lib/dist-custom-elements/duet-collapsible.js +4 -4
  117. package/lib/dist-custom-elements/duet-combobox.js +327 -133
  118. package/lib/dist-custom-elements/duet-contact-card.js +8 -8
  119. package/lib/dist-custom-elements/duet-cookie-consent.js +7 -7
  120. package/lib/dist-custom-elements/duet-date-picker.js +14 -14
  121. package/lib/dist-custom-elements/duet-divider.js +1 -1
  122. package/lib/dist-custom-elements/duet-editable-table.js +8 -8
  123. package/lib/dist-custom-elements/duet-empty-state.js +1 -1
  124. package/lib/dist-custom-elements/duet-fieldset.js +1 -1
  125. package/lib/dist-custom-elements/duet-file-chooser.js +2 -2
  126. package/lib/dist-custom-elements/duet-footer.js +5 -5
  127. package/lib/dist-custom-elements/duet-grid-item.js +1 -1
  128. package/lib/dist-custom-elements/duet-grid.js +1 -1
  129. package/lib/dist-custom-elements/duet-header.js +9 -9
  130. package/lib/dist-custom-elements/duet-heading.js +1 -1
  131. package/lib/dist-custom-elements/duet-hero.js +10 -10
  132. package/lib/dist-custom-elements/duet-icon.js +1 -1
  133. package/lib/dist-custom-elements/duet-input.js +1 -1
  134. package/lib/dist-custom-elements/duet-label.js +1 -1
  135. package/lib/dist-custom-elements/duet-layout.js +1 -1
  136. package/lib/dist-custom-elements/duet-link.js +1 -1
  137. package/lib/dist-custom-elements/duet-list-item.js +1 -1
  138. package/lib/dist-custom-elements/duet-list.js +1 -1
  139. package/lib/dist-custom-elements/duet-logo.js +1 -1
  140. package/lib/dist-custom-elements/duet-menu-bar-button.js +2 -2
  141. package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.js +3 -3
  142. package/lib/dist-custom-elements/duet-menu-bar-dropdown.js +3 -3
  143. package/lib/dist-custom-elements/duet-menu-bar-item.js +2 -2
  144. package/lib/dist-custom-elements/duet-menu-bar-link.js +2 -2
  145. package/lib/dist-custom-elements/duet-menu-bar.js +2 -2
  146. package/lib/dist-custom-elements/duet-modal.js +22 -12
  147. package/lib/dist-custom-elements/duet-multiselect.js +11 -11
  148. package/lib/dist-custom-elements/duet-nav.js +1 -1
  149. package/lib/dist-custom-elements/duet-notification-drawer.js +5 -5
  150. package/lib/dist-custom-elements/duet-notification.js +3 -3
  151. package/lib/dist-custom-elements/duet-number-input.js +13 -33
  152. package/lib/dist-custom-elements/duet-overlay.js +1 -1
  153. package/lib/dist-custom-elements/duet-page-heading.js +2 -2
  154. package/lib/dist-custom-elements/duet-pagination.js +14 -14
  155. package/lib/dist-custom-elements/duet-paragraph.js +1 -1
  156. package/lib/dist-custom-elements/duet-popup-menu-item.js +2 -2
  157. package/lib/dist-custom-elements/duet-popup-menu.js +2 -2
  158. package/lib/dist-custom-elements/duet-progress.js +1 -1
  159. package/lib/dist-custom-elements/duet-promo-card.js +4 -4
  160. package/lib/dist-custom-elements/duet-radio-group.js +9 -9
  161. package/lib/dist-custom-elements/duet-radio.js +1 -1
  162. package/lib/dist-custom-elements/duet-range-slider.js +3 -3
  163. package/lib/dist-custom-elements/duet-range-stepper.js +5 -5
  164. package/lib/dist-custom-elements/duet-scrollable.js +1 -1
  165. package/lib/dist-custom-elements/duet-section-layout.js +1 -1
  166. package/lib/dist-custom-elements/duet-select.js +1 -1
  167. package/lib/dist-custom-elements/duet-shaped-image.js +1 -1
  168. package/lib/dist-custom-elements/duet-show-more.js +1 -1
  169. package/lib/dist-custom-elements/duet-slideout-lang.js +2 -2
  170. package/lib/dist-custom-elements/duet-slideout-link.js +2 -2
  171. package/lib/dist-custom-elements/duet-slideout-panel-dropdown.js +2 -2
  172. package/lib/dist-custom-elements/duet-slideout-panel.js +3 -3
  173. package/lib/dist-custom-elements/duet-slideout.js +5 -5
  174. package/lib/dist-custom-elements/duet-spacer.js +1 -1
  175. package/lib/dist-custom-elements/duet-spinner.js +1 -1
  176. package/lib/dist-custom-elements/duet-step.js +5 -5
  177. package/lib/dist-custom-elements/duet-stepper.js +2 -2
  178. package/lib/dist-custom-elements/duet-submenu-bar-dropdown-link.js +3 -3
  179. package/lib/dist-custom-elements/duet-submenu-bar-dropdown.js +3 -3
  180. package/lib/dist-custom-elements/duet-submenu-bar-item.js +3 -3
  181. package/lib/dist-custom-elements/duet-submenu-bar-link.js +3 -3
  182. package/lib/dist-custom-elements/duet-submenu-bar.js +3 -3
  183. package/lib/dist-custom-elements/duet-tab-group.js +14 -14
  184. package/lib/dist-custom-elements/duet-tab.js +2 -2
  185. package/lib/dist-custom-elements/duet-table.js +1 -1
  186. package/lib/dist-custom-elements/duet-textarea.js +11 -11
  187. package/lib/dist-custom-elements/duet-toggle.js +3 -3
  188. package/lib/dist-custom-elements/duet-toolbar-dropdown-link.js +3 -3
  189. package/lib/dist-custom-elements/duet-toolbar-dropdown.js +3 -3
  190. package/lib/dist-custom-elements/duet-toolbar-item.js +2 -2
  191. package/lib/dist-custom-elements/duet-toolbar-link.js +2 -2
  192. package/lib/dist-custom-elements/duet-toolbar.js +1 -1
  193. package/lib/dist-custom-elements/duet-tooltip-button.js +1 -1
  194. package/lib/dist-custom-elements/duet-tooltip-popup.js +1 -1
  195. package/lib/dist-custom-elements/duet-tooltip.js +1 -1
  196. package/lib/dist-custom-elements/duet-tray.js +4 -4
  197. package/lib/dist-custom-elements/duet-upload-aria-status.js +1 -1
  198. package/lib/dist-custom-elements/duet-upload-item.js +1 -1
  199. package/lib/dist-custom-elements/duet-upload.js +19 -19
  200. package/lib/dist-custom-elements/duet-visually-hidden.js +1 -1
  201. package/lib/dist-custom-elements/index.js +1 -1
  202. package/lib/dist-custom-elements/{p-000d074a.js → p-014c1177.js} +56 -15
  203. package/lib/dist-custom-elements/{p-74bc7fb5.js → p-03152b20.js} +4 -4
  204. package/lib/dist-custom-elements/{p-d87f6dd5.js → p-06e608ae.js} +3 -1
  205. package/lib/dist-custom-elements/{p-f902dfbb.js → p-08124065.js} +1 -1
  206. package/lib/dist-custom-elements/{p-9ef81fa1.js → p-0cee8a12.js} +4 -4
  207. package/lib/dist-custom-elements/{p-0dadb3dc.js → p-17ed32c8.js} +1 -1
  208. package/lib/dist-custom-elements/{p-a1d85bb1.js → p-1e9f6125.js} +1 -1
  209. package/lib/dist-custom-elements/{p-23ee46c7.js → p-23e23ced.js} +1 -1
  210. package/lib/dist-custom-elements/{p-6b7e5158.js → p-24693e9a.js} +11 -11
  211. package/lib/dist-custom-elements/{p-9be4acc3.js → p-28ec3461.js} +6 -6
  212. package/lib/dist-custom-elements/{p-099262f4.js → p-43967022.js} +1 -1
  213. package/lib/dist-custom-elements/{p-e80b5157.js → p-449019b6.js} +1 -1
  214. package/lib/dist-custom-elements/{p-76e650aa.js → p-45fd4d84.js} +3 -3
  215. package/lib/dist-custom-elements/{p-0bdd51f9.js → p-46074a1a.js} +1 -1
  216. package/lib/dist-custom-elements/{p-e3a662be.js → p-4b31300c.js} +2 -2
  217. package/lib/dist-custom-elements/{p-76a995aa.js → p-63954651.js} +1 -1
  218. package/lib/dist-custom-elements/{p-b189e243.js → p-667579b0.js} +1 -1
  219. package/lib/dist-custom-elements/{p-522231d2.js → p-68ba7bf1.js} +2 -2
  220. package/lib/dist-custom-elements/{p-623db984.js → p-6d366100.js} +8 -8
  221. package/lib/dist-custom-elements/p-755dd68f.js +285 -0
  222. package/lib/dist-custom-elements/{p-e44c0eff.js → p-785686e3.js} +1 -1
  223. package/lib/dist-custom-elements/{p-106c4204.js → p-83231ea8.js} +4 -4
  224. package/lib/dist-custom-elements/{p-38c8a0d9.js → p-92a16064.js} +6 -6
  225. package/lib/dist-custom-elements/{p-92c2651e.js → p-9490b060.js} +1 -1
  226. package/lib/dist-custom-elements/{p-07ba3d1b.js → p-971b25c0.js} +1 -1
  227. package/lib/dist-custom-elements/{p-958eb465.js → p-a02e62f3.js} +6 -6
  228. package/lib/dist-custom-elements/{p-8b18e721.js → p-a167e2a0.js} +1 -1
  229. package/lib/dist-custom-elements/{p-18ae9f6e.js → p-a4a10570.js} +3 -3
  230. package/lib/dist-custom-elements/{p-35946067.js → p-a829df6e.js} +2 -2
  231. package/lib/dist-custom-elements/{p-51cbd16b.js → p-b6322d8d.js} +1 -1
  232. package/lib/dist-custom-elements/{p-7a64db6d.js → p-baf3208f.js} +1 -1
  233. package/lib/dist-custom-elements/{p-186b3f98.js → p-bb25377b.js} +1 -1
  234. package/lib/dist-custom-elements/{p-319b5b5e.js → p-c8415e2f.js} +3 -3
  235. package/lib/dist-custom-elements/{p-4d080ea7.js → p-ce969139.js} +1 -1
  236. package/lib/dist-custom-elements/{p-5e09876b.js → p-d1815d2a.js} +1 -1
  237. package/lib/dist-custom-elements/{p-8085d9dc.js → p-d482a2e9.js} +1 -1
  238. package/lib/dist-custom-elements/{p-fcd29996.js → p-e3d597b6.js} +1 -1
  239. package/lib/dist-custom-elements/{p-90c00415.js → p-e702eb52.js} +9 -9
  240. package/lib/dist-custom-elements/{p-37349749.js → p-e98f9bb0.js} +1 -1
  241. package/lib/duet/duet.esm.js +1 -1
  242. package/lib/duet/duet.js +1 -1
  243. package/lib/duet/{p-5015d055.entry.js → p-00685523.entry.js} +1 -1
  244. package/lib/duet/{p-1e286d10.entry.js → p-025cfc0c.entry.js} +1 -1
  245. package/lib/duet/{p-39b78771.entry.js → p-050ffaf5.entry.js} +1 -1
  246. package/lib/duet/{p-13bc5519.entry.js → p-05a72320.entry.js} +1 -1
  247. package/lib/duet/{p-2a38e7ca.system.entry.js → p-061f4be0.system.entry.js} +1 -1
  248. package/lib/duet/p-06e608ae.js +4 -0
  249. package/lib/duet/{p-aff30f30.system.entry.js → p-0778ccde.system.entry.js} +1 -1
  250. package/lib/duet/p-07ac7f3e.system.entry.js +4 -0
  251. package/lib/duet/{p-5a9f4435.entry.js → p-08efced6.entry.js} +1 -1
  252. package/lib/duet/{p-0153663a.system.entry.js → p-0bd322cf.system.entry.js} +1 -1
  253. package/lib/duet/{p-81c5369e.system.entry.js → p-0de8d0c0.system.entry.js} +1 -1
  254. package/lib/duet/{p-a14dd8d6.entry.js → p-15c22a22.entry.js} +1 -1
  255. package/lib/duet/p-15e24bf0.entry.js +4 -0
  256. package/lib/duet/{p-ae55d362.system.entry.js → p-174ad02e.system.entry.js} +1 -1
  257. package/lib/duet/{p-a8729ddc.system.entry.js → p-179881d0.system.entry.js} +1 -1
  258. package/lib/duet/{p-e4f7a639.entry.js → p-1a7649e4.entry.js} +1 -1
  259. package/lib/duet/{p-711ed527.entry.js → p-1af72e95.entry.js} +1 -1
  260. package/lib/duet/{p-44ddb31b.system.entry.js → p-1ef0e5ca.system.entry.js} +1 -1
  261. package/lib/duet/{p-b4c0b337.entry.js → p-1f8ae410.entry.js} +1 -1
  262. package/lib/duet/{p-4c40347d.system.entry.js → p-1fc21d0d.system.entry.js} +1 -1
  263. package/lib/duet/{p-d28743bc.entry.js → p-2084a65f.entry.js} +1 -1
  264. package/lib/duet/{p-f8444a45.entry.js → p-23cecf9f.entry.js} +1 -1
  265. package/lib/duet/{p-64332c33.entry.js → p-2522cfc3.entry.js} +1 -1
  266. package/lib/duet/{p-1daade5e.system.entry.js → p-257800b7.system.entry.js} +1 -1
  267. package/lib/duet/{p-96b277d4.entry.js → p-26c5cd6f.entry.js} +1 -1
  268. package/lib/duet/{p-9f343e62.entry.js → p-29491f9f.entry.js} +1 -1
  269. package/lib/duet/{p-6edaf3e7.system.entry.js → p-2ae2e883.system.entry.js} +1 -1
  270. package/lib/duet/p-2f966c7e.entry.js +4 -0
  271. package/lib/duet/{p-532b94c5.entry.js → p-2faba2ba.entry.js} +1 -1
  272. package/lib/duet/{p-d16256d2.system.entry.js → p-31ad4690.system.entry.js} +1 -1
  273. package/lib/duet/{p-992b5c2a.entry.js → p-3302d75d.entry.js} +1 -1
  274. package/lib/duet/{p-9e61f9fc.entry.js → p-36f031e7.entry.js} +1 -1
  275. package/lib/duet/{p-f0e80d49.system.entry.js → p-37802e1f.system.entry.js} +2 -2
  276. package/lib/duet/{p-00524e54.entry.js → p-38f9c1e3.entry.js} +1 -1
  277. package/lib/duet/{p-1bd97f5e.system.entry.js → p-3f2d14e3.system.entry.js} +1 -1
  278. package/lib/duet/{p-e4665d66.entry.js → p-3f5a19f5.entry.js} +1 -1
  279. package/lib/duet/{p-2146ccb1.entry.js → p-40375e30.entry.js} +1 -1
  280. package/lib/duet/{p-b779fe4a.entry.js → p-427b81f9.entry.js} +1 -1
  281. package/lib/duet/p-43887017.system.js +4 -0
  282. package/lib/duet/{p-90cdb56a.system.entry.js → p-43d4b538.system.entry.js} +1 -1
  283. package/lib/duet/{p-f6d54697.system.entry.js → p-45bb3cd0.system.entry.js} +1 -1
  284. package/lib/duet/{p-9f89ac77.system.entry.js → p-46dda347.system.entry.js} +1 -1
  285. package/lib/duet/p-4781cd58.entry.js +4 -0
  286. package/lib/duet/{p-2f3ac2b1.entry.js → p-49add367.entry.js} +1 -1
  287. package/lib/duet/{p-33f4ec9a.entry.js → p-4c9725a9.entry.js} +1 -1
  288. package/lib/duet/p-4cb5943c.entry.js +4 -0
  289. package/lib/duet/{p-ded3678b.system.entry.js → p-4d959a3f.system.entry.js} +1 -1
  290. package/lib/duet/{p-60ad9b34.system.entry.js → p-4de910bd.system.entry.js} +1 -1
  291. package/lib/duet/p-4dfb4bf2.entry.js +4 -0
  292. package/lib/duet/{p-9ed19593.entry.js → p-4e724a7d.entry.js} +1 -1
  293. package/lib/duet/{p-bd9cd443.system.entry.js → p-52fb459a.system.entry.js} +1 -1
  294. package/lib/duet/{p-13350c6d.entry.js → p-5383553b.entry.js} +1 -1
  295. package/lib/duet/{p-bfeb20eb.entry.js → p-53c64c6f.entry.js} +1 -1
  296. package/lib/duet/{p-bdadb9bd.entry.js → p-547bba59.entry.js} +1 -1
  297. package/lib/duet/{p-5bded4d9.system.entry.js → p-54c848f2.system.entry.js} +1 -1
  298. package/lib/duet/{p-dcc50031.system.entry.js → p-5e59c38c.system.entry.js} +1 -1
  299. package/lib/duet/{p-8aaa05c9.system.entry.js → p-60fbf60b.system.entry.js} +1 -1
  300. package/lib/duet/p-6151635f.system.js +4 -0
  301. package/lib/duet/{p-12101d0a.entry.js → p-628ae8ba.entry.js} +1 -1
  302. package/lib/duet/{p-eb075fc2.system.entry.js → p-64afb6ad.system.entry.js} +1 -1
  303. package/lib/duet/{p-5c4729d1.entry.js → p-67382632.entry.js} +1 -1
  304. package/lib/duet/{p-4fcc690f.system.entry.js → p-67958acc.system.entry.js} +2 -2
  305. package/lib/duet/{p-add7cc51.entry.js → p-6c9cfb6d.entry.js} +1 -1
  306. package/lib/duet/{p-06af3e0d.system.entry.js → p-6d4c6665.system.entry.js} +1 -1
  307. package/lib/duet/p-6eab3859.system.entry.js +4 -0
  308. package/lib/duet/{p-d2812eda.entry.js → p-71900b7d.entry.js} +1 -1
  309. package/lib/duet/{p-063fa159.system.entry.js → p-7203b196.system.entry.js} +1 -1
  310. package/lib/duet/{p-152af927.entry.js → p-73cd3afd.entry.js} +1 -1
  311. package/lib/duet/{p-103e1ea5.entry.js → p-76e54ff5.entry.js} +1 -1
  312. package/lib/duet/{p-0f6f5022.entry.js → p-7a161455.entry.js} +1 -1
  313. package/lib/duet/{p-9ea65ea6.entry.js → p-7bc20355.entry.js} +1 -1
  314. package/lib/duet/{p-c436c01c.entry.js → p-7ca15c93.entry.js} +1 -1
  315. package/lib/duet/{p-5e27ecf8.system.entry.js → p-7de614df.system.entry.js} +1 -1
  316. package/lib/duet/{p-36814b20.system.entry.js → p-7f4b420c.system.entry.js} +1 -1
  317. package/lib/duet/{p-47b31337.system.entry.js → p-80ffc878.system.entry.js} +1 -1
  318. package/lib/duet/{p-a8ba298f.entry.js → p-83238fe7.entry.js} +1 -1
  319. package/lib/duet/{p-537a5ea4.js → p-83e9058b.js} +1 -1
  320. package/lib/duet/{p-10e8ec3c.system.entry.js → p-84b95df0.system.entry.js} +1 -1
  321. package/lib/duet/{p-bee0bef0.system.entry.js → p-85d58c2d.system.entry.js} +1 -1
  322. package/lib/duet/{p-5ed0239d.system.entry.js → p-8a41bde4.system.entry.js} +1 -1
  323. package/lib/duet/{p-6af8ebbd.system.entry.js → p-8a4ba903.system.entry.js} +1 -1
  324. package/lib/duet/p-8ba91848.entry.js +4 -0
  325. package/lib/duet/{p-294b6828.entry.js → p-8cc30578.entry.js} +1 -1
  326. package/lib/duet/{p-f70248e4.entry.js → p-8f7c7961.entry.js} +1 -1
  327. package/lib/duet/{p-ef7c1882.system.entry.js → p-8fb1d27a.system.entry.js} +1 -1
  328. package/lib/duet/{p-31cb6f2a.system.entry.js → p-9540e0a7.system.entry.js} +1 -1
  329. package/lib/duet/{p-978ac0fd.system.entry.js → p-956fad95.system.entry.js} +1 -1
  330. package/lib/duet/{p-a1e148ff.system.js → p-9644775c.system.js} +1 -1
  331. package/lib/duet/{p-10ed4192.entry.js → p-9735b2f9.entry.js} +1 -1
  332. package/lib/duet/{p-ca873140.system.entry.js → p-98ffa852.system.entry.js} +1 -1
  333. package/lib/duet/{p-7278eebe.system.entry.js → p-999fff8d.system.entry.js} +1 -1
  334. package/lib/duet/{p-c1cff444.entry.js → p-9ad40682.entry.js} +1 -1
  335. package/lib/duet/{p-2f1c1495.system.entry.js → p-9b4a8098.system.entry.js} +1 -1
  336. package/lib/duet/{p-9969b8d2.entry.js → p-9be9b4d2.entry.js} +1 -1
  337. package/lib/duet/{p-039fb5e0.system.entry.js → p-9e75e5d8.system.entry.js} +1 -1
  338. package/lib/duet/{p-350ce555.system.entry.js → p-a0954730.system.entry.js} +1 -1
  339. package/lib/duet/{p-e6337cba.system.entry.js → p-a21391c0.system.entry.js} +1 -1
  340. package/lib/duet/{p-cba2677e.entry.js → p-a3afb1af.entry.js} +1 -1
  341. package/lib/duet/p-a3e90064.system.entry.js +4 -0
  342. package/lib/duet/{p-bddb8969.system.entry.js → p-a476a851.system.entry.js} +1 -1
  343. package/lib/duet/{p-7416c3fd.entry.js → p-a5981a39.entry.js} +1 -1
  344. package/lib/duet/{p-07793fd7.system.entry.js → p-a7e9bc31.system.entry.js} +1 -1
  345. package/lib/duet/{p-58e1eb11.system.entry.js → p-a90f23ec.system.entry.js} +1 -1
  346. package/lib/duet/{p-8ea95681.entry.js → p-aaf99cb9.entry.js} +1 -1
  347. package/lib/duet/{p-f77cd41f.system.entry.js → p-aba91113.system.entry.js} +1 -1
  348. package/lib/duet/{p-87d4f03b.entry.js → p-ad9b7b51.entry.js} +1 -1
  349. package/lib/duet/p-ae21ad57.system.js +4 -0
  350. package/lib/duet/{p-ea4f9d4f.entry.js → p-aedb1d02.entry.js} +1 -1
  351. package/lib/duet/{p-fc6fc2b4.entry.js → p-af751e6f.entry.js} +1 -1
  352. package/lib/duet/{p-212816c2.system.entry.js → p-afc89c50.system.entry.js} +1 -1
  353. package/lib/duet/{p-963dda60.entry.js → p-afe7d680.entry.js} +1 -1
  354. package/lib/duet/{p-8f309969.entry.js → p-b1985704.entry.js} +1 -1
  355. package/lib/duet/{p-ccb0a9b5.entry.js → p-b2bd0b07.entry.js} +1 -1
  356. package/lib/duet/{p-ddd01622.system.entry.js → p-b2fc4b72.system.entry.js} +1 -1
  357. package/lib/duet/{p-4954dde9.entry.js → p-b3774ea3.entry.js} +1 -1
  358. package/lib/duet/{p-257cffd3.system.entry.js → p-b3c41b77.system.entry.js} +1 -1
  359. package/lib/duet/{p-ed830ad5.entry.js → p-b5595969.entry.js} +1 -1
  360. package/lib/duet/{p-5a828886.entry.js → p-b6f62761.entry.js} +1 -1
  361. package/lib/duet/p-b78c3e3e.entry.js +4 -0
  362. package/lib/duet/{p-76da5621.system.entry.js → p-bba9682d.system.entry.js} +1 -1
  363. package/lib/duet/{p-4a23f89c.system.entry.js → p-bca7ed02.system.entry.js} +1 -1
  364. package/lib/duet/{p-53095407.system.entry.js → p-bd0e5e20.system.entry.js} +1 -1
  365. package/lib/duet/{p-26c1f653.system.entry.js → p-be4b69a8.system.entry.js} +1 -1
  366. package/lib/duet/{p-f03de546.system.entry.js → p-bece15cd.system.entry.js} +1 -1
  367. package/lib/duet/{p-da00d24c.entry.js → p-c0793903.entry.js} +1 -1
  368. package/lib/duet/{p-ecbe605f.system.entry.js → p-c3bda242.system.entry.js} +1 -1
  369. package/lib/duet/{p-c602d65f.entry.js → p-c3c12f8d.entry.js} +1 -1
  370. package/lib/duet/{p-c881af7d.system.entry.js → p-c586a2c4.system.entry.js} +1 -1
  371. package/lib/duet/{p-d3c73570.entry.js → p-c5cf76db.entry.js} +1 -1
  372. package/lib/duet/{p-2910ca06.system.entry.js → p-c68602c9.system.entry.js} +1 -1
  373. package/lib/duet/{p-df8d8907.system.entry.js → p-c9370d43.system.entry.js} +1 -1
  374. package/lib/duet/{p-40e86323.system.entry.js → p-c94f3167.system.entry.js} +1 -1
  375. package/lib/duet/{p-640fd3a5.entry.js → p-cba00852.entry.js} +1 -1
  376. package/lib/duet/{p-2d3f539e.system.entry.js → p-cc18e40b.system.entry.js} +1 -1
  377. package/lib/duet/{p-7d1c7279.entry.js → p-cc78a011.entry.js} +1 -1
  378. package/lib/duet/{p-8b6a4691.entry.js → p-cc949a27.entry.js} +1 -1
  379. package/lib/duet/{p-1178f976.entry.js → p-cc9cfdb3.entry.js} +1 -1
  380. package/lib/duet/{p-7b5049b4.system.entry.js → p-cd87960a.system.entry.js} +1 -1
  381. package/lib/duet/{p-fdc4dc5e.entry.js → p-ce69866c.entry.js} +1 -1
  382. package/lib/duet/{p-50313fe6.system.entry.js → p-d5721f0d.system.entry.js} +1 -1
  383. package/lib/duet/p-d624e990.js +4 -0
  384. package/lib/duet/{p-43ea292e.system.entry.js → p-d72b94d2.system.entry.js} +1 -1
  385. package/lib/duet/{p-adcb7023.system.entry.js → p-d739e7af.system.entry.js} +1 -1
  386. package/lib/duet/{p-43b38eec.entry.js → p-dc133655.entry.js} +1 -1
  387. package/lib/duet/{p-9833b851.system.entry.js → p-dd95c9fb.system.entry.js} +1 -1
  388. package/lib/duet/p-de5054b6.system.entry.js +4 -0
  389. package/lib/duet/{p-18de73c6.system.entry.js → p-de6e4f28.system.entry.js} +1 -1
  390. package/lib/duet/{p-8c293cd5.entry.js → p-deb98669.entry.js} +1 -1
  391. package/lib/duet/{p-5e1120da.entry.js → p-df345202.entry.js} +1 -1
  392. package/lib/duet/{p-9353767c.entry.js → p-e0907f29.entry.js} +1 -1
  393. package/lib/duet/p-e333b9fc.system.entry.js +4 -0
  394. package/lib/duet/{p-db39d325.system.entry.js → p-e362468f.system.entry.js} +1 -1
  395. package/lib/duet/p-e411627f.entry.js +4 -0
  396. package/lib/duet/{p-6410e5dd.system.entry.js → p-e58015e8.system.entry.js} +1 -1
  397. package/lib/duet/{p-487de512.system.entry.js → p-e614e39f.system.entry.js} +1 -1
  398. package/lib/duet/{p-e934cfac.system.entry.js → p-e640a515.system.entry.js} +1 -1
  399. package/lib/duet/{p-493902bd.entry.js → p-e7fd0d14.entry.js} +1 -1
  400. package/lib/duet/{p-58c64457.system.entry.js → p-e86cafa6.system.entry.js} +2 -2
  401. package/lib/duet/{p-1ce4129b.system.entry.js → p-eafed149.system.entry.js} +1 -1
  402. package/lib/duet/{p-674c32de.system.entry.js → p-ebbecac7.system.entry.js} +1 -1
  403. package/lib/duet/{p-7c1bf9e8.entry.js → p-ec2e1d5e.entry.js} +1 -1
  404. package/lib/duet/{p-48738ce9.entry.js → p-ee4af632.entry.js} +1 -1
  405. package/lib/duet/{p-0e54eb00.entry.js → p-f07cbc38.entry.js} +1 -1
  406. package/lib/duet/{p-247102ef.entry.js → p-f1b5656c.entry.js} +1 -1
  407. package/lib/duet/p-f2279e1e.entry.js +4 -0
  408. package/lib/duet/{p-d86fad06.system.entry.js → p-f42f7738.system.entry.js} +2 -2
  409. package/lib/duet/{p-7104bf8e.entry.js → p-f48deed8.entry.js} +1 -1
  410. package/lib/duet/{p-39ac2361.system.entry.js → p-fa311641.system.entry.js} +1 -1
  411. package/lib/duet/{p-34d9bec1.system.entry.js → p-fa72c79b.system.entry.js} +1 -1
  412. package/lib/esm/duet-action-button.entry.js +1 -1
  413. package/lib/esm/duet-alert.entry.js +2 -2
  414. package/lib/esm/duet-badge.entry.js +1 -1
  415. package/lib/esm/duet-banner.entry.js +2 -2
  416. package/lib/esm/duet-breadcrumb.entry.js +1 -1
  417. package/lib/esm/duet-breadcrumbs.entry.js +1 -1
  418. package/lib/esm/duet-button_2.entry.js +1 -1
  419. package/lib/esm/duet-callout.entry.js +2 -2
  420. package/lib/esm/duet-caption_4.entry.js +1 -1
  421. package/lib/esm/duet-card.entry.js +1 -1
  422. package/lib/esm/duet-checkbox.entry.js +1 -1
  423. package/lib/esm/duet-checkmark.entry.js +1 -1
  424. package/lib/esm/duet-chip.entry.js +10 -3
  425. package/lib/esm/duet-choice_2.entry.js +2 -2
  426. package/lib/esm/duet-collapsible.entry.js +2 -2
  427. package/lib/esm/duet-combobox.entry.js +262 -129
  428. package/lib/esm/duet-contact-card.entry.js +1 -1
  429. package/lib/esm/duet-cookie-consent.entry.js +1 -1
  430. package/lib/esm/duet-date-picker.entry.js +3 -3
  431. package/lib/esm/duet-divider_2.entry.js +1 -1
  432. package/lib/esm/duet-editable-table_3.entry.js +1 -1
  433. package/lib/esm/duet-empty-state.entry.js +1 -1
  434. package/lib/esm/duet-fieldset.entry.js +2 -2
  435. package/lib/esm/duet-file-chooser.entry.js +1 -1
  436. package/lib/esm/duet-footer.entry.js +1 -1
  437. package/lib/esm/duet-grid_2.entry.js +1 -1
  438. package/lib/esm/duet-header_2.entry.js +1 -1
  439. package/lib/esm/duet-hero.entry.js +2 -2
  440. package/lib/esm/duet-icon.entry.js +1 -1
  441. package/lib/esm/duet-input_2.entry.js +40 -4
  442. package/lib/esm/duet-layout.entry.js +1 -1
  443. package/lib/esm/duet-list_2.entry.js +1 -1
  444. package/lib/esm/duet-menu-bar-button.entry.js +1 -1
  445. package/lib/esm/duet-menu-bar-dropdown-link.entry.js +1 -1
  446. package/lib/esm/duet-menu-bar-dropdown.entry.js +1 -1
  447. package/lib/esm/duet-menu-bar-item.entry.js +1 -1
  448. package/lib/esm/duet-menu-bar-link.entry.js +1 -1
  449. package/lib/esm/duet-menu-bar.entry.js +1 -1
  450. package/lib/esm/duet-modal.entry.js +15 -5
  451. package/lib/esm/duet-multiselect.entry.js +2 -2
  452. package/lib/esm/duet-nav.entry.js +1 -1
  453. package/lib/esm/duet-notification_2.entry.js +1 -1
  454. package/lib/esm/duet-number-input.entry.js +2 -22
  455. package/lib/esm/duet-overlay.entry.js +1 -1
  456. package/lib/esm/duet-page-heading.entry.js +1 -1
  457. package/lib/esm/duet-pagination_2.entry.js +1 -1
  458. package/lib/esm/duet-popup-menu-item.entry.js +1 -1
  459. package/lib/esm/duet-popup-menu.entry.js +2 -2
  460. package/lib/esm/duet-progress.entry.js +2 -2
  461. package/lib/esm/duet-promo-card.entry.js +2 -2
  462. package/lib/esm/duet-radio_2.entry.js +2 -2
  463. package/lib/esm/duet-range-slider.entry.js +1 -1
  464. package/lib/esm/duet-scrollable_3.entry.js +2 -2
  465. package/lib/esm/duet-section-layout.entry.js +1 -1
  466. package/lib/esm/duet-select.entry.js +2 -2
  467. package/lib/esm/duet-shaped-image.entry.js +1 -1
  468. package/lib/esm/duet-show-more.entry.js +1 -1
  469. package/lib/esm/duet-slideout-lang.entry.js +1 -1
  470. package/lib/esm/duet-slideout-link.entry.js +1 -1
  471. package/lib/esm/duet-slideout-panel-dropdown.entry.js +1 -1
  472. package/lib/esm/duet-slideout-panel.entry.js +3 -3
  473. package/lib/esm/duet-slideout.entry.js +3 -3
  474. package/lib/esm/duet-step_2.entry.js +1 -1
  475. package/lib/esm/duet-submenu-bar-dropdown-link.entry.js +1 -1
  476. package/lib/esm/duet-submenu-bar-dropdown.entry.js +1 -1
  477. package/lib/esm/duet-submenu-bar-item.entry.js +1 -1
  478. package/lib/esm/duet-submenu-bar-link.entry.js +1 -1
  479. package/lib/esm/duet-submenu-bar.entry.js +1 -1
  480. package/lib/esm/duet-textarea.entry.js +2 -2
  481. package/lib/esm/duet-toggle.entry.js +1 -1
  482. package/lib/esm/duet-toolbar-dropdown-link.entry.js +1 -1
  483. package/lib/esm/duet-toolbar-dropdown.entry.js +1 -1
  484. package/lib/esm/duet-toolbar-item.entry.js +1 -1
  485. package/lib/esm/duet-toolbar-link.entry.js +1 -1
  486. package/lib/esm/duet-toolbar.entry.js +1 -1
  487. package/lib/esm/duet-tooltip-button_2.entry.js +2 -2
  488. package/lib/esm/duet-tooltip.entry.js +1 -1
  489. package/lib/esm/duet-tray.entry.js +1 -1
  490. package/lib/esm/duet-upload-aria-status.entry.js +1 -1
  491. package/lib/esm/duet-upload-item.entry.js +2 -2
  492. package/lib/esm/duet-visually-hidden.entry.js +1 -1
  493. package/lib/esm/duet.js +3 -3
  494. package/lib/esm/{focus-utils-9390e3ea.js → focus-utils-ef611bf3.js} +1 -1
  495. package/lib/esm/{index-3dfa2ad1.js → index-356c0666.js} +1 -1
  496. package/lib/esm/loader.js +3 -3
  497. package/lib/esm/{slot-utils-1115a819.js → slot-utils-b50aaef5.js} +3 -1
  498. package/lib/esm-es5/duet-action-button.entry.js +1 -1
  499. package/lib/esm-es5/duet-alert.entry.js +1 -1
  500. package/lib/esm-es5/duet-badge.entry.js +1 -1
  501. package/lib/esm-es5/duet-banner.entry.js +1 -1
  502. package/lib/esm-es5/duet-breadcrumb.entry.js +1 -1
  503. package/lib/esm-es5/duet-breadcrumbs.entry.js +1 -1
  504. package/lib/esm-es5/duet-button_2.entry.js +1 -1
  505. package/lib/esm-es5/duet-callout.entry.js +1 -1
  506. package/lib/esm-es5/duet-caption_4.entry.js +1 -1
  507. package/lib/esm-es5/duet-card.entry.js +1 -1
  508. package/lib/esm-es5/duet-checkbox.entry.js +2 -2
  509. package/lib/esm-es5/duet-checkmark.entry.js +1 -1
  510. package/lib/esm-es5/duet-chip.entry.js +1 -1
  511. package/lib/esm-es5/duet-choice_2.entry.js +1 -1
  512. package/lib/esm-es5/duet-collapsible.entry.js +1 -1
  513. package/lib/esm-es5/duet-combobox.entry.js +2 -2
  514. package/lib/esm-es5/duet-contact-card.entry.js +1 -1
  515. package/lib/esm-es5/duet-cookie-consent.entry.js +1 -1
  516. package/lib/esm-es5/duet-date-picker.entry.js +1 -1
  517. package/lib/esm-es5/duet-divider_2.entry.js +1 -1
  518. package/lib/esm-es5/duet-editable-table_3.entry.js +1 -1
  519. package/lib/esm-es5/duet-empty-state.entry.js +1 -1
  520. package/lib/esm-es5/duet-fieldset.entry.js +1 -1
  521. package/lib/esm-es5/duet-file-chooser.entry.js +1 -1
  522. package/lib/esm-es5/duet-footer.entry.js +1 -1
  523. package/lib/esm-es5/duet-grid_2.entry.js +1 -1
  524. package/lib/esm-es5/duet-header_2.entry.js +1 -1
  525. package/lib/esm-es5/duet-hero.entry.js +1 -1
  526. package/lib/esm-es5/duet-icon.entry.js +1 -1
  527. package/lib/esm-es5/duet-input_2.entry.js +2 -2
  528. package/lib/esm-es5/duet-layout.entry.js +1 -1
  529. package/lib/esm-es5/duet-list_2.entry.js +1 -1
  530. package/lib/esm-es5/duet-menu-bar-button.entry.js +1 -1
  531. package/lib/esm-es5/duet-menu-bar-dropdown-link.entry.js +1 -1
  532. package/lib/esm-es5/duet-menu-bar-dropdown.entry.js +1 -1
  533. package/lib/esm-es5/duet-menu-bar-item.entry.js +1 -1
  534. package/lib/esm-es5/duet-menu-bar-link.entry.js +1 -1
  535. package/lib/esm-es5/duet-menu-bar.entry.js +1 -1
  536. package/lib/esm-es5/duet-modal.entry.js +1 -1
  537. package/lib/esm-es5/duet-multiselect.entry.js +1 -1
  538. package/lib/esm-es5/duet-nav.entry.js +1 -1
  539. package/lib/esm-es5/duet-notification_2.entry.js +1 -1
  540. package/lib/esm-es5/duet-number-input.entry.js +1 -1
  541. package/lib/esm-es5/duet-overlay.entry.js +1 -1
  542. package/lib/esm-es5/duet-page-heading.entry.js +1 -1
  543. package/lib/esm-es5/duet-pagination_2.entry.js +1 -1
  544. package/lib/esm-es5/duet-popup-menu-item.entry.js +1 -1
  545. package/lib/esm-es5/duet-popup-menu.entry.js +1 -1
  546. package/lib/esm-es5/duet-progress.entry.js +1 -1
  547. package/lib/esm-es5/duet-promo-card.entry.js +2 -2
  548. package/lib/esm-es5/duet-radio_2.entry.js +1 -1
  549. package/lib/esm-es5/duet-range-slider.entry.js +1 -1
  550. package/lib/esm-es5/duet-scrollable_3.entry.js +1 -1
  551. package/lib/esm-es5/duet-section-layout.entry.js +1 -1
  552. package/lib/esm-es5/duet-select.entry.js +1 -1
  553. package/lib/esm-es5/duet-shaped-image.entry.js +1 -1
  554. package/lib/esm-es5/duet-show-more.entry.js +1 -1
  555. package/lib/esm-es5/duet-slideout-lang.entry.js +1 -1
  556. package/lib/esm-es5/duet-slideout-link.entry.js +1 -1
  557. package/lib/esm-es5/duet-slideout-panel-dropdown.entry.js +1 -1
  558. package/lib/esm-es5/duet-slideout-panel.entry.js +1 -1
  559. package/lib/esm-es5/duet-slideout.entry.js +1 -1
  560. package/lib/esm-es5/duet-step_2.entry.js +1 -1
  561. package/lib/esm-es5/duet-submenu-bar-dropdown-link.entry.js +1 -1
  562. package/lib/esm-es5/duet-submenu-bar-dropdown.entry.js +1 -1
  563. package/lib/esm-es5/duet-submenu-bar-item.entry.js +1 -1
  564. package/lib/esm-es5/duet-submenu-bar-link.entry.js +1 -1
  565. package/lib/esm-es5/duet-submenu-bar.entry.js +1 -1
  566. package/lib/esm-es5/duet-textarea.entry.js +1 -1
  567. package/lib/esm-es5/duet-toggle.entry.js +1 -1
  568. package/lib/esm-es5/duet-toolbar-dropdown-link.entry.js +1 -1
  569. package/lib/esm-es5/duet-toolbar-dropdown.entry.js +1 -1
  570. package/lib/esm-es5/duet-toolbar-item.entry.js +1 -1
  571. package/lib/esm-es5/duet-toolbar-link.entry.js +1 -1
  572. package/lib/esm-es5/duet-toolbar.entry.js +1 -1
  573. package/lib/esm-es5/duet-tooltip-button_2.entry.js +1 -1
  574. package/lib/esm-es5/duet-tooltip.entry.js +1 -1
  575. package/lib/esm-es5/duet-tray.entry.js +1 -1
  576. package/lib/esm-es5/duet-upload-aria-status.entry.js +1 -1
  577. package/lib/esm-es5/duet-upload-item.entry.js +1 -1
  578. package/lib/esm-es5/duet-visually-hidden.entry.js +1 -1
  579. package/lib/esm-es5/duet.js +1 -1
  580. package/lib/esm-es5/{focus-utils-9390e3ea.js → focus-utils-ef611bf3.js} +1 -1
  581. package/lib/esm-es5/{index-3dfa2ad1.js → index-356c0666.js} +1 -1
  582. package/lib/esm-es5/loader.js +1 -1
  583. package/lib/esm-es5/slot-utils-b50aaef5.js +4 -0
  584. package/lib/types/components/duet-chip/duet-chip.d.ts +4 -0
  585. package/lib/types/components/duet-combobox/duet-combobox.d.ts +49 -35
  586. package/lib/types/components/duet-input/duet-input.d.ts +30 -0
  587. package/lib/types/components.d.ts +44 -21
  588. package/package.json +8 -8
  589. package/lib/duet/p-0a115218.entry.js +0 -4
  590. package/lib/duet/p-0d022f48.entry.js +0 -4
  591. package/lib/duet/p-14fffe50.system.entry.js +0 -4
  592. package/lib/duet/p-1c2748ee.entry.js +0 -4
  593. package/lib/duet/p-23ebb813.system.entry.js +0 -4
  594. package/lib/duet/p-3e53a745.entry.js +0 -4
  595. package/lib/duet/p-40fb2b0e.js +0 -4
  596. package/lib/duet/p-553ec65b.entry.js +0 -4
  597. package/lib/duet/p-5aa0c6a4.system.js +0 -4
  598. package/lib/duet/p-7cf03aa8.system.js +0 -4
  599. package/lib/duet/p-8c14f613.entry.js +0 -4
  600. package/lib/duet/p-98dbf928.system.entry.js +0 -4
  601. package/lib/duet/p-bb588a96.system.entry.js +0 -4
  602. package/lib/duet/p-c3d47de6.entry.js +0 -4
  603. package/lib/duet/p-ce490ebd.system.js +0 -4
  604. package/lib/duet/p-d0241096.entry.js +0 -4
  605. package/lib/duet/p-d87f6dd5.js +0 -4
  606. package/lib/duet/p-e8107d10.system.entry.js +0 -4
  607. package/lib/duet/p-feb80651.entry.js +0 -4
  608. package/lib/esm-es5/slot-utils-1115a819.js +0 -4
@@ -1,20 +1,21 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { h, F as Fragment, r as registerInstance, c as createEvent, H as Host, g as getElement } from './index-3dfa2ad1.js';
4
+ import { h, F as Fragment, r as registerInstance, c as createEvent, H as Host, g as getElement } from './index-356c0666.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-724c0f7e.js';
6
6
  import { c as createID } from './create-id-149a1b6d.js';
7
7
  import { d as debounce } from './js-utils-9b9e0039.js';
8
- import { j as isEnterKey, f as isEscapeKey, o as isTabKey, b as isArrowUpKey, c as isArrowDownKey } from './keyboard-utils-439bcc8b.js';
8
+ import { j as isEnterKey, f as isEscapeKey, o as isTabKey, e as isBackspaceKey, b as isArrowUpKey, c as isArrowDownKey } from './keyboard-utils-439bcc8b.js';
9
9
  import { g as getLocaleString, a as getLanguage, c as connectLanguageChangeObserver, d as disconnectLanguageChangeObserver } from './language-utils-00ca4c55.js';
10
+ import { g as getElementsFromDefaultSlot } from './slot-utils-b50aaef5.js';
10
11
  import { p as parsePossibleJSON } from './string-utils-ca039233.js';
11
12
 
12
13
  const SelectSingle = ({ item, search = "", selected }) => {
13
- const regEx = search !== "" ? new RegExp("(" + search.split(" ").join("|") + ")", "gi") : undefined;
14
+ const regEx = search !== "" ? new RegExp("(" + search.split(" ").join("|") + ")", "i") : undefined;
14
15
  return (h(Fragment, null,
15
16
  selected && h("duet-icon", { class: "option-icon", name: "messaging-checked", size: "xx-small", margin: "none" }),
16
17
  regEx ? (h("span", { class: "option-container", "aria-hidden": "true" },
17
- h("span", { innerHTML: item.name.replace(regEx, '<span class="highlight">$&</span>') }))) : (item.name),
18
+ h("span", { innerHTML: item.name.replace(regEx, '<span class="highlight sc-duet-combobox">$&</span>') }))) : (item.name),
18
19
  item.tags && h("span", { class: "option-tags" }, item.tags.join(", "))));
19
20
  };
20
21
 
@@ -33,7 +34,7 @@ const DuetComboBoxSelect = ({ item, active, total, selected, label = undefined,
33
34
  h(SelectSingle, { item: item, search: search, selected: selected }))));
34
35
  };
35
36
 
36
- const duetComboboxCss = ".sc-duet-combobox-h{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;position:relative;display:inline-block;width:100%;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(0, 41, 77)}.sc-duet-combobox-h a.sc-duet-combobox{color:rgb(0, 41, 77);transition:none}.duet-theme-turva.sc-duet-combobox-h{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-theme-turva.sc-duet-combobox-h a.sc-duet-combobox{color:rgb(23, 28, 58)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option.sc-duet-combobox .option-tags.sc-duet-combobox{color:rgb(116, 116, 117)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option.selected.sc-duet-combobox{background:rgb(244, 207, 214)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover{color:rgb(255, 255, 255);background:rgb(198, 12, 48)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox .option-tags.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus .option-tags.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover .option-tags.sc-duet-combobox{color:rgb(255, 255, 255)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox a.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus a.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover a.sc-duet-combobox{color:rgb(255, 255, 255)}.duet-combobox-list.sc-duet-combobox{position:absolute;top:calc(100% - 12px);z-index:700;display:none;background:rgb(255, 255, 255);border-radius:0 4px;box-shadow:0 2px 10px 0 rgba(0, 41, 77, 0.1)}.duet-combobox-list.open.sc-duet-combobox{display:block}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox{max-height:200px;padding:0.75rem 0;margin:0;overflow-y:scroll;font-weight:600;list-style:none;cursor:pointer;scroll-behavior:smooth}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox{padding:4px 0}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:not(.selected){padding-left:16px}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:not(.selected) .highlight.sc-duet-combobox{text-decoration:underline}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option.sc-duet-combobox .option-link.sc-duet-combobox{display:block;width:100%}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option.sc-duet-combobox .option-tags.sc-duet-combobox{float:right;padding-right:0.875rem;font-weight:400;color:rgb(144, 149, 153)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option-link.sc-duet-combobox{display:block;width:100%}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.selected.sc-duet-combobox{padding-left:0;background:rgb(205, 229, 241)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.selected.option.sc-duet-combobox .option-icon.sc-duet-combobox{padding:0 8px 0 8px}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.selected.option.sc-duet-combobox .option-tags.sc-duet-combobox{color:rgb(144, 149, 153)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover{color:rgb(255, 255, 255);background:rgb(0, 119, 179)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox .option-tags.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus .option-tags.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover .option-tags.sc-duet-combobox{color:rgb(255, 255, 255)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox a.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus a.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover a.sc-duet-combobox{color:rgb(255, 255, 255)}";
37
+ const duetComboboxCss = ".sc-duet-combobox-h{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;position:relative;display:inline-block;width:100%;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(0, 41, 77)}.sc-duet-combobox-h a.sc-duet-combobox{color:rgb(0, 41, 77);transition:none}.duet-theme-turva.sc-duet-combobox-h{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-theme-turva.sc-duet-combobox-h a.sc-duet-combobox{color:rgb(23, 28, 58)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option.sc-duet-combobox .option-tags.sc-duet-combobox{color:rgb(116, 116, 117)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option.selected.sc-duet-combobox{background:rgb(244, 207, 214)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover{color:rgb(255, 255, 255);background:rgb(198, 12, 48)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox .option-tags.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus .option-tags.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover .option-tags.sc-duet-combobox{color:rgb(255, 255, 255)}.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox a.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus a.sc-duet-combobox,.duet-theme-turva.sc-duet-combobox-h .duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover a.sc-duet-combobox{color:rgb(255, 255, 255)}.duet-combobox-list.sc-duet-combobox{position:absolute;top:calc(100% - 12px);z-index:700;margin:8px 0 0;visibility:hidden;background:rgb(255, 255, 255);border-radius:0 4px;box-shadow:0 2px 10px 0 rgba(0, 41, 77, 0.1);opacity:0;transition:transform 300ms ease, opacity 300ms ease, visibility 300ms ease;transform:scale(0.96) translateZ(0) translateY(-20px);transform-origin:top right}.duet-combobox-list.open.sc-duet-combobox{visibility:visible;opacity:1;transition-property:transform, opacity;transform:scale(1.0001) translateZ(0) translateY(0)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox{max-height:200px;padding:0.75rem 0;margin:0;overflow-y:scroll;font-weight:600;list-style:none;cursor:pointer;scroll-behavior:smooth}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox{padding:4px 0}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:not(.selected){padding-left:16px}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:not(.selected) .highlight.sc-duet-combobox{text-decoration:underline}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option.sc-duet-combobox .option-link.sc-duet-combobox{display:block;width:100%}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option.sc-duet-combobox .option-tags.sc-duet-combobox{float:right;padding-right:0.875rem;font-weight:400;color:rgb(144, 149, 153)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.option-link.sc-duet-combobox{display:block;width:100%}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.selected.sc-duet-combobox{padding-left:0;background:rgb(205, 229, 241)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.selected.option.sc-duet-combobox .option-icon.sc-duet-combobox{padding:0 8px 0 8px}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.selected.option.sc-duet-combobox .option-tags.sc-duet-combobox{color:rgb(144, 149, 153)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover{color:rgb(255, 255, 255);background:rgb(0, 119, 179)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox .option-tags.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus .option-tags.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover .option-tags.sc-duet-combobox{color:rgb(255, 255, 255)}.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.active.sc-duet-combobox a.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:focus a.sc-duet-combobox,.duet-combobox-list.sc-duet-combobox .duet-combobox-listbox.sc-duet-combobox .list-item.sc-duet-combobox:hover a.sc-duet-combobox{color:rgb(255, 255, 255)}";
37
38
 
38
39
  const DuetCombobox = class {
39
40
  constructor(hostRef) {
@@ -49,24 +50,63 @@ const DuetCombobox = class {
49
50
  // this.listElement.style.width = `${currentWidth + 1}px`
50
51
  }
51
52
  }, 100));
52
- this.handleInputKeyDownEvent = (e) => {
53
+ this.onInputChange = async (e) => {
54
+ const newValue = e.detail.value;
55
+ this.inputValue = newValue;
56
+ };
57
+ this.onInputClick = () => {
58
+ var _a, _b;
59
+ if (this.openListOnClick) {
60
+ this.listOpen = !this.listOpen;
61
+ }
62
+ else {
63
+ this.listOpen = ((_a = this.inputValue) === null || _a === void 0 ? void 0 : _a.length) >= this.minCharacters;
64
+ }
65
+ if (!((_b = this.getFilteredItems()) === null || _b === void 0 ? void 0 : _b.length)) {
66
+ this.listOpen = false;
67
+ }
68
+ };
69
+ this.onInputTyping = async (e) => {
70
+ var _a;
71
+ const newValue = e.detail.value;
72
+ if (!this.force && !this.multiple && this.selectedItems.size > 0 && newValue !== this.getSelectedItemLabel()) {
73
+ this.selectedItems.clear();
74
+ }
75
+ this.listOpen = String(newValue).length >= this.minCharacters && ((_a = this.getFilteredItems()) === null || _a === void 0 ? void 0 : _a.length) > 0;
76
+ };
77
+ this.onKeyDown = (e) => {
53
78
  //if selection is made, close the list and update internal and external values
79
+ const listItems = this.returnFilteredOrNonFiltered();
54
80
  // this should be set to undefined on everything BUT up/down arrow according to the aria 1.1 specs
55
81
  // https://www.w3.org/TR/wai-aria-practices-1.1/#combobox
56
82
  this.input.accessibleActiveDescendant = undefined;
57
83
  if (isEnterKey(e)) {
58
84
  e.preventDefault();
59
- this.selectActiveItem();
60
- this.updateInputText(false);
85
+ if (this.listOpen && this.activeItem !== undefined && listItems[this.activeItem]) {
86
+ if (this.multiple) {
87
+ this.addSelectedItem(listItems[this.activeItem].id, true);
88
+ }
89
+ else {
90
+ this.updateSelectedItem(listItems[this.activeItem].id, true);
91
+ }
92
+ }
93
+ this.activeItem = undefined;
61
94
  this.listOpen = false;
62
95
  return;
63
96
  }
64
- //tabbing out or escaping, restore initial state
65
97
  if (isEscapeKey(e) || isTabKey(e)) {
66
98
  this.updateInputText(true);
99
+ this.activeItem = undefined;
67
100
  this.listOpen = false;
68
101
  return;
69
102
  }
103
+ if (isBackspaceKey(e) && this.inputValue === "") {
104
+ if (this.multiple && this.selectedItems.size > 0) {
105
+ const lastItem = Array.from(this.selectedItems).pop();
106
+ this.removeSelectedItem(lastItem, true);
107
+ }
108
+ return;
109
+ }
70
110
  //handle arrow up/down navigation
71
111
  let nextActiveItem = this.activeItem;
72
112
  if (isArrowUpKey(e)) {
@@ -79,7 +119,6 @@ const DuetCombobox = class {
79
119
  this.listOpen = true;
80
120
  }
81
121
  if (isArrowDownKey(e) || isArrowUpKey(e)) {
82
- const listItems = this.shouldListBeFiltered() ? this.getFilteredItems() : this.processedItems;
83
122
  if (nextActiveItem < 0 || !nextActiveItem) {
84
123
  nextActiveItem = 0;
85
124
  }
@@ -92,13 +131,10 @@ const DuetCombobox = class {
92
131
  this.activeItem = nextActiveItem;
93
132
  this.scrollToActive();
94
133
  }
95
- this.announceActive();
96
134
  return;
97
135
  };
98
136
  this.processedItems = null;
99
- this.inputWidth = 0;
100
137
  this.inputValue = "";
101
- this.selectionMsg = "";
102
138
  this.listOpen = false;
103
139
  this.selectedItems = new Set();
104
140
  this.activeItem = undefined;
@@ -120,8 +156,11 @@ const DuetCombobox = class {
120
156
  },
121
157
  };
122
158
  this.accessibleLabels = getLocaleString(this.accessibleLabelDefaults, getLanguage());
159
+ this.label = "";
160
+ this.caption = "";
123
161
  this.theme = "";
124
162
  this.force = false;
163
+ this.multiple = false;
125
164
  this.items = undefined;
126
165
  this.formatter = (item) => item && item.name ? item.name : "";
127
166
  this.value = undefined;
@@ -137,7 +176,7 @@ const DuetCombobox = class {
137
176
  const path = e.composedPath();
138
177
  const isClickOutside = path.every(el => el !== this.element);
139
178
  if (isClickOutside) {
140
- this.updateInputText(true, true);
179
+ this.updateInputText(true);
141
180
  this.listOpen = false;
142
181
  }
143
182
  }
@@ -148,17 +187,67 @@ const DuetCombobox = class {
148
187
  async formatItem(item) {
149
188
  return this.formatter(item);
150
189
  }
151
- async processItems() {
152
- this.items = this.processedItems = parsePossibleJSON(this.items);
153
- await this.updateInputText();
190
+ processItems() {
191
+ const ids = [];
192
+ this.processedItems = parsePossibleJSON(this.items);
193
+ if (!Array.isArray(this.processedItems)) {
194
+ console.error("DuetCombobox: Items should be an array");
195
+ return;
196
+ }
197
+ if (this.processedItems.length !== new Set([...this.processedItems]).size) {
198
+ console.warn("DuetCombobox: Duplicate item values found in the list");
199
+ }
200
+ this.processedItems = this.processedItems.map((item, index) => {
201
+ if (typeof item === "string") {
202
+ item = { name: item, value: item };
203
+ }
204
+ if (item.id !== undefined) {
205
+ item.id = String(item.id);
206
+ }
207
+ else {
208
+ item.id = `${JSON.stringify(item.value)}-${item.name}`;
209
+ }
210
+ if (ids.includes(item.id)) {
211
+ console.warn("DuetCombobox: Duplicate item id found in the list, postfixed with index");
212
+ item.id = `${item.id}-${index}`;
213
+ }
214
+ ids.push(item.id);
215
+ return item;
216
+ });
217
+ // remove any item selections that are no longer in the items list
218
+ const selectionsMissing = Array.from(this.selectedItems).filter(id => !this.processedItems.find(item => item.id === id));
219
+ if (selectionsMissing.length) {
220
+ if (this.multiple) {
221
+ selectionsMissing.forEach(id => this.removeSelectedItem(id));
222
+ }
223
+ else {
224
+ this.updateSelectedItem(selectionsMissing[0], true);
225
+ }
226
+ }
154
227
  }
155
- async processValue() {
156
- if (this.value) {
157
- const selectedItem = this.items.find(item => item.value === this.value);
158
- this.updateSelectedItems(selectedItem.id);
228
+ processValue() {
229
+ // empty string may be valid item value
230
+ if (this.value !== "" && !this.value) {
231
+ this.selectedItems.clear();
232
+ return;
233
+ }
234
+ const values = Array.isArray(this.value) ? this.value : [this.value];
235
+ const ids = this.processedItems.filter(item => values.includes(item.value)).map(item => item.id);
236
+ // if value corresponds to the selectedItems, do nothing
237
+ if (ids.length === this.selectedItems.size && ids.every(id => this.selectedItems.has(id))) {
238
+ return;
239
+ }
240
+ if (this.multiple) {
241
+ this.selectedItems.clear();
242
+ this.input.clearChips();
243
+ ids.forEach(id => this.addSelectedItem(id));
244
+ }
245
+ else {
246
+ const selectedItem = this.processedItems.find(item => item.value === this.value);
247
+ this.updateSelectedItem(selectedItem.id);
159
248
  }
160
249
  }
161
- async processListOpenChange() {
250
+ processListOpenChange() {
162
251
  if (this.openListOnClick) {
163
252
  this.input.icon = this.listOpen ? "action-arrow-up" : "action-arrow-down";
164
253
  }
@@ -171,63 +260,51 @@ const DuetCombobox = class {
171
260
  inheritGlobalTheme(this);
172
261
  }
173
262
  connectedCallback() {
174
- this.items = this.processedItems = parsePossibleJSON(this.items);
175
- this.input = this.element.querySelector("duet-input");
176
- this.input.addEventListener("duetChange", this.updateInputValue.bind(this));
177
- this.input.addEventListener("click", () => {
178
- if (!this.openListOnClick) {
179
- this.inputValue.length >= this.minCharacters ? (this.listOpen = true) : (this.listOpen = false);
180
- }
181
- else {
182
- this.listOpen = !this.listOpen;
183
- }
184
- });
185
- this.element.addEventListener("keydown", this.handleInputKeyDownEvent);
186
- connectLanguageChangeObserver(this, { prop: "accessibleLabels", defaults: "accessibleLabelDefaults" });
263
+ if (this.items) {
264
+ this.processItems();
265
+ }
266
+ const slottedElements = getElementsFromDefaultSlot(this.element);
267
+ if (slottedElements.length) {
268
+ this.input = slottedElements[0];
269
+ }
270
+ else {
271
+ this.input = document.createElement("duet-input");
272
+ this.input.label = this.label;
273
+ this.input.caption = this.caption;
274
+ this.input.expand = true;
275
+ this.element.prepend(this.input);
276
+ }
277
+ this.input.chips = this.multiple;
278
+ this.input.addEventListener("duetChange", this.onInputChange);
279
+ this.input.addEventListener("duetInput", this.onInputTyping);
280
+ this.input.addEventListener("click", this.onInputClick);
187
281
  //add correct aria attributes to the input element
188
282
  this.input.role = "combobox";
189
283
  this.input.accessibleExpanded = this.listOpen ? "true" : "false";
190
284
  this.input.accessibleAutocomplete = "list";
191
285
  this.input.accessibleControls = this.listBoxId;
286
+ this.element.addEventListener("keydown", this.onKeyDown);
287
+ connectLanguageChangeObserver(this, { prop: "accessibleLabels", defaults: "accessibleLabelDefaults" });
192
288
  this.processListOpenChange();
193
289
  }
194
290
  disconnectedCallback() {
195
- this.input.removeEventListener("duetChange", this.updateInputValue.bind(this));
196
- this.input.removeEventListener("click", () => this.inputValue.length ? (this.listOpen = true) : (this.listOpen = false));
197
- this.element.removeEventListener("keydown", this.handleInputKeyDownEvent);
198
- this.listElement.removeEventListener("click", e => {
199
- e.stopPropagation();
200
- });
291
+ this.input.removeEventListener("duetChange", this.onInputChange);
292
+ this.input.removeEventListener("click", this.onInputClick);
293
+ this.element.removeEventListener("keydown", this.onKeyDown);
201
294
  this.resizeObserver.disconnect();
202
295
  disconnectLanguageChangeObserver(this);
203
296
  }
204
297
  componentDidLoad() {
205
298
  // observe resize events to dynamically adjust size of dropdown area
206
299
  this.resizeObserver.observe(this.input);
207
- this.listElement.addEventListener("click", e => {
208
- e.stopPropagation();
209
- });
210
300
  this.processValue();
211
301
  }
212
- /**
213
- * Updates the input text based on the selected/clicked items.
214
- * @param event - event
215
- *'param item: DuetComboboxItem - the item that was selected
216
- */
217
- onListClick(e, item) {
218
- e.preventDefault();
219
- // update selected item with id
220
- this.updateSelectedItems(item.id, true);
221
- this.listOpen = false;
222
- return this.listOpen;
223
- }
224
302
  /**
225
303
  * Helper function that checks inputs in the field, compares it with the item list and returns true when inputvalue matches selectedItem id
226
- * TODO: this should be disabled in multiple mode
227
304
  */
228
305
  shouldListBeFiltered() {
229
- if (this.selectedItems.size && this.input.value === this.inputValue) {
230
- const item = this.items.filter(item => this.selectedItems.has(item.id));
306
+ if (!this.multiple && this.selectedItems.size && this.input.value === this.inputValue) {
307
+ const item = this.processedItems.find(item => this.selectedItems.has(item.id));
231
308
  return !(this.formatter(item).toLowerCase() === this.input.value.toLowerCase());
232
309
  }
233
310
  return true;
@@ -242,91 +319,135 @@ const DuetCombobox = class {
242
319
  : this.sortFilteredItems(this.processedItems)
243
320
  : [];
244
321
  }
322
+ emitChangeEvent(id) {
323
+ const item = this.processedItems.find(item => item.id === id);
324
+ this.duetChange.emit({
325
+ item,
326
+ value: this.value,
327
+ component: "duet-combobox",
328
+ });
329
+ }
245
330
  /**
246
- * Updates the selected items based on the item id.
247
- * @param id
248
- * @private
331
+ * Updates the value after selected items have changed for multiple selection.
249
332
  */
250
- async updateSelectedItems(id, emitEvent) {
251
- // for a multiple scenario wrap this in an if/else and just don't clear here
252
- this.selectedItems.clear();
253
- if (this.selectedItems) {
254
- if (this.selectedItems.has(id)) {
255
- this.selectedItems.delete(id);
256
- }
257
- else {
258
- this.selectedItems.add(id);
259
- }
333
+ updateMultipleValue() {
334
+ this.value = this.processedItems.filter(item => this.selectedItems.has(item.id)).map(item => item.value);
335
+ this.input.value = "";
336
+ this.updateChips();
337
+ }
338
+ /**
339
+ * Add item with id to the selectedItems set. Used only when multiple is true.
340
+ */
341
+ addSelectedItem(id, emitEvent) {
342
+ if (this.selectedItems.has(id)) {
343
+ return;
260
344
  }
345
+ this.selectedItems.add(id);
346
+ this.updateMultipleValue();
261
347
  if (emitEvent) {
262
- const item = this.selectedItems.size === 0 ? [] : this.items.filter(item => this.selectedItems.has(item.id));
263
- this.duetChange.emit({
264
- value: item[0].value,
265
- item: item[0],
266
- component: "duet-combobox",
267
- });
348
+ this.emitChangeEvent(id);
268
349
  }
269
- await this.updateInputText();
270
350
  }
271
351
  /**
272
- * Updates the input text based on the selected/clicked items.
273
- * @param bool -override to clear if invoked by "click outside"
352
+ * Remove item with id from the selectedItems set. Used only when multiple is true.
274
353
  */
275
- async updateInputText(isBlurred = false, isClickOutside = false) {
276
- const item = this.selectedItems.size === 0 ? [] : this.items.filter(item => this.selectedItems.has(item.id));
277
- //if items changed and given id no longer exists
278
- if (item.length === 0 && this.selectedItems.size > 0) {
279
- this.selectedItems.clear();
280
- this.input.value = "";
354
+ removeSelectedItem(id, emitEvent) {
355
+ if (!this.selectedItems.has(id)) {
356
+ return;
357
+ }
358
+ this.selectedItems.delete(id);
359
+ this.updateMultipleValue();
360
+ if (emitEvent) {
361
+ this.emitChangeEvent(id);
362
+ }
363
+ }
364
+ /**
365
+ * Updates the selected item based on the item id. Used only when multiple is false.
366
+ */
367
+ async updateSelectedItem(id, emitEvent) {
368
+ if (this.selectedItems.has(id)) {
369
+ this.selectedItems.delete(id);
281
370
  this.value = undefined;
282
- this.activeItem = undefined;
283
371
  }
284
- if (!isClickOutside && this.selectedItems.size === 1) {
285
- this.input.value = ""; // set value to empty so that cursor position follows accordingly
286
- this.input.value = await this.formatItem(item[0]);
287
- this.input.scrollLeft = this.input.scrollWidth;
288
- this.activeItem = undefined;
289
- this.value = item[0].value;
372
+ else {
373
+ this.selectedItems.clear();
374
+ this.selectedItems.add(id);
375
+ this.value = this.processedItems.find(item => item.id === id).value;
290
376
  }
291
- if (isBlurred) {
292
- if (this.selectedItems.size === 0) {
293
- this.activeItem = undefined;
294
- if (this.force) {
295
- this.inputValue = "";
296
- this.input.value = "";
297
- }
377
+ if (emitEvent) {
378
+ this.emitChangeEvent(id);
379
+ }
380
+ await this.updateInputText();
381
+ }
382
+ /**
383
+ * Add or remove chips of the input based on the selectedItems Set.
384
+ */
385
+ async updateChips() {
386
+ const ids = Array.from(this.selectedItems);
387
+ const chips = await this.input.getChips();
388
+ ids.forEach(async (id) => {
389
+ const item = this.processedItems.find(i => i.id === id);
390
+ const text = await this.formatItem(item);
391
+ const chipExists = await this.input.hasChip({ value: `${id}`, text });
392
+ if (!chipExists) {
393
+ const chip = document.createElement("duet-chip");
394
+ chip.variation = "input";
395
+ chip.value = `${id}`;
396
+ chip.textContent = text;
397
+ chip.addEventListener("duetRemove", evt => {
398
+ const id = evt.detail.value;
399
+ this.removeSelectedItem(id, true);
400
+ });
401
+ this.input.addChip(chip);
298
402
  }
299
- else if (this.force) {
300
- const selectedValueIndex = [...this.selectedItems][0];
301
- const selectedValueLabel = await this.formatItem(this.items[selectedValueIndex]);
302
- this.inputValue = selectedValueLabel;
303
- this.input.value = selectedValueLabel;
403
+ });
404
+ chips.forEach(chip => {
405
+ if (!ids.includes(chip.value)) {
406
+ chip.remove();
304
407
  }
305
- }
306
- this.listOpen = false;
408
+ });
307
409
  }
308
- updateInputValue(e) {
309
- var _a;
310
- this.inputValue = e.detail.value;
311
- this.listOpen = String(this.inputValue).length >= this.minCharacters && ((_a = this.getFilteredItems()) === null || _a === void 0 ? void 0 : _a.length) > 0;
410
+ async getSelectedItemLabel() {
411
+ const item = this.processedItems.find(item => this.selectedItems.has(item.id));
412
+ const label = item ? await this.formatItem(item) : "";
413
+ return label;
312
414
  }
313
- selectActiveItem() {
314
- if (this.activeItem === undefined) {
415
+ /**
416
+ * Updates the input text when the combobox loses focus or when a selection is made.
417
+ */
418
+ async updateInputText(isBlurred = false) {
419
+ if (isBlurred && this.multiple) {
420
+ this.input.value = "";
315
421
  return;
316
422
  }
317
- const filteredItem = this.returnFilteredOrNonFiltered();
318
- const item = filteredItem[this.activeItem];
319
- this.updateSelectedItems(item.id, true);
423
+ if (isBlurred && this.force) {
424
+ if (this.selectedItems.size === 0) {
425
+ this.input.value = "";
426
+ }
427
+ else {
428
+ this.input.value = await this.getSelectedItemLabel();
429
+ }
430
+ }
431
+ if (!isBlurred && this.selectedItems.size > 0) {
432
+ this.input.value = ""; // set value to empty so that cursor position follows accordingly
433
+ this.input.value = await this.getSelectedItemLabel();
434
+ this.input.scrollLeft = this.input.scrollWidth;
435
+ }
320
436
  }
321
- announceActive(items) {
322
- if (!items) {
323
- items = this.returnFilteredOrNonFiltered();
437
+ // Event handlers
438
+ onListClick(e, item) {
439
+ e.preventDefault();
440
+ e.stopPropagation();
441
+ // update selected item with id
442
+ if (this.multiple) {
443
+ this.addSelectedItem(item.id, true);
324
444
  }
325
- if (this.activeItem === undefined || this.activeItem === -1) {
326
- return;
445
+ else {
446
+ this.updateSelectedItem(item.id, true);
327
447
  }
328
- const item = items[this.activeItem];
329
- this.selectionMsg = structuredClone(this.formatLabel(item, items.length, this.items.length));
448
+ this.activeItem = undefined;
449
+ this.listOpen = false;
450
+ return this.listOpen;
330
451
  }
331
452
  //function that scrolls to the li element with the class "active"
332
453
  scrollToActive() {
@@ -354,16 +475,27 @@ const DuetCombobox = class {
354
475
  */
355
476
  getFilteredItems() {
356
477
  // filter items based on user inputs
357
- const filteredItems = this.processedItems.filter(item => {
358
- var _a, _b, _c, _d;
478
+ const filteredItems = this.processedItems
479
+ .filter(item => {
480
+ var _a, _b, _c, _d, _e;
359
481
  // filter by name and value
360
482
  // if value contains inputvalue
361
483
  return ((_a = String(item.value)) === null || _a === void 0 ? void 0 : _a.toLowerCase()[this.filterType]((_b = this.inputValue) === null || _b === void 0 ? void 0 : _b.toLowerCase())) ||
362
484
  (
363
485
  // if name contains input value
364
486
  (_c = String(item.name)) === null || _c === void 0 ? void 0 : _c.toLowerCase()[this.filterType]((_d = this.inputValue) === null || _d === void 0 ? void 0 : _d.toLowerCase())) ||
487
+ // if name contains input value
488
+ this.formatter(item).toLowerCase()[this.filterType]((_e = this.inputValue) === null || _e === void 0 ? void 0 : _e.toLowerCase()) ||
365
489
  // if the item is selected
366
490
  this.selectedItems.has(item.id);
491
+ })
492
+ // if multiple, filter out the selected items
493
+ .filter(item => {
494
+ let include = true;
495
+ if (this.multiple && this.selectedItems.has(item.id)) {
496
+ include = false;
497
+ }
498
+ return include;
367
499
  });
368
500
  return this.sortFilteredItems(filteredItems);
369
501
  }
@@ -397,9 +529,10 @@ const DuetCombobox = class {
397
529
  }, ref: el => (this.listContainer = el) }, h("ul", { class: {
398
530
  "duet-combobox-listbox-open": this.listOpen,
399
531
  "duet-combobox-listbox": true,
400
- }, role: "listbox", ref: el => (this.listElement = el), id: this.listBoxId }, selectElements.map((item, index) => {
401
- return (h(DuetComboBoxSelect, { item: item, active: index === this.activeItem, selected: this.selectedItems.has(item.id), search: this.inputValue, total: selectElements.length, clickHandler: e => this.onListClick(e, item), label: this.formatLabel(item, selectElements.length, this.items.length) }));
402
- })))));
532
+ }, role: "listbox", ref: el => (this.listElement = el), id: this.listBoxId }, this.listOpen &&
533
+ selectElements.map((item, index) => {
534
+ return (h(DuetComboBoxSelect, { item: item, active: index === this.activeItem, selected: this.selectedItems.has(item.id), search: this.inputValue, total: selectElements.length, clickHandler: e => this.onListClick(e, item), label: this.formatLabel(item, selectElements.length, this.processedItems.length) }));
535
+ })))));
403
536
  }
404
537
  get element() { return getElement(this); }
405
538
  static get watchers() { return {
@@ -1,7 +1,7 @@
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-3dfa2ad1.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-356c0666.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-724c0f7e.js';
6
6
  import { a as getLanguage, c as connectLanguageChangeObserver, d as disconnectLanguageChangeObserver } from './language-utils-00ca4c55.js';
7
7
  import './string-utils-ca039233.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-3dfa2ad1.js';
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-356c0666.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-724c0f7e.js';
6
6
  import { s as subscribeTabbingChange, u as unsubscribeTabbingChange } from './keyboard-utils-439bcc8b.js';
7
7
 
@@ -1,12 +1,12 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { h, r as registerInstance, c as createEvent, H as Host, g as getElement } from './index-3dfa2ad1.js';
4
+ import { h, r as registerInstance, c as createEvent, H as Host, g as getElement } from './index-356c0666.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-724c0f7e.js';
6
6
  import { c as createID } from './create-id-149a1b6d.js';
7
- import { F as FocusGuard } from './focus-utils-9390e3ea.js';
7
+ import { F as FocusGuard } from './focus-utils-ef611bf3.js';
8
8
  import { a as getLanguage, g as getLocaleString, c as connectLanguageChangeObserver, d as disconnectLanguageChangeObserver } from './language-utils-00ca4c55.js';
9
- import { c as checkNamedSlotElement } from './slot-utils-1115a819.js';
9
+ import { c as checkNamedSlotElement } from './slot-utils-b50aaef5.js';
10
10
  import './string-utils-ca039233.js';
11
11
 
12
12
  const formatOptionsShort = { day: "numeric", month: "long" };
@@ -1,7 +1,7 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, h, g as getElement, H as Host } from './index-3dfa2ad1.js';
4
+ import { r as registerInstance, h, g as getElement, H as Host } from './index-356c0666.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-724c0f7e.js';
6
6
  import { g as getColorByName } from './token-utils-2adbab3f.js';
7
7
  import './tokens.module-8dbafec7.js';
@@ -1,7 +1,7 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { h, r as registerInstance, c as createEvent, H as Host, g as getElement, F as Fragment } from './index-3dfa2ad1.js';
4
+ import { h, r as registerInstance, c as createEvent, H as Host, g as getElement, F as Fragment } from './index-356c0666.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-724c0f7e.js';
6
6
  import { f as fieldSorter, d as debounce } from './js-utils-9b9e0039.js';
7
7
  import { i as isKeyboardClick } from './keyboard-utils-439bcc8b.js';
@@ -1,7 +1,7 @@
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-3dfa2ad1.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-356c0666.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-724c0f7e.js';
6
6
 
7
7
  const duetEmptyStateCss = "*,*::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;display:block;width:100%;height:100%}.duet-empty-state{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%;padding:48px;color:rgb(0, 41, 77);text-align:center;background:rgb(245, 248, 250);border-radius:4px}.duet-empty-state.duet-theme-turva{color:rgb(23, 28, 58);background:rgb(245, 245, 247)}";