@duetds/components 8.0.5 → 8.1.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 (1202) hide show
  1. package/hydrate/index.d.ts +2 -2
  2. package/hydrate/index.js +19102 -17869
  3. package/lib/cjs/app-globals-cd75f624.js +54 -0
  4. package/lib/cjs/{common-strings-86913e94.js → common-strings-22c70ef0.js} +6 -6
  5. package/lib/cjs/create-id-1f8c438f.js +13 -0
  6. package/lib/cjs/duet-action-button.cjs.entry.js +133 -133
  7. package/lib/cjs/duet-alert.cjs.entry.js +106 -106
  8. package/lib/cjs/duet-badge.cjs.entry.js +29 -29
  9. package/lib/cjs/duet-banner.cjs.entry.js +52 -52
  10. package/lib/cjs/duet-breadcrumb.cjs.entry.js +41 -41
  11. package/lib/cjs/duet-breadcrumbs.cjs.entry.js +51 -51
  12. package/lib/cjs/duet-button_2.cjs.entry.js +229 -229
  13. package/lib/cjs/duet-callout.cjs.entry.js +28 -28
  14. package/lib/cjs/duet-caption_4.cjs.entry.js +187 -187
  15. package/lib/cjs/duet-card.cjs.entry.js +93 -93
  16. package/lib/cjs/duet-checkbox.cjs.entry.js +85 -85
  17. package/lib/cjs/duet-checkmark.cjs.entry.js +23 -23
  18. package/lib/cjs/duet-chip.cjs.entry.js +182 -182
  19. package/lib/cjs/duet-choice_2.cjs.entry.js +392 -392
  20. package/lib/cjs/duet-collapsible.cjs.entry.js +98 -98
  21. package/lib/cjs/duet-combobox.cjs.entry.js +362 -362
  22. package/lib/cjs/duet-contact-card.cjs.entry.js +49 -49
  23. package/lib/cjs/duet-cookie-consent.cjs.entry.js +35 -35
  24. package/lib/cjs/duet-date-picker.cjs.entry.js +610 -610
  25. package/lib/cjs/duet-divider_2.cjs.entry.js +53 -53
  26. package/lib/cjs/duet-editable-table_3.cjs.entry.js +1247 -1247
  27. package/lib/cjs/duet-empty-state.cjs.entry.js +26 -26
  28. package/lib/cjs/duet-fieldset.cjs.entry.js +50 -50
  29. package/lib/cjs/duet-file-chooser.cjs.entry.js +44 -44
  30. package/lib/cjs/duet-footer.cjs.entry.js +118 -118
  31. package/lib/cjs/duet-grid_2.cjs.entry.js +185 -185
  32. package/lib/cjs/duet-header_2.cjs.entry.js +610 -610
  33. package/lib/cjs/duet-hero.cjs.entry.js +172 -172
  34. package/lib/cjs/duet-icon.cjs.entry.js +141 -141
  35. package/lib/cjs/duet-input_2.cjs.entry.js +346 -346
  36. package/lib/cjs/duet-layout.cjs.entry.js +51 -51
  37. package/lib/cjs/duet-list_2.cjs.entry.js +99 -99
  38. package/lib/cjs/duet-menu-bar-button.cjs.entry.js +70 -70
  39. package/lib/cjs/duet-menu-bar-dropdown-link.cjs.entry.js +44 -44
  40. package/lib/cjs/duet-menu-bar-dropdown.cjs.entry.js +93 -93
  41. package/lib/cjs/duet-menu-bar-link.cjs.entry.js +58 -58
  42. package/lib/cjs/duet-menu-bar.cjs.entry.js +116 -116
  43. package/lib/cjs/duet-modal.cjs.entry.js +188 -188
  44. package/lib/cjs/duet-multiselect.cjs.entry.js +206 -206
  45. package/lib/cjs/duet-nav.cjs.entry.js +20 -20
  46. package/lib/cjs/duet-notification_2.cjs.entry.js +140 -140
  47. package/lib/cjs/duet-number-input.cjs.entry.js +337 -337
  48. package/lib/cjs/duet-page-heading.cjs.entry.js +26 -26
  49. package/lib/cjs/duet-pagination_2.cjs.entry.js +511 -511
  50. package/lib/cjs/duet-popup-menu-item.cjs.entry.js +62 -62
  51. package/lib/cjs/duet-popup-menu.cjs.entry.js +147 -147
  52. package/lib/cjs/duet-progress.cjs.entry.js +54 -54
  53. package/lib/cjs/duet-promo-card.cjs.entry.js +40 -40
  54. package/lib/cjs/duet-radio_2.cjs.entry.js +197 -197
  55. package/lib/cjs/duet-range-slider.cjs.entry.js +105 -105
  56. package/lib/cjs/duet-scrollable_3.cjs.entry.js +384 -386
  57. package/lib/cjs/duet-section-layout.cjs.entry.js +21 -21
  58. package/lib/cjs/duet-select.cjs.entry.js +156 -156
  59. package/lib/cjs/duet-shaped-image.cjs.entry.js +28 -28
  60. package/lib/cjs/duet-show-more.cjs.entry.js +98 -98
  61. package/lib/cjs/duet-slideout-lang.cjs.entry.js +36 -36
  62. package/lib/cjs/duet-slideout-link.cjs.entry.js +33 -33
  63. package/lib/cjs/duet-slideout-panel-dropdown.cjs.entry.js +50 -50
  64. package/lib/cjs/duet-slideout-panel.cjs.entry.js +120 -120
  65. package/lib/cjs/duet-slideout.cjs.entry.js +194 -194
  66. package/lib/cjs/duet-step_2.cjs.entry.js +182 -184
  67. package/lib/cjs/duet-submenu-bar-dropdown-link.cjs.entry.js +36 -36
  68. package/lib/cjs/duet-submenu-bar-dropdown.cjs.entry.js +103 -103
  69. package/lib/cjs/duet-submenu-bar-link.cjs.entry.js +59 -59
  70. package/lib/cjs/duet-submenu-bar.cjs.entry.js +110 -110
  71. package/lib/cjs/duet-textarea.cjs.entry.js +160 -160
  72. package/lib/cjs/duet-toggle.cjs.entry.js +72 -72
  73. package/lib/cjs/duet-toolbar-dropdown-link.cjs.entry.js +35 -35
  74. package/lib/cjs/duet-toolbar-dropdown.cjs.entry.js +60 -57
  75. package/lib/cjs/duet-toolbar-link.cjs.entry.js +32 -25
  76. package/lib/cjs/duet-toolbar.cjs.entry.js +35 -33
  77. package/lib/cjs/duet-tooltip-button_2.cjs.entry.js +98 -80
  78. package/lib/cjs/duet-tooltip.cjs.entry.js +185 -187
  79. package/lib/cjs/duet-tray.cjs.entry.js +82 -82
  80. package/lib/cjs/duet-upload-aria-status.cjs.entry.js +65 -65
  81. package/lib/cjs/duet-upload-item.cjs.entry.js +81 -81
  82. package/lib/cjs/duet-visually-hidden.cjs.entry.js +12 -12
  83. package/lib/cjs/duet.cjs.js +4 -4
  84. package/lib/cjs/errorcodes.utils-a86b1f94.js +39 -0
  85. package/lib/cjs/focus-utils-9b549956.js +21 -0
  86. package/lib/cjs/{index-9e2ea961.js → index-ce232ed8.js} +106 -45
  87. package/lib/cjs/input-utils-1096a2c5.js +56 -0
  88. package/lib/cjs/{is-internet-explorer-76c3b538.js → is-internet-explorer-e7f58ebc.js} +2 -2
  89. package/lib/cjs/{js-utils-b20cfc79.js → js-utils-92e24ba1.js} +27 -27
  90. package/lib/cjs/{language-utils-dc19e8b6.js → language-utils-e8a527e5.js} +74 -74
  91. package/lib/cjs/loader.cjs.js +3 -3
  92. package/lib/cjs/{slot-query-b7555763.js → slot-query-3259af5b.js} +1 -1
  93. package/lib/cjs/string-utils-053749ff.js +59 -0
  94. package/lib/cjs/teleport-e9d05bca.js +99 -0
  95. package/lib/cjs/themeable-component-83a2a0d4.js +15 -0
  96. package/lib/cjs/token-utils-84b3bca6.js +124 -0
  97. package/lib/cjs/watch-options-30a12622.js +61 -0
  98. package/lib/collection/collection-manifest.json +2 -2
  99. package/lib/collection/common/slot-query.js +3 -3
  100. package/lib/collection/common/themeable-component.js +6 -6
  101. package/lib/collection/common-strings.js +6 -6
  102. package/lib/collection/components/duet-action-button/duet-action-button.a11y.e2e.js +5 -5
  103. package/lib/collection/components/duet-action-button/duet-action-button.js +570 -569
  104. package/lib/collection/components/duet-alert/duet-alert.a11y.e2e.js +10 -10
  105. package/lib/collection/components/duet-alert/duet-alert.e2e.js +47 -47
  106. package/lib/collection/components/duet-alert/duet-alert.js +442 -441
  107. package/lib/collection/components/duet-badge/duet-badge.a11y.e2e.js +10 -10
  108. package/lib/collection/components/duet-badge/duet-badge.e2e.js +21 -21
  109. package/lib/collection/components/duet-badge/duet-badge.js +134 -134
  110. package/lib/collection/components/duet-banner/duet-banner.a11y.e2e.js +5 -5
  111. package/lib/collection/components/duet-banner/duet-banner.e2e.js +16 -16
  112. package/lib/collection/components/duet-banner/duet-banner.js +309 -309
  113. package/lib/collection/components/duet-breadcrumbs/duet-breadcrumb.js +139 -139
  114. package/lib/collection/components/duet-breadcrumbs/duet-breadcrumbs.a11y.e2e.js +5 -5
  115. package/lib/collection/components/duet-breadcrumbs/duet-breadcrumbs.e2e.js +6 -6
  116. package/lib/collection/components/duet-breadcrumbs/duet-breadcrumbs.js +112 -112
  117. package/lib/collection/components/duet-button/duet-button.a11y.e2e.js +30 -30
  118. package/lib/collection/components/duet-button/duet-button.e2e.js +187 -187
  119. package/lib/collection/components/duet-button/duet-button.js +1068 -1067
  120. package/lib/collection/components/duet-callout/duet-callout.a11y.e2e.js +5 -5
  121. package/lib/collection/components/duet-callout/duet-callout.e2e.js +15 -15
  122. package/lib/collection/components/duet-callout/duet-callout.js +88 -88
  123. package/lib/collection/components/duet-caption/duet-caption.a11y.e2e.js +5 -5
  124. package/lib/collection/components/duet-caption/duet-caption.e2e.js +20 -20
  125. package/lib/collection/components/duet-caption/duet-caption.js +131 -131
  126. package/lib/collection/components/duet-card/duet-card.a11y.e2e.js +10 -10
  127. package/lib/collection/components/duet-card/duet-card.e2e.js +85 -85
  128. package/lib/collection/components/duet-card/duet-card.js +492 -491
  129. package/lib/collection/components/duet-checkbox/duet-checkbox.a11y.e2e.js +10 -10
  130. package/lib/collection/components/duet-checkbox/duet-checkbox.e2e.js +103 -103
  131. package/lib/collection/components/duet-checkbox/duet-checkbox.js +553 -549
  132. package/lib/collection/components/duet-chip/duet-chip.a11y.e2e.js +10 -10
  133. package/lib/collection/components/duet-chip/duet-chip.e2e.js +40 -40
  134. package/lib/collection/components/duet-chip/duet-chip.js +487 -486
  135. package/lib/collection/components/duet-choice/duet-checkmark.js +136 -136
  136. package/lib/collection/components/duet-choice/duet-choice.a11y.e2e.js +25 -25
  137. package/lib/collection/components/duet-choice/duet-choice.e2e.js +171 -171
  138. package/lib/collection/components/duet-choice/duet-choice.js +1092 -1088
  139. package/lib/collection/components/duet-choice-group/duet-choice-group.a11y.e2e.js +5 -5
  140. package/lib/collection/components/duet-choice-group/duet-choice-group.e2e.js +63 -63
  141. package/lib/collection/components/duet-choice-group/duet-choice-group.js +456 -453
  142. package/lib/collection/components/duet-collapsible/duet-collapsible.a11y.e2e.js +10 -10
  143. package/lib/collection/components/duet-collapsible/duet-collapsible.e2e.js +87 -87
  144. package/lib/collection/components/duet-collapsible/duet-collapsible.js +363 -362
  145. package/lib/collection/components/duet-combobox/duet-combobox-select-single.js +2 -2
  146. package/lib/collection/components/duet-combobox/duet-combobox-select.js +8 -8
  147. package/lib/collection/components/duet-combobox/duet-combobox.a11y.e2e.js +5 -5
  148. package/lib/collection/components/duet-combobox/duet-combobox.e2e.js +115 -115
  149. package/lib/collection/components/duet-combobox/duet-combobox.js +670 -669
  150. package/lib/collection/components/duet-contact-card/duet-contact-card.a11y.e2e.js +5 -5
  151. package/lib/collection/components/duet-contact-card/duet-contact-card.js +255 -255
  152. package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.a11y.e2e.js +5 -5
  153. package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.e2e.js +16 -16
  154. package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.js +127 -127
  155. package/lib/collection/components/duet-date-picker/date-i18n.js +97 -97
  156. package/lib/collection/components/duet-date-picker/date-picker-day.js +9 -9
  157. package/lib/collection/components/duet-date-picker/date-picker-input.js +5 -5
  158. package/lib/collection/components/duet-date-picker/date-picker-month.js +16 -16
  159. package/lib/collection/components/duet-date-picker/date-utils.js +95 -95
  160. package/lib/collection/components/duet-date-picker/date-utils.spec.js +323 -323
  161. package/lib/collection/components/duet-date-picker/duet-date-picker.a11y.e2e.js +5 -5
  162. package/lib/collection/components/duet-date-picker/duet-date-picker.e2e.js +618 -618
  163. package/lib/collection/components/duet-date-picker/duet-date-picker.js +1049 -1044
  164. package/lib/collection/components/duet-date-picker/utils.js +29 -29
  165. package/lib/collection/components/duet-divider/duet-divider.a11y.e2e.js +5 -5
  166. package/lib/collection/components/duet-divider/duet-divider.e2e.js +24 -24
  167. package/lib/collection/components/duet-divider/duet-divider.js +112 -112
  168. package/lib/collection/components/duet-editable-table/duet-editable-table-tabledata.js +7 -7
  169. package/lib/collection/components/duet-editable-table/duet-editable-table.a11y.e2e.js +5 -5
  170. package/lib/collection/components/duet-editable-table/duet-editable-table.e2e.js +19 -19
  171. package/lib/collection/components/duet-editable-table/duet-editable-table.js +501 -498
  172. package/lib/collection/components/duet-empty-state/duet-empty-state.a11y.e2e.js +5 -5
  173. package/lib/collection/components/duet-empty-state/duet-empty-state.e2e.js +10 -10
  174. package/lib/collection/components/duet-empty-state/duet-empty-state.js +110 -110
  175. package/lib/collection/components/duet-fieldset/duet-fieldset.a11y.e2e.js +5 -5
  176. package/lib/collection/components/duet-fieldset/duet-fieldset.e2e.js +5 -5
  177. package/lib/collection/components/duet-fieldset/duet-fieldset.js +245 -245
  178. package/lib/collection/components/duet-file-chooser/duet-file-chooser.js +179 -179
  179. package/lib/collection/components/duet-footer/duet-footer.a11y.e2e.js +5 -5
  180. package/lib/collection/components/duet-footer/duet-footer.e2e.js +163 -163
  181. package/lib/collection/components/duet-footer/duet-footer.js +485 -485
  182. package/lib/collection/components/duet-grid/duet-grid.a11y.e2e.js +5 -5
  183. package/lib/collection/components/duet-grid/duet-grid.e2e.js +36 -36
  184. package/lib/collection/components/duet-grid/duet-grid.js +345 -342
  185. package/lib/collection/components/duet-grid-item/duet-grid-item.js +233 -230
  186. package/lib/collection/components/duet-header/duet-header-dropdown.js +12 -12
  187. package/lib/collection/components/duet-header/duet-header-icon.js +2 -2
  188. package/lib/collection/components/duet-header/duet-header.a11y.e2e.js +5 -5
  189. package/lib/collection/components/duet-header/duet-header.e2e.js +430 -430
  190. package/lib/collection/components/duet-header/duet-header.js +1297 -1295
  191. package/lib/collection/components/duet-heading/duet-heading.a11y.e2e.js +5 -5
  192. package/lib/collection/components/duet-heading/duet-heading.e2e.js +21 -21
  193. package/lib/collection/components/duet-heading/duet-heading.js +230 -230
  194. package/lib/collection/components/duet-hero/duet-hero.a11y.e2e.js +15 -15
  195. package/lib/collection/components/duet-hero/duet-hero.e2e.js +166 -166
  196. package/lib/collection/components/duet-hero/duet-hero.js +814 -814
  197. package/lib/collection/components/duet-icon/duet-icon.a11y.e2e.js +5 -5
  198. package/lib/collection/components/duet-icon/duet-icon.e2e.js +26 -26
  199. package/lib/collection/components/duet-icon/duet-icon.js +392 -392
  200. package/lib/collection/components/duet-icon/icon-utils.js +59 -59
  201. package/lib/collection/components/duet-icon/icon-utils.spec.js +76 -76
  202. package/lib/collection/components/duet-input/duet-input.a11y.e2e.js +20 -20
  203. package/lib/collection/components/duet-input/duet-input.e2e.js +195 -195
  204. package/lib/collection/components/duet-input/duet-input.js +1249 -1245
  205. package/lib/collection/components/duet-label/duet-label.a11y.e2e.js +5 -5
  206. package/lib/collection/components/duet-label/duet-label.e2e.js +26 -26
  207. package/lib/collection/components/duet-label/duet-label.js +134 -131
  208. package/lib/collection/components/duet-layout/duet-layout.a11y.e2e.js +5 -5
  209. package/lib/collection/components/duet-layout/duet-layout.e2e.js +26 -26
  210. package/lib/collection/components/duet-layout/duet-layout.js +207 -207
  211. package/lib/collection/components/duet-link/duet-link.a11y.e2e.js +15 -15
  212. package/lib/collection/components/duet-link/duet-link.e2e.js +47 -47
  213. package/lib/collection/components/duet-link/duet-link.js +436 -435
  214. package/lib/collection/components/duet-list/duet-list.a11y.e2e.js +11 -11
  215. package/lib/collection/components/duet-list/duet-list.e2e.js +50 -50
  216. package/lib/collection/components/duet-list/duet-list.js +292 -292
  217. package/lib/collection/components/duet-list-item/duet-list-item.js +81 -81
  218. package/lib/collection/components/duet-logo/duet-logo.a11y.e2e.js +5 -5
  219. package/lib/collection/components/duet-logo/duet-logo.e2e.js +36 -36
  220. package/lib/collection/components/duet-logo/duet-logo.js +293 -292
  221. package/lib/collection/components/duet-menu-bar/duet-menu-bar.a11y.e2e.js +5 -5
  222. package/lib/collection/components/duet-menu-bar/duet-menu-bar.js +261 -261
  223. package/lib/collection/components/duet-menu-bar-button/duet-menu-bar-button.js +347 -346
  224. package/lib/collection/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.js +224 -223
  225. package/lib/collection/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.js +133 -133
  226. package/lib/collection/components/duet-menu-bar-link/duet-menu-bar-link.js +170 -170
  227. package/lib/collection/components/duet-modal/duet-modal.a11y.e2e.js +10 -10
  228. package/lib/collection/components/duet-modal/duet-modal.e2e.js +78 -78
  229. package/lib/collection/components/duet-modal/duet-modal.js +687 -687
  230. package/lib/collection/components/duet-multiselect/duet-multiselect.a11y.e2e.js +5 -5
  231. package/lib/collection/components/duet-multiselect/duet-multiselect.e2e.js +87 -87
  232. package/lib/collection/components/duet-multiselect/duet-multiselect.js +654 -653
  233. package/lib/collection/components/duet-nav/duet-nav.js +56 -56
  234. package/lib/collection/components/duet-notification/duet-notification.a11y.e2e.js +5 -5
  235. package/lib/collection/components/duet-notification/duet-notification.e2e.js +6 -6
  236. package/lib/collection/components/duet-notification/duet-notification.js +257 -259
  237. package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.a11y.e2e.js +10 -10
  238. package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.e2e.js +141 -141
  239. package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.js +379 -383
  240. package/lib/collection/components/duet-number-input/duet-number-input-negative.e2e.js +26 -26
  241. package/lib/collection/components/duet-number-input/duet-number-input.a11y.e2e.js +5 -5
  242. package/lib/collection/components/duet-number-input/duet-number-input.e2e.js +232 -232
  243. package/lib/collection/components/duet-number-input/duet-number-input.js +1117 -1113
  244. package/lib/collection/components/duet-page-heading/duet-page-heading.a11y.e2e.js +5 -5
  245. package/lib/collection/components/duet-page-heading/duet-page-heading.js +104 -104
  246. package/lib/collection/components/duet-pagination/duet-pagination-utils.js +4 -4
  247. package/lib/collection/components/duet-pagination/duet-pagination.a11y.e2e.js +10 -10
  248. package/lib/collection/components/duet-pagination/duet-pagination.e2e.js +79 -79
  249. package/lib/collection/components/duet-pagination/duet-pagination.js +677 -677
  250. package/lib/collection/components/duet-paragraph/duet-paragraph.a11y.e2e.js +5 -5
  251. package/lib/collection/components/duet-paragraph/duet-paragraph.e2e.js +21 -21
  252. package/lib/collection/components/duet-paragraph/duet-paragraph.js +190 -190
  253. package/lib/collection/components/duet-popup-menu/duet-popup-menu.a11y.e2e.js +5 -5
  254. package/lib/collection/components/duet-popup-menu/duet-popup-menu.js +407 -407
  255. package/lib/collection/components/duet-popup-menu-item/duet-popup-menu-item.js +344 -343
  256. package/lib/collection/components/duet-progress/duet-progress.a11y.e2e.js +7 -7
  257. package/lib/collection/components/duet-progress/duet-progress.e2e.js +6 -6
  258. package/lib/collection/components/duet-progress/duet-progress.js +276 -273
  259. package/lib/collection/components/duet-promo-card/duet-promo-card.a11y.e2e.js +5 -5
  260. package/lib/collection/components/duet-promo-card/duet-promo-card.e2e.js +16 -16
  261. package/lib/collection/components/duet-promo-card/duet-promo-card.js +206 -206
  262. package/lib/collection/components/duet-radio/duet-radio.a11y.e2e.js +5 -5
  263. package/lib/collection/components/duet-radio/duet-radio.e2e.js +126 -126
  264. package/lib/collection/components/duet-radio/duet-radio.js +609 -605
  265. package/lib/collection/components/duet-radio-group/duet-radio-group.a11y.e2e.js +10 -10
  266. package/lib/collection/components/duet-radio-group/duet-radio-group.e2e.js +39 -39
  267. package/lib/collection/components/duet-radio-group/duet-radio-group.js +423 -420
  268. package/lib/collection/components/duet-range-slider/duet-range-slider.a11y.e2e.js +5 -5
  269. package/lib/collection/components/duet-range-slider/duet-range-slider.e2e.js +51 -51
  270. package/lib/collection/components/duet-range-slider/duet-range-slider.js +561 -557
  271. package/lib/collection/components/duet-range-stepper/duet-range-stepper.a11y.e2e.js +5 -5
  272. package/lib/collection/components/duet-range-stepper/duet-range-stepper.e2e.js +46 -46
  273. package/lib/collection/components/duet-range-stepper/duet-range-stepper.js +341 -341
  274. package/lib/collection/components/duet-range-stepper/duet-range-stepper.spec.js +17 -17
  275. package/lib/collection/components/duet-scrollable/duet-scrollable.a11y.e2e.js +5 -5
  276. package/lib/collection/components/duet-scrollable/duet-scrollable.e2e.js +6 -6
  277. package/lib/collection/components/duet-scrollable/duet-scrollable.js +294 -294
  278. package/lib/collection/components/duet-section-layout/duet-section-layout.a11y.e2e.js +5 -5
  279. package/lib/collection/components/duet-section-layout/duet-section-layout.e2e.js +16 -16
  280. package/lib/collection/components/duet-section-layout/duet-section-layout.js +75 -75
  281. package/lib/collection/components/duet-select/duet-select.a11y.e2e.js +10 -10
  282. package/lib/collection/components/duet-select/duet-select.e2e.js +201 -201
  283. package/lib/collection/components/duet-select/duet-select.js +722 -718
  284. package/lib/collection/components/duet-shaped-image/duet-shaped-image.a11y.e2e.js +5 -5
  285. package/lib/collection/components/duet-shaped-image/duet-shaped-image.js +143 -143
  286. package/lib/collection/components/duet-show-more/duet-show-more.a11y.e2e.js +5 -5
  287. package/lib/collection/components/duet-show-more/duet-show-more.js +436 -436
  288. package/lib/collection/components/duet-slideout/duet-slideout.a11y.e2e.js +5 -5
  289. package/lib/collection/components/duet-slideout/duet-slideout.js +408 -407
  290. package/lib/collection/components/duet-slideout-lang/duet-slideout-lang.js +75 -75
  291. package/lib/collection/components/duet-slideout-link/duet-slideout-link.js +215 -215
  292. package/lib/collection/components/duet-slideout-panel/duet-slideout-panel.js +282 -281
  293. package/lib/collection/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.js +177 -176
  294. package/lib/collection/components/duet-spacer/duet-spacer.a11y.e2e.js +5 -5
  295. package/lib/collection/components/duet-spacer/duet-spacer.e2e.js +21 -21
  296. package/lib/collection/components/duet-spacer/duet-spacer.js +110 -110
  297. package/lib/collection/components/duet-spinner/duet-spinner.a11y.e2e.js +5 -5
  298. package/lib/collection/components/duet-spinner/duet-spinner.e2e.js +23 -23
  299. package/lib/collection/components/duet-spinner/duet-spinner.js +131 -131
  300. package/lib/collection/components/duet-step/duet-step.e2e.js +83 -83
  301. package/lib/collection/components/duet-step/duet-step.js +292 -290
  302. package/lib/collection/components/duet-stepper/duet-stepper.a11y.e2e.js +8 -8
  303. package/lib/collection/components/duet-stepper/duet-stepper.e2e.js +49 -49
  304. package/lib/collection/components/duet-stepper/duet-stepper.js +243 -243
  305. package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.a11y.e2e.js +5 -5
  306. package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.js +218 -217
  307. package/lib/collection/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.js +235 -234
  308. package/lib/collection/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.js +162 -162
  309. package/lib/collection/components/duet-submenu-bar-link/duet-submenu-bar-link.js +154 -154
  310. package/lib/collection/components/duet-tab/duet-tab.e2e.js +10 -10
  311. package/lib/collection/components/duet-tab/duet-tab.js +162 -161
  312. package/lib/collection/components/duet-tab-group/duet-tab-group.a11y.e2e.js +5 -5
  313. package/lib/collection/components/duet-tab-group/duet-tab-group.e2e.js +60 -60
  314. package/lib/collection/components/duet-tab-group/duet-tab-group.js +633 -632
  315. package/lib/collection/components/duet-table/duet-table.a11y.e2e.js +5 -5
  316. package/lib/collection/components/duet-table/duet-table.e2e.js +25 -25
  317. package/lib/collection/components/duet-table/duet-table.js +284 -281
  318. package/lib/collection/components/duet-textarea/duet-textarea.a11y.e2e.js +10 -10
  319. package/lib/collection/components/duet-textarea/duet-textarea.e2e.js +193 -193
  320. package/lib/collection/components/duet-textarea/duet-textarea.js +849 -845
  321. package/lib/collection/components/duet-toggle/duet-toggle.a11y.e2e.js +5 -5
  322. package/lib/collection/components/duet-toggle/duet-toggle.e2e.js +66 -66
  323. package/lib/collection/components/duet-toggle/duet-toggle.js +468 -464
  324. package/lib/collection/components/duet-toolbar/duet-toolbar.a11y.e2e.js +5 -5
  325. package/lib/collection/components/duet-toolbar/duet-toolbar.css +12 -0
  326. package/lib/collection/components/duet-toolbar/duet-toolbar.js +105 -85
  327. package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.css +38 -0
  328. package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.js +221 -199
  329. package/lib/collection/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.js +160 -160
  330. package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.css +32 -0
  331. package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.js +156 -131
  332. package/lib/collection/components/duet-tooltip/duet-tooltip-button.js +194 -164
  333. package/lib/collection/components/duet-tooltip/duet-tooltip-popup.js +280 -251
  334. package/lib/collection/components/duet-tooltip/duet-tooltip.a11y.e2e.js +14 -14
  335. package/lib/collection/components/duet-tooltip/duet-tooltip.e2e.js +76 -76
  336. package/lib/collection/components/duet-tooltip/duet-tooltip.js +533 -529
  337. package/lib/collection/components/duet-tray/duet-tray.a11y.e2e.js +5 -5
  338. package/lib/collection/components/duet-tray/duet-tray.e2e.js +67 -67
  339. package/lib/collection/components/duet-tray/duet-tray.js +315 -315
  340. package/lib/collection/components/duet-upload/duet-upload.e2e.js +40 -40
  341. package/lib/collection/components/duet-upload/duet-upload.js +2282 -2276
  342. package/lib/collection/components/duet-upload/errorcodes.utils.js +22 -22
  343. package/lib/collection/components/duet-upload/mock.helpers.js +85 -85
  344. package/lib/collection/components/duet-upload/upload-editable-item-error.js +4 -4
  345. package/lib/collection/components/duet-upload/upload-editable-item-success.js +15 -15
  346. package/lib/collection/components/duet-upload/upload-item-category.js +2 -2
  347. package/lib/collection/components/duet-upload/upload-item-header.js +4 -4
  348. package/lib/collection/components/duet-upload/upload-validators.js +96 -96
  349. package/lib/collection/components/duet-upload/upload-validators.spec.js +35 -35
  350. package/lib/collection/components/duet-upload/upload.helpers.js +8 -8
  351. package/lib/collection/components/duet-upload/xhr.helpers.js +26 -26
  352. package/lib/collection/components/duet-upload-aria-status/duet-upload-aria-status.js +194 -194
  353. package/lib/collection/components/duet-upload-item/duet-upload-item.js +306 -306
  354. package/lib/collection/components/duet-visually-hidden/duet-visually-hidden.a11y.e2e.js +5 -5
  355. package/lib/collection/components/duet-visually-hidden/duet-visually-hidden.e2e.js +6 -6
  356. package/lib/collection/components/duet-visually-hidden/duet-visually-hidden.js +20 -20
  357. package/lib/collection/global/duet-global.js +22 -22
  358. package/lib/collection/global/log-wrapper.js +29 -29
  359. package/lib/collection/utils/axe-core-utils.js +24 -24
  360. package/lib/collection/utils/create-id.js +2 -2
  361. package/lib/collection/utils/create-id.spec.js +6 -6
  362. package/lib/collection/utils/fixture-utils.js +25 -25
  363. package/lib/collection/utils/focus-utils.js +7 -7
  364. package/lib/collection/utils/group-by.js +9 -9
  365. package/lib/collection/utils/input-utils.js +25 -25
  366. package/lib/collection/utils/is-internet-explorer.js +2 -2
  367. package/lib/collection/utils/js-utils.js +38 -38
  368. package/lib/collection/utils/js-utils.spec.js +14 -14
  369. package/lib/collection/utils/language-utils.js +73 -73
  370. package/lib/collection/utils/language-utils.spec.js +151 -151
  371. package/lib/collection/utils/math.utils.js +59 -59
  372. package/lib/collection/utils/math.utils.spec.js +130 -130
  373. package/lib/collection/utils/picture-utils.js +2 -2
  374. package/lib/collection/utils/string-utils.js +31 -31
  375. package/lib/collection/utils/string-utils.spec.js +32 -32
  376. package/lib/collection/utils/teleport.js +77 -77
  377. package/lib/collection/utils/template-utils.js +18 -18
  378. package/lib/collection/utils/template-utils.spec.js +33 -33
  379. package/lib/collection/utils/test-utils.js +31 -31
  380. package/lib/collection/utils/token-utils.js +96 -96
  381. package/lib/collection/utils/token-utils.spec.js +170 -170
  382. package/lib/collection/utils/watch-options.js +44 -44
  383. package/lib/dist-custom-elements/duet-action-button.d.ts +2 -2
  384. package/lib/dist-custom-elements/duet-action-button.js +1 -1
  385. package/lib/dist-custom-elements/duet-alert.d.ts +2 -2
  386. package/lib/dist-custom-elements/duet-alert.js +1 -1
  387. package/lib/dist-custom-elements/duet-badge.d.ts +2 -2
  388. package/lib/dist-custom-elements/duet-badge.js +1 -1
  389. package/lib/dist-custom-elements/duet-banner.d.ts +2 -2
  390. package/lib/dist-custom-elements/duet-banner.js +96 -96
  391. package/lib/dist-custom-elements/duet-breadcrumb.d.ts +2 -2
  392. package/lib/dist-custom-elements/duet-breadcrumb.js +66 -66
  393. package/lib/dist-custom-elements/duet-breadcrumbs.d.ts +2 -2
  394. package/lib/dist-custom-elements/duet-breadcrumbs.js +68 -68
  395. package/lib/dist-custom-elements/duet-button.d.ts +2 -2
  396. package/lib/dist-custom-elements/duet-button.js +1 -1
  397. package/lib/dist-custom-elements/duet-callout.d.ts +2 -2
  398. package/lib/dist-custom-elements/duet-callout.js +57 -57
  399. package/lib/dist-custom-elements/duet-caption.d.ts +2 -2
  400. package/lib/dist-custom-elements/duet-caption.js +1 -1
  401. package/lib/dist-custom-elements/duet-card.d.ts +2 -2
  402. package/lib/dist-custom-elements/duet-card.js +137 -137
  403. package/lib/dist-custom-elements/duet-checkbox.d.ts +2 -2
  404. package/lib/dist-custom-elements/duet-checkbox.js +1 -1
  405. package/lib/dist-custom-elements/duet-checkmark.d.ts +2 -2
  406. package/lib/dist-custom-elements/duet-checkmark.js +1 -1
  407. package/lib/dist-custom-elements/duet-chip.d.ts +2 -2
  408. package/lib/dist-custom-elements/duet-chip.js +219 -219
  409. package/lib/dist-custom-elements/duet-choice-group.d.ts +2 -2
  410. package/lib/dist-custom-elements/duet-choice-group.js +189 -189
  411. package/lib/dist-custom-elements/duet-choice.d.ts +2 -2
  412. package/lib/dist-custom-elements/duet-choice.js +357 -357
  413. package/lib/dist-custom-elements/duet-collapsible.d.ts +2 -2
  414. package/lib/dist-custom-elements/duet-collapsible.js +130 -130
  415. package/lib/dist-custom-elements/duet-combobox.d.ts +2 -2
  416. package/lib/dist-custom-elements/duet-combobox.js +405 -405
  417. package/lib/dist-custom-elements/duet-contact-card.d.ts +2 -2
  418. package/lib/dist-custom-elements/duet-contact-card.js +116 -116
  419. package/lib/dist-custom-elements/duet-cookie-consent.d.ts +2 -2
  420. package/lib/dist-custom-elements/duet-cookie-consent.js +82 -82
  421. package/lib/dist-custom-elements/duet-date-picker.d.ts +2 -2
  422. package/lib/dist-custom-elements/duet-date-picker.js +728 -728
  423. package/lib/dist-custom-elements/duet-divider.d.ts +2 -2
  424. package/lib/dist-custom-elements/duet-divider.js +1 -1
  425. package/lib/dist-custom-elements/duet-editable-table.d.ts +2 -2
  426. package/lib/dist-custom-elements/duet-editable-table.js +230 -230
  427. package/lib/dist-custom-elements/duet-empty-state.d.ts +2 -2
  428. package/lib/dist-custom-elements/duet-empty-state.js +1 -1
  429. package/lib/dist-custom-elements/duet-fieldset.d.ts +2 -2
  430. package/lib/dist-custom-elements/duet-fieldset.js +1 -1
  431. package/lib/dist-custom-elements/duet-file-chooser.d.ts +2 -2
  432. package/lib/dist-custom-elements/duet-file-chooser.js +70 -70
  433. package/lib/dist-custom-elements/duet-footer.d.ts +2 -2
  434. package/lib/dist-custom-elements/duet-footer.js +167 -167
  435. package/lib/dist-custom-elements/duet-grid-item.d.ts +2 -2
  436. package/lib/dist-custom-elements/duet-grid-item.js +1 -1
  437. package/lib/dist-custom-elements/duet-grid.d.ts +2 -2
  438. package/lib/dist-custom-elements/duet-grid.js +1 -1
  439. package/lib/dist-custom-elements/duet-header.d.ts +2 -2
  440. package/lib/dist-custom-elements/duet-header.js +637 -637
  441. package/lib/dist-custom-elements/duet-heading.d.ts +2 -2
  442. package/lib/dist-custom-elements/duet-heading.js +1 -1
  443. package/lib/dist-custom-elements/duet-hero.d.ts +2 -2
  444. package/lib/dist-custom-elements/duet-hero.js +270 -270
  445. package/lib/dist-custom-elements/duet-icon.d.ts +2 -2
  446. package/lib/dist-custom-elements/duet-icon.js +1 -1
  447. package/lib/dist-custom-elements/duet-input.d.ts +2 -2
  448. package/lib/dist-custom-elements/duet-input.js +1 -1
  449. package/lib/dist-custom-elements/duet-label.d.ts +2 -2
  450. package/lib/dist-custom-elements/duet-label.js +1 -1
  451. package/lib/dist-custom-elements/duet-layout.d.ts +2 -2
  452. package/lib/dist-custom-elements/duet-layout.js +73 -73
  453. package/lib/dist-custom-elements/duet-link.d.ts +2 -2
  454. package/lib/dist-custom-elements/duet-link.js +1 -1
  455. package/lib/dist-custom-elements/duet-list-item.d.ts +2 -2
  456. package/lib/dist-custom-elements/duet-list-item.js +1 -1
  457. package/lib/dist-custom-elements/duet-list.d.ts +2 -2
  458. package/lib/dist-custom-elements/duet-list.js +1 -1
  459. package/lib/dist-custom-elements/duet-logo.d.ts +2 -2
  460. package/lib/dist-custom-elements/duet-logo.js +1 -1
  461. package/lib/dist-custom-elements/duet-menu-bar-button.d.ts +2 -2
  462. package/lib/dist-custom-elements/duet-menu-bar-button.js +106 -106
  463. package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.d.ts +2 -2
  464. package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.js +69 -69
  465. package/lib/dist-custom-elements/duet-menu-bar-dropdown.d.ts +2 -2
  466. package/lib/dist-custom-elements/duet-menu-bar-dropdown.js +120 -120
  467. package/lib/dist-custom-elements/duet-menu-bar-link.d.ts +2 -2
  468. package/lib/dist-custom-elements/duet-menu-bar-link.js +85 -85
  469. package/lib/dist-custom-elements/duet-menu-bar.d.ts +2 -2
  470. package/lib/dist-custom-elements/duet-menu-bar.js +145 -145
  471. package/lib/dist-custom-elements/duet-modal.d.ts +2 -2
  472. package/lib/dist-custom-elements/duet-modal.js +262 -262
  473. package/lib/dist-custom-elements/duet-multiselect.d.ts +2 -2
  474. package/lib/dist-custom-elements/duet-multiselect.js +299 -299
  475. package/lib/dist-custom-elements/duet-nav.d.ts +2 -2
  476. package/lib/dist-custom-elements/duet-nav.js +36 -36
  477. package/lib/dist-custom-elements/duet-notification-drawer.d.ts +2 -2
  478. package/lib/dist-custom-elements/duet-notification-drawer.js +142 -142
  479. package/lib/dist-custom-elements/duet-notification.d.ts +2 -2
  480. package/lib/dist-custom-elements/duet-notification.js +76 -76
  481. package/lib/dist-custom-elements/duet-number-input.d.ts +2 -2
  482. package/lib/dist-custom-elements/duet-number-input.js +448 -448
  483. package/lib/dist-custom-elements/duet-page-heading.d.ts +2 -2
  484. package/lib/dist-custom-elements/duet-page-heading.js +50 -50
  485. package/lib/dist-custom-elements/duet-pagination.d.ts +2 -2
  486. package/lib/dist-custom-elements/duet-pagination.js +449 -449
  487. package/lib/dist-custom-elements/duet-paragraph.d.ts +2 -2
  488. package/lib/dist-custom-elements/duet-paragraph.js +1 -1
  489. package/lib/dist-custom-elements/duet-popup-menu-item.d.ts +2 -2
  490. package/lib/dist-custom-elements/duet-popup-menu-item.js +95 -95
  491. package/lib/dist-custom-elements/duet-popup-menu.d.ts +2 -2
  492. package/lib/dist-custom-elements/duet-popup-menu.js +176 -176
  493. package/lib/dist-custom-elements/duet-progress.d.ts +2 -2
  494. package/lib/dist-custom-elements/duet-progress.js +1 -1
  495. package/lib/dist-custom-elements/duet-promo-card.d.ts +2 -2
  496. package/lib/dist-custom-elements/duet-promo-card.js +74 -74
  497. package/lib/dist-custom-elements/duet-radio-group.d.ts +2 -2
  498. package/lib/dist-custom-elements/duet-radio-group.js +183 -183
  499. package/lib/dist-custom-elements/duet-radio.d.ts +2 -2
  500. package/lib/dist-custom-elements/duet-radio.js +130 -130
  501. package/lib/dist-custom-elements/duet-range-slider.d.ts +2 -2
  502. package/lib/dist-custom-elements/duet-range-slider.js +146 -146
  503. package/lib/dist-custom-elements/duet-range-stepper.d.ts +2 -2
  504. package/lib/dist-custom-elements/duet-range-stepper.js +206 -206
  505. package/lib/dist-custom-elements/duet-scrollable.d.ts +2 -2
  506. package/lib/dist-custom-elements/duet-scrollable.js +1 -1
  507. package/lib/dist-custom-elements/duet-section-layout.d.ts +2 -2
  508. package/lib/dist-custom-elements/duet-section-layout.js +38 -38
  509. package/lib/dist-custom-elements/duet-select.d.ts +2 -2
  510. package/lib/dist-custom-elements/duet-select.js +1 -1
  511. package/lib/dist-custom-elements/duet-shaped-image.d.ts +2 -2
  512. package/lib/dist-custom-elements/duet-shaped-image.js +48 -48
  513. package/lib/dist-custom-elements/duet-show-more.d.ts +2 -2
  514. package/lib/dist-custom-elements/duet-show-more.js +151 -151
  515. package/lib/dist-custom-elements/duet-slideout-lang.d.ts +2 -2
  516. package/lib/dist-custom-elements/duet-slideout-lang.js +58 -58
  517. package/lib/dist-custom-elements/duet-slideout-link.d.ts +2 -2
  518. package/lib/dist-custom-elements/duet-slideout-link.js +63 -63
  519. package/lib/dist-custom-elements/duet-slideout-panel-dropdown.d.ts +2 -2
  520. package/lib/dist-custom-elements/duet-slideout-panel-dropdown.js +76 -76
  521. package/lib/dist-custom-elements/duet-slideout-panel.d.ts +2 -2
  522. package/lib/dist-custom-elements/duet-slideout-panel.js +149 -149
  523. package/lib/dist-custom-elements/duet-slideout.d.ts +2 -2
  524. package/lib/dist-custom-elements/duet-slideout.js +225 -225
  525. package/lib/dist-custom-elements/duet-spacer.d.ts +2 -2
  526. package/lib/dist-custom-elements/duet-spacer.js +1 -1
  527. package/lib/dist-custom-elements/duet-spinner.d.ts +2 -2
  528. package/lib/dist-custom-elements/duet-spinner.js +1 -1
  529. package/lib/dist-custom-elements/duet-step.d.ts +2 -2
  530. package/lib/dist-custom-elements/duet-step.js +116 -118
  531. package/lib/dist-custom-elements/duet-stepper.d.ts +2 -2
  532. package/lib/dist-custom-elements/duet-stepper.js +129 -129
  533. package/lib/dist-custom-elements/duet-submenu-bar-dropdown-link.d.ts +2 -2
  534. package/lib/dist-custom-elements/duet-submenu-bar-dropdown-link.js +63 -63
  535. package/lib/dist-custom-elements/duet-submenu-bar-dropdown.d.ts +2 -2
  536. package/lib/dist-custom-elements/duet-submenu-bar-dropdown.js +131 -131
  537. package/lib/dist-custom-elements/duet-submenu-bar-link.d.ts +2 -2
  538. package/lib/dist-custom-elements/duet-submenu-bar-link.js +85 -85
  539. package/lib/dist-custom-elements/duet-submenu-bar.d.ts +2 -2
  540. package/lib/dist-custom-elements/duet-submenu-bar.js +139 -139
  541. package/lib/dist-custom-elements/duet-tab-group.d.ts +2 -2
  542. package/lib/dist-custom-elements/duet-tab-group.js +309 -309
  543. package/lib/dist-custom-elements/duet-tab.d.ts +2 -2
  544. package/lib/dist-custom-elements/duet-tab.js +50 -52
  545. package/lib/dist-custom-elements/duet-table.d.ts +2 -2
  546. package/lib/dist-custom-elements/duet-table.js +1 -1
  547. package/lib/dist-custom-elements/duet-textarea.d.ts +2 -2
  548. package/lib/dist-custom-elements/duet-textarea.js +262 -262
  549. package/lib/dist-custom-elements/duet-toggle.d.ts +2 -2
  550. package/lib/dist-custom-elements/duet-toggle.js +113 -113
  551. package/lib/dist-custom-elements/duet-toolbar-dropdown-link.d.ts +2 -2
  552. package/lib/dist-custom-elements/duet-toolbar-dropdown-link.js +62 -62
  553. package/lib/dist-custom-elements/duet-toolbar-dropdown.d.ts +2 -2
  554. package/lib/dist-custom-elements/duet-toolbar-dropdown.js +88 -84
  555. package/lib/dist-custom-elements/duet-toolbar-link.d.ts +2 -2
  556. package/lib/dist-custom-elements/duet-toolbar-link.js +59 -51
  557. package/lib/dist-custom-elements/duet-toolbar.d.ts +2 -2
  558. package/lib/dist-custom-elements/duet-toolbar.js +53 -50
  559. package/lib/dist-custom-elements/duet-tooltip-button.d.ts +2 -2
  560. package/lib/dist-custom-elements/duet-tooltip-button.js +1 -1
  561. package/lib/dist-custom-elements/duet-tooltip-popup.d.ts +2 -2
  562. package/lib/dist-custom-elements/duet-tooltip-popup.js +1 -1
  563. package/lib/dist-custom-elements/duet-tooltip.d.ts +2 -2
  564. package/lib/dist-custom-elements/duet-tooltip.js +1 -1
  565. package/lib/dist-custom-elements/duet-tray.d.ts +2 -2
  566. package/lib/dist-custom-elements/duet-tray.js +119 -119
  567. package/lib/dist-custom-elements/duet-upload-aria-status.d.ts +2 -2
  568. package/lib/dist-custom-elements/duet-upload-aria-status.js +1 -1
  569. package/lib/dist-custom-elements/duet-upload-item.d.ts +2 -2
  570. package/lib/dist-custom-elements/duet-upload-item.js +1 -1
  571. package/lib/dist-custom-elements/duet-upload.d.ts +2 -2
  572. package/lib/dist-custom-elements/duet-upload.js +1163 -1163
  573. package/lib/dist-custom-elements/duet-visually-hidden.d.ts +2 -2
  574. package/lib/dist-custom-elements/duet-visually-hidden.js +1 -1
  575. package/lib/dist-custom-elements/index.js +36 -36
  576. package/lib/dist-custom-elements/p-02eb68f2.js +123 -0
  577. package/lib/dist-custom-elements/p-0825cbc5.js +82 -0
  578. package/lib/dist-custom-elements/p-0a7c0d3d.js +205 -0
  579. package/lib/dist-custom-elements/p-0e052642.js +55 -0
  580. package/lib/{esm/slot-query-7877f18f.js → dist-custom-elements/p-11230037.js} +1 -1
  581. package/lib/dist-custom-elements/{p-ae75bc08.js → p-1cd7077a.js} +37 -37
  582. package/lib/dist-custom-elements/p-247a9d01.js +174 -0
  583. package/lib/dist-custom-elements/p-257f2e82.js +147 -0
  584. package/lib/dist-custom-elements/p-2605a78e.js +62 -0
  585. package/lib/{esm/language-utils-9ff76444.js → dist-custom-elements/p-2e36d5bf.js} +74 -74
  586. package/lib/dist-custom-elements/p-38b35e69.js +265 -0
  587. package/lib/dist-custom-elements/{p-bde48422.js → p-39827833.js} +171 -171
  588. package/lib/dist-custom-elements/p-3a17ba0c.js +226 -0
  589. package/lib/dist-custom-elements/p-402e81c0.js +206 -0
  590. package/lib/dist-custom-elements/p-43b89e38.js +9 -0
  591. package/lib/dist-custom-elements/{p-274d11e3.js → p-4ab776f4.js} +6 -6
  592. package/lib/dist-custom-elements/p-4f43c247.js +126 -0
  593. package/lib/dist-custom-elements/p-57a1cba9.js +117 -0
  594. package/lib/dist-custom-elements/p-598731b0.js +110 -0
  595. package/lib/dist-custom-elements/p-5e59e970.js +11 -0
  596. package/lib/dist-custom-elements/{p-3a63e916.js → p-5fe36e8b.js} +278 -278
  597. package/lib/dist-custom-elements/{p-670570b2.js → p-6f7dcc4d.js} +65 -43
  598. package/lib/dist-custom-elements/{p-b996e85b.js → p-6fbb1970.js} +128 -128
  599. package/lib/dist-custom-elements/{p-cb0eec72.js → p-70a66e96.js} +42 -42
  600. package/lib/dist-custom-elements/{p-219d974b.js → p-76b345c8.js} +174 -174
  601. package/lib/dist-custom-elements/p-7d8a2628.js +57 -0
  602. package/lib/dist-custom-elements/p-86649f25.js +465 -0
  603. package/lib/dist-custom-elements/p-872a2adb.js +93 -0
  604. package/lib/dist-custom-elements/p-98746766.js +60 -0
  605. package/lib/dist-custom-elements/p-9b5f8ba4.js +98 -0
  606. package/lib/{esm/js-utils-a35dcc8c.js → dist-custom-elements/p-9e371678.js} +27 -27
  607. package/lib/dist-custom-elements/{p-e558d310.js → p-a45d0398.js} +56 -56
  608. package/lib/dist-custom-elements/p-a58bd561.js +13 -0
  609. package/lib/dist-custom-elements/{p-8290757e.js → p-a6e6f578.js} +48 -48
  610. package/lib/dist-custom-elements/p-b2e550a3.js +97 -0
  611. package/lib/dist-custom-elements/{p-650d5990.js → p-ba0f907f.js} +64 -64
  612. package/lib/dist-custom-elements/{p-4469d73c.js → p-ba9ad148.js} +47 -47
  613. package/lib/dist-custom-elements/p-bc3fa417.js +76 -0
  614. package/lib/dist-custom-elements/{p-49a51210.js → p-ce1cc5ab.js} +98 -88
  615. package/lib/dist-custom-elements/p-d5f3b174.js +38 -0
  616. package/lib/dist-custom-elements/{p-d3ee5c39.js → p-d5fc2405.js} +50 -50
  617. package/lib/dist-custom-elements/p-df7874f9.js +53 -0
  618. package/lib/dist-custom-elements/{p-d7f8cd01.js → p-dfd29738.js} +43 -43
  619. package/lib/dist-custom-elements/p-eef66341.js +18 -0
  620. package/lib/dist-custom-elements/p-f91cddd9.js +269 -0
  621. package/lib/dist-custom-elements/p-ff387a2f.js +59 -0
  622. package/lib/dist-custom-elements/p-ffc7f083.js +137 -0
  623. package/lib/duet/duet.esm.js +1 -1
  624. package/lib/duet/duet.js +15 -15
  625. package/lib/duet/{p-6d7578b9.js → p-07af14f1.js} +1 -1
  626. package/lib/duet/{p-e79a0e0b.entry.js → p-0a7c3ecf.entry.js} +1 -1
  627. package/lib/duet/{p-5ddd8a91.system.entry.js → p-0aa1b1cd.system.entry.js} +2 -2
  628. package/lib/duet/{p-29d7df6e.entry.js → p-105a1448.entry.js} +1 -1
  629. package/lib/duet/{p-bb56723c.entry.js → p-132ea5e6.entry.js} +1 -1
  630. package/lib/duet/{p-9d1267d8.entry.js → p-13876bc6.entry.js} +1 -1
  631. package/lib/duet/{p-34c59882.entry.js → p-13f7d993.entry.js} +1 -1
  632. package/lib/duet/{p-602f1983.entry.js → p-16db7b1e.entry.js} +1 -1
  633. package/lib/duet/{p-1a7b4937.entry.js → p-191959c7.entry.js} +1 -1
  634. package/lib/duet/p-1b11541f.entry.js +4 -0
  635. package/lib/duet/{p-2869dc54.system.entry.js → p-1e587bcc.system.entry.js} +1 -1
  636. package/lib/duet/{p-4b0cee30.system.entry.js → p-1ea5e7e8.system.entry.js} +1 -1
  637. package/lib/duet/{p-7b5cadc7.entry.js → p-1fbbf69f.entry.js} +1 -1
  638. package/lib/duet/{p-6e3f96c8.system.entry.js → p-200089a6.system.entry.js} +1 -1
  639. package/lib/duet/{p-8972381a.system.js → p-224f6c46.system.js} +1 -1
  640. package/lib/duet/{p-367d5eb9.entry.js → p-226489c4.entry.js} +1 -1
  641. package/lib/duet/{p-ac19c76a.entry.js → p-2349e838.entry.js} +1 -1
  642. package/lib/duet/{p-b188d4e3.entry.js → p-246db04a.entry.js} +1 -1
  643. package/lib/duet/p-24f7d6bf.entry.js +4 -0
  644. package/lib/duet/p-258b8732.entry.js +4 -0
  645. package/lib/duet/{p-ad0f3fb7.entry.js → p-25bde810.entry.js} +1 -1
  646. package/lib/duet/{p-53490e72.entry.js → p-26c85bab.entry.js} +1 -1
  647. package/lib/duet/{p-778f42fe.system.entry.js → p-26f7d1b9.system.entry.js} +1 -1
  648. package/lib/duet/{p-28d09818.entry.js → p-2b9499f1.entry.js} +1 -1
  649. package/lib/duet/{p-d056bac9.entry.js → p-2c730d40.entry.js} +1 -1
  650. package/lib/duet/{p-4883df66.js → p-2e36d5bf.js} +1 -1
  651. package/lib/duet/{p-50f395c1.entry.js → p-2f0a23ae.entry.js} +1 -1
  652. package/lib/duet/{p-893c30c7.entry.js → p-338ba4d2.entry.js} +1 -1
  653. package/lib/duet/{p-6278cc44.entry.js → p-33d6e5ef.entry.js} +1 -1
  654. package/lib/duet/{p-3247b913.entry.js → p-342527a4.entry.js} +1 -1
  655. package/lib/duet/{p-424f29fc.system.entry.js → p-3aa3fb24.system.entry.js} +1 -1
  656. package/lib/duet/{p-61e50943.system.entry.js → p-3cafacc3.system.entry.js} +1 -1
  657. package/lib/duet/{p-a94e261a.entry.js → p-3e1248d8.entry.js} +1 -1
  658. package/lib/duet/p-40ee5f5e.system.entry.js +4 -0
  659. package/lib/duet/p-4212bab8.js +5 -0
  660. package/lib/duet/{p-8609ea8a.system.entry.js → p-42b49430.system.entry.js} +1 -1
  661. package/lib/duet/{p-8a954fe5.system.entry.js → p-42b9c6f9.system.entry.js} +1 -1
  662. package/lib/duet/{p-3e6ef3dd.system.entry.js → p-464adc60.system.entry.js} +1 -1
  663. package/lib/duet/{p-e921c496.system.entry.js → p-48d6a81d.system.entry.js} +1 -1
  664. package/lib/duet/p-4911c778.system.entry.js +4 -0
  665. package/lib/duet/{p-51a3bd98.system.entry.js → p-4b272eca.system.entry.js} +1 -1
  666. package/lib/duet/p-4c650a9e.entry.js +4 -0
  667. package/lib/duet/{p-8b7f5890.entry.js → p-502f43bb.entry.js} +1 -1
  668. package/lib/duet/{p-a33aea42.entry.js → p-513dfe01.entry.js} +1 -1
  669. package/lib/duet/{p-6b66a45f.system.entry.js → p-51bdb5fd.system.entry.js} +1 -1
  670. package/lib/duet/{p-659e1bf0.entry.js → p-51d53e57.entry.js} +1 -1
  671. package/lib/duet/p-542d792f.entry.js +4 -0
  672. package/lib/duet/{p-d8bcb92e.entry.js → p-55f98dc4.entry.js} +1 -1
  673. package/lib/duet/{p-1c2a80cb.entry.js → p-57a63204.entry.js} +1 -1
  674. package/lib/duet/{p-cb9548e8.entry.js → p-580a7bae.entry.js} +1 -1
  675. package/lib/duet/{p-dfd872f3.entry.js → p-5b86c564.entry.js} +1 -1
  676. package/lib/duet/{p-d94805ae.system.entry.js → p-5c94249e.system.entry.js} +1 -1
  677. package/lib/duet/{p-ccc4e7bb.entry.js → p-5dccd17b.entry.js} +1 -1
  678. package/lib/duet/p-5ed00370.system.js +4 -0
  679. package/lib/duet/{p-dde05948.entry.js → p-5f43dbcf.entry.js} +1 -1
  680. package/lib/duet/{p-b1c635b8.system.entry.js → p-60cee508.system.entry.js} +1 -1
  681. package/lib/duet/{p-d1f67700.system.entry.js → p-61fe1543.system.entry.js} +1 -1
  682. package/lib/duet/{p-3158cd64.system.entry.js → p-625f750f.system.entry.js} +1 -1
  683. package/lib/duet/{p-f50f189c.entry.js → p-6576401a.entry.js} +1 -1
  684. package/lib/duet/{p-8d3f98b7.entry.js → p-65e434a5.entry.js} +1 -1
  685. package/lib/duet/{p-0a929975.system.entry.js → p-69fba9fe.system.entry.js} +1 -1
  686. package/lib/duet/{p-d6875b70.system.entry.js → p-6a972453.system.entry.js} +1 -1
  687. package/lib/duet/{p-63635163.entry.js → p-6b2876f1.entry.js} +1 -1
  688. package/lib/duet/{p-c827fd02.entry.js → p-6cae9d4b.entry.js} +1 -1
  689. package/lib/duet/{p-087aeef6.system.entry.js → p-6e6ececd.system.entry.js} +1 -1
  690. package/lib/duet/{p-20ac2a2d.entry.js → p-6f891451.entry.js} +1 -1
  691. package/lib/duet/{p-6376d683.system.entry.js → p-71ef1651.system.entry.js} +1 -1
  692. package/lib/duet/{p-8bcc2542.system.entry.js → p-73f176dc.system.entry.js} +1 -1
  693. package/lib/duet/{p-60ed1a37.system.entry.js → p-75243a15.system.entry.js} +1 -1
  694. package/lib/duet/{p-079a4f75.entry.js → p-785ff4f2.entry.js} +1 -1
  695. package/lib/duet/{p-3cbbc148.system.entry.js → p-793d7e04.system.entry.js} +1 -1
  696. package/lib/duet/{p-6ba4b5b4.system.entry.js → p-7a085479.system.entry.js} +1 -1
  697. package/lib/duet/p-7a832531.entry.js +4 -0
  698. package/lib/duet/p-7a91a53e.system.entry.js +4 -0
  699. package/lib/duet/{p-6adfb9eb.system.entry.js → p-7b5cd54a.system.entry.js} +1 -1
  700. package/lib/duet/{p-63e91537.system.entry.js → p-7b847e11.system.entry.js} +1 -1
  701. package/lib/duet/{p-453ec42e.system.entry.js → p-7bbc5a65.system.entry.js} +1 -1
  702. package/lib/duet/{p-487fd6b0.system.entry.js → p-7e833901.system.entry.js} +1 -1
  703. package/lib/duet/{p-61e03237.system.entry.js → p-81230084.system.entry.js} +1 -1
  704. package/lib/duet/{p-df315839.system.entry.js → p-8920edb7.system.entry.js} +1 -1
  705. package/lib/duet/{p-62cc70a1.entry.js → p-8a16fb3c.entry.js} +1 -1
  706. package/lib/duet/{p-7aa9fffd.entry.js → p-8bc5df74.entry.js} +1 -1
  707. package/lib/duet/{p-852dc293.entry.js → p-8cf2feaa.entry.js} +1 -1
  708. package/lib/duet/{p-77e6559b.entry.js → p-8d69624a.entry.js} +1 -1
  709. package/lib/duet/{p-65c96206.system.entry.js → p-8d8bdf90.system.entry.js} +2 -2
  710. package/lib/duet/{p-9b6f7d9b.entry.js → p-8e414050.entry.js} +1 -1
  711. package/lib/duet/{p-cf480e2e.system.entry.js → p-8eb82556.system.entry.js} +1 -1
  712. package/lib/duet/{p-d0022dc9.entry.js → p-903efe1d.entry.js} +1 -1
  713. package/lib/duet/{p-8a1790be.system.entry.js → p-9192de69.system.entry.js} +1 -1
  714. package/lib/duet/{p-c9c7f469.system.entry.js → p-9308c47c.system.entry.js} +1 -1
  715. package/lib/duet/{p-c0442e1a.entry.js → p-97488cc9.entry.js} +1 -1
  716. package/lib/duet/{p-2f8c95b7.system.entry.js → p-97d72f16.system.entry.js} +1 -1
  717. package/lib/duet/{p-a7962854.entry.js → p-9aa0ebba.entry.js} +1 -1
  718. package/lib/duet/{p-9e64ef8e.entry.js → p-9de9d3eb.entry.js} +1 -1
  719. package/lib/duet/{p-83cfac28.system.entry.js → p-9ec69dbc.system.entry.js} +1 -1
  720. package/lib/duet/{p-6c665829.system.entry.js → p-9f39d6de.system.entry.js} +1 -1
  721. package/lib/duet/{p-2a0f3958.system.entry.js → p-9fb3e7b4.system.entry.js} +1 -1
  722. package/lib/duet/{p-dbbd0ded.entry.js → p-a4dd147b.entry.js} +1 -1
  723. package/lib/duet/p-a5504252.entry.js +4 -0
  724. package/lib/duet/{p-41ad5fe4.entry.js → p-a59b5059.entry.js} +1 -1
  725. package/lib/duet/{p-35fff67f.system.entry.js → p-aa6ad573.system.entry.js} +1 -1
  726. package/lib/duet/{p-756aabe3.entry.js → p-ab2da6f9.entry.js} +1 -1
  727. package/lib/duet/{p-7ef0a13e.system.entry.js → p-ad0179fa.system.entry.js} +1 -1
  728. package/lib/duet/{p-f3c15b5b.system.entry.js → p-ad3021d3.system.entry.js} +1 -1
  729. package/lib/duet/p-ad5e3c9c.system.entry.js +4 -0
  730. package/lib/duet/{p-cc8908a2.system.entry.js → p-b022a3d5.system.entry.js} +2 -2
  731. package/lib/duet/{p-0f810b17.system.entry.js → p-b036d4f0.system.entry.js} +1 -1
  732. package/lib/duet/{p-738e4a30.system.entry.js → p-b27b1902.system.entry.js} +1 -1
  733. package/lib/duet/{p-21665b49.entry.js → p-b54be005.entry.js} +1 -1
  734. package/lib/duet/{p-49a7c9ae.system.entry.js → p-b5831260.system.entry.js} +1 -1
  735. package/lib/duet/p-b5ffa156.entry.js +4 -0
  736. package/lib/duet/{p-35c39ed3.system.entry.js → p-b62108c8.system.entry.js} +2 -2
  737. package/lib/duet/{p-e19c5a93.entry.js → p-b62ed1f0.entry.js} +1 -1
  738. package/lib/duet/{p-2c971ea1.entry.js → p-b6af2626.entry.js} +1 -1
  739. package/lib/duet/{p-2cc074b2.system.entry.js → p-b868bb09.system.entry.js} +1 -1
  740. package/lib/duet/{p-a1780035.system.entry.js → p-b8b0249f.system.entry.js} +1 -1
  741. package/lib/duet/{p-080af406.entry.js → p-bc16a555.entry.js} +1 -1
  742. package/lib/duet/p-bcd1e9d8.system.entry.js +4 -0
  743. package/lib/duet/p-bd97fff1.system.entry.js +4 -0
  744. package/lib/duet/{p-196d661f.entry.js → p-bf0e9413.entry.js} +1 -1
  745. package/lib/duet/{p-980da7ef.system.entry.js → p-bf3bf531.system.entry.js} +1 -1
  746. package/lib/duet/{p-3973c640.system.entry.js → p-c0152624.system.entry.js} +1 -1
  747. package/lib/duet/{p-bcb319e6.system.entry.js → p-c0c9acd9.system.entry.js} +1 -1
  748. package/lib/duet/{p-99192406.system.entry.js → p-c565698d.system.entry.js} +1 -1
  749. package/lib/duet/{p-11c0868f.entry.js → p-cb69ce4a.entry.js} +1 -1
  750. package/lib/duet/{p-162d843a.entry.js → p-cd8177fe.entry.js} +1 -1
  751. package/lib/duet/{p-bab934fc.entry.js → p-cfb85117.entry.js} +1 -1
  752. package/lib/duet/{p-78a100ed.system.entry.js → p-d13cb6f4.system.entry.js} +1 -1
  753. package/lib/duet/{p-24f7cd35.entry.js → p-d2681203.entry.js} +1 -1
  754. package/lib/duet/{p-89041ec3.entry.js → p-d3069a7b.entry.js} +1 -1
  755. package/lib/duet/{p-0beab734.system.entry.js → p-d32e9ae1.system.entry.js} +1 -1
  756. package/lib/duet/{p-9e41e5a6.entry.js → p-d41e819d.entry.js} +1 -1
  757. package/lib/duet/{p-2176c975.system.entry.js → p-d5d57b8f.system.entry.js} +1 -1
  758. package/lib/duet/{p-075d23d4.entry.js → p-d73f7574.entry.js} +1 -1
  759. package/lib/duet/{p-df802ae3.entry.js → p-d8104d1b.entry.js} +1 -1
  760. package/lib/duet/{p-0b479ca3.entry.js → p-d8ee9cc9.entry.js} +1 -1
  761. package/lib/duet/{p-7671b7b7.system.js → p-da20db91.system.js} +1 -1
  762. package/lib/duet/{p-24a81bf6.system.entry.js → p-db14fdfd.system.entry.js} +1 -1
  763. package/lib/duet/{p-a9f62bc8.entry.js → p-dce5a6f9.entry.js} +1 -1
  764. package/lib/duet/p-dcfe6e27.system.entry.js +4 -0
  765. package/lib/duet/{p-7b411c65.system.entry.js → p-e1f6b6f3.system.entry.js} +2 -2
  766. package/lib/duet/p-e3574b05.entry.js +4 -0
  767. package/lib/duet/{p-726f5b13.system.entry.js → p-e3a8dcb3.system.entry.js} +1 -1
  768. package/lib/duet/{p-e70dc2a1.entry.js → p-e3c5663f.entry.js} +1 -1
  769. package/lib/duet/{p-76dcd997.system.entry.js → p-e6bd0e51.system.entry.js} +1 -1
  770. package/lib/duet/p-e79bf1c2.entry.js +4 -0
  771. package/lib/duet/{p-f107bb45.system.entry.js → p-e96a5f8b.system.entry.js} +1 -1
  772. package/lib/duet/{p-ea37e5ca.system.entry.js → p-ebe22b98.system.entry.js} +1 -1
  773. package/lib/duet/{p-61755646.system.entry.js → p-ec98691e.system.entry.js} +1 -1
  774. package/lib/duet/p-f009e108.entry.js +4 -0
  775. package/lib/duet/{p-5e6d0fba.entry.js → p-f0dc0a5b.entry.js} +1 -1
  776. package/lib/duet/{p-b033b5a6.system.entry.js → p-f1d894da.system.entry.js} +1 -1
  777. package/lib/duet/{p-49c560a4.system.entry.js → p-f25e57fe.system.entry.js} +1 -1
  778. package/lib/duet/{p-71818a07.system.js → p-f3bf4d40.system.js} +1 -1
  779. package/lib/duet/{p-00b1b87e.entry.js → p-f4493cb6.entry.js} +1 -1
  780. package/lib/duet/p-f7b58d72.system.js +5 -0
  781. package/lib/duet/{p-5390af39.system.entry.js → p-f8c64564.system.entry.js} +1 -1
  782. package/lib/duet/p-fabb616b.js +4 -0
  783. package/lib/duet/{p-523b6afe.system.entry.js → p-fb30fcb0.system.entry.js} +1 -1
  784. package/lib/duet/{p-2afb3d9f.system.entry.js → p-fb8a5b68.system.entry.js} +1 -1
  785. package/lib/duet/{p-29800d01.system.entry.js → p-fc0fe631.system.entry.js} +2 -2
  786. package/lib/duet/{p-ee1cade9.system.entry.js → p-fc4f175f.system.entry.js} +1 -1
  787. package/lib/duet/{p-757d8ba4.entry.js → p-ff815e47.entry.js} +1 -1
  788. package/lib/esm/app-globals-41b37f11.js +52 -0
  789. package/lib/esm/{common-strings-c0ac5a0b.js → common-strings-59db6973.js} +6 -6
  790. package/lib/esm/create-id-149a1b6d.js +11 -0
  791. package/lib/esm/duet-action-button.entry.js +133 -133
  792. package/lib/esm/duet-alert.entry.js +106 -106
  793. package/lib/esm/duet-badge.entry.js +29 -29
  794. package/lib/esm/duet-banner.entry.js +52 -52
  795. package/lib/esm/duet-breadcrumb.entry.js +41 -41
  796. package/lib/esm/duet-breadcrumbs.entry.js +51 -51
  797. package/lib/esm/duet-button_2.entry.js +229 -229
  798. package/lib/esm/duet-callout.entry.js +28 -28
  799. package/lib/esm/duet-caption_4.entry.js +187 -187
  800. package/lib/esm/duet-card.entry.js +93 -93
  801. package/lib/esm/duet-checkbox.entry.js +85 -85
  802. package/lib/esm/duet-checkmark.entry.js +23 -23
  803. package/lib/esm/duet-chip.entry.js +182 -182
  804. package/lib/esm/duet-choice_2.entry.js +392 -392
  805. package/lib/esm/duet-collapsible.entry.js +98 -98
  806. package/lib/esm/duet-combobox.entry.js +362 -362
  807. package/lib/esm/duet-contact-card.entry.js +49 -49
  808. package/lib/esm/duet-cookie-consent.entry.js +35 -35
  809. package/lib/esm/duet-date-picker.entry.js +610 -610
  810. package/lib/esm/duet-divider_2.entry.js +53 -53
  811. package/lib/esm/duet-editable-table_3.entry.js +1247 -1247
  812. package/lib/esm/duet-empty-state.entry.js +26 -26
  813. package/lib/esm/duet-fieldset.entry.js +50 -50
  814. package/lib/esm/duet-file-chooser.entry.js +44 -44
  815. package/lib/esm/duet-footer.entry.js +118 -118
  816. package/lib/esm/duet-grid_2.entry.js +185 -185
  817. package/lib/esm/duet-header_2.entry.js +610 -610
  818. package/lib/esm/duet-hero.entry.js +172 -172
  819. package/lib/esm/duet-icon.entry.js +141 -141
  820. package/lib/esm/duet-input_2.entry.js +346 -346
  821. package/lib/esm/duet-layout.entry.js +51 -51
  822. package/lib/esm/duet-list_2.entry.js +99 -99
  823. package/lib/esm/duet-menu-bar-button.entry.js +70 -70
  824. package/lib/esm/duet-menu-bar-dropdown-link.entry.js +44 -44
  825. package/lib/esm/duet-menu-bar-dropdown.entry.js +93 -93
  826. package/lib/esm/duet-menu-bar-link.entry.js +58 -58
  827. package/lib/esm/duet-menu-bar.entry.js +116 -116
  828. package/lib/esm/duet-modal.entry.js +188 -188
  829. package/lib/esm/duet-multiselect.entry.js +206 -206
  830. package/lib/esm/duet-nav.entry.js +20 -20
  831. package/lib/esm/duet-notification_2.entry.js +140 -140
  832. package/lib/esm/duet-number-input.entry.js +337 -337
  833. package/lib/esm/duet-page-heading.entry.js +26 -26
  834. package/lib/esm/duet-pagination_2.entry.js +511 -511
  835. package/lib/esm/duet-popup-menu-item.entry.js +62 -62
  836. package/lib/esm/duet-popup-menu.entry.js +147 -147
  837. package/lib/esm/duet-progress.entry.js +54 -54
  838. package/lib/esm/duet-promo-card.entry.js +40 -40
  839. package/lib/esm/duet-radio_2.entry.js +197 -197
  840. package/lib/esm/duet-range-slider.entry.js +105 -105
  841. package/lib/esm/duet-scrollable_3.entry.js +384 -386
  842. package/lib/esm/duet-section-layout.entry.js +21 -21
  843. package/lib/esm/duet-select.entry.js +156 -156
  844. package/lib/esm/duet-shaped-image.entry.js +28 -28
  845. package/lib/esm/duet-show-more.entry.js +98 -98
  846. package/lib/esm/duet-slideout-lang.entry.js +36 -36
  847. package/lib/esm/duet-slideout-link.entry.js +33 -33
  848. package/lib/esm/duet-slideout-panel-dropdown.entry.js +50 -50
  849. package/lib/esm/duet-slideout-panel.entry.js +120 -120
  850. package/lib/esm/duet-slideout.entry.js +194 -194
  851. package/lib/esm/duet-step_2.entry.js +182 -184
  852. package/lib/esm/duet-submenu-bar-dropdown-link.entry.js +36 -36
  853. package/lib/esm/duet-submenu-bar-dropdown.entry.js +103 -103
  854. package/lib/esm/duet-submenu-bar-link.entry.js +59 -59
  855. package/lib/esm/duet-submenu-bar.entry.js +110 -110
  856. package/lib/esm/duet-textarea.entry.js +160 -160
  857. package/lib/esm/duet-toggle.entry.js +72 -72
  858. package/lib/esm/duet-toolbar-dropdown-link.entry.js +35 -35
  859. package/lib/esm/duet-toolbar-dropdown.entry.js +60 -57
  860. package/lib/esm/duet-toolbar-link.entry.js +32 -25
  861. package/lib/esm/duet-toolbar.entry.js +35 -33
  862. package/lib/esm/duet-tooltip-button_2.entry.js +98 -80
  863. package/lib/esm/duet-tooltip.entry.js +185 -187
  864. package/lib/esm/duet-tray.entry.js +82 -82
  865. package/lib/esm/duet-upload-aria-status.entry.js +65 -65
  866. package/lib/esm/duet-upload-item.entry.js +81 -81
  867. package/lib/esm/duet-visually-hidden.entry.js +12 -12
  868. package/lib/esm/duet.js +5 -5
  869. package/lib/esm/errorcodes.utils-e681347c.js +36 -0
  870. package/lib/esm/focus-utils-d54af982.js +18 -0
  871. package/lib/esm/{index-e89bc6bf.js → index-d4489a2e.js} +106 -45
  872. package/lib/esm/input-utils-85681162.js +53 -0
  873. package/lib/esm/is-internet-explorer-2c48f686.js +9 -0
  874. package/lib/{dist-custom-elements/p-3d8d557b.js → esm/js-utils-9b9e0039.js} +27 -27
  875. package/lib/{dist-custom-elements/p-4883df66.js → esm/language-utils-00ca4c55.js} +74 -74
  876. package/lib/esm/loader.js +4 -4
  877. package/lib/{dist-custom-elements/p-f8c76b25.js → esm/slot-query-022710bb.js} +1 -1
  878. package/lib/esm/string-utils-ca039233.js +55 -0
  879. package/lib/esm/teleport-4462e8c1.js +97 -0
  880. package/lib/esm/themeable-component-724c0f7e.js +13 -0
  881. package/lib/esm/token-utils-b4bd3ec7.js +117 -0
  882. package/lib/esm/watch-options-e96ecd92.js +57 -0
  883. package/lib/esm-es5/duet-action-button.entry.js +1 -1
  884. package/lib/esm-es5/duet-alert.entry.js +1 -1
  885. package/lib/esm-es5/duet-badge.entry.js +1 -1
  886. package/lib/esm-es5/duet-banner.entry.js +1 -1
  887. package/lib/esm-es5/duet-breadcrumb.entry.js +1 -1
  888. package/lib/esm-es5/duet-breadcrumbs.entry.js +1 -1
  889. package/lib/esm-es5/duet-button_2.entry.js +1 -1
  890. package/lib/esm-es5/duet-callout.entry.js +1 -1
  891. package/lib/esm-es5/duet-caption_4.entry.js +1 -1
  892. package/lib/esm-es5/duet-card.entry.js +2 -2
  893. package/lib/esm-es5/duet-checkbox.entry.js +1 -1
  894. package/lib/esm-es5/duet-checkmark.entry.js +1 -1
  895. package/lib/esm-es5/duet-chip.entry.js +1 -1
  896. package/lib/esm-es5/duet-choice_2.entry.js +1 -1
  897. package/lib/esm-es5/duet-collapsible.entry.js +1 -1
  898. package/lib/esm-es5/duet-combobox.entry.js +1 -1
  899. package/lib/esm-es5/duet-contact-card.entry.js +1 -1
  900. package/lib/esm-es5/duet-cookie-consent.entry.js +1 -1
  901. package/lib/esm-es5/duet-date-picker.entry.js +1 -1
  902. package/lib/esm-es5/duet-divider_2.entry.js +1 -1
  903. package/lib/esm-es5/duet-editable-table_3.entry.js +1 -1
  904. package/lib/esm-es5/duet-empty-state.entry.js +1 -1
  905. package/lib/esm-es5/duet-fieldset.entry.js +1 -1
  906. package/lib/esm-es5/duet-file-chooser.entry.js +1 -1
  907. package/lib/esm-es5/duet-footer.entry.js +1 -1
  908. package/lib/esm-es5/duet-grid_2.entry.js +1 -1
  909. package/lib/esm-es5/duet-header_2.entry.js +1 -1
  910. package/lib/esm-es5/duet-hero.entry.js +1 -1
  911. package/lib/esm-es5/duet-icon.entry.js +1 -1
  912. package/lib/esm-es5/duet-input_2.entry.js +1 -1
  913. package/lib/esm-es5/duet-layout.entry.js +1 -1
  914. package/lib/esm-es5/duet-list_2.entry.js +1 -1
  915. package/lib/esm-es5/duet-menu-bar-button.entry.js +1 -1
  916. package/lib/esm-es5/duet-menu-bar-dropdown-link.entry.js +1 -1
  917. package/lib/esm-es5/duet-menu-bar-dropdown.entry.js +1 -1
  918. package/lib/esm-es5/duet-menu-bar-link.entry.js +1 -1
  919. package/lib/esm-es5/duet-menu-bar.entry.js +1 -1
  920. package/lib/esm-es5/duet-modal.entry.js +1 -1
  921. package/lib/esm-es5/duet-multiselect.entry.js +1 -1
  922. package/lib/esm-es5/duet-nav.entry.js +1 -1
  923. package/lib/esm-es5/duet-notification_2.entry.js +1 -1
  924. package/lib/esm-es5/duet-number-input.entry.js +1 -1
  925. package/lib/esm-es5/duet-page-heading.entry.js +1 -1
  926. package/lib/esm-es5/duet-pagination_2.entry.js +1 -1
  927. package/lib/esm-es5/duet-popup-menu-item.entry.js +1 -1
  928. package/lib/esm-es5/duet-popup-menu.entry.js +1 -1
  929. package/lib/esm-es5/duet-progress.entry.js +1 -1
  930. package/lib/esm-es5/duet-promo-card.entry.js +1 -1
  931. package/lib/esm-es5/duet-radio_2.entry.js +1 -1
  932. package/lib/esm-es5/duet-range-slider.entry.js +1 -1
  933. package/lib/esm-es5/duet-scrollable_3.entry.js +2 -2
  934. package/lib/esm-es5/duet-section-layout.entry.js +1 -1
  935. package/lib/esm-es5/duet-select.entry.js +1 -1
  936. package/lib/esm-es5/duet-shaped-image.entry.js +1 -1
  937. package/lib/esm-es5/duet-show-more.entry.js +1 -1
  938. package/lib/esm-es5/duet-slideout-lang.entry.js +1 -1
  939. package/lib/esm-es5/duet-slideout-link.entry.js +1 -1
  940. package/lib/esm-es5/duet-slideout-panel-dropdown.entry.js +1 -1
  941. package/lib/esm-es5/duet-slideout-panel.entry.js +1 -1
  942. package/lib/esm-es5/duet-slideout.entry.js +2 -2
  943. package/lib/esm-es5/duet-step_2.entry.js +2 -2
  944. package/lib/esm-es5/duet-submenu-bar-dropdown-link.entry.js +1 -1
  945. package/lib/esm-es5/duet-submenu-bar-dropdown.entry.js +1 -1
  946. package/lib/esm-es5/duet-submenu-bar-link.entry.js +1 -1
  947. package/lib/esm-es5/duet-submenu-bar.entry.js +1 -1
  948. package/lib/esm-es5/duet-textarea.entry.js +1 -1
  949. package/lib/esm-es5/duet-toggle.entry.js +1 -1
  950. package/lib/esm-es5/duet-toolbar-dropdown-link.entry.js +1 -1
  951. package/lib/esm-es5/duet-toolbar-dropdown.entry.js +2 -2
  952. package/lib/esm-es5/duet-toolbar-link.entry.js +1 -1
  953. package/lib/esm-es5/duet-toolbar.entry.js +1 -1
  954. package/lib/esm-es5/duet-tooltip-button_2.entry.js +2 -2
  955. package/lib/esm-es5/duet-tooltip.entry.js +1 -1
  956. package/lib/esm-es5/duet-tray.entry.js +1 -1
  957. package/lib/esm-es5/duet-upload-aria-status.entry.js +1 -1
  958. package/lib/esm-es5/duet-upload-item.entry.js +1 -1
  959. package/lib/esm-es5/duet-visually-hidden.entry.js +1 -1
  960. package/lib/esm-es5/duet.js +1 -1
  961. package/lib/esm-es5/{errorcodes.utils-424b1197.js → errorcodes.utils-e681347c.js} +1 -1
  962. package/lib/esm-es5/{focus-utils-4707a1e8.js → focus-utils-d54af982.js} +1 -1
  963. package/lib/esm-es5/index-d4489a2e.js +5 -0
  964. package/lib/esm-es5/{language-utils-9ff76444.js → language-utils-00ca4c55.js} +1 -1
  965. package/lib/esm-es5/loader.js +1 -1
  966. package/lib/types/common/a11y-component.d.ts +7 -7
  967. package/lib/types/common/form-components.d.ts +15 -15
  968. package/lib/types/common/themeable-component.d.ts +4 -4
  969. package/lib/types/components/duet-action-button/duet-action-button.d.ts +126 -126
  970. package/lib/types/components/duet-alert/duet-alert.d.ts +100 -100
  971. package/lib/types/components/duet-badge/duet-badge.d.ts +27 -27
  972. package/lib/types/components/duet-banner/duet-banner.d.ts +58 -58
  973. package/lib/types/components/duet-breadcrumbs/duet-breadcrumb.d.ts +32 -32
  974. package/lib/types/components/duet-breadcrumbs/duet-breadcrumbs.d.ts +23 -23
  975. package/lib/types/components/duet-button/duet-button.d.ts +219 -219
  976. package/lib/types/components/duet-callout/duet-callout.d.ts +19 -19
  977. package/lib/types/components/duet-caption/duet-caption.d.ts +26 -26
  978. package/lib/types/components/duet-card/duet-card.d.ts +119 -119
  979. package/lib/types/components/duet-checkbox/duet-checkbox.d.ts +132 -132
  980. package/lib/types/components/duet-chip/duet-chip.d.ts +109 -109
  981. package/lib/types/components/duet-choice/duet-checkmark.d.ts +27 -27
  982. package/lib/types/components/duet-choice/duet-choice.d.ts +259 -259
  983. package/lib/types/components/duet-choice-group/duet-choice-group.d.ts +103 -103
  984. package/lib/types/components/duet-collapsible/duet-collapsible.d.ts +88 -88
  985. package/lib/types/components/duet-combobox/duet-combobox-select-single.d.ts +3 -3
  986. package/lib/types/components/duet-combobox/duet-combobox-select.d.ts +8 -8
  987. package/lib/types/components/duet-combobox/duet-combobox.d.ts +135 -135
  988. package/lib/types/components/duet-contact-card/duet-contact-card.d.ts +60 -60
  989. package/lib/types/components/duet-cookie-consent/duet-cookie-consent.d.ts +29 -29
  990. package/lib/types/components/duet-date-picker/date-i18n.d.ts +13 -13
  991. package/lib/types/components/duet-date-picker/date-picker-day.d.ts +9 -9
  992. package/lib/types/components/duet-date-picker/date-picker-input.d.ts +28 -28
  993. package/lib/types/components/duet-date-picker/date-picker-month.d.ts +12 -12
  994. package/lib/types/components/duet-date-picker/duet-date-picker.d.ts +220 -220
  995. package/lib/types/components/duet-divider/duet-divider.d.ts +26 -26
  996. package/lib/types/components/duet-editable-table/duet-editable-table-tabledata.d.ts +3 -3
  997. package/lib/types/components/duet-editable-table/duet-editable-table.d.ts +133 -133
  998. package/lib/types/components/duet-empty-state/duet-empty-state.d.ts +22 -22
  999. package/lib/types/components/duet-fieldset/duet-fieldset.d.ts +60 -60
  1000. package/lib/types/components/duet-file-chooser/duet-file-chooser.d.ts +35 -35
  1001. package/lib/types/components/duet-footer/duet-footer.d.ts +143 -143
  1002. package/lib/types/components/duet-grid/duet-grid.d.ts +73 -73
  1003. package/lib/types/components/duet-grid-item/duet-grid-item.d.ts +49 -49
  1004. package/lib/types/components/duet-header/duet-header-dropdown.d.ts +11 -11
  1005. package/lib/types/components/duet-header/duet-header-icon.d.ts +3 -3
  1006. package/lib/types/components/duet-header/duet-header.d.ts +347 -347
  1007. package/lib/types/components/duet-heading/duet-heading.d.ts +49 -49
  1008. package/lib/types/components/duet-hero/duet-hero.d.ts +198 -198
  1009. package/lib/types/components/duet-icon/duet-icon.d.ts +79 -79
  1010. package/lib/types/components/duet-input/duet-input.d.ts +279 -279
  1011. package/lib/types/components/duet-label/duet-label.d.ts +26 -26
  1012. package/lib/types/components/duet-layout/duet-layout.d.ts +48 -48
  1013. package/lib/types/components/duet-link/duet-link.d.ts +94 -94
  1014. package/lib/types/components/duet-list/duet-list.d.ts +60 -60
  1015. package/lib/types/components/duet-list-item/duet-list-item.d.ts +17 -17
  1016. package/lib/types/components/duet-logo/duet-logo.d.ts +59 -59
  1017. package/lib/types/components/duet-menu-bar/duet-menu-bar.d.ts +68 -68
  1018. package/lib/types/components/duet-menu-bar-button/duet-menu-bar-button.d.ts +84 -84
  1019. package/lib/types/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.d.ts +49 -49
  1020. package/lib/types/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.d.ts +36 -36
  1021. package/lib/types/components/duet-menu-bar-link/duet-menu-bar-link.d.ts +44 -44
  1022. package/lib/types/components/duet-modal/duet-modal.d.ts +155 -155
  1023. package/lib/types/components/duet-multiselect/duet-multiselect.d.ts +153 -153
  1024. package/lib/types/components/duet-nav/duet-nav.d.ts +20 -20
  1025. package/lib/types/components/duet-notification/duet-notification.d.ts +55 -55
  1026. package/lib/types/components/duet-notification-drawer/duet-notification-drawer.d.ts +83 -83
  1027. package/lib/types/components/duet-number-input/duet-number-input.d.ts +230 -230
  1028. package/lib/types/components/duet-page-heading/duet-page-heading.d.ts +25 -25
  1029. package/lib/types/components/duet-pagination/duet-pagination.d.ts +129 -129
  1030. package/lib/types/components/duet-paragraph/duet-paragraph.d.ts +38 -38
  1031. package/lib/types/components/duet-popup-menu/duet-popup-menu.d.ts +80 -80
  1032. package/lib/types/components/duet-popup-menu-item/duet-popup-menu-item.d.ts +73 -73
  1033. package/lib/types/components/duet-progress/duet-progress.d.ts +71 -71
  1034. package/lib/types/components/duet-promo-card/duet-promo-card.d.ts +42 -42
  1035. package/lib/types/components/duet-radio/duet-radio.d.ts +145 -145
  1036. package/lib/types/components/duet-radio-group/duet-radio-group.d.ts +93 -93
  1037. package/lib/types/components/duet-range-slider/duet-range-slider.d.ts +130 -130
  1038. package/lib/types/components/duet-range-stepper/duet-range-stepper.d.ts +68 -68
  1039. package/lib/types/components/duet-scrollable/duet-scrollable.d.ts +61 -61
  1040. package/lib/types/components/duet-section-layout/duet-section-layout.d.ts +17 -17
  1041. package/lib/types/components/duet-select/duet-select.d.ts +179 -179
  1042. package/lib/types/components/duet-shaped-image/duet-shaped-image.d.ts +30 -30
  1043. package/lib/types/components/duet-show-more/duet-show-more.d.ts +83 -83
  1044. package/lib/types/components/duet-slideout/duet-slideout.d.ts +86 -86
  1045. package/lib/types/components/duet-slideout-lang/duet-slideout-lang.d.ts +24 -24
  1046. package/lib/types/components/duet-slideout-link/duet-slideout-link.d.ts +55 -55
  1047. package/lib/types/components/duet-slideout-panel/duet-slideout-panel.d.ts +55 -55
  1048. package/lib/types/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.d.ts +39 -39
  1049. package/lib/types/components/duet-spacer/duet-spacer.d.ts +18 -18
  1050. package/lib/types/components/duet-spinner/duet-spinner.d.ts +30 -30
  1051. package/lib/types/components/duet-step/duet-step.d.ts +66 -66
  1052. package/lib/types/components/duet-stepper/duet-stepper.d.ts +47 -47
  1053. package/lib/types/components/duet-submenu-bar/duet-submenu-bar.d.ts +50 -50
  1054. package/lib/types/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.d.ts +47 -47
  1055. package/lib/types/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.d.ts +43 -43
  1056. package/lib/types/components/duet-submenu-bar-link/duet-submenu-bar-link.d.ts +39 -39
  1057. package/lib/types/components/duet-tab/duet-tab.d.ts +37 -37
  1058. package/lib/types/components/duet-tab-group/duet-tab-group.d.ts +132 -132
  1059. package/lib/types/components/duet-table/duet-table.d.ts +66 -66
  1060. package/lib/types/components/duet-textarea/duet-textarea.d.ts +200 -200
  1061. package/lib/types/components/duet-toggle/duet-toggle.d.ts +113 -113
  1062. package/lib/types/components/duet-toolbar/duet-toolbar.d.ts +30 -26
  1063. package/lib/types/components/duet-toolbar-dropdown/duet-toolbar-dropdown.d.ts +50 -46
  1064. package/lib/types/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.d.ts +43 -43
  1065. package/lib/types/components/duet-toolbar-link/duet-toolbar-link.d.ts +42 -38
  1066. package/lib/types/components/duet-tooltip/duet-tooltip-button.d.ts +22 -19
  1067. package/lib/types/components/duet-tooltip/duet-tooltip-popup.d.ts +34 -31
  1068. package/lib/types/components/duet-tooltip/duet-tooltip.d.ts +122 -122
  1069. package/lib/types/components/duet-tray/duet-tray.d.ts +84 -84
  1070. package/lib/types/components/duet-upload/duet-upload.d.ts +484 -484
  1071. package/lib/types/components/duet-upload/errorcodes.utils.d.ts +3 -3
  1072. package/lib/types/components/duet-upload/upload-editable-item-error.d.ts +2 -2
  1073. package/lib/types/components/duet-upload/upload-editable-item-inprogres.d.ts +2 -2
  1074. package/lib/types/components/duet-upload/upload-editable-item-pending.d.ts +1 -1
  1075. package/lib/types/components/duet-upload/upload-editable-item-success.d.ts +2 -2
  1076. package/lib/types/components/duet-upload/upload-item-header.d.ts +2 -2
  1077. package/lib/types/components/duet-upload/upload-validators.d.ts +4 -4
  1078. package/lib/types/components/duet-upload/xhr.helpers.d.ts +10 -10
  1079. package/lib/types/components/duet-upload-aria-status/duet-upload-aria-status.d.ts +40 -40
  1080. package/lib/types/components/duet-upload-item/duet-upload-item.d.ts +54 -54
  1081. package/lib/types/components/duet-visually-hidden/duet-visually-hidden.d.ts +6 -6
  1082. package/lib/types/components.d.ts +24 -0
  1083. package/lib/types/stencil-public-runtime.d.ts +8 -0
  1084. package/lib/types/utils/axe-core-utils.d.ts +3 -3
  1085. package/lib/types/utils/fixture-utils.d.ts +2 -2
  1086. package/lib/types/utils/focus-utils.d.ts +2 -2
  1087. package/lib/types/utils/language-utils.d.ts +10 -10
  1088. package/lib/types/utils/picture-utils.d.ts +10 -10
  1089. package/lib/types/utils/teleport.d.ts +20 -20
  1090. package/lib/types/utils/template-utils.d.ts +1 -1
  1091. package/lib/types/utils/test-utils.d.ts +2 -2
  1092. package/lib/types/utils/token-utils.d.ts +9 -9
  1093. package/package.json +6 -6
  1094. package/lib/cjs/app-globals-4ab83f59.js +0 -54
  1095. package/lib/cjs/create-id-167cd350.js +0 -13
  1096. package/lib/cjs/errorcodes.utils-8e928de5.js +0 -39
  1097. package/lib/cjs/focus-utils-9b46865d.js +0 -21
  1098. package/lib/cjs/input-utils-b4615782.js +0 -56
  1099. package/lib/cjs/string-utils-51a2f59f.js +0 -59
  1100. package/lib/cjs/teleport-af825e04.js +0 -99
  1101. package/lib/cjs/themeable-component-0be6d1f4.js +0 -15
  1102. package/lib/cjs/token-utils-dbfeff2e.js +0 -124
  1103. package/lib/cjs/watch-options-1773d69f.js +0 -61
  1104. package/lib/dist-custom-elements/p-08b3f943.js +0 -226
  1105. package/lib/dist-custom-elements/p-105af500.js +0 -265
  1106. package/lib/dist-custom-elements/p-1296f08a.js +0 -465
  1107. package/lib/dist-custom-elements/p-1a395a8d.js +0 -55
  1108. package/lib/dist-custom-elements/p-1e625a72.js +0 -147
  1109. package/lib/dist-custom-elements/p-2434057e.js +0 -123
  1110. package/lib/dist-custom-elements/p-24853ebf.js +0 -97
  1111. package/lib/dist-custom-elements/p-24a51286.js +0 -38
  1112. package/lib/dist-custom-elements/p-268171f7.js +0 -9
  1113. package/lib/dist-custom-elements/p-3f6372e1.js +0 -271
  1114. package/lib/dist-custom-elements/p-40f73dc7.js +0 -174
  1115. package/lib/dist-custom-elements/p-45f71a69.js +0 -11
  1116. package/lib/dist-custom-elements/p-701d0f44.js +0 -126
  1117. package/lib/dist-custom-elements/p-77f2dbee.js +0 -53
  1118. package/lib/dist-custom-elements/p-7855af1f.js +0 -72
  1119. package/lib/dist-custom-elements/p-8350edff.js +0 -206
  1120. package/lib/dist-custom-elements/p-8a760b84.js +0 -76
  1121. package/lib/dist-custom-elements/p-9d8865d0.js +0 -137
  1122. package/lib/dist-custom-elements/p-a1371eee.js +0 -57
  1123. package/lib/dist-custom-elements/p-a848925d.js +0 -98
  1124. package/lib/dist-custom-elements/p-a90d09f3.js +0 -110
  1125. package/lib/dist-custom-elements/p-aa5fdf1c.js +0 -59
  1126. package/lib/dist-custom-elements/p-ae0811df.js +0 -93
  1127. package/lib/dist-custom-elements/p-b0ed56f3.js +0 -60
  1128. package/lib/dist-custom-elements/p-bafa44de.js +0 -205
  1129. package/lib/dist-custom-elements/p-c137ffb9.js +0 -62
  1130. package/lib/dist-custom-elements/p-c5032d3a.js +0 -18
  1131. package/lib/dist-custom-elements/p-d48735b6.js +0 -13
  1132. package/lib/dist-custom-elements/p-e19d1e27.js +0 -117
  1133. package/lib/duet/p-035ed3a5.entry.js +0 -4
  1134. package/lib/duet/p-0c2260c1.entry.js +0 -4
  1135. package/lib/duet/p-0ff971c3.entry.js +0 -4
  1136. package/lib/duet/p-1088a724.system.entry.js +0 -4
  1137. package/lib/duet/p-12b77122.entry.js +0 -4
  1138. package/lib/duet/p-227a98c3.system.js +0 -5
  1139. package/lib/duet/p-27db4f60.system.entry.js +0 -4
  1140. package/lib/duet/p-306c56d8.entry.js +0 -4
  1141. package/lib/duet/p-40b64c0f.entry.js +0 -4
  1142. package/lib/duet/p-4669b0af.js +0 -4
  1143. package/lib/duet/p-60e4c89d.entry.js +0 -4
  1144. package/lib/duet/p-88e554c9.entry.js +0 -4
  1145. package/lib/duet/p-8e13850e.system.entry.js +0 -4
  1146. package/lib/duet/p-9160fca2.system.entry.js +0 -4
  1147. package/lib/duet/p-a3c1b8ea.entry.js +0 -4
  1148. package/lib/duet/p-b10e72ff.system.js +0 -4
  1149. package/lib/duet/p-b8d12bc2.js +0 -5
  1150. package/lib/duet/p-c33904be.system.entry.js +0 -4
  1151. package/lib/duet/p-c62e9ef9.entry.js +0 -4
  1152. package/lib/duet/p-c8a46cb9.system.entry.js +0 -4
  1153. package/lib/duet/p-d9c3fb44.system.entry.js +0 -4
  1154. package/lib/duet/p-f50ecfd3.entry.js +0 -4
  1155. package/lib/esm/app-globals-de2a5510.js +0 -52
  1156. package/lib/esm/create-id-2b0cd46d.js +0 -11
  1157. package/lib/esm/errorcodes.utils-424b1197.js +0 -36
  1158. package/lib/esm/focus-utils-4707a1e8.js +0 -18
  1159. package/lib/esm/input-utils-a0225b92.js +0 -53
  1160. package/lib/esm/is-internet-explorer-032d4dae.js +0 -9
  1161. package/lib/esm/string-utils-59ad4cb2.js +0 -55
  1162. package/lib/esm/teleport-15747328.js +0 -97
  1163. package/lib/esm/themeable-component-fdce4fd7.js +0 -13
  1164. package/lib/esm/token-utils-46c8fe31.js +0 -117
  1165. package/lib/esm/watch-options-f189118b.js +0 -57
  1166. package/lib/esm-es5/index-e89bc6bf.js +0 -5
  1167. /package/lib/duet/{p-b1db3006.js → p-0782a6e5.js} +0 -0
  1168. /package/lib/duet/{p-1a395a8d.js → p-0e052642.js} +0 -0
  1169. /package/lib/duet/{p-f8c76b25.js → p-11230037.js} +0 -0
  1170. /package/lib/duet/{p-0b31864f.js → p-38320af8.js} +0 -0
  1171. /package/lib/duet/{p-c30a5f7c.system.js → p-41982d26.system.js} +0 -0
  1172. /package/lib/duet/{p-268171f7.js → p-43b89e38.js} +0 -0
  1173. /package/lib/duet/{p-274d11e3.js → p-4ab776f4.js} +0 -0
  1174. /package/lib/duet/{p-77b6e4ba.system.js → p-50f4bca2.system.js} +0 -0
  1175. /package/lib/duet/{p-45f71a69.js → p-5e59e970.js} +0 -0
  1176. /package/lib/duet/{p-75daef16.system.js → p-634e8787.system.js} +0 -0
  1177. /package/lib/duet/{p-719b38fe.system.js → p-67c653f9.system.js} +0 -0
  1178. /package/lib/duet/{p-b99c00fa.system.js → p-6ef75455.system.js} +0 -0
  1179. /package/lib/duet/{p-a1371eee.js → p-7d8a2628.js} +0 -0
  1180. /package/lib/duet/{p-21f3a17a.system.js → p-81a6df68.system.js} +0 -0
  1181. /package/lib/duet/{p-ecf1f6cd.system.js → p-9e36548d.system.js} +0 -0
  1182. /package/lib/duet/{p-3d8d557b.js → p-9e371678.js} +0 -0
  1183. /package/lib/duet/{p-d48735b6.js → p-a58bd561.js} +0 -0
  1184. /package/lib/duet/{p-8e1da663.system.js → p-afad5fd3.system.js} +0 -0
  1185. /package/lib/duet/{p-24853ebf.js → p-b2e550a3.js} +0 -0
  1186. /package/lib/duet/{p-7c29d36a.system.js → p-b864159a.system.js} +0 -0
  1187. /package/lib/duet/{p-88a50491.system.js → p-d1cedaa1.system.js} +0 -0
  1188. /package/lib/duet/{p-77f2dbee.js → p-df7874f9.js} +0 -0
  1189. /package/lib/duet/{p-87dd7bf3.system.js → p-e12066c8.system.js} +0 -0
  1190. /package/lib/duet/{p-1a91e22a.system.js → p-e6b5a1c7.system.js} +0 -0
  1191. /package/lib/esm-es5/{app-globals-de2a5510.js → app-globals-41b37f11.js} +0 -0
  1192. /package/lib/esm-es5/{common-strings-c0ac5a0b.js → common-strings-59db6973.js} +0 -0
  1193. /package/lib/esm-es5/{create-id-2b0cd46d.js → create-id-149a1b6d.js} +0 -0
  1194. /package/lib/esm-es5/{input-utils-a0225b92.js → input-utils-85681162.js} +0 -0
  1195. /package/lib/esm-es5/{is-internet-explorer-032d4dae.js → is-internet-explorer-2c48f686.js} +0 -0
  1196. /package/lib/esm-es5/{js-utils-a35dcc8c.js → js-utils-9b9e0039.js} +0 -0
  1197. /package/lib/esm-es5/{slot-query-7877f18f.js → slot-query-022710bb.js} +0 -0
  1198. /package/lib/esm-es5/{string-utils-59ad4cb2.js → string-utils-ca039233.js} +0 -0
  1199. /package/lib/esm-es5/{teleport-15747328.js → teleport-4462e8c1.js} +0 -0
  1200. /package/lib/esm-es5/{themeable-component-fdce4fd7.js → themeable-component-724c0f7e.js} +0 -0
  1201. /package/lib/esm-es5/{token-utils-46c8fe31.js → token-utils-b4bd3ec7.js} +0 -0
  1202. /package/lib/esm-es5/{watch-options-f189118b.js → watch-options-e96ecd92.js} +0 -0
@@ -4,73 +4,73 @@
4
4
  import { createPage } from "../../utils/test-utils";
5
5
  import i18n from "./date-i18n";
6
6
  async function getFocusedElement(page) {
7
- return page.evaluateHandle(() => document.activeElement);
7
+ return page.evaluateHandle(() => document.activeElement);
8
8
  }
9
9
  async function getChooseDateButton(page) {
10
- return page.find(".duet-date-button");
10
+ return page.find(".duet-date-button");
11
11
  }
12
12
  async function getInput(page) {
13
- return page.find("duet-input");
13
+ return page.find("duet-input");
14
14
  }
15
15
  async function getDialog(page) {
16
- return page.find(`[role="dialog"]`);
16
+ return page.find(`[role="dialog"]`);
17
17
  }
18
18
  async function getGrid(page) {
19
- const dialog = await getDialog(page);
20
- return dialog.find("table");
19
+ const dialog = await getDialog(page);
20
+ return dialog.find("table");
21
21
  }
22
22
  async function getPicker(page) {
23
- return page.find("duet-date-picker");
23
+ return page.find("duet-date-picker");
24
24
  }
25
25
  async function setMonthDropdown(page, month) {
26
- await page.select(".duet-date-month-select", month);
27
- await page.waitForChanges();
26
+ await page.select(".duet-date-month-select", month);
27
+ await page.waitForChanges();
28
28
  }
29
29
  async function setYearDropdown(page, year) {
30
- await page.select(".duet-date-year-select", year);
31
- await page.waitForChanges();
30
+ await page.select(".duet-date-year-select", year);
31
+ await page.waitForChanges();
32
32
  }
33
33
  async function getPrevMonthButton(page) {
34
- const dialog = await getDialog(page);
35
- return dialog.find(`.duet-date-dialog-prev >>> button`);
34
+ const dialog = await getDialog(page);
35
+ return dialog.find(`.duet-date-dialog-prev >>> button`);
36
36
  }
37
37
  async function getNextMonthButton(page) {
38
- const dialog = await getDialog(page);
39
- return dialog.find(`.duet-date-dialog-next >>> button`);
38
+ const dialog = await getDialog(page);
39
+ return dialog.find(`.duet-date-dialog-next >>> button`);
40
40
  }
41
41
  async function findByText(context, selector, text) {
42
- const elements = await context.findAll(selector);
43
- return elements.find(element => element.innerText.includes(text));
42
+ const elements = await context.findAll(selector);
43
+ return elements.find(element => element.innerText.includes(text));
44
44
  }
45
45
  async function clickDay(page, date) {
46
- const grid = await getGrid(page);
47
- const button = await findByText(grid, "button", date);
48
- await button.click();
49
- await page.waitForChanges();
46
+ const grid = await getGrid(page);
47
+ const button = await findByText(grid, "button", date);
48
+ await button.click();
49
+ await page.waitForChanges();
50
50
  }
51
51
  async function openCalendar(page) {
52
- const button = await getChooseDateButton(page);
53
- await button.click();
54
- await page.waitForChanges();
55
- const dialog = await getDialog(page);
56
- await dialog.waitForVisible();
52
+ const button = await getChooseDateButton(page);
53
+ await button.click();
54
+ await page.waitForChanges();
55
+ const dialog = await getDialog(page);
56
+ await dialog.waitForVisible();
57
57
  }
58
58
  async function clickOutside(page) {
59
- const input = await getInput(page);
60
- await input.click();
61
- await page.waitForChanges();
62
- const dialog = await getDialog(page);
63
- await dialog.waitForNotVisible();
59
+ const input = await getInput(page);
60
+ await input.click();
61
+ await page.waitForChanges();
62
+ const dialog = await getDialog(page);
63
+ await dialog.waitForNotVisible();
64
64
  }
65
65
  async function isCalendarOpen(page) {
66
- const dialog = await getDialog(page);
67
- return dialog.isVisible();
66
+ const dialog = await getDialog(page);
67
+ return dialog.isVisible();
68
68
  }
69
69
  const generatePage = (props) => {
70
- const attrs = Object.entries(Object.assign({ label: "Valitse paiva", expand: true }, props))
71
- .map(([attr, value]) => `${attr}="${value}"`)
72
- .join(" ");
73
- return createPage(`
70
+ const attrs = Object.entries(Object.assign({ label: "Valitse paiva", expand: true }, props))
71
+ .map(([attr, value]) => `${attr}="${value}"`)
72
+ .join(" ");
73
+ return createPage(`
74
74
  <body style="min-height: 400px">
75
75
  <duet-date-picker ${attrs}></duet-date-picker>
76
76
  </body>
@@ -78,572 +78,572 @@ const generatePage = (props) => {
78
78
  };
79
79
  const ANIMATION_DELAY = 600;
80
80
  describe("duet-date-picker", () => {
81
- it("should render a date picker", async () => {
82
- const page = await createPage(`<duet-date-picker value="2020-06-16"></duet-date-picker>`);
83
- const component = await getPicker(page);
84
- expect(component).not.toBeNull();
85
- });
86
- describe("user input", () => {
87
- it("does not reformat input if date doesn't have leading zeroes", async () => {
88
- const page = await generatePage();
89
- const picker = await getPicker(page);
90
- const input = await page.find("duet-input input");
91
- const spy = await picker.spyOnEvent("duetChange");
92
- await input.type("1.2.2021", { delay: 50 });
93
- await page.waitForChanges();
94
- // the input's value should not get formatted with leading zeroes
95
- expect(await input.getProperty("value")).toBe("1.2.2021");
96
- // but we should still emit correctly formatted ISO dates
97
- expect(await picker.getProperty("value")).toBe("2021-02-01");
98
- expect(spy).toHaveReceivedEventTimes(1);
99
- expect(spy.lastEvent.detail.value).toBe("2021-02-01");
100
- });
101
- it("allows input to be cleared by setting value to empty string", async () => {
102
- const page = await generatePage();
103
- const picker = await getPicker(page);
104
- const input = await page.find("duet-input input");
105
- await input.type("1.2.2021", { delay: 50 });
106
- await page.waitForChanges();
107
- picker.setProperty("value", "");
108
- await page.waitForChanges();
109
- expect(await input.getProperty("value")).toBe("");
110
- });
111
- it("supports dashes and slashes as separators", async () => {
112
- const page = await generatePage();
113
- const picker = await getPicker(page);
114
- const input = await page.find("duet-input input");
115
- const spy = await picker.spyOnEvent("duetChange");
116
- // slashes
117
- await input.type("1/1/2021", { delay: 50 });
118
- await page.waitForChanges();
119
- expect(await picker.getProperty("value")).toBe("2021-01-01");
120
- expect(spy.lastEvent.detail.value).toBe("2021-01-01");
121
- // clear input
122
- picker.setProperty("value", "");
123
- await page.waitForChanges();
124
- // dashes
125
- await input.type("2-1-2021", { delay: 50 });
126
- await page.waitForChanges();
127
- expect(await picker.getProperty("value")).toBe("2021-01-02");
128
- expect(spy.lastEvent.detail.value).toBe("2021-01-02");
129
- });
130
- });
131
- describe("mouse interaction", () => {
132
- it("should open on button click", async () => {
133
- const page = await generatePage();
134
- expect(await isCalendarOpen(page)).toBe(false);
135
- await openCalendar(page);
136
- expect(await isCalendarOpen(page)).toBe(true);
137
- });
138
- it("should close on click outside", async () => {
139
- const page = await generatePage();
140
- await openCalendar(page);
141
- expect(await isCalendarOpen(page)).toBe(true);
142
- await clickOutside(page);
143
- expect(await isCalendarOpen(page)).toBe(false);
144
- });
145
- it("supports selecting a date in the future", async () => {
146
- const page = await generatePage({ value: "2020-01-01" });
147
- await openCalendar(page);
148
- const picker = await getPicker(page);
149
- const nextMonth = await getNextMonthButton(page);
150
- const spy = await picker.spyOnEvent("duetChange");
151
- await nextMonth.click();
152
- await nextMonth.click();
153
- await nextMonth.click();
154
- await clickDay(page, "19. huhtikuuta");
155
- expect(spy).toHaveReceivedEventTimes(1);
156
- expect(spy.lastEvent.detail).toEqual({
157
- component: "duet-date-picker",
158
- value: "2020-04-19",
159
- valueAsDate: new Date(2020, 3, 19).toISOString(),
160
- });
161
- });
162
- it("supports selecting a date in the past", async () => {
163
- const page = await generatePage({ value: "2020-01-01" });
164
- await openCalendar(page);
165
- const picker = await getPicker(page);
166
- const spy = await picker.spyOnEvent("duetChange");
167
- await setMonthDropdown(page, "3");
168
- await setYearDropdown(page, "2019");
169
- await page.waitForTimeout(ANIMATION_DELAY);
170
- await clickDay(page, "19. huhtikuuta");
171
- expect(spy).toHaveReceivedEventTimes(1);
172
- expect(spy.lastEvent.detail).toEqual({
173
- component: "duet-date-picker",
174
- value: "2019-04-19",
175
- valueAsDate: new Date(2019, 3, 19).toISOString(),
176
- });
177
- });
178
- });
179
- // see: https://www.w3.org/TR/wai-aria-practices/examples/dialog-modal/datepicker-dialog.html
180
- describe("a11y/ARIA requirements", () => {
181
- describe("input", () => {
182
- it("has accessible label", async () => {
183
- const page = await generatePage({ label: "pick date" });
184
- const input = await page.find("input");
185
- const id = input.getAttribute("id");
186
- expect(id).toBeDefined();
187
- const label = await page.find(`label[for="${id}"]`);
188
- expect(label).toEqualText("pick date");
189
- });
190
- });
191
- describe("button", () => {
192
- it("has an accessible label", async () => {
193
- const page = await generatePage();
194
- const button = await getChooseDateButton(page);
195
- const element = await button.find("duet-visually-hidden");
196
- expect(element).toEqualText(i18n.fi.buttonLabel);
197
- });
198
- });
199
- describe("dialog", () => {
200
- it("meets a11y requirements", async () => {
201
- const page = await generatePage();
202
- const dialog = await getDialog(page);
203
- // has aria-modal attr
204
- expect(dialog).toBeDefined();
205
- expect(dialog).toEqualAttribute("aria-modal", "true");
206
- // has accessible label
207
- const labelledById = dialog.getAttribute("aria-labelledby");
208
- const title = await page.find(`#${labelledById}`);
209
- expect(title).toBeDefined();
210
- // announces keyboard support
211
- const instructionText = await dialog.find("duet-visually-hidden[aria-live]");
212
- expect(instructionText).toEqualText(i18n.fi.keyboardInstruction);
213
- });
214
- });
215
- describe("grid", () => {
216
- it("meets a11y requirements", async () => {
217
- const page = await generatePage({ value: "2020-01-01" });
218
- const grid = await getGrid(page);
219
- // has accessible label
220
- const labelledById = await grid.getAttribute("aria-labelledby");
221
- const title = await page.find(`#${labelledById}`);
222
- expect(title).toBeDefined();
223
- await openCalendar(page);
224
- // should be single selected element, and it should have role="gridcell"
225
- const selected = await grid.findAll(`[aria-pressed="true"]`);
226
- expect(selected.length).toBe(1);
227
- // only one button is in focus order, has accessible label, and correct text content
228
- expect(selected[0]).toEqualAttribute("tabindex", "0");
229
- expect(selected[0].innerText).toContain("1. tammikuuta");
230
- });
231
- it.todo("correctly abbreviates the shortened day names");
232
- });
233
- });
234
- describe("keyboard a11y", () => {
235
- it("closes on ESC press", async () => {
236
- const page = await generatePage();
237
- await openCalendar(page);
238
- await page.waitForTimeout(ANIMATION_DELAY);
239
- expect(await isCalendarOpen(page)).toBe(true);
240
- await page.keyboard.press("Escape");
241
- await page.waitForChanges();
242
- await page.waitForTimeout(ANIMATION_DELAY);
243
- expect(await isCalendarOpen(page)).toBe(false);
244
- });
245
- it("supports selecting a date in the future", async () => {
246
- const page = await generatePage({ value: "2020-01-01" });
247
- const picker = await getPicker(page);
248
- const spy = await picker.spyOnEvent("duetChange");
249
- // open calendar
250
- await page.keyboard.press("Tab");
251
- await page.waitForChanges();
252
- await page.keyboard.press("Tab");
253
- await page.waitForChanges();
254
- await page.keyboard.press("Enter");
255
- await page.waitForChanges();
256
- // wait for calendar to open
257
- await page.waitForTimeout(ANIMATION_DELAY);
258
- // set month to april
259
- await setMonthDropdown(page, "3");
260
- // tab to grid
261
- await page.keyboard.press("Tab");
262
- await page.waitForChanges();
263
- await page.keyboard.press("Tab");
264
- await page.waitForChanges();
265
- await page.keyboard.press("Tab");
266
- await page.waitForChanges();
267
- await page.keyboard.press("Tab");
268
- await page.waitForChanges();
269
- // select 19th of month
270
- await page.keyboard.press("ArrowDown");
271
- await page.waitForChanges();
272
- await page.keyboard.press("ArrowDown");
273
- await page.waitForChanges();
274
- await page.keyboard.press("ArrowRight");
275
- await page.waitForChanges();
276
- await page.keyboard.press("ArrowRight");
277
- await page.waitForChanges();
278
- await page.keyboard.press("ArrowRight");
279
- await page.waitForChanges();
280
- await page.keyboard.press("ArrowRight");
281
- await page.waitForChanges();
282
- await page.keyboard.press("Enter");
283
- await page.waitForChanges();
284
- expect(spy).toHaveReceivedEventTimes(1);
285
- expect(spy.lastEvent.detail).toEqual({
286
- component: "duet-date-picker",
287
- value: "2020-04-19",
288
- valueAsDate: new Date(2020, 3, 19).toISOString(),
289
- });
290
- });
291
- it("supports selecting a date in the past", async () => {
292
- const page = await generatePage({ value: "2020-01-01" });
293
- const picker = await getPicker(page);
294
- const spy = await picker.spyOnEvent("duetChange");
295
- // open calendar
296
- await page.keyboard.press("Tab");
297
- await page.waitForChanges();
298
- await page.keyboard.press("Tab");
299
- await page.waitForChanges();
300
- await page.keyboard.press("Enter");
301
- await page.waitForChanges();
302
- // wait for calendar to open
303
- await page.waitForTimeout(ANIMATION_DELAY);
304
- // select april from month dropdown
305
- await setMonthDropdown(page, "3");
306
- // tab to year dropdown, select 2019
307
- await setYearDropdown(page, "2019");
308
- // tab to grid
309
- await page.keyboard.press("Tab");
310
- await page.waitForChanges();
311
- await page.keyboard.press("Tab");
312
- await page.waitForChanges();
313
- await page.keyboard.press("Tab");
314
- await page.waitForChanges();
315
- await page.keyboard.press("Tab");
316
- await page.waitForChanges();
317
- // select date 19th of month
318
- await page.keyboard.press("ArrowDown");
319
- await page.waitForChanges();
320
- await page.keyboard.press("ArrowDown");
321
- await page.waitForChanges();
322
- await page.keyboard.press("ArrowRight");
323
- await page.waitForChanges();
324
- await page.keyboard.press("ArrowRight");
325
- await page.waitForChanges();
326
- await page.keyboard.press("ArrowRight");
327
- await page.waitForChanges();
328
- await page.keyboard.press("ArrowRight");
329
- await page.waitForChanges();
330
- await page.keyboard.press("Enter");
331
- await page.waitForChanges();
332
- expect(spy).toHaveReceivedEventTimes(1);
333
- expect(spy.lastEvent.detail).toEqual({
334
- component: "duet-date-picker",
335
- value: "2019-04-19",
336
- valueAsDate: new Date(2019, 3, 19).toISOString(),
337
- });
338
- });
339
- it.todo("moves focus to start of week on home press");
340
- it.todo("moves focus to end of week end press");
341
- it.todo("moves focus to previous month on page up press");
342
- it.todo("moves focus to next month on page down press");
343
- it.todo("moves focus to previous year on shift + page down press");
344
- it.todo("moves focus to next year on shift + page down press");
345
- });
346
- describe("events", () => {
347
- it("raises a duetBlur event when the input is blurred", async () => {
348
- const page = await generatePage();
349
- const picker = await page.find("duet-date-picker");
350
- const spy = await picker.spyOnEvent("duetBlur");
351
- await page.keyboard.press("Tab");
352
- await page.keyboard.press("Tab");
353
- expect(spy).toHaveReceivedEventTimes(1);
354
- });
355
- it("raises a duetFocus event when the input is focused", async () => {
356
- const page = await generatePage();
357
- const picker = await page.find("duet-date-picker");
358
- const spy = await picker.spyOnEvent("duetFocus");
359
- await page.keyboard.press("Tab");
360
- expect(spy).toHaveReceivedEventTimes(1);
361
- });
362
- });
363
- describe("focus management", () => {
364
- async function assertDayButtonFocused(page) {
365
- const focused = await getFocusedElement(page);
366
- const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
367
- const tabIndex = await page.evaluate((element) => element.tabIndex, focused);
368
- expect(tabIndex).toBe(0);
369
- expect(tag).toEqual("button");
370
- }
371
- async function assertCloseButtonFocused(page) {
372
- const focused = await getFocusedElement(page);
373
- const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
374
- const text = await page.evaluate((element) => element.innerText, focused);
375
- expect(text).toBe(i18n.fi.closeLabel);
376
- expect(tag).toEqual("button");
377
- }
378
- async function assertMonthDropdownFocused(page) {
379
- const focused = await getFocusedElement(page);
380
- const tag = await page.evaluate(element => element.tagName.toLowerCase(), focused);
381
- const id = await page.evaluate(element => element.id, focused);
382
- const label = await page.find(`label[for="${id}"]`);
383
- expect(label).toEqualText(i18n.fi.monthSelectLabel);
384
- expect(tag).toEqual("select");
385
- }
386
- async function assertYearDropdownFocused(page) {
387
- const focused = await getFocusedElement(page);
388
- const tag = await page.evaluate(element => element.tagName.toLowerCase(), focused);
389
- const id = await page.evaluate(element => element.id, focused);
390
- const label = await page.find(`label[for="${id}"]`);
391
- expect(label).toEqualText(i18n.fi.yearSelectLabel);
392
- expect(tag).toEqual("select");
393
- }
394
- async function assertPrevMonthFocused(page) {
395
- const focused = await getFocusedElement(page);
396
- const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
397
- const text = await page.evaluate((element) => element.innerText, focused);
398
- expect(text).toBe(i18n.fi.prevMonthLabel);
399
- expect(tag).toEqual("duet-action-button");
400
- }
401
- async function assertNextMonthFocused(page) {
402
- const focused = await getFocusedElement(page);
403
- const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
404
- const text = await page.evaluate((element) => element.innerText, focused);
405
- expect(text).toBe(i18n.fi.nextMonthLabel);
406
- expect(tag).toEqual("duet-action-button");
407
- }
408
- async function assertToggleButtonFocused(page, negate = false) {
409
- const focused = await getFocusedElement(page);
410
- const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
411
- const text = await page.evaluate((element) => element.innerText, focused);
412
- if (negate) {
413
- expect(tag).not.toEqual("button");
414
- expect(text).not.toContain(`${i18n.fi.buttonLabel}, ${i18n.fi.selected}`);
415
- }
416
- else {
417
- expect(tag).toEqual("button");
418
- expect(text).toContain(`${i18n.fi.buttonLabel}, ${i18n.fi.selected}`);
419
- }
420
- }
421
- it("traps focus in calendar", async () => {
422
- const page = await generatePage();
423
- await openCalendar(page);
424
- await page.waitForTimeout(ANIMATION_DELAY);
425
- const focusOrder = [
426
- assertMonthDropdownFocused,
427
- assertYearDropdownFocused,
428
- assertPrevMonthFocused,
429
- assertNextMonthFocused,
430
- assertDayButtonFocused,
431
- assertCloseButtonFocused,
432
- ];
433
- for (const assertion of focusOrder) {
434
- await assertion(page);
435
- await page.keyboard.press("Tab");
436
- }
437
- // should arrive back at the start
438
- const assertion = focusOrder[0];
439
- await assertion(page);
440
- });
441
- it.todo("doesn't shift focus when interacting with calendar navigation controls");
442
- it("shifts focus back to button on date select", async () => {
443
- const page = await generatePage({ value: "2020-01-01" });
444
- await openCalendar(page);
445
- await page.waitForTimeout(ANIMATION_DELAY);
446
- await clickDay(page, "10. tammikuuta");
447
- await page.waitForChanges();
448
- await assertToggleButtonFocused(page);
449
- });
450
- it("shifts focus back to button on ESC press", async () => {
451
- const page = await generatePage({ value: "2020-01-01" });
452
- await openCalendar(page);
453
- await page.waitForTimeout(ANIMATION_DELAY);
454
- await page.keyboard.press("Escape");
455
- await page.waitForChanges();
456
- await assertToggleButtonFocused(page);
457
- });
458
- it("doesn't shift focus to button on click outside", async () => {
459
- const page = await generatePage({ value: "2020-01-01" });
460
- await openCalendar(page);
461
- await page.waitForTimeout(ANIMATION_DELAY);
462
- await clickOutside(page);
463
- await assertToggleButtonFocused(page, true);
464
- });
465
- });
466
- describe("min/max support", () => {
467
- it("supports a min date", async () => {
468
- const page = await generatePage({ value: "2020-01-15", min: "2020-01-02" });
469
- const picker = await getPicker(page);
470
- const spy = await picker.spyOnEvent("duetChange");
471
- await openCalendar(page);
472
- // wait for calendar to open
473
- await page.waitForTimeout(ANIMATION_DELAY);
474
- // try clicking a day outside the range
475
- await clickDay(page, "1. tammikuuta");
476
- expect(spy).toHaveReceivedEventTimes(0);
477
- // click a day inside the range
478
- await clickDay(page, "2. tammikuuta");
479
- expect(spy).toHaveReceivedEventTimes(1);
480
- expect(spy.lastEvent.detail).toEqual({
481
- component: "duet-date-picker",
482
- value: "2020-01-02",
483
- valueAsDate: new Date(2020, 0, 2).toISOString(),
484
- });
485
- });
486
- it("supports a max date", async () => {
487
- const page = await generatePage({ value: "2020-01-15", max: "2020-01-30" });
488
- const picker = await getPicker(page);
489
- const spy = await picker.spyOnEvent("duetChange");
490
- await openCalendar(page);
491
- // wait for calendar to open
492
- await page.waitForTimeout(ANIMATION_DELAY);
493
- // try clicking a day outside the range
494
- await clickDay(page, "31. tammikuuta");
495
- expect(spy).toHaveReceivedEventTimes(0);
496
- // click a day inside the range
497
- await clickDay(page, "30. tammikuuta");
498
- expect(spy).toHaveReceivedEventTimes(1);
499
- expect(spy.lastEvent.detail).toEqual({
500
- component: "duet-date-picker",
501
- value: "2020-01-30",
502
- valueAsDate: new Date(2020, 0, 30).toISOString(),
503
- });
504
- });
505
- it("supports min and max dates", async () => {
506
- const page = await generatePage({ value: "2020-01-15", min: "2020-01-02", max: "2020-01-30" });
507
- const picker = await getPicker(page);
508
- const spy = await picker.spyOnEvent("duetChange");
509
- await openCalendar(page);
510
- // wait for calendar to open
511
- await page.waitForTimeout(ANIMATION_DELAY);
512
- // try clicking a day less than min
513
- await clickDay(page, "1. tammikuuta");
514
- expect(spy).toHaveReceivedEventTimes(0);
515
- // try clicking a day greater than max
516
- await clickDay(page, "31. tammikuuta");
517
- expect(spy).toHaveReceivedEventTimes(0);
518
- // click a day inside the range
519
- await clickDay(page, "30. tammikuuta");
520
- expect(spy).toHaveReceivedEventTimes(1);
521
- expect(spy.lastEvent.detail).toEqual({
522
- component: "duet-date-picker",
523
- value: "2020-01-30",
524
- valueAsDate: new Date(2020, 0, 30).toISOString(),
525
- });
526
- });
527
- it("disables prev month button if same month and year as min", async () => {
528
- const page = await generatePage({ value: "2020-04-19", min: "2020-04-01" });
529
- await openCalendar(page);
530
- const prevMonthButton = await getPrevMonthButton(page);
531
- expect(prevMonthButton).toHaveAttribute("disabled");
532
- });
533
- it("disables next month button if same month and year as max", async () => {
534
- const page = await generatePage({ value: "2020-04-19", max: "2020-04-30" });
535
- await openCalendar(page);
536
- const nextMonthButton = await getNextMonthButton(page);
537
- expect(nextMonthButton).toHaveAttribute("disabled");
81
+ it("should render a date picker", async () => {
82
+ const page = await createPage(`<duet-date-picker value="2020-06-16"></duet-date-picker>`);
83
+ const component = await getPicker(page);
84
+ expect(component).not.toBeNull();
85
+ });
86
+ describe("user input", () => {
87
+ it("does not reformat input if date doesn't have leading zeroes", async () => {
88
+ const page = await generatePage();
89
+ const picker = await getPicker(page);
90
+ const input = await page.find("duet-input input");
91
+ const spy = await picker.spyOnEvent("duetChange");
92
+ await input.type("1.2.2021", { delay: 50 });
93
+ await page.waitForChanges();
94
+ // the input's value should not get formatted with leading zeroes
95
+ expect(await input.getProperty("value")).toBe("1.2.2021");
96
+ // but we should still emit correctly formatted ISO dates
97
+ expect(await picker.getProperty("value")).toBe("2021-02-01");
98
+ expect(spy).toHaveReceivedEventTimes(1);
99
+ expect(spy.lastEvent.detail.value).toBe("2021-02-01");
100
+ });
101
+ it("allows input to be cleared by setting value to empty string", async () => {
102
+ const page = await generatePage();
103
+ const picker = await getPicker(page);
104
+ const input = await page.find("duet-input input");
105
+ await input.type("1.2.2021", { delay: 50 });
106
+ await page.waitForChanges();
107
+ picker.setProperty("value", "");
108
+ await page.waitForChanges();
109
+ expect(await input.getProperty("value")).toBe("");
110
+ });
111
+ it("supports dashes and slashes as separators", async () => {
112
+ const page = await generatePage();
113
+ const picker = await getPicker(page);
114
+ const input = await page.find("duet-input input");
115
+ const spy = await picker.spyOnEvent("duetChange");
116
+ // slashes
117
+ await input.type("1/1/2021", { delay: 50 });
118
+ await page.waitForChanges();
119
+ expect(await picker.getProperty("value")).toBe("2021-01-01");
120
+ expect(spy.lastEvent.detail.value).toBe("2021-01-01");
121
+ // clear input
122
+ picker.setProperty("value", "");
123
+ await page.waitForChanges();
124
+ // dashes
125
+ await input.type("2-1-2021", { delay: 50 });
126
+ await page.waitForChanges();
127
+ expect(await picker.getProperty("value")).toBe("2021-01-02");
128
+ expect(spy.lastEvent.detail.value).toBe("2021-01-02");
129
+ });
538
130
  });
539
- it("does not disable prev/next buttons when only month value (but not year) is same as min and max", async () => {
540
- // there was a bug whereby both buttons would be disabled if the min/max/selected date
541
- // had the same month (here: 4), but different years. this tests ensures no regression
542
- const page = await generatePage({ value: "2020-04-19", min: "2019-04-19", max: "2021-04-19" });
543
- await openCalendar(page);
544
- const prevMonthButton = await getPrevMonthButton(page);
545
- const nextMonthButton = await getNextMonthButton(page);
546
- expect(prevMonthButton).not.toHaveAttribute("disabled");
547
- expect(nextMonthButton).not.toHaveAttribute("disabled");
131
+ describe("mouse interaction", () => {
132
+ it("should open on button click", async () => {
133
+ const page = await generatePage();
134
+ expect(await isCalendarOpen(page)).toBe(false);
135
+ await openCalendar(page);
136
+ expect(await isCalendarOpen(page)).toBe(true);
137
+ });
138
+ it("should close on click outside", async () => {
139
+ const page = await generatePage();
140
+ await openCalendar(page);
141
+ expect(await isCalendarOpen(page)).toBe(true);
142
+ await clickOutside(page);
143
+ expect(await isCalendarOpen(page)).toBe(false);
144
+ });
145
+ it("supports selecting a date in the future", async () => {
146
+ const page = await generatePage({ value: "2020-01-01" });
147
+ await openCalendar(page);
148
+ const picker = await getPicker(page);
149
+ const nextMonth = await getNextMonthButton(page);
150
+ const spy = await picker.spyOnEvent("duetChange");
151
+ await nextMonth.click();
152
+ await nextMonth.click();
153
+ await nextMonth.click();
154
+ await clickDay(page, "19. huhtikuuta");
155
+ expect(spy).toHaveReceivedEventTimes(1);
156
+ expect(spy.lastEvent.detail).toEqual({
157
+ component: "duet-date-picker",
158
+ value: "2020-04-19",
159
+ valueAsDate: new Date(2020, 3, 19).toISOString(),
160
+ });
161
+ });
162
+ it("supports selecting a date in the past", async () => {
163
+ const page = await generatePage({ value: "2020-01-01" });
164
+ await openCalendar(page);
165
+ const picker = await getPicker(page);
166
+ const spy = await picker.spyOnEvent("duetChange");
167
+ await setMonthDropdown(page, "3");
168
+ await setYearDropdown(page, "2019");
169
+ await page.waitForTimeout(ANIMATION_DELAY);
170
+ await clickDay(page, "19. huhtikuuta");
171
+ expect(spy).toHaveReceivedEventTimes(1);
172
+ expect(spy.lastEvent.detail).toEqual({
173
+ component: "duet-date-picker",
174
+ value: "2019-04-19",
175
+ valueAsDate: new Date(2019, 3, 19).toISOString(),
176
+ });
177
+ });
548
178
  });
549
- it("respects min/max dates when generating year dropdown", async () => {
550
- const page = await generatePage({ value: "2020-04-19", min: "2019-04-19", max: "2021-04-19" });
551
- const allowedYears = await page.$eval(".duet-date-year-select", (select) => {
552
- return Array.from(select.options).map(option => option.value);
553
- });
554
- expect(allowedYears).toEqual(["2019", "2020", "2021"]);
179
+ // see: https://www.w3.org/TR/wai-aria-practices/examples/dialog-modal/datepicker-dialog.html
180
+ describe("a11y/ARIA requirements", () => {
181
+ describe("input", () => {
182
+ it("has accessible label", async () => {
183
+ const page = await generatePage({ label: "pick date" });
184
+ const input = await page.find("input");
185
+ const id = input.getAttribute("id");
186
+ expect(id).toBeDefined();
187
+ const label = await page.find(`label[for="${id}"]`);
188
+ expect(label).toEqualText("pick date");
189
+ });
190
+ });
191
+ describe("button", () => {
192
+ it("has an accessible label", async () => {
193
+ const page = await generatePage();
194
+ const button = await getChooseDateButton(page);
195
+ const element = await button.find("duet-visually-hidden");
196
+ expect(element).toEqualText(i18n.fi.buttonLabel);
197
+ });
198
+ });
199
+ describe("dialog", () => {
200
+ it("meets a11y requirements", async () => {
201
+ const page = await generatePage();
202
+ const dialog = await getDialog(page);
203
+ // has aria-modal attr
204
+ expect(dialog).toBeDefined();
205
+ expect(dialog).toEqualAttribute("aria-modal", "true");
206
+ // has accessible label
207
+ const labelledById = dialog.getAttribute("aria-labelledby");
208
+ const title = await page.find(`#${labelledById}`);
209
+ expect(title).toBeDefined();
210
+ // announces keyboard support
211
+ const instructionText = await dialog.find("duet-visually-hidden[aria-live]");
212
+ expect(instructionText).toEqualText(i18n.fi.keyboardInstruction);
213
+ });
214
+ });
215
+ describe("grid", () => {
216
+ it("meets a11y requirements", async () => {
217
+ const page = await generatePage({ value: "2020-01-01" });
218
+ const grid = await getGrid(page);
219
+ // has accessible label
220
+ const labelledById = await grid.getAttribute("aria-labelledby");
221
+ const title = await page.find(`#${labelledById}`);
222
+ expect(title).toBeDefined();
223
+ await openCalendar(page);
224
+ // should be single selected element, and it should have role="gridcell"
225
+ const selected = await grid.findAll(`[aria-pressed="true"]`);
226
+ expect(selected.length).toBe(1);
227
+ // only one button is in focus order, has accessible label, and correct text content
228
+ expect(selected[0]).toEqualAttribute("tabindex", "0");
229
+ expect(selected[0].innerText).toContain("1. tammikuuta");
230
+ });
231
+ it.todo("correctly abbreviates the shortened day names");
232
+ });
555
233
  });
556
- it("respects min/max dates when generating month dropdown", async () => {
557
- const page = await generatePage({ value: "2020-04-19", min: "2019-04-01", max: "2020-05-31" });
558
- await openCalendar(page);
559
- function getAllowedMonths() {
560
- return page.$eval(".duet-date-month-select", (select) => {
561
- return Array.from(select.options)
562
- .filter(option => !option.disabled)
563
- .map(option => option.value);
564
- });
565
- }
566
- // in 2020, January - May is allowed
567
- let allowedMonths = await getAllowedMonths();
568
- expect(allowedMonths).toEqual(["0", "1", "2", "3", "4"]);
569
- await setYearDropdown(page, "2019");
570
- // in 2019, April - December is allowed
571
- allowedMonths = await getAllowedMonths();
572
- expect(allowedMonths).toEqual(["3", "4", "5", "6", "7", "8", "9", "10", "11"]);
234
+ describe("keyboard a11y", () => {
235
+ it("closes on ESC press", async () => {
236
+ const page = await generatePage();
237
+ await openCalendar(page);
238
+ await page.waitForTimeout(ANIMATION_DELAY);
239
+ expect(await isCalendarOpen(page)).toBe(true);
240
+ await page.keyboard.press("Escape");
241
+ await page.waitForChanges();
242
+ await page.waitForTimeout(ANIMATION_DELAY);
243
+ expect(await isCalendarOpen(page)).toBe(false);
244
+ });
245
+ it("supports selecting a date in the future", async () => {
246
+ const page = await generatePage({ value: "2020-01-01" });
247
+ const picker = await getPicker(page);
248
+ const spy = await picker.spyOnEvent("duetChange");
249
+ // open calendar
250
+ await page.keyboard.press("Tab");
251
+ await page.waitForChanges();
252
+ await page.keyboard.press("Tab");
253
+ await page.waitForChanges();
254
+ await page.keyboard.press("Enter");
255
+ await page.waitForChanges();
256
+ // wait for calendar to open
257
+ await page.waitForTimeout(ANIMATION_DELAY);
258
+ // set month to april
259
+ await setMonthDropdown(page, "3");
260
+ // tab to grid
261
+ await page.keyboard.press("Tab");
262
+ await page.waitForChanges();
263
+ await page.keyboard.press("Tab");
264
+ await page.waitForChanges();
265
+ await page.keyboard.press("Tab");
266
+ await page.waitForChanges();
267
+ await page.keyboard.press("Tab");
268
+ await page.waitForChanges();
269
+ // select 19th of month
270
+ await page.keyboard.press("ArrowDown");
271
+ await page.waitForChanges();
272
+ await page.keyboard.press("ArrowDown");
273
+ await page.waitForChanges();
274
+ await page.keyboard.press("ArrowRight");
275
+ await page.waitForChanges();
276
+ await page.keyboard.press("ArrowRight");
277
+ await page.waitForChanges();
278
+ await page.keyboard.press("ArrowRight");
279
+ await page.waitForChanges();
280
+ await page.keyboard.press("ArrowRight");
281
+ await page.waitForChanges();
282
+ await page.keyboard.press("Enter");
283
+ await page.waitForChanges();
284
+ expect(spy).toHaveReceivedEventTimes(1);
285
+ expect(spy.lastEvent.detail).toEqual({
286
+ component: "duet-date-picker",
287
+ value: "2020-04-19",
288
+ valueAsDate: new Date(2020, 3, 19).toISOString(),
289
+ });
290
+ });
291
+ it("supports selecting a date in the past", async () => {
292
+ const page = await generatePage({ value: "2020-01-01" });
293
+ const picker = await getPicker(page);
294
+ const spy = await picker.spyOnEvent("duetChange");
295
+ // open calendar
296
+ await page.keyboard.press("Tab");
297
+ await page.waitForChanges();
298
+ await page.keyboard.press("Tab");
299
+ await page.waitForChanges();
300
+ await page.keyboard.press("Enter");
301
+ await page.waitForChanges();
302
+ // wait for calendar to open
303
+ await page.waitForTimeout(ANIMATION_DELAY);
304
+ // select april from month dropdown
305
+ await setMonthDropdown(page, "3");
306
+ // tab to year dropdown, select 2019
307
+ await setYearDropdown(page, "2019");
308
+ // tab to grid
309
+ await page.keyboard.press("Tab");
310
+ await page.waitForChanges();
311
+ await page.keyboard.press("Tab");
312
+ await page.waitForChanges();
313
+ await page.keyboard.press("Tab");
314
+ await page.waitForChanges();
315
+ await page.keyboard.press("Tab");
316
+ await page.waitForChanges();
317
+ // select date 19th of month
318
+ await page.keyboard.press("ArrowDown");
319
+ await page.waitForChanges();
320
+ await page.keyboard.press("ArrowDown");
321
+ await page.waitForChanges();
322
+ await page.keyboard.press("ArrowRight");
323
+ await page.waitForChanges();
324
+ await page.keyboard.press("ArrowRight");
325
+ await page.waitForChanges();
326
+ await page.keyboard.press("ArrowRight");
327
+ await page.waitForChanges();
328
+ await page.keyboard.press("ArrowRight");
329
+ await page.waitForChanges();
330
+ await page.keyboard.press("Enter");
331
+ await page.waitForChanges();
332
+ expect(spy).toHaveReceivedEventTimes(1);
333
+ expect(spy.lastEvent.detail).toEqual({
334
+ component: "duet-date-picker",
335
+ value: "2019-04-19",
336
+ valueAsDate: new Date(2019, 3, 19).toISOString(),
337
+ });
338
+ });
339
+ it.todo("moves focus to start of week on home press");
340
+ it.todo("moves focus to end of week end press");
341
+ it.todo("moves focus to previous month on page up press");
342
+ it.todo("moves focus to next month on page down press");
343
+ it.todo("moves focus to previous year on shift + page down press");
344
+ it.todo("moves focus to next year on shift + page down press");
345
+ });
346
+ describe("events", () => {
347
+ it("raises a duetBlur event when the input is blurred", async () => {
348
+ const page = await generatePage();
349
+ const picker = await page.find("duet-date-picker");
350
+ const spy = await picker.spyOnEvent("duetBlur");
351
+ await page.keyboard.press("Tab");
352
+ await page.keyboard.press("Tab");
353
+ expect(spy).toHaveReceivedEventTimes(1);
354
+ });
355
+ it("raises a duetFocus event when the input is focused", async () => {
356
+ const page = await generatePage();
357
+ const picker = await page.find("duet-date-picker");
358
+ const spy = await picker.spyOnEvent("duetFocus");
359
+ await page.keyboard.press("Tab");
360
+ expect(spy).toHaveReceivedEventTimes(1);
361
+ });
573
362
  });
574
- });
575
- describe("methods", () => {
576
- it("should open calendar on show()", async () => {
577
- const page = await generatePage();
578
- const picker = await page.find("duet-date-picker");
579
- expect(await isCalendarOpen(page)).toBe(false);
580
- await picker.callMethod("show");
581
- await page.waitForChanges();
582
- expect(await isCalendarOpen(page)).toBe(true);
363
+ describe("focus management", () => {
364
+ async function assertDayButtonFocused(page) {
365
+ const focused = await getFocusedElement(page);
366
+ const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
367
+ const tabIndex = await page.evaluate((element) => element.tabIndex, focused);
368
+ expect(tabIndex).toBe(0);
369
+ expect(tag).toEqual("button");
370
+ }
371
+ async function assertCloseButtonFocused(page) {
372
+ const focused = await getFocusedElement(page);
373
+ const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
374
+ const text = await page.evaluate((element) => element.innerText, focused);
375
+ expect(text).toBe(i18n.fi.closeLabel);
376
+ expect(tag).toEqual("button");
377
+ }
378
+ async function assertMonthDropdownFocused(page) {
379
+ const focused = await getFocusedElement(page);
380
+ const tag = await page.evaluate(element => element.tagName.toLowerCase(), focused);
381
+ const id = await page.evaluate(element => element.id, focused);
382
+ const label = await page.find(`label[for="${id}"]`);
383
+ expect(label).toEqualText(i18n.fi.monthSelectLabel);
384
+ expect(tag).toEqual("select");
385
+ }
386
+ async function assertYearDropdownFocused(page) {
387
+ const focused = await getFocusedElement(page);
388
+ const tag = await page.evaluate(element => element.tagName.toLowerCase(), focused);
389
+ const id = await page.evaluate(element => element.id, focused);
390
+ const label = await page.find(`label[for="${id}"]`);
391
+ expect(label).toEqualText(i18n.fi.yearSelectLabel);
392
+ expect(tag).toEqual("select");
393
+ }
394
+ async function assertPrevMonthFocused(page) {
395
+ const focused = await getFocusedElement(page);
396
+ const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
397
+ const text = await page.evaluate((element) => element.innerText, focused);
398
+ expect(text).toBe(i18n.fi.prevMonthLabel);
399
+ expect(tag).toEqual("duet-action-button");
400
+ }
401
+ async function assertNextMonthFocused(page) {
402
+ const focused = await getFocusedElement(page);
403
+ const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
404
+ const text = await page.evaluate((element) => element.innerText, focused);
405
+ expect(text).toBe(i18n.fi.nextMonthLabel);
406
+ expect(tag).toEqual("duet-action-button");
407
+ }
408
+ async function assertToggleButtonFocused(page, negate = false) {
409
+ const focused = await getFocusedElement(page);
410
+ const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
411
+ const text = await page.evaluate((element) => element.innerText, focused);
412
+ if (negate) {
413
+ expect(tag).not.toEqual("button");
414
+ expect(text).not.toContain(`${i18n.fi.buttonLabel}, ${i18n.fi.selected}`);
415
+ }
416
+ else {
417
+ expect(tag).toEqual("button");
418
+ expect(text).toContain(`${i18n.fi.buttonLabel}, ${i18n.fi.selected}`);
419
+ }
420
+ }
421
+ it("traps focus in calendar", async () => {
422
+ const page = await generatePage();
423
+ await openCalendar(page);
424
+ await page.waitForTimeout(ANIMATION_DELAY);
425
+ const focusOrder = [
426
+ assertMonthDropdownFocused,
427
+ assertYearDropdownFocused,
428
+ assertPrevMonthFocused,
429
+ assertNextMonthFocused,
430
+ assertDayButtonFocused,
431
+ assertCloseButtonFocused,
432
+ ];
433
+ for (const assertion of focusOrder) {
434
+ await assertion(page);
435
+ await page.keyboard.press("Tab");
436
+ }
437
+ // should arrive back at the start
438
+ const assertion = focusOrder[0];
439
+ await assertion(page);
440
+ });
441
+ it.todo("doesn't shift focus when interacting with calendar navigation controls");
442
+ it("shifts focus back to button on date select", async () => {
443
+ const page = await generatePage({ value: "2020-01-01" });
444
+ await openCalendar(page);
445
+ await page.waitForTimeout(ANIMATION_DELAY);
446
+ await clickDay(page, "10. tammikuuta");
447
+ await page.waitForChanges();
448
+ await assertToggleButtonFocused(page);
449
+ });
450
+ it("shifts focus back to button on ESC press", async () => {
451
+ const page = await generatePage({ value: "2020-01-01" });
452
+ await openCalendar(page);
453
+ await page.waitForTimeout(ANIMATION_DELAY);
454
+ await page.keyboard.press("Escape");
455
+ await page.waitForChanges();
456
+ await assertToggleButtonFocused(page);
457
+ });
458
+ it("doesn't shift focus to button on click outside", async () => {
459
+ const page = await generatePage({ value: "2020-01-01" });
460
+ await openCalendar(page);
461
+ await page.waitForTimeout(ANIMATION_DELAY);
462
+ await clickOutside(page);
463
+ await assertToggleButtonFocused(page, true);
464
+ });
583
465
  });
584
- it("should close calendar on hide()", async () => {
585
- const page = await generatePage();
586
- const picker = await page.find("duet-date-picker");
587
- await picker.callMethod("show");
588
- await page.waitForChanges();
589
- expect(await isCalendarOpen(page)).toBe(true);
590
- await picker.callMethod("hide");
591
- await page.waitForChanges();
592
- const dialog = await getDialog(page);
593
- await dialog.waitForNotVisible();
594
- expect(await isCalendarOpen(page)).toBe(false);
466
+ describe("min/max support", () => {
467
+ it("supports a min date", async () => {
468
+ const page = await generatePage({ value: "2020-01-15", min: "2020-01-02" });
469
+ const picker = await getPicker(page);
470
+ const spy = await picker.spyOnEvent("duetChange");
471
+ await openCalendar(page);
472
+ // wait for calendar to open
473
+ await page.waitForTimeout(ANIMATION_DELAY);
474
+ // try clicking a day outside the range
475
+ await clickDay(page, "1. tammikuuta");
476
+ expect(spy).toHaveReceivedEventTimes(0);
477
+ // click a day inside the range
478
+ await clickDay(page, "2. tammikuuta");
479
+ expect(spy).toHaveReceivedEventTimes(1);
480
+ expect(spy.lastEvent.detail).toEqual({
481
+ component: "duet-date-picker",
482
+ value: "2020-01-02",
483
+ valueAsDate: new Date(2020, 0, 2).toISOString(),
484
+ });
485
+ });
486
+ it("supports a max date", async () => {
487
+ const page = await generatePage({ value: "2020-01-15", max: "2020-01-30" });
488
+ const picker = await getPicker(page);
489
+ const spy = await picker.spyOnEvent("duetChange");
490
+ await openCalendar(page);
491
+ // wait for calendar to open
492
+ await page.waitForTimeout(ANIMATION_DELAY);
493
+ // try clicking a day outside the range
494
+ await clickDay(page, "31. tammikuuta");
495
+ expect(spy).toHaveReceivedEventTimes(0);
496
+ // click a day inside the range
497
+ await clickDay(page, "30. tammikuuta");
498
+ expect(spy).toHaveReceivedEventTimes(1);
499
+ expect(spy.lastEvent.detail).toEqual({
500
+ component: "duet-date-picker",
501
+ value: "2020-01-30",
502
+ valueAsDate: new Date(2020, 0, 30).toISOString(),
503
+ });
504
+ });
505
+ it("supports min and max dates", async () => {
506
+ const page = await generatePage({ value: "2020-01-15", min: "2020-01-02", max: "2020-01-30" });
507
+ const picker = await getPicker(page);
508
+ const spy = await picker.spyOnEvent("duetChange");
509
+ await openCalendar(page);
510
+ // wait for calendar to open
511
+ await page.waitForTimeout(ANIMATION_DELAY);
512
+ // try clicking a day less than min
513
+ await clickDay(page, "1. tammikuuta");
514
+ expect(spy).toHaveReceivedEventTimes(0);
515
+ // try clicking a day greater than max
516
+ await clickDay(page, "31. tammikuuta");
517
+ expect(spy).toHaveReceivedEventTimes(0);
518
+ // click a day inside the range
519
+ await clickDay(page, "30. tammikuuta");
520
+ expect(spy).toHaveReceivedEventTimes(1);
521
+ expect(spy.lastEvent.detail).toEqual({
522
+ component: "duet-date-picker",
523
+ value: "2020-01-30",
524
+ valueAsDate: new Date(2020, 0, 30).toISOString(),
525
+ });
526
+ });
527
+ it("disables prev month button if same month and year as min", async () => {
528
+ const page = await generatePage({ value: "2020-04-19", min: "2020-04-01" });
529
+ await openCalendar(page);
530
+ const prevMonthButton = await getPrevMonthButton(page);
531
+ expect(prevMonthButton).toHaveAttribute("disabled");
532
+ });
533
+ it("disables next month button if same month and year as max", async () => {
534
+ const page = await generatePage({ value: "2020-04-19", max: "2020-04-30" });
535
+ await openCalendar(page);
536
+ const nextMonthButton = await getNextMonthButton(page);
537
+ expect(nextMonthButton).toHaveAttribute("disabled");
538
+ });
539
+ it("does not disable prev/next buttons when only month value (but not year) is same as min and max", async () => {
540
+ // there was a bug whereby both buttons would be disabled if the min/max/selected date
541
+ // had the same month (here: 4), but different years. this tests ensures no regression
542
+ const page = await generatePage({ value: "2020-04-19", min: "2019-04-19", max: "2021-04-19" });
543
+ await openCalendar(page);
544
+ const prevMonthButton = await getPrevMonthButton(page);
545
+ const nextMonthButton = await getNextMonthButton(page);
546
+ expect(prevMonthButton).not.toHaveAttribute("disabled");
547
+ expect(nextMonthButton).not.toHaveAttribute("disabled");
548
+ });
549
+ it("respects min/max dates when generating year dropdown", async () => {
550
+ const page = await generatePage({ value: "2020-04-19", min: "2019-04-19", max: "2021-04-19" });
551
+ const allowedYears = await page.$eval(".duet-date-year-select", (select) => {
552
+ return Array.from(select.options).map(option => option.value);
553
+ });
554
+ expect(allowedYears).toEqual(["2019", "2020", "2021"]);
555
+ });
556
+ it("respects min/max dates when generating month dropdown", async () => {
557
+ const page = await generatePage({ value: "2020-04-19", min: "2019-04-01", max: "2020-05-31" });
558
+ await openCalendar(page);
559
+ function getAllowedMonths() {
560
+ return page.$eval(".duet-date-month-select", (select) => {
561
+ return Array.from(select.options)
562
+ .filter(option => !option.disabled)
563
+ .map(option => option.value);
564
+ });
565
+ }
566
+ // in 2020, January - May is allowed
567
+ let allowedMonths = await getAllowedMonths();
568
+ expect(allowedMonths).toEqual(["0", "1", "2", "3", "4"]);
569
+ await setYearDropdown(page, "2019");
570
+ // in 2019, April - December is allowed
571
+ allowedMonths = await getAllowedMonths();
572
+ expect(allowedMonths).toEqual(["3", "4", "5", "6", "7", "8", "9", "10", "11"]);
573
+ });
595
574
  });
596
- it("should focus input on setFocus()", async () => {
597
- const page = await generatePage({ label: "test label" });
598
- const picker = await page.find("duet-date-picker");
599
- await picker.callMethod("setFocus");
600
- await page.waitForChanges();
601
- const focused = await getFocusedElement(page);
602
- const id = await page.evaluate(element => element.id, focused);
603
- const label = await page.find(`label[for="${id}"]`);
604
- expect(label).toEqualText("test label");
575
+ describe("methods", () => {
576
+ it("should open calendar on show()", async () => {
577
+ const page = await generatePage();
578
+ const picker = await page.find("duet-date-picker");
579
+ expect(await isCalendarOpen(page)).toBe(false);
580
+ await picker.callMethod("show");
581
+ await page.waitForChanges();
582
+ expect(await isCalendarOpen(page)).toBe(true);
583
+ });
584
+ it("should close calendar on hide()", async () => {
585
+ const page = await generatePage();
586
+ const picker = await page.find("duet-date-picker");
587
+ await picker.callMethod("show");
588
+ await page.waitForChanges();
589
+ expect(await isCalendarOpen(page)).toBe(true);
590
+ await picker.callMethod("hide");
591
+ await page.waitForChanges();
592
+ const dialog = await getDialog(page);
593
+ await dialog.waitForNotVisible();
594
+ expect(await isCalendarOpen(page)).toBe(false);
595
+ });
596
+ it("should focus input on setFocus()", async () => {
597
+ const page = await generatePage({ label: "test label" });
598
+ const picker = await page.find("duet-date-picker");
599
+ await picker.callMethod("setFocus");
600
+ await page.waitForChanges();
601
+ const focused = await getFocusedElement(page);
602
+ const id = await page.evaluate(element => element.id, focused);
603
+ const label = await page.find(`label[for="${id}"]`);
604
+ expect(label).toEqualText("test label");
605
+ });
605
606
  });
606
- });
607
- describe("form interaction", () => {
608
- it("supports required attribute", async () => {
609
- const page = await createPage(`
607
+ describe("form interaction", () => {
608
+ it("supports required attribute", async () => {
609
+ const page = await createPage(`
610
610
  <form>
611
611
  <duet-date-picker required></duet-date-picker>
612
612
  <button type="submit">submit</button>
613
613
  </form>
614
614
  `);
615
- const picker = await getPicker(page);
616
- const button = await page.find("button[type='submit']");
617
- const form = await page.find("form");
618
- const spy = await form.spyOnEvent("submit");
619
- await button.click();
620
- await page.waitForChanges();
621
- expect(spy).toHaveReceivedEventTimes(0);
622
- picker.setProperty("value", "2020-01-01");
623
- await page.waitForChanges();
624
- await button.click();
625
- expect(spy).toHaveReceivedEventTimes(1);
626
- });
627
- it("always submits value as ISO date", async () => {
628
- const page = await createPage(`
615
+ const picker = await getPicker(page);
616
+ const button = await page.find("button[type='submit']");
617
+ const form = await page.find("form");
618
+ const spy = await form.spyOnEvent("submit");
619
+ await button.click();
620
+ await page.waitForChanges();
621
+ expect(spy).toHaveReceivedEventTimes(0);
622
+ picker.setProperty("value", "2020-01-01");
623
+ await page.waitForChanges();
624
+ await button.click();
625
+ expect(spy).toHaveReceivedEventTimes(1);
626
+ });
627
+ it("always submits value as ISO date", async () => {
628
+ const page = await createPage(`
629
629
  <form>
630
630
  <duet-date-picker name="test"></duet-date-picker>
631
631
  <button type="submit">submit</button>
632
632
  </form>
633
633
  `);
634
- const picker = await getPicker(page);
635
- const input = await getInput(page);
636
- picker.setProperty("value", "2020-01-01");
637
- await page.waitForChanges();
638
- // submitted value should be ISO format
639
- const submittedValue = await page.$eval("form", (form) => new FormData(form).get("test"));
640
- expect(submittedValue).toEqual("2020-01-01");
641
- // whilst the displayed value should be Finnish format
642
- expect(await input.getProperty("value")).toEqual("01.01.2020");
634
+ const picker = await getPicker(page);
635
+ const input = await getInput(page);
636
+ picker.setProperty("value", "2020-01-01");
637
+ await page.waitForChanges();
638
+ // submitted value should be ISO format
639
+ const submittedValue = await page.$eval("form", (form) => new FormData(form).get("test"));
640
+ expect(submittedValue).toEqual("2020-01-01");
641
+ // whilst the displayed value should be Finnish format
642
+ expect(await input.getProperty("value")).toEqual("01.01.2020");
643
+ });
643
644
  });
644
- });
645
- describe("constraint validation", () => {
646
- test.each `
645
+ describe("constraint validation", () => {
646
+ test.each `
647
647
  input | required | min | max | valueMissing | badInput | rangeUnderflow | rangeOverflow
648
648
  ${""} | ${false} | ${""} | ${""} | ${false} | ${false} | ${false} | ${false}
649
649
  ${""} | ${true} | ${""} | ${""} | ${true} | ${false} | ${false} | ${false}
@@ -653,41 +653,41 @@ describe("duet-date-picker", () => {
653
653
  ${"01.01.2023"} | ${true} | ${"2021-01-01"} | ${"2022-01-01"} | ${false} | ${false} | ${false} | ${true}
654
654
  ${"01.01.2021"} | ${true} | ${"2021-01-01"} | ${"2022-01-01"} | ${false} | ${false} | ${false} | ${false}
655
655
  `("when '$input' is entered, required is '$required', min is '$min', max is '$max', then valueMissing is $valueMissing, badInput is $badInput, rangerOverflow is $rangeOverflow, rangeUnderflow is $rangeUnderflow", async ({ input, required, min, max, valueMissing, badInput, rangeUnderflow, rangeOverflow }) => {
656
- const attrs = Object.entries({ min, max, required })
657
- .filter(([, value]) => value)
658
- .map(([attr, value]) => `${attr}="${value}"`)
659
- .join(" ");
660
- const page = await createPage(`
656
+ const attrs = Object.entries({ min, max, required })
657
+ .filter(([, value]) => value)
658
+ .map(([attr, value]) => `${attr}="${value}"`)
659
+ .join(" ");
660
+ const page = await createPage(`
661
661
  <duet-date-picker ${attrs}></duet-date-picker>
662
662
  <input type="date" ${attrs} />
663
663
  `);
664
- await page.type(`duet-date-picker input[type="text"]`, input, { delay: 20 });
665
- const duetValidity = await page.$eval(`duet-date-picker`, ({ validity }) => validity);
666
- await page.type(`input[type="date"]`, input.replace(".", ""), { delay: 20 });
667
- // have to manually copy properties into new object,
668
- // since native ValidityState doesn't support JSON serialization
669
- const nativeValidity = await page.$eval(`input[type="date"]`, ({ validity }) => {
670
- const result = {};
671
- for (const prop in validity) {
672
- result[prop] = validity[prop];
673
- }
674
- return result;
675
- });
676
- const expected = {
677
- patternMismatch: false,
678
- customError: false,
679
- stepMismatch: false,
680
- tooLong: false,
681
- tooShort: false,
682
- typeMismatch: false,
683
- valueMissing,
684
- badInput,
685
- rangeUnderflow,
686
- rangeOverflow,
687
- valid: !valueMissing && !badInput && !rangeUnderflow && !rangeOverflow,
688
- };
689
- expect(duetValidity).toEqual(expected);
690
- expect(nativeValidity).toEqual(expected);
664
+ await page.type(`duet-date-picker input[type="text"]`, input, { delay: 20 });
665
+ const duetValidity = await page.$eval(`duet-date-picker`, ({ validity }) => validity);
666
+ await page.type(`input[type="date"]`, input.replace(".", ""), { delay: 20 });
667
+ // have to manually copy properties into new object,
668
+ // since native ValidityState doesn't support JSON serialization
669
+ const nativeValidity = await page.$eval(`input[type="date"]`, ({ validity }) => {
670
+ const result = {};
671
+ for (const prop in validity) {
672
+ result[prop] = validity[prop];
673
+ }
674
+ return result;
675
+ });
676
+ const expected = {
677
+ patternMismatch: false,
678
+ customError: false,
679
+ stepMismatch: false,
680
+ tooLong: false,
681
+ tooShort: false,
682
+ typeMismatch: false,
683
+ valueMissing,
684
+ badInput,
685
+ rangeUnderflow,
686
+ rangeOverflow,
687
+ valid: !valueMissing && !badInput && !rangeUnderflow && !rangeOverflow,
688
+ };
689
+ expect(duetValidity).toEqual(expected);
690
+ expect(nativeValidity).toEqual(expected);
691
+ });
691
692
  });
692
- });
693
693
  });