@six-group/ui-library 4.0.4 → 4.1.1

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 (1087) hide show
  1. package/dist/cjs/error-messages-6e8049a4.js +119 -0
  2. package/dist/cjs/error-messages-6e8049a4.js.map +1 -0
  3. package/dist/cjs/event-listeners-9fb878f1.js +61 -0
  4. package/dist/cjs/event-listeners-9fb878f1.js.map +1 -0
  5. package/dist/cjs/{execution-control-b4707294.js → execution-control-d728da70.js} +15 -15
  6. package/dist/cjs/{execution-control-b4707294.js.map → execution-control-d728da70.js.map} +1 -1
  7. package/dist/cjs/focus-visible-e2c9255a.js +47 -0
  8. package/dist/cjs/{focus-visible-ae2470dd.js.map → focus-visible-e2c9255a.js.map} +1 -1
  9. package/dist/cjs/form-9ebaae7c.js +20 -0
  10. package/dist/cjs/{form-2df8c5bb.js.map → form-9ebaae7c.js.map} +1 -1
  11. package/dist/cjs/form-control-8d64e974.js +36 -0
  12. package/dist/cjs/form-control-8d64e974.js.map +1 -0
  13. package/dist/cjs/{index-7d73cbd6.js → index-d7748d51.js} +296 -695
  14. package/dist/cjs/index-d7748d51.js.map +1 -0
  15. package/dist/cjs/index.cjs.js +55 -102
  16. package/dist/cjs/index.cjs.js.map +1 -1
  17. package/dist/cjs/loader.cjs.js +2 -2
  18. package/dist/cjs/modal-3ce015be.js +52 -0
  19. package/dist/cjs/modal-3ce015be.js.map +1 -0
  20. package/dist/cjs/{popover-2df7e154.js → popover-1e7c09f1.js} +99 -99
  21. package/dist/cjs/popover-1e7c09f1.js.map +1 -0
  22. package/dist/cjs/popup-e854acda.js +103 -0
  23. package/dist/cjs/popup-e854acda.js.map +1 -0
  24. package/dist/cjs/scroll-68033901.js +68 -0
  25. package/dist/cjs/{scroll-2c4200dc.js.map → scroll-68033901.js.map} +1 -1
  26. package/dist/cjs/six-alert.cjs.entry.js +142 -110
  27. package/dist/cjs/six-alert.cjs.entry.js.map +1 -1
  28. package/dist/cjs/six-avatar.cjs.entry.js +21 -21
  29. package/dist/cjs/six-avatar.cjs.entry.js.map +1 -1
  30. package/dist/cjs/six-badge.cjs.entry.js +23 -23
  31. package/dist/cjs/six-badge.cjs.entry.js.map +1 -1
  32. package/dist/cjs/six-button.cjs.entry.js +95 -95
  33. package/dist/cjs/six-button.cjs.entry.js.map +1 -1
  34. package/dist/cjs/six-card.cjs.entry.js +8 -8
  35. package/dist/cjs/six-card.cjs.entry.js.map +1 -1
  36. package/dist/cjs/six-checkbox_2.cjs.entry.js +190 -0
  37. package/dist/cjs/six-checkbox_2.cjs.entry.js.map +1 -0
  38. package/dist/cjs/six-datepicker.cjs.entry.js +860 -834
  39. package/dist/cjs/six-datepicker.cjs.entry.js.map +1 -1
  40. package/dist/cjs/six-details.cjs.entry.js +127 -127
  41. package/dist/cjs/six-details.cjs.entry.js.map +1 -1
  42. package/dist/cjs/six-dialog.cjs.entry.js +131 -129
  43. package/dist/cjs/six-dialog.cjs.entry.js.map +1 -1
  44. package/dist/cjs/six-drawer.cjs.entry.js +147 -147
  45. package/dist/cjs/six-drawer.cjs.entry.js.map +1 -1
  46. package/dist/cjs/six-dropdown_2.cjs.entry.js +709 -637
  47. package/dist/cjs/six-dropdown_2.cjs.entry.js.map +1 -1
  48. package/dist/cjs/six-error-page.cjs.entry.js +82 -82
  49. package/dist/cjs/six-error-page.cjs.entry.js.map +1 -1
  50. package/dist/cjs/six-error.cjs.entry.js +7 -7
  51. package/dist/cjs/six-error.cjs.entry.js.map +1 -1
  52. package/dist/cjs/six-file-list-item.cjs.entry.js +34 -34
  53. package/dist/cjs/six-file-list-item.cjs.entry.js.map +1 -1
  54. package/dist/cjs/six-file-list.cjs.entry.js +7 -7
  55. package/dist/cjs/six-file-list.cjs.entry.js.map +1 -1
  56. package/dist/cjs/six-file-upload.cjs.entry.js +99 -99
  57. package/dist/cjs/six-file-upload.cjs.entry.js.map +1 -1
  58. package/dist/cjs/six-footer.cjs.entry.js +8 -8
  59. package/dist/cjs/six-footer.cjs.entry.js.map +1 -1
  60. package/dist/cjs/six-group-label.cjs.entry.js +43 -43
  61. package/dist/cjs/six-group-label.cjs.entry.js.map +1 -1
  62. package/dist/cjs/six-header.cjs.entry.js +171 -156
  63. package/dist/cjs/six-header.cjs.entry.js.map +1 -1
  64. package/dist/cjs/six-icon-button.cjs.entry.js +32 -32
  65. package/dist/cjs/six-icon-button.cjs.entry.js.map +1 -1
  66. package/dist/cjs/six-icon.cjs.entry.js +22 -22
  67. package/dist/cjs/six-icon.cjs.entry.js.map +1 -1
  68. package/dist/cjs/six-input.cjs.entry.js +192 -190
  69. package/dist/cjs/six-input.cjs.entry.js.map +1 -1
  70. package/dist/cjs/six-item-picker.cjs.entry.js +405 -309
  71. package/dist/cjs/six-item-picker.cjs.entry.js.map +1 -1
  72. package/dist/cjs/six-language-switcher.cjs.entry.js +46 -46
  73. package/dist/cjs/six-language-switcher.cjs.entry.js.map +1 -1
  74. package/dist/cjs/six-layout-grid.cjs.entry.js +20 -20
  75. package/dist/cjs/six-layout-grid.cjs.entry.js.map +1 -1
  76. package/dist/cjs/six-main-container.cjs.entry.js +9 -9
  77. package/dist/cjs/six-main-container.cjs.entry.js.map +1 -1
  78. package/dist/cjs/six-menu-divider.cjs.entry.js +8 -8
  79. package/dist/cjs/six-menu-divider.cjs.entry.js.map +1 -1
  80. package/dist/cjs/six-menu-label.cjs.entry.js +8 -8
  81. package/dist/cjs/six-menu-label.cjs.entry.js.map +1 -1
  82. package/dist/cjs/six-picto.cjs.entry.js +14 -14
  83. package/dist/cjs/six-picto.cjs.entry.js.map +1 -1
  84. package/dist/cjs/six-progress-bar.cjs.entry.js +15 -15
  85. package/dist/cjs/six-progress-bar.cjs.entry.js.map +1 -1
  86. package/dist/cjs/six-progress-ring.cjs.entry.js +30 -30
  87. package/dist/cjs/six-progress-ring.cjs.entry.js.map +1 -1
  88. package/dist/cjs/six-radio.cjs.entry.js +104 -104
  89. package/dist/cjs/six-radio.cjs.entry.js.map +1 -1
  90. package/dist/cjs/six-range.cjs.entry.js +180 -180
  91. package/dist/cjs/six-range.cjs.entry.js.map +1 -1
  92. package/dist/cjs/six-root.cjs.entry.js +11 -30
  93. package/dist/cjs/six-root.cjs.entry.js.map +1 -1
  94. package/dist/cjs/six-search-field.cjs.entry.js +44 -44
  95. package/dist/cjs/six-search-field.cjs.entry.js.map +1 -1
  96. package/dist/cjs/six-select.cjs.entry.js +497 -366
  97. package/dist/cjs/six-select.cjs.entry.js.map +1 -1
  98. package/dist/cjs/six-sidebar-item-group.cjs.entry.js +54 -54
  99. package/dist/cjs/six-sidebar-item-group.cjs.entry.js.map +1 -1
  100. package/dist/cjs/six-sidebar-item.cjs.entry.js +16 -16
  101. package/dist/cjs/six-sidebar-item.cjs.entry.js.map +1 -1
  102. package/dist/cjs/six-sidebar.cjs.entry.js +174 -174
  103. package/dist/cjs/six-sidebar.cjs.entry.js.map +1 -1
  104. package/dist/cjs/six-spinner.cjs.entry.js +15 -15
  105. package/dist/cjs/six-spinner.cjs.entry.js.map +1 -1
  106. package/dist/cjs/six-stage-indicator.cjs.entry.js +22 -0
  107. package/dist/cjs/six-stage-indicator.cjs.entry.js.map +1 -0
  108. package/dist/cjs/six-switch.cjs.entry.js +107 -107
  109. package/dist/cjs/six-switch.cjs.entry.js.map +1 -1
  110. package/dist/cjs/six-tab-group.cjs.entry.js +215 -215
  111. package/dist/cjs/six-tab-group.cjs.entry.js.map +1 -1
  112. package/dist/cjs/six-tab-panel.cjs.entry.js +14 -14
  113. package/dist/cjs/six-tab-panel.cjs.entry.js.map +1 -1
  114. package/dist/cjs/six-tab.cjs.entry.js +55 -55
  115. package/dist/cjs/six-tab.cjs.entry.js.map +1 -1
  116. package/dist/cjs/six-tag.cjs.entry.js +53 -53
  117. package/dist/cjs/six-tag.cjs.entry.js.map +1 -1
  118. package/dist/cjs/six-textarea.cjs.entry.js +181 -181
  119. package/dist/cjs/six-textarea.cjs.entry.js.map +1 -1
  120. package/dist/cjs/six-tile.cjs.entry.js +77 -77
  121. package/dist/cjs/six-tile.cjs.entry.js.map +1 -1
  122. package/dist/cjs/six-timepicker.cjs.entry.js +349 -349
  123. package/dist/cjs/six-timepicker.cjs.entry.js.map +1 -1
  124. package/dist/cjs/six-tooltip.cjs.entry.js +148 -148
  125. package/dist/cjs/six-tooltip.cjs.entry.js.map +1 -1
  126. package/dist/cjs/slot-1b1232a1.js +51 -0
  127. package/dist/cjs/slot-1b1232a1.js.map +1 -0
  128. package/dist/cjs/types-d3da200b.js +19 -0
  129. package/dist/cjs/types-d3da200b.js.map +1 -0
  130. package/dist/cjs/ui-library.cjs.js +3 -3
  131. package/dist/cjs/ui-library.cjs.js.map +1 -1
  132. package/dist/collection/collection-manifest.json +4 -5
  133. package/dist/collection/components/six-alert/six-alert.css +5 -1
  134. package/dist/collection/components/six-alert/six-alert.js +382 -337
  135. package/dist/collection/components/six-alert/six-alert.js.map +1 -1
  136. package/dist/collection/components/six-alert/test/six-alert.spec.js +7 -7
  137. package/dist/collection/components/six-alert/test/six-alert.spec.js.map +1 -1
  138. package/dist/collection/components/six-avatar/six-avatar.css +2 -2
  139. package/dist/collection/components/six-avatar/six-avatar.js +111 -111
  140. package/dist/collection/components/six-avatar/six-avatar.js.map +1 -1
  141. package/dist/collection/components/six-avatar/test/six-avatar.spec.js +7 -7
  142. package/dist/collection/components/six-avatar/test/six-avatar.spec.js.map +1 -1
  143. package/dist/collection/components/six-badge/six-badge.css +1 -1
  144. package/dist/collection/components/six-badge/six-badge.js +90 -90
  145. package/dist/collection/components/six-badge/six-badge.js.map +1 -1
  146. package/dist/collection/components/six-badge/test/six-badge.spec.js +7 -7
  147. package/dist/collection/components/six-badge/test/six-badge.spec.js.map +1 -1
  148. package/dist/collection/components/six-button/six-button.css +2 -1
  149. package/dist/collection/components/six-button/six-button.js +447 -446
  150. package/dist/collection/components/six-button/six-button.js.map +1 -1
  151. package/dist/collection/components/six-button/test/six-button.spec.js +44 -44
  152. package/dist/collection/components/six-button/test/six-button.spec.js.map +1 -1
  153. package/dist/collection/components/six-card/six-card.css +4 -5
  154. package/dist/collection/components/six-card/six-card.js +15 -15
  155. package/dist/collection/components/six-card/six-card.js.map +1 -1
  156. package/dist/collection/components/six-card/test/six-card.spec.js +7 -7
  157. package/dist/collection/components/six-card/test/six-card.spec.js.map +1 -1
  158. package/dist/collection/components/six-checkbox/six-checkbox.css +6 -1
  159. package/dist/collection/components/six-checkbox/six-checkbox.js +421 -420
  160. package/dist/collection/components/six-checkbox/six-checkbox.js.map +1 -1
  161. package/dist/collection/components/six-checkbox/test/six-checkbox.spec.js +13 -13
  162. package/dist/collection/components/six-checkbox/test/six-checkbox.spec.js.map +1 -1
  163. package/dist/collection/components/six-datepicker/components/day-selection.js +8 -8
  164. package/dist/collection/components/six-datepicker/components/day-selection.js.map +1 -1
  165. package/dist/collection/components/six-datepicker/components/month-selection.js +8 -8
  166. package/dist/collection/components/six-datepicker/components/month-selection.js.map +1 -1
  167. package/dist/collection/components/six-datepicker/components/year-selection.js +8 -8
  168. package/dist/collection/components/six-datepicker/components/year-selection.js.map +1 -1
  169. package/dist/collection/components/six-datepicker/six-date-formats.js +21 -20
  170. package/dist/collection/components/six-datepicker/six-date-formats.js.map +1 -1
  171. package/dist/collection/components/six-datepicker/six-datepicker.css +1 -1
  172. package/dist/collection/components/six-datepicker/six-datepicker.js +1052 -1050
  173. package/dist/collection/components/six-datepicker/six-datepicker.js.map +1 -1
  174. package/dist/collection/components/six-datepicker/test/six-datepicker.spec.js +7 -7
  175. package/dist/collection/components/six-datepicker/test/six-datepicker.spec.js.map +1 -1
  176. package/dist/collection/components/six-datepicker/test/six-datepicker.test-helpers.js +14 -14
  177. package/dist/collection/components/six-datepicker/test/six-datepicker.test-helpers.js.map +1 -1
  178. package/dist/collection/components/six-details/six-details.css +1 -5
  179. package/dist/collection/components/six-details/six-details.js +410 -410
  180. package/dist/collection/components/six-details/six-details.js.map +1 -1
  181. package/dist/collection/components/six-details/test/six-details.spec.js +7 -7
  182. package/dist/collection/components/six-details/test/six-details.spec.js.map +1 -1
  183. package/dist/collection/components/six-dialog/six-dialog.css +2 -2
  184. package/dist/collection/components/six-dialog/six-dialog.js +356 -354
  185. package/dist/collection/components/six-dialog/six-dialog.js.map +1 -1
  186. package/dist/collection/components/six-dialog/test/six-dialog.spec.js +7 -7
  187. package/dist/collection/components/six-dialog/test/six-dialog.spec.js.map +1 -1
  188. package/dist/collection/components/six-drawer/six-drawer.css +2 -2
  189. package/dist/collection/components/six-drawer/six-drawer.js +409 -409
  190. package/dist/collection/components/six-drawer/six-drawer.js.map +1 -1
  191. package/dist/collection/components/six-drawer/test/six-drawer.spec.js +7 -7
  192. package/dist/collection/components/six-drawer/test/six-drawer.spec.js.map +1 -1
  193. package/dist/collection/components/six-dropdown/six-dropdown.css +22 -7
  194. package/dist/collection/components/six-dropdown/six-dropdown.js +983 -891
  195. package/dist/collection/components/six-dropdown/six-dropdown.js.map +1 -1
  196. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js +92 -67
  197. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js.map +1 -1
  198. package/dist/collection/components/six-error/six-error.js +15 -15
  199. package/dist/collection/components/six-error/six-error.js.map +1 -1
  200. package/dist/collection/components/six-error-page/six-error-page.js +177 -177
  201. package/dist/collection/components/six-error-page/six-error-page.js.map +1 -1
  202. package/dist/collection/components/six-error-page/test/six-error-page.spec.js +77 -77
  203. package/dist/collection/components/six-error-page/test/six-error-page.spec.js.map +1 -1
  204. package/dist/collection/components/six-file-list/six-file-list.js +15 -15
  205. package/dist/collection/components/six-file-list/six-file-list.js.map +1 -1
  206. package/dist/collection/components/six-file-list/test/six-file-list.spec.js +16 -16
  207. package/dist/collection/components/six-file-list/test/six-file-list.spec.js.map +1 -1
  208. package/dist/collection/components/six-file-list-item/six-file-list-item.css +1 -1
  209. package/dist/collection/components/six-file-list-item/six-file-list-item.js +195 -195
  210. package/dist/collection/components/six-file-list-item/six-file-list-item.js.map +1 -1
  211. package/dist/collection/components/six-file-list-item/test/six-file-list-item.spec.js +42 -42
  212. package/dist/collection/components/six-file-list-item/test/six-file-list-item.spec.js.map +1 -1
  213. package/dist/collection/components/six-file-upload/six-file-upload.css +1 -4
  214. package/dist/collection/components/six-file-upload/six-file-upload.js +291 -291
  215. package/dist/collection/components/six-file-upload/six-file-upload.js.map +1 -1
  216. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js +27 -27
  217. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js.map +1 -1
  218. package/dist/collection/components/six-footer/six-footer.css +2 -2
  219. package/dist/collection/components/six-footer/six-footer.js +15 -15
  220. package/dist/collection/components/six-footer/six-footer.js.map +1 -1
  221. package/dist/collection/components/six-footer/test/six-footer.spec.js +7 -7
  222. package/dist/collection/components/six-footer/test/six-footer.spec.js.map +1 -1
  223. package/dist/collection/components/six-group-label/six-group-label.css +1 -1
  224. package/dist/collection/components/six-group-label/six-group-label.js +155 -155
  225. package/dist/collection/components/six-group-label/six-group-label.js.map +1 -1
  226. package/dist/collection/components/six-group-label/test/six-group-label.spec.js +12 -12
  227. package/dist/collection/components/six-group-label/test/six-group-label.spec.js.map +1 -1
  228. package/dist/collection/components/six-header/six-header.css +6 -2
  229. package/dist/collection/components/six-header/six-header.js +439 -405
  230. package/dist/collection/components/six-header/six-header.js.map +1 -1
  231. package/dist/collection/components/six-header/test/six-header.spec.js +77 -33
  232. package/dist/collection/components/six-header/test/six-header.spec.js.map +1 -1
  233. package/dist/collection/components/six-icon/six-icon.css +5 -2
  234. package/dist/collection/components/six-icon/six-icon.js +71 -71
  235. package/dist/collection/components/six-icon/six-icon.js.map +1 -1
  236. package/dist/collection/components/six-icon/test/six-icon.spec.js +7 -7
  237. package/dist/collection/components/six-icon/test/six-icon.spec.js.map +1 -1
  238. package/dist/collection/components/six-icon-button/six-icon-button.css +1 -1
  239. package/dist/collection/components/six-icon-button/six-icon-button.js +131 -131
  240. package/dist/collection/components/six-icon-button/six-icon-button.js.map +1 -1
  241. package/dist/collection/components/six-icon-button/test/six-icon-button.spec.js +7 -7
  242. package/dist/collection/components/six-icon-button/test/six-icon-button.spec.js.map +1 -1
  243. package/dist/collection/components/six-input/six-input.css +10 -1
  244. package/dist/collection/components/six-input/six-input.js +967 -939
  245. package/dist/collection/components/six-input/six-input.js.map +1 -1
  246. package/dist/collection/components/six-input/test/six-input.spec.js +7 -7
  247. package/dist/collection/components/six-input/test/six-input.spec.js.map +1 -1
  248. package/dist/collection/components/six-item-picker/six-item-picker.css +8 -0
  249. package/dist/collection/components/six-item-picker/six-item-picker.js +727 -631
  250. package/dist/collection/components/six-item-picker/six-item-picker.js.map +1 -1
  251. package/dist/collection/components/six-item-picker/test/six-item-picker.spec.js +82 -82
  252. package/dist/collection/components/six-item-picker/test/six-item-picker.spec.js.map +1 -1
  253. package/dist/collection/components/six-item-picker/types.js +9 -7
  254. package/dist/collection/components/six-item-picker/types.js.map +1 -1
  255. package/dist/collection/components/six-language-switcher/six-language-switcher.js +124 -124
  256. package/dist/collection/components/six-language-switcher/six-language-switcher.js.map +1 -1
  257. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js +79 -79
  258. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js.map +1 -1
  259. package/dist/collection/components/six-layout-grid/six-layout-grid.js +54 -54
  260. package/dist/collection/components/six-layout-grid/six-layout-grid.js.map +1 -1
  261. package/dist/collection/components/six-layout-grid/test/six-layout-grid.spec.js +7 -7
  262. package/dist/collection/components/six-layout-grid/test/six-layout-grid.spec.js.map +1 -1
  263. package/dist/collection/components/six-main-container/six-main-container.js +41 -41
  264. package/dist/collection/components/six-main-container/six-main-container.js.map +1 -1
  265. package/dist/collection/components/six-main-container/test/six-main-container.spec.js +7 -7
  266. package/dist/collection/components/six-main-container/test/six-main-container.spec.js.map +1 -1
  267. package/dist/collection/components/six-menu/six-menu.css +8 -7
  268. package/dist/collection/components/six-menu/six-menu.js +388 -366
  269. package/dist/collection/components/six-menu/six-menu.js.map +1 -1
  270. package/dist/collection/components/six-menu/test/six-menu.spec.js +41 -41
  271. package/dist/collection/components/six-menu/test/six-menu.spec.js.map +1 -1
  272. package/dist/collection/components/six-menu-divider/six-menu-divider.css +3 -2
  273. package/dist/collection/components/six-menu-divider/six-menu-divider.js +15 -15
  274. package/dist/collection/components/six-menu-divider/six-menu-divider.js.map +1 -1
  275. package/dist/collection/components/six-menu-divider/test/six-menu-divider.spec.js +7 -7
  276. package/dist/collection/components/six-menu-divider/test/six-menu-divider.spec.js.map +1 -1
  277. package/dist/collection/components/six-menu-item/six-menu-item.css +13 -2
  278. package/dist/collection/components/six-menu-item/six-menu-item.js +209 -180
  279. package/dist/collection/components/six-menu-item/six-menu-item.js.map +1 -1
  280. package/dist/collection/components/six-menu-item/test/six-menu-item.spec.js +7 -7
  281. package/dist/collection/components/six-menu-item/test/six-menu-item.spec.js.map +1 -1
  282. package/dist/collection/components/six-menu-label/six-menu-label.css +1 -1
  283. package/dist/collection/components/six-menu-label/six-menu-label.js +15 -15
  284. package/dist/collection/components/six-menu-label/six-menu-label.js.map +1 -1
  285. package/dist/collection/components/six-menu-label/test/six-menu-label.spec.js +7 -7
  286. package/dist/collection/components/six-menu-label/test/six-menu-label.spec.js.map +1 -1
  287. package/dist/collection/components/six-picto/six-picto.js +46 -46
  288. package/dist/collection/components/six-picto/six-picto.js.map +1 -1
  289. package/dist/collection/components/six-picto/test/six-picto.spec.js +13 -13
  290. package/dist/collection/components/six-picto/test/six-picto.spec.js.map +1 -1
  291. package/dist/collection/components/six-progress-bar/six-progress-bar.css +1 -1
  292. package/dist/collection/components/six-progress-bar/six-progress-bar.js +64 -64
  293. package/dist/collection/components/six-progress-bar/six-progress-bar.js.map +1 -1
  294. package/dist/collection/components/six-progress-bar/test/six-progress-bar.spec.js +7 -7
  295. package/dist/collection/components/six-progress-bar/test/six-progress-bar.spec.js.map +1 -1
  296. package/dist/collection/components/six-progress-ring/six-progress-ring.css +1 -1
  297. package/dist/collection/components/six-progress-ring/six-progress-ring.js +100 -100
  298. package/dist/collection/components/six-progress-ring/six-progress-ring.js.map +1 -1
  299. package/dist/collection/components/six-progress-ring/test/six-progress-ring.spec.js +7 -7
  300. package/dist/collection/components/six-progress-ring/test/six-progress-ring.spec.js.map +1 -1
  301. package/dist/collection/components/six-radio/six-radio.css +1 -1
  302. package/dist/collection/components/six-radio/six-radio.js +321 -320
  303. package/dist/collection/components/six-radio/six-radio.js.map +1 -1
  304. package/dist/collection/components/six-radio/test/six-radio.spec.js +13 -13
  305. package/dist/collection/components/six-radio/test/six-radio.spec.js.map +1 -1
  306. package/dist/collection/components/six-range/six-range.css +1 -1
  307. package/dist/collection/components/six-range/six-range.js +564 -563
  308. package/dist/collection/components/six-range/six-range.js.map +1 -1
  309. package/dist/collection/components/six-range/test/six-range.spec.js +8 -8
  310. package/dist/collection/components/six-range/test/six-range.spec.js.map +1 -1
  311. package/dist/collection/components/six-root/six-root.js +84 -152
  312. package/dist/collection/components/six-root/six-root.js.map +1 -1
  313. package/dist/collection/components/six-root/test/six-root.spec.js +7 -14
  314. package/dist/collection/components/six-root/test/six-root.spec.js.map +1 -1
  315. package/dist/collection/components/six-search-field/six-search-field.css +1 -1
  316. package/dist/collection/components/six-search-field/six-search-field.js +169 -169
  317. package/dist/collection/components/six-search-field/six-search-field.js.map +1 -1
  318. package/dist/collection/components/six-search-field/test/six-search-field.spec.js +7 -7
  319. package/dist/collection/components/six-search-field/test/six-search-field.spec.js.map +1 -1
  320. package/dist/collection/components/six-select/six-select.css +54 -66
  321. package/dist/collection/components/six-select/six-select.js +1117 -942
  322. package/dist/collection/components/six-select/six-select.js.map +1 -1
  323. package/dist/collection/components/six-select/test/six-select.spec.js +45 -29
  324. package/dist/collection/components/six-select/test/six-select.spec.js.map +1 -1
  325. package/dist/collection/components/six-select/test/util.spec.js +73 -73
  326. package/dist/collection/components/six-select/test/util.spec.js.map +1 -1
  327. package/dist/collection/components/six-select/util.js +34 -34
  328. package/dist/collection/components/six-select/util.js.map +1 -1
  329. package/dist/collection/components/six-sidebar/six-sidebar.css +2 -2
  330. package/dist/collection/components/six-sidebar/six-sidebar.js +466 -464
  331. package/dist/collection/components/six-sidebar/six-sidebar.js.map +1 -1
  332. package/dist/collection/components/six-sidebar/test/six-sidebar.spec.js +7 -7
  333. package/dist/collection/components/six-sidebar/test/six-sidebar.spec.js.map +1 -1
  334. package/dist/collection/components/six-sidebar-item/six-sidebar-item.js +101 -101
  335. package/dist/collection/components/six-sidebar-item/six-sidebar-item.js.map +1 -1
  336. package/dist/collection/components/six-sidebar-item/test/six-sidebar-item.spec.js +19 -19
  337. package/dist/collection/components/six-sidebar-item/test/six-sidebar-item.spec.js.map +1 -1
  338. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.css +1 -1
  339. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js +178 -178
  340. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js.map +1 -1
  341. package/dist/collection/components/six-sidebar-item-group/test/six-sidebar-item-group.spec.js +14 -14
  342. package/dist/collection/components/six-sidebar-item-group/test/six-sidebar-item-group.spec.js.map +1 -1
  343. package/dist/collection/components/six-spinner/six-spinner.css +1 -1
  344. package/dist/collection/components/six-spinner/six-spinner.js +47 -46
  345. package/dist/collection/components/six-spinner/six-spinner.js.map +1 -1
  346. package/dist/collection/components/six-spinner/test/six-spinner.spec.js +14 -14
  347. package/dist/collection/components/six-spinner/test/six-spinner.spec.js.map +1 -1
  348. package/dist/collection/components/six-stage-indicator/six-stage-indicator.css +1 -1
  349. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js +45 -45
  350. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js.map +1 -1
  351. package/dist/collection/components/six-stage-indicator/test/six-stage-indicator.spec.js +37 -37
  352. package/dist/collection/components/six-stage-indicator/test/six-stage-indicator.spec.js.map +1 -1
  353. package/dist/collection/components/six-switch/six-switch.css +1 -1
  354. package/dist/collection/components/six-switch/six-switch.js +384 -383
  355. package/dist/collection/components/six-switch/six-switch.js.map +1 -1
  356. package/dist/collection/components/six-switch/test/six-switch.spec.js +13 -13
  357. package/dist/collection/components/six-switch/test/six-switch.spec.js.map +1 -1
  358. package/dist/collection/components/six-tab/six-tab.css +1 -1
  359. package/dist/collection/components/six-tab/six-tab.js +206 -205
  360. package/dist/collection/components/six-tab/six-tab.js.map +1 -1
  361. package/dist/collection/components/six-tab-group/six-tab-group.css +1 -1
  362. package/dist/collection/components/six-tab-group/six-tab-group.js +317 -316
  363. package/dist/collection/components/six-tab-group/six-tab-group.js.map +1 -1
  364. package/dist/collection/components/six-tab-panel/six-tab-panel.css +1 -1
  365. package/dist/collection/components/six-tab-panel/six-tab-panel.js +63 -63
  366. package/dist/collection/components/six-tab-panel/six-tab-panel.js.map +1 -1
  367. package/dist/collection/components/six-tab-panel/test/six-tab-panel.spec.js +7 -7
  368. package/dist/collection/components/six-tab-panel/test/six-tab-panel.spec.js.map +1 -1
  369. package/dist/collection/components/six-tag/six-tag.css +1 -1
  370. package/dist/collection/components/six-tag/six-tag.js +158 -158
  371. package/dist/collection/components/six-tag/six-tag.js.map +1 -1
  372. package/dist/collection/components/six-tag/test/six-tag.spec.js +19 -19
  373. package/dist/collection/components/six-tag/test/six-tag.spec.js.map +1 -1
  374. package/dist/collection/components/six-textarea/six-textarea.css +1 -1
  375. package/dist/collection/components/six-textarea/six-textarea.js +792 -784
  376. package/dist/collection/components/six-textarea/six-textarea.js.map +1 -1
  377. package/dist/collection/components/six-textarea/test/six-textarea.spec.js +94 -94
  378. package/dist/collection/components/six-textarea/test/six-textarea.spec.js.map +1 -1
  379. package/dist/collection/components/six-tile/six-tile.css +2 -2
  380. package/dist/collection/components/six-tile/six-tile.js +298 -298
  381. package/dist/collection/components/six-tile/six-tile.js.map +1 -1
  382. package/dist/collection/components/six-tile/test/six-tile.spec.js +14 -14
  383. package/dist/collection/components/six-tile/test/six-tile.spec.js.map +1 -1
  384. package/dist/collection/components/six-timepicker/six-timepicker.css +1 -1
  385. package/dist/collection/components/six-timepicker/six-timepicker.js +823 -822
  386. package/dist/collection/components/six-timepicker/six-timepicker.js.map +1 -1
  387. package/dist/collection/components/six-timepicker/test/six-timepicker.spec.js +155 -155
  388. package/dist/collection/components/six-timepicker/test/six-timepicker.spec.js.map +1 -1
  389. package/dist/collection/components/six-tooltip/six-tooltip.css +1 -1
  390. package/dist/collection/components/six-tooltip/six-tooltip.js +407 -407
  391. package/dist/collection/components/six-tooltip/six-tooltip.js.map +1 -1
  392. package/dist/collection/components/six-tooltip/test/six-tooltip.spec.js +7 -7
  393. package/dist/collection/components/six-tooltip/test/six-tooltip.spec.js.map +1 -1
  394. package/dist/collection/functional-components/form-control/form-control.js +19 -19
  395. package/dist/collection/functional-components/form-control/form-control.js.map +1 -1
  396. package/dist/collection/index.js +1 -0
  397. package/dist/collection/index.js.map +1 -1
  398. package/dist/collection/testUtil/delay.js +1 -1
  399. package/dist/collection/testUtil/delay.js.map +1 -1
  400. package/dist/collection/utils/alert.js +54 -0
  401. package/dist/collection/utils/alert.js.map +1 -0
  402. package/dist/collection/utils/animation.js +19 -19
  403. package/dist/collection/utils/animation.js.map +1 -1
  404. package/dist/collection/utils/date-util.js +525 -500
  405. package/dist/collection/utils/date-util.js.map +1 -1
  406. package/dist/collection/utils/date-util.spec.js +984 -984
  407. package/dist/collection/utils/date-util.spec.js.map +1 -1
  408. package/dist/collection/utils/error-messages.js +101 -94
  409. package/dist/collection/utils/error-messages.js.map +1 -1
  410. package/dist/collection/utils/event-listeners.js +51 -51
  411. package/dist/collection/utils/event-listeners.js.map +1 -1
  412. package/dist/collection/utils/execution-control.js +14 -14
  413. package/dist/collection/utils/execution-control.js.map +1 -1
  414. package/dist/collection/utils/focus-visible.js +28 -28
  415. package/dist/collection/utils/focus-visible.js.map +1 -1
  416. package/dist/collection/utils/form.js +12 -12
  417. package/dist/collection/utils/form.js.map +1 -1
  418. package/dist/collection/utils/modal.js +25 -25
  419. package/dist/collection/utils/modal.js.map +1 -1
  420. package/dist/collection/utils/offset.js +4 -4
  421. package/dist/collection/utils/offset.js.map +1 -1
  422. package/dist/collection/utils/popover.js +99 -99
  423. package/dist/collection/utils/popover.js.map +1 -1
  424. package/dist/collection/utils/popup.js +71 -71
  425. package/dist/collection/utils/popup.js.map +1 -1
  426. package/dist/collection/utils/scroll.js +27 -27
  427. package/dist/collection/utils/scroll.js.map +1 -1
  428. package/dist/collection/utils/scroll.spec.js +116 -116
  429. package/dist/collection/utils/scroll.spec.js.map +1 -1
  430. package/dist/collection/utils/slot.js +28 -29
  431. package/dist/collection/utils/slot.js.map +1 -1
  432. package/dist/collection/utils/support.js +10 -10
  433. package/dist/collection/utils/support.js.map +1 -1
  434. package/dist/collection/utils/tabbable.js +17 -17
  435. package/dist/collection/utils/tabbable.js.map +1 -1
  436. package/dist/collection/utils/time.util.js +72 -72
  437. package/dist/collection/utils/time.util.js.map +1 -1
  438. package/dist/collection/utils/time.util.spec.js +353 -353
  439. package/dist/collection/utils/time.util.spec.js.map +1 -1
  440. package/dist/components/event-listeners.js +51 -51
  441. package/dist/components/event-listeners.js.map +1 -1
  442. package/dist/components/execution-control.js +14 -14
  443. package/dist/components/execution-control.js.map +1 -1
  444. package/dist/components/focus-visible.js +28 -28
  445. package/dist/components/focus-visible.js.map +1 -1
  446. package/dist/components/form-control.js +26 -26
  447. package/dist/components/form-control.js.map +1 -1
  448. package/dist/components/form.js +12 -12
  449. package/dist/components/form.js.map +1 -1
  450. package/dist/components/index.js +111 -163
  451. package/dist/components/index.js.map +1 -1
  452. package/dist/components/modal.js +35 -35
  453. package/dist/components/modal.js.map +1 -1
  454. package/dist/components/popover.js +98 -98
  455. package/dist/components/popover.js.map +1 -1
  456. package/dist/components/scroll.js +31 -31
  457. package/dist/components/scroll.js.map +1 -1
  458. package/dist/components/six-alert.d.ts +2 -2
  459. package/dist/components/six-alert.js +177 -145
  460. package/dist/components/six-alert.js.map +1 -1
  461. package/dist/components/six-avatar.d.ts +2 -2
  462. package/dist/components/six-avatar.js +45 -45
  463. package/dist/components/six-avatar.js.map +1 -1
  464. package/dist/components/six-badge.d.ts +2 -2
  465. package/dist/components/six-badge.js +40 -40
  466. package/dist/components/six-badge.js.map +1 -1
  467. package/dist/components/six-button.d.ts +2 -2
  468. package/dist/components/six-button.js +1 -142
  469. package/dist/components/six-button.js.map +1 -1
  470. package/dist/components/six-button2.js +146 -0
  471. package/dist/components/six-button2.js.map +1 -0
  472. package/dist/components/six-card.d.ts +2 -2
  473. package/dist/components/six-card.js +21 -21
  474. package/dist/components/six-card.js.map +1 -1
  475. package/dist/components/six-checkbox.d.ts +2 -2
  476. package/dist/components/six-checkbox.js +1 -161
  477. package/dist/components/six-checkbox.js.map +1 -1
  478. package/dist/components/six-checkbox2.js +165 -0
  479. package/dist/components/six-checkbox2.js.map +1 -0
  480. package/dist/components/six-datepicker.d.ts +2 -2
  481. package/dist/components/six-datepicker.js +930 -904
  482. package/dist/components/six-datepicker.js.map +1 -1
  483. package/dist/components/six-details.d.ts +2 -2
  484. package/dist/components/six-details2.js +158 -158
  485. package/dist/components/six-details2.js.map +1 -1
  486. package/dist/components/six-dialog.d.ts +2 -2
  487. package/dist/components/six-dialog.js +161 -159
  488. package/dist/components/six-dialog.js.map +1 -1
  489. package/dist/components/six-drawer.d.ts +2 -2
  490. package/dist/components/six-drawer.js +179 -179
  491. package/dist/components/six-drawer.js.map +1 -1
  492. package/dist/components/six-dropdown.d.ts +2 -2
  493. package/dist/components/six-dropdown2.js +552 -476
  494. package/dist/components/six-dropdown2.js.map +1 -1
  495. package/dist/components/six-error-page.d.ts +2 -2
  496. package/dist/components/six-error-page.js +106 -106
  497. package/dist/components/six-error-page.js.map +1 -1
  498. package/dist/components/six-error.d.ts +2 -2
  499. package/dist/components/six-error2.js +20 -20
  500. package/dist/components/six-error2.js.map +1 -1
  501. package/dist/components/six-file-list-item.d.ts +2 -2
  502. package/dist/components/six-file-list-item.js +59 -59
  503. package/dist/components/six-file-list-item.js.map +1 -1
  504. package/dist/components/six-file-list.d.ts +2 -2
  505. package/dist/components/six-file-list.js +20 -20
  506. package/dist/components/six-file-list.js.map +1 -1
  507. package/dist/components/six-file-upload.d.ts +2 -2
  508. package/dist/components/six-file-upload.js +124 -124
  509. package/dist/components/six-file-upload.js.map +1 -1
  510. package/dist/components/six-footer.d.ts +2 -2
  511. package/dist/components/six-footer.js +21 -21
  512. package/dist/components/six-footer.js.map +1 -1
  513. package/dist/components/six-group-label.d.ts +2 -2
  514. package/dist/components/six-group-label.js +70 -70
  515. package/dist/components/six-group-label.js.map +1 -1
  516. package/dist/components/six-header.d.ts +2 -2
  517. package/dist/components/six-header.js +235 -213
  518. package/dist/components/six-header.js.map +1 -1
  519. package/dist/components/six-icon-button.d.ts +2 -2
  520. package/dist/components/six-icon-button2.js +55 -55
  521. package/dist/components/six-icon-button2.js.map +1 -1
  522. package/dist/components/six-icon.d.ts +2 -2
  523. package/dist/components/six-icon2.js +38 -38
  524. package/dist/components/six-icon2.js.map +1 -1
  525. package/dist/components/six-input.d.ts +2 -2
  526. package/dist/components/six-input2.js +257 -254
  527. package/dist/components/six-input2.js.map +1 -1
  528. package/dist/components/six-item-picker.d.ts +2 -2
  529. package/dist/components/six-item-picker2.js +450 -352
  530. package/dist/components/six-item-picker2.js.map +1 -1
  531. package/dist/components/six-language-switcher.d.ts +2 -2
  532. package/dist/components/six-language-switcher.js +64 -64
  533. package/dist/components/six-language-switcher.js.map +1 -1
  534. package/dist/components/six-layout-grid.d.ts +2 -2
  535. package/dist/components/six-layout-grid.js +37 -37
  536. package/dist/components/six-layout-grid.js.map +1 -1
  537. package/dist/components/six-main-container.d.ts +2 -2
  538. package/dist/components/six-main-container.js +24 -24
  539. package/dist/components/six-main-container.js.map +1 -1
  540. package/dist/components/six-menu-divider.d.ts +2 -2
  541. package/dist/components/six-menu-divider.js +21 -21
  542. package/dist/components/six-menu-divider.js.map +1 -1
  543. package/dist/components/six-menu-item.d.ts +2 -2
  544. package/dist/components/six-menu-item2.js +98 -75
  545. package/dist/components/six-menu-item2.js.map +1 -1
  546. package/dist/components/six-menu-label.d.ts +2 -2
  547. package/dist/components/six-menu-label.js +21 -21
  548. package/dist/components/six-menu-label.js.map +1 -1
  549. package/dist/components/six-menu.d.ts +2 -2
  550. package/dist/components/six-menu2.js +236 -220
  551. package/dist/components/six-menu2.js.map +1 -1
  552. package/dist/components/six-picto.d.ts +2 -2
  553. package/dist/components/six-picto2.js +29 -29
  554. package/dist/components/six-picto2.js.map +1 -1
  555. package/dist/components/six-progress-bar.d.ts +2 -2
  556. package/dist/components/six-progress-bar.js +31 -31
  557. package/dist/components/six-progress-bar.js.map +1 -1
  558. package/dist/components/six-progress-ring.d.ts +2 -2
  559. package/dist/components/six-progress-ring.js +49 -49
  560. package/dist/components/six-progress-ring.js.map +1 -1
  561. package/dist/components/six-radio.d.ts +2 -2
  562. package/dist/components/six-radio.js +128 -128
  563. package/dist/components/six-radio.js.map +1 -1
  564. package/dist/components/six-range.d.ts +2 -2
  565. package/dist/components/six-range.js +232 -232
  566. package/dist/components/six-range.js.map +1 -1
  567. package/dist/components/six-root.d.ts +2 -2
  568. package/dist/components/six-root.js +39 -68
  569. package/dist/components/six-root.js.map +1 -1
  570. package/dist/components/six-search-field.d.ts +2 -2
  571. package/dist/components/six-search-field.js +78 -78
  572. package/dist/components/six-search-field.js.map +1 -1
  573. package/dist/components/six-select.d.ts +2 -2
  574. package/dist/components/six-select.js +719 -469
  575. package/dist/components/six-select.js.map +1 -1
  576. package/dist/components/six-sidebar-item-group.d.ts +2 -2
  577. package/dist/components/six-sidebar-item-group.js +85 -85
  578. package/dist/components/six-sidebar-item-group.js.map +1 -1
  579. package/dist/components/six-sidebar-item.d.ts +2 -2
  580. package/dist/components/six-sidebar-item.js +34 -34
  581. package/dist/components/six-sidebar-item.js.map +1 -1
  582. package/dist/components/six-sidebar.d.ts +2 -2
  583. package/dist/components/six-sidebar.js +199 -199
  584. package/dist/components/six-sidebar.js.map +1 -1
  585. package/dist/components/six-spinner.d.ts +2 -2
  586. package/dist/components/six-spinner2.js +30 -30
  587. package/dist/components/six-spinner2.js.map +1 -1
  588. package/dist/components/six-stage-indicator.d.ts +2 -2
  589. package/dist/components/six-stage-indicator2.js +29 -29
  590. package/dist/components/six-stage-indicator2.js.map +1 -1
  591. package/dist/components/six-switch.d.ts +2 -2
  592. package/dist/components/six-switch.js +140 -140
  593. package/dist/components/six-switch.js.map +1 -1
  594. package/dist/components/six-tab-group.d.ts +2 -2
  595. package/dist/components/six-tab-group.js +244 -244
  596. package/dist/components/six-tab-group.js.map +1 -1
  597. package/dist/components/six-tab-panel.d.ts +2 -2
  598. package/dist/components/six-tab-panel.js +30 -30
  599. package/dist/components/six-tab-panel.js.map +1 -1
  600. package/dist/components/six-tab.d.ts +2 -2
  601. package/dist/components/six-tab.js +85 -85
  602. package/dist/components/six-tab.js.map +1 -1
  603. package/dist/components/six-tag.d.ts +2 -2
  604. package/dist/components/six-tag.js +98 -1
  605. package/dist/components/six-tag.js.map +1 -1
  606. package/dist/components/six-textarea.d.ts +2 -2
  607. package/dist/components/six-textarea.js +234 -234
  608. package/dist/components/six-textarea.js.map +1 -1
  609. package/dist/components/six-tile.d.ts +2 -2
  610. package/dist/components/six-tile.js +117 -117
  611. package/dist/components/six-tile.js.map +1 -1
  612. package/dist/components/six-timepicker.d.ts +2 -2
  613. package/dist/components/six-timepicker2.js +490 -490
  614. package/dist/components/six-timepicker2.js.map +1 -1
  615. package/dist/components/six-tooltip.d.ts +2 -2
  616. package/dist/components/six-tooltip2.js +172 -172
  617. package/dist/components/six-tooltip2.js.map +1 -1
  618. package/dist/components/slot.js +29 -30
  619. package/dist/components/slot.js.map +1 -1
  620. package/dist/components.d.ts +1 -21
  621. package/dist/components.json +604 -231
  622. package/dist/esm/error-messages-1eaaad23.js +115 -0
  623. package/dist/esm/error-messages-1eaaad23.js.map +1 -0
  624. package/dist/esm/event-listeners-706d4309.js +59 -0
  625. package/dist/esm/event-listeners-706d4309.js.map +1 -0
  626. package/dist/esm/{execution-control-e0892a05.js → execution-control-2ebaf4ef.js} +15 -15
  627. package/dist/esm/{execution-control-e0892a05.js.map → execution-control-2ebaf4ef.js.map} +1 -1
  628. package/dist/esm/focus-visible-d9dbfeef.js +45 -0
  629. package/dist/esm/{focus-visible-fc6ac671.js.map → focus-visible-d9dbfeef.js.map} +1 -1
  630. package/dist/esm/form-4b145b7a.js +18 -0
  631. package/dist/esm/{form-81252534.js.map → form-4b145b7a.js.map} +1 -1
  632. package/dist/esm/form-control-d403a9cf.js +34 -0
  633. package/dist/esm/form-control-d403a9cf.js.map +1 -0
  634. package/dist/esm/{index-4ee8b33e.js → index-79d4ef67.js} +296 -695
  635. package/dist/esm/index-79d4ef67.js.map +1 -0
  636. package/dist/esm/index.js +52 -101
  637. package/dist/esm/index.js.map +1 -1
  638. package/dist/esm/loader.js +3 -3
  639. package/dist/esm/modal-96526245.js +49 -0
  640. package/dist/esm/modal-96526245.js.map +1 -0
  641. package/dist/esm/{popover-136d1f73.js → popover-25996e62.js} +99 -99
  642. package/dist/esm/popover-25996e62.js.map +1 -0
  643. package/dist/esm/popup-7209e9d5.js +98 -0
  644. package/dist/esm/popup-7209e9d5.js.map +1 -0
  645. package/dist/esm/scroll-3e16851e.js +64 -0
  646. package/dist/esm/{scroll-774762d6.js.map → scroll-3e16851e.js.map} +1 -1
  647. package/dist/esm/six-alert.entry.js +142 -110
  648. package/dist/esm/six-alert.entry.js.map +1 -1
  649. package/dist/esm/six-avatar.entry.js +21 -21
  650. package/dist/esm/six-avatar.entry.js.map +1 -1
  651. package/dist/esm/six-badge.entry.js +23 -23
  652. package/dist/esm/six-badge.entry.js.map +1 -1
  653. package/dist/esm/six-button.entry.js +95 -95
  654. package/dist/esm/six-button.entry.js.map +1 -1
  655. package/dist/esm/six-card.entry.js +8 -8
  656. package/dist/esm/six-card.entry.js.map +1 -1
  657. package/dist/esm/six-checkbox_2.entry.js +185 -0
  658. package/dist/esm/six-checkbox_2.entry.js.map +1 -0
  659. package/dist/esm/six-datepicker.entry.js +860 -834
  660. package/dist/esm/six-datepicker.entry.js.map +1 -1
  661. package/dist/esm/six-details.entry.js +127 -127
  662. package/dist/esm/six-details.entry.js.map +1 -1
  663. package/dist/esm/six-dialog.entry.js +131 -129
  664. package/dist/esm/six-dialog.entry.js.map +1 -1
  665. package/dist/esm/six-drawer.entry.js +147 -147
  666. package/dist/esm/six-drawer.entry.js.map +1 -1
  667. package/dist/esm/six-dropdown_2.entry.js +709 -637
  668. package/dist/esm/six-dropdown_2.entry.js.map +1 -1
  669. package/dist/esm/six-error-page.entry.js +82 -82
  670. package/dist/esm/six-error-page.entry.js.map +1 -1
  671. package/dist/esm/six-error.entry.js +7 -7
  672. package/dist/esm/six-error.entry.js.map +1 -1
  673. package/dist/esm/six-file-list-item.entry.js +34 -34
  674. package/dist/esm/six-file-list-item.entry.js.map +1 -1
  675. package/dist/esm/six-file-list.entry.js +7 -7
  676. package/dist/esm/six-file-list.entry.js.map +1 -1
  677. package/dist/esm/six-file-upload.entry.js +99 -99
  678. package/dist/esm/six-file-upload.entry.js.map +1 -1
  679. package/dist/esm/six-footer.entry.js +8 -8
  680. package/dist/esm/six-footer.entry.js.map +1 -1
  681. package/dist/esm/six-group-label.entry.js +43 -43
  682. package/dist/esm/six-group-label.entry.js.map +1 -1
  683. package/dist/esm/six-header.entry.js +171 -156
  684. package/dist/esm/six-header.entry.js.map +1 -1
  685. package/dist/esm/six-icon-button.entry.js +32 -32
  686. package/dist/esm/six-icon-button.entry.js.map +1 -1
  687. package/dist/esm/six-icon.entry.js +22 -22
  688. package/dist/esm/six-icon.entry.js.map +1 -1
  689. package/dist/esm/six-input.entry.js +192 -190
  690. package/dist/esm/six-input.entry.js.map +1 -1
  691. package/dist/esm/six-item-picker.entry.js +405 -309
  692. package/dist/esm/six-item-picker.entry.js.map +1 -1
  693. package/dist/esm/six-language-switcher.entry.js +46 -46
  694. package/dist/esm/six-language-switcher.entry.js.map +1 -1
  695. package/dist/esm/six-layout-grid.entry.js +20 -20
  696. package/dist/esm/six-layout-grid.entry.js.map +1 -1
  697. package/dist/esm/six-main-container.entry.js +9 -9
  698. package/dist/esm/six-main-container.entry.js.map +1 -1
  699. package/dist/esm/six-menu-divider.entry.js +8 -8
  700. package/dist/esm/six-menu-divider.entry.js.map +1 -1
  701. package/dist/esm/six-menu-label.entry.js +8 -8
  702. package/dist/esm/six-menu-label.entry.js.map +1 -1
  703. package/dist/esm/six-picto.entry.js +14 -14
  704. package/dist/esm/six-picto.entry.js.map +1 -1
  705. package/dist/esm/six-progress-bar.entry.js +15 -15
  706. package/dist/esm/six-progress-bar.entry.js.map +1 -1
  707. package/dist/esm/six-progress-ring.entry.js +30 -30
  708. package/dist/esm/six-progress-ring.entry.js.map +1 -1
  709. package/dist/esm/six-radio.entry.js +104 -104
  710. package/dist/esm/six-radio.entry.js.map +1 -1
  711. package/dist/esm/six-range.entry.js +180 -180
  712. package/dist/esm/six-range.entry.js.map +1 -1
  713. package/dist/esm/six-root.entry.js +11 -30
  714. package/dist/esm/six-root.entry.js.map +1 -1
  715. package/dist/esm/six-search-field.entry.js +44 -44
  716. package/dist/esm/six-search-field.entry.js.map +1 -1
  717. package/dist/esm/six-select.entry.js +497 -366
  718. package/dist/esm/six-select.entry.js.map +1 -1
  719. package/dist/esm/six-sidebar-item-group.entry.js +54 -54
  720. package/dist/esm/six-sidebar-item-group.entry.js.map +1 -1
  721. package/dist/esm/six-sidebar-item.entry.js +16 -16
  722. package/dist/esm/six-sidebar-item.entry.js.map +1 -1
  723. package/dist/esm/six-sidebar.entry.js +174 -174
  724. package/dist/esm/six-sidebar.entry.js.map +1 -1
  725. package/dist/esm/six-spinner.entry.js +15 -15
  726. package/dist/esm/six-spinner.entry.js.map +1 -1
  727. package/dist/esm/six-stage-indicator.entry.js +18 -0
  728. package/dist/esm/six-stage-indicator.entry.js.map +1 -0
  729. package/dist/esm/six-switch.entry.js +107 -107
  730. package/dist/esm/six-switch.entry.js.map +1 -1
  731. package/dist/esm/six-tab-group.entry.js +215 -215
  732. package/dist/esm/six-tab-group.entry.js.map +1 -1
  733. package/dist/esm/six-tab-panel.entry.js +14 -14
  734. package/dist/esm/six-tab-panel.entry.js.map +1 -1
  735. package/dist/esm/six-tab.entry.js +55 -55
  736. package/dist/esm/six-tab.entry.js.map +1 -1
  737. package/dist/esm/six-tag.entry.js +53 -53
  738. package/dist/esm/six-tag.entry.js.map +1 -1
  739. package/dist/esm/six-textarea.entry.js +181 -181
  740. package/dist/esm/six-textarea.entry.js.map +1 -1
  741. package/dist/esm/six-tile.entry.js +77 -77
  742. package/dist/esm/six-tile.entry.js.map +1 -1
  743. package/dist/esm/six-timepicker.entry.js +349 -349
  744. package/dist/esm/six-timepicker.entry.js.map +1 -1
  745. package/dist/esm/six-tooltip.entry.js +148 -148
  746. package/dist/esm/six-tooltip.entry.js.map +1 -1
  747. package/dist/esm/slot-56531341.js +47 -0
  748. package/dist/esm/slot-56531341.js.map +1 -0
  749. package/dist/esm/types-a07bb999.js +19 -0
  750. package/dist/esm/types-a07bb999.js.map +1 -0
  751. package/dist/esm/ui-library.js +4 -4
  752. package/dist/esm/ui-library.js.map +1 -1
  753. package/dist/types/components/six-alert/six-alert.d.ts +47 -40
  754. package/dist/types/components/six-avatar/six-avatar.d.ts +11 -11
  755. package/dist/types/components/six-badge/six-badge.d.ts +7 -7
  756. package/dist/types/components/six-button/six-button.d.ts +48 -48
  757. package/dist/types/components/six-card/six-card.d.ts +1 -1
  758. package/dist/types/components/six-checkbox/six-checkbox.d.ts +58 -58
  759. package/dist/types/components/six-datepicker/components/day-selection.d.ts +3 -3
  760. package/dist/types/components/six-datepicker/components/month-selection.d.ts +3 -3
  761. package/dist/types/components/six-datepicker/components/year-selection.d.ts +3 -3
  762. package/dist/types/components/six-datepicker/six-date-formats.d.ts +20 -20
  763. package/dist/types/components/six-datepicker/six-datepicker.d.ts +187 -187
  764. package/dist/types/components/six-details/six-details.d.ts +42 -42
  765. package/dist/types/components/six-dialog/six-dialog.d.ts +51 -50
  766. package/dist/types/components/six-drawer/six-drawer.d.ts +58 -58
  767. package/dist/types/components/six-dropdown/six-dropdown.d.ts +131 -112
  768. package/dist/types/components/six-error/six-error.d.ts +1 -1
  769. package/dist/types/components/six-error-page/six-error-page.d.ts +25 -25
  770. package/dist/types/components/six-file-list/six-file-list.d.ts +1 -1
  771. package/dist/types/components/six-file-list-item/six-file-list-item.d.ts +23 -23
  772. package/dist/types/components/six-file-upload/six-file-upload.d.ts +33 -33
  773. package/dist/types/components/six-footer/six-footer.d.ts +1 -1
  774. package/dist/types/components/six-group-label/six-group-label.d.ts +22 -22
  775. package/dist/types/components/six-header/six-header.d.ts +59 -55
  776. package/dist/types/components/six-icon/six-icon.d.ts +5 -5
  777. package/dist/types/components/six-icon-button/six-icon-button.d.ts +18 -18
  778. package/dist/types/components/six-input/six-input.d.ts +109 -105
  779. package/dist/types/components/six-item-picker/six-item-picker.d.ts +95 -88
  780. package/dist/types/components/six-item-picker/types.d.ts +7 -7
  781. package/dist/types/components/six-language-switcher/six-language-switcher.d.ts +15 -15
  782. package/dist/types/components/six-layout-grid/six-layout-grid.d.ts +6 -6
  783. package/dist/types/components/six-main-container/six-main-container.d.ts +4 -4
  784. package/dist/types/components/six-menu/six-menu.d.ts +67 -63
  785. package/dist/types/components/six-menu-divider/six-menu-divider.d.ts +1 -1
  786. package/dist/types/components/six-menu-item/six-menu-item.d.ts +27 -21
  787. package/dist/types/components/six-menu-label/six-menu-label.d.ts +1 -1
  788. package/dist/types/components/six-picto/six-picto.d.ts +6 -6
  789. package/dist/types/components/six-progress-bar/six-progress-bar.d.ts +5 -5
  790. package/dist/types/components/six-progress-ring/six-progress-ring.d.ts +11 -11
  791. package/dist/types/components/six-radio/six-radio.d.ts +38 -38
  792. package/dist/types/components/six-range/six-range.d.ts +75 -75
  793. package/dist/types/components/six-root/six-root.d.ts +8 -21
  794. package/dist/types/components/six-search-field/six-search-field.d.ts +20 -20
  795. package/dist/types/components/six-select/six-select.d.ts +137 -122
  796. package/dist/types/components/six-select/util.d.ts +1 -1
  797. package/dist/types/components/six-sidebar/six-sidebar.d.ts +45 -45
  798. package/dist/types/components/six-sidebar-item/six-sidebar-item.d.ts +12 -12
  799. package/dist/types/components/six-sidebar-item-group/six-sidebar-item-group.d.ts +25 -25
  800. package/dist/types/components/six-spinner/six-spinner.d.ts +6 -5
  801. package/dist/types/components/six-stage-indicator/six-stage-indicator.d.ts +3 -3
  802. package/dist/types/components/six-switch/six-switch.d.ts +48 -48
  803. package/dist/types/components/six-tab/six-tab.d.ts +20 -20
  804. package/dist/types/components/six-tab-group/six-tab-group.d.ts +35 -35
  805. package/dist/types/components/six-tab-panel/six-tab-panel.d.ts +7 -7
  806. package/dist/types/components/six-tag/six-tag.d.ts +20 -20
  807. package/dist/types/components/six-textarea/six-textarea.d.ts +89 -89
  808. package/dist/types/components/six-tile/six-tile.d.ts +31 -31
  809. package/dist/types/components/six-timepicker/six-timepicker.d.ts +152 -152
  810. package/dist/types/components/six-tooltip/six-tooltip.d.ts +55 -55
  811. package/dist/types/components.d.ts +72 -60
  812. package/dist/types/functional-components/form-control/form-control.d.ts +32 -32
  813. package/dist/types/index.d.ts +1 -0
  814. package/dist/types/stencil-public-runtime.d.ts +8 -0
  815. package/dist/types/types.d.ts +1 -0
  816. package/dist/types/utils/alert.d.ts +10 -0
  817. package/dist/types/utils/date-util.d.ts +58 -50
  818. package/dist/types/utils/error-messages.d.ts +25 -24
  819. package/dist/types/utils/event-listeners.d.ts +11 -11
  820. package/dist/types/utils/focus-visible.d.ts +2 -2
  821. package/dist/types/utils/modal.d.ts +8 -8
  822. package/dist/types/utils/offset.d.ts +2 -2
  823. package/dist/types/utils/popover.d.ts +21 -21
  824. package/dist/types/utils/slot.d.ts +0 -1
  825. package/dist/types/utils/time.util.d.ts +6 -6
  826. package/dist/types/utils/types.d.ts +1 -1
  827. package/dist/ui-library/index.esm.js +1 -1
  828. package/dist/ui-library/index.esm.js.map +1 -1
  829. package/dist/ui-library/p-0440335d.entry.js +2 -0
  830. package/dist/ui-library/{p-48b7c199.entry.js.map → p-0440335d.entry.js.map} +1 -1
  831. package/dist/ui-library/p-04cc397c.entry.js +2 -0
  832. package/dist/ui-library/{p-cd3281fb.entry.js.map → p-04cc397c.entry.js.map} +1 -1
  833. package/dist/ui-library/{p-5654e4c7.js → p-06ba4450.js} +1 -1
  834. package/dist/ui-library/p-0cebf1d2.js +2 -0
  835. package/dist/ui-library/p-0cebf1d2.js.map +1 -0
  836. package/dist/ui-library/p-0edd3091.entry.js +2 -0
  837. package/dist/ui-library/{p-cb32f8d2.entry.js.map → p-0edd3091.entry.js.map} +1 -1
  838. package/dist/ui-library/p-150b7664.entry.js +2 -0
  839. package/dist/ui-library/{p-5904d3c3.entry.js.map → p-150b7664.entry.js.map} +1 -1
  840. package/dist/ui-library/{p-3d7678a8.entry.js → p-1f5840b5.entry.js} +2 -2
  841. package/dist/ui-library/p-28cc013e.entry.js +2 -0
  842. package/dist/ui-library/p-28cc013e.entry.js.map +1 -0
  843. package/dist/ui-library/p-3424bbc0.entry.js +2 -0
  844. package/dist/ui-library/p-3424bbc0.entry.js.map +1 -0
  845. package/dist/ui-library/p-348c68a8.entry.js +2 -0
  846. package/dist/ui-library/p-348c68a8.entry.js.map +1 -0
  847. package/dist/ui-library/p-3723ca06.entry.js +2 -0
  848. package/dist/ui-library/p-3723ca06.entry.js.map +1 -0
  849. package/dist/ui-library/p-37aeac5e.entry.js +2 -0
  850. package/dist/ui-library/{p-6e87aeea.entry.js.map → p-37aeac5e.entry.js.map} +1 -1
  851. package/dist/ui-library/p-3d7fb086.entry.js +2 -0
  852. package/dist/ui-library/p-3d7fb086.entry.js.map +1 -0
  853. package/dist/ui-library/{p-94bd8347.entry.js → p-457f7373.entry.js} +2 -2
  854. package/dist/ui-library/{p-94bd8347.entry.js.map → p-457f7373.entry.js.map} +1 -1
  855. package/dist/ui-library/p-4a667f31.entry.js +2 -0
  856. package/dist/ui-library/p-4a667f31.entry.js.map +1 -0
  857. package/dist/ui-library/p-50dae789.entry.js +2 -0
  858. package/dist/ui-library/{p-b7597736.entry.js.map → p-50dae789.entry.js.map} +1 -1
  859. package/dist/ui-library/{p-c75694df.entry.js → p-546e33d9.entry.js} +2 -2
  860. package/dist/ui-library/{p-b97764a1.entry.js → p-5db3a705.entry.js} +2 -2
  861. package/dist/ui-library/{p-b97764a1.entry.js.map → p-5db3a705.entry.js.map} +1 -1
  862. package/dist/ui-library/{p-f3fdc121.js → p-61e66671.js} +2 -2
  863. package/dist/ui-library/p-6296779b.entry.js +2 -0
  864. package/dist/ui-library/{p-de7a9448.entry.js.map → p-6296779b.entry.js.map} +1 -1
  865. package/dist/ui-library/p-64b4755d.entry.js +2 -0
  866. package/dist/ui-library/{p-9bec3e14.entry.js.map → p-64b4755d.entry.js.map} +1 -1
  867. package/dist/ui-library/p-6c1b046e.entry.js +2 -0
  868. package/dist/ui-library/p-6c1b046e.entry.js.map +1 -0
  869. package/dist/ui-library/p-7115316e.entry.js +2 -0
  870. package/dist/ui-library/p-7115316e.entry.js.map +1 -0
  871. package/dist/ui-library/p-73dd493f.entry.js +2 -0
  872. package/dist/ui-library/p-73dd493f.entry.js.map +1 -0
  873. package/dist/ui-library/{p-0fdb185d.js → p-7f856f00.js} +1 -1
  874. package/dist/ui-library/{p-052aa8d3.js → p-8227aaed.js} +1 -1
  875. package/dist/ui-library/{p-8c0971e0.js → p-842b492e.js} +1 -1
  876. package/dist/ui-library/{p-0f510624.js → p-862d474e.js} +1 -1
  877. package/dist/ui-library/p-862d474e.js.map +1 -0
  878. package/dist/ui-library/p-870b988d.entry.js +2 -0
  879. package/dist/ui-library/{p-b3a14438.entry.js.map → p-870b988d.entry.js.map} +1 -1
  880. package/dist/ui-library/{p-7d00de3a.entry.js → p-884c5cf9.entry.js} +2 -2
  881. package/dist/ui-library/p-8888a367.entry.js +2 -0
  882. package/dist/ui-library/{p-1f7dac36.entry.js.map → p-8888a367.entry.js.map} +1 -1
  883. package/dist/ui-library/{p-7d95def3.js → p-8bfb4bfc.js} +1 -1
  884. package/dist/ui-library/p-8ced18d8.entry.js +2 -0
  885. package/dist/ui-library/p-8ced18d8.entry.js.map +1 -0
  886. package/dist/ui-library/{p-b42fd9c3.entry.js → p-935c78a7.entry.js} +2 -2
  887. package/dist/ui-library/p-961bd001.entry.js +2 -0
  888. package/dist/ui-library/{p-bbefcec9.entry.js.map → p-961bd001.entry.js.map} +1 -1
  889. package/dist/ui-library/{p-9ace84c7.js → p-998de05d.js} +1 -1
  890. package/dist/ui-library/p-9b08068d.entry.js +2 -0
  891. package/dist/ui-library/p-9b08068d.entry.js.map +1 -0
  892. package/dist/ui-library/p-9c79341d.entry.js +2 -0
  893. package/dist/ui-library/{p-2e99f389.entry.js.map → p-9c79341d.entry.js.map} +1 -1
  894. package/dist/ui-library/{p-698bb2c8.js → p-a1502802.js} +1 -1
  895. package/dist/ui-library/{p-66d1d93d.entry.js → p-a9c159f2.entry.js} +2 -2
  896. package/dist/ui-library/p-ac57ba5c.entry.js +2 -0
  897. package/dist/ui-library/{p-20cb60c9.entry.js.map → p-ac57ba5c.entry.js.map} +1 -1
  898. package/dist/ui-library/p-af15381b.js +3 -0
  899. package/dist/ui-library/p-af15381b.js.map +1 -0
  900. package/dist/ui-library/p-b1a5f3cd.entry.js +2 -0
  901. package/dist/ui-library/p-b1a5f3cd.entry.js.map +1 -0
  902. package/dist/ui-library/p-b385a241.entry.js +2 -0
  903. package/dist/ui-library/{p-2945a132.entry.js.map → p-b385a241.entry.js.map} +1 -1
  904. package/dist/ui-library/p-b74c5d6b.entry.js +2 -0
  905. package/dist/ui-library/p-b74c5d6b.entry.js.map +1 -0
  906. package/dist/ui-library/p-bf2fb53f.entry.js +2 -0
  907. package/dist/ui-library/p-bf2fb53f.entry.js.map +1 -0
  908. package/dist/ui-library/p-c2c7370b.entry.js +2 -0
  909. package/dist/ui-library/{p-ae383f66.entry.js.map → p-c2c7370b.entry.js.map} +1 -1
  910. package/dist/ui-library/p-caea1eb6.entry.js +2 -0
  911. package/dist/ui-library/{p-93a9b693.entry.js.map → p-caea1eb6.entry.js.map} +1 -1
  912. package/dist/ui-library/{p-6aced322.entry.js → p-d3f5b9a8.entry.js} +2 -2
  913. package/dist/ui-library/p-d42b18eb.entry.js +2 -0
  914. package/dist/ui-library/{p-27987d45.entry.js.map → p-d42b18eb.entry.js.map} +1 -1
  915. package/dist/ui-library/p-d95e292e.entry.js +2 -0
  916. package/dist/ui-library/{p-66a48dc4.entry.js.map → p-d95e292e.entry.js.map} +1 -1
  917. package/dist/ui-library/p-da7f3dbd.entry.js +2 -0
  918. package/dist/ui-library/p-da7f3dbd.entry.js.map +1 -0
  919. package/dist/ui-library/p-dfb89b6a.entry.js +2 -0
  920. package/dist/ui-library/p-dfb89b6a.entry.js.map +1 -0
  921. package/dist/ui-library/p-e080d5b6.js +2 -0
  922. package/dist/ui-library/p-e080d5b6.js.map +1 -0
  923. package/dist/ui-library/p-e6032375.entry.js +2 -0
  924. package/dist/ui-library/p-e6032375.entry.js.map +1 -0
  925. package/dist/ui-library/p-e60d2324.entry.js +2 -0
  926. package/dist/ui-library/p-e60d2324.entry.js.map +1 -0
  927. package/dist/ui-library/p-e8298c6e.entry.js +2 -0
  928. package/dist/ui-library/{p-4196a75a.entry.js.map → p-e8298c6e.entry.js.map} +1 -1
  929. package/dist/ui-library/p-ed279165.entry.js +2 -0
  930. package/dist/ui-library/p-ed279165.entry.js.map +1 -0
  931. package/dist/ui-library/p-ed61b75c.entry.js +2 -0
  932. package/dist/ui-library/p-ed61b75c.entry.js.map +1 -0
  933. package/dist/ui-library/p-f136a6b2.js +2 -0
  934. package/dist/ui-library/p-f136a6b2.js.map +1 -0
  935. package/dist/ui-library/p-f1ab3384.entry.js +2 -0
  936. package/dist/ui-library/{p-51630491.entry.js.map → p-f1ab3384.entry.js.map} +1 -1
  937. package/dist/ui-library/p-f4ef481c.entry.js +2 -0
  938. package/dist/ui-library/p-f4ef481c.entry.js.map +1 -0
  939. package/dist/ui-library/{p-a15928c4.entry.js → p-f8cbb8da.entry.js} +2 -2
  940. package/dist/ui-library/ui-library.css +1 -10
  941. package/dist/ui-library/ui-library.esm.js +1 -1
  942. package/dist/ui-library/ui-library.esm.js.map +1 -1
  943. package/package.json +7 -11
  944. package/dist/cjs/event-listeners-fdfe838c.js +0 -61
  945. package/dist/cjs/event-listeners-fdfe838c.js.map +0 -1
  946. package/dist/cjs/focus-visible-ae2470dd.js +0 -47
  947. package/dist/cjs/form-2df8c5bb.js +0 -20
  948. package/dist/cjs/form-control-19303ed2.js +0 -36
  949. package/dist/cjs/form-control-19303ed2.js.map +0 -1
  950. package/dist/cjs/index-7d73cbd6.js.map +0 -1
  951. package/dist/cjs/modal-d5f074c7.js +0 -52
  952. package/dist/cjs/modal-d5f074c7.js.map +0 -1
  953. package/dist/cjs/popover-2df7e154.js.map +0 -1
  954. package/dist/cjs/popup-f1d9910f.js +0 -103
  955. package/dist/cjs/popup-f1d9910f.js.map +0 -1
  956. package/dist/cjs/scroll-2c4200dc.js +0 -68
  957. package/dist/cjs/set-attributes_2.cjs.entry.js +0 -73
  958. package/dist/cjs/set-attributes_2.cjs.entry.js.map +0 -1
  959. package/dist/cjs/six-checkbox.cjs.entry.js +0 -127
  960. package/dist/cjs/six-checkbox.cjs.entry.js.map +0 -1
  961. package/dist/cjs/six-menu-item.cjs.entry.js +0 -63
  962. package/dist/cjs/six-menu-item.cjs.entry.js.map +0 -1
  963. package/dist/cjs/slot-6e6a400f.js +0 -53
  964. package/dist/cjs/slot-6e6a400f.js.map +0 -1
  965. package/dist/cjs/types-47199040.js +0 -17
  966. package/dist/cjs/types-47199040.js.map +0 -1
  967. package/dist/collection/wrappers/set-attributes/set-attributes.js +0 -74
  968. package/dist/collection/wrappers/set-attributes/set-attributes.js.map +0 -1
  969. package/dist/collection/wrappers/set-attributes/test/set-attributes.spec.js +0 -16
  970. package/dist/collection/wrappers/set-attributes/test/set-attributes.spec.js.map +0 -1
  971. package/dist/components/set-attributes.d.ts +0 -11
  972. package/dist/components/set-attributes.js +0 -8
  973. package/dist/components/set-attributes.js.map +0 -1
  974. package/dist/components/set-attributes2.js +0 -73
  975. package/dist/components/set-attributes2.js.map +0 -1
  976. package/dist/components/six-tag2.js +0 -102
  977. package/dist/components/six-tag2.js.map +0 -1
  978. package/dist/esm/event-listeners-f6e5b0ab.js +0 -59
  979. package/dist/esm/event-listeners-f6e5b0ab.js.map +0 -1
  980. package/dist/esm/focus-visible-fc6ac671.js +0 -45
  981. package/dist/esm/form-81252534.js +0 -18
  982. package/dist/esm/form-control-079f7fb6.js +0 -34
  983. package/dist/esm/form-control-079f7fb6.js.map +0 -1
  984. package/dist/esm/index-4ee8b33e.js.map +0 -1
  985. package/dist/esm/modal-7d32e141.js +0 -49
  986. package/dist/esm/modal-7d32e141.js.map +0 -1
  987. package/dist/esm/popover-136d1f73.js.map +0 -1
  988. package/dist/esm/popup-7f89a001.js +0 -98
  989. package/dist/esm/popup-7f89a001.js.map +0 -1
  990. package/dist/esm/scroll-774762d6.js +0 -64
  991. package/dist/esm/set-attributes_2.entry.js +0 -68
  992. package/dist/esm/set-attributes_2.entry.js.map +0 -1
  993. package/dist/esm/six-checkbox.entry.js +0 -123
  994. package/dist/esm/six-checkbox.entry.js.map +0 -1
  995. package/dist/esm/six-menu-item.entry.js +0 -59
  996. package/dist/esm/six-menu-item.entry.js.map +0 -1
  997. package/dist/esm/slot-ad36df3a.js +0 -48
  998. package/dist/esm/slot-ad36df3a.js.map +0 -1
  999. package/dist/esm/types-59b455aa.js +0 -17
  1000. package/dist/esm/types-59b455aa.js.map +0 -1
  1001. package/dist/types/wrappers/set-attributes/set-attributes.d.ts +0 -9
  1002. package/dist/ui-library/p-0416ec85.entry.js +0 -2
  1003. package/dist/ui-library/p-0416ec85.entry.js.map +0 -1
  1004. package/dist/ui-library/p-0d8154b1.entry.js +0 -2
  1005. package/dist/ui-library/p-0d8154b1.entry.js.map +0 -1
  1006. package/dist/ui-library/p-0f510624.js.map +0 -1
  1007. package/dist/ui-library/p-120a1b66.entry.js +0 -2
  1008. package/dist/ui-library/p-120a1b66.entry.js.map +0 -1
  1009. package/dist/ui-library/p-15559d38.js +0 -2
  1010. package/dist/ui-library/p-15559d38.js.map +0 -1
  1011. package/dist/ui-library/p-16eb37cd.entry.js +0 -2
  1012. package/dist/ui-library/p-16eb37cd.entry.js.map +0 -1
  1013. package/dist/ui-library/p-1f7dac36.entry.js +0 -2
  1014. package/dist/ui-library/p-20cb60c9.entry.js +0 -2
  1015. package/dist/ui-library/p-21606e14.entry.js +0 -2
  1016. package/dist/ui-library/p-21606e14.entry.js.map +0 -1
  1017. package/dist/ui-library/p-2280038f.entry.js +0 -2
  1018. package/dist/ui-library/p-2280038f.entry.js.map +0 -1
  1019. package/dist/ui-library/p-24e80289.entry.js +0 -2
  1020. package/dist/ui-library/p-24e80289.entry.js.map +0 -1
  1021. package/dist/ui-library/p-27987d45.entry.js +0 -2
  1022. package/dist/ui-library/p-2945a132.entry.js +0 -2
  1023. package/dist/ui-library/p-2e99f389.entry.js +0 -2
  1024. package/dist/ui-library/p-4196a75a.entry.js +0 -2
  1025. package/dist/ui-library/p-48b7c199.entry.js +0 -2
  1026. package/dist/ui-library/p-51630491.entry.js +0 -2
  1027. package/dist/ui-library/p-5218986b.entry.js +0 -2
  1028. package/dist/ui-library/p-5218986b.entry.js.map +0 -1
  1029. package/dist/ui-library/p-5904d3c3.entry.js +0 -2
  1030. package/dist/ui-library/p-59210f0b.js +0 -2
  1031. package/dist/ui-library/p-59210f0b.js.map +0 -1
  1032. package/dist/ui-library/p-66a48dc4.entry.js +0 -2
  1033. package/dist/ui-library/p-6e87aeea.entry.js +0 -2
  1034. package/dist/ui-library/p-74179b03.entry.js +0 -2
  1035. package/dist/ui-library/p-74179b03.entry.js.map +0 -1
  1036. package/dist/ui-library/p-77424c6b.entry.js +0 -2
  1037. package/dist/ui-library/p-77424c6b.entry.js.map +0 -1
  1038. package/dist/ui-library/p-7e9257f3.entry.js +0 -2
  1039. package/dist/ui-library/p-7e9257f3.entry.js.map +0 -1
  1040. package/dist/ui-library/p-8226e363.entry.js +0 -2
  1041. package/dist/ui-library/p-8226e363.entry.js.map +0 -1
  1042. package/dist/ui-library/p-8296e24c.entry.js +0 -2
  1043. package/dist/ui-library/p-8296e24c.entry.js.map +0 -1
  1044. package/dist/ui-library/p-93a9b693.entry.js +0 -2
  1045. package/dist/ui-library/p-9bec3e14.entry.js +0 -2
  1046. package/dist/ui-library/p-a4348ad4.entry.js +0 -2
  1047. package/dist/ui-library/p-a4348ad4.entry.js.map +0 -1
  1048. package/dist/ui-library/p-acd3ecfd.entry.js +0 -2
  1049. package/dist/ui-library/p-acd3ecfd.entry.js.map +0 -1
  1050. package/dist/ui-library/p-ae383f66.entry.js +0 -2
  1051. package/dist/ui-library/p-af0e163e.entry.js +0 -2
  1052. package/dist/ui-library/p-af0e163e.entry.js.map +0 -1
  1053. package/dist/ui-library/p-b3a14438.entry.js +0 -2
  1054. package/dist/ui-library/p-b5fdfa6a.js +0 -3
  1055. package/dist/ui-library/p-b5fdfa6a.js.map +0 -1
  1056. package/dist/ui-library/p-b7597736.entry.js +0 -2
  1057. package/dist/ui-library/p-b906a605.entry.js +0 -2
  1058. package/dist/ui-library/p-b906a605.entry.js.map +0 -1
  1059. package/dist/ui-library/p-bbefcec9.entry.js +0 -2
  1060. package/dist/ui-library/p-cb32f8d2.entry.js +0 -2
  1061. package/dist/ui-library/p-cd3281fb.entry.js +0 -2
  1062. package/dist/ui-library/p-cec8c149.entry.js +0 -2
  1063. package/dist/ui-library/p-cec8c149.entry.js.map +0 -1
  1064. package/dist/ui-library/p-d1ba2ad5.entry.js +0 -2
  1065. package/dist/ui-library/p-d1ba2ad5.entry.js.map +0 -1
  1066. package/dist/ui-library/p-d2196113.entry.js +0 -2
  1067. package/dist/ui-library/p-d2196113.entry.js.map +0 -1
  1068. package/dist/ui-library/p-de7a9448.entry.js +0 -2
  1069. package/dist/ui-library/p-df1c4a1f.entry.js +0 -2
  1070. package/dist/ui-library/p-df1c4a1f.entry.js.map +0 -1
  1071. package/dist/ui-library/p-e740215a.entry.js +0 -2
  1072. package/dist/ui-library/p-e740215a.entry.js.map +0 -1
  1073. /package/dist/ui-library/{p-5654e4c7.js.map → p-06ba4450.js.map} +0 -0
  1074. /package/dist/ui-library/{p-3d7678a8.entry.js.map → p-1f5840b5.entry.js.map} +0 -0
  1075. /package/dist/ui-library/{p-c75694df.entry.js.map → p-546e33d9.entry.js.map} +0 -0
  1076. /package/dist/ui-library/{p-f3fdc121.js.map → p-61e66671.js.map} +0 -0
  1077. /package/dist/ui-library/{p-0fdb185d.js.map → p-7f856f00.js.map} +0 -0
  1078. /package/dist/ui-library/{p-052aa8d3.js.map → p-8227aaed.js.map} +0 -0
  1079. /package/dist/ui-library/{p-8c0971e0.js.map → p-842b492e.js.map} +0 -0
  1080. /package/dist/ui-library/{p-7d00de3a.entry.js.map → p-884c5cf9.entry.js.map} +0 -0
  1081. /package/dist/ui-library/{p-7d95def3.js.map → p-8bfb4bfc.js.map} +0 -0
  1082. /package/dist/ui-library/{p-b42fd9c3.entry.js.map → p-935c78a7.entry.js.map} +0 -0
  1083. /package/dist/ui-library/{p-9ace84c7.js.map → p-998de05d.js.map} +0 -0
  1084. /package/dist/ui-library/{p-698bb2c8.js.map → p-a1502802.js.map} +0 -0
  1085. /package/dist/ui-library/{p-66d1d93d.entry.js.map → p-a9c159f2.entry.js.map} +0 -0
  1086. /package/dist/ui-library/{p-6aced322.entry.js.map → p-d3f5b9a8.entry.js.map} +0 -0
  1087. /package/dist/ui-library/{p-a15928c4.entry.js.map → p-f8cbb8da.entry.js.map} +0 -0
@@ -2,11 +2,7 @@ import { h } from "@stencil/core";
2
2
  import { getNearestTabbableElement } from "../../utils/tabbable";
3
3
  import Popover from "../../utils/popover";
4
4
  import { EventListeners } from "../../utils/event-listeners";
5
- import { getSlotChildren } from "../../utils/slot";
6
5
  import { debounce, DEFAULT_DEBOUNCE_FAST } from "../../utils/execution-control";
7
- const isTagName = (name) => (el) => (el === null || el === void 0 ? void 0 : el.tagName.toLowerCase()) === name.toLowerCase();
8
- const isSixMenu = isTagName('six-menu');
9
- const isSixMenuItem = isTagName('six-menu-item');
10
6
  let id = 0;
11
7
  /**
12
8
  * @since 1.0
@@ -15,6 +11,7 @@ let id = 0;
15
11
  * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.
16
12
  *
17
13
  * @slot trigger - The dropdown's trigger, usually a `<six-button>` element.
14
+ * @slot dropdown-footer - The dropdown's footer area.
18
15
  * @slot - The dropdown's content.
19
16
  *
20
17
  * @part base - The component's base wrapper.
@@ -22,922 +19,1017 @@ let id = 0;
22
19
  * @part panel - The panel that gets shown when the dropdown is open.
23
20
  */
24
21
  export class SixDropdown {
25
- constructor() {
26
- this.componentId = `dropdown-${++id}`;
27
- this.isVisible = false;
28
- this.hasBeenInitialized = false;
29
- this.eventListeners = new EventListeners();
30
- this.getMenuItems = () => {
31
- if (this.filteredOptions.length > 0) {
32
- return this.filteredOptions.map((option) => h("six-menu-item", { value: option.value }, option.label));
33
- }
34
- if (this.panel == null)
35
- return [];
36
- const [panel] = getSlotChildren(this.panel);
37
- // the menu-items can be in a slot e.g. in six-select or direct children of the panel
38
- return getSlotChildren(panel) || Array.from(panel.querySelectorAll('six-menu-item'));
39
- };
40
- this.handleFilterInputChange = () => {
41
- var _a, _b;
42
- if (this.filterInputElement == null)
43
- return;
44
- const lowerCaseFilterTerm = ((_b = (_a = this.filterInputElement.value) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === null || _b === void 0 ? void 0 : _b.trim()) || '';
45
- if (this.filteredOptions.length > 0) {
46
- this.handleFilteringForAttributeItems(lowerCaseFilterTerm);
47
- }
48
- else {
49
- this.handleFilteringForSlotItems(lowerCaseFilterTerm);
50
- }
51
- this.sixAutoFilter.emit({ filterValue: lowerCaseFilterTerm });
52
- };
53
- this.handleDocumentKeyDown = (event) => {
54
- var _a;
55
- const keyboardEvent = event;
56
- // Close when escape is pressed
57
- if (keyboardEvent.key === 'Escape') {
58
- void this.hide();
59
- this.focusOnTrigger();
60
- return;
61
- }
62
- if (this.filterInputElement === ((_a = this.host.shadowRoot) === null || _a === void 0 ? void 0 : _a.activeElement)) {
63
- if (keyboardEvent.key === 'ArrowDown') {
64
- const item = this.getMenuItems().find((item) => item.style.display !== 'none');
65
- if (item != null) {
66
- item.setFocus();
67
- }
68
- }
69
- }
70
- // Handle tabbing
71
- if (keyboardEvent.key === 'Tab') {
72
- // Tabbing within an open menu should close the dropdown and refocus the trigger
73
- if (this.open && document.activeElement != null && isSixMenuItem(document.activeElement)) {
74
- keyboardEvent.preventDefault();
75
- void this.hide();
76
- this.focusOnTrigger();
77
- return;
78
- }
79
- // Tabbing outside the containing element closes the panel
80
- //
81
- // If the dropdown is used within a shadow DOM, we need to obtain the activeElement within that shadowRoot,
82
- // otherwise `document.activeElement` will only return the name of the parent shadow DOM element.
83
- setTimeout(() => {
84
- var _a, _b;
85
- const activeElement = this.container.getRootNode() instanceof ShadowRoot
86
- ? (_b = (_a = document.activeElement) === null || _a === void 0 ? void 0 : _a.shadowRoot) === null || _b === void 0 ? void 0 : _b.activeElement
87
- : document.activeElement;
88
- if ((activeElement === null || activeElement === void 0 ? void 0 : activeElement.closest(this.container.tagName.toLowerCase())) !== this.container) {
89
- void this.hide();
90
- return;
91
- }
92
- });
93
- }
94
- };
95
- this.handleDocumentMouseDown = (event) => {
96
- // Close when clicking outside the containing element
97
- const path = event.composedPath();
98
- if (!path.includes(this.container)) {
99
- void this.hide();
100
- return;
101
- }
102
- };
103
- this.handlePanelSelect = (event) => {
104
- const target = event.target;
105
- // Hide the dropdown when a menu item is selected
106
- if (this.closeOnSelect && isSixMenu(target)) {
107
- void this.hide();
108
- this.focusOnTrigger();
109
- }
110
- };
111
- this.handleTriggerClick = () => {
112
- this.open ? this.hide() : this.show();
113
- };
114
- this.handleTriggerKeyDown = (event) => {
115
- // Close when escape or tab is pressed
116
- if (event.key === 'Escape') {
117
- this.focusOnTrigger();
118
- void this.hide();
119
- return;
120
- }
121
- // When spacebar/enter is pressed, show the panel but don't focus on the menu. This let's the user press the same
122
- // key again to hide the menu in case they don't want to make a selection.
123
- if (!this.disableHideOnEnterAndSpace && [' ', 'Enter'].includes(event.key)) {
124
- event.preventDefault();
125
- this.open ? void this.hide() : void this.show();
126
- return;
127
- }
128
- const menu = this.getMenu();
129
- // When up/down is pressed, we make the assumption that the user is familiar with the menu and plans to make a
130
- // selection. Rather than toggle the panel, we focus on the menu (if one exists) and activate the first item for
131
- // faster navigation.
132
- if (['ArrowDown', 'ArrowUp'].includes(event.key)) {
133
- event.preventDefault();
134
- // Show the menu if it's not already open
135
- if (!this.open) {
136
- void this.show();
137
- }
138
- if (menu == null) {
139
- return;
140
- }
141
- const menuItems = [...menu.querySelectorAll('six-menu-item')];
142
- const firstMenuItem = menuItems.at(0);
143
- const lastMenuItem = menuItems.at(menuItems.length - 1);
144
- // Focus on a menu item
145
- if (event.key === 'ArrowDown' && firstMenuItem != null) {
146
- firstMenuItem.setFocus();
147
- return;
148
- }
149
- if (event.key === 'ArrowUp' && lastMenuItem != null) {
150
- lastMenuItem.setFocus();
151
- return;
152
- }
153
- }
154
- // Other keys bring focus to the menu and initiate type-to-select behavior
155
- const ignoredKeys = ['Tab', 'Shift', 'Meta', 'Ctrl', 'Alt'];
156
- if (this.open && menu != null && !ignoredKeys.includes(event.key)) {
157
- void menu.typeToSelect(event.key);
158
- return;
159
- }
160
- };
161
- this.handleTriggerKeyUp = (event) => {
162
- // Prevent space from triggering a click event in Firefox
163
- if (event.key === ' ') {
164
- event.preventDefault();
165
- }
166
- };
167
- this.handleTriggerSlotChange = () => {
168
- this.updateAccessibleTrigger();
169
- };
170
- this.handleDropdownScroll = () => {
171
- if (this.panel == null)
172
- return;
173
- this.sixScroll.emit({
174
- scrollHeight: this.panel.scrollHeight,
175
- scrollTop: this.panel.scrollTop,
176
- scrollbarHeight: this.panel.offsetHeight * (this.panel.offsetHeight / this.panel.scrollHeight),
177
- scrollRatio: this.panel.scrollTop / (this.panel.scrollHeight - this.panel.clientHeight),
178
- });
179
- };
180
- this.open = false;
181
- this.placement = 'bottom-start';
182
- this.closeOnSelect = true;
183
- this.distance = 0;
184
- this.skidding = 0;
185
- this.hoist = false;
186
- this.containingElement = undefined;
187
- this.filter = false;
188
- this.asyncFilter = false;
189
- this.filterPlaceholder = 'Filter...';
190
- this.autofocusFilter = true;
191
- this.filterDebounce = DEFAULT_DEBOUNCE_FAST;
192
- this.disableHideOnEnterAndSpace = false;
193
- this.options = [];
194
- this.virtualScroll = false;
195
- this.filteredOptions = [];
196
- }
197
- get hasFilterEnabled() {
198
- return this.filter || this.asyncFilter;
199
- }
200
- get container() {
201
- return this.containingElement || this.host;
202
- }
203
- handleOpenChange() {
204
- this.open ? this.show() : this.hide();
205
- this.updateAccessibleTrigger();
206
- }
207
- handlePopoverOptionsChange() {
208
- if (this.popover == null)
209
- return;
210
- this.popover.setOptions({
211
- strategy: this.hoist ? 'fixed' : 'absolute',
212
- placement: this.placement,
213
- distance: this.distance,
214
- skidding: this.skidding,
215
- });
216
- }
217
- handleOptionsChange() {
218
- if (Array.isArray(this.options)) {
219
- this.filteredOptions = [...this.options];
22
+ constructor() {
23
+ this.componentId = `dropdown-${++id}`;
24
+ this.isVisible = false;
25
+ this.resizeObserver = new ResizeObserver(debounce(() => this.updatePanelPosition(), 100));
26
+ this.eventListeners = new EventListeners();
27
+ this.getMenuItems = () => {
28
+ var _a, _b, _c, _d;
29
+ if (this.options.length > 0) {
30
+ return {
31
+ sixMenuItems: this.renderedOptions.map((option) => (h("six-menu-item", { value: option.value }, option.label))),
32
+ selectionContainerItems: [],
33
+ };
34
+ }
35
+ if (this.panel == null)
36
+ return { sixMenuItems: [], selectionContainerItems: [] };
37
+ // Relies on the implementation of six-select. Its dropdown slot contains two elements,
38
+ // one for the selected menu items, and one for the other items.
39
+ const selectionContainer = (_a = this.panelSlot) === null || _a === void 0 ? void 0 : _a.assignedElements({ flatten: true }).filter(isSelectionContainer).at(0);
40
+ const sixMenuElement = (_b = this.panelSlot) === null || _b === void 0 ? void 0 : _b.assignedElements({ flatten: true }).filter(isSixMenu).at(0);
41
+ const selectionContainerItems = (selectionContainer === null || selectionContainer === void 0 ? void 0 : selectionContainer.querySelectorAll('six-menu-item')) || [];
42
+ let sixMenuItems = ((_c = sixMenuElement === null || sixMenuElement === void 0 ? void 0 : sixMenuElement.querySelector('slot')) === null || _c === void 0 ? void 0 : _c.assignedElements().filter((el) => isSixMenuItem(el))) || [];
43
+ if (sixMenuItems.length === 0) {
44
+ sixMenuItems = Array.from(((_d = sixMenuElement === null || sixMenuElement === void 0 ? void 0 : sixMenuElement.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelectorAll('six-menu-item')) || []);
45
+ }
46
+ if (selectionContainerItems.length > 0 || sixMenuItems.length > 0) {
47
+ return { sixMenuItems, selectionContainerItems: [...selectionContainerItems] };
48
+ }
49
+ else {
50
+ return {
51
+ sixMenuItems: sixMenuElement ? Array.from(sixMenuElement.querySelectorAll('six-menu-item')) : [],
52
+ selectionContainerItems: [],
53
+ };
54
+ }
55
+ };
56
+ this.handleDocumentKeyDown = (event) => {
57
+ var _a;
58
+ const keyboardEvent = event;
59
+ // Close when escape is pressed
60
+ if (keyboardEvent.key === 'Escape') {
61
+ void this.hide();
62
+ this.focusOnTrigger();
63
+ return;
64
+ }
65
+ if (this.filterInputElement === ((_a = this.host.shadowRoot) === null || _a === void 0 ? void 0 : _a.activeElement)) {
66
+ if (keyboardEvent.key === 'ArrowDown') {
67
+ const { sixMenuItems, selectionContainerItems } = this.getMenuItems();
68
+ const item = [...selectionContainerItems, ...sixMenuItems].find((item) => item.style.display !== 'none');
69
+ if (item != null) {
70
+ item.setFocus();
71
+ }
72
+ }
73
+ }
74
+ // Handle tabbing
75
+ if (keyboardEvent.key === 'Tab') {
76
+ // Tabbing within an open menu should close the dropdown and refocus the trigger
77
+ if (this.open && document.activeElement != null && isSixMenuItem(document.activeElement)) {
78
+ keyboardEvent.preventDefault();
79
+ void this.hide();
80
+ this.focusOnTrigger();
81
+ return;
82
+ }
83
+ // Tabbing outside the containing element closes the panel
84
+ //
85
+ // If the dropdown is used within a shadow DOM, we need to obtain the activeElement within that shadowRoot,
86
+ // otherwise `document.activeElement` will only return the name of the parent shadow DOM element.
87
+ setTimeout(() => {
88
+ var _a, _b;
89
+ const activeElement = this.container.getRootNode() instanceof ShadowRoot
90
+ ? (_b = (_a = document.activeElement) === null || _a === void 0 ? void 0 : _a.shadowRoot) === null || _b === void 0 ? void 0 : _b.activeElement
91
+ : document.activeElement;
92
+ if ((activeElement === null || activeElement === void 0 ? void 0 : activeElement.closest(this.container.tagName.toLowerCase())) !== this.container) {
93
+ void this.hide();
94
+ return;
95
+ }
96
+ });
97
+ }
98
+ };
99
+ this.handleDocumentMouseDown = (event) => {
100
+ // Close when clicking outside the containing element
101
+ const path = event.composedPath();
102
+ if (!path.includes(this.container)) {
103
+ void this.hide();
104
+ return;
105
+ }
106
+ };
107
+ this.handlePanelSelect = (event) => {
108
+ const target = event.target;
109
+ // Hide the dropdown when a menu item is selected
110
+ if (this.closeOnSelect && isSixMenu(target)) {
111
+ void this.hide();
112
+ this.focusOnTrigger();
113
+ }
114
+ };
115
+ this.handleTriggerClick = () => {
116
+ this.open ? this.hide() : this.show();
117
+ };
118
+ this.handleTriggerKeyDown = (event) => {
119
+ // Close when escape or tab is pressed
120
+ if (event.key === 'Escape') {
121
+ this.focusOnTrigger();
122
+ void this.hide();
123
+ return;
124
+ }
125
+ // When spacebar/enter is pressed, show the panel but don't focus on the menu. This let's the user press the same
126
+ // key again to hide the menu in case they don't want to make a selection.
127
+ if (!this.disableHideOnEnterAndSpace && [' ', 'Enter'].includes(event.key)) {
128
+ event.preventDefault();
129
+ this.open ? void this.hide() : void this.show();
130
+ return;
131
+ }
132
+ const menu = this.getMenu();
133
+ // When up/down is pressed, we make the assumption that the user is familiar with the menu and plans to make a
134
+ // selection. Rather than toggle the panel, we focus on the menu (if one exists) and activate the first item for
135
+ // faster navigation.
136
+ if (['ArrowDown', 'ArrowUp'].includes(event.key)) {
137
+ event.preventDefault();
138
+ // Show the menu if it's not already open
139
+ if (!this.open) {
140
+ void this.show();
141
+ }
142
+ if (menu == null) {
143
+ return;
144
+ }
145
+ const menuItems = [...menu.querySelectorAll('six-menu-item')];
146
+ const firstMenuItem = menuItems.at(0);
147
+ const lastMenuItem = menuItems.at(menuItems.length - 1);
148
+ // Focus on a menu item
149
+ if (event.key === 'ArrowDown' && firstMenuItem != null) {
150
+ firstMenuItem.setFocus();
151
+ return;
152
+ }
153
+ if (event.key === 'ArrowUp' && lastMenuItem != null) {
154
+ lastMenuItem.setFocus();
155
+ return;
156
+ }
157
+ }
158
+ // Other keys bring focus to the menu and initiate type-to-select behavior
159
+ const ignoredKeys = ['Tab', 'Shift', 'Meta', 'Ctrl', 'Alt'];
160
+ if (this.open && menu != null && !ignoredKeys.includes(event.key)) {
161
+ void menu.typeToSelect(event.key);
162
+ return;
163
+ }
164
+ };
165
+ this.handleTriggerKeyUp = (event) => {
166
+ // Prevent space from triggering a click event in Firefox
167
+ if (event.key === ' ') {
168
+ event.preventDefault();
169
+ }
170
+ };
171
+ this.handleTriggerSlotChange = () => {
172
+ this.updateAccessibleTrigger();
173
+ };
174
+ this.handleDropdownScroll = () => {
175
+ if (this.scrollPanel == null)
176
+ return;
177
+ this.sixScroll.emit({
178
+ scrollHeight: this.scrollPanel.scrollHeight,
179
+ scrollTop: this.scrollPanel.scrollTop,
180
+ scrollbarHeight: this.scrollPanel.offsetHeight * (this.scrollPanel.offsetHeight / this.scrollPanel.scrollHeight),
181
+ scrollRatio: this.scrollPanel.scrollTop / (this.scrollPanel.scrollHeight - this.scrollPanel.clientHeight),
182
+ });
183
+ };
184
+ this.open = false;
185
+ this.placement = 'bottom-start';
186
+ this.closeOnSelect = true;
187
+ this.distance = 4;
188
+ this.skidding = 0;
189
+ this.hoist = false;
190
+ this.containingElement = undefined;
191
+ this.filter = false;
192
+ this.asyncFilter = false;
193
+ this.filterPlaceholder = 'Filter...';
194
+ this.autofocusFilter = true;
195
+ this.filterDebounce = 0;
196
+ this.disableHideOnEnterAndSpace = false;
197
+ this.options = [];
198
+ this.virtualScroll = false;
199
+ this.matchTriggerWidth = false;
200
+ this.renderedOptions = [];
220
201
  }
221
- }
222
- connectedCallback() {
223
- if (this.virtualScroll && this.options === null) {
224
- console.error('Options must be defined when using virtual scrolling');
202
+ get filterEnabled() {
203
+ return this.filter || this.asyncFilter;
225
204
  }
226
- if (Array.isArray(this.options)) {
227
- this.filteredOptions = [...this.options];
205
+ get container() {
206
+ return this.containingElement || this.host;
228
207
  }
229
- if (this.hasBeenInitialized && this.popover == null) {
230
- // there was a weird bug when using six-dropdown inside an ag-grid filter. When closing the ag-grid filter
231
- // disconnectedCallback() is executed. However, since componentDidLoad() will not be rerendered the popover had
232
- // no longer a connected transitionEnd callback to the dropdown. To fix this, we have this sanity check here,
233
- // to re-initialize the popover in case the component has already been initialized but the popover is undefined.
234
- this.initializePopover();
208
+ handleOpenChange() {
209
+ this.open ? this.show() : this.hide();
210
+ this.updateAccessibleTrigger();
235
211
  }
236
- }
237
- componentDidLoad() {
238
- this.hasBeenInitialized = true;
239
- this.initializePopover();
240
- // Show on init if open
241
- if (this.open) {
242
- void this.show();
212
+ handlePopoverOptionsChange() {
213
+ if (this.popover == null)
214
+ return;
215
+ this.popover.setOptions({
216
+ strategy: this.hoist ? 'fixed' : 'absolute',
217
+ placement: this.placement,
218
+ distance: this.distance,
219
+ skidding: this.skidding,
220
+ });
243
221
  }
244
- if (this.filter) {
245
- this.setupFiltering(this.handleFilterInputChange);
222
+ handleOptionsChange() {
223
+ this.validateOptions();
246
224
  }
247
- else if (this.asyncFilter) {
248
- this.setupFiltering(() => { var _a, _b; return this.sixAsyncFilterFired.emit({ filterValue: (_b = (_a = this.filterInputElement) === null || _a === void 0 ? void 0 : _a.value) !== null && _b !== void 0 ? _b : '' }); });
225
+ validateOptions() {
226
+ if (!Array.isArray(this.options)) {
227
+ this.options = [];
228
+ }
229
+ if (this.virtualScroll && this.options.length === 0) {
230
+ console.error('Options must be defined when using virtual scrolling');
231
+ }
232
+ this.renderedOptions = [...this.options];
249
233
  }
250
- }
251
- initializePopover() {
252
- if (this.trigger == null || this.positioner == null)
253
- return;
254
- const onAfterHide = () => {
255
- if (this.filter && this.filterInputElement != null) {
256
- this.filterInputElement.value = '';
257
- if (this.filteredOptions.length > 0) {
258
- this.filteredOptions = [...this.options];
234
+ componentWillLoad() {
235
+ this.validateOptions();
236
+ if (this.asyncFilter) {
237
+ this.filterDebounce = DEFAULT_DEBOUNCE_FAST;
259
238
  }
260
- else {
261
- const menuItems = this.getMenuItems();
262
- menuItems.forEach((item) => (item.style.display = 'unset'));
239
+ }
240
+ componentDidLoad() {
241
+ this.init();
242
+ if (this.open) {
243
+ void this.show();
263
244
  }
264
- }
265
- this.sixAfterHide.emit();
266
- };
267
- const onAfterShow = async () => {
268
- var _a;
269
- if (this.hasFilterEnabled && this.autofocusFilter) {
270
- // if dropdown filter is enabled we should autofocus the search field
271
- await ((_a = this.filterInputElement) === null || _a === void 0 ? void 0 : _a.setFocus());
272
- }
273
- this.sixAfterShow.emit();
274
- };
275
- const onTransitionEnd = () => {
276
- if (!this.open && this.panel != null) {
277
- this.panel.scrollTop = 0;
278
- }
279
- };
280
- this.popover = new Popover(this.trigger, this.positioner, {
281
- strategy: this.hoist ? 'fixed' : 'absolute',
282
- placement: this.placement,
283
- distance: this.distance,
284
- skidding: this.skidding,
285
- transitionElement: this.panel,
286
- onAfterHide,
287
- onAfterShow,
288
- onTransitionEnd,
289
- });
290
- }
291
- setupFiltering(callback) {
292
- if (this.filterInputElement != null) {
293
- this.eventListeners.add(this.filterInputElement, 'six-input-input', debounce(callback, this.filterDebounce));
294
245
  }
295
- }
296
- handleFilteringForAttributeItems(lowerCaseFilterTerm) {
297
- if (lowerCaseFilterTerm === '' && Array.isArray(this.options)) {
298
- this.filteredOptions = [...this.options];
299
- return;
246
+ connectedCallback() {
247
+ this.init();
300
248
  }
301
- this.filteredOptions = this.options.filter((option) => {
302
- var _a, _b, _c, _d;
303
- return (option.label && ((_b = (_a = String(option.label)) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === null || _b === void 0 ? void 0 : _b.includes(lowerCaseFilterTerm))) ||
304
- (option.value && ((_d = (_c = String(option.value)) === null || _c === void 0 ? void 0 : _c.toLowerCase()) === null || _d === void 0 ? void 0 : _d.includes(lowerCaseFilterTerm)));
305
- });
306
- }
307
- handleFilteringForSlotItems(lowerCaseFilterTerm) {
308
- const menuItems = this.getMenuItems();
309
- menuItems.forEach(async (menuItem) => {
310
- var _a, _b, _c, _d;
311
- // hide all elements which don't contain the entered substring
312
- const elementContainsFilterTerm = ((_b = (_a = menuItem === null || menuItem === void 0 ? void 0 : menuItem.value) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === null || _b === void 0 ? void 0 : _b.includes(lowerCaseFilterTerm)) ||
313
- ((_d = (_c = (await (menuItem === null || menuItem === void 0 ? void 0 : menuItem.getTextLabel()))) === null || _c === void 0 ? void 0 : _c.toLowerCase()) === null || _d === void 0 ? void 0 : _d.includes(lowerCaseFilterTerm));
314
- menuItem.style.display = elementContainsFilterTerm ? 'unset' : 'none';
315
- });
316
- }
317
- disconnectedCallback() {
318
- var _a;
319
- this.eventListeners.removeAll();
320
- void this.hide();
321
- (_a = this.popover) === null || _a === void 0 ? void 0 : _a.destroy();
322
- this.popover = undefined;
323
- }
324
- /** Shows the dropdown panel */
325
- async show() {
326
- // Prevent subsequent calls to the method, whether manually or triggered by the `open` watcher
327
- if (this.isVisible || this.popover == null || this.panel == null) {
328
- return;
249
+ init() {
250
+ this.initPopover();
251
+ // listen to filter
252
+ const filterInputElement = this.filterInputElement;
253
+ if (filterInputElement != null) {
254
+ this.eventListeners.add(filterInputElement, 'six-input-input', debounce(() => {
255
+ var _a;
256
+ const filterValue = (_a = filterInputElement.value) !== null && _a !== void 0 ? _a : '';
257
+ if (this.filter) {
258
+ this.applyFilter(filterValue);
259
+ }
260
+ this.emitFilterEvents(filterValue);
261
+ }, this.filterDebounce));
262
+ }
329
263
  }
330
- const sixShow = this.sixShow.emit();
331
- if (sixShow.defaultPrevented) {
332
- this.open = false;
333
- return;
264
+ applyFilter(filterTerm) {
265
+ var _a;
266
+ const lowerCaseFilterTerm = ((_a = filterTerm.toLowerCase()) === null || _a === void 0 ? void 0 : _a.trim()) || '';
267
+ if (this.options.length > 0) {
268
+ this.renderedOptions = this.options.filter((option) => {
269
+ var _a, _b, _c, _d;
270
+ return (option.label && ((_b = (_a = String(option.label)) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === null || _b === void 0 ? void 0 : _b.includes(lowerCaseFilterTerm))) ||
271
+ (option.value && ((_d = (_c = String(option.value)) === null || _c === void 0 ? void 0 : _c.toLowerCase()) === null || _d === void 0 ? void 0 : _d.includes(lowerCaseFilterTerm)));
272
+ });
273
+ }
274
+ else {
275
+ const { selectionContainerItems, sixMenuItems } = this.getMenuItems();
276
+ const selectionContainerValues = selectionContainerItems.map((s) => s.value);
277
+ // Filter items in selection container
278
+ selectionContainerItems.forEach(async (menuItem) => {
279
+ menuItem.style.display = (await containsFilterTerm(menuItem, lowerCaseFilterTerm)) ? 'unset' : 'none';
280
+ });
281
+ // Filter other items. Always hide items which contained in the selection container.
282
+ sixMenuItems.forEach(async (menuItem) => {
283
+ menuItem.style.display =
284
+ (await containsFilterTerm(menuItem, lowerCaseFilterTerm)) &&
285
+ !selectionContainerValues.includes(menuItem.value)
286
+ ? 'unset'
287
+ : 'none';
288
+ });
289
+ }
334
290
  }
335
- this.eventListeners.add(this.panel, 'six-menu-item-selected', this.handlePanelSelect);
336
- this.eventListeners.add(document, 'keydown', this.handleDocumentKeyDown);
337
- this.eventListeners.add(document, 'mousedown', this.handleDocumentMouseDown);
338
- this.isVisible = true;
339
- this.open = true;
340
- this.popover.show();
341
- }
342
- /** Hides the dropdown panel */
343
- async hide() {
344
- // Prevent subsequent calls to the method, whether manually or triggered by the `open` watcher
345
- if (!this.isVisible || this.panel == null || this.popover == null) {
346
- return;
291
+ resetFilter() {
292
+ if (this.filterInputElement != null) {
293
+ this.filterInputElement.value = '';
294
+ this.emitFilterEvents('');
295
+ }
296
+ if (this.options.length > 0) {
297
+ this.renderedOptions = [...this.options];
298
+ }
299
+ else {
300
+ const { selectionContainerItems, sixMenuItems } = this.getMenuItems();
301
+ [...selectionContainerItems, ...sixMenuItems].forEach((item) => (item.style.display = 'unset'));
302
+ }
347
303
  }
348
- const sixHide = this.sixHide.emit();
349
- if (sixHide.defaultPrevented) {
350
- this.open = true;
351
- return;
304
+ emitFilterEvents(filterValue) {
305
+ if (this.filter) {
306
+ this.sixAutoFilter.emit({ filterValue });
307
+ }
308
+ else if (this.asyncFilter) {
309
+ this.sixAsyncFilterFired.emit({ filterValue });
310
+ }
352
311
  }
353
- this.eventListeners.remove(this.panel, 'six-menu-item-selected', this.handlePanelSelect);
354
- this.eventListeners.remove(document, 'keydown', this.handleDocumentKeyDown);
355
- this.eventListeners.remove(document, 'mousedown', this.handleDocumentMouseDown);
356
- this.isVisible = false;
357
- this.open = false;
358
- this.popover.hide();
359
- }
360
- focusOnTrigger() {
361
- if (this.trigger == null)
362
- return;
363
- const [trigger] = getSlotChildren(this.trigger);
364
- if (trigger != null) {
365
- if (typeof trigger.setFocus === 'function') {
366
- trigger.setFocus();
367
- }
368
- else if (typeof trigger.focus === 'function') {
369
- trigger.focus();
370
- }
312
+ initPopover() {
313
+ if (this.trigger == null || this.positioner == null)
314
+ return;
315
+ this.popover = new Popover(this.trigger, this.positioner, {
316
+ strategy: this.hoist ? 'fixed' : 'absolute',
317
+ placement: this.placement,
318
+ distance: this.distance,
319
+ skidding: this.skidding,
320
+ transitionElement: this.panel,
321
+ onAfterHide: () => {
322
+ if (this.filterEnabled) {
323
+ this.resetFilter();
324
+ }
325
+ this.sixAfterHide.emit();
326
+ },
327
+ onAfterShow: async () => {
328
+ this.sixAfterShow.emit();
329
+ },
330
+ onTransitionEnd: () => {
331
+ if (!this.open && this.scrollPanel != null) {
332
+ this.scrollPanel.scrollTop = 0;
333
+ }
334
+ },
335
+ });
371
336
  }
372
- }
373
- getMenu() {
374
- if (this.panel == null)
375
- return;
376
- return getSlotChildren(this.panel).filter(isSixMenu).at(0);
377
- }
378
- /**
379
- * Instructs the dropdown menu to reposition. Useful when the position or size of the trigger changes when the menu
380
- * is activated.
381
- */
382
- async reposition() {
383
- if (!this.open || this.popover == null) {
384
- return;
337
+ disconnectedCallback() {
338
+ var _a;
339
+ this.resizeObserver.disconnect();
340
+ this.eventListeners.removeAll();
341
+ void this.hide();
342
+ (_a = this.popover) === null || _a === void 0 ? void 0 : _a.destroy();
343
+ this.popover = undefined;
385
344
  }
386
- this.popover.reposition();
387
- }
388
- //
389
- // Slotted triggers can be arbitrary content, but we need to link them to the dropdown panel with `aria-haspopup` and
390
- // `aria-expanded`. These must be applied to the "accessible trigger" (the tabbable portion of the trigger element
391
- // that gets slotted in) so screen readers will understand them. The accessible trigger could be the slotted element,
392
- // a child of the slotted element, or an element in the slotted element's shadow root.
393
- //
394
- // For example, the accessible trigger of an <sl-button> is a <button> located inside its shadow root.
395
- //
396
- // To determine this, we assume the first tabbable element in the trigger slot is the "accessible trigger."
397
- //
398
- updateAccessibleTrigger() {
399
- if (this.trigger == null)
400
- return;
401
- const accessibleTrigger = getSlotChildren(this.trigger).map(getNearestTabbableElement).at(0);
402
- if (accessibleTrigger != null) {
403
- accessibleTrigger.setAttribute('aria-haspopup', 'true');
404
- accessibleTrigger.setAttribute('aria-expanded', this.open ? 'true' : 'false');
345
+ /** Shows the dropdown panel */
346
+ async show() {
347
+ // Prevent subsequent calls to the method, whether manually or triggered by the `open` watcher
348
+ if (this.isVisible || this.popover == null || this.panel == null) {
349
+ return;
350
+ }
351
+ const sixShow = this.sixShow.emit();
352
+ if (sixShow.defaultPrevented) {
353
+ this.open = false;
354
+ return;
355
+ }
356
+ this.eventListeners.add(this.panel, 'six-menu-item-selected', this.handlePanelSelect);
357
+ this.eventListeners.add(document, 'keydown', this.handleDocumentKeyDown);
358
+ this.eventListeners.add(document, 'mousedown', this.handleDocumentMouseDown);
359
+ this.isVisible = true;
360
+ this.open = true;
361
+ if (this.trigger != null) {
362
+ this.resizeObserver.observe(this.trigger);
363
+ }
364
+ this.updatePanelPosition();
365
+ this.popover.show();
366
+ if (this.filterEnabled && this.autofocusFilter) {
367
+ requestAnimationFrame(() => {
368
+ var _a;
369
+ (_a = this.filterInputElement) === null || _a === void 0 ? void 0 : _a.setFocus();
370
+ });
371
+ }
405
372
  }
406
- }
407
- render() {
408
- return (h("div", { part: "base", id: this.componentId, class: {
409
- dropdown: true,
410
- 'dropdown--open': this.open,
411
- } }, h("span", { part: "trigger", class: "dropdown__trigger", ref: (el) => (this.trigger = el), onClick: this.handleTriggerClick, onKeyDown: this.handleTriggerKeyDown, onKeyUp: this.handleTriggerKeyUp }, h("slot", { name: "trigger", onSlotchange: this.handleTriggerSlotChange })), h("div", { ref: (el) => (this.positioner = el), class: {
412
- dropdown__positioner: true,
413
- dropdown__positioner__filtered: (this.filter || this.asyncFilter) && !this.hoist,
414
- } }, this.hasFilterEnabled && (h("six-input", { class: {
415
- 'filter-hidden': !this.open,
416
- }, "aria-hidden": this.open ? 'false' : 'true', ref: (el) => (this.filterInputElement = el), placeholder: this.filterPlaceholder })), h("div", { ref: (el) => (this.panel = el), part: "panel", class: "dropdown__panel", role: "menu", "aria-hidden": this.open ? 'false' : 'true', "aria-labelledby": this.componentId, onScroll: this.handleDropdownScroll }, h("slot", null), this.filteredOptions.length > 0 && (h("six-menu", { part: "menu", items: this.filteredOptions, virtualScroll: this.virtualScroll }))))));
417
- }
418
- static get is() { return "six-dropdown"; }
419
- static get encapsulation() { return "shadow"; }
420
- static get originalStyleUrls() {
421
- return {
422
- "$": ["six-dropdown.scss"]
423
- };
424
- }
425
- static get styleUrls() {
426
- return {
427
- "$": ["six-dropdown.css"]
428
- };
429
- }
430
- static get properties() {
431
- return {
432
- "open": {
433
- "type": "boolean",
434
- "mutable": true,
435
- "complexType": {
436
- "original": "boolean",
437
- "resolved": "boolean",
438
- "references": {}
439
- },
440
- "required": false,
441
- "optional": false,
442
- "docs": {
443
- "tags": [],
444
- "text": "Indicates whether the dropdown is open. You can use this in lieu of the show/hide methods."
445
- },
446
- "attribute": "open",
447
- "reflect": true,
448
- "defaultValue": "false"
449
- },
450
- "placement": {
451
- "type": "string",
452
- "mutable": false,
453
- "complexType": {
454
- "original": "| 'top'\n | 'top-start'\n | 'top-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n | 'right'\n | 'right-start'\n | 'right-end'\n | 'left'\n | 'left-start'\n | 'left-end'",
455
- "resolved": "\"bottom\" | \"bottom-end\" | \"bottom-start\" | \"left\" | \"left-end\" | \"left-start\" | \"right\" | \"right-end\" | \"right-start\" | \"top\" | \"top-end\" | \"top-start\"",
456
- "references": {}
457
- },
458
- "required": false,
459
- "optional": false,
460
- "docs": {
461
- "tags": [],
462
- "text": "The preferred placement of the dropdown panel. Note that the actual placement may vary as needed to keep the panel\ninside the viewport."
463
- },
464
- "attribute": "placement",
465
- "reflect": false,
466
- "defaultValue": "'bottom-start'"
467
- },
468
- "closeOnSelect": {
469
- "type": "boolean",
470
- "mutable": false,
471
- "complexType": {
472
- "original": "boolean",
473
- "resolved": "boolean",
474
- "references": {}
475
- },
476
- "required": false,
477
- "optional": false,
478
- "docs": {
479
- "tags": [],
480
- "text": "Determines whether the dropdown should hide when a menu item is selected."
481
- },
482
- "attribute": "close-on-select",
483
- "reflect": false,
484
- "defaultValue": "true"
485
- },
486
- "distance": {
487
- "type": "number",
488
- "mutable": false,
489
- "complexType": {
490
- "original": "number",
491
- "resolved": "number",
492
- "references": {}
493
- },
494
- "required": false,
495
- "optional": false,
496
- "docs": {
497
- "tags": [],
498
- "text": "The distance in pixels from which to offset the panel away from its trigger."
499
- },
500
- "attribute": "distance",
501
- "reflect": false,
502
- "defaultValue": "0"
503
- },
504
- "skidding": {
505
- "type": "number",
506
- "mutable": false,
507
- "complexType": {
508
- "original": "number",
509
- "resolved": "number",
510
- "references": {}
511
- },
512
- "required": false,
513
- "optional": false,
514
- "docs": {
515
- "tags": [],
516
- "text": "The distance in pixels from which to offset the panel along its trigger."
517
- },
518
- "attribute": "skidding",
519
- "reflect": false,
520
- "defaultValue": "0"
521
- },
522
- "hoist": {
523
- "type": "boolean",
524
- "mutable": false,
525
- "complexType": {
526
- "original": "boolean",
527
- "resolved": "boolean",
528
- "references": {}
529
- },
530
- "required": false,
531
- "optional": false,
532
- "docs": {
533
- "tags": [],
534
- "text": "Enable this option to prevent the panel from being clipped when the component is placed inside a container with\n`overflow: auto|scroll`."
535
- },
536
- "attribute": "hoist",
537
- "reflect": false,
538
- "defaultValue": "false"
539
- },
540
- "containingElement": {
541
- "type": "unknown",
542
- "mutable": false,
543
- "complexType": {
544
- "original": "HTMLElement",
545
- "resolved": "HTMLElement | undefined",
546
- "references": {
547
- "HTMLElement": {
548
- "location": "global",
549
- "id": "global::HTMLElement"
550
- }
551
- }
552
- },
553
- "required": false,
554
- "optional": true,
555
- "docs": {
556
- "tags": [],
557
- "text": "The dropdown will close when the user interacts outside of this element (e.g. clicking)."
373
+ /**
374
+ * Set min width of dropdown panel to the width of the trigger element
375
+ */
376
+ updatePanelPosition() {
377
+ if (!this.open) {
378
+ return;
558
379
  }
559
- },
560
- "filter": {
561
- "type": "boolean",
562
- "mutable": false,
563
- "complexType": {
564
- "original": "boolean",
565
- "resolved": "boolean",
566
- "references": {}
567
- },
568
- "required": false,
569
- "optional": false,
570
- "docs": {
571
- "tags": [],
572
- "text": "Set to true to allow auto filtering for entries in the dropdown.\nWith this flag the dropdown will automatically filter itsel.\nIf you need to coordinate the shown elements yourself,\ne.g. because you need to call an endpoint use asyncFilter instead"
573
- },
574
- "attribute": "filter",
575
- "reflect": false,
576
- "defaultValue": "false"
577
- },
578
- "asyncFilter": {
579
- "type": "boolean",
580
- "mutable": false,
581
- "complexType": {
582
- "original": "boolean",
583
- "resolved": "boolean",
584
- "references": {}
585
- },
586
- "required": false,
587
- "optional": false,
588
- "docs": {
589
- "tags": [],
590
- "text": "Set to true to allow async filtering.\nWhen you enter something in the search field the component will only emit an event but not filter any elements itself.\nYou can then simply listen to the 'six-async-filter-fired' event to manage the shown menu-items yourself"
591
- },
592
- "attribute": "async-filter",
593
- "reflect": false,
594
- "defaultValue": "false"
595
- },
596
- "filterPlaceholder": {
597
- "type": "string",
598
- "mutable": false,
599
- "complexType": {
600
- "original": "string",
601
- "resolved": "string",
602
- "references": {}
603
- },
604
- "required": false,
605
- "optional": false,
606
- "docs": {
607
- "tags": [],
608
- "text": "The filter's placeholder text."
609
- },
610
- "attribute": "filter-placeholder",
611
- "reflect": false,
612
- "defaultValue": "'Filter...'"
613
- },
614
- "autofocusFilter": {
615
- "type": "boolean",
616
- "mutable": false,
617
- "complexType": {
618
- "original": "boolean",
619
- "resolved": "boolean",
620
- "references": {}
621
- },
622
- "required": false,
623
- "optional": false,
624
- "docs": {
625
- "tags": [],
626
- "text": "By default the search field will be focused when opening a dropdown with filtering enabled."
627
- },
628
- "attribute": "autofocus-filter",
629
- "reflect": false,
630
- "defaultValue": "true"
631
- },
632
- "filterDebounce": {
633
- "type": "number",
634
- "mutable": false,
635
- "complexType": {
636
- "original": "number",
637
- "resolved": "number",
638
- "references": {}
639
- },
640
- "required": false,
641
- "optional": false,
642
- "docs": {
643
- "tags": [],
644
- "text": "The debounce for the filter callbacks."
645
- },
646
- "attribute": "filter-debounce",
647
- "reflect": false,
648
- "defaultValue": "DEFAULT_DEBOUNCE_FAST"
649
- },
650
- "disableHideOnEnterAndSpace": {
651
- "type": "boolean",
652
- "mutable": false,
653
- "complexType": {
654
- "original": "boolean",
655
- "resolved": "boolean",
656
- "references": {}
657
- },
658
- "required": false,
659
- "optional": false,
660
- "docs": {
661
- "tags": [],
662
- "text": "The panel can be opend/closed by pressing the spacebar or the enter key. In some cases you might want to avoid this"
663
- },
664
- "attribute": "disable-hide-on-enter-and-space",
665
- "reflect": false,
666
- "defaultValue": "false"
667
- },
668
- "options": {
669
- "type": "unknown",
670
- "mutable": false,
671
- "complexType": {
672
- "original": "SixMenuItemData[]",
673
- "resolved": "SixMenuItemData[]",
674
- "references": {
675
- "SixMenuItemData": {
676
- "location": "import",
677
- "path": "../six-menu/six-menu",
678
- "id": "src/components/six-menu/six-menu.tsx::SixMenuItemData"
679
- }
680
- }
681
- },
682
- "required": false,
683
- "optional": false,
684
- "docs": {
685
- "tags": [],
686
- "text": "Set the options to be shown in the dropdown (alternative to setting the elements via html)"
687
- },
688
- "defaultValue": "[]"
689
- },
690
- "virtualScroll": {
691
- "type": "boolean",
692
- "mutable": false,
693
- "complexType": {
694
- "original": "boolean",
695
- "resolved": "boolean",
696
- "references": {}
697
- },
698
- "required": false,
699
- "optional": false,
700
- "docs": {
701
- "tags": [],
702
- "text": "Defines whether the menu list will be rendered virtually i.e. only the elements actually shown (and a couple around)\nare actually rendered in the DOM. If you use virtual scrolling pass the elements via prop instead of via slot."
703
- },
704
- "attribute": "virtual-scroll",
705
- "reflect": false,
706
- "defaultValue": "false"
707
- }
708
- };
709
- }
710
- static get states() {
711
- return {
712
- "filteredOptions": {}
713
- };
714
- }
715
- static get events() {
716
- return [{
717
- "method": "sixShow",
718
- "name": "six-dropdown-show",
719
- "bubbles": true,
720
- "cancelable": true,
721
- "composed": true,
722
- "docs": {
723
- "tags": [],
724
- "text": "Emitted when the dropdown opens. Calling `event.preventDefault()` will prevent it from being opened."
725
- },
726
- "complexType": {
727
- "original": "EmptyPayload",
728
- "resolved": "undefined",
729
- "references": {
730
- "EmptyPayload": {
731
- "location": "import",
732
- "path": "../../utils/types",
733
- "id": "src/utils/types.ts::EmptyPayload"
734
- }
735
- }
380
+ if (this.matchTriggerWidth && this.trigger != null && this.panel != null) {
381
+ const width = this.trigger.getBoundingClientRect().width;
382
+ this.panel.style.minWidth = `${width}px`;
736
383
  }
737
- }, {
738
- "method": "sixAfterShow",
739
- "name": "six-dropdown-after-show",
740
- "bubbles": true,
741
- "cancelable": true,
742
- "composed": true,
743
- "docs": {
744
- "tags": [],
745
- "text": "Emitted after the dropdown opens and all transitions are complete."
746
- },
747
- "complexType": {
748
- "original": "EmptyPayload",
749
- "resolved": "undefined",
750
- "references": {
751
- "EmptyPayload": {
752
- "location": "import",
753
- "path": "../../utils/types",
754
- "id": "src/utils/types.ts::EmptyPayload"
755
- }
756
- }
384
+ if (this.popover != null) {
385
+ this.popover.reposition();
757
386
  }
758
- }, {
759
- "method": "sixHide",
760
- "name": "six-dropdown-hide",
761
- "bubbles": true,
762
- "cancelable": true,
763
- "composed": true,
764
- "docs": {
765
- "tags": [],
766
- "text": "Emitted when the dropdown closes. Calling `event.preventDefault()` will prevent it from being closed."
767
- },
768
- "complexType": {
769
- "original": "EmptyPayload",
770
- "resolved": "undefined",
771
- "references": {
772
- "EmptyPayload": {
773
- "location": "import",
774
- "path": "../../utils/types",
775
- "id": "src/utils/types.ts::EmptyPayload"
776
- }
777
- }
387
+ }
388
+ /** Hides the dropdown panel */
389
+ async hide() {
390
+ this.resizeObserver.disconnect();
391
+ // Prevent subsequent calls to the method, whether manually or triggered by the `open` watcher
392
+ if (!this.isVisible || this.panel == null || this.popover == null) {
393
+ return;
778
394
  }
779
- }, {
780
- "method": "sixAfterHide",
781
- "name": "six-dropdown-after-hide",
782
- "bubbles": true,
783
- "cancelable": true,
784
- "composed": true,
785
- "docs": {
786
- "tags": [],
787
- "text": "Emitted after the dropdown closes and all transitions are complete."
788
- },
789
- "complexType": {
790
- "original": "EmptyPayload",
791
- "resolved": "undefined",
792
- "references": {
793
- "EmptyPayload": {
794
- "location": "import",
795
- "path": "../../utils/types",
796
- "id": "src/utils/types.ts::EmptyPayload"
797
- }
798
- }
395
+ const sixHide = this.sixHide.emit();
396
+ if (sixHide.defaultPrevented) {
397
+ this.open = true;
398
+ return;
799
399
  }
800
- }, {
801
- "method": "sixAutoFilter",
802
- "name": "six-dropdown-auto-filter-fired",
803
- "bubbles": true,
804
- "cancelable": true,
805
- "composed": true,
806
- "docs": {
807
- "tags": [],
808
- "text": "Emitted when the auto filter is triggered"
809
- },
810
- "complexType": {
811
- "original": "SixDropdownAutoFilterPayload",
812
- "resolved": "SixDropdownAutoFilterPayload",
813
- "references": {
814
- "SixDropdownAutoFilterPayload": {
815
- "location": "local",
816
- "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-dropdown/six-dropdown.tsx",
817
- "id": "src/components/six-dropdown/six-dropdown.tsx::SixDropdownAutoFilterPayload"
400
+ this.eventListeners.remove(this.panel, 'six-menu-item-selected', this.handlePanelSelect);
401
+ this.eventListeners.remove(document, 'keydown', this.handleDocumentKeyDown);
402
+ this.eventListeners.remove(document, 'mousedown', this.handleDocumentMouseDown);
403
+ this.isVisible = false;
404
+ this.open = false;
405
+ this.popover.hide();
406
+ }
407
+ focusOnTrigger() {
408
+ var _a;
409
+ if (this.trigger == null)
410
+ return;
411
+ const trigger = (_a = this.triggerSlot) === null || _a === void 0 ? void 0 : _a.assignedElements({ flatten: true }).at(0);
412
+ if (trigger != null) {
413
+ if (typeof trigger.setFocus === 'function') {
414
+ trigger.setFocus();
818
415
  }
819
- }
820
- }
821
- }, {
822
- "method": "sixAsyncFilterFired",
823
- "name": "six-async-filter-fired",
824
- "bubbles": true,
825
- "cancelable": true,
826
- "composed": true,
827
- "docs": {
828
- "tags": [],
829
- "text": "Emitted when the async filter is triggered"
830
- },
831
- "complexType": {
832
- "original": "SixDropdownAsyncFilterPayload",
833
- "resolved": "SixDropdownAsyncFilterPayload",
834
- "references": {
835
- "SixDropdownAsyncFilterPayload": {
836
- "location": "local",
837
- "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-dropdown/six-dropdown.tsx",
838
- "id": "src/components/six-dropdown/six-dropdown.tsx::SixDropdownAsyncFilterPayload"
416
+ else if (typeof trigger.focus === 'function') {
417
+ trigger.focus();
839
418
  }
840
- }
841
419
  }
842
- }, {
843
- "method": "sixScroll",
844
- "name": "six-dropdown-scroll",
845
- "bubbles": true,
846
- "cancelable": true,
847
- "composed": true,
848
- "docs": {
849
- "tags": [],
850
- "text": "Emitted when the user scrolls inside dropdown panel."
851
- },
852
- "complexType": {
853
- "original": "SixDropdownScrollPayload",
854
- "resolved": "SixDropdownScrollPayload",
855
- "references": {
856
- "SixDropdownScrollPayload": {
857
- "location": "local",
858
- "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-dropdown/six-dropdown.tsx",
859
- "id": "src/components/six-dropdown/six-dropdown.tsx::SixDropdownScrollPayload"
860
- }
861
- }
420
+ }
421
+ getMenu() {
422
+ var _a;
423
+ return (_a = this.panelSlot) === null || _a === void 0 ? void 0 : _a.assignedElements({ flatten: true }).filter(isSixMenu).at(0);
424
+ }
425
+ /**
426
+ * Instructs the dropdown menu to reposition. Useful when the position or size of the trigger changes when the menu
427
+ * is activated.
428
+ *
429
+ * @deprecated: use the property `matchTriggerWidth` instead.
430
+ */
431
+ async reposition() {
432
+ if (this.open && this.popover != null) {
433
+ this.popover.reposition();
862
434
  }
863
- }];
864
- }
865
- static get methods() {
866
- return {
867
- "show": {
868
- "complexType": {
869
- "signature": "() => Promise<void>",
870
- "parameters": [],
871
- "references": {
872
- "Promise": {
873
- "location": "global",
874
- "id": "global::Promise"
875
- }
876
- },
877
- "return": "Promise<void>"
878
- },
879
- "docs": {
880
- "text": "Shows the dropdown panel",
881
- "tags": []
435
+ }
436
+ //
437
+ // Slotted triggers can be arbitrary content, but we need to link them to the dropdown panel with `aria-haspopup` and
438
+ // `aria-expanded`. These must be applied to the "accessible trigger" (the tabbable portion of the trigger element
439
+ // that gets slotted in) so screen readers will understand them. The accessible trigger could be the slotted element,
440
+ // a child of the slotted element, or an element in the slotted element's shadow root.
441
+ //
442
+ // For example, the accessible trigger of an <sl-button> is a <button> located inside its shadow root.
443
+ //
444
+ // To determine this, we assume the first tabbable element in the trigger slot is the "accessible trigger."
445
+ //
446
+ updateAccessibleTrigger() {
447
+ var _a;
448
+ if (this.trigger == null)
449
+ return;
450
+ const assignedElements = (((_a = this.triggerSlot) === null || _a === void 0 ? void 0 : _a.assignedElements({ flatten: true })) || []);
451
+ const accessibleTrigger = assignedElements.map(getNearestTabbableElement).at(0);
452
+ if (accessibleTrigger != null) {
453
+ accessibleTrigger.setAttribute('aria-haspopup', 'true');
454
+ accessibleTrigger.setAttribute('aria-expanded', this.open ? 'true' : 'false');
882
455
  }
883
- },
884
- "hide": {
885
- "complexType": {
886
- "signature": "() => Promise<void>",
887
- "parameters": [],
888
- "references": {
889
- "Promise": {
890
- "location": "global",
891
- "id": "global::Promise"
456
+ }
457
+ render() {
458
+ return (h("div", { part: "base", id: this.componentId, class: {
459
+ dropdown: true,
460
+ 'dropdown--open': this.open,
461
+ } }, h("span", { part: "trigger", class: "dropdown__trigger", ref: (el) => (this.trigger = el), onClick: this.handleTriggerClick, onKeyDown: this.handleTriggerKeyDown, onKeyUp: this.handleTriggerKeyUp }, h("slot", { name: "trigger", ref: (el) => (this.triggerSlot = el), onSlotchange: this.handleTriggerSlotChange })), h("div", { ref: (el) => (this.positioner = el), class: {
462
+ dropdown__positioner: true,
463
+ dropdown__positioner__filtered: (this.filter || this.asyncFilter) && !this.hoist,
464
+ } }, h("div", { ref: (el) => (this.panel = el), part: "panel", class: "dropdown__panel", role: "menu", "aria-hidden": this.open ? 'false' : 'true', "aria-labelledby": this.componentId }, this.filterEnabled && (h("six-input", { class: {
465
+ filter: true,
466
+ 'filter-hidden': !this.open,
467
+ }, "dropdown-search": true, "aria-hidden": this.open ? 'false' : 'true', ref: (el) => (this.filterInputElement = el), placeholder: this.filterPlaceholder }, h("six-icon", { class: "filter__icon", slot: "suffix", size: "small" }, "search"))), h("div", { class: {
468
+ dropdown__panel__scroll: true,
469
+ 'dropdown__panel__scroll--virtual': this.virtualScroll,
470
+ }, onScroll: this.handleDropdownScroll, ref: (el) => (this.scrollPanel = el) }, h("slot", { ref: (el) => (this.panelSlot = el) }), this.options.length > 0 && (h("six-menu", { part: "menu", items: this.renderedOptions, virtualScroll: this.virtualScroll }))), h("slot", { name: "dropdown-footer" })))));
471
+ }
472
+ static get is() { return "six-dropdown"; }
473
+ static get encapsulation() { return "shadow"; }
474
+ static get originalStyleUrls() {
475
+ return {
476
+ "$": ["six-dropdown.scss"]
477
+ };
478
+ }
479
+ static get styleUrls() {
480
+ return {
481
+ "$": ["six-dropdown.css"]
482
+ };
483
+ }
484
+ static get properties() {
485
+ return {
486
+ "open": {
487
+ "type": "boolean",
488
+ "mutable": true,
489
+ "complexType": {
490
+ "original": "boolean",
491
+ "resolved": "boolean",
492
+ "references": {}
493
+ },
494
+ "required": false,
495
+ "optional": false,
496
+ "docs": {
497
+ "tags": [],
498
+ "text": "Indicates whether the dropdown is open. You can use this in lieu of the show/hide methods."
499
+ },
500
+ "attribute": "open",
501
+ "reflect": true,
502
+ "defaultValue": "false"
503
+ },
504
+ "placement": {
505
+ "type": "string",
506
+ "mutable": false,
507
+ "complexType": {
508
+ "original": "| 'top'\n | 'top-start'\n | 'top-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n | 'right'\n | 'right-start'\n | 'right-end'\n | 'left'\n | 'left-start'\n | 'left-end'",
509
+ "resolved": "\"bottom\" | \"bottom-end\" | \"bottom-start\" | \"left\" | \"left-end\" | \"left-start\" | \"right\" | \"right-end\" | \"right-start\" | \"top\" | \"top-end\" | \"top-start\"",
510
+ "references": {}
511
+ },
512
+ "required": false,
513
+ "optional": false,
514
+ "docs": {
515
+ "tags": [],
516
+ "text": "The preferred placement of the dropdown panel. Note that the actual placement may vary as needed to keep the panel\ninside the viewport."
517
+ },
518
+ "attribute": "placement",
519
+ "reflect": false,
520
+ "defaultValue": "'bottom-start'"
521
+ },
522
+ "closeOnSelect": {
523
+ "type": "boolean",
524
+ "mutable": false,
525
+ "complexType": {
526
+ "original": "boolean",
527
+ "resolved": "boolean",
528
+ "references": {}
529
+ },
530
+ "required": false,
531
+ "optional": false,
532
+ "docs": {
533
+ "tags": [],
534
+ "text": "Determines whether the dropdown should hide when a menu item is selected."
535
+ },
536
+ "attribute": "close-on-select",
537
+ "reflect": false,
538
+ "defaultValue": "true"
539
+ },
540
+ "distance": {
541
+ "type": "number",
542
+ "mutable": false,
543
+ "complexType": {
544
+ "original": "number",
545
+ "resolved": "number",
546
+ "references": {}
547
+ },
548
+ "required": false,
549
+ "optional": false,
550
+ "docs": {
551
+ "tags": [],
552
+ "text": "The distance in pixels from which to offset the panel away from its trigger."
553
+ },
554
+ "attribute": "distance",
555
+ "reflect": false,
556
+ "defaultValue": "4"
557
+ },
558
+ "skidding": {
559
+ "type": "number",
560
+ "mutable": false,
561
+ "complexType": {
562
+ "original": "number",
563
+ "resolved": "number",
564
+ "references": {}
565
+ },
566
+ "required": false,
567
+ "optional": false,
568
+ "docs": {
569
+ "tags": [],
570
+ "text": "The distance in pixels from which to offset the panel along its trigger."
571
+ },
572
+ "attribute": "skidding",
573
+ "reflect": false,
574
+ "defaultValue": "0"
575
+ },
576
+ "hoist": {
577
+ "type": "boolean",
578
+ "mutable": false,
579
+ "complexType": {
580
+ "original": "boolean",
581
+ "resolved": "boolean",
582
+ "references": {}
583
+ },
584
+ "required": false,
585
+ "optional": false,
586
+ "docs": {
587
+ "tags": [],
588
+ "text": "Enable this option to prevent the panel from being clipped when the component is placed inside a container with\n`overflow: auto|scroll`."
589
+ },
590
+ "attribute": "hoist",
591
+ "reflect": false,
592
+ "defaultValue": "false"
593
+ },
594
+ "containingElement": {
595
+ "type": "unknown",
596
+ "mutable": false,
597
+ "complexType": {
598
+ "original": "HTMLElement",
599
+ "resolved": "HTMLElement | undefined",
600
+ "references": {
601
+ "HTMLElement": {
602
+ "location": "global",
603
+ "id": "global::HTMLElement"
604
+ }
605
+ }
606
+ },
607
+ "required": false,
608
+ "optional": true,
609
+ "docs": {
610
+ "tags": [],
611
+ "text": "The dropdown will close when the user interacts outside of this element (e.g. clicking)."
612
+ }
613
+ },
614
+ "filter": {
615
+ "type": "boolean",
616
+ "mutable": false,
617
+ "complexType": {
618
+ "original": "boolean",
619
+ "resolved": "boolean",
620
+ "references": {}
621
+ },
622
+ "required": false,
623
+ "optional": false,
624
+ "docs": {
625
+ "tags": [],
626
+ "text": "Set to true to allow auto filtering for entries in the dropdown.\nWith this flag the dropdown will automatically filter itsel.\nIf you need to coordinate the shown elements yourself,\ne.g. because you need to call an endpoint use asyncFilter instead"
627
+ },
628
+ "attribute": "filter",
629
+ "reflect": false,
630
+ "defaultValue": "false"
631
+ },
632
+ "asyncFilter": {
633
+ "type": "boolean",
634
+ "mutable": false,
635
+ "complexType": {
636
+ "original": "boolean",
637
+ "resolved": "boolean",
638
+ "references": {}
639
+ },
640
+ "required": false,
641
+ "optional": false,
642
+ "docs": {
643
+ "tags": [],
644
+ "text": "Set to true to allow async filtering.\nWhen you enter something in the search field the component will only emit an event but not filter any elements itself.\nYou can then simply listen to the 'six-async-filter-fired' event to manage the shown menu-items yourself"
645
+ },
646
+ "attribute": "async-filter",
647
+ "reflect": false,
648
+ "defaultValue": "false"
649
+ },
650
+ "filterPlaceholder": {
651
+ "type": "string",
652
+ "mutable": false,
653
+ "complexType": {
654
+ "original": "string",
655
+ "resolved": "string",
656
+ "references": {}
657
+ },
658
+ "required": false,
659
+ "optional": false,
660
+ "docs": {
661
+ "tags": [],
662
+ "text": "The filter's placeholder text."
663
+ },
664
+ "attribute": "filter-placeholder",
665
+ "reflect": false,
666
+ "defaultValue": "'Filter...'"
667
+ },
668
+ "autofocusFilter": {
669
+ "type": "boolean",
670
+ "mutable": false,
671
+ "complexType": {
672
+ "original": "boolean",
673
+ "resolved": "boolean",
674
+ "references": {}
675
+ },
676
+ "required": false,
677
+ "optional": false,
678
+ "docs": {
679
+ "tags": [],
680
+ "text": "By default the search field will be focused when opening a dropdown with filtering enabled."
681
+ },
682
+ "attribute": "autofocus-filter",
683
+ "reflect": false,
684
+ "defaultValue": "true"
685
+ },
686
+ "filterDebounce": {
687
+ "type": "number",
688
+ "mutable": true,
689
+ "complexType": {
690
+ "original": "number",
691
+ "resolved": "number",
692
+ "references": {}
693
+ },
694
+ "required": false,
695
+ "optional": false,
696
+ "docs": {
697
+ "tags": [],
698
+ "text": "The debounce for the filter callbacks."
699
+ },
700
+ "attribute": "filter-debounce",
701
+ "reflect": false,
702
+ "defaultValue": "0"
703
+ },
704
+ "disableHideOnEnterAndSpace": {
705
+ "type": "boolean",
706
+ "mutable": false,
707
+ "complexType": {
708
+ "original": "boolean",
709
+ "resolved": "boolean",
710
+ "references": {}
711
+ },
712
+ "required": false,
713
+ "optional": false,
714
+ "docs": {
715
+ "tags": [],
716
+ "text": "The panel can be opend/closed by pressing the spacebar or the enter key. In some cases you might want to avoid this"
717
+ },
718
+ "attribute": "disable-hide-on-enter-and-space",
719
+ "reflect": false,
720
+ "defaultValue": "false"
721
+ },
722
+ "options": {
723
+ "type": "unknown",
724
+ "mutable": true,
725
+ "complexType": {
726
+ "original": "SixMenuItemData[]",
727
+ "resolved": "SixMenuItemData[]",
728
+ "references": {
729
+ "SixMenuItemData": {
730
+ "location": "import",
731
+ "path": "../six-menu/six-menu",
732
+ "id": "src/components/six-menu/six-menu.tsx::SixMenuItemData"
733
+ }
734
+ }
735
+ },
736
+ "required": false,
737
+ "optional": false,
738
+ "docs": {
739
+ "tags": [],
740
+ "text": "Set the options to be shown in the dropdown (alternative to setting the elements via html)"
741
+ },
742
+ "defaultValue": "[]"
743
+ },
744
+ "virtualScroll": {
745
+ "type": "boolean",
746
+ "mutable": false,
747
+ "complexType": {
748
+ "original": "boolean",
749
+ "resolved": "boolean",
750
+ "references": {}
751
+ },
752
+ "required": false,
753
+ "optional": false,
754
+ "docs": {
755
+ "tags": [],
756
+ "text": "Defines whether the menu list will be rendered virtually i.e. only the elements actually shown (and a couple around)\nare actually rendered in the DOM. If you use virtual scrolling pass the elements via prop instead of via slot."
757
+ },
758
+ "attribute": "virtual-scroll",
759
+ "reflect": false,
760
+ "defaultValue": "false"
761
+ },
762
+ "matchTriggerWidth": {
763
+ "type": "boolean",
764
+ "mutable": false,
765
+ "complexType": {
766
+ "original": "boolean",
767
+ "resolved": "boolean",
768
+ "references": {}
769
+ },
770
+ "required": false,
771
+ "optional": false,
772
+ "docs": {
773
+ "tags": [],
774
+ "text": "Determines if the dropdown panel's width should match the width of the trigger element.\n\nIf set to `true`, the panel will resize its width to align with the trigger's width.\nIf `false` or omitted, the panel will maintain its default width."
775
+ },
776
+ "attribute": "match-trigger-width",
777
+ "reflect": false,
778
+ "defaultValue": "false"
892
779
  }
893
- },
894
- "return": "Promise<void>"
895
- },
896
- "docs": {
897
- "text": "Hides the dropdown panel",
898
- "tags": []
899
- }
900
- },
901
- "reposition": {
902
- "complexType": {
903
- "signature": "() => Promise<void>",
904
- "parameters": [],
905
- "references": {
906
- "Promise": {
907
- "location": "global",
908
- "id": "global::Promise"
780
+ };
781
+ }
782
+ static get states() {
783
+ return {
784
+ "renderedOptions": {}
785
+ };
786
+ }
787
+ static get events() {
788
+ return [{
789
+ "method": "sixShow",
790
+ "name": "six-dropdown-show",
791
+ "bubbles": true,
792
+ "cancelable": true,
793
+ "composed": true,
794
+ "docs": {
795
+ "tags": [],
796
+ "text": "Emitted when the dropdown opens. Calling `event.preventDefault()` will prevent it from being opened."
797
+ },
798
+ "complexType": {
799
+ "original": "EmptyPayload",
800
+ "resolved": "undefined",
801
+ "references": {
802
+ "EmptyPayload": {
803
+ "location": "import",
804
+ "path": "../../utils/types",
805
+ "id": "src/utils/types.ts::EmptyPayload"
806
+ }
807
+ }
808
+ }
809
+ }, {
810
+ "method": "sixAfterShow",
811
+ "name": "six-dropdown-after-show",
812
+ "bubbles": true,
813
+ "cancelable": true,
814
+ "composed": true,
815
+ "docs": {
816
+ "tags": [],
817
+ "text": "Emitted after the dropdown opens and all transitions are complete."
818
+ },
819
+ "complexType": {
820
+ "original": "EmptyPayload",
821
+ "resolved": "undefined",
822
+ "references": {
823
+ "EmptyPayload": {
824
+ "location": "import",
825
+ "path": "../../utils/types",
826
+ "id": "src/utils/types.ts::EmptyPayload"
827
+ }
828
+ }
829
+ }
830
+ }, {
831
+ "method": "sixHide",
832
+ "name": "six-dropdown-hide",
833
+ "bubbles": true,
834
+ "cancelable": true,
835
+ "composed": true,
836
+ "docs": {
837
+ "tags": [],
838
+ "text": "Emitted when the dropdown closes. Calling `event.preventDefault()` will prevent it from being closed."
839
+ },
840
+ "complexType": {
841
+ "original": "EmptyPayload",
842
+ "resolved": "undefined",
843
+ "references": {
844
+ "EmptyPayload": {
845
+ "location": "import",
846
+ "path": "../../utils/types",
847
+ "id": "src/utils/types.ts::EmptyPayload"
848
+ }
849
+ }
850
+ }
851
+ }, {
852
+ "method": "sixAfterHide",
853
+ "name": "six-dropdown-after-hide",
854
+ "bubbles": true,
855
+ "cancelable": true,
856
+ "composed": true,
857
+ "docs": {
858
+ "tags": [],
859
+ "text": "Emitted after the dropdown closes and all transitions are complete."
860
+ },
861
+ "complexType": {
862
+ "original": "EmptyPayload",
863
+ "resolved": "undefined",
864
+ "references": {
865
+ "EmptyPayload": {
866
+ "location": "import",
867
+ "path": "../../utils/types",
868
+ "id": "src/utils/types.ts::EmptyPayload"
869
+ }
870
+ }
871
+ }
872
+ }, {
873
+ "method": "sixAutoFilter",
874
+ "name": "six-dropdown-auto-filter-fired",
875
+ "bubbles": true,
876
+ "cancelable": true,
877
+ "composed": true,
878
+ "docs": {
879
+ "tags": [],
880
+ "text": "Emitted when the auto filter is triggered"
881
+ },
882
+ "complexType": {
883
+ "original": "SixDropdownAutoFilterPayload",
884
+ "resolved": "SixDropdownAutoFilterPayload",
885
+ "references": {
886
+ "SixDropdownAutoFilterPayload": {
887
+ "location": "local",
888
+ "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-dropdown/six-dropdown.tsx",
889
+ "id": "src/components/six-dropdown/six-dropdown.tsx::SixDropdownAutoFilterPayload"
890
+ }
891
+ }
892
+ }
893
+ }, {
894
+ "method": "sixAsyncFilterFired",
895
+ "name": "six-async-filter-fired",
896
+ "bubbles": true,
897
+ "cancelable": true,
898
+ "composed": true,
899
+ "docs": {
900
+ "tags": [],
901
+ "text": "Emitted when the async filter is triggered"
902
+ },
903
+ "complexType": {
904
+ "original": "SixDropdownAsyncFilterPayload",
905
+ "resolved": "SixDropdownAsyncFilterPayload",
906
+ "references": {
907
+ "SixDropdownAsyncFilterPayload": {
908
+ "location": "local",
909
+ "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-dropdown/six-dropdown.tsx",
910
+ "id": "src/components/six-dropdown/six-dropdown.tsx::SixDropdownAsyncFilterPayload"
911
+ }
912
+ }
913
+ }
914
+ }, {
915
+ "method": "sixScroll",
916
+ "name": "six-dropdown-scroll",
917
+ "bubbles": true,
918
+ "cancelable": true,
919
+ "composed": true,
920
+ "docs": {
921
+ "tags": [],
922
+ "text": "Emitted when the user scrolls inside dropdown panel."
923
+ },
924
+ "complexType": {
925
+ "original": "SixDropdownScrollPayload",
926
+ "resolved": "SixDropdownScrollPayload",
927
+ "references": {
928
+ "SixDropdownScrollPayload": {
929
+ "location": "local",
930
+ "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-dropdown/six-dropdown.tsx",
931
+ "id": "src/components/six-dropdown/six-dropdown.tsx::SixDropdownScrollPayload"
932
+ }
933
+ }
934
+ }
935
+ }];
936
+ }
937
+ static get methods() {
938
+ return {
939
+ "show": {
940
+ "complexType": {
941
+ "signature": "() => Promise<void>",
942
+ "parameters": [],
943
+ "references": {
944
+ "Promise": {
945
+ "location": "global",
946
+ "id": "global::Promise"
947
+ }
948
+ },
949
+ "return": "Promise<void>"
950
+ },
951
+ "docs": {
952
+ "text": "Shows the dropdown panel",
953
+ "tags": []
954
+ }
955
+ },
956
+ "hide": {
957
+ "complexType": {
958
+ "signature": "() => Promise<void>",
959
+ "parameters": [],
960
+ "references": {
961
+ "Promise": {
962
+ "location": "global",
963
+ "id": "global::Promise"
964
+ }
965
+ },
966
+ "return": "Promise<void>"
967
+ },
968
+ "docs": {
969
+ "text": "Hides the dropdown panel",
970
+ "tags": []
971
+ }
972
+ },
973
+ "reposition": {
974
+ "complexType": {
975
+ "signature": "() => Promise<void>",
976
+ "parameters": [],
977
+ "references": {
978
+ "Promise": {
979
+ "location": "global",
980
+ "id": "global::Promise"
981
+ }
982
+ },
983
+ "return": "Promise<void>"
984
+ },
985
+ "docs": {
986
+ "text": "Instructs the dropdown menu to reposition. Useful when the position or size of the trigger changes when the menu\nis activated.",
987
+ "tags": [{
988
+ "name": "deprecated",
989
+ "text": ": use the property `matchTriggerWidth` instead."
990
+ }]
991
+ }
909
992
  }
910
- },
911
- "return": "Promise<void>"
912
- },
913
- "docs": {
914
- "text": "Instructs the dropdown menu to reposition. Useful when the position or size of the trigger changes when the menu\nis activated.",
915
- "tags": []
916
- }
917
- }
918
- };
919
- }
920
- static get elementRef() { return "host"; }
921
- static get watchers() {
922
- return [{
923
- "propName": "open",
924
- "methodName": "handleOpenChange"
925
- }, {
926
- "propName": "distance",
927
- "methodName": "handlePopoverOptionsChange"
928
- }, {
929
- "propName": "hoist",
930
- "methodName": "handlePopoverOptionsChange"
931
- }, {
932
- "propName": "placement",
933
- "methodName": "handlePopoverOptionsChange"
934
- }, {
935
- "propName": "skidding",
936
- "methodName": "handlePopoverOptionsChange"
937
- }, {
938
- "propName": "options",
939
- "methodName": "handleOptionsChange"
940
- }];
941
- }
993
+ };
994
+ }
995
+ static get elementRef() { return "host"; }
996
+ static get watchers() {
997
+ return [{
998
+ "propName": "open",
999
+ "methodName": "handleOpenChange"
1000
+ }, {
1001
+ "propName": "distance",
1002
+ "methodName": "handlePopoverOptionsChange"
1003
+ }, {
1004
+ "propName": "hoist",
1005
+ "methodName": "handlePopoverOptionsChange"
1006
+ }, {
1007
+ "propName": "placement",
1008
+ "methodName": "handlePopoverOptionsChange"
1009
+ }, {
1010
+ "propName": "skidding",
1011
+ "methodName": "handlePopoverOptionsChange"
1012
+ }, {
1013
+ "propName": "options",
1014
+ "methodName": "handleOptionsChange"
1015
+ }, {
1016
+ "propName": "virtualScroll",
1017
+ "methodName": "handleOptionsChange"
1018
+ }];
1019
+ }
1020
+ }
1021
+ function isSixMenu(el) {
1022
+ return (el === null || el === void 0 ? void 0 : el.tagName.toLowerCase()) === 'six-menu';
1023
+ }
1024
+ function isSixMenuItem(el) {
1025
+ return (el === null || el === void 0 ? void 0 : el.tagName.toLowerCase()) === 'six-menu-item';
1026
+ }
1027
+ function isSelectionContainer(el) {
1028
+ var _a;
1029
+ return ((_a = el === null || el === void 0 ? void 0 : el.getAttribute('class')) === null || _a === void 0 ? void 0 : _a.includes('selection-container')) || false;
1030
+ }
1031
+ async function containsFilterTerm(menuItem, lowerCaseFilterTerm) {
1032
+ return (menuItem.value.toLowerCase().includes(lowerCaseFilterTerm) ||
1033
+ (await menuItem.getTextLabel()).toLowerCase().includes(lowerCaseFilterTerm));
942
1034
  }
943
1035
  //# sourceMappingURL=six-dropdown.js.map