@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
@@ -5,20 +5,21 @@
5
5
 
6
6
  Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
- const index = require('./index-bf510b90.js');
8
+ const index = require('./index-b77ebc31.js');
9
9
  const themeableComponent = require('./themeable-component-83a2a0d4.js');
10
10
  const createId = require('./create-id-1f8c438f.js');
11
11
  const jsUtils = require('./js-utils-92e24ba1.js');
12
12
  const keyboardUtils = require('./keyboard-utils-681e11ec.js');
13
13
  const languageUtils = require('./language-utils-e8a527e5.js');
14
+ const slotUtils = require('./slot-utils-03a40c78.js');
14
15
  const stringUtils = require('./string-utils-053749ff.js');
15
16
 
16
17
  const SelectSingle = ({ item, search = "", selected }) => {
17
- const regEx = search !== "" ? new RegExp("(" + search.split(" ").join("|") + ")", "gi") : undefined;
18
+ const regEx = search !== "" ? new RegExp("(" + search.split(" ").join("|") + ")", "i") : undefined;
18
19
  return (index.h(index.Fragment, null,
19
20
  selected && index.h("duet-icon", { class: "option-icon", name: "messaging-checked", size: "xx-small", margin: "none" }),
20
21
  regEx ? (index.h("span", { class: "option-container", "aria-hidden": "true" },
21
- index.h("span", { innerHTML: item.name.replace(regEx, '<span class="highlight">$&</span>') }))) : (item.name),
22
+ index.h("span", { innerHTML: item.name.replace(regEx, '<span class="highlight sc-duet-combobox">$&</span>') }))) : (item.name),
22
23
  item.tags && index.h("span", { class: "option-tags" }, item.tags.join(", "))));
23
24
  };
24
25
 
@@ -37,7 +38,7 @@ const DuetComboBoxSelect = ({ item, active, total, selected, label = undefined,
37
38
  index.h(SelectSingle, { item: item, search: search, selected: selected }))));
38
39
  };
39
40
 
40
- 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)}";
41
+ 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)}";
41
42
 
42
43
  const DuetCombobox = class {
43
44
  constructor(hostRef) {
@@ -53,24 +54,63 @@ const DuetCombobox = class {
53
54
  // this.listElement.style.width = `${currentWidth + 1}px`
54
55
  }
55
56
  }, 100));
56
- this.handleInputKeyDownEvent = (e) => {
57
+ this.onInputChange = async (e) => {
58
+ const newValue = e.detail.value;
59
+ this.inputValue = newValue;
60
+ };
61
+ this.onInputClick = () => {
62
+ var _a, _b;
63
+ if (this.openListOnClick) {
64
+ this.listOpen = !this.listOpen;
65
+ }
66
+ else {
67
+ this.listOpen = ((_a = this.inputValue) === null || _a === void 0 ? void 0 : _a.length) >= this.minCharacters;
68
+ }
69
+ if (!((_b = this.getFilteredItems()) === null || _b === void 0 ? void 0 : _b.length)) {
70
+ this.listOpen = false;
71
+ }
72
+ };
73
+ this.onInputTyping = async (e) => {
74
+ var _a;
75
+ const newValue = e.detail.value;
76
+ if (!this.force && !this.multiple && this.selectedItems.size > 0 && newValue !== this.getSelectedItemLabel()) {
77
+ this.selectedItems.clear();
78
+ }
79
+ this.listOpen = String(newValue).length >= this.minCharacters && ((_a = this.getFilteredItems()) === null || _a === void 0 ? void 0 : _a.length) > 0;
80
+ };
81
+ this.onKeyDown = (e) => {
57
82
  //if selection is made, close the list and update internal and external values
83
+ const listItems = this.returnFilteredOrNonFiltered();
58
84
  // this should be set to undefined on everything BUT up/down arrow according to the aria 1.1 specs
59
85
  // https://www.w3.org/TR/wai-aria-practices-1.1/#combobox
60
86
  this.input.accessibleActiveDescendant = undefined;
61
87
  if (keyboardUtils.isEnterKey(e)) {
62
88
  e.preventDefault();
63
- this.selectActiveItem();
64
- this.updateInputText(false);
89
+ if (this.listOpen && this.activeItem !== undefined && listItems[this.activeItem]) {
90
+ if (this.multiple) {
91
+ this.addSelectedItem(listItems[this.activeItem].id, true);
92
+ }
93
+ else {
94
+ this.updateSelectedItem(listItems[this.activeItem].id, true);
95
+ }
96
+ }
97
+ this.activeItem = undefined;
65
98
  this.listOpen = false;
66
99
  return;
67
100
  }
68
- //tabbing out or escaping, restore initial state
69
101
  if (keyboardUtils.isEscapeKey(e) || keyboardUtils.isTabKey(e)) {
70
102
  this.updateInputText(true);
103
+ this.activeItem = undefined;
71
104
  this.listOpen = false;
72
105
  return;
73
106
  }
107
+ if (keyboardUtils.isBackspaceKey(e) && this.inputValue === "") {
108
+ if (this.multiple && this.selectedItems.size > 0) {
109
+ const lastItem = Array.from(this.selectedItems).pop();
110
+ this.removeSelectedItem(lastItem, true);
111
+ }
112
+ return;
113
+ }
74
114
  //handle arrow up/down navigation
75
115
  let nextActiveItem = this.activeItem;
76
116
  if (keyboardUtils.isArrowUpKey(e)) {
@@ -83,7 +123,6 @@ const DuetCombobox = class {
83
123
  this.listOpen = true;
84
124
  }
85
125
  if (keyboardUtils.isArrowDownKey(e) || keyboardUtils.isArrowUpKey(e)) {
86
- const listItems = this.shouldListBeFiltered() ? this.getFilteredItems() : this.processedItems;
87
126
  if (nextActiveItem < 0 || !nextActiveItem) {
88
127
  nextActiveItem = 0;
89
128
  }
@@ -96,13 +135,10 @@ const DuetCombobox = class {
96
135
  this.activeItem = nextActiveItem;
97
136
  this.scrollToActive();
98
137
  }
99
- this.announceActive();
100
138
  return;
101
139
  };
102
140
  this.processedItems = null;
103
- this.inputWidth = 0;
104
141
  this.inputValue = "";
105
- this.selectionMsg = "";
106
142
  this.listOpen = false;
107
143
  this.selectedItems = new Set();
108
144
  this.activeItem = undefined;
@@ -124,8 +160,11 @@ const DuetCombobox = class {
124
160
  },
125
161
  };
126
162
  this.accessibleLabels = languageUtils.getLocaleString(this.accessibleLabelDefaults, languageUtils.getLanguage());
163
+ this.label = "";
164
+ this.caption = "";
127
165
  this.theme = "";
128
166
  this.force = false;
167
+ this.multiple = false;
129
168
  this.items = undefined;
130
169
  this.formatter = (item) => item && item.name ? item.name : "";
131
170
  this.value = undefined;
@@ -141,7 +180,7 @@ const DuetCombobox = class {
141
180
  const path = e.composedPath();
142
181
  const isClickOutside = path.every(el => el !== this.element);
143
182
  if (isClickOutside) {
144
- this.updateInputText(true, true);
183
+ this.updateInputText(true);
145
184
  this.listOpen = false;
146
185
  }
147
186
  }
@@ -152,17 +191,67 @@ const DuetCombobox = class {
152
191
  async formatItem(item) {
153
192
  return this.formatter(item);
154
193
  }
155
- async processItems() {
156
- this.items = this.processedItems = stringUtils.parsePossibleJSON(this.items);
157
- await this.updateInputText();
194
+ processItems() {
195
+ const ids = [];
196
+ this.processedItems = stringUtils.parsePossibleJSON(this.items);
197
+ if (!Array.isArray(this.processedItems)) {
198
+ console.error("DuetCombobox: Items should be an array");
199
+ return;
200
+ }
201
+ if (this.processedItems.length !== new Set([...this.processedItems]).size) {
202
+ console.warn("DuetCombobox: Duplicate item values found in the list");
203
+ }
204
+ this.processedItems = this.processedItems.map((item, index) => {
205
+ if (typeof item === "string") {
206
+ item = { name: item, value: item };
207
+ }
208
+ if (item.id !== undefined) {
209
+ item.id = String(item.id);
210
+ }
211
+ else {
212
+ item.id = `${JSON.stringify(item.value)}-${item.name}`;
213
+ }
214
+ if (ids.includes(item.id)) {
215
+ console.warn("DuetCombobox: Duplicate item id found in the list, postfixed with index");
216
+ item.id = `${item.id}-${index}`;
217
+ }
218
+ ids.push(item.id);
219
+ return item;
220
+ });
221
+ // remove any item selections that are no longer in the items list
222
+ const selectionsMissing = Array.from(this.selectedItems).filter(id => !this.processedItems.find(item => item.id === id));
223
+ if (selectionsMissing.length) {
224
+ if (this.multiple) {
225
+ selectionsMissing.forEach(id => this.removeSelectedItem(id));
226
+ }
227
+ else {
228
+ this.updateSelectedItem(selectionsMissing[0], true);
229
+ }
230
+ }
158
231
  }
159
- async processValue() {
160
- if (this.value) {
161
- const selectedItem = this.items.find(item => item.value === this.value);
162
- this.updateSelectedItems(selectedItem.id);
232
+ processValue() {
233
+ // empty string may be valid item value
234
+ if (this.value !== "" && !this.value) {
235
+ this.selectedItems.clear();
236
+ return;
237
+ }
238
+ const values = Array.isArray(this.value) ? this.value : [this.value];
239
+ const ids = this.processedItems.filter(item => values.includes(item.value)).map(item => item.id);
240
+ // if value corresponds to the selectedItems, do nothing
241
+ if (ids.length === this.selectedItems.size && ids.every(id => this.selectedItems.has(id))) {
242
+ return;
243
+ }
244
+ if (this.multiple) {
245
+ this.selectedItems.clear();
246
+ this.input.clearChips();
247
+ ids.forEach(id => this.addSelectedItem(id));
248
+ }
249
+ else {
250
+ const selectedItem = this.processedItems.find(item => item.value === this.value);
251
+ this.updateSelectedItem(selectedItem.id);
163
252
  }
164
253
  }
165
- async processListOpenChange() {
254
+ processListOpenChange() {
166
255
  if (this.openListOnClick) {
167
256
  this.input.icon = this.listOpen ? "action-arrow-up" : "action-arrow-down";
168
257
  }
@@ -175,63 +264,51 @@ const DuetCombobox = class {
175
264
  themeableComponent.inheritGlobalTheme(this);
176
265
  }
177
266
  connectedCallback() {
178
- this.items = this.processedItems = stringUtils.parsePossibleJSON(this.items);
179
- this.input = this.element.querySelector("duet-input");
180
- this.input.addEventListener("duetChange", this.updateInputValue.bind(this));
181
- this.input.addEventListener("click", () => {
182
- if (!this.openListOnClick) {
183
- this.inputValue.length >= this.minCharacters ? (this.listOpen = true) : (this.listOpen = false);
184
- }
185
- else {
186
- this.listOpen = !this.listOpen;
187
- }
188
- });
189
- this.element.addEventListener("keydown", this.handleInputKeyDownEvent);
190
- languageUtils.connectLanguageChangeObserver(this, { prop: "accessibleLabels", defaults: "accessibleLabelDefaults" });
267
+ if (this.items) {
268
+ this.processItems();
269
+ }
270
+ const slottedElements = slotUtils.getElementsFromDefaultSlot(this.element);
271
+ if (slottedElements.length) {
272
+ this.input = slottedElements[0];
273
+ }
274
+ else {
275
+ this.input = document.createElement("duet-input");
276
+ this.input.label = this.label;
277
+ this.input.caption = this.caption;
278
+ this.input.expand = true;
279
+ this.element.prepend(this.input);
280
+ }
281
+ this.input.chips = this.multiple;
282
+ this.input.addEventListener("duetChange", this.onInputChange);
283
+ this.input.addEventListener("duetInput", this.onInputTyping);
284
+ this.input.addEventListener("click", this.onInputClick);
191
285
  //add correct aria attributes to the input element
192
286
  this.input.role = "combobox";
193
287
  this.input.accessibleExpanded = this.listOpen ? "true" : "false";
194
288
  this.input.accessibleAutocomplete = "list";
195
289
  this.input.accessibleControls = this.listBoxId;
290
+ this.element.addEventListener("keydown", this.onKeyDown);
291
+ languageUtils.connectLanguageChangeObserver(this, { prop: "accessibleLabels", defaults: "accessibleLabelDefaults" });
196
292
  this.processListOpenChange();
197
293
  }
198
294
  disconnectedCallback() {
199
- this.input.removeEventListener("duetChange", this.updateInputValue.bind(this));
200
- this.input.removeEventListener("click", () => this.inputValue.length ? (this.listOpen = true) : (this.listOpen = false));
201
- this.element.removeEventListener("keydown", this.handleInputKeyDownEvent);
202
- this.listElement.removeEventListener("click", e => {
203
- e.stopPropagation();
204
- });
295
+ this.input.removeEventListener("duetChange", this.onInputChange);
296
+ this.input.removeEventListener("click", this.onInputClick);
297
+ this.element.removeEventListener("keydown", this.onKeyDown);
205
298
  this.resizeObserver.disconnect();
206
299
  languageUtils.disconnectLanguageChangeObserver(this);
207
300
  }
208
301
  componentDidLoad() {
209
302
  // observe resize events to dynamically adjust size of dropdown area
210
303
  this.resizeObserver.observe(this.input);
211
- this.listElement.addEventListener("click", e => {
212
- e.stopPropagation();
213
- });
214
304
  this.processValue();
215
305
  }
216
- /**
217
- * Updates the input text based on the selected/clicked items.
218
- * @param event - event
219
- *'param item: DuetComboboxItem - the item that was selected
220
- */
221
- onListClick(e, item) {
222
- e.preventDefault();
223
- // update selected item with id
224
- this.updateSelectedItems(item.id, true);
225
- this.listOpen = false;
226
- return this.listOpen;
227
- }
228
306
  /**
229
307
  * Helper function that checks inputs in the field, compares it with the item list and returns true when inputvalue matches selectedItem id
230
- * TODO: this should be disabled in multiple mode
231
308
  */
232
309
  shouldListBeFiltered() {
233
- if (this.selectedItems.size && this.input.value === this.inputValue) {
234
- const item = this.items.filter(item => this.selectedItems.has(item.id));
310
+ if (!this.multiple && this.selectedItems.size && this.input.value === this.inputValue) {
311
+ const item = this.processedItems.find(item => this.selectedItems.has(item.id));
235
312
  return !(this.formatter(item).toLowerCase() === this.input.value.toLowerCase());
236
313
  }
237
314
  return true;
@@ -246,91 +323,135 @@ const DuetCombobox = class {
246
323
  : this.sortFilteredItems(this.processedItems)
247
324
  : [];
248
325
  }
326
+ emitChangeEvent(id) {
327
+ const item = this.processedItems.find(item => item.id === id);
328
+ this.duetChange.emit({
329
+ item,
330
+ value: this.value,
331
+ component: "duet-combobox",
332
+ });
333
+ }
249
334
  /**
250
- * Updates the selected items based on the item id.
251
- * @param id
252
- * @private
335
+ * Updates the value after selected items have changed for multiple selection.
253
336
  */
254
- async updateSelectedItems(id, emitEvent) {
255
- // for a multiple scenario wrap this in an if/else and just don't clear here
256
- this.selectedItems.clear();
257
- if (this.selectedItems) {
258
- if (this.selectedItems.has(id)) {
259
- this.selectedItems.delete(id);
260
- }
261
- else {
262
- this.selectedItems.add(id);
263
- }
337
+ updateMultipleValue() {
338
+ this.value = this.processedItems.filter(item => this.selectedItems.has(item.id)).map(item => item.value);
339
+ this.input.value = "";
340
+ this.updateChips();
341
+ }
342
+ /**
343
+ * Add item with id to the selectedItems set. Used only when multiple is true.
344
+ */
345
+ addSelectedItem(id, emitEvent) {
346
+ if (this.selectedItems.has(id)) {
347
+ return;
264
348
  }
349
+ this.selectedItems.add(id);
350
+ this.updateMultipleValue();
265
351
  if (emitEvent) {
266
- const item = this.selectedItems.size === 0 ? [] : this.items.filter(item => this.selectedItems.has(item.id));
267
- this.duetChange.emit({
268
- value: item[0].value,
269
- item: item[0],
270
- component: "duet-combobox",
271
- });
352
+ this.emitChangeEvent(id);
272
353
  }
273
- await this.updateInputText();
274
354
  }
275
355
  /**
276
- * Updates the input text based on the selected/clicked items.
277
- * @param bool -override to clear if invoked by "click outside"
356
+ * Remove item with id from the selectedItems set. Used only when multiple is true.
278
357
  */
279
- async updateInputText(isBlurred = false, isClickOutside = false) {
280
- const item = this.selectedItems.size === 0 ? [] : this.items.filter(item => this.selectedItems.has(item.id));
281
- //if items changed and given id no longer exists
282
- if (item.length === 0 && this.selectedItems.size > 0) {
283
- this.selectedItems.clear();
284
- this.input.value = "";
358
+ removeSelectedItem(id, emitEvent) {
359
+ if (!this.selectedItems.has(id)) {
360
+ return;
361
+ }
362
+ this.selectedItems.delete(id);
363
+ this.updateMultipleValue();
364
+ if (emitEvent) {
365
+ this.emitChangeEvent(id);
366
+ }
367
+ }
368
+ /**
369
+ * Updates the selected item based on the item id. Used only when multiple is false.
370
+ */
371
+ async updateSelectedItem(id, emitEvent) {
372
+ if (this.selectedItems.has(id)) {
373
+ this.selectedItems.delete(id);
285
374
  this.value = undefined;
286
- this.activeItem = undefined;
287
375
  }
288
- if (!isClickOutside && this.selectedItems.size === 1) {
289
- this.input.value = ""; // set value to empty so that cursor position follows accordingly
290
- this.input.value = await this.formatItem(item[0]);
291
- this.input.scrollLeft = this.input.scrollWidth;
292
- this.activeItem = undefined;
293
- this.value = item[0].value;
376
+ else {
377
+ this.selectedItems.clear();
378
+ this.selectedItems.add(id);
379
+ this.value = this.processedItems.find(item => item.id === id).value;
294
380
  }
295
- if (isBlurred) {
296
- if (this.selectedItems.size === 0) {
297
- this.activeItem = undefined;
298
- if (this.force) {
299
- this.inputValue = "";
300
- this.input.value = "";
301
- }
381
+ if (emitEvent) {
382
+ this.emitChangeEvent(id);
383
+ }
384
+ await this.updateInputText();
385
+ }
386
+ /**
387
+ * Add or remove chips of the input based on the selectedItems Set.
388
+ */
389
+ async updateChips() {
390
+ const ids = Array.from(this.selectedItems);
391
+ const chips = await this.input.getChips();
392
+ ids.forEach(async (id) => {
393
+ const item = this.processedItems.find(i => i.id === id);
394
+ const text = await this.formatItem(item);
395
+ const chipExists = await this.input.hasChip({ value: `${id}`, text });
396
+ if (!chipExists) {
397
+ const chip = document.createElement("duet-chip");
398
+ chip.variation = "input";
399
+ chip.value = `${id}`;
400
+ chip.textContent = text;
401
+ chip.addEventListener("duetRemove", evt => {
402
+ const id = evt.detail.value;
403
+ this.removeSelectedItem(id, true);
404
+ });
405
+ this.input.addChip(chip);
302
406
  }
303
- else if (this.force) {
304
- const selectedValueIndex = [...this.selectedItems][0];
305
- const selectedValueLabel = await this.formatItem(this.items[selectedValueIndex]);
306
- this.inputValue = selectedValueLabel;
307
- this.input.value = selectedValueLabel;
407
+ });
408
+ chips.forEach(chip => {
409
+ if (!ids.includes(chip.value)) {
410
+ chip.remove();
308
411
  }
309
- }
310
- this.listOpen = false;
412
+ });
311
413
  }
312
- updateInputValue(e) {
313
- var _a;
314
- this.inputValue = e.detail.value;
315
- this.listOpen = String(this.inputValue).length >= this.minCharacters && ((_a = this.getFilteredItems()) === null || _a === void 0 ? void 0 : _a.length) > 0;
414
+ async getSelectedItemLabel() {
415
+ const item = this.processedItems.find(item => this.selectedItems.has(item.id));
416
+ const label = item ? await this.formatItem(item) : "";
417
+ return label;
316
418
  }
317
- selectActiveItem() {
318
- if (this.activeItem === undefined) {
419
+ /**
420
+ * Updates the input text when the combobox loses focus or when a selection is made.
421
+ */
422
+ async updateInputText(isBlurred = false) {
423
+ if (isBlurred && this.multiple) {
424
+ this.input.value = "";
319
425
  return;
320
426
  }
321
- const filteredItem = this.returnFilteredOrNonFiltered();
322
- const item = filteredItem[this.activeItem];
323
- this.updateSelectedItems(item.id, true);
427
+ if (isBlurred && this.force) {
428
+ if (this.selectedItems.size === 0) {
429
+ this.input.value = "";
430
+ }
431
+ else {
432
+ this.input.value = await this.getSelectedItemLabel();
433
+ }
434
+ }
435
+ if (!isBlurred && this.selectedItems.size > 0) {
436
+ this.input.value = ""; // set value to empty so that cursor position follows accordingly
437
+ this.input.value = await this.getSelectedItemLabel();
438
+ this.input.scrollLeft = this.input.scrollWidth;
439
+ }
324
440
  }
325
- announceActive(items) {
326
- if (!items) {
327
- items = this.returnFilteredOrNonFiltered();
441
+ // Event handlers
442
+ onListClick(e, item) {
443
+ e.preventDefault();
444
+ e.stopPropagation();
445
+ // update selected item with id
446
+ if (this.multiple) {
447
+ this.addSelectedItem(item.id, true);
328
448
  }
329
- if (this.activeItem === undefined || this.activeItem === -1) {
330
- return;
449
+ else {
450
+ this.updateSelectedItem(item.id, true);
331
451
  }
332
- const item = items[this.activeItem];
333
- this.selectionMsg = structuredClone(this.formatLabel(item, items.length, this.items.length));
452
+ this.activeItem = undefined;
453
+ this.listOpen = false;
454
+ return this.listOpen;
334
455
  }
335
456
  //function that scrolls to the li element with the class "active"
336
457
  scrollToActive() {
@@ -358,16 +479,27 @@ const DuetCombobox = class {
358
479
  */
359
480
  getFilteredItems() {
360
481
  // filter items based on user inputs
361
- const filteredItems = this.processedItems.filter(item => {
362
- var _a, _b, _c, _d;
482
+ const filteredItems = this.processedItems
483
+ .filter(item => {
484
+ var _a, _b, _c, _d, _e;
363
485
  // filter by name and value
364
486
  // if value contains inputvalue
365
487
  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())) ||
366
488
  (
367
489
  // if name contains input value
368
490
  (_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())) ||
491
+ // if name contains input value
492
+ this.formatter(item).toLowerCase()[this.filterType]((_e = this.inputValue) === null || _e === void 0 ? void 0 : _e.toLowerCase()) ||
369
493
  // if the item is selected
370
494
  this.selectedItems.has(item.id);
495
+ })
496
+ // if multiple, filter out the selected items
497
+ .filter(item => {
498
+ let include = true;
499
+ if (this.multiple && this.selectedItems.has(item.id)) {
500
+ include = false;
501
+ }
502
+ return include;
371
503
  });
372
504
  return this.sortFilteredItems(filteredItems);
373
505
  }
@@ -401,9 +533,10 @@ const DuetCombobox = class {
401
533
  }, ref: el => (this.listContainer = el) }, index.h("ul", { class: {
402
534
  "duet-combobox-listbox-open": this.listOpen,
403
535
  "duet-combobox-listbox": true,
404
- }, role: "listbox", ref: el => (this.listElement = el), id: this.listBoxId }, selectElements.map((item, index$1) => {
405
- return (index.h(DuetComboBoxSelect, { item: item, active: index$1 === 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) }));
406
- })))));
536
+ }, role: "listbox", ref: el => (this.listElement = el), id: this.listBoxId }, this.listOpen &&
537
+ selectElements.map((item, index$1) => {
538
+ return (index.h(DuetComboBoxSelect, { item: item, active: index$1 === 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) }));
539
+ })))));
407
540
  }
408
541
  get element() { return index.getElement(this); }
409
542
  static get watchers() { return {
@@ -5,7 +5,7 @@
5
5
 
6
6
  Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
- const index = require('./index-bf510b90.js');
8
+ const index = require('./index-b77ebc31.js');
9
9
  const themeableComponent = require('./themeable-component-83a2a0d4.js');
10
10
  const languageUtils = require('./language-utils-e8a527e5.js');
11
11
  require('./string-utils-053749ff.js');
@@ -5,7 +5,7 @@
5
5
 
6
6
  Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
- const index = require('./index-bf510b90.js');
8
+ const index = require('./index-b77ebc31.js');
9
9
  const themeableComponent = require('./themeable-component-83a2a0d4.js');
10
10
  const keyboardUtils = require('./keyboard-utils-681e11ec.js');
11
11
 
@@ -5,12 +5,12 @@
5
5
 
6
6
  Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
- const index = require('./index-bf510b90.js');
8
+ const index = require('./index-b77ebc31.js');
9
9
  const themeableComponent = require('./themeable-component-83a2a0d4.js');
10
10
  const createId = require('./create-id-1f8c438f.js');
11
- const focusUtils = require('./focus-utils-44e2723d.js');
11
+ const focusUtils = require('./focus-utils-56f2d983.js');
12
12
  const languageUtils = require('./language-utils-e8a527e5.js');
13
- const slotUtils = require('./slot-utils-f5073417.js');
13
+ const slotUtils = require('./slot-utils-03a40c78.js');
14
14
  require('./string-utils-053749ff.js');
15
15
 
16
16
  const formatOptionsShort = { day: "numeric", month: "long" };
@@ -5,7 +5,7 @@
5
5
 
6
6
  Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
- const index = require('./index-bf510b90.js');
8
+ const index = require('./index-b77ebc31.js');
9
9
  const themeableComponent = require('./themeable-component-83a2a0d4.js');
10
10
  const tokenUtils = require('./token-utils-4ff49a49.js');
11
11
  require('./tokens.module-2198b663.js');
@@ -5,7 +5,7 @@
5
5
 
6
6
  Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
- const index = require('./index-bf510b90.js');
8
+ const index = require('./index-b77ebc31.js');
9
9
  const themeableComponent = require('./themeable-component-83a2a0d4.js');
10
10
  const jsUtils = require('./js-utils-92e24ba1.js');
11
11
  const keyboardUtils = require('./keyboard-utils-681e11ec.js');
@@ -5,7 +5,7 @@
5
5
 
6
6
  Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
- const index = require('./index-bf510b90.js');
8
+ const index = require('./index-b77ebc31.js');
9
9
  const themeableComponent = require('./themeable-component-83a2a0d4.js');
10
10
 
11
11
  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)}";