@duetds/components 6.0.7 → 6.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (524) hide show
  1. package/hydrate/index.js +1362 -216
  2. package/lib/cjs/duet-action-button.cjs.entry.js +3 -3
  3. package/lib/cjs/duet-alert.cjs.entry.js +1 -1
  4. package/lib/cjs/duet-badge.cjs.entry.js +1 -1
  5. package/lib/cjs/duet-breadcrumb.cjs.entry.js +1 -1
  6. package/lib/cjs/duet-breadcrumbs.cjs.entry.js +1 -1
  7. package/lib/cjs/duet-button_2.cjs.entry.js +3 -3
  8. package/lib/cjs/duet-caption_4.cjs.entry.js +3 -3
  9. package/lib/cjs/duet-card.cjs.entry.js +10 -4
  10. package/lib/cjs/duet-checkbox.cjs.entry.js +6 -2
  11. package/lib/cjs/duet-choice_2.cjs.entry.js +2 -2
  12. package/lib/cjs/duet-collapsible.cjs.entry.js +2 -2
  13. package/lib/cjs/duet-combobox.cjs.entry.js +1 -1
  14. package/lib/cjs/duet-cookie-consent.cjs.entry.js +1 -1
  15. package/lib/cjs/duet-date-picker.cjs.entry.js +2 -2
  16. package/lib/cjs/duet-divider_2.cjs.entry.js +1 -1
  17. package/lib/cjs/duet-editable-table_3.cjs.entry.js +7 -18
  18. package/lib/cjs/duet-empty-state.cjs.entry.js +1 -1
  19. package/lib/cjs/duet-fieldset.cjs.entry.js +1 -1
  20. package/lib/cjs/duet-footer.cjs.entry.js +1 -1
  21. package/lib/cjs/duet-grid_2.cjs.entry.js +2 -2
  22. package/lib/cjs/duet-header_2.cjs.entry.js +3 -3
  23. package/lib/cjs/duet-hero.cjs.entry.js +1 -1
  24. package/lib/cjs/duet-icon.cjs.entry.js +3 -3
  25. package/lib/cjs/duet-input_2.cjs.entry.js +1 -1
  26. package/lib/cjs/duet-layout.cjs.entry.js +8 -2
  27. package/lib/cjs/duet-list_2.cjs.entry.js +1 -1
  28. package/lib/cjs/duet-menu-bar-dropdown-link.cjs.entry.js +49 -0
  29. package/lib/cjs/duet-menu-bar-dropdown.cjs.entry.js +65 -0
  30. package/lib/cjs/duet-menu-bar-link.cjs.entry.js +46 -0
  31. package/lib/cjs/duet-menu-bar-menu-dropdown-link.cjs.entry.js +58 -0
  32. package/lib/cjs/duet-menu-bar-menu-dropdown.cjs.entry.js +65 -0
  33. package/lib/cjs/duet-menu-bar-menu-link.cjs.entry.js +50 -0
  34. package/lib/cjs/duet-menu-bar-menu.cjs.entry.js +65 -0
  35. package/lib/cjs/duet-menu-bar.cjs.entry.js +76 -0
  36. package/lib/cjs/duet-modal.cjs.entry.js +2 -2
  37. package/lib/cjs/duet-multiselect.cjs.entry.js +227 -0
  38. package/lib/cjs/duet-nav.cjs.entry.js +116 -0
  39. package/lib/cjs/duet-notification_2.cjs.entry.js +1 -1
  40. package/lib/cjs/duet-number-input.cjs.entry.js +1 -1
  41. package/lib/cjs/duet-pagination_2.cjs.entry.js +1 -1
  42. package/lib/cjs/duet-progress.cjs.entry.js +1 -1
  43. package/lib/cjs/duet-radio_2.cjs.entry.js +1 -1
  44. package/lib/cjs/duet-range-slider.cjs.entry.js +2 -2
  45. package/lib/cjs/duet-scrollable_3.cjs.entry.js +1 -1
  46. package/lib/cjs/duet-section-layout.cjs.entry.js +42 -0
  47. package/lib/cjs/duet-select.cjs.entry.js +1 -1
  48. package/lib/cjs/duet-step_2.cjs.entry.js +1 -1
  49. package/lib/cjs/duet-textarea.cjs.entry.js +1 -1
  50. package/lib/cjs/duet-toggle.cjs.entry.js +1 -1
  51. package/lib/cjs/duet-toolbar-dropdown-link.cjs.entry.js +54 -0
  52. package/lib/cjs/duet-toolbar-dropdown.cjs.entry.js +78 -0
  53. package/lib/cjs/duet-toolbar-link.cjs.entry.js +50 -0
  54. package/lib/cjs/duet-toolbar.cjs.entry.js +38 -0
  55. package/lib/cjs/duet-tooltip.cjs.entry.js +1 -1
  56. package/lib/cjs/duet-tray.cjs.entry.js +2 -2
  57. package/lib/cjs/duet-upload-aria-status.cjs.entry.js +1 -1
  58. package/lib/cjs/duet-visually-hidden.cjs.entry.js +1 -1
  59. package/lib/cjs/duet.cjs.js +2 -2
  60. package/lib/cjs/{focus-utils-46880ee6.js → focus-utils-7a45cd29.js} +1 -1
  61. package/lib/cjs/{index-54afad07.js → index-222041ff.js} +1 -1
  62. package/lib/cjs/loader.cjs.js +2 -2
  63. package/lib/cjs/{token-utils-f6e2f4ef.js → token-utils-2e10264d.js} +17 -1
  64. package/lib/cjs/{tokens-4c69b122.js → tokens-21b244ee.js} +1 -0
  65. package/lib/cjs/{tokens.module-1bb2d45e.js → tokens.module-69170ddd.js} +3 -0
  66. package/lib/collection/collection-manifest.json +20 -0
  67. package/lib/collection/components/duet-card/duet-card.css +45 -0
  68. package/lib/collection/components/duet-card/duet-card.js +29 -0
  69. package/lib/collection/components/duet-checkbox/duet-checkbox.js +23 -1
  70. package/lib/collection/components/duet-editable-table/duet-editable-table.js +2 -1
  71. package/lib/collection/components/duet-layout/duet-layout.css +45 -0
  72. package/lib/collection/components/duet-layout/duet-layout.js +29 -0
  73. package/lib/collection/components/duet-menu-bar/duet-menu-bar.css +62 -0
  74. package/lib/collection/components/duet-menu-bar/duet-menu-bar.js +109 -0
  75. package/lib/collection/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.css +125 -0
  76. package/lib/collection/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.js +150 -0
  77. package/lib/collection/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.css +52 -0
  78. package/lib/collection/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.js +110 -0
  79. package/lib/collection/components/duet-menu-bar-link/duet-menu-bar-link.css +61 -0
  80. package/lib/collection/components/duet-menu-bar-link/duet-menu-bar-link.js +107 -0
  81. package/lib/collection/components/duet-menu-bar-menu/duet-menu-bar-menu.css +113 -0
  82. package/lib/collection/components/duet-menu-bar-menu/duet-menu-bar-menu.js +147 -0
  83. package/lib/collection/components/duet-menu-bar-menu-dropdown/duet-menu-bar-menu-dropdown.css +113 -0
  84. package/lib/collection/components/duet-menu-bar-menu-dropdown/duet-menu-bar-menu-dropdown.js +150 -0
  85. package/lib/collection/components/duet-menu-bar-menu-dropdown-link/duet-menu-bar-menu-dropdown-link.css +60 -0
  86. package/lib/collection/components/duet-menu-bar-menu-dropdown-link/duet-menu-bar-menu-dropdown-link.js +156 -0
  87. package/lib/collection/components/duet-menu-bar-menu-link/duet-menu-bar-menu-link.css +65 -0
  88. package/lib/collection/components/duet-menu-bar-menu-link/duet-menu-bar-menu-link.js +129 -0
  89. package/lib/collection/components/duet-multiselect/duet-multiselect.css +257 -0
  90. package/lib/collection/components/duet-multiselect/duet-multiselect.js +607 -0
  91. package/lib/collection/components/duet-nav/duet-nav.css +24 -0
  92. package/lib/collection/components/duet-nav/duet-nav.js +177 -0
  93. package/lib/collection/components/duet-section-layout/duet-section-layout.css +100 -0
  94. package/lib/collection/components/duet-section-layout/duet-section-layout.js +85 -0
  95. package/lib/collection/components/duet-table/duet-table.js +4 -16
  96. package/lib/collection/components/duet-toolbar/duet-toolbar.css +43 -0
  97. package/lib/collection/components/duet-toolbar/duet-toolbar.js +67 -0
  98. package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.css +117 -0
  99. package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.js +181 -0
  100. package/lib/collection/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.css +60 -0
  101. package/lib/collection/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.js +133 -0
  102. package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.css +78 -0
  103. package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.js +129 -0
  104. package/lib/collection/utils/token-utils.js +15 -0
  105. package/lib/dist-custom-elements/duet-action-button.js +1 -1
  106. package/lib/dist-custom-elements/duet-alert.js +1 -1
  107. package/lib/dist-custom-elements/duet-badge.js +1 -1
  108. package/lib/dist-custom-elements/duet-breadcrumb.js +2 -2
  109. package/lib/dist-custom-elements/duet-breadcrumbs.js +2 -2
  110. package/lib/dist-custom-elements/duet-button.js +1 -1
  111. package/lib/dist-custom-elements/duet-caption.js +1 -1
  112. package/lib/dist-custom-elements/duet-card.js +12 -5
  113. package/lib/dist-custom-elements/duet-checkbox.js +1 -155
  114. package/lib/dist-custom-elements/duet-choice-group.js +6 -6
  115. package/lib/dist-custom-elements/duet-choice.js +5 -5
  116. package/lib/dist-custom-elements/duet-collapsible.js +3 -3
  117. package/lib/dist-custom-elements/duet-combobox.js +3 -3
  118. package/lib/dist-custom-elements/duet-cookie-consent.js +6 -6
  119. package/lib/dist-custom-elements/duet-date-picker.js +8 -8
  120. package/lib/dist-custom-elements/duet-divider.js +1 -1
  121. package/lib/dist-custom-elements/duet-editable-table.js +1 -1
  122. package/lib/dist-custom-elements/duet-empty-state.js +1 -1
  123. package/lib/dist-custom-elements/duet-fieldset.js +1 -1
  124. package/lib/dist-custom-elements/duet-footer.js +4 -4
  125. package/lib/dist-custom-elements/duet-grid-item.js +1 -1
  126. package/lib/dist-custom-elements/duet-grid.js +1 -1
  127. package/lib/dist-custom-elements/duet-header.js +9 -9
  128. package/lib/dist-custom-elements/duet-heading.js +1 -1
  129. package/lib/dist-custom-elements/duet-hero.js +9 -9
  130. package/lib/dist-custom-elements/duet-icon.js +1 -1
  131. package/lib/dist-custom-elements/duet-input.js +1 -1
  132. package/lib/dist-custom-elements/duet-label.js +1 -1
  133. package/lib/dist-custom-elements/duet-layout.js +10 -3
  134. package/lib/dist-custom-elements/duet-link.js +1 -1
  135. package/lib/dist-custom-elements/duet-list-item.js +1 -1
  136. package/lib/dist-custom-elements/duet-list.js +1 -1
  137. package/lib/dist-custom-elements/duet-logo.js +1 -1
  138. package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.d.ts +11 -0
  139. package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.js +73 -0
  140. package/lib/dist-custom-elements/duet-menu-bar-dropdown.d.ts +11 -0
  141. package/lib/dist-custom-elements/duet-menu-bar-dropdown.js +89 -0
  142. package/lib/dist-custom-elements/duet-menu-bar-link.d.ts +11 -0
  143. package/lib/dist-custom-elements/duet-menu-bar-link.js +70 -0
  144. package/lib/dist-custom-elements/duet-menu-bar-menu-dropdown-link.d.ts +11 -0
  145. package/lib/dist-custom-elements/duet-menu-bar-menu-dropdown-link.js +84 -0
  146. package/lib/dist-custom-elements/duet-menu-bar-menu-dropdown.d.ts +11 -0
  147. package/lib/dist-custom-elements/duet-menu-bar-menu-dropdown.js +89 -0
  148. package/lib/dist-custom-elements/duet-menu-bar-menu-link.d.ts +11 -0
  149. package/lib/dist-custom-elements/duet-menu-bar-menu-link.js +75 -0
  150. package/lib/dist-custom-elements/duet-menu-bar-menu.d.ts +11 -0
  151. package/lib/dist-custom-elements/duet-menu-bar-menu.js +83 -0
  152. package/lib/dist-custom-elements/duet-menu-bar.d.ts +11 -0
  153. package/lib/dist-custom-elements/duet-menu-bar.js +99 -0
  154. package/lib/dist-custom-elements/duet-modal.js +7 -7
  155. package/lib/dist-custom-elements/duet-multiselect.d.ts +11 -0
  156. package/lib/dist-custom-elements/duet-multiselect.js +302 -0
  157. package/lib/dist-custom-elements/duet-nav.d.ts +11 -0
  158. package/lib/dist-custom-elements/duet-nav.js +132 -0
  159. package/lib/dist-custom-elements/duet-notification-drawer.js +4 -4
  160. package/lib/dist-custom-elements/duet-notification.js +2 -2
  161. package/lib/dist-custom-elements/duet-number-input.js +7 -7
  162. package/lib/dist-custom-elements/duet-pagination.js +7 -7
  163. package/lib/dist-custom-elements/duet-paragraph.js +1 -1
  164. package/lib/dist-custom-elements/duet-progress.js +1 -1
  165. package/lib/dist-custom-elements/duet-radio-group.js +6 -6
  166. package/lib/dist-custom-elements/duet-radio.js +1 -1
  167. package/lib/dist-custom-elements/duet-range-slider.js +3 -3
  168. package/lib/dist-custom-elements/duet-range-stepper.js +4 -4
  169. package/lib/dist-custom-elements/duet-scrollable.js +1 -1
  170. package/lib/dist-custom-elements/duet-section-layout.d.ts +11 -0
  171. package/lib/dist-custom-elements/duet-section-layout.js +59 -0
  172. package/lib/dist-custom-elements/duet-select.js +1 -1
  173. package/lib/dist-custom-elements/duet-spacer.js +1 -1
  174. package/lib/dist-custom-elements/duet-spinner.js +1 -1
  175. package/lib/dist-custom-elements/duet-step.js +4 -4
  176. package/lib/dist-custom-elements/duet-stepper.js +2 -2
  177. package/lib/dist-custom-elements/duet-tab-group.js +8 -8
  178. package/lib/dist-custom-elements/duet-tab.js +1 -1
  179. package/lib/dist-custom-elements/duet-table.js +1 -1
  180. package/lib/dist-custom-elements/duet-textarea.js +8 -8
  181. package/lib/dist-custom-elements/duet-toggle.js +2 -2
  182. package/lib/dist-custom-elements/duet-toolbar-dropdown-link.d.ts +11 -0
  183. package/lib/dist-custom-elements/duet-toolbar-dropdown-link.js +79 -0
  184. package/lib/dist-custom-elements/duet-toolbar-dropdown.d.ts +11 -0
  185. package/lib/dist-custom-elements/duet-toolbar-dropdown.js +103 -0
  186. package/lib/dist-custom-elements/duet-toolbar-link.d.ts +11 -0
  187. package/lib/dist-custom-elements/duet-toolbar-link.js +75 -0
  188. package/lib/dist-custom-elements/duet-toolbar.d.ts +11 -0
  189. package/lib/dist-custom-elements/duet-toolbar.js +54 -0
  190. package/lib/dist-custom-elements/duet-tooltip.js +1 -1
  191. package/lib/dist-custom-elements/duet-tray.js +4 -4
  192. package/lib/dist-custom-elements/duet-upload-aria-status.js +1 -1
  193. package/lib/dist-custom-elements/duet-upload.js +18 -18
  194. package/lib/dist-custom-elements/duet-visually-hidden.js +1 -1
  195. package/lib/dist-custom-elements/index.js +1 -1
  196. package/lib/dist-custom-elements/{p-3426a84c.js → p-10c5ec0a.js} +2 -2
  197. package/lib/dist-custom-elements/{p-f23c23e9.js → p-30639e6d.js} +3 -3
  198. package/lib/{esm/tokens.module-385c4cf8.js → dist-custom-elements/p-33e00967.js} +1 -1
  199. package/lib/dist-custom-elements/{p-2f73ed5f.js → p-3691df06.js} +2 -2
  200. package/lib/dist-custom-elements/{p-12a61b16.js → p-3b984f00.js} +2 -2
  201. package/lib/dist-custom-elements/{p-4e94138b.js → p-53aed47b.js} +5 -5
  202. package/lib/dist-custom-elements/{p-836021e7.js → p-59f83f34.js} +2 -2
  203. package/lib/dist-custom-elements/{p-f42b7c16.js → p-629a7253.js} +4 -4
  204. package/lib/dist-custom-elements/{p-01a47ed0.js → p-704cfe64.js} +2 -2
  205. package/lib/dist-custom-elements/{p-bf876e72.js → p-70bfd26c.js} +2 -2
  206. package/lib/dist-custom-elements/{p-a081f721.js → p-809d88d4.js} +3 -3
  207. package/lib/dist-custom-elements/{p-a56649ff.js → p-8f052709.js} +6 -6
  208. package/lib/dist-custom-elements/{p-565c7b5e.js → p-914d8914.js} +2 -2
  209. package/lib/dist-custom-elements/p-936569fb.js +165 -0
  210. package/lib/dist-custom-elements/{p-0a3b3fbb.js → p-936e320e.js} +5 -5
  211. package/lib/dist-custom-elements/{p-c8517782.js → p-9607e182.js} +5 -17
  212. package/lib/dist-custom-elements/{p-76a78894.js → p-990a00b7.js} +2 -2
  213. package/lib/dist-custom-elements/{p-86faf728.js → p-9ed347f9.js} +17 -2
  214. package/lib/dist-custom-elements/{p-d05492d6.js → p-a5395818.js} +2 -2
  215. package/lib/dist-custom-elements/{p-3185bbc5.js → p-a563c612.js} +1 -1
  216. package/lib/dist-custom-elements/{p-b7f5c755.js → p-b715c813.js} +1 -1
  217. package/lib/dist-custom-elements/{p-10a1a3da.js → p-b8a94f80.js} +1 -1
  218. package/lib/dist-custom-elements/{p-f07d95b9.js → p-bcc881ab.js} +1 -1
  219. package/lib/dist-custom-elements/{p-fbb39f58.js → p-bd7fbd74.js} +1 -1
  220. package/lib/dist-custom-elements/{p-dfb36895.js → p-c0cc3992.js} +1 -1
  221. package/lib/dist-custom-elements/{p-02305a1e.js → p-c4d8cad0.js} +1 -1
  222. package/lib/dist-custom-elements/{p-f20bce7d.js → p-c62a4b7f.js} +1 -1
  223. package/lib/dist-custom-elements/{p-2215e15e.js → p-c9848d70.js} +6 -6
  224. package/lib/dist-custom-elements/{p-59480ad8.js → p-cf5f722f.js} +1 -1
  225. package/lib/dist-custom-elements/{p-068d8815.js → p-d629bb70.js} +1 -1
  226. package/lib/dist-custom-elements/{p-fe39bfb6.js → p-dde5cc29.js} +9 -8
  227. package/lib/dist-custom-elements/{p-1940df2f.js → p-f25401f4.js} +1 -1
  228. package/lib/dist-custom-elements/{p-85e4dd88.js → p-fcbb448b.js} +2 -2
  229. package/lib/dist-custom-elements/{p-c36d9eb5.js → p-fd6ca85a.js} +2 -2
  230. package/lib/duet/duet.esm.js +1 -1
  231. package/lib/duet/duet.js +1 -1
  232. package/lib/duet/{p-d98eedc7.entry.js → p-008723a7.entry.js} +1 -1
  233. package/lib/duet/{p-8b0fef4c.system.entry.js → p-00875eb4.system.entry.js} +1 -1
  234. package/lib/duet/{p-c16f5680.system.entry.js → p-019dd9ee.system.entry.js} +1 -1
  235. package/lib/duet/p-02f96400.system.js +4 -0
  236. package/lib/duet/{p-108f093f.system.entry.js → p-038c0be8.system.entry.js} +1 -1
  237. package/lib/duet/{p-e873306b.system.entry.js → p-05a9b2ed.system.entry.js} +1 -1
  238. package/lib/duet/p-081ca907.entry.js +4 -0
  239. package/lib/duet/{p-794e74ca.system.entry.js → p-0b2968fd.system.entry.js} +1 -1
  240. package/lib/duet/{p-0ef9099d.system.entry.js → p-0b4d0648.system.entry.js} +1 -1
  241. package/lib/duet/{p-ed8d9d14.system.entry.js → p-0e26a1f7.system.entry.js} +1 -1
  242. package/lib/duet/{p-00228a70.entry.js → p-0e3add03.entry.js} +1 -1
  243. package/lib/duet/{p-dbdaec86.entry.js → p-14a34528.entry.js} +1 -1
  244. package/lib/duet/p-17063917.system.js +4 -0
  245. package/lib/duet/{p-bd85d575.entry.js → p-17d6a4ae.entry.js} +1 -1
  246. package/lib/duet/{p-0082ff0a.system.entry.js → p-1a46b65f.system.entry.js} +1 -1
  247. package/lib/duet/{p-6a49efbc.js → p-1c98eb39.js} +1 -1
  248. package/lib/duet/p-1cf2522d.js +4 -0
  249. package/lib/duet/{p-f8ae4f24.system.entry.js → p-1d398157.system.entry.js} +1 -1
  250. package/lib/duet/{p-1fd65b6a.system.entry.js → p-21c20799.system.entry.js} +1 -1
  251. package/lib/duet/{p-afdf9c1c.system.entry.js → p-221a80d7.system.entry.js} +1 -1
  252. package/lib/duet/{p-e7f779ed.entry.js → p-23c032d9.entry.js} +1 -1
  253. package/lib/duet/p-2436c0a5.system.entry.js +4 -0
  254. package/lib/duet/{p-8baa5bd1.system.entry.js → p-2801f614.system.entry.js} +1 -1
  255. package/lib/duet/{p-00030749.entry.js → p-28fd9fd5.entry.js} +1 -1
  256. package/lib/duet/p-2d2e2b4b.entry.js +4 -0
  257. package/lib/duet/p-2d84d85d.entry.js +4 -0
  258. package/lib/duet/p-2ed0b7b5.entry.js +4 -0
  259. package/lib/duet/p-2ed52fbc.entry.js +4 -0
  260. package/lib/duet/p-32fb7a16.entry.js +4 -0
  261. package/lib/duet/{p-59edf7bc.system.entry.js → p-3d1a4328.system.entry.js} +1 -1
  262. package/lib/duet/{p-16f67902.system.entry.js → p-3dbbac7c.system.entry.js} +1 -1
  263. package/lib/duet/{p-444b7187.system.entry.js → p-438f4e56.system.entry.js} +1 -1
  264. package/lib/duet/{p-3054a69d.entry.js → p-43f6c489.entry.js} +1 -1
  265. package/lib/duet/{p-69b0c916.system.entry.js → p-46c90395.system.entry.js} +1 -1
  266. package/lib/duet/p-4929228f.entry.js +4 -0
  267. package/lib/duet/p-5283c47e.system.entry.js +4 -0
  268. package/lib/duet/{p-b77057b8.entry.js → p-5360c82c.entry.js} +1 -1
  269. package/lib/duet/{p-8ff5cb03.entry.js → p-54fb6981.entry.js} +1 -1
  270. package/lib/duet/{p-7088d347.entry.js → p-54fdd242.entry.js} +1 -1
  271. package/lib/duet/{p-933a2bd0.system.entry.js → p-551d2285.system.entry.js} +1 -1
  272. package/lib/duet/{p-d74d81a1.system.entry.js → p-5596a05a.system.entry.js} +1 -1
  273. package/lib/duet/p-559f5bd9.system.entry.js +4 -0
  274. package/lib/duet/{p-3fd6ad80.entry.js → p-5716f7cf.entry.js} +1 -1
  275. package/lib/duet/p-5a1feacf.system.entry.js +4 -0
  276. package/lib/duet/p-5d46f619.system.js +4 -0
  277. package/lib/duet/{p-5116e9b7.system.entry.js → p-5da6bb5e.system.entry.js} +1 -1
  278. package/lib/duet/p-5effbb73.system.entry.js +4 -0
  279. package/lib/duet/p-63d9b5be.entry.js +4 -0
  280. package/lib/duet/p-66ecef22.entry.js +4 -0
  281. package/lib/duet/{p-d4bb0408.entry.js → p-67afeaa0.entry.js} +1 -1
  282. package/lib/duet/p-67caf318.system.entry.js +4 -0
  283. package/lib/duet/p-67dfbcb9.system.entry.js +4 -0
  284. package/lib/duet/{p-0433b19b.entry.js → p-6829edbb.entry.js} +1 -1
  285. package/lib/duet/{p-f92491e1.entry.js → p-69bd2658.entry.js} +1 -1
  286. package/lib/duet/{p-13cdbe65.entry.js → p-6f085d5d.entry.js} +1 -1
  287. package/lib/duet/{p-63b7a28e.system.entry.js → p-709b02d5.system.entry.js} +2 -2
  288. package/lib/duet/p-709d05a4.entry.js +4 -0
  289. package/lib/duet/p-73ee04df.system.entry.js +4 -0
  290. package/lib/duet/{p-9cb0def1.system.entry.js → p-754da360.system.entry.js} +1 -1
  291. package/lib/duet/{p-d674ef21.entry.js → p-768b2c68.entry.js} +1 -1
  292. package/lib/duet/{p-7e3d7a7e.system.entry.js → p-78aa261b.system.entry.js} +1 -1
  293. package/lib/duet/{p-9f51f625.entry.js → p-797c482e.entry.js} +1 -1
  294. package/lib/duet/p-79a9746e.js +4 -0
  295. package/lib/duet/{p-c76ec371.system.entry.js → p-7b1eb2c4.system.entry.js} +1 -1
  296. package/lib/duet/p-7d4fb3ca.system.entry.js +4 -0
  297. package/lib/duet/{p-faf74d63.entry.js → p-7ebf9213.entry.js} +1 -1
  298. package/lib/duet/{p-6be76f1d.entry.js → p-7ef938ce.entry.js} +1 -1
  299. package/lib/duet/p-806ef9ec.system.entry.js +4 -0
  300. package/lib/duet/p-8078b081.system.js +4 -0
  301. package/lib/duet/{p-6e648879.entry.js → p-808cae20.entry.js} +1 -1
  302. package/lib/duet/{p-f3e7fc61.system.entry.js → p-80c32801.system.entry.js} +1 -1
  303. package/lib/duet/{p-7ba68318.system.entry.js → p-828c0da8.system.entry.js} +1 -1
  304. package/lib/duet/p-82fb4b79.entry.js +4 -0
  305. package/lib/duet/p-8adfc149.entry.js +4 -0
  306. package/lib/duet/{p-f40277da.system.entry.js → p-8c647ccd.system.entry.js} +1 -1
  307. package/lib/duet/p-8e03dfcf.system.entry.js +4 -0
  308. package/lib/duet/p-8f037a84.system.entry.js +4 -0
  309. package/lib/duet/p-9052b6f5.js +4 -0
  310. package/lib/duet/{p-1219c251.system.js → p-945d09b1.system.js} +1 -1
  311. package/lib/duet/p-9511eeb0.system.entry.js +4 -0
  312. package/lib/duet/p-9b7206f2.entry.js +4 -0
  313. package/lib/duet/p-9eb819d4.entry.js +4 -0
  314. package/lib/duet/{p-607eb013.entry.js → p-9f180230.entry.js} +1 -1
  315. package/lib/duet/{p-b44ae985.system.entry.js → p-a308e5d8.system.entry.js} +1 -1
  316. package/lib/duet/{p-3dadf26a.system.entry.js → p-a896fc94.system.entry.js} +1 -1
  317. package/lib/duet/p-aa2d8671.system.entry.js +4 -0
  318. package/lib/duet/p-aae2908f.entry.js +4 -0
  319. package/lib/duet/{p-187a788e.entry.js → p-ac965a4c.entry.js} +1 -1
  320. package/lib/duet/p-b0cdcf07.system.entry.js +4 -0
  321. package/lib/duet/{p-6372465a.entry.js → p-b77a7f39.entry.js} +1 -1
  322. package/lib/duet/{p-ff4995cc.entry.js → p-bd764d77.entry.js} +1 -1
  323. package/lib/duet/p-be0fb72f.entry.js +4 -0
  324. package/lib/duet/{p-a3ca26e9.system.entry.js → p-c0522118.system.entry.js} +1 -1
  325. package/lib/duet/{p-39c02539.system.entry.js → p-c25bac2c.system.entry.js} +1 -1
  326. package/lib/duet/{p-889cf32a.system.entry.js → p-c3c89ceb.system.entry.js} +1 -1
  327. package/lib/duet/{p-dc163c6e.entry.js → p-c47d6d7f.entry.js} +1 -1
  328. package/lib/duet/p-c4d8cad0.js +4 -0
  329. package/lib/duet/p-c602c7d9.system.entry.js +4 -0
  330. package/lib/duet/{p-e52ea726.entry.js → p-c659f77e.entry.js} +1 -1
  331. package/lib/duet/p-cd81fe71.entry.js +4 -0
  332. package/lib/duet/{p-50551874.entry.js → p-ce2cb1a1.entry.js} +1 -1
  333. package/lib/duet/p-d2f68f18.system.entry.js +4 -0
  334. package/lib/duet/{p-b0bf6662.entry.js → p-d82fa629.entry.js} +1 -1
  335. package/lib/duet/{p-be4c1b3f.entry.js → p-d8e321c6.entry.js} +1 -1
  336. package/lib/duet/{p-b4ffca84.system.entry.js → p-dc56dcf6.system.entry.js} +1 -1
  337. package/lib/duet/p-dcf961de.entry.js +4 -0
  338. package/lib/duet/{p-70a1a9bf.system.js → p-e1dbc0ce.system.js} +1 -1
  339. package/lib/duet/{p-c4a44c55.system.entry.js → p-e2b3fd43.system.entry.js} +1 -1
  340. package/lib/duet/{p-14e9ccd4.entry.js → p-e4455346.entry.js} +1 -1
  341. package/lib/duet/p-e4af296b.entry.js +4 -0
  342. package/lib/duet/p-e658e8eb.system.entry.js +4 -0
  343. package/lib/duet/{p-661839a3.entry.js → p-e8fa961d.entry.js} +1 -1
  344. package/lib/duet/{p-46f86392.entry.js → p-ef10e614.entry.js} +1 -1
  345. package/lib/duet/{p-c1c11d71.system.entry.js → p-ef82e2ef.system.entry.js} +1 -1
  346. package/lib/duet/p-efaf5929.system.entry.js +4 -0
  347. package/lib/duet/{p-cacad773.system.entry.js → p-f07bfed6.system.entry.js} +1 -1
  348. package/lib/duet/p-f1fa5107.entry.js +4 -0
  349. package/lib/duet/{p-90e58b7f.entry.js → p-f26434c2.entry.js} +1 -1
  350. package/lib/duet/{p-24210b97.system.entry.js → p-f414ce87.system.entry.js} +1 -1
  351. package/lib/duet/{p-92c491d9.entry.js → p-f65d9557.entry.js} +1 -1
  352. package/lib/duet/{p-a44366ba.entry.js → p-f78e687a.entry.js} +1 -1
  353. package/lib/duet/{p-f020f7b9.entry.js → p-fbcaf752.entry.js} +1 -1
  354. package/lib/duet/{p-177abbdc.system.entry.js → p-fccbd519.system.entry.js} +1 -1
  355. package/lib/duet/{p-dcb5d509.system.entry.js → p-fe3b4f38.system.entry.js} +1 -1
  356. package/lib/duet/{p-9587a804.entry.js → p-ff6af701.entry.js} +1 -1
  357. package/lib/esm/duet-action-button.entry.js +3 -3
  358. package/lib/esm/duet-alert.entry.js +1 -1
  359. package/lib/esm/duet-badge.entry.js +1 -1
  360. package/lib/esm/duet-breadcrumb.entry.js +1 -1
  361. package/lib/esm/duet-breadcrumbs.entry.js +1 -1
  362. package/lib/esm/duet-button_2.entry.js +3 -3
  363. package/lib/esm/duet-caption_4.entry.js +3 -3
  364. package/lib/esm/duet-card.entry.js +10 -4
  365. package/lib/esm/duet-checkbox.entry.js +6 -2
  366. package/lib/esm/duet-choice_2.entry.js +2 -2
  367. package/lib/esm/duet-collapsible.entry.js +2 -2
  368. package/lib/esm/duet-combobox.entry.js +1 -1
  369. package/lib/esm/duet-cookie-consent.entry.js +1 -1
  370. package/lib/esm/duet-date-picker.entry.js +2 -2
  371. package/lib/esm/duet-divider_2.entry.js +1 -1
  372. package/lib/esm/duet-editable-table_3.entry.js +7 -18
  373. package/lib/esm/duet-empty-state.entry.js +1 -1
  374. package/lib/esm/duet-fieldset.entry.js +1 -1
  375. package/lib/esm/duet-footer.entry.js +1 -1
  376. package/lib/esm/duet-grid_2.entry.js +2 -2
  377. package/lib/esm/duet-header_2.entry.js +3 -3
  378. package/lib/esm/duet-hero.entry.js +1 -1
  379. package/lib/esm/duet-icon.entry.js +3 -3
  380. package/lib/esm/duet-input_2.entry.js +1 -1
  381. package/lib/esm/duet-layout.entry.js +8 -2
  382. package/lib/esm/duet-list_2.entry.js +1 -1
  383. package/lib/esm/duet-menu-bar-dropdown-link.entry.js +45 -0
  384. package/lib/esm/duet-menu-bar-dropdown.entry.js +61 -0
  385. package/lib/esm/duet-menu-bar-link.entry.js +42 -0
  386. package/lib/esm/duet-menu-bar-menu-dropdown-link.entry.js +54 -0
  387. package/lib/esm/duet-menu-bar-menu-dropdown.entry.js +61 -0
  388. package/lib/esm/duet-menu-bar-menu-link.entry.js +46 -0
  389. package/lib/esm/duet-menu-bar-menu.entry.js +61 -0
  390. package/lib/esm/duet-menu-bar.entry.js +72 -0
  391. package/lib/esm/duet-modal.entry.js +2 -2
  392. package/lib/esm/duet-multiselect.entry.js +223 -0
  393. package/lib/esm/duet-nav.entry.js +112 -0
  394. package/lib/esm/duet-notification_2.entry.js +1 -1
  395. package/lib/esm/duet-number-input.entry.js +1 -1
  396. package/lib/esm/duet-pagination_2.entry.js +1 -1
  397. package/lib/esm/duet-progress.entry.js +1 -1
  398. package/lib/esm/duet-radio_2.entry.js +1 -1
  399. package/lib/esm/duet-range-slider.entry.js +2 -2
  400. package/lib/esm/duet-scrollable_3.entry.js +1 -1
  401. package/lib/esm/duet-section-layout.entry.js +38 -0
  402. package/lib/esm/duet-select.entry.js +1 -1
  403. package/lib/esm/duet-step_2.entry.js +1 -1
  404. package/lib/esm/duet-textarea.entry.js +1 -1
  405. package/lib/esm/duet-toggle.entry.js +1 -1
  406. package/lib/esm/duet-toolbar-dropdown-link.entry.js +50 -0
  407. package/lib/esm/duet-toolbar-dropdown.entry.js +74 -0
  408. package/lib/esm/duet-toolbar-link.entry.js +46 -0
  409. package/lib/esm/duet-toolbar.entry.js +34 -0
  410. package/lib/esm/duet-tooltip.entry.js +1 -1
  411. package/lib/esm/duet-tray.entry.js +2 -2
  412. package/lib/esm/duet-upload-aria-status.entry.js +1 -1
  413. package/lib/esm/duet-visually-hidden.entry.js +1 -1
  414. package/lib/esm/duet.js +2 -2
  415. package/lib/esm/{focus-utils-d5499410.js → focus-utils-ac3a342e.js} +1 -1
  416. package/lib/esm/{index-26388161.js → index-5c6775f8.js} +1 -1
  417. package/lib/esm/loader.js +2 -2
  418. package/lib/esm/{token-utils-ebf797ab.js → token-utils-b531747a.js} +17 -2
  419. package/lib/esm/{tokens-b9d87fda.js → tokens-0963dc8b.js} +1 -1
  420. package/lib/{dist-custom-elements/p-266411cf.js → esm/tokens.module-d3321092.js} +1 -1
  421. package/lib/esm-es5/duet-action-button.entry.js +1 -1
  422. package/lib/esm-es5/duet-alert.entry.js +1 -1
  423. package/lib/esm-es5/duet-badge.entry.js +1 -1
  424. package/lib/esm-es5/duet-breadcrumb.entry.js +1 -1
  425. package/lib/esm-es5/duet-breadcrumbs.entry.js +1 -1
  426. package/lib/esm-es5/duet-button_2.entry.js +1 -1
  427. package/lib/esm-es5/duet-caption_4.entry.js +1 -1
  428. package/lib/esm-es5/duet-card.entry.js +2 -2
  429. package/lib/esm-es5/duet-checkbox.entry.js +2 -2
  430. package/lib/esm-es5/duet-choice_2.entry.js +2 -2
  431. package/lib/esm-es5/duet-collapsible.entry.js +1 -1
  432. package/lib/esm-es5/duet-combobox.entry.js +1 -1
  433. package/lib/esm-es5/duet-cookie-consent.entry.js +1 -1
  434. package/lib/esm-es5/duet-date-picker.entry.js +1 -1
  435. package/lib/esm-es5/duet-divider_2.entry.js +1 -1
  436. package/lib/esm-es5/duet-editable-table_3.entry.js +2 -2
  437. package/lib/esm-es5/duet-empty-state.entry.js +1 -1
  438. package/lib/esm-es5/duet-fieldset.entry.js +1 -1
  439. package/lib/esm-es5/duet-footer.entry.js +1 -1
  440. package/lib/esm-es5/duet-grid_2.entry.js +1 -1
  441. package/lib/esm-es5/duet-header_2.entry.js +1 -1
  442. package/lib/esm-es5/duet-hero.entry.js +1 -1
  443. package/lib/esm-es5/duet-icon.entry.js +1 -1
  444. package/lib/esm-es5/duet-input_2.entry.js +1 -1
  445. package/lib/esm-es5/duet-layout.entry.js +1 -1
  446. package/lib/esm-es5/duet-list_2.entry.js +1 -1
  447. package/lib/esm-es5/duet-menu-bar-dropdown-link.entry.js +4 -0
  448. package/lib/esm-es5/duet-menu-bar-dropdown.entry.js +4 -0
  449. package/lib/esm-es5/duet-menu-bar-link.entry.js +4 -0
  450. package/lib/esm-es5/duet-menu-bar-menu-dropdown-link.entry.js +4 -0
  451. package/lib/esm-es5/duet-menu-bar-menu-dropdown.entry.js +4 -0
  452. package/lib/esm-es5/duet-menu-bar-menu-link.entry.js +4 -0
  453. package/lib/esm-es5/duet-menu-bar-menu.entry.js +4 -0
  454. package/lib/esm-es5/duet-menu-bar.entry.js +4 -0
  455. package/lib/esm-es5/duet-modal.entry.js +1 -1
  456. package/lib/esm-es5/duet-multiselect.entry.js +4 -0
  457. package/lib/esm-es5/duet-nav.entry.js +4 -0
  458. package/lib/esm-es5/duet-notification_2.entry.js +1 -1
  459. package/lib/esm-es5/duet-number-input.entry.js +1 -1
  460. package/lib/esm-es5/duet-pagination_2.entry.js +1 -1
  461. package/lib/esm-es5/duet-progress.entry.js +1 -1
  462. package/lib/esm-es5/duet-radio_2.entry.js +1 -1
  463. package/lib/esm-es5/duet-range-slider.entry.js +1 -1
  464. package/lib/esm-es5/duet-scrollable_3.entry.js +1 -1
  465. package/lib/esm-es5/duet-section-layout.entry.js +4 -0
  466. package/lib/esm-es5/duet-select.entry.js +1 -1
  467. package/lib/esm-es5/duet-step_2.entry.js +1 -1
  468. package/lib/esm-es5/duet-textarea.entry.js +1 -1
  469. package/lib/esm-es5/duet-toggle.entry.js +1 -1
  470. package/lib/esm-es5/duet-toolbar-dropdown-link.entry.js +4 -0
  471. package/lib/esm-es5/duet-toolbar-dropdown.entry.js +4 -0
  472. package/lib/esm-es5/duet-toolbar-link.entry.js +4 -0
  473. package/lib/esm-es5/duet-toolbar.entry.js +4 -0
  474. package/lib/esm-es5/duet-tooltip.entry.js +1 -1
  475. package/lib/esm-es5/duet-tray.entry.js +1 -1
  476. package/lib/esm-es5/duet-upload-aria-status.entry.js +1 -1
  477. package/lib/esm-es5/duet-visually-hidden.entry.js +1 -1
  478. package/lib/esm-es5/duet.js +1 -1
  479. package/lib/esm-es5/{focus-utils-d5499410.js → focus-utils-ac3a342e.js} +1 -1
  480. package/lib/esm-es5/{index-26388161.js → index-5c6775f8.js} +1 -1
  481. package/lib/esm-es5/loader.js +1 -1
  482. package/lib/esm-es5/token-utils-b531747a.js +4 -0
  483. package/lib/esm-es5/{tokens-b9d87fda.js → tokens-0963dc8b.js} +1 -1
  484. package/lib/esm-es5/{tokens.module-385c4cf8.js → tokens.module-d3321092.js} +1 -1
  485. package/lib/types/components/duet-card/duet-card.d.ts +6 -0
  486. package/lib/types/components/duet-checkbox/duet-checkbox.d.ts +4 -0
  487. package/lib/types/components/duet-layout/duet-layout.d.ts +6 -0
  488. package/lib/types/components/duet-menu-bar/duet-menu-bar.d.ts +35 -0
  489. package/lib/types/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.d.ts +49 -0
  490. package/lib/types/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.d.ts +32 -0
  491. package/lib/types/components/duet-menu-bar-link/duet-menu-bar-link.d.ts +32 -0
  492. package/lib/types/components/duet-menu-bar-menu/duet-menu-bar-menu.d.ts +49 -0
  493. package/lib/types/components/duet-menu-bar-menu-dropdown/duet-menu-bar-menu-dropdown.d.ts +49 -0
  494. package/lib/types/components/duet-menu-bar-menu-dropdown-link/duet-menu-bar-menu-dropdown-link.d.ts +40 -0
  495. package/lib/types/components/duet-menu-bar-menu-link/duet-menu-bar-menu-link.d.ts +36 -0
  496. package/lib/types/components/duet-multiselect/duet-multiselect.d.ts +137 -0
  497. package/lib/types/components/duet-nav/duet-nav.d.ts +42 -0
  498. package/lib/types/components/duet-section-layout/duet-section-layout.d.ts +21 -0
  499. package/lib/types/components/duet-table/duet-table.d.ts +1 -12
  500. package/lib/types/components/duet-toolbar/duet-toolbar.d.ts +28 -0
  501. package/lib/types/components/duet-toolbar-dropdown/duet-toolbar-dropdown.d.ts +53 -0
  502. package/lib/types/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.d.ts +36 -0
  503. package/lib/types/components/duet-toolbar-link/duet-toolbar-link.d.ts +36 -0
  504. package/lib/types/components.d.ts +717 -0
  505. package/lib/types/utils/token-utils.d.ts +12 -0
  506. package/package.json +8 -7
  507. package/lib/duet/p-02305a1e.js +0 -4
  508. package/lib/duet/p-159ce776.js +0 -4
  509. package/lib/duet/p-1d7bd203.system.entry.js +0 -4
  510. package/lib/duet/p-1fc60a60.system.js +0 -4
  511. package/lib/duet/p-32f7178a.system.js +0 -4
  512. package/lib/duet/p-50081b36.entry.js +0 -4
  513. package/lib/duet/p-532e9db7.js +0 -4
  514. package/lib/duet/p-588be556.js +0 -4
  515. package/lib/duet/p-58eeed4f.system.entry.js +0 -4
  516. package/lib/duet/p-5d160b76.system.entry.js +0 -4
  517. package/lib/duet/p-6caf3423.entry.js +0 -4
  518. package/lib/duet/p-9f37c7e3.entry.js +0 -4
  519. package/lib/duet/p-c1d755c9.system.entry.js +0 -4
  520. package/lib/duet/p-d209191d.system.js +0 -4
  521. package/lib/duet/p-d267c3a2.entry.js +0 -4
  522. package/lib/duet/p-e30dc26c.entry.js +0 -4
  523. package/lib/duet/p-e841deb6.system.js +0 -4
  524. package/lib/esm-es5/token-utils-ebf797ab.js +0 -4
@@ -0,0 +1,46 @@
1
+ /*!
2
+ * Built with Duet Design System
3
+ */
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
+ import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
+
7
+ const duetMenuBarMenuLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}.duet-menu-bar-menu-link{display:flex;flex-direction:column;gap:5px;align-items:center;justify-content:center;height:100%;padding:0 1.5rem;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:600;line-height:1.25;color:#00294d;text-align:center;text-decoration:none}.duet-menu-bar-menu-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:#171c3a}.duet-menu-bar-menu-link:hover{color:#004d80;background:#e6f2f8}.duet-menu-bar-menu-link:hover.duet-theme-turva{color:#940925;background:#e4e4e6}.duet-menu-bar-menu-link.active{color:#0077b3}.duet-menu-bar-menu-link.active.duet-theme-turva{color:#c60c30}.duet-menu-bar-menu-link.active.active:hover{color:#004d80}.duet-menu-bar-menu-link.active.active:hover.duet-theme-turva{color:#940925}";
8
+
9
+ const DuetMenuBarMenuLink = class {
10
+ constructor(hostRef) {
11
+ registerInstance(this, hostRef);
12
+ /**
13
+ * Theme.
14
+ */
15
+ this.theme = "";
16
+ /**
17
+ * Active
18
+ */
19
+ this.active = false;
20
+ /**
21
+ * Href
22
+ */
23
+ this.href = "#";
24
+ /**
25
+ * Icon
26
+ */
27
+ this.icon = undefined;
28
+ }
29
+ /**
30
+ * Component lifecycle events.
31
+ */
32
+ componentWillLoad() {
33
+ inheritGlobalTheme(this);
34
+ }
35
+ /**
36
+ * render() function
37
+ * Always the last one in the class.
38
+ */
39
+ render() {
40
+ return (h(Host, null, h("a", { class: { "duet-menu-bar-menu-link": true, "duet-theme-turva": this.theme === "turva", active: this.active }, href: this.href, role: "menuitem" }, this.icon && h("duet-icon", { name: this.icon, size: "x-small", margin: "none" }), h("slot", null))));
41
+ }
42
+ get element() { return getElement(this); }
43
+ };
44
+ DuetMenuBarMenuLink.style = duetMenuBarMenuLinkCss;
45
+
46
+ export { DuetMenuBarMenuLink as duet_menu_bar_menu_link };
@@ -0,0 +1,61 @@
1
+ /*!
2
+ * Built with Duet Design System
3
+ */
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
+ import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
+
7
+ const duetMenuBarMenuCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}.duet-menu-bar-menu{height:100%}.duet-menu-bar-menu button{position:relative;display:flex;gap:8px;align-items:center;justify-content:center;height:100%;min-height:5rem;padding:0 12px;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.25;color:#00294d;text-align:center;text-decoration:none;cursor:pointer}@media (min-width: 62em){.duet-menu-bar-menu button{padding:0 20px}}@media (min-width: 64.0625em){.duet-menu-bar-menu button{padding:0 28px}}.duet-menu-bar-menu button:hover{color:#0077b3}.duet-menu-bar-menu button.active{color:#0077b3}.duet-theme-turva .duet-menu-bar-menu button.active{color:#c60c30}.duet-menu-bar-menu button.active::after{position:absolute;top:auto;bottom:2px;left:0;display:block;width:100%;height:2px;content:\"\";background:#0077b3;transition:300ms ease;transform:translateY(2px)}.duet-theme-turva .duet-menu-bar-menu button.active::after{background:#c60c30}.duet-menu-bar-menu .items{position:absolute;left:0;display:flex;align-items:center;justify-content:center;width:100%;height:4rem;color:#00294d;background:#f3f9fc;border-bottom:1px solid #cde5f1;box-shadow:0 3px 6px 0 rgba(0, 41, 77, 0.1) inset}.duet-menu-bar-menu .items.hidden{display:none}.duet-menu-bar-menu.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:#171c3a}.duet-menu-bar-menu.duet-theme-turva button:hover{color:#c60c30}.duet-menu-bar-menu.duet-theme-turva button.active{color:#c60c30}.duet-menu-bar-menu.duet-theme-turva button.active::after{background:#c60c30}.duet-menu-bar-menu.duet-theme-turva .items{background:#f5f5f7}";
8
+
9
+ const DuetMenuBarMenu = class {
10
+ constructor(hostRef) {
11
+ registerInstance(this, hostRef);
12
+ this.duetMenuBarMenuEvent = createEvent(this, "duetMenuBarMenuEvent", 7);
13
+ /**
14
+ * Theme.
15
+ */
16
+ this.theme = "";
17
+ /**
18
+ * Active
19
+ */
20
+ this.active = false;
21
+ /**
22
+ * Open
23
+ */
24
+ this.open = false;
25
+ this.toggleMenu = (e) => {
26
+ const toggle = !this.open;
27
+ this.open = toggle;
28
+ this.duetMenuBarMenuEvent.emit({
29
+ originalEvent: e,
30
+ data: { element: this.element, open: this.open },
31
+ component: "duet-menu-bar-menu",
32
+ });
33
+ };
34
+ this.onClick = (e) => {
35
+ this.toggleMenu(e);
36
+ e.stopImmediatePropagation();
37
+ };
38
+ }
39
+ /**
40
+ * Component lifecycle events.
41
+ */
42
+ componentWillLoad() {
43
+ inheritGlobalTheme(this);
44
+ }
45
+ /**
46
+ * render() function
47
+ * Always the last one in the class.
48
+ */
49
+ render() {
50
+ return (h(Host, null, h("div", { class: { "duet-menu-bar-menu": true, "duet-theme-turva": this.theme === "turva", active: this.active } }, h("button", { "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
51
+ active: this.active || this.open,
52
+ }, onClick: this.onClick }, h("slot", { name: "label" })), h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
53
+ items: true,
54
+ hidden: !this.open,
55
+ } }, h("slot", null)))));
56
+ }
57
+ get element() { return getElement(this); }
58
+ };
59
+ DuetMenuBarMenu.style = duetMenuBarMenuCss;
60
+
61
+ export { DuetMenuBarMenu as duet_menu_bar_menu };
@@ -0,0 +1,72 @@
1
+ /*!
2
+ * Built with Duet Design System
3
+ */
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
+ import { m as media_query_large, c as media_query_xx_large } from './tokens-0963dc8b.js';
6
+ import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
7
+
8
+ const duetMenuBarCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%}.duet-menu-bar{position:relative;display:flex;align-items:center;justify-content:space-between;width:100%;height:5rem;padding:0 28px;background:white;border-top:1px solid #e1e3e6;box-shadow:0 3px 6px 0 rgba(0, 41, 77, 0.1)}.duet-menu-bar>*{display:flex;align-items:center;justify-content:center;height:100%}.duet-menu-bar>:first-child{flex-basis:0;flex-grow:1;justify-content:flex-start}.duet-menu-bar>:last-child{flex-basis:0;flex-grow:1;justify-content:flex-end}.duet-menu-bar ::slotted(*){display:flex;align-items:center;justify-content:center;height:100%}.duet-menu-bar.duet-theme-turva{background:white}";
9
+
10
+ const DuetMenuBar = class {
11
+ constructor(hostRef) {
12
+ registerInstance(this, hostRef);
13
+ /**
14
+ * Own Properties.
15
+ */
16
+ this.mql = [
17
+ window.matchMedia(media_query_large.replace(/'/g, "")),
18
+ window.matchMedia(media_query_xx_large.replace(/'/g, "")),
19
+ ];
20
+ this.boundMqlFunctions = [];
21
+ this.logoSize = "large";
22
+ /**
23
+ * Theme.
24
+ */
25
+ this.theme = "";
26
+ this.changeLogoSize = () => {
27
+ if (this.mql[1].matches) {
28
+ this.logoSize = "large";
29
+ }
30
+ else {
31
+ this.logoSize = "medium";
32
+ }
33
+ };
34
+ }
35
+ /**
36
+ * Component lifecycle events.
37
+ */
38
+ componentWillLoad() {
39
+ inheritGlobalTheme(this);
40
+ }
41
+ connectedCallback() {
42
+ this.changeLogoSize();
43
+ for (let i = 0; i < this.mql.length; i++) {
44
+ // addEventListener is not available in Stencil hydrate
45
+ if (this.mql[i].addEventListener) {
46
+ const bound = this.changeLogoSize.bind(this);
47
+ this.mql[i].addEventListener("change", bound);
48
+ this.boundMqlFunctions[i] = bound;
49
+ }
50
+ }
51
+ }
52
+ disconnectedCallback() {
53
+ for (let i = 0; i < this.mql.length; i++) {
54
+ // removeEventListener is not available in Stencil hydrate
55
+ if (this.mql[i].removeEventListener) {
56
+ this.mql[i].removeEventListener("change", this.boundMqlFunctions[i]);
57
+ }
58
+ }
59
+ this.boundMqlFunctions = [];
60
+ }
61
+ /**
62
+ * render() function
63
+ * Always the last one in the class.
64
+ */
65
+ render() {
66
+ return (h(Host, null, h("div", { class: { "duet-menu-bar": true, "duet-theme-turva": this.theme === "turva" }, role: "menubar" }, h("duet-logo", { size: this.logoSize, margin: "none" }), h("slot", { name: "center" }), h("slot", { name: "right" }))));
67
+ }
68
+ get element() { return getElement(this); }
69
+ };
70
+ DuetMenuBar.style = duetMenuBarCss;
71
+
72
+ export { DuetMenuBar as duet_menu_bar };
@@ -1,11 +1,11 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, c as createEvent, h, g as getElement } from './index-26388161.js';
4
+ import { r as registerInstance, c as createEvent, h, g as getElement } from './index-5c6775f8.js';
5
5
  import { d as disableBodyScroll, e as enableBodyScroll } from './bodyScrollLock.es6-61b5e9a4.js';
6
6
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
7
7
  import { c as createID } from './create-id-981107da.js';
8
- import { f as focusElement, F as FocusGuard } from './focus-utils-d5499410.js';
8
+ import { f as focusElement, F as FocusGuard } from './focus-utils-ac3a342e.js';
9
9
  import { f as isEscapeKey } from './keyboard-utils-88ea1007.js';
10
10
  import { a as getLanguage, g as getLocaleString } from './language-utils-bf701d37.js';
11
11
  import './string-utils-5954f458.js';
@@ -0,0 +1,223 @@
1
+ /*!
2
+ * Built with Duet Design System
3
+ */
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
+ import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
+ import { c as createID } from './create-id-981107da.js';
7
+ import { f as isEscapeKey, o as isTabKey, n as isEnterKey, d as isArrowLeftKey, b as isArrowUpKey, a as isArrowRightKey, c as isArrowDownKey } from './keyboard-utils-88ea1007.js';
8
+ import { g as getLocaleString } from './language-utils-bf701d37.js';
9
+ import { p as parsePossibleJSON } from './string-utils-5954f458.js';
10
+
11
+ const duetMultiselectCss = "*,*::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;margin-right:16px !important;margin-bottom:12px !important;display:inline-flex;width:100%;max-width:100%;vertical-align:bottom}:host:last-child,:host:last-of-type{margin-right:0 !important}@media (min-width: 36em){:host{width:calc(50% - 16px - 3px)}:host.duet-expand{width:100% !important}}:host(.duet-m-0){margin:0 !important}.duet-multiselect-tooltip{position:absolute;top:12px;right:0}@media (min-width: 48em){.duet-multiselect-tooltip{position:relative;top:4px;right:auto}}.duet-multiselect-placeholder{position:absolute;top:-9px;left:9px;z-index:200;display:block;width:auto;max-width:60%;padding:0 0.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:white}.duet-multiselect-container{position:relative;width:100%}.duet-multiselect-wrapper{position:relative;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\";font-size:1rem;font-weight:400;line-height:1.25}.duet-theme-turva .duet-multiselect-wrapper{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\"}.duet-multiselect{display:flex;gap:12px;align-items:center;justify-content:flex-start;width:100%;min-width:8rem;padding:12px 14px !important;overflow:hidden;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:400;font-variant-numeric:tabular-nums;line-height:1.5;color:#00294d;text-align:left;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;background:white;border:1px solid #909599;border-radius:4px;transition:150ms ease}.duet-multiselect:hover{border-color:#909599;box-shadow:0 0 0 1px #909599}.duet-theme-turva .duet-multiselect:hover{border-color:#747475;box-shadow:0 0 0 1px #747475}.has-error .duet-multiselect:hover{box-shadow:0 0 0 1px #de2362}.duet-theme-turva.has-error .duet-multiselect:hover{box-shadow:0 0 0 1px #e02a0d}.duet-multiselect:focus,.duet-multiselect.duet-multiselect-active{border-color:#0077b3;outline:0;box-shadow:0 0 0 1px #0077b3;transition:none}.duet-theme-turva .duet-multiselect:focus,.duet-theme-turva .duet-multiselect.duet-multiselect-active{border-color:#171c3a;box-shadow:0 0 0 1px #171c3a}.has-error .duet-multiselect:focus,.has-error .duet-multiselect.duet-multiselect-active{box-shadow:0 0 0 1px #de2362}.duet-theme-turva.has-error .duet-multiselect:focus,.duet-theme-turva.has-error .duet-multiselect.duet-multiselect-active{box-shadow:0 0 0 1px #e02a0d}.duet-multiselect[disabled]{color:#00294d !important;cursor:default !important;background:#f5f8fa !important;border-color:#f5f8fa !important;box-shadow:none !important;opacity:1 !important;-webkit-text-fill-color:#00294d !important}.duet-theme-turva .duet-multiselect[disabled]{color:#171c3a !important;background:#f5f5f7 !important;border-color:#f5f5f7 !important;-webkit-text-fill-color:#171c3a !important}.duet-multiselect>:first-child{flex:1}.duet-multiselect .duet-multiselect-badge{position:absolute;right:3rem}.has-error .duet-multiselect{border-color:#de2362 !important}.has-error .duet-multiselect .duet-multiselect-icon{color:#de2362 !important}.duet-theme-turva.has-error .duet-multiselect{border-color:#e02a0d !important}.duet-theme-turva.has-error .duet-multiselect .duet-multiselect-icon{color:#e02a0d !important}.duet-theme-turva .duet-multiselect{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:#171c3a;border-color:#747475}.duet-multiselect svg{width:20px;height:20px;color:#00294d;pointer-events:none}.duet-theme-turva .duet-multiselect svg{color:#171c3a}.duet-multiselect svg.duet-multiselect-icon--rotate{transform:rotate(180deg)}.duet-multiselect-checkboxes{position:absolute;z-index:700;width:100%;padding:16px;margin:8px 0 0;visibility:hidden;background:white;border:1px solid #e1e3e6;border-radius:4px;box-shadow:0 4px 10px 0 rgba(0, 41, 77, 0.15);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-theme-turva .duet-multiselect-checkboxes{background:white;border-color:#e4e4e6;box-shadow:0 4px 10px 0 rgba(23, 28, 58, 0.15)}.duet-multiselect-checkboxes.duet-multiselect-checkboxes-active{visibility:visible;opacity:1;transition-property:transform, opacity;transform:scale(1.0001) translateZ(0) translateY(0)}.duet-multiselect-help{display:block;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:400;line-height:1.25;color:#657787;border-radius:4px}.duet-multiselect-help span{display:block;margin-top:8px}.duet-theme-turva .duet-multiselect-help{color:#747475}.has-error .duet-multiselect-help{color:#de2362}.duet-theme-turva.has-error .duet-multiselect-help{color:#e02a0d}.duet-label-hidden duet-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}";
12
+
13
+ function toggleInArray(arr, item) {
14
+ return arr.includes(item) ? arr.filter(i => i !== item) : [...arr, item];
15
+ }
16
+ const DuetMultiselect = class {
17
+ constructor(hostRef) {
18
+ registerInstance(this, hostRef);
19
+ this.duetChange = createEvent(this, "duetChange", 3);
20
+ this.duetFocus = createEvent(this, "duetFocus", 7);
21
+ this.duetBlur = createEvent(this, "duetBlur", 7);
22
+ /**
23
+ * Own Properties
24
+ */
25
+ this.errorId = createID("DuetError");
26
+ this.labelId = createID("DuetLabel");
27
+ this.topCaptionId = createID("DuetCaptionTop");
28
+ this.selectedLangObject = {
29
+ en: "selected",
30
+ fi: "valittu",
31
+ sv: "vald",
32
+ };
33
+ /**
34
+ * State() variables
35
+ * Inlined decorator, alphabetical order.
36
+ */
37
+ this.processedItems = [];
38
+ this.checkboxesVisible = false;
39
+ this.activeDescendant = "";
40
+ /**
41
+ * Controls the margin of the component.
42
+ */
43
+ this.margin = "auto";
44
+ /**
45
+ * Display the select in error state along with an error message.
46
+ */
47
+ this.error = "";
48
+ /**
49
+ * Expands the input to fill 100% of the container width.
50
+ */
51
+ this.expand = false;
52
+ /**
53
+ * Value of multiselect
54
+ */
55
+ this.value = [];
56
+ /**
57
+ * Theme of the select.
58
+ */
59
+ this.theme = "";
60
+ /**
61
+ * Visually hide the label, but still show it to screen readers.
62
+ */
63
+ this.labelHidden = false;
64
+ /**
65
+ * Adds a unique identifier for the select.
66
+ */
67
+ this.identifier = createID("DuetMultiselect");
68
+ /**
69
+ * Hint text to display.
70
+ */
71
+ this.placeholder = "";
72
+ /**
73
+ * Makes the select component disabled. This prevents users from being able
74
+ * to interact with the select, and conveys its inactive state to assistive
75
+ * technologies.
76
+ */
77
+ this.disabled = false;
78
+ /**
79
+ * Label for the select.
80
+ */
81
+ this.label = "label";
82
+ /**
83
+ * Tooltip to display next to the label of the input.
84
+ */
85
+ this.tooltip = "";
86
+ /**
87
+ * With direction setting you can force the tooltip to always open towards left
88
+ * or right instead of automatically determining the direction.
89
+ */
90
+ this.tooltipDirection = "auto";
91
+ /**
92
+ * Component event handling.
93
+ */
94
+ this.onChange = (ev) => {
95
+ this.duetChange.emit({
96
+ originalEvent: ev,
97
+ value: this.value,
98
+ component: "duet-multiselect",
99
+ });
100
+ };
101
+ this.onBlur = (ev) => {
102
+ this.duetBlur.emit({
103
+ originalEvent: ev,
104
+ value: this.value,
105
+ component: "duet-multiselect",
106
+ });
107
+ };
108
+ this.onFocus = (ev) => {
109
+ this.duetFocus.emit({
110
+ originalEvent: ev,
111
+ value: this.value,
112
+ component: "duet-multiselect",
113
+ });
114
+ };
115
+ this.onMultiselectKeyDown = (e) => {
116
+ if (isEscapeKey(e) || isTabKey(e)) {
117
+ if (this.checkboxesVisible) {
118
+ this.checkboxesVisible = false;
119
+ this.multiselectElement.focus();
120
+ e.preventDefault();
121
+ }
122
+ }
123
+ };
124
+ this.onMultiselectInputKeyDown = (e) => {
125
+ if (isEnterKey(e)) {
126
+ e.preventDefault();
127
+ this.toggleCheckboxes();
128
+ setTimeout(() => {
129
+ if (this.checkboxesVisible) {
130
+ const firstOption = this.element.shadowRoot.querySelector(`#${this.getOptionIdentifier(0)}`);
131
+ if (firstOption) {
132
+ firstOption.focus();
133
+ }
134
+ }
135
+ }, 200);
136
+ }
137
+ };
138
+ this.onCheckboxKeyDown = (e, key) => {
139
+ let nextOption;
140
+ if (isArrowLeftKey(e) || isArrowUpKey(e)) {
141
+ nextOption = this.element.shadowRoot.querySelector(`#${this.getOptionIdentifier(key - 1)}`);
142
+ }
143
+ else if (isArrowRightKey(e) || isArrowDownKey(e)) {
144
+ nextOption = this.element.shadowRoot.querySelector(`#${this.getOptionIdentifier(key + 1)}`);
145
+ }
146
+ if (nextOption) {
147
+ nextOption.focus();
148
+ e.preventDefault();
149
+ this.activeDescendant = nextOption.id;
150
+ }
151
+ };
152
+ this.toggleCheckboxes = () => {
153
+ this.checkboxesVisible = !this.checkboxesVisible;
154
+ };
155
+ this.toggleCheckbox = (e, item) => {
156
+ this.value = toggleInArray(this.value, item);
157
+ this.onChange(e);
158
+ };
159
+ this.getOptionIdentifier = (key) => {
160
+ return `${this.identifier}-option-${key}`;
161
+ };
162
+ }
163
+ handleFocus(e) {
164
+ const isClickOutside = e.composedPath().every(node => node !== this.element);
165
+ if (isClickOutside) {
166
+ this.checkboxesVisible = false;
167
+ }
168
+ }
169
+ /**
170
+ * Component lifecycle events.
171
+ */
172
+ componentWillLoad() {
173
+ inheritGlobalTheme(this);
174
+ this.isCaptionVisible = !!this.caption;
175
+ this.refresh();
176
+ }
177
+ /**
178
+ * Sets focus on the specified `duet-multiselect`. Use this method instead of the global
179
+ * `multiselect.focus()`.
180
+ */
181
+ async setFocus(options) {
182
+ if (this.multiselectElement) {
183
+ this.multiselectElement.focus(options);
184
+ }
185
+ }
186
+ /**
187
+ * Local methods.
188
+ */
189
+ async refresh() {
190
+ this.processedItems = parsePossibleJSON(this.items);
191
+ }
192
+ /**
193
+ * render() function
194
+ * Always the last one in the class.
195
+ */
196
+ render() {
197
+ const selectedTranslation = getLocaleString(this.selectedLangObject);
198
+ return (h(Host, { class: {
199
+ "duet-m-0": this.margin === "none",
200
+ "duet-expand": this.expand,
201
+ } }, h("div", { class: {
202
+ "duet-multiselect-container": true,
203
+ "duet-label-hidden": this.labelHidden,
204
+ "duet-theme-turva": this.theme === "turva",
205
+ "duet-input-top-caption-shown": this.isCaptionVisible,
206
+ "has-error": !!this.error,
207
+ }, onKeyDown: (e) => this.onMultiselectKeyDown(e) }, h("duet-label", { theme: this.theme === "turva" ? "turva" : "default", class: { "duet-has-tooltip": !!this.tooltip }, id: this.labelId, for: this.identifier }, this.label), this.tooltip && (h("duet-tooltip", { class: "duet-multiselect-tooltip", direction: this.tooltipDirection, accessibleInputLabel: this.label }, this.tooltip)), this.caption && (h("duet-caption", { id: this.topCaptionId, size: "medium" }, this.caption)), h("div", { class: "duet-multiselect-wrapper" }, h("button", { id: this.identifier, ref: el => (this.multiselectElement = el), class: { "duet-multiselect": true, "duet-multiselect-active": this.checkboxesVisible }, tabindex: "0", onClick: () => this.toggleCheckboxes(), onFocus: e => this.onFocus(e), onBlur: e => this.onBlur(e), role: "combobox", "aria-expanded": this.checkboxesVisible ? "true" : "false", "aria-haspopup": "listbox", "aria-labelledby": `${this.labelId} ${this.errorId}`, "aria-owns": `${this.identifier}-checkboxes`, onKeyDown: (e) => this.onMultiselectInputKeyDown(e), disabled: this.disabled }, h("span", { role: "textbox", "aria-readonly": "true", "aria-multiline": "false", "aria-autocomplete": "none", "aria-controls": `${this.identifier}-checkboxes` }, this.placeholder), this.value && this.value.length > 0 && (h("duet-badge", { class: "duet-multiselect-badge", margin: "none", theme: this.theme }, this.value.length, " ", selectedTranslation, h("duet-visually-hidden", null, ", ", this.value.map(item => item.label).join(", ")))), h("svg", { role: "img", class: { "duet-multiselect-icon": true, "duet-multiselect-icon--rotate": this.checkboxesVisible }, fill: "currentColor", viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg" }, h("path", { d: "m12 18.999c-.4 0-.776-.156-1.059-.438l-10.721-10.72c-.142-.142-.22-.33-.22-.531 0-.2.078-.389.22-.53.142-.142.33-.22.53-.22s.389.078.53.22l10.72 10.719 10.72-10.719c.142-.142.33-.22.53-.22s.389.078.53.22c.142.142.22.33.22.53s-.078.389-.22.53l-10.72 10.72c-.282.283-.659.439-1.06.439z" }))), h("div", { id: `${this.identifier}-checkboxes`, role: "listbox", class: {
208
+ "duet-multiselect-checkboxes": true,
209
+ "duet-multiselect-checkboxes-active": this.checkboxesVisible,
210
+ }, "aria-activedescendant": this.activeDescendant, "aria-multiselectable": "true" }, this.processedItems &&
211
+ this.processedItems.map((item, key) => {
212
+ var _a, _b;
213
+ return (h("duet-checkbox", { identifier: this.getOptionIdentifier(key), role: "option", label: item.label, value: item.value, key: item.value, checked: (_a = this.value) === null || _a === void 0 ? void 0 : _a.includes(item), "accessible-selected": ((_b = this.value) === null || _b === void 0 ? void 0 : _b.includes(item)) ? "true" : undefined, disabled: !this.checkboxesVisible || item.disabled, onDuetChange: e => this.toggleCheckbox(e, item), onKeyDown: (e) => this.onCheckboxKeyDown(e, key), theme: this.theme }));
214
+ }))), h("span", { class: "duet-multiselect-help", id: this.errorId, "aria-live": "assertive", "aria-relevant": "additions removals" }, this.error && h("span", null, this.error)))));
215
+ }
216
+ get element() { return getElement(this); }
217
+ static get watchers() { return {
218
+ "items": ["refresh"]
219
+ }; }
220
+ };
221
+ DuetMultiselect.style = duetMultiselectCss;
222
+
223
+ export { DuetMultiselect as duet_multiselect };
@@ -0,0 +1,112 @@
1
+ /*!
2
+ * Built with Duet Design System
3
+ */
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
+ import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
+
7
+ const duetNavCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%}";
8
+
9
+ const DuetMenuBar = class {
10
+ constructor(hostRef) {
11
+ registerInstance(this, hostRef);
12
+ /**
13
+ * Theme.
14
+ */
15
+ this.theme = "";
16
+ this.getToolbarDropdowns = () => this.element.querySelectorAll("duet-toolbar-dropdown");
17
+ this.getMenuBarMenus = () => this.element.querySelectorAll("duet-menu-bar-menu");
18
+ this.getActiveMenu = () => this.element.querySelector("duet-menu-bar-menu[active]");
19
+ this.getActiveTool = () => this.element.querySelector("duet-toolbar-link[active],duet-toolbar-dropdown[active]");
20
+ this.getMenuBarMenuDropdowns = () => this.element.querySelectorAll("duet-menu-bar-menu-dropdown");
21
+ this.getMenuBarDropdowns = () => this.element.querySelectorAll("duet-menu-bar-dropdown");
22
+ this.toggleActiveMenu = (active) => {
23
+ const activeMenu = this.getActiveMenu();
24
+ if (activeMenu) {
25
+ activeMenu.setAttribute("active", active ? "true" : "false");
26
+ }
27
+ };
28
+ this.toggleActiveTool = (active) => {
29
+ const activeTool = this.getActiveTool();
30
+ if (activeTool) {
31
+ activeTool.setAttribute("active", active ? "true" : "false");
32
+ }
33
+ };
34
+ this.close = (elementGetter, elementToKeepOpen) => {
35
+ elementGetter().forEach(element => {
36
+ if (elementToKeepOpen) {
37
+ if (element !== elementToKeepOpen) {
38
+ element.setAttribute("open", "false");
39
+ }
40
+ }
41
+ else {
42
+ element.setAttribute("open", "false");
43
+ }
44
+ });
45
+ };
46
+ }
47
+ /**
48
+ * Component lifecycle events.
49
+ */
50
+ componentWillLoad() {
51
+ inheritGlobalTheme(this);
52
+ }
53
+ handleToolbarDropdownEvent(e) {
54
+ if (e.detail.data.element) {
55
+ if (e.detail.data.open) {
56
+ this.close(this.getMenuBarMenus);
57
+ this.close(this.getToolbarDropdowns, e.detail.data.element);
58
+ this.close(this.getMenuBarMenuDropdowns);
59
+ this.close(this.getMenuBarDropdowns);
60
+ }
61
+ this.toggleActiveMenu(true);
62
+ this.toggleActiveTool(!e.detail.data.open);
63
+ }
64
+ }
65
+ handleMenuEvent(e) {
66
+ if (e.detail.data.element) {
67
+ if (e.detail.data.open) {
68
+ this.close(this.getMenuBarMenus, e.detail.data.element);
69
+ this.close(this.getToolbarDropdowns);
70
+ this.close(this.getMenuBarMenuDropdowns);
71
+ this.close(this.getMenuBarDropdowns);
72
+ }
73
+ this.toggleActiveMenu(!e.detail.data.open);
74
+ this.toggleActiveTool(true);
75
+ }
76
+ }
77
+ handleMenuDropdownEvent(e) {
78
+ if (e.detail.data.element && e.detail.data.open) {
79
+ this.close(this.getMenuBarMenuDropdowns, e.detail.data.element);
80
+ this.close(this.getMenuBarDropdowns);
81
+ }
82
+ }
83
+ handleDropdownEvent(e) {
84
+ if (e.detail.data.element && e.detail.data.open) {
85
+ this.close(this.getMenuBarDropdowns, e.detail.data.element);
86
+ this.close(this.getToolbarDropdowns);
87
+ this.close(this.getMenuBarMenus);
88
+ this.close(this.getMenuBarMenuDropdowns);
89
+ }
90
+ this.toggleActiveMenu(!e.detail.data.open);
91
+ this.toggleActiveTool(true);
92
+ }
93
+ handleFocus() {
94
+ this.toggleActiveMenu(true);
95
+ this.toggleActiveTool(true);
96
+ this.close(this.getToolbarDropdowns);
97
+ this.close(this.getMenuBarMenus);
98
+ this.close(this.getMenuBarMenuDropdowns);
99
+ this.close(this.getMenuBarDropdowns);
100
+ }
101
+ /**
102
+ * render() function
103
+ * Always the last one in the class.
104
+ */
105
+ render() {
106
+ return (h(Host, null, h("nav", null, h("slot", null))));
107
+ }
108
+ get element() { return getElement(this); }
109
+ };
110
+ DuetMenuBar.style = duetNavCss;
111
+
112
+ export { DuetMenuBar as duet_nav };
@@ -1,7 +1,7 @@
1
1
  /*!
2
2
  * Built with Duet Design System
3
3
  */
4
- import { r as registerInstance, h, g as getElement } from './index-26388161.js';
4
+ import { r as registerInstance, h, g as getElement } from './index-5c6775f8.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
  import { a as getLanguage, g as getLocaleString } from './language-utils-bf701d37.js';
7
7
  import { a as actionArrowDownSmall } from './action-arrow-down-small-82273dc8.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-26388161.js';
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
  import { c as createID } from './create-id-981107da.js';
7
7
  import { a as isArrowRightKey, b as isArrowUpKey, c as isArrowDownKey, d as isArrowLeftKey, e as isBackspaceKey } from './keyboard-utils-88ea1007.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, F as Fragment, H as Host, g as getElement } from './index-26388161.js';
4
+ import { r as registerInstance, c as createEvent, h, F as Fragment, H as Host, g as getElement } from './index-5c6775f8.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
  import { c as createID } from './create-id-981107da.js';
7
7
  import { d as debounce } from './js-utils-fa98b8cd.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-26388161.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
  import { c as createID } from './create-id-981107da.js';
7
7
  import { g as getLocaleString } from './language-utils-bf701d37.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-26388161.js';
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
  import { c as createID } from './create-id-981107da.js';
7
7
  import { f as findCheckedOption, w as watchForOptions } from './watch-options-dd55bce8.js';
@@ -1,8 +1,8 @@
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-26388161.js';
5
- import { c as colorPrimaryTurva, a as colorGrayTurva, b as colorPrimary, d as colorGray } from './tokens.module-385c4cf8.js';
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
+ import { i as colorPrimaryTurva, j as colorGrayTurva, k as colorPrimary, l as colorGray } from './tokens.module-d3321092.js';
6
6
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
7
7
  import { c as createID } from './create-id-981107da.js';
8
8
  import { i as isInternetExplorer } from './is-internet-explorer-62b3bdbd.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, c as createEvent } from './index-26388161.js';
4
+ import { r as registerInstance, h, H as Host, g as getElement, c as createEvent } from './index-5c6775f8.js';
5
5
  import { i as inheritGlobalTheme } from './themeable-component-cb76be7c.js';
6
6
  import { g as getLocaleString, a as getLanguage } from './language-utils-bf701d37.js';
7
7
  import { c as createID } from './create-id-981107da.js';
@@ -0,0 +1,38 @@
1
+ /*!
2
+ * Built with Duet Design System
3
+ */
4
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-5c6775f8.js';
5
+ import { i as isInternetExplorer } from './is-internet-explorer-62b3bdbd.js';
6
+
7
+ const duetSectionLayoutCss = "*,*::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;flex:1 0 auto;width:100%}:host(.duet-middle){display:flex}:host(.duet-middle) .duet-layout{padding:36px 28px !important}@media (min-width: 36em){:host(.duet-middle) .duet-layout{padding:48px 36px !important}}@media (min-width: 62em){:host(.duet-middle) .duet-layout{padding:56px !important}}:host(.duet-ie){height:100%}:host(.duet-middle.duet-ie){height:auto}.duet-layout{position:relative;padding:0 16px;margin:48px auto 36px}@media (min-width: 36em){.duet-layout{margin-top:72px}}.duet-layout.duet-m-0{margin-top:0 !important;margin-bottom:0 !important}@media (min-width: 36em){.duet-layout{padding:0 28px}}@media (min-width: 62em){.duet-layout{display:flex;flex-direction:row;padding:0 56px;margin-bottom:48px}}@media (min-width: 76.25em){.duet-layout{max-width:1110px;padding:0}}.duet-main{display:block;width:100%}@media (min-width: 62em){.duet-main{min-width:600px;margin:0 auto}.has-sidebar .duet-main{max-width:734px;margin-right:20px}}";
8
+
9
+ const DuetSectionLayout = class {
10
+ constructor(hostRef) {
11
+ registerInstance(this, hostRef);
12
+ /**
13
+ * Controls the margin of the component.
14
+ */
15
+ this.margin = "auto";
16
+ /**
17
+ * Align container vertically in the middle when the space allows it.
18
+ */
19
+ this.middle = false;
20
+ }
21
+ /**
22
+ * render() function.
23
+ * Always the last one in the class.
24
+ */
25
+ render() {
26
+ return (h(Host, { class: {
27
+ "duet-middle": this.middle,
28
+ "duet-ie": isInternetExplorer(),
29
+ } }, h("div", { class: {
30
+ "duet-layout": true,
31
+ "duet-m-0": this.margin === "none",
32
+ } }, h("section", { class: "duet-main" }, h("slot", null)))));
33
+ }
34
+ get element() { return getElement(this); }
35
+ };
36
+ DuetSectionLayout.style = duetSectionLayoutCss;
37
+
38
+ export { DuetSectionLayout as duet_section_layout };