@six-group/ui-library 0.0.0-insider.cd0cd0d → 0.0.0-insider.d005298

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 (1139) hide show
  1. package/README.md +9 -0
  2. package/dist/cjs/error-messages-6e8049a4.js +119 -0
  3. package/dist/cjs/error-messages-6e8049a4.js.map +1 -0
  4. package/dist/cjs/event-listeners-9fb878f1.js +61 -0
  5. package/dist/cjs/event-listeners-9fb878f1.js.map +1 -0
  6. package/dist/cjs/{execution-control-45c84c46.js → execution-control-d728da70.js} +15 -15
  7. package/dist/cjs/execution-control-d728da70.js.map +1 -0
  8. package/dist/cjs/focus-visible-e2c9255a.js +47 -0
  9. package/dist/cjs/focus-visible-e2c9255a.js.map +1 -0
  10. package/dist/cjs/form-9ebaae7c.js +20 -0
  11. package/dist/{esm/form-0b9c11cd.js.map → cjs/form-9ebaae7c.js.map} +1 -1
  12. package/dist/cjs/form-control-8d64e974.js +36 -0
  13. package/dist/cjs/form-control-8d64e974.js.map +1 -0
  14. package/dist/cjs/{index-2f6daa5b.js → index-d7748d51.js} +587 -480
  15. package/dist/cjs/index-d7748d51.js.map +1 -0
  16. package/dist/cjs/index.cjs.js +55 -87
  17. package/dist/cjs/index.cjs.js.map +1 -1
  18. package/dist/cjs/loader.cjs.js +3 -12
  19. package/dist/cjs/loader.cjs.js.map +1 -1
  20. package/dist/cjs/modal-3ce015be.js +52 -0
  21. package/dist/cjs/modal-3ce015be.js.map +1 -0
  22. package/dist/cjs/{popover-8885d50f.js → popover-1e7c09f1.js} +99 -99
  23. package/dist/cjs/popover-1e7c09f1.js.map +1 -0
  24. package/dist/cjs/popup-e854acda.js +103 -0
  25. package/dist/cjs/popup-e854acda.js.map +1 -0
  26. package/dist/cjs/scroll-68033901.js +68 -0
  27. package/dist/{esm/scroll-180b53fd.js.map → cjs/scroll-68033901.js.map} +1 -1
  28. package/dist/cjs/six-alert.cjs.entry.js +142 -110
  29. package/dist/cjs/six-alert.cjs.entry.js.map +1 -1
  30. package/dist/cjs/six-avatar.cjs.entry.js +21 -21
  31. package/dist/cjs/six-avatar.cjs.entry.js.map +1 -1
  32. package/dist/cjs/six-badge.cjs.entry.js +23 -23
  33. package/dist/cjs/six-badge.cjs.entry.js.map +1 -1
  34. package/dist/cjs/six-button.cjs.entry.js +95 -95
  35. package/dist/cjs/six-button.cjs.entry.js.map +1 -1
  36. package/dist/cjs/six-card.cjs.entry.js +8 -8
  37. package/dist/cjs/six-card.cjs.entry.js.map +1 -1
  38. package/dist/cjs/six-checkbox_2.cjs.entry.js +190 -0
  39. package/dist/cjs/six-checkbox_2.cjs.entry.js.map +1 -0
  40. package/dist/cjs/six-datepicker.cjs.entry.js +861 -838
  41. package/dist/cjs/six-datepicker.cjs.entry.js.map +1 -1
  42. package/dist/cjs/six-details.cjs.entry.js +127 -127
  43. package/dist/cjs/six-details.cjs.entry.js.map +1 -1
  44. package/dist/cjs/six-dialog.cjs.entry.js +131 -129
  45. package/dist/cjs/six-dialog.cjs.entry.js.map +1 -1
  46. package/dist/cjs/six-drawer.cjs.entry.js +147 -147
  47. package/dist/cjs/six-drawer.cjs.entry.js.map +1 -1
  48. package/dist/cjs/six-dropdown_2.cjs.entry.js +709 -637
  49. package/dist/cjs/six-dropdown_2.cjs.entry.js.map +1 -1
  50. package/dist/cjs/six-error-page.cjs.entry.js +82 -82
  51. package/dist/cjs/six-error-page.cjs.entry.js.map +1 -1
  52. package/dist/cjs/six-error.cjs.entry.js +21 -0
  53. package/dist/cjs/six-error.cjs.entry.js.map +1 -0
  54. package/dist/cjs/six-file-list-item.cjs.entry.js +34 -34
  55. package/dist/cjs/six-file-list-item.cjs.entry.js.map +1 -1
  56. package/dist/cjs/six-file-list.cjs.entry.js +7 -7
  57. package/dist/cjs/six-file-list.cjs.entry.js.map +1 -1
  58. package/dist/cjs/six-file-upload.cjs.entry.js +99 -99
  59. package/dist/cjs/six-file-upload.cjs.entry.js.map +1 -1
  60. package/dist/cjs/six-footer.cjs.entry.js +8 -8
  61. package/dist/cjs/six-footer.cjs.entry.js.map +1 -1
  62. package/dist/cjs/six-group-label.cjs.entry.js +43 -43
  63. package/dist/cjs/six-group-label.cjs.entry.js.map +1 -1
  64. package/dist/cjs/six-header.cjs.entry.js +171 -156
  65. package/dist/cjs/six-header.cjs.entry.js.map +1 -1
  66. package/dist/cjs/six-icon-button.cjs.entry.js +32 -32
  67. package/dist/cjs/six-icon-button.cjs.entry.js.map +1 -1
  68. package/dist/cjs/six-icon.cjs.entry.js +22 -22
  69. package/dist/cjs/six-icon.cjs.entry.js.map +1 -1
  70. package/dist/cjs/six-input.cjs.entry.js +192 -187
  71. package/dist/cjs/six-input.cjs.entry.js.map +1 -1
  72. package/dist/cjs/six-item-picker.cjs.entry.js +405 -309
  73. package/dist/cjs/six-item-picker.cjs.entry.js.map +1 -1
  74. package/dist/cjs/six-language-switcher.cjs.entry.js +46 -46
  75. package/dist/cjs/six-language-switcher.cjs.entry.js.map +1 -1
  76. package/dist/cjs/six-layout-grid.cjs.entry.js +20 -20
  77. package/dist/cjs/six-layout-grid.cjs.entry.js.map +1 -1
  78. package/dist/cjs/six-main-container.cjs.entry.js +9 -9
  79. package/dist/cjs/six-main-container.cjs.entry.js.map +1 -1
  80. package/dist/cjs/six-menu-divider.cjs.entry.js +8 -8
  81. package/dist/cjs/six-menu-divider.cjs.entry.js.map +1 -1
  82. package/dist/cjs/six-menu-label.cjs.entry.js +8 -8
  83. package/dist/cjs/six-menu-label.cjs.entry.js.map +1 -1
  84. package/dist/cjs/six-picto.cjs.entry.js +14 -14
  85. package/dist/cjs/six-picto.cjs.entry.js.map +1 -1
  86. package/dist/cjs/six-progress-bar.cjs.entry.js +15 -15
  87. package/dist/cjs/six-progress-bar.cjs.entry.js.map +1 -1
  88. package/dist/cjs/six-progress-ring.cjs.entry.js +30 -30
  89. package/dist/cjs/six-progress-ring.cjs.entry.js.map +1 -1
  90. package/dist/cjs/six-radio.cjs.entry.js +104 -112
  91. package/dist/cjs/six-radio.cjs.entry.js.map +1 -1
  92. package/dist/cjs/six-range.cjs.entry.js +180 -177
  93. package/dist/cjs/six-range.cjs.entry.js.map +1 -1
  94. package/dist/cjs/six-root.cjs.entry.js +11 -30
  95. package/dist/cjs/six-root.cjs.entry.js.map +1 -1
  96. package/dist/cjs/six-search-field.cjs.entry.js +44 -44
  97. package/dist/cjs/six-search-field.cjs.entry.js.map +1 -1
  98. package/dist/cjs/six-select.cjs.entry.js +496 -361
  99. package/dist/cjs/six-select.cjs.entry.js.map +1 -1
  100. package/dist/cjs/six-sidebar-item-group.cjs.entry.js +56 -45
  101. package/dist/cjs/six-sidebar-item-group.cjs.entry.js.map +1 -1
  102. package/dist/cjs/six-sidebar-item.cjs.entry.js +17 -15
  103. package/dist/cjs/six-sidebar-item.cjs.entry.js.map +1 -1
  104. package/dist/cjs/six-sidebar.cjs.entry.js +174 -174
  105. package/dist/cjs/six-sidebar.cjs.entry.js.map +1 -1
  106. package/dist/cjs/six-spinner.cjs.entry.js +15 -15
  107. package/dist/cjs/six-spinner.cjs.entry.js.map +1 -1
  108. package/dist/cjs/six-stage-indicator.cjs.entry.js +22 -0
  109. package/dist/cjs/six-stage-indicator.cjs.entry.js.map +1 -0
  110. package/dist/cjs/six-switch.cjs.entry.js +107 -87
  111. package/dist/cjs/six-switch.cjs.entry.js.map +1 -1
  112. package/dist/cjs/six-tab-group.cjs.entry.js +230 -235
  113. package/dist/cjs/six-tab-group.cjs.entry.js.map +1 -1
  114. package/dist/cjs/six-tab-panel.cjs.entry.js +14 -14
  115. package/dist/cjs/six-tab-panel.cjs.entry.js.map +1 -1
  116. package/dist/cjs/six-tab.cjs.entry.js +55 -39
  117. package/dist/cjs/six-tab.cjs.entry.js.map +1 -1
  118. package/dist/cjs/six-tag.cjs.entry.js +55 -33
  119. package/dist/cjs/six-tag.cjs.entry.js.map +1 -1
  120. package/dist/cjs/six-textarea.cjs.entry.js +181 -178
  121. package/dist/cjs/six-textarea.cjs.entry.js.map +1 -1
  122. package/dist/cjs/six-tile.cjs.entry.js +77 -77
  123. package/dist/cjs/six-tile.cjs.entry.js.map +1 -1
  124. package/dist/cjs/six-timepicker.cjs.entry.js +348 -353
  125. package/dist/cjs/six-timepicker.cjs.entry.js.map +1 -1
  126. package/dist/cjs/six-tooltip.cjs.entry.js +148 -148
  127. package/dist/cjs/six-tooltip.cjs.entry.js.map +1 -1
  128. package/dist/cjs/slot-1b1232a1.js +51 -0
  129. package/dist/cjs/slot-1b1232a1.js.map +1 -0
  130. package/dist/cjs/types-d3da200b.js +19 -0
  131. package/dist/cjs/types-d3da200b.js.map +1 -0
  132. package/dist/cjs/ui-library.cjs.js +3 -6
  133. package/dist/cjs/ui-library.cjs.js.map +1 -1
  134. package/dist/collection/collection-manifest.json +54 -54
  135. package/dist/collection/components/six-alert/six-alert.css +5 -1
  136. package/dist/collection/components/six-alert/six-alert.js +383 -331
  137. package/dist/collection/components/six-alert/six-alert.js.map +1 -1
  138. package/dist/collection/components/six-alert/test/six-alert.spec.js +25 -0
  139. package/dist/collection/components/six-alert/test/six-alert.spec.js.map +1 -0
  140. package/dist/collection/components/six-avatar/six-avatar.css +2 -2
  141. package/dist/collection/components/six-avatar/six-avatar.js +112 -112
  142. package/dist/collection/components/six-avatar/six-avatar.js.map +1 -1
  143. package/dist/collection/components/six-avatar/test/six-avatar.spec.js +26 -0
  144. package/dist/collection/components/six-avatar/test/six-avatar.spec.js.map +1 -0
  145. package/dist/collection/components/six-badge/six-badge.css +1 -1
  146. package/dist/collection/components/six-badge/six-badge.js +91 -91
  147. package/dist/collection/components/six-badge/six-badge.js.map +1 -1
  148. package/dist/collection/components/six-badge/test/six-badge.spec.js +20 -0
  149. package/dist/collection/components/six-badge/test/six-badge.spec.js.map +1 -0
  150. package/dist/collection/components/six-button/six-button.css +7 -31
  151. package/dist/collection/components/six-button/six-button.js +450 -444
  152. package/dist/collection/components/six-button/six-button.js.map +1 -1
  153. package/dist/collection/components/six-button/test/six-button.spec.js +69 -0
  154. package/dist/collection/components/six-button/test/six-button.spec.js.map +1 -0
  155. package/dist/collection/components/six-card/six-card.css +4 -5
  156. package/dist/collection/components/six-card/six-card.js +16 -16
  157. package/dist/collection/components/six-card/six-card.js.map +1 -1
  158. package/dist/collection/components/six-card/test/six-card.spec.js +18 -0
  159. package/dist/collection/components/six-card/test/six-card.spec.js.map +1 -0
  160. package/dist/collection/components/six-checkbox/six-checkbox.css +10 -2
  161. package/dist/collection/components/six-checkbox/six-checkbox.js +424 -420
  162. package/dist/collection/components/six-checkbox/six-checkbox.js.map +1 -1
  163. package/dist/collection/components/six-checkbox/test/six-checkbox.spec.js +83 -0
  164. package/dist/collection/components/six-checkbox/test/six-checkbox.spec.js.map +1 -0
  165. package/dist/collection/components/six-datepicker/components/day-selection.js +9 -9
  166. package/dist/collection/components/six-datepicker/components/day-selection.js.map +1 -1
  167. package/dist/collection/components/six-datepicker/components/month-selection.js +10 -10
  168. package/dist/collection/components/six-datepicker/components/month-selection.js.map +1 -1
  169. package/dist/collection/components/six-datepicker/components/year-selection.js +10 -10
  170. package/dist/collection/components/six-datepicker/components/year-selection.js.map +1 -1
  171. package/dist/collection/components/six-datepicker/six-date-formats.js +21 -20
  172. package/dist/collection/components/six-datepicker/six-date-formats.js.map +1 -1
  173. package/dist/collection/components/six-datepicker/six-datepicker.css +1 -1
  174. package/dist/collection/components/six-datepicker/six-datepicker.js +1062 -1035
  175. package/dist/collection/components/six-datepicker/six-datepicker.js.map +1 -1
  176. package/dist/collection/components/six-datepicker/test/six-datepicker.spec.js +26 -0
  177. package/dist/collection/components/six-datepicker/test/six-datepicker.spec.js.map +1 -0
  178. package/dist/collection/components/six-datepicker/test/six-datepicker.test-helpers.js +14 -14
  179. package/dist/collection/components/six-datepicker/test/six-datepicker.test-helpers.js.map +1 -1
  180. package/dist/collection/components/six-details/six-details.css +4 -6
  181. package/dist/collection/components/six-details/six-details.js +412 -406
  182. package/dist/collection/components/six-details/six-details.js.map +1 -1
  183. package/dist/collection/components/six-details/test/six-details.spec.js +36 -0
  184. package/dist/collection/components/six-details/test/six-details.spec.js.map +1 -0
  185. package/dist/collection/components/six-dialog/six-dialog.css +2 -2
  186. package/dist/collection/components/six-dialog/six-dialog.js +361 -351
  187. package/dist/collection/components/six-dialog/six-dialog.js.map +1 -1
  188. package/dist/collection/components/six-dialog/test/six-dialog.spec.js +34 -0
  189. package/dist/collection/components/six-dialog/test/six-dialog.spec.js.map +1 -0
  190. package/dist/collection/components/six-drawer/six-drawer.css +2 -2
  191. package/dist/collection/components/six-drawer/six-drawer.js +414 -406
  192. package/dist/collection/components/six-drawer/six-drawer.js.map +1 -1
  193. package/dist/collection/components/six-drawer/test/six-drawer.spec.js +34 -0
  194. package/dist/collection/components/six-drawer/test/six-drawer.spec.js.map +1 -0
  195. package/dist/collection/components/six-dropdown/six-dropdown.css +22 -6
  196. package/dist/collection/components/six-dropdown/six-dropdown.js +988 -884
  197. package/dist/collection/components/six-dropdown/six-dropdown.js.map +1 -1
  198. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js +147 -0
  199. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js.map +1 -0
  200. package/dist/collection/components/six-error/six-error.css +5 -0
  201. package/dist/collection/components/six-error/six-error.js +25 -0
  202. package/dist/collection/components/six-error/six-error.js.map +1 -0
  203. package/dist/collection/components/six-error-page/six-error-page.js +178 -178
  204. package/dist/collection/components/six-error-page/six-error-page.js.map +1 -1
  205. package/dist/collection/components/six-error-page/test/six-error-page.spec.js +240 -0
  206. package/dist/collection/components/six-error-page/test/six-error-page.spec.js.map +1 -0
  207. package/dist/collection/components/six-file-list/six-file-list.js +16 -16
  208. package/dist/collection/components/six-file-list/six-file-list.js.map +1 -1
  209. package/dist/collection/components/six-file-list/test/six-file-list.spec.js +67 -0
  210. package/dist/collection/components/six-file-list/test/six-file-list.spec.js.map +1 -0
  211. package/dist/collection/components/six-file-list-item/six-file-list-item.css +1 -1
  212. package/dist/collection/components/six-file-list-item/six-file-list-item.js +196 -194
  213. package/dist/collection/components/six-file-list-item/six-file-list-item.js.map +1 -1
  214. package/dist/collection/components/six-file-list-item/test/six-file-list-item.spec.js +169 -0
  215. package/dist/collection/components/six-file-list-item/test/six-file-list-item.spec.js.map +1 -0
  216. package/dist/collection/components/six-file-upload/six-file-upload.css +1 -4
  217. package/dist/collection/components/six-file-upload/six-file-upload.js +292 -290
  218. package/dist/collection/components/six-file-upload/six-file-upload.js.map +1 -1
  219. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js +103 -0
  220. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js.map +1 -0
  221. package/dist/collection/components/six-footer/six-footer.css +2 -2
  222. package/dist/collection/components/six-footer/six-footer.js +16 -16
  223. package/dist/collection/components/six-footer/six-footer.js.map +1 -1
  224. package/dist/collection/components/six-footer/test/six-footer.spec.js +21 -0
  225. package/dist/collection/components/six-footer/test/six-footer.spec.js.map +1 -0
  226. package/dist/collection/components/six-group-label/six-group-label.css +5 -2
  227. package/dist/collection/components/six-group-label/six-group-label.js +158 -158
  228. package/dist/collection/components/six-group-label/six-group-label.js.map +1 -1
  229. package/dist/collection/components/six-group-label/test/six-group-label.spec.js +45 -0
  230. package/dist/collection/components/six-group-label/test/six-group-label.spec.js.map +1 -0
  231. package/dist/collection/components/six-header/six-header.css +6 -2
  232. package/dist/collection/components/six-header/six-header.js +442 -400
  233. package/dist/collection/components/six-header/six-header.js.map +1 -1
  234. package/dist/collection/components/six-header/test/six-header.spec.js +177 -0
  235. package/dist/collection/components/six-header/test/six-header.spec.js.map +1 -0
  236. package/dist/collection/components/six-icon/six-icon.css +5 -2
  237. package/dist/collection/components/six-icon/six-icon.js +72 -72
  238. package/dist/collection/components/six-icon/six-icon.js.map +1 -1
  239. package/dist/collection/components/six-icon/test/six-icon.spec.js +20 -0
  240. package/dist/collection/components/six-icon/test/six-icon.spec.js.map +1 -0
  241. package/dist/collection/components/six-icon-button/six-icon-button.css +5 -5
  242. package/dist/collection/components/six-icon-button/six-icon-button.js +133 -133
  243. package/dist/collection/components/six-icon-button/six-icon-button.js.map +1 -1
  244. package/dist/collection/components/six-icon-button/test/six-icon-button.spec.js +23 -0
  245. package/dist/collection/components/six-icon-button/test/six-icon-button.spec.js.map +1 -0
  246. package/dist/collection/components/six-input/six-input.css +15 -3
  247. package/dist/collection/components/six-input/six-input.js +975 -913
  248. package/dist/collection/components/six-input/six-input.js.map +1 -1
  249. package/dist/collection/components/six-input/test/six-input.spec.js +39 -0
  250. package/dist/collection/components/six-input/test/six-input.spec.js.map +1 -0
  251. package/dist/collection/components/six-item-picker/six-item-picker.css +8 -0
  252. package/dist/collection/components/six-item-picker/six-item-picker.js +731 -631
  253. package/dist/collection/components/six-item-picker/six-item-picker.js.map +1 -1
  254. package/dist/collection/components/six-item-picker/test/six-item-picker.spec.js +90 -0
  255. package/dist/collection/components/six-item-picker/test/six-item-picker.spec.js.map +1 -0
  256. package/dist/collection/components/six-item-picker/types.js +9 -7
  257. package/dist/collection/components/six-item-picker/types.js.map +1 -1
  258. package/dist/collection/components/six-language-switcher/six-language-switcher.js +125 -123
  259. package/dist/collection/components/six-language-switcher/six-language-switcher.js.map +1 -1
  260. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js +196 -0
  261. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js.map +1 -0
  262. package/dist/collection/components/six-layout-grid/six-layout-grid.js +55 -55
  263. package/dist/collection/components/six-layout-grid/six-layout-grid.js.map +1 -1
  264. package/dist/collection/components/six-layout-grid/test/six-layout-grid.spec.js +18 -0
  265. package/dist/collection/components/six-layout-grid/test/six-layout-grid.spec.js.map +1 -0
  266. package/dist/collection/components/six-main-container/six-main-container.js +42 -42
  267. package/dist/collection/components/six-main-container/six-main-container.js.map +1 -1
  268. package/dist/collection/components/six-main-container/test/six-main-container.spec.js +22 -0
  269. package/dist/collection/components/six-main-container/test/six-main-container.spec.js.map +1 -0
  270. package/dist/collection/components/six-menu/six-menu.css +8 -7
  271. package/dist/collection/components/six-menu/six-menu.js +392 -366
  272. package/dist/collection/components/six-menu/six-menu.js.map +1 -1
  273. package/dist/collection/components/six-menu/test/six-menu.spec.js +93 -0
  274. package/dist/collection/components/six-menu/test/six-menu.spec.js.map +1 -0
  275. package/dist/collection/components/six-menu-divider/six-menu-divider.css +3 -2
  276. package/dist/collection/components/six-menu-divider/six-menu-divider.js +16 -16
  277. package/dist/collection/components/six-menu-divider/six-menu-divider.js.map +1 -1
  278. package/dist/collection/components/six-menu-divider/test/six-menu-divider.spec.js +18 -0
  279. package/dist/collection/components/six-menu-divider/test/six-menu-divider.spec.js.map +1 -0
  280. package/dist/collection/components/six-menu-item/six-menu-item.css +13 -2
  281. package/dist/collection/components/six-menu-item/six-menu-item.js +211 -178
  282. package/dist/collection/components/six-menu-item/six-menu-item.js.map +1 -1
  283. package/dist/collection/components/six-menu-item/test/six-menu-item.spec.js +33 -0
  284. package/dist/collection/components/six-menu-item/test/six-menu-item.spec.js.map +1 -0
  285. package/dist/collection/components/six-menu-label/six-menu-label.css +1 -1
  286. package/dist/collection/components/six-menu-label/six-menu-label.js +16 -16
  287. package/dist/collection/components/six-menu-label/six-menu-label.js.map +1 -1
  288. package/dist/collection/components/six-menu-label/test/six-menu-label.spec.js +20 -0
  289. package/dist/collection/components/six-menu-label/test/six-menu-label.spec.js.map +1 -0
  290. package/dist/collection/components/six-picto/six-picto.js +47 -47
  291. package/dist/collection/components/six-picto/six-picto.js.map +1 -1
  292. package/dist/collection/components/six-picto/test/six-picto.spec.js +33 -0
  293. package/dist/collection/components/six-picto/test/six-picto.spec.js.map +1 -0
  294. package/dist/collection/components/six-progress-bar/six-progress-bar.css +1 -1
  295. package/dist/collection/components/six-progress-bar/six-progress-bar.js +65 -65
  296. package/dist/collection/components/six-progress-bar/six-progress-bar.js.map +1 -1
  297. package/dist/collection/components/six-progress-bar/test/six-progress-bar.spec.js +24 -0
  298. package/dist/collection/components/six-progress-bar/test/six-progress-bar.spec.js.map +1 -0
  299. package/dist/collection/components/six-progress-ring/six-progress-ring.css +1 -1
  300. package/dist/collection/components/six-progress-ring/six-progress-ring.js +101 -101
  301. package/dist/collection/components/six-progress-ring/six-progress-ring.js.map +1 -1
  302. package/dist/collection/components/six-progress-ring/test/six-progress-ring.spec.js +26 -0
  303. package/dist/collection/components/six-progress-ring/test/six-progress-ring.spec.js.map +1 -0
  304. package/dist/collection/components/six-radio/six-radio.css +1 -1
  305. package/dist/collection/components/six-radio/six-radio.js +323 -340
  306. package/dist/collection/components/six-radio/six-radio.js.map +1 -1
  307. package/dist/collection/components/six-radio/test/six-radio.spec.js +63 -0
  308. package/dist/collection/components/six-radio/test/six-radio.spec.js.map +1 -0
  309. package/dist/collection/components/six-range/six-range.css +5 -2
  310. package/dist/collection/components/six-range/six-range.js +568 -540
  311. package/dist/collection/components/six-range/six-range.js.map +1 -1
  312. package/dist/collection/components/six-range/test/six-range.spec.js +34 -0
  313. package/dist/collection/components/six-range/test/six-range.spec.js.map +1 -0
  314. package/dist/collection/components/six-root/six-root.js +85 -151
  315. package/dist/collection/components/six-root/six-root.js.map +1 -1
  316. package/dist/collection/components/six-root/test/six-root.spec.js +36 -0
  317. package/dist/collection/components/six-root/test/six-root.spec.js.map +1 -0
  318. package/dist/collection/components/six-search-field/six-search-field.css +1 -1
  319. package/dist/collection/components/six-search-field/six-search-field.js +172 -171
  320. package/dist/collection/components/six-search-field/six-search-field.js.map +1 -1
  321. package/dist/collection/components/six-search-field/test/six-search-field.spec.js +22 -0
  322. package/dist/collection/components/six-search-field/test/six-search-field.spec.js.map +1 -0
  323. package/dist/collection/components/six-select/six-select.css +61 -73
  324. package/dist/collection/components/six-select/six-select.js +1123 -920
  325. package/dist/collection/components/six-select/six-select.js.map +1 -1
  326. package/dist/collection/components/six-select/test/six-select.spec.js +102 -0
  327. package/dist/collection/components/six-select/test/six-select.spec.js.map +1 -0
  328. package/dist/collection/components/six-select/test/util.spec.js +81 -0
  329. package/dist/collection/components/six-select/test/util.spec.js.map +1 -0
  330. package/dist/collection/components/six-select/util.js +34 -34
  331. package/dist/collection/components/six-select/util.js.map +1 -1
  332. package/dist/collection/components/six-sidebar/six-sidebar.css +2 -2
  333. package/dist/collection/components/six-sidebar/six-sidebar.js +468 -454
  334. package/dist/collection/components/six-sidebar/six-sidebar.js.map +1 -1
  335. package/dist/collection/components/six-sidebar/test/six-sidebar.spec.js +22 -0
  336. package/dist/collection/components/six-sidebar/test/six-sidebar.spec.js.map +1 -0
  337. package/dist/collection/components/six-sidebar-item/six-sidebar-item.css +6 -1
  338. package/dist/collection/components/six-sidebar-item/six-sidebar-item.js +102 -83
  339. package/dist/collection/components/six-sidebar-item/six-sidebar-item.js.map +1 -1
  340. package/dist/collection/components/six-sidebar-item/test/six-sidebar-item.spec.js +50 -0
  341. package/dist/collection/components/six-sidebar-item/test/six-sidebar-item.spec.js.map +1 -0
  342. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.css +12 -1
  343. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js +182 -154
  344. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js.map +1 -1
  345. package/dist/collection/components/six-sidebar-item-group/test/six-sidebar-item-group.spec.js +53 -0
  346. package/dist/collection/components/six-sidebar-item-group/test/six-sidebar-item-group.spec.js.map +1 -0
  347. package/dist/collection/components/six-spinner/six-spinner.css +1 -1
  348. package/dist/collection/components/six-spinner/six-spinner.js +48 -47
  349. package/dist/collection/components/six-spinner/six-spinner.js.map +1 -1
  350. package/dist/collection/components/six-spinner/test/six-spinner.spec.js +37 -0
  351. package/dist/collection/components/six-spinner/test/six-spinner.spec.js.map +1 -0
  352. package/dist/collection/components/six-stage-indicator/six-stage-indicator.css +1 -1
  353. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js +46 -45
  354. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js.map +1 -1
  355. package/dist/collection/components/six-stage-indicator/test/six-stage-indicator.spec.js +117 -0
  356. package/dist/collection/components/six-stage-indicator/test/six-stage-indicator.spec.js.map +1 -0
  357. package/dist/collection/components/six-switch/six-switch.css +5 -2
  358. package/dist/collection/components/six-switch/six-switch.js +389 -341
  359. package/dist/collection/components/six-switch/six-switch.js.map +1 -1
  360. package/dist/collection/components/six-switch/test/six-switch.spec.js +73 -0
  361. package/dist/collection/components/six-switch/test/six-switch.spec.js.map +1 -0
  362. package/dist/collection/components/six-tab/six-tab.css +55 -6
  363. package/dist/collection/components/six-tab/six-tab.js +207 -186
  364. package/dist/collection/components/six-tab/six-tab.js.map +1 -1
  365. package/dist/collection/components/six-tab-group/six-tab-group.css +1 -32
  366. package/dist/collection/components/six-tab-group/six-tab-group.js +320 -357
  367. package/dist/collection/components/six-tab-group/six-tab-group.js.map +1 -1
  368. package/dist/collection/components/six-tab-panel/six-tab-panel.css +1 -1
  369. package/dist/collection/components/six-tab-panel/six-tab-panel.js +64 -64
  370. package/dist/collection/components/six-tab-panel/six-tab-panel.js.map +1 -1
  371. package/dist/collection/components/six-tab-panel/test/six-tab-panel.spec.js +20 -0
  372. package/dist/collection/components/six-tab-panel/test/six-tab-panel.spec.js.map +1 -0
  373. package/dist/collection/components/six-tag/six-tag.css +7 -1
  374. package/dist/collection/components/six-tag/six-tag.js +162 -139
  375. package/dist/collection/components/six-tag/six-tag.js.map +1 -1
  376. package/dist/collection/components/six-tag/test/six-tag.spec.js +54 -0
  377. package/dist/collection/components/six-tag/test/six-tag.spec.js.map +1 -0
  378. package/dist/collection/components/six-textarea/six-textarea.css +5 -2
  379. package/dist/collection/components/six-textarea/six-textarea.js +796 -757
  380. package/dist/collection/components/six-textarea/six-textarea.js.map +1 -1
  381. package/dist/collection/components/six-textarea/test/six-textarea.spec.js +119 -0
  382. package/dist/collection/components/six-textarea/test/six-textarea.spec.js.map +1 -0
  383. package/dist/collection/components/six-tile/six-tile.css +2 -2
  384. package/dist/collection/components/six-tile/six-tile.js +300 -296
  385. package/dist/collection/components/six-tile/six-tile.js.map +1 -1
  386. package/dist/collection/components/six-tile/test/six-tile.spec.js +69 -0
  387. package/dist/collection/components/six-tile/test/six-tile.spec.js.map +1 -0
  388. package/dist/collection/components/six-timepicker/six-timepicker.css +1 -1
  389. package/dist/collection/components/six-timepicker/six-timepicker.js +832 -813
  390. package/dist/collection/components/six-timepicker/six-timepicker.js.map +1 -1
  391. package/dist/collection/components/six-timepicker/test/six-timepicker.spec.js +496 -0
  392. package/dist/collection/components/six-timepicker/test/six-timepicker.spec.js.map +1 -0
  393. package/dist/collection/components/six-tooltip/six-tooltip.css +2 -2
  394. package/dist/collection/components/six-tooltip/six-tooltip.js +409 -403
  395. package/dist/collection/components/six-tooltip/six-tooltip.js.map +1 -1
  396. package/dist/collection/components/six-tooltip/test/six-tooltip.spec.js +28 -0
  397. package/dist/collection/components/six-tooltip/test/six-tooltip.spec.js.map +1 -0
  398. package/dist/collection/functional-components/form-control/form-control.js +20 -18
  399. package/dist/collection/functional-components/form-control/form-control.js.map +1 -1
  400. package/dist/collection/index.js +1 -0
  401. package/dist/collection/index.js.map +1 -1
  402. package/dist/collection/testUtil/delay.js +1 -1
  403. package/dist/collection/testUtil/delay.js.map +1 -1
  404. package/dist/collection/utils/alert.js +54 -0
  405. package/dist/collection/utils/alert.js.map +1 -0
  406. package/dist/collection/utils/animation.js +34 -0
  407. package/dist/collection/utils/animation.js.map +1 -0
  408. package/dist/collection/utils/date-util.js +526 -501
  409. package/dist/collection/utils/date-util.js.map +1 -1
  410. package/dist/collection/utils/date-util.spec.js +995 -0
  411. package/dist/collection/utils/date-util.spec.js.map +1 -0
  412. package/dist/collection/utils/error-messages.js +102 -81
  413. package/dist/collection/utils/error-messages.js.map +1 -1
  414. package/dist/collection/utils/event-listeners.js +51 -51
  415. package/dist/collection/utils/event-listeners.js.map +1 -1
  416. package/dist/collection/utils/execution-control.js +14 -14
  417. package/dist/collection/utils/execution-control.js.map +1 -1
  418. package/dist/collection/utils/focus-visible.js +28 -28
  419. package/dist/collection/utils/focus-visible.js.map +1 -1
  420. package/dist/collection/utils/form.js +12 -12
  421. package/dist/collection/utils/form.js.map +1 -1
  422. package/dist/collection/utils/modal.js +25 -25
  423. package/dist/collection/utils/modal.js.map +1 -1
  424. package/dist/collection/utils/offset.js +4 -4
  425. package/dist/collection/utils/offset.js.map +1 -1
  426. package/dist/collection/utils/popover.js +100 -100
  427. package/dist/collection/utils/popover.js.map +1 -1
  428. package/dist/collection/utils/popup.js +71 -71
  429. package/dist/collection/utils/popup.js.map +1 -1
  430. package/dist/collection/utils/scroll.js +28 -28
  431. package/dist/collection/utils/scroll.js.map +1 -1
  432. package/dist/collection/utils/scroll.spec.js +122 -0
  433. package/dist/collection/utils/scroll.spec.js.map +1 -0
  434. package/dist/collection/utils/slot.js +28 -29
  435. package/dist/collection/utils/slot.js.map +1 -1
  436. package/dist/collection/utils/support.js +10 -10
  437. package/dist/collection/utils/support.js.map +1 -1
  438. package/dist/collection/utils/tabbable.js +17 -17
  439. package/dist/collection/utils/tabbable.js.map +1 -1
  440. package/dist/collection/utils/time.util.js +72 -72
  441. package/dist/collection/utils/time.util.js.map +1 -1
  442. package/dist/collection/utils/time.util.spec.js +368 -0
  443. package/dist/collection/utils/time.util.spec.js.map +1 -0
  444. package/dist/components/event-listeners.js +51 -51
  445. package/dist/components/event-listeners.js.map +1 -1
  446. package/dist/components/execution-control.js +14 -14
  447. package/dist/components/execution-control.js.map +1 -1
  448. package/dist/components/focus-visible.js +28 -28
  449. package/dist/components/focus-visible.js.map +1 -1
  450. package/dist/components/form-control.js +26 -23
  451. package/dist/components/form-control.js.map +1 -1
  452. package/dist/components/form.js +12 -12
  453. package/dist/components/form.js.map +1 -1
  454. package/dist/components/index.d.ts +6 -0
  455. package/dist/components/index.js +113 -149
  456. package/dist/components/index.js.map +1 -1
  457. package/dist/components/modal.js +35 -35
  458. package/dist/components/modal.js.map +1 -1
  459. package/dist/components/popover.js +98 -98
  460. package/dist/components/popover.js.map +1 -1
  461. package/dist/components/scroll.js +32 -32
  462. package/dist/components/scroll.js.map +1 -1
  463. package/dist/components/six-alert.d.ts +2 -2
  464. package/dist/components/six-alert.js +177 -142
  465. package/dist/components/six-alert.js.map +1 -1
  466. package/dist/components/six-avatar.d.ts +2 -2
  467. package/dist/components/six-avatar.js +45 -45
  468. package/dist/components/six-avatar.js.map +1 -1
  469. package/dist/components/six-badge.d.ts +2 -2
  470. package/dist/components/six-badge.js +40 -40
  471. package/dist/components/six-badge.js.map +1 -1
  472. package/dist/components/six-button.d.ts +2 -2
  473. package/dist/components/six-button.js +1 -142
  474. package/dist/components/six-button.js.map +1 -1
  475. package/dist/components/six-button2.js +146 -0
  476. package/dist/components/six-button2.js.map +1 -0
  477. package/dist/components/six-card.d.ts +2 -2
  478. package/dist/components/six-card.js +21 -21
  479. package/dist/components/six-card.js.map +1 -1
  480. package/dist/components/six-checkbox.d.ts +2 -2
  481. package/dist/components/six-checkbox.js +1 -154
  482. package/dist/components/six-checkbox.js.map +1 -1
  483. package/dist/components/six-checkbox2.js +165 -0
  484. package/dist/components/six-checkbox2.js.map +1 -0
  485. package/dist/components/six-datepicker.d.ts +2 -2
  486. package/dist/components/six-datepicker.js +932 -899
  487. package/dist/components/six-datepicker.js.map +1 -1
  488. package/dist/components/six-details.d.ts +2 -2
  489. package/dist/components/six-details2.js +158 -156
  490. package/dist/components/six-details2.js.map +1 -1
  491. package/dist/components/six-dialog.d.ts +2 -2
  492. package/dist/components/six-dialog.js +161 -157
  493. package/dist/components/six-dialog.js.map +1 -1
  494. package/dist/components/six-drawer.d.ts +2 -2
  495. package/dist/components/six-drawer.js +179 -177
  496. package/dist/components/six-drawer.js.map +1 -1
  497. package/dist/components/six-dropdown.d.ts +2 -2
  498. package/dist/components/six-dropdown2.js +553 -464
  499. package/dist/components/six-dropdown2.js.map +1 -1
  500. package/dist/components/six-error-page.d.ts +2 -2
  501. package/dist/components/six-error-page.js +106 -106
  502. package/dist/components/six-error-page.js.map +1 -1
  503. package/dist/components/{set-attributes.d.ts → six-error.d.ts} +4 -4
  504. package/dist/components/six-error.js +8 -0
  505. package/dist/components/six-error.js.map +1 -0
  506. package/dist/components/six-error2.js +32 -0
  507. package/dist/components/six-error2.js.map +1 -0
  508. package/dist/components/six-file-list-item.d.ts +2 -2
  509. package/dist/components/six-file-list-item.js +59 -59
  510. package/dist/components/six-file-list-item.js.map +1 -1
  511. package/dist/components/six-file-list.d.ts +2 -2
  512. package/dist/components/six-file-list.js +20 -20
  513. package/dist/components/six-file-list.js.map +1 -1
  514. package/dist/components/six-file-upload.d.ts +2 -2
  515. package/dist/components/six-file-upload.js +124 -124
  516. package/dist/components/six-file-upload.js.map +1 -1
  517. package/dist/components/six-footer.d.ts +2 -2
  518. package/dist/components/six-footer.js +21 -21
  519. package/dist/components/six-footer.js.map +1 -1
  520. package/dist/components/six-group-label.d.ts +2 -2
  521. package/dist/components/six-group-label.js +71 -62
  522. package/dist/components/six-group-label.js.map +1 -1
  523. package/dist/components/six-header.d.ts +2 -2
  524. package/dist/components/six-header.js +237 -207
  525. package/dist/components/six-header.js.map +1 -1
  526. package/dist/components/six-icon-button.d.ts +2 -2
  527. package/dist/components/six-icon-button2.js +55 -55
  528. package/dist/components/six-icon-button2.js.map +1 -1
  529. package/dist/components/six-icon.d.ts +2 -2
  530. package/dist/components/six-icon2.js +38 -38
  531. package/dist/components/six-icon2.js.map +1 -1
  532. package/dist/components/six-input.d.ts +2 -2
  533. package/dist/components/six-input2.js +258 -239
  534. package/dist/components/six-input2.js.map +1 -1
  535. package/dist/components/six-item-picker.d.ts +2 -2
  536. package/dist/components/six-item-picker2.js +450 -348
  537. package/dist/components/six-item-picker2.js.map +1 -1
  538. package/dist/components/six-language-switcher.d.ts +2 -2
  539. package/dist/components/six-language-switcher.js +64 -62
  540. package/dist/components/six-language-switcher.js.map +1 -1
  541. package/dist/components/six-layout-grid.d.ts +2 -2
  542. package/dist/components/six-layout-grid.js +37 -35
  543. package/dist/components/six-layout-grid.js.map +1 -1
  544. package/dist/components/six-main-container.d.ts +2 -2
  545. package/dist/components/six-main-container.js +24 -24
  546. package/dist/components/six-main-container.js.map +1 -1
  547. package/dist/components/six-menu-divider.d.ts +2 -2
  548. package/dist/components/six-menu-divider.js +21 -21
  549. package/dist/components/six-menu-divider.js.map +1 -1
  550. package/dist/components/six-menu-item.d.ts +2 -2
  551. package/dist/components/six-menu-item2.js +98 -75
  552. package/dist/components/six-menu-item2.js.map +1 -1
  553. package/dist/components/six-menu-label.d.ts +2 -2
  554. package/dist/components/six-menu-label.js +21 -21
  555. package/dist/components/six-menu-label.js.map +1 -1
  556. package/dist/components/six-menu.d.ts +2 -2
  557. package/dist/components/six-menu2.js +236 -220
  558. package/dist/components/six-menu2.js.map +1 -1
  559. package/dist/components/six-picto.d.ts +2 -2
  560. package/dist/components/six-picto2.js +29 -29
  561. package/dist/components/six-picto2.js.map +1 -1
  562. package/dist/components/six-progress-bar.d.ts +2 -2
  563. package/dist/components/six-progress-bar.js +31 -31
  564. package/dist/components/six-progress-bar.js.map +1 -1
  565. package/dist/components/six-progress-ring.d.ts +2 -2
  566. package/dist/components/six-progress-ring.js +49 -47
  567. package/dist/components/six-progress-ring.js.map +1 -1
  568. package/dist/components/six-radio.d.ts +2 -2
  569. package/dist/components/six-radio.js +128 -134
  570. package/dist/components/six-radio.js.map +1 -1
  571. package/dist/components/six-range.d.ts +2 -2
  572. package/dist/components/six-range.js +233 -215
  573. package/dist/components/six-range.js.map +1 -1
  574. package/dist/components/six-root.d.ts +2 -2
  575. package/dist/components/six-root.js +39 -66
  576. package/dist/components/six-root.js.map +1 -1
  577. package/dist/components/six-search-field.d.ts +2 -2
  578. package/dist/components/six-search-field.js +79 -71
  579. package/dist/components/six-search-field.js.map +1 -1
  580. package/dist/components/six-select.d.ts +2 -2
  581. package/dist/components/six-select.js +713 -438
  582. package/dist/components/six-select.js.map +1 -1
  583. package/dist/components/six-sidebar-item-group.d.ts +2 -2
  584. package/dist/components/six-sidebar-item-group.js +87 -75
  585. package/dist/components/six-sidebar-item-group.js.map +1 -1
  586. package/dist/components/six-sidebar-item.d.ts +2 -2
  587. package/dist/components/six-sidebar-item.js +35 -32
  588. package/dist/components/six-sidebar-item.js.map +1 -1
  589. package/dist/components/six-sidebar.d.ts +2 -2
  590. package/dist/components/six-sidebar.js +199 -197
  591. package/dist/components/six-sidebar.js.map +1 -1
  592. package/dist/components/six-spinner.d.ts +2 -2
  593. package/dist/components/six-spinner2.js +30 -30
  594. package/dist/components/six-spinner2.js.map +1 -1
  595. package/dist/components/six-stage-indicator.d.ts +2 -2
  596. package/dist/components/six-stage-indicator2.js +29 -29
  597. package/dist/components/six-stage-indicator2.js.map +1 -1
  598. package/dist/components/six-switch.d.ts +2 -2
  599. package/dist/components/six-switch.js +142 -110
  600. package/dist/components/six-switch.js.map +1 -1
  601. package/dist/components/six-tab-group.d.ts +2 -2
  602. package/dist/components/six-tab-group.js +260 -263
  603. package/dist/components/six-tab-group.js.map +1 -1
  604. package/dist/components/six-tab-panel.d.ts +2 -2
  605. package/dist/components/six-tab-panel.js +30 -30
  606. package/dist/components/six-tab-panel.js.map +1 -1
  607. package/dist/components/six-tab.d.ts +2 -2
  608. package/dist/components/six-tab.js +85 -69
  609. package/dist/components/six-tab.js.map +1 -1
  610. package/dist/components/six-tag.d.ts +2 -2
  611. package/dist/components/six-tag.js +98 -1
  612. package/dist/components/six-tag.js.map +1 -1
  613. package/dist/components/six-textarea.d.ts +2 -2
  614. package/dist/components/six-textarea.js +235 -218
  615. package/dist/components/six-textarea.js.map +1 -1
  616. package/dist/components/six-tile.d.ts +2 -2
  617. package/dist/components/six-tile.js +117 -117
  618. package/dist/components/six-tile.js.map +1 -1
  619. package/dist/components/six-timepicker.d.ts +2 -2
  620. package/dist/components/six-timepicker2.js +491 -487
  621. package/dist/components/six-timepicker2.js.map +1 -1
  622. package/dist/components/six-tooltip.d.ts +2 -2
  623. package/dist/components/six-tooltip2.js +172 -170
  624. package/dist/components/six-tooltip2.js.map +1 -1
  625. package/dist/components/slot.js +29 -30
  626. package/dist/components/slot.js.map +1 -1
  627. package/dist/components.d.ts +341 -88
  628. package/dist/components.json +4665 -242
  629. package/dist/esm/error-messages-1eaaad23.js +115 -0
  630. package/dist/esm/error-messages-1eaaad23.js.map +1 -0
  631. package/dist/esm/event-listeners-706d4309.js +59 -0
  632. package/dist/esm/event-listeners-706d4309.js.map +1 -0
  633. package/dist/esm/{execution-control-72cc50f4.js → execution-control-2ebaf4ef.js} +15 -15
  634. package/dist/esm/execution-control-2ebaf4ef.js.map +1 -0
  635. package/dist/esm/focus-visible-d9dbfeef.js +45 -0
  636. package/dist/esm/focus-visible-d9dbfeef.js.map +1 -0
  637. package/dist/esm/form-4b145b7a.js +18 -0
  638. package/dist/esm/form-4b145b7a.js.map +1 -0
  639. package/dist/esm/form-control-d403a9cf.js +34 -0
  640. package/dist/esm/form-control-d403a9cf.js.map +1 -0
  641. package/dist/esm/{index-5c0f6628.js → index-79d4ef67.js} +587 -480
  642. package/dist/esm/index-79d4ef67.js.map +1 -0
  643. package/dist/esm/index.js +52 -87
  644. package/dist/esm/index.js.map +1 -1
  645. package/dist/esm/loader.js +4 -13
  646. package/dist/esm/loader.js.map +1 -1
  647. package/dist/esm/modal-96526245.js +49 -0
  648. package/dist/esm/modal-96526245.js.map +1 -0
  649. package/dist/esm/{popover-2e72e7d8.js → popover-25996e62.js} +99 -99
  650. package/dist/esm/popover-25996e62.js.map +1 -0
  651. package/dist/esm/popup-7209e9d5.js +98 -0
  652. package/dist/esm/popup-7209e9d5.js.map +1 -0
  653. package/dist/esm/scroll-3e16851e.js +64 -0
  654. package/dist/esm/scroll-3e16851e.js.map +1 -0
  655. package/dist/esm/six-alert.entry.js +142 -110
  656. package/dist/esm/six-alert.entry.js.map +1 -1
  657. package/dist/esm/six-avatar.entry.js +21 -21
  658. package/dist/esm/six-avatar.entry.js.map +1 -1
  659. package/dist/esm/six-badge.entry.js +23 -23
  660. package/dist/esm/six-badge.entry.js.map +1 -1
  661. package/dist/esm/six-button.entry.js +95 -95
  662. package/dist/esm/six-button.entry.js.map +1 -1
  663. package/dist/esm/six-card.entry.js +8 -8
  664. package/dist/esm/six-card.entry.js.map +1 -1
  665. package/dist/esm/six-checkbox_2.entry.js +185 -0
  666. package/dist/esm/six-checkbox_2.entry.js.map +1 -0
  667. package/dist/esm/six-datepicker.entry.js +861 -838
  668. package/dist/esm/six-datepicker.entry.js.map +1 -1
  669. package/dist/esm/six-details.entry.js +127 -127
  670. package/dist/esm/six-details.entry.js.map +1 -1
  671. package/dist/esm/six-dialog.entry.js +131 -129
  672. package/dist/esm/six-dialog.entry.js.map +1 -1
  673. package/dist/esm/six-drawer.entry.js +147 -147
  674. package/dist/esm/six-drawer.entry.js.map +1 -1
  675. package/dist/esm/six-dropdown_2.entry.js +709 -637
  676. package/dist/esm/six-dropdown_2.entry.js.map +1 -1
  677. package/dist/esm/six-error-page.entry.js +82 -82
  678. package/dist/esm/six-error-page.entry.js.map +1 -1
  679. package/dist/esm/six-error.entry.js +17 -0
  680. package/dist/esm/six-error.entry.js.map +1 -0
  681. package/dist/esm/six-file-list-item.entry.js +34 -34
  682. package/dist/esm/six-file-list-item.entry.js.map +1 -1
  683. package/dist/esm/six-file-list.entry.js +7 -7
  684. package/dist/esm/six-file-list.entry.js.map +1 -1
  685. package/dist/esm/six-file-upload.entry.js +99 -99
  686. package/dist/esm/six-file-upload.entry.js.map +1 -1
  687. package/dist/esm/six-footer.entry.js +8 -8
  688. package/dist/esm/six-footer.entry.js.map +1 -1
  689. package/dist/esm/six-group-label.entry.js +43 -43
  690. package/dist/esm/six-group-label.entry.js.map +1 -1
  691. package/dist/esm/six-header.entry.js +171 -156
  692. package/dist/esm/six-header.entry.js.map +1 -1
  693. package/dist/esm/six-icon-button.entry.js +32 -32
  694. package/dist/esm/six-icon-button.entry.js.map +1 -1
  695. package/dist/esm/six-icon.entry.js +22 -22
  696. package/dist/esm/six-icon.entry.js.map +1 -1
  697. package/dist/esm/six-input.entry.js +192 -187
  698. package/dist/esm/six-input.entry.js.map +1 -1
  699. package/dist/esm/six-item-picker.entry.js +405 -309
  700. package/dist/esm/six-item-picker.entry.js.map +1 -1
  701. package/dist/esm/six-language-switcher.entry.js +46 -46
  702. package/dist/esm/six-language-switcher.entry.js.map +1 -1
  703. package/dist/esm/six-layout-grid.entry.js +20 -20
  704. package/dist/esm/six-layout-grid.entry.js.map +1 -1
  705. package/dist/esm/six-main-container.entry.js +9 -9
  706. package/dist/esm/six-main-container.entry.js.map +1 -1
  707. package/dist/esm/six-menu-divider.entry.js +8 -8
  708. package/dist/esm/six-menu-divider.entry.js.map +1 -1
  709. package/dist/esm/six-menu-label.entry.js +8 -8
  710. package/dist/esm/six-menu-label.entry.js.map +1 -1
  711. package/dist/esm/six-picto.entry.js +14 -14
  712. package/dist/esm/six-picto.entry.js.map +1 -1
  713. package/dist/esm/six-progress-bar.entry.js +15 -15
  714. package/dist/esm/six-progress-bar.entry.js.map +1 -1
  715. package/dist/esm/six-progress-ring.entry.js +30 -30
  716. package/dist/esm/six-progress-ring.entry.js.map +1 -1
  717. package/dist/esm/six-radio.entry.js +104 -112
  718. package/dist/esm/six-radio.entry.js.map +1 -1
  719. package/dist/esm/six-range.entry.js +180 -177
  720. package/dist/esm/six-range.entry.js.map +1 -1
  721. package/dist/esm/six-root.entry.js +11 -30
  722. package/dist/esm/six-root.entry.js.map +1 -1
  723. package/dist/esm/six-search-field.entry.js +44 -44
  724. package/dist/esm/six-search-field.entry.js.map +1 -1
  725. package/dist/esm/six-select.entry.js +496 -361
  726. package/dist/esm/six-select.entry.js.map +1 -1
  727. package/dist/esm/six-sidebar-item-group.entry.js +56 -45
  728. package/dist/esm/six-sidebar-item-group.entry.js.map +1 -1
  729. package/dist/esm/six-sidebar-item.entry.js +17 -15
  730. package/dist/esm/six-sidebar-item.entry.js.map +1 -1
  731. package/dist/esm/six-sidebar.entry.js +174 -174
  732. package/dist/esm/six-sidebar.entry.js.map +1 -1
  733. package/dist/esm/six-spinner.entry.js +15 -15
  734. package/dist/esm/six-spinner.entry.js.map +1 -1
  735. package/dist/esm/six-stage-indicator.entry.js +18 -0
  736. package/dist/esm/six-stage-indicator.entry.js.map +1 -0
  737. package/dist/esm/six-switch.entry.js +107 -87
  738. package/dist/esm/six-switch.entry.js.map +1 -1
  739. package/dist/esm/six-tab-group.entry.js +230 -235
  740. package/dist/esm/six-tab-group.entry.js.map +1 -1
  741. package/dist/esm/six-tab-panel.entry.js +14 -14
  742. package/dist/esm/six-tab-panel.entry.js.map +1 -1
  743. package/dist/esm/six-tab.entry.js +55 -39
  744. package/dist/esm/six-tab.entry.js.map +1 -1
  745. package/dist/esm/six-tag.entry.js +55 -33
  746. package/dist/esm/six-tag.entry.js.map +1 -1
  747. package/dist/esm/six-textarea.entry.js +181 -178
  748. package/dist/esm/six-textarea.entry.js.map +1 -1
  749. package/dist/esm/six-tile.entry.js +77 -77
  750. package/dist/esm/six-tile.entry.js.map +1 -1
  751. package/dist/esm/six-timepicker.entry.js +348 -353
  752. package/dist/esm/six-timepicker.entry.js.map +1 -1
  753. package/dist/esm/six-tooltip.entry.js +148 -148
  754. package/dist/esm/six-tooltip.entry.js.map +1 -1
  755. package/dist/esm/slot-56531341.js +47 -0
  756. package/dist/esm/slot-56531341.js.map +1 -0
  757. package/dist/esm/types-a07bb999.js +19 -0
  758. package/dist/esm/types-a07bb999.js.map +1 -0
  759. package/dist/esm/ui-library.js +4 -7
  760. package/dist/esm/ui-library.js.map +1 -1
  761. package/dist/types/components/six-alert/six-alert.d.ts +47 -40
  762. package/dist/types/components/six-avatar/six-avatar.d.ts +11 -11
  763. package/dist/types/components/six-badge/six-badge.d.ts +7 -7
  764. package/dist/types/components/six-button/six-button.d.ts +48 -48
  765. package/dist/types/components/six-card/six-card.d.ts +1 -1
  766. package/dist/types/components/six-checkbox/six-checkbox.d.ts +58 -59
  767. package/dist/types/components/six-datepicker/components/day-selection.d.ts +3 -3
  768. package/dist/types/components/six-datepicker/components/month-selection.d.ts +3 -3
  769. package/dist/types/components/six-datepicker/components/year-selection.d.ts +3 -3
  770. package/dist/types/components/six-datepicker/six-date-formats.d.ts +20 -20
  771. package/dist/types/components/six-datepicker/six-datepicker.d.ts +188 -186
  772. package/dist/types/components/six-details/six-details.d.ts +42 -42
  773. package/dist/types/components/six-dialog/six-dialog.d.ts +51 -50
  774. package/dist/types/components/six-drawer/six-drawer.d.ts +58 -58
  775. package/dist/types/components/six-dropdown/six-dropdown.d.ts +131 -112
  776. package/dist/types/components/six-error/six-error.d.ts +9 -0
  777. package/dist/types/components/six-error-page/six-error-page.d.ts +25 -25
  778. package/dist/types/components/six-file-list/six-file-list.d.ts +1 -1
  779. package/dist/types/components/six-file-list-item/six-file-list-item.d.ts +23 -23
  780. package/dist/types/components/six-file-upload/six-file-upload.d.ts +33 -33
  781. package/dist/types/components/six-footer/six-footer.d.ts +1 -1
  782. package/dist/types/components/six-group-label/six-group-label.d.ts +22 -22
  783. package/dist/types/components/six-header/six-header.d.ts +59 -55
  784. package/dist/types/components/six-icon/six-icon.d.ts +5 -5
  785. package/dist/types/components/six-icon-button/six-icon-button.d.ts +18 -18
  786. package/dist/types/components/six-input/six-input.d.ts +112 -103
  787. package/dist/types/components/six-item-picker/six-item-picker.d.ts +95 -88
  788. package/dist/types/components/six-item-picker/types.d.ts +7 -7
  789. package/dist/types/components/six-language-switcher/six-language-switcher.d.ts +15 -15
  790. package/dist/types/components/six-layout-grid/six-layout-grid.d.ts +6 -6
  791. package/dist/types/components/six-main-container/six-main-container.d.ts +4 -4
  792. package/dist/types/components/six-menu/six-menu.d.ts +67 -63
  793. package/dist/types/components/six-menu-divider/six-menu-divider.d.ts +1 -1
  794. package/dist/types/components/six-menu-item/six-menu-item.d.ts +27 -21
  795. package/dist/types/components/six-menu-label/six-menu-label.d.ts +1 -1
  796. package/dist/types/components/six-picto/six-picto.d.ts +6 -6
  797. package/dist/types/components/six-progress-bar/six-progress-bar.d.ts +5 -5
  798. package/dist/types/components/six-progress-ring/six-progress-ring.d.ts +11 -11
  799. package/dist/types/components/six-radio/six-radio.d.ts +38 -43
  800. package/dist/types/components/six-range/six-range.d.ts +75 -72
  801. package/dist/types/components/six-root/six-root.d.ts +8 -21
  802. package/dist/types/components/six-search-field/six-search-field.d.ts +20 -20
  803. package/dist/types/components/six-select/six-select.d.ts +137 -119
  804. package/dist/types/components/six-select/util.d.ts +1 -1
  805. package/dist/types/components/six-sidebar/six-sidebar.d.ts +45 -45
  806. package/dist/types/components/six-sidebar-item/six-sidebar-item.d.ts +12 -7
  807. package/dist/types/components/six-sidebar-item-group/six-sidebar-item-group.d.ts +25 -19
  808. package/dist/types/components/six-spinner/six-spinner.d.ts +6 -5
  809. package/dist/types/components/six-stage-indicator/six-stage-indicator.d.ts +3 -3
  810. package/dist/types/components/six-switch/six-switch.d.ts +49 -42
  811. package/dist/types/components/six-tab/six-tab.d.ts +20 -20
  812. package/dist/types/components/six-tab-group/six-tab-group.d.ts +35 -38
  813. package/dist/types/components/six-tab-panel/six-tab-panel.d.ts +7 -7
  814. package/dist/types/components/six-tag/six-tag.d.ts +20 -12
  815. package/dist/types/components/six-textarea/six-textarea.d.ts +89 -86
  816. package/dist/types/components/six-tile/six-tile.d.ts +31 -31
  817. package/dist/types/components/six-timepicker/six-timepicker.d.ts +154 -151
  818. package/dist/types/components/six-tooltip/six-tooltip.d.ts +55 -55
  819. package/dist/types/components.d.ts +565 -72
  820. package/dist/types/functional-components/form-control/form-control.d.ts +32 -28
  821. package/dist/types/index.d.ts +1 -0
  822. package/dist/types/stencil-public-runtime.d.ts +49 -5
  823. package/dist/types/types.d.ts +1 -0
  824. package/dist/types/utils/alert.d.ts +10 -0
  825. package/dist/types/utils/animation.d.ts +12 -0
  826. package/dist/types/utils/date-util.d.ts +58 -50
  827. package/dist/types/utils/error-messages.d.ts +27 -25
  828. package/dist/types/utils/event-listeners.d.ts +11 -11
  829. package/dist/types/utils/focus-visible.d.ts +2 -2
  830. package/dist/types/utils/modal.d.ts +8 -8
  831. package/dist/types/utils/offset.d.ts +2 -2
  832. package/dist/types/utils/popover.d.ts +21 -21
  833. package/dist/types/utils/slot.d.ts +0 -1
  834. package/dist/types/utils/time.util.d.ts +6 -6
  835. package/dist/types/utils/types.d.ts +1 -1
  836. package/dist/ui-library/index.esm.js +1 -1
  837. package/dist/ui-library/index.esm.js.map +1 -1
  838. package/dist/ui-library/{p-9337cdd6.entry.js → p-0440335d.entry.js} +2 -2
  839. package/dist/ui-library/p-0440335d.entry.js.map +1 -0
  840. package/dist/ui-library/p-04cc397c.entry.js +2 -0
  841. package/dist/ui-library/p-04cc397c.entry.js.map +1 -0
  842. package/dist/ui-library/{p-0cc08e91.js → p-06ba4450.js} +1 -1
  843. package/dist/ui-library/p-06ba4450.js.map +1 -0
  844. package/dist/ui-library/p-0cebf1d2.js +2 -0
  845. package/dist/ui-library/p-0cebf1d2.js.map +1 -0
  846. package/dist/ui-library/p-0edd3091.entry.js +2 -0
  847. package/dist/ui-library/p-0edd3091.entry.js.map +1 -0
  848. package/dist/ui-library/p-150b7664.entry.js +2 -0
  849. package/dist/ui-library/p-150b7664.entry.js.map +1 -0
  850. package/dist/ui-library/p-1f5840b5.entry.js +2 -0
  851. package/dist/ui-library/p-1f5840b5.entry.js.map +1 -0
  852. package/dist/ui-library/p-28cc013e.entry.js +2 -0
  853. package/dist/ui-library/p-28cc013e.entry.js.map +1 -0
  854. package/dist/ui-library/p-3424bbc0.entry.js +2 -0
  855. package/dist/ui-library/p-3424bbc0.entry.js.map +1 -0
  856. package/dist/ui-library/p-348c68a8.entry.js +2 -0
  857. package/dist/ui-library/p-348c68a8.entry.js.map +1 -0
  858. package/dist/ui-library/p-3723ca06.entry.js +2 -0
  859. package/dist/ui-library/p-3723ca06.entry.js.map +1 -0
  860. package/dist/ui-library/p-37aeac5e.entry.js +2 -0
  861. package/dist/ui-library/p-37aeac5e.entry.js.map +1 -0
  862. package/dist/ui-library/p-3d7fb086.entry.js +2 -0
  863. package/dist/ui-library/p-3d7fb086.entry.js.map +1 -0
  864. package/dist/ui-library/{p-28be55f0.entry.js → p-457f7373.entry.js} +2 -2
  865. package/dist/ui-library/p-457f7373.entry.js.map +1 -0
  866. package/dist/ui-library/p-4a667f31.entry.js +2 -0
  867. package/dist/ui-library/p-4a667f31.entry.js.map +1 -0
  868. package/dist/ui-library/p-50dae789.entry.js +2 -0
  869. package/dist/ui-library/p-50dae789.entry.js.map +1 -0
  870. package/dist/ui-library/{p-dcd7c547.entry.js → p-546e33d9.entry.js} +2 -2
  871. package/dist/ui-library/p-546e33d9.entry.js.map +1 -0
  872. package/dist/ui-library/{p-73597d13.entry.js → p-5db3a705.entry.js} +2 -2
  873. package/dist/ui-library/p-5db3a705.entry.js.map +1 -0
  874. package/dist/ui-library/p-61e66671.js +2 -0
  875. package/dist/ui-library/p-61e66671.js.map +1 -0
  876. package/dist/ui-library/p-6296779b.entry.js +2 -0
  877. package/dist/ui-library/p-6296779b.entry.js.map +1 -0
  878. package/dist/ui-library/p-64b4755d.entry.js +2 -0
  879. package/dist/ui-library/p-64b4755d.entry.js.map +1 -0
  880. package/dist/ui-library/p-6c1b046e.entry.js +2 -0
  881. package/dist/ui-library/p-6c1b046e.entry.js.map +1 -0
  882. package/dist/ui-library/p-7115316e.entry.js +2 -0
  883. package/dist/ui-library/p-7115316e.entry.js.map +1 -0
  884. package/dist/ui-library/p-73dd493f.entry.js +2 -0
  885. package/dist/ui-library/p-73dd493f.entry.js.map +1 -0
  886. package/dist/ui-library/{p-0b2c6348.js → p-7f856f00.js} +1 -1
  887. package/dist/ui-library/p-7f856f00.js.map +1 -0
  888. package/dist/ui-library/{p-eb8f05a9.js → p-8227aaed.js} +2 -2
  889. package/dist/ui-library/p-8227aaed.js.map +1 -0
  890. package/dist/ui-library/{p-4d408fb4.js → p-842b492e.js} +1 -1
  891. package/dist/ui-library/p-842b492e.js.map +1 -0
  892. package/dist/ui-library/{p-25a3bf57.js → p-862d474e.js} +1 -1
  893. package/dist/ui-library/p-862d474e.js.map +1 -0
  894. package/dist/ui-library/p-870b988d.entry.js +2 -0
  895. package/dist/ui-library/p-870b988d.entry.js.map +1 -0
  896. package/dist/ui-library/{p-e8feb81f.entry.js → p-884c5cf9.entry.js} +2 -2
  897. package/dist/ui-library/p-884c5cf9.entry.js.map +1 -0
  898. package/dist/ui-library/p-8888a367.entry.js +2 -0
  899. package/dist/ui-library/p-8888a367.entry.js.map +1 -0
  900. package/dist/ui-library/{p-60621dc6.js → p-8bfb4bfc.js} +1 -1
  901. package/dist/ui-library/p-8bfb4bfc.js.map +1 -0
  902. package/dist/ui-library/p-8ced18d8.entry.js +2 -0
  903. package/dist/ui-library/p-8ced18d8.entry.js.map +1 -0
  904. package/dist/ui-library/{p-820c23f0.entry.js → p-935c78a7.entry.js} +2 -2
  905. package/dist/ui-library/p-935c78a7.entry.js.map +1 -0
  906. package/dist/ui-library/p-961bd001.entry.js +2 -0
  907. package/dist/ui-library/p-961bd001.entry.js.map +1 -0
  908. package/dist/ui-library/{p-ba74863a.js → p-998de05d.js} +1 -1
  909. package/dist/ui-library/p-998de05d.js.map +1 -0
  910. package/dist/ui-library/p-9b08068d.entry.js +2 -0
  911. package/dist/ui-library/p-9b08068d.entry.js.map +1 -0
  912. package/dist/ui-library/p-9c79341d.entry.js +2 -0
  913. package/dist/ui-library/p-9c79341d.entry.js.map +1 -0
  914. package/dist/ui-library/{p-8cf72af6.js → p-a1502802.js} +1 -1
  915. package/dist/ui-library/p-a1502802.js.map +1 -0
  916. package/dist/ui-library/{p-afcbe9da.entry.js → p-a9c159f2.entry.js} +2 -2
  917. package/dist/ui-library/p-a9c159f2.entry.js.map +1 -0
  918. package/dist/ui-library/p-ac57ba5c.entry.js +2 -0
  919. package/dist/ui-library/p-ac57ba5c.entry.js.map +1 -0
  920. package/dist/ui-library/p-af15381b.js +3 -0
  921. package/dist/ui-library/p-af15381b.js.map +1 -0
  922. package/dist/ui-library/p-b1a5f3cd.entry.js +2 -0
  923. package/dist/ui-library/p-b1a5f3cd.entry.js.map +1 -0
  924. package/dist/ui-library/p-b385a241.entry.js +2 -0
  925. package/dist/ui-library/p-b385a241.entry.js.map +1 -0
  926. package/dist/ui-library/p-b74c5d6b.entry.js +2 -0
  927. package/dist/ui-library/p-b74c5d6b.entry.js.map +1 -0
  928. package/dist/ui-library/p-bf2fb53f.entry.js +2 -0
  929. package/dist/ui-library/p-bf2fb53f.entry.js.map +1 -0
  930. package/dist/ui-library/p-c2c7370b.entry.js +2 -0
  931. package/dist/ui-library/p-c2c7370b.entry.js.map +1 -0
  932. package/dist/ui-library/p-caea1eb6.entry.js +2 -0
  933. package/dist/ui-library/p-caea1eb6.entry.js.map +1 -0
  934. package/dist/ui-library/p-d3f5b9a8.entry.js +2 -0
  935. package/dist/ui-library/p-d3f5b9a8.entry.js.map +1 -0
  936. package/dist/ui-library/p-d42b18eb.entry.js +2 -0
  937. package/dist/ui-library/p-d42b18eb.entry.js.map +1 -0
  938. package/dist/ui-library/p-d95e292e.entry.js +2 -0
  939. package/dist/ui-library/p-d95e292e.entry.js.map +1 -0
  940. package/dist/ui-library/p-da7f3dbd.entry.js +2 -0
  941. package/dist/ui-library/p-da7f3dbd.entry.js.map +1 -0
  942. package/dist/ui-library/p-dfb89b6a.entry.js +2 -0
  943. package/dist/ui-library/p-dfb89b6a.entry.js.map +1 -0
  944. package/dist/ui-library/p-e080d5b6.js +2 -0
  945. package/dist/ui-library/p-e080d5b6.js.map +1 -0
  946. package/dist/ui-library/p-e6032375.entry.js +2 -0
  947. package/dist/ui-library/p-e6032375.entry.js.map +1 -0
  948. package/dist/ui-library/p-e60d2324.entry.js +2 -0
  949. package/dist/ui-library/p-e60d2324.entry.js.map +1 -0
  950. package/dist/ui-library/p-e8298c6e.entry.js +2 -0
  951. package/dist/ui-library/p-e8298c6e.entry.js.map +1 -0
  952. package/dist/ui-library/p-ed279165.entry.js +2 -0
  953. package/dist/ui-library/p-ed279165.entry.js.map +1 -0
  954. package/dist/ui-library/p-ed61b75c.entry.js +2 -0
  955. package/dist/ui-library/p-ed61b75c.entry.js.map +1 -0
  956. package/dist/ui-library/p-f136a6b2.js +2 -0
  957. package/dist/ui-library/p-f136a6b2.js.map +1 -0
  958. package/dist/ui-library/p-f1ab3384.entry.js +2 -0
  959. package/dist/ui-library/p-f1ab3384.entry.js.map +1 -0
  960. package/dist/ui-library/p-f4ef481c.entry.js +2 -0
  961. package/dist/ui-library/p-f4ef481c.entry.js.map +1 -0
  962. package/dist/ui-library/{p-d6798d35.entry.js → p-f8cbb8da.entry.js} +2 -2
  963. package/dist/ui-library/p-f8cbb8da.entry.js.map +1 -0
  964. package/dist/ui-library/ui-library.css +1 -10
  965. package/dist/ui-library/ui-library.esm.js +1 -1
  966. package/dist/ui-library/ui-library.esm.js.map +1 -1
  967. package/loader/index.d.ts +1 -1
  968. package/package.json +19 -20
  969. package/dist/cjs/event-listeners-b835dfae.js +0 -61
  970. package/dist/cjs/event-listeners-b835dfae.js.map +0 -1
  971. package/dist/cjs/execution-control-45c84c46.js.map +0 -1
  972. package/dist/cjs/focus-visible-e0d93a95.js +0 -47
  973. package/dist/cjs/focus-visible-e0d93a95.js.map +0 -1
  974. package/dist/cjs/form-8cbd4e0e.js +0 -20
  975. package/dist/cjs/form-8cbd4e0e.js.map +0 -1
  976. package/dist/cjs/form-control-8df00a52.js +0 -33
  977. package/dist/cjs/form-control-8df00a52.js.map +0 -1
  978. package/dist/cjs/index-2f6daa5b.js.map +0 -1
  979. package/dist/cjs/modal-21350fb5.js +0 -52
  980. package/dist/cjs/modal-21350fb5.js.map +0 -1
  981. package/dist/cjs/popover-8885d50f.js.map +0 -1
  982. package/dist/cjs/popup-44836aaf.js +0 -103
  983. package/dist/cjs/popup-44836aaf.js.map +0 -1
  984. package/dist/cjs/scroll-76e6f5d7.js +0 -69
  985. package/dist/cjs/scroll-76e6f5d7.js.map +0 -1
  986. package/dist/cjs/set-attributes_2.cjs.entry.js +0 -73
  987. package/dist/cjs/set-attributes_2.cjs.entry.js.map +0 -1
  988. package/dist/cjs/six-checkbox.cjs.entry.js +0 -132
  989. package/dist/cjs/six-checkbox.cjs.entry.js.map +0 -1
  990. package/dist/cjs/six-menu-item.cjs.entry.js +0 -63
  991. package/dist/cjs/six-menu-item.cjs.entry.js.map +0 -1
  992. package/dist/cjs/slot-bccbdb59.js +0 -53
  993. package/dist/cjs/slot-bccbdb59.js.map +0 -1
  994. package/dist/cjs/types-64878648.js +0 -17
  995. package/dist/cjs/types-64878648.js.map +0 -1
  996. package/dist/collection/wrappers/set-attributes/set-attributes.js +0 -74
  997. package/dist/collection/wrappers/set-attributes/set-attributes.js.map +0 -1
  998. package/dist/components/set-attributes.js +0 -8
  999. package/dist/components/set-attributes.js.map +0 -1
  1000. package/dist/components/set-attributes2.js +0 -71
  1001. package/dist/components/set-attributes2.js.map +0 -1
  1002. package/dist/components/six-tag2.js +0 -74
  1003. package/dist/components/six-tag2.js.map +0 -1
  1004. package/dist/esm/event-listeners-535f3ad1.js +0 -59
  1005. package/dist/esm/event-listeners-535f3ad1.js.map +0 -1
  1006. package/dist/esm/execution-control-72cc50f4.js.map +0 -1
  1007. package/dist/esm/focus-visible-fa7129a0.js +0 -45
  1008. package/dist/esm/focus-visible-fa7129a0.js.map +0 -1
  1009. package/dist/esm/form-0b9c11cd.js +0 -18
  1010. package/dist/esm/form-control-785c5f79.js +0 -31
  1011. package/dist/esm/form-control-785c5f79.js.map +0 -1
  1012. package/dist/esm/index-5c0f6628.js.map +0 -1
  1013. package/dist/esm/modal-b1d96441.js +0 -49
  1014. package/dist/esm/modal-b1d96441.js.map +0 -1
  1015. package/dist/esm/polyfills/css-shim.js +0 -1
  1016. package/dist/esm/popover-2e72e7d8.js.map +0 -1
  1017. package/dist/esm/popup-678b8592.js +0 -98
  1018. package/dist/esm/popup-678b8592.js.map +0 -1
  1019. package/dist/esm/scroll-180b53fd.js +0 -64
  1020. package/dist/esm/set-attributes_2.entry.js +0 -68
  1021. package/dist/esm/set-attributes_2.entry.js.map +0 -1
  1022. package/dist/esm/six-checkbox.entry.js +0 -128
  1023. package/dist/esm/six-checkbox.entry.js.map +0 -1
  1024. package/dist/esm/six-menu-item.entry.js +0 -59
  1025. package/dist/esm/six-menu-item.entry.js.map +0 -1
  1026. package/dist/esm/slot-2e64df19.js +0 -48
  1027. package/dist/esm/slot-2e64df19.js.map +0 -1
  1028. package/dist/esm/types-4b10b413.js +0 -17
  1029. package/dist/esm/types-4b10b413.js.map +0 -1
  1030. package/dist/types/wrappers/set-attributes/set-attributes.d.ts +0 -9
  1031. package/dist/ui-library/p-0108fe92.entry.js +0 -2
  1032. package/dist/ui-library/p-0108fe92.entry.js.map +0 -1
  1033. package/dist/ui-library/p-03a145f5.entry.js +0 -2
  1034. package/dist/ui-library/p-03a145f5.entry.js.map +0 -1
  1035. package/dist/ui-library/p-087fdd96.entry.js +0 -2
  1036. package/dist/ui-library/p-087fdd96.entry.js.map +0 -1
  1037. package/dist/ui-library/p-09779e47.entry.js +0 -2
  1038. package/dist/ui-library/p-09779e47.entry.js.map +0 -1
  1039. package/dist/ui-library/p-097cced4.entry.js +0 -2
  1040. package/dist/ui-library/p-097cced4.entry.js.map +0 -1
  1041. package/dist/ui-library/p-0b2c6348.js.map +0 -1
  1042. package/dist/ui-library/p-0cc08e91.js.map +0 -1
  1043. package/dist/ui-library/p-0fe78f9b.js +0 -2
  1044. package/dist/ui-library/p-0fe78f9b.js.map +0 -1
  1045. package/dist/ui-library/p-18e9f8b8.entry.js +0 -2
  1046. package/dist/ui-library/p-18e9f8b8.entry.js.map +0 -1
  1047. package/dist/ui-library/p-21859bca.entry.js +0 -2
  1048. package/dist/ui-library/p-21859bca.entry.js.map +0 -1
  1049. package/dist/ui-library/p-25a3bf57.js.map +0 -1
  1050. package/dist/ui-library/p-2761f908.js +0 -2
  1051. package/dist/ui-library/p-2761f908.js.map +0 -1
  1052. package/dist/ui-library/p-28be55f0.entry.js.map +0 -1
  1053. package/dist/ui-library/p-3929b0af.entry.js +0 -2
  1054. package/dist/ui-library/p-3929b0af.entry.js.map +0 -1
  1055. package/dist/ui-library/p-445ba5b8.entry.js +0 -2
  1056. package/dist/ui-library/p-445ba5b8.entry.js.map +0 -1
  1057. package/dist/ui-library/p-4d408fb4.js.map +0 -1
  1058. package/dist/ui-library/p-502ff3d3.entry.js +0 -2
  1059. package/dist/ui-library/p-502ff3d3.entry.js.map +0 -1
  1060. package/dist/ui-library/p-5a34c93e.entry.js +0 -2
  1061. package/dist/ui-library/p-5a34c93e.entry.js.map +0 -1
  1062. package/dist/ui-library/p-60621dc6.js.map +0 -1
  1063. package/dist/ui-library/p-63703ba3.entry.js +0 -2
  1064. package/dist/ui-library/p-63703ba3.entry.js.map +0 -1
  1065. package/dist/ui-library/p-66180e89.entry.js +0 -2
  1066. package/dist/ui-library/p-66180e89.entry.js.map +0 -1
  1067. package/dist/ui-library/p-686b12ec.entry.js +0 -2
  1068. package/dist/ui-library/p-686b12ec.entry.js.map +0 -1
  1069. package/dist/ui-library/p-6d75f216.entry.js +0 -2
  1070. package/dist/ui-library/p-6d75f216.entry.js.map +0 -1
  1071. package/dist/ui-library/p-71035abf.entry.js +0 -2
  1072. package/dist/ui-library/p-71035abf.entry.js.map +0 -1
  1073. package/dist/ui-library/p-724e154d.entry.js +0 -2
  1074. package/dist/ui-library/p-724e154d.entry.js.map +0 -1
  1075. package/dist/ui-library/p-72ca96e1.entry.js +0 -2
  1076. package/dist/ui-library/p-72ca96e1.entry.js.map +0 -1
  1077. package/dist/ui-library/p-73597d13.entry.js.map +0 -1
  1078. package/dist/ui-library/p-778cf804.entry.js +0 -2
  1079. package/dist/ui-library/p-778cf804.entry.js.map +0 -1
  1080. package/dist/ui-library/p-820c23f0.entry.js.map +0 -1
  1081. package/dist/ui-library/p-87032e26.entry.js +0 -2
  1082. package/dist/ui-library/p-87032e26.entry.js.map +0 -1
  1083. package/dist/ui-library/p-8cf72af6.js.map +0 -1
  1084. package/dist/ui-library/p-8e0b6b7e.entry.js +0 -2
  1085. package/dist/ui-library/p-8e0b6b7e.entry.js.map +0 -1
  1086. package/dist/ui-library/p-912092c0.entry.js +0 -2
  1087. package/dist/ui-library/p-912092c0.entry.js.map +0 -1
  1088. package/dist/ui-library/p-92ca6a84.entry.js +0 -2
  1089. package/dist/ui-library/p-92ca6a84.entry.js.map +0 -1
  1090. package/dist/ui-library/p-9337cdd6.entry.js.map +0 -1
  1091. package/dist/ui-library/p-9461417e.entry.js +0 -2
  1092. package/dist/ui-library/p-9461417e.entry.js.map +0 -1
  1093. package/dist/ui-library/p-97323ad7.entry.js +0 -2
  1094. package/dist/ui-library/p-97323ad7.entry.js.map +0 -1
  1095. package/dist/ui-library/p-a1d4f6cf.entry.js +0 -2
  1096. package/dist/ui-library/p-a1d4f6cf.entry.js.map +0 -1
  1097. package/dist/ui-library/p-a49ae60a.entry.js +0 -2
  1098. package/dist/ui-library/p-a49ae60a.entry.js.map +0 -1
  1099. package/dist/ui-library/p-a844cb72.entry.js +0 -2
  1100. package/dist/ui-library/p-a844cb72.entry.js.map +0 -1
  1101. package/dist/ui-library/p-ac4f4d45.js +0 -3
  1102. package/dist/ui-library/p-ac4f4d45.js.map +0 -1
  1103. package/dist/ui-library/p-afcbe9da.entry.js.map +0 -1
  1104. package/dist/ui-library/p-b3bff992.entry.js +0 -2
  1105. package/dist/ui-library/p-b3bff992.entry.js.map +0 -1
  1106. package/dist/ui-library/p-b4547fb5.entry.js +0 -2
  1107. package/dist/ui-library/p-b4547fb5.entry.js.map +0 -1
  1108. package/dist/ui-library/p-ba74863a.js.map +0 -1
  1109. package/dist/ui-library/p-baa03951.entry.js +0 -2
  1110. package/dist/ui-library/p-baa03951.entry.js.map +0 -1
  1111. package/dist/ui-library/p-bd8f8eef.entry.js +0 -2
  1112. package/dist/ui-library/p-bd8f8eef.entry.js.map +0 -1
  1113. package/dist/ui-library/p-c57f16af.entry.js +0 -2
  1114. package/dist/ui-library/p-c57f16af.entry.js.map +0 -1
  1115. package/dist/ui-library/p-c5cdba08.entry.js +0 -2
  1116. package/dist/ui-library/p-c5cdba08.entry.js.map +0 -1
  1117. package/dist/ui-library/p-c87810b0.entry.js +0 -2
  1118. package/dist/ui-library/p-c87810b0.entry.js.map +0 -1
  1119. package/dist/ui-library/p-cdcde4cd.entry.js +0 -2
  1120. package/dist/ui-library/p-cdcde4cd.entry.js.map +0 -1
  1121. package/dist/ui-library/p-d6798d35.entry.js.map +0 -1
  1122. package/dist/ui-library/p-d87a6f4d.js +0 -2
  1123. package/dist/ui-library/p-d87a6f4d.js.map +0 -1
  1124. package/dist/ui-library/p-dc3f5996.entry.js +0 -2
  1125. package/dist/ui-library/p-dc3f5996.entry.js.map +0 -1
  1126. package/dist/ui-library/p-dcd7c547.entry.js.map +0 -1
  1127. package/dist/ui-library/p-dd3c76f1.entry.js +0 -2
  1128. package/dist/ui-library/p-dd3c76f1.entry.js.map +0 -1
  1129. package/dist/ui-library/p-e07b3f0c.entry.js +0 -2
  1130. package/dist/ui-library/p-e07b3f0c.entry.js.map +0 -1
  1131. package/dist/ui-library/p-e19a6c95.entry.js +0 -2
  1132. package/dist/ui-library/p-e19a6c95.entry.js.map +0 -1
  1133. package/dist/ui-library/p-e8feb81f.entry.js.map +0 -1
  1134. package/dist/ui-library/p-eb8f05a9.js.map +0 -1
  1135. package/dist/ui-library/p-ef3936e5.entry.js +0 -2
  1136. package/dist/ui-library/p-ef3936e5.entry.js.map +0 -1
  1137. package/dist/ui-library/p-f0dd77e1.entry.js +0 -2
  1138. package/dist/ui-library/p-f0dd77e1.entry.js.map +0 -1
  1139. package/readme.md +0 -156
@@ -2,256 +2,272 @@ import { proxyCustomElement, HTMLElement, createEvent, h } from '@stencil/core/i
2
2
  import { a as getTextContent } from './slot.js';
3
3
  import { E as EventListeners } from './event-listeners.js';
4
4
  import { a as debounce } from './execution-control.js';
5
+ import { d as defineCustomElement$4 } from './six-checkbox2.js';
6
+ import { d as defineCustomElement$3 } from './six-error2.js';
5
7
  import { d as defineCustomElement$2 } from './six-icon2.js';
6
8
  import { d as defineCustomElement$1 } from './six-menu-item2.js';
7
9
 
8
- const sixMenuCss = ":host{position:relative;box-sizing:border-box}:host *,:host *:before,:host *:after{box-sizing:inherit}:host{display:block}.menu{padding:0 0;border:none;box-shadow:var(--six-elevation-2dp)}.menu:focus{outline:none}.menu--noshadow{box-shadow:none}.menu__wrapper--scrollable{overflow-y:auto}";
10
+ const sixMenuCss = ":host{position:relative;box-sizing:border-box}:host *,:host *:before,:host *:after{box-sizing:border-box}:host{display:block}.menu{padding:var(--six-spacing-xx-small) 0;border:none;box-shadow:var(--six-shadow-small);overflow-y:auto;overflow-x:hidden}.menu:focus{outline:none}.no-shadow{box-shadow:none}";
9
11
 
10
12
  const isFocusedMenuItem = (menuItem) => { var _a, _b, _c; return (_c = (_b = (_a = menuItem === null || menuItem === void 0 ? void 0 : menuItem.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.menu-item')) === null || _b === void 0 ? void 0 : _b.classList) === null || _c === void 0 ? void 0 : _c.contains('menu-item--focused'); };
11
13
  const isSIXMenuItemElement = (el) => (el === null || el === void 0 ? void 0 : el.tagName.toLowerCase()) === 'six-menu-item';
12
- const mapToMenuItem = ({ value, label }) => h("six-menu-item", { value: value }, label);
14
+ const mapToMenuItem = ({ value, label }) => (h("six-menu-item", { key: value, value: value }, label));
13
15
  const DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING = 5;
14
16
  const DEFAULT_SIX_MENU_ITEM_HEIGHT = 64;
15
17
  const SixMenu = /*@__PURE__*/ proxyCustomElement(class SixMenu extends HTMLElement {
16
- constructor() {
17
- super();
18
- this.__registerHost();
19
- this.__attachShadow();
20
- this.sixMenuItemSelected = createEvent(this, "six-menu-item-selected", 7);
21
- this.eventListeners = new EventListeners();
22
- this.typeToSelectString = '';
23
- this.handleScrolling = () => {
24
- if (this.menuWrapper == null)
25
- return;
26
- // for performance improvements we only update the DOM if the scrollRatio change "enough"
27
- this.scrollingIndex = Math.floor(this.menuWrapper.scrollTop / this.sixMenuItemHeight);
28
- };
29
- this.removeBoxShadow = false;
30
- this.items = null;
31
- this.itemsShown = undefined;
32
- this.virtualScroll = false;
33
- this.itemSize = 10;
34
- this.scrollingDebounce = 15;
35
- this.scrollingIndex = 0;
36
- this.sixMenuItemHeight = DEFAULT_SIX_MENU_ITEM_HEIGHT;
37
- }
38
- connectedCallback() {
39
- this.handleClick = this.handleClick.bind(this);
40
- this.handleKeyDown = this.handleKeyDown.bind(this);
41
- }
42
- componentWillLoad() {
43
- if (this.items === null) {
44
- return;
18
+ constructor() {
19
+ super();
20
+ this.__registerHost();
21
+ this.__attachShadow();
22
+ this.sixMenuItemSelected = createEvent(this, "six-menu-item-selected", 7);
23
+ this.eventListeners = new EventListeners();
24
+ this.typeToSelectString = '';
25
+ this.handleScrolling = () => {
26
+ if (this.menuWrapper == null)
27
+ return;
28
+ // for performance improvements we only update the DOM if the scrollRatio change "enough"
29
+ this.scrollingIndex = Math.floor(this.menuWrapper.scrollTop / this.sixMenuItemHeight);
30
+ };
31
+ this.removeBoxShadow = false;
32
+ this.items = null;
33
+ this.itemsShown = undefined;
34
+ this.virtualScroll = false;
35
+ this.itemSize = 10;
36
+ this.scrollingDebounce = 15;
37
+ this.disableKeyboardHandling = false;
38
+ this.scrollingIndex = 0;
39
+ this.sixMenuItemHeight = DEFAULT_SIX_MENU_ITEM_HEIGHT;
45
40
  }
46
- }
47
- componentDidLoad() {
48
- this.setupForVirtualScrollingAfterRendering();
49
- }
50
- disconnectedCallback() {
51
- this.eventListeners.removeAll();
52
- }
53
- /**
54
- * Initiates type-to-select logic, which automatically selects an option based on what the user is currently typing.
55
- * The key passed will be appended to the internal query and the selection will be updated. After a brief period, the
56
- * internal query is cleared automatically. This method is intended to be used with the keydown event. Useful for
57
- * enabling type-to-select when the menu doesn't have focus.
58
- */
59
- async typeToSelect(key) {
60
- var _a;
61
- clearTimeout(this.typeToSelectTimeout);
62
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
63
- // @ts-ignore
64
- this.typeToSelectTimeout = setTimeout(() => (this.typeToSelectString = ''), 750);
65
- this.typeToSelectString += key.toLowerCase();
66
- const items = this.getItems();
67
- for (const item of items) {
68
- const slot = (_a = item.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('slot:not([name])');
69
- const label = getTextContent(slot).toLowerCase().trim();
70
- if (label.substring(0, this.typeToSelectString.length) === this.typeToSelectString) {
71
- item.setFocus();
72
- break;
73
- }
41
+ connectedCallback() {
42
+ this.handleClick = this.handleClick.bind(this);
43
+ this.handleKeyDown = this.handleKeyDown.bind(this);
74
44
  }
75
- }
76
- getItemsShown() {
77
- var _a;
78
- const defaultItemsShown = this.virtualScroll ? DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING : 0;
79
- return (_a = this.itemsShown) !== null && _a !== void 0 ? _a : defaultItemsShown;
80
- }
81
- setupForVirtualScrollingAfterRendering() {
82
- var _a, _b;
83
- if (!this.virtualScroll || this.menuWrapper == null)
84
- return;
85
- this.eventListeners.add(this.menuWrapper, 'scroll', debounce(this.handleScrolling, this.scrollingDebounce));
86
- // set menu height to proper height once the item is rendered.
87
- const menuItemHeight = (_b = (_a = this.menu) === null || _a === void 0 ? void 0 : _a.querySelector('six-menu-item')) === null || _b === void 0 ? void 0 : _b.clientHeight;
88
- if (menuItemHeight != null && menuItemHeight > 0) {
89
- this.sixMenuItemHeight = menuItemHeight;
45
+ componentWillLoad() {
46
+ if (this.items === null) {
47
+ return;
48
+ }
90
49
  }
91
- }
92
- getItems() {
93
- if (this.menu == null)
94
- return [];
95
- if (this.items != null) {
96
- return this.items.map(mapToMenuItem);
50
+ componentDidLoad() {
51
+ this.setupForVirtualScrollingAfterRendering();
97
52
  }
98
- const slot = this.menu.querySelector('slot');
99
- if (slot == null)
100
- return [];
101
- return [...slot.assignedElements({ flatten: true })].filter((el) => isSIXMenuItemElement(el) && !el.disabled);
102
- }
103
- getActiveItemIndex() {
104
- const items = this.getItems();
105
- const selectedItem = this.getActiveItem();
106
- if (selectedItem != null) {
107
- const itemIndex = items.indexOf(selectedItem);
108
- if (itemIndex > -1) {
109
- return itemIndex;
110
- }
53
+ disconnectedCallback() {
54
+ this.eventListeners.removeAll();
111
55
  }
112
- const sixMenuItems = this.extractItemsFromDOM();
113
- return sixMenuItems.findIndex(isFocusedMenuItem);
114
- }
115
- getActiveItem() {
116
- var _a;
117
- const activeElement = this.getItems().find((i) => i === document.activeElement);
118
- if (activeElement != null) {
119
- return activeElement;
56
+ /**
57
+ * Initiates type-to-select logic, which automatically selects an option based on what the user is currently typing.
58
+ * The key passed will be appended to the internal query and the selection will be updated. After a brief period, the
59
+ * internal query is cleared automatically. This method is intended to be used with the keydown event. Useful for
60
+ * enabling type-to-select when the menu doesn't have focus.
61
+ */
62
+ async typeToSelect(key) {
63
+ var _a;
64
+ clearTimeout(this.typeToSelectTimeout);
65
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
66
+ // @ts-ignore
67
+ this.typeToSelectTimeout = setTimeout(() => (this.typeToSelectString = ''), 750);
68
+ this.typeToSelectString += key.toLowerCase();
69
+ const items = this.getItems();
70
+ for (const item of items) {
71
+ const slot = (_a = item.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('slot:not([name])');
72
+ const label = getTextContent(slot).toLowerCase().trim();
73
+ if (label.substring(0, this.typeToSelectString.length) === this.typeToSelectString) {
74
+ item.setFocus();
75
+ break;
76
+ }
77
+ }
120
78
  }
121
- return (_a = this.extractItemsFromDOM()) === null || _a === void 0 ? void 0 : _a.find(isFocusedMenuItem);
122
- }
123
- extractItemsFromDOM() {
124
- var _a, _b;
125
- return Array.from((_b = (_a = this.host.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('six-menu-item')) !== null && _b !== void 0 ? _b : []);
126
- }
127
- setActiveItem(item) {
128
- item === null || item === void 0 ? void 0 : item.setFocus();
129
- }
130
- handleClick(event) {
131
- const target = event.target;
132
- const clickedItem = target.closest('six-menu-item');
133
- if (clickedItem && !clickedItem.disabled) {
134
- this.sixMenuItemSelected.emit({ name: clickedItem.value, item: clickedItem });
79
+ getItemsShown() {
80
+ var _a;
81
+ const defaultItemsShown = this.virtualScroll ? DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING : 0;
82
+ return (_a = this.itemsShown) !== null && _a !== void 0 ? _a : defaultItemsShown;
135
83
  }
136
- }
137
- handleKeyDown(event) {
138
- // Make a selection when pressing enter
139
- if (event.key === 'Enter') {
140
- const activeItem = this.getActiveItem();
141
- event.preventDefault();
142
- if (activeItem != null) {
143
- this.sixMenuItemSelected.emit({ name: activeItem.value, item: activeItem });
144
- }
84
+ setupForVirtualScrollingAfterRendering() {
85
+ var _a, _b;
86
+ if (!this.virtualScroll || this.menuWrapper == null)
87
+ return;
88
+ this.eventListeners.add(this.menuWrapper, 'scroll', debounce(this.handleScrolling, this.scrollingDebounce));
89
+ // set menu height to proper height once the item is rendered.
90
+ const menuItemHeight = (_b = (_a = this.menu) === null || _a === void 0 ? void 0 : _a.querySelector('six-menu-item')) === null || _b === void 0 ? void 0 : _b.clientHeight;
91
+ if (menuItemHeight != null && menuItemHeight > 0) {
92
+ this.sixMenuItemHeight = menuItemHeight;
93
+ }
145
94
  }
146
- // Prevent scrolling when space is pressed
147
- if (event.key === ' ') {
148
- event.preventDefault();
95
+ getItems() {
96
+ if (this.menu == null)
97
+ return [];
98
+ if (this.items != null) {
99
+ return this.items.map(mapToMenuItem);
100
+ }
101
+ const slot = this.menu.querySelector('slot');
102
+ if (slot == null)
103
+ return [];
104
+ return [...slot.assignedElements({ flatten: true })].filter((el) => isSIXMenuItemElement(el) && !el.disabled);
149
105
  }
150
- // Move the selection when pressing down or up
151
- if (['ArrowDown', 'ArrowUp', 'Home', 'End'].includes(event.key)) {
152
- const items = this.items === null ? this.getItems() : this.extractItemsFromDOM();
153
- let indexOfActiveItem = this.getActiveItemIndex();
154
- if (items.length > 0) {
155
- event.preventDefault();
156
- if (event.key === 'ArrowDown') {
157
- indexOfActiveItem++;
106
+ getActiveItemIndex() {
107
+ const items = this.getItems();
108
+ const selectedItem = this.getActiveItem();
109
+ if (selectedItem != null) {
110
+ const itemIndex = items.indexOf(selectedItem);
111
+ if (itemIndex > -1) {
112
+ return itemIndex;
113
+ }
158
114
  }
159
- else if (event.key === 'ArrowUp') {
160
- indexOfActiveItem--;
115
+ const sixMenuItems = this.extractItemsFromDOM();
116
+ return sixMenuItems.findIndex(isFocusedMenuItem);
117
+ }
118
+ getActiveItem() {
119
+ var _a;
120
+ const activeElement = this.getItems().find((i) => i === document.activeElement);
121
+ if (activeElement != null) {
122
+ return activeElement;
161
123
  }
162
- else if (event.key === 'Home') {
163
- indexOfActiveItem = 0;
124
+ return (_a = this.extractItemsFromDOM()) === null || _a === void 0 ? void 0 : _a.find(isFocusedMenuItem);
125
+ }
126
+ extractItemsFromDOM() {
127
+ var _a, _b;
128
+ return Array.from((_b = (_a = this.host.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('six-menu-item')) !== null && _b !== void 0 ? _b : []);
129
+ }
130
+ setActiveItem(item) {
131
+ item === null || item === void 0 ? void 0 : item.setFocus();
132
+ }
133
+ handleClick(event) {
134
+ const target = event.target;
135
+ const clickedItem = target.closest('six-menu-item');
136
+ if (clickedItem && !clickedItem.disabled) {
137
+ this.sixMenuItemSelected.emit({ name: clickedItem.value, item: clickedItem });
164
138
  }
165
- else if (event.key === 'End') {
166
- indexOfActiveItem = items.length - 1;
139
+ }
140
+ handleKeyDown(event) {
141
+ if (this.disableKeyboardHandling) {
142
+ return;
167
143
  }
168
- if (indexOfActiveItem < 0)
169
- indexOfActiveItem = 0;
170
- if (indexOfActiveItem > items.length - 1)
171
- indexOfActiveItem = items.length - 1;
172
- this.setActiveItem(items[indexOfActiveItem]);
173
- return;
174
- }
144
+ // Make a selection when pressing enter
145
+ if (event.key === 'Enter') {
146
+ const activeItem = this.getActiveItem();
147
+ event.preventDefault();
148
+ if (activeItem != null) {
149
+ this.sixMenuItemSelected.emit({ name: activeItem.value, item: activeItem });
150
+ }
151
+ }
152
+ // Prevent scrolling when space is pressed
153
+ if (event.key === ' ') {
154
+ event.preventDefault();
155
+ }
156
+ // Move the selection when pressing down or up
157
+ if (['ArrowDown', 'ArrowUp', 'Home', 'End'].includes(event.key)) {
158
+ const items = this.items === null ? this.getItems() : this.extractItemsFromDOM();
159
+ let indexOfActiveItem = this.getActiveItemIndex();
160
+ if (items.length > 0) {
161
+ event.preventDefault();
162
+ if (event.key === 'ArrowDown') {
163
+ indexOfActiveItem++;
164
+ }
165
+ else if (event.key === 'ArrowUp') {
166
+ indexOfActiveItem--;
167
+ }
168
+ else if (event.key === 'Home') {
169
+ indexOfActiveItem = 0;
170
+ }
171
+ else if (event.key === 'End') {
172
+ indexOfActiveItem = items.length - 1;
173
+ }
174
+ if (indexOfActiveItem < 0)
175
+ indexOfActiveItem = 0;
176
+ if (indexOfActiveItem > items.length - 1)
177
+ indexOfActiveItem = items.length - 1;
178
+ this.setActiveItem(items[indexOfActiveItem]);
179
+ return;
180
+ }
181
+ }
182
+ void this.typeToSelect(event.key);
175
183
  }
176
- void this.typeToSelect(event.key);
177
- }
178
- getMenuWrapperStyle() {
179
- var _a;
180
- const styles = {};
181
- if (this.getItemsShown() > 0) {
182
- // calculate the proper height to show the correct number of items
183
- styles.height = `${((_a = this.getItemsShown()) !== null && _a !== void 0 ? _a : 0) * this.sixMenuItemHeight}px`;
184
+ getMenuWrapperStyle() {
185
+ var _a;
186
+ const styles = {};
187
+ if (this.getItemsShown() > 0) {
188
+ // calculate the proper height to show the correct number of items
189
+ styles.height = `${((_a = this.getItemsShown()) !== null && _a !== void 0 ? _a : 0) * this.sixMenuItemHeight}px`;
190
+ }
191
+ return Object.assign({}, styles);
184
192
  }
185
- return Object.assign({}, styles);
186
- }
187
- getMenuContainerStyle() {
188
- const styles = {};
189
- if (this.virtualScroll) {
190
- // calculate height of content are if all items would be rendered so the scrollbar has the proper size
191
- styles.transform = `translateY(${this.sixMenuItemHeight * this.scrollingIndex}px)`;
193
+ getMenuContainerStyle() {
194
+ const styles = {};
195
+ if (this.virtualScroll) {
196
+ // calculate height of content are if all items would be rendered so the scrollbar has the proper size
197
+ styles.transform = `translateY(${this.sixMenuItemHeight * this.scrollingIndex}px)`;
198
+ }
199
+ return Object.assign({}, styles);
192
200
  }
193
- return Object.assign({}, styles);
194
- }
195
- getScrollbarGhostStyle() {
196
- const styles = {};
197
- if (this.virtualScroll && this.items !== null) {
198
- styles.height = `${this.items.length * this.sixMenuItemHeight - this.itemSize * this.sixMenuItemHeight}px`;
201
+ getScrollbarGhostStyle() {
202
+ const styles = {};
203
+ if (this.virtualScroll && this.items !== null) {
204
+ styles.height = `${this.items.length * this.sixMenuItemHeight - this.itemSize * this.sixMenuItemHeight}px`;
205
+ }
206
+ return Object.assign({}, styles);
199
207
  }
200
- return Object.assign({}, styles);
201
- }
202
- renderItems() {
203
- if (this.items === undefined || this.items === null) {
204
- return;
208
+ renderItems() {
209
+ if (this.items === undefined || this.items === null) {
210
+ return;
211
+ }
212
+ if (!this.virtualScroll) {
213
+ return this.items.map(mapToMenuItem);
214
+ }
215
+ return this.items
216
+ .slice(this.scrollingIndex, Math.min(this.items.length, this.itemSize + this.scrollingIndex))
217
+ .map(({ value, label }) => (h("six-menu-item", { checkType: "check", key: value, value: value }, label)));
205
218
  }
206
- if (!this.virtualScroll) {
207
- return this.items.map(mapToMenuItem);
219
+ render() {
220
+ return (h("div", { ref: (el) => (this.menuWrapper = el), style: this.getMenuWrapperStyle(), part: "wrapper", class: {
221
+ menu: true,
222
+ '.no-shadow': this.removeBoxShadow,
223
+ } }, h("div", { ref: (el) => (this.menu = el), part: "base", role: "menu", onClick: this.handleClick, onKeyDown: this.handleKeyDown, tabIndex: 0, style: this.getMenuContainerStyle() }, h("slot", null), this.renderItems()), this.virtualScroll && h("div", { style: this.getScrollbarGhostStyle() })));
208
224
  }
209
- return this.items
210
- .slice(this.scrollingIndex, Math.min(this.items.length, this.itemSize + this.scrollingIndex))
211
- .map(mapToMenuItem);
212
- }
213
- render() {
214
- return (h("div", { ref: (el) => (this.menuWrapper = el), style: this.getMenuWrapperStyle(), part: "wrapper", class: {
215
- menu: true,
216
- 'menu--noshadow': this.removeBoxShadow,
217
- 'menu__wrapper--scrollable': this.getItemsShown() > 0,
218
- } }, h("div", { ref: (el) => (this.menu = el), part: "base", role: "menu", onClick: this.handleClick, onKeyDown: this.handleKeyDown, tabIndex: 0, style: this.getMenuContainerStyle() }, h("slot", null), this.renderItems()), this.virtualScroll && h("div", { style: this.getScrollbarGhostStyle() })));
219
- }
220
- get host() { return this; }
221
- static get style() { return sixMenuCss; }
225
+ get host() { return this; }
226
+ static get style() { return sixMenuCss; }
222
227
  }, [1, "six-menu", {
223
- "removeBoxShadow": [4, "remove-box-shadow"],
224
- "items": [16],
225
- "itemsShown": [2, "items-shown"],
226
- "virtualScroll": [4, "virtual-scroll"],
227
- "itemSize": [2, "item-size"],
228
- "scrollingDebounce": [2, "scrolling-debounce"],
229
- "scrollingIndex": [32],
230
- "sixMenuItemHeight": [32],
231
- "typeToSelect": [64]
232
- }]);
228
+ "removeBoxShadow": [4, "remove-box-shadow"],
229
+ "items": [16],
230
+ "itemsShown": [2, "items-shown"],
231
+ "virtualScroll": [4, "virtual-scroll"],
232
+ "itemSize": [2, "item-size"],
233
+ "scrollingDebounce": [2, "scrolling-debounce"],
234
+ "disableKeyboardHandling": [4, "disable-keyboard-handling"],
235
+ "scrollingIndex": [32],
236
+ "sixMenuItemHeight": [32],
237
+ "typeToSelect": [64]
238
+ }]);
233
239
  function defineCustomElement() {
234
- if (typeof customElements === "undefined") {
235
- return;
236
- }
237
- const components = ["six-menu", "six-icon", "six-menu-item"];
238
- components.forEach(tagName => { switch (tagName) {
239
- case "six-menu":
240
- if (!customElements.get(tagName)) {
241
- customElements.define(tagName, SixMenu);
242
- }
243
- break;
244
- case "six-icon":
245
- if (!customElements.get(tagName)) {
246
- defineCustomElement$2();
247
- }
248
- break;
249
- case "six-menu-item":
250
- if (!customElements.get(tagName)) {
251
- defineCustomElement$1();
252
- }
253
- break;
254
- } });
240
+ if (typeof customElements === "undefined") {
241
+ return;
242
+ }
243
+ const components = ["six-menu", "six-checkbox", "six-error", "six-icon", "six-menu-item"];
244
+ components.forEach(tagName => { switch (tagName) {
245
+ case "six-menu":
246
+ if (!customElements.get(tagName)) {
247
+ customElements.define(tagName, SixMenu);
248
+ }
249
+ break;
250
+ case "six-checkbox":
251
+ if (!customElements.get(tagName)) {
252
+ defineCustomElement$4();
253
+ }
254
+ break;
255
+ case "six-error":
256
+ if (!customElements.get(tagName)) {
257
+ defineCustomElement$3();
258
+ }
259
+ break;
260
+ case "six-icon":
261
+ if (!customElements.get(tagName)) {
262
+ defineCustomElement$2();
263
+ }
264
+ break;
265
+ case "six-menu-item":
266
+ if (!customElements.get(tagName)) {
267
+ defineCustomElement$1();
268
+ }
269
+ break;
270
+ } });
255
271
  }
256
272
 
257
273
  export { SixMenu as S, defineCustomElement as d };
@@ -1 +1 @@
1
- {"file":"six-menu2.js","mappings":"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","names":[],"sources":["./src/components/six-menu/six-menu.scss?tag=six-menu&encapsulation=shadow","./src/components/six-menu/six-menu.tsx"],"sourcesContent":["@import 'src/global/component';\n\n:host {\n display: block;\n}\n\n.menu {\n padding: 0 0;\n border: none;\n box-shadow: var(--six-elevation-2dp);\n\n &:focus {\n outline: none;\n }\n\n &--noshadow {\n box-shadow: none;\n }\n\n &__wrapper {\n &--scrollable {\n overflow-y: auto;\n }\n }\n}\n","import { Component, Element, Event, EventEmitter, h, Method, Prop, State } from '@stencil/core';\nimport { getTextContent } from '../../utils/slot';\nimport { StyleDeclaration } from '../../utils/types';\nimport { EventListeners } from '../../utils/event-listeners';\nimport { debounce } from '../../utils/execution-control';\n\nexport interface SixMenuItemData {\n label: string;\n value: string;\n}\n\nexport interface SixMenuItemSelectedPayload {\n name: string;\n item: HTMLSixMenuItemElement;\n}\n\nconst isFocusedMenuItem = (menuItem: HTMLSixMenuItemElement) =>\n menuItem?.shadowRoot?.querySelector('.menu-item')?.classList?.contains('menu-item--focused');\n\nconst isSIXMenuItemElement = (el?: Element): el is HTMLSixMenuItemElement =>\n el?.tagName.toLowerCase() === 'six-menu-item';\n\nconst mapToMenuItem = ({ value, label }: SixMenuItemData) => <six-menu-item value={value}>{label}</six-menu-item>;\n\nconst DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING = 5;\n\nconst DEFAULT_SIX_MENU_ITEM_HEIGHT = 64;\n\n/**\n * @since 1.0\n * @status stable\n *\n * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.\n *\n * @slot - The menu's content, including menu items, menu dividers, and menu labels.\n *\n * @part base - The component's base wrapper.\n */\n@Component({\n tag: 'six-menu',\n styleUrl: 'six-menu.scss',\n shadow: true,\n})\nexport class SixMenu {\n private readonly eventListeners = new EventListeners();\n\n private menu?: HTMLElement;\n private menuWrapper?: HTMLElement;\n private typeToSelectString = '';\n private typeToSelectTimeout?: number;\n\n @Element() host!: HTMLSixMenuElement;\n\n /** Emitted when a menu item is selected. */\n @Event({ eventName: 'six-menu-item-selected' }) sixMenuItemSelected!: EventEmitter<SixMenuItemSelectedPayload>;\n\n /** Set to true to remove the box-shadow */\n @Prop() removeBoxShadow = false;\n\n /** Set the options to be shown in the dropdown */\n @Prop() items: SixMenuItemData[] | null = null;\n\n /** Defines how many items should be shown. If the number of items is larger than this property a scrollbar will be shown */\n @Prop() itemsShown?: number;\n\n /** Defines whether the menu list will be rendered virtually i.e. only the elements actually shown (and a couple around)\n * are actually rendered in the DOM. If you use virtual scrolling pass the elements via prop instead of via slot. */\n @Prop() virtualScroll = false;\n\n /**\n * Used for virtual scrolling\n * Define how many items should be rendered in the DOM when using virtual scrolling\n */\n @Prop() itemSize = 10;\n\n /**\n * Used for virtual scrolling\n * Define the debounce for listening on scrolling changes in milliseconds.\n * The lower the number the more sensitive the component reacts to scrolling changes.\n */\n @Prop() scrollingDebounce = 15;\n\n /**\n * Used to calculate which items should be rendered in the DOM\n */\n @State()\n private scrollingIndex = 0;\n\n // set a default item height, this variable will be updated with the real value after the first render.\n // However, it's necessary to have a default value because we can only fetch the proper height after the first render\n @State()\n sixMenuItemHeight = DEFAULT_SIX_MENU_ITEM_HEIGHT;\n\n connectedCallback() {\n this.handleClick = this.handleClick.bind(this);\n this.handleKeyDown = this.handleKeyDown.bind(this);\n }\n\n componentWillLoad() {\n if (this.items === null) {\n return;\n }\n }\n\n private handleScrolling = () => {\n if (this.menuWrapper == null) return;\n // for performance improvements we only update the DOM if the scrollRatio change \"enough\"\n this.scrollingIndex = Math.floor(this.menuWrapper.scrollTop / this.sixMenuItemHeight);\n };\n\n componentDidLoad() {\n this.setupForVirtualScrollingAfterRendering();\n }\n\n disconnectedCallback() {\n this.eventListeners.removeAll();\n }\n\n /**\n * Initiates type-to-select logic, which automatically selects an option based on what the user is currently typing.\n * The key passed will be appended to the internal query and the selection will be updated. After a brief period, the\n * internal query is cleared automatically. This method is intended to be used with the keydown event. Useful for\n * enabling type-to-select when the menu doesn't have focus.\n */\n @Method()\n async typeToSelect(key: string) {\n clearTimeout(this.typeToSelectTimeout);\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n this.typeToSelectTimeout = setTimeout(() => (this.typeToSelectString = ''), 750);\n this.typeToSelectString += key.toLowerCase();\n const items = this.getItems();\n for (const item of items) {\n const slot = item.shadowRoot?.querySelector('slot:not([name])') as HTMLSlotElement;\n const label = getTextContent(slot).toLowerCase().trim();\n if (label.substring(0, this.typeToSelectString.length) === this.typeToSelectString) {\n item.setFocus();\n break;\n }\n }\n }\n\n private getItemsShown(): number {\n const defaultItemsShown = this.virtualScroll ? DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING : 0;\n return this.itemsShown ?? defaultItemsShown;\n }\n\n private setupForVirtualScrollingAfterRendering() {\n if (!this.virtualScroll || this.menuWrapper == null) return;\n\n this.eventListeners.add(this.menuWrapper, 'scroll', debounce(this.handleScrolling, this.scrollingDebounce));\n\n // set menu height to proper height once the item is rendered.\n const menuItemHeight = this.menu?.querySelector('six-menu-item')?.clientHeight;\n if (menuItemHeight != null && menuItemHeight > 0) {\n this.sixMenuItemHeight = menuItemHeight;\n }\n }\n\n private getItems(): HTMLSixMenuItemElement[] {\n if (this.menu == null) return [];\n\n if (this.items != null) {\n return this.items.map(mapToMenuItem);\n }\n\n const slot = this.menu.querySelector('slot');\n if (slot == null) return [];\n return [...slot.assignedElements({ flatten: true })].filter(\n (el): el is HTMLSixMenuItemElement => isSIXMenuItemElement(el) && !el.disabled\n );\n }\n\n private getActiveItemIndex() {\n const items = this.getItems();\n const selectedItem = this.getActiveItem();\n if (selectedItem != null) {\n const itemIndex = items.indexOf(selectedItem);\n if (itemIndex > -1) {\n return itemIndex;\n }\n }\n const sixMenuItems = this.extractItemsFromDOM();\n return sixMenuItems.findIndex(isFocusedMenuItem);\n }\n\n private getActiveItem(): HTMLSixMenuItemElement | undefined {\n const activeElement = this.getItems().find((i) => i === document.activeElement);\n if (activeElement != null) {\n return activeElement;\n }\n return this.extractItemsFromDOM()?.find(isFocusedMenuItem);\n }\n\n private extractItemsFromDOM() {\n return Array.from(this.host.shadowRoot?.querySelectorAll('six-menu-item') ?? []);\n }\n\n private setActiveItem(item: HTMLSixMenuItemElement) {\n item?.setFocus();\n }\n\n private handleClick(event: MouseEvent) {\n const target = event.target as HTMLElement;\n const clickedItem = target.closest('six-menu-item');\n if (clickedItem && !clickedItem.disabled) {\n this.sixMenuItemSelected.emit({ name: clickedItem.value, item: clickedItem });\n }\n }\n\n private handleKeyDown(event: KeyboardEvent) {\n // Make a selection when pressing enter\n if (event.key === 'Enter') {\n const activeItem = this.getActiveItem();\n event.preventDefault();\n\n if (activeItem != null) {\n this.sixMenuItemSelected.emit({ name: activeItem.value, item: activeItem });\n }\n }\n\n // Prevent scrolling when space is pressed\n if (event.key === ' ') {\n event.preventDefault();\n }\n\n // Move the selection when pressing down or up\n if (['ArrowDown', 'ArrowUp', 'Home', 'End'].includes(event.key)) {\n const items = this.items === null ? this.getItems() : this.extractItemsFromDOM();\n\n let indexOfActiveItem = this.getActiveItemIndex();\n\n if (items.length > 0) {\n event.preventDefault();\n\n if (event.key === 'ArrowDown') {\n indexOfActiveItem++;\n } else if (event.key === 'ArrowUp') {\n indexOfActiveItem--;\n } else if (event.key === 'Home') {\n indexOfActiveItem = 0;\n } else if (event.key === 'End') {\n indexOfActiveItem = items.length - 1;\n }\n\n if (indexOfActiveItem < 0) indexOfActiveItem = 0;\n if (indexOfActiveItem > items.length - 1) indexOfActiveItem = items.length - 1;\n\n this.setActiveItem(items[indexOfActiveItem]);\n\n return;\n }\n }\n\n void this.typeToSelect(event.key);\n }\n\n private getMenuWrapperStyle() {\n const styles: Partial<StyleDeclaration> = {};\n if (this.getItemsShown() > 0) {\n // calculate the proper height to show the correct number of items\n styles.height = `${(this.getItemsShown() ?? 0) * this.sixMenuItemHeight}px`;\n }\n return {\n ...styles,\n };\n }\n\n private getMenuContainerStyle() {\n const styles: Partial<StyleDeclaration> = {};\n\n if (this.virtualScroll) {\n // calculate height of content are if all items would be rendered so the scrollbar has the proper size\n styles.transform = `translateY(${this.sixMenuItemHeight * this.scrollingIndex}px)`;\n }\n\n return {\n ...styles,\n };\n }\n\n private getScrollbarGhostStyle() {\n const styles: Partial<StyleDeclaration> = {};\n\n if (this.virtualScroll && this.items !== null) {\n styles.height = `${this.items.length * this.sixMenuItemHeight - this.itemSize * this.sixMenuItemHeight}px`;\n }\n\n return {\n ...styles,\n };\n }\n\n private renderItems() {\n if (this.items === undefined || this.items === null) {\n return;\n }\n\n if (!this.virtualScroll) {\n return this.items.map(mapToMenuItem);\n }\n\n return this.items\n .slice(this.scrollingIndex, Math.min(this.items.length, this.itemSize + this.scrollingIndex))\n .map(mapToMenuItem);\n }\n\n render() {\n return (\n <div\n ref={(el) => (this.menuWrapper = el)}\n style={this.getMenuWrapperStyle()}\n part=\"wrapper\"\n class={{\n menu: true,\n 'menu--noshadow': this.removeBoxShadow,\n 'menu__wrapper--scrollable': this.getItemsShown() > 0,\n }}\n >\n <div\n ref={(el) => (this.menu = el)}\n part=\"base\"\n role=\"menu\"\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n tabIndex={0}\n style={this.getMenuContainerStyle()}\n >\n <slot />\n {this.renderItems()}\n </div>\n {this.virtualScroll && <div style={this.getScrollbarGhostStyle()} />}\n </div>\n );\n }\n}\n"],"version":3}
1
+ {"file":"six-menu2.js","mappings":"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","names":[],"sources":["src/components/six-menu/six-menu.scss?tag=six-menu&encapsulation=shadow","src/components/six-menu/six-menu.tsx"],"sourcesContent":["@import 'src/global/component';\n\n:host {\n display: block;\n}\n\n.menu {\n padding: var(--six-spacing-xx-small) 0;\n border: none;\n box-shadow: var(--six-shadow-small);\n overflow-y: auto;\n overflow-x: hidden;\n}\n\n.menu:focus {\n outline: none;\n}\n\n.no-shadow {\n box-shadow: none;\n}\n","import { Component, Element, Event, EventEmitter, h, Method, Prop, State } from '@stencil/core';\nimport { getTextContent } from '../../utils/slot';\nimport { StyleDeclaration } from '../../utils/types';\nimport { EventListeners } from '../../utils/event-listeners';\nimport { debounce } from '../../utils/execution-control';\n\nexport interface SixMenuItemData {\n label: string;\n value: string;\n}\n\nexport interface SixMenuItemSelectedPayload {\n name: string;\n item: HTMLSixMenuItemElement;\n}\n\nconst isFocusedMenuItem = (menuItem: HTMLSixMenuItemElement) =>\n menuItem?.shadowRoot?.querySelector('.menu-item')?.classList?.contains('menu-item--focused');\n\nconst isSIXMenuItemElement = (el?: Element): el is HTMLSixMenuItemElement =>\n el?.tagName.toLowerCase() === 'six-menu-item';\n\nconst mapToMenuItem = ({ value, label }: SixMenuItemData) => (\n <six-menu-item key={value} value={value}>\n {label}\n </six-menu-item>\n);\n\nconst DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING = 5;\n\nconst DEFAULT_SIX_MENU_ITEM_HEIGHT = 64;\n\n/**\n * @since 1.0\n * @status stable\n *\n * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.\n *\n * @slot - The menu's content, including menu items, menu dividers, and menu labels.\n *\n * @part base - The component's base wrapper.\n */\n@Component({\n tag: 'six-menu',\n styleUrl: 'six-menu.scss',\n shadow: true,\n})\nexport class SixMenu {\n private readonly eventListeners = new EventListeners();\n\n private menu?: HTMLElement;\n private menuWrapper?: HTMLElement;\n private typeToSelectString = '';\n private typeToSelectTimeout?: number;\n\n @Element() host!: HTMLSixMenuElement;\n\n /** Emitted when a menu item is selected. */\n @Event({ eventName: 'six-menu-item-selected' }) sixMenuItemSelected!: EventEmitter<SixMenuItemSelectedPayload>;\n\n /** Set to true to remove the box-shadow */\n @Prop() removeBoxShadow = false;\n\n /** Set the options to be shown in the dropdown */\n @Prop() items: SixMenuItemData[] | null = null;\n\n /** Defines how many items should be shown. If the number of items is larger than this property a scrollbar will be shown */\n @Prop() itemsShown?: number;\n\n /** Defines whether the menu list will be rendered virtually i.e. only the elements actually shown (and a couple around)\n * are actually rendered in the DOM. If you use virtual scrolling pass the elements via prop instead of via slot. */\n @Prop() virtualScroll = false;\n\n /**\n * Used for virtual scrolling\n * Define how many items should be rendered in the DOM when using virtual scrolling\n */\n @Prop() itemSize = 10;\n\n /**\n * Used for virtual scrolling\n * Define the debounce for listening on scrolling changes in milliseconds.\n * The lower the number the more sensitive the component reacts to scrolling changes.\n */\n @Prop() scrollingDebounce = 15;\n\n /**\n * Internal: Disables handling of key presses.\n */\n @Prop() disableKeyboardHandling = false;\n\n /**\n * Used to calculate which items should be rendered in the DOM\n */\n @State()\n private scrollingIndex = 0;\n\n // set a default item height, this variable will be updated with the real value after the first render.\n // However, it's necessary to have a default value because we can only fetch the proper height after the first render\n @State()\n sixMenuItemHeight = DEFAULT_SIX_MENU_ITEM_HEIGHT;\n\n connectedCallback() {\n this.handleClick = this.handleClick.bind(this);\n this.handleKeyDown = this.handleKeyDown.bind(this);\n }\n\n componentWillLoad() {\n if (this.items === null) {\n return;\n }\n }\n\n private handleScrolling = () => {\n if (this.menuWrapper == null) return;\n // for performance improvements we only update the DOM if the scrollRatio change \"enough\"\n this.scrollingIndex = Math.floor(this.menuWrapper.scrollTop / this.sixMenuItemHeight);\n };\n\n componentDidLoad() {\n this.setupForVirtualScrollingAfterRendering();\n }\n\n disconnectedCallback() {\n this.eventListeners.removeAll();\n }\n\n /**\n * Initiates type-to-select logic, which automatically selects an option based on what the user is currently typing.\n * The key passed will be appended to the internal query and the selection will be updated. After a brief period, the\n * internal query is cleared automatically. This method is intended to be used with the keydown event. Useful for\n * enabling type-to-select when the menu doesn't have focus.\n */\n @Method()\n async typeToSelect(key: string) {\n clearTimeout(this.typeToSelectTimeout);\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n this.typeToSelectTimeout = setTimeout(() => (this.typeToSelectString = ''), 750);\n this.typeToSelectString += key.toLowerCase();\n const items = this.getItems();\n for (const item of items) {\n const slot = item.shadowRoot?.querySelector('slot:not([name])') as HTMLSlotElement;\n const label = getTextContent(slot).toLowerCase().trim();\n if (label.substring(0, this.typeToSelectString.length) === this.typeToSelectString) {\n item.setFocus();\n break;\n }\n }\n }\n\n private getItemsShown(): number {\n const defaultItemsShown = this.virtualScroll ? DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING : 0;\n return this.itemsShown ?? defaultItemsShown;\n }\n\n private setupForVirtualScrollingAfterRendering() {\n if (!this.virtualScroll || this.menuWrapper == null) return;\n\n this.eventListeners.add(this.menuWrapper, 'scroll', debounce(this.handleScrolling, this.scrollingDebounce));\n\n // set menu height to proper height once the item is rendered.\n const menuItemHeight = this.menu?.querySelector('six-menu-item')?.clientHeight;\n if (menuItemHeight != null && menuItemHeight > 0) {\n this.sixMenuItemHeight = menuItemHeight;\n }\n }\n\n private getItems(): HTMLSixMenuItemElement[] {\n if (this.menu == null) return [];\n\n if (this.items != null) {\n return this.items.map(mapToMenuItem);\n }\n\n const slot = this.menu.querySelector('slot');\n if (slot == null) return [];\n return [...slot.assignedElements({ flatten: true })].filter(\n (el): el is HTMLSixMenuItemElement => isSIXMenuItemElement(el) && !el.disabled\n );\n }\n\n private getActiveItemIndex() {\n const items = this.getItems();\n const selectedItem = this.getActiveItem();\n if (selectedItem != null) {\n const itemIndex = items.indexOf(selectedItem);\n if (itemIndex > -1) {\n return itemIndex;\n }\n }\n const sixMenuItems = this.extractItemsFromDOM();\n return sixMenuItems.findIndex(isFocusedMenuItem);\n }\n\n private getActiveItem(): HTMLSixMenuItemElement | undefined {\n const activeElement = this.getItems().find((i) => i === document.activeElement);\n if (activeElement != null) {\n return activeElement;\n }\n return this.extractItemsFromDOM()?.find(isFocusedMenuItem);\n }\n\n private extractItemsFromDOM() {\n return Array.from(this.host.shadowRoot?.querySelectorAll('six-menu-item') ?? []);\n }\n\n private setActiveItem(item: HTMLSixMenuItemElement) {\n item?.setFocus();\n }\n\n private handleClick(event: MouseEvent) {\n const target = event.target as HTMLElement;\n const clickedItem = target.closest('six-menu-item');\n if (clickedItem && !clickedItem.disabled) {\n this.sixMenuItemSelected.emit({ name: clickedItem.value, item: clickedItem });\n }\n }\n\n private handleKeyDown(event: KeyboardEvent) {\n if (this.disableKeyboardHandling) {\n return;\n }\n\n // Make a selection when pressing enter\n if (event.key === 'Enter') {\n const activeItem = this.getActiveItem();\n event.preventDefault();\n\n if (activeItem != null) {\n this.sixMenuItemSelected.emit({ name: activeItem.value, item: activeItem });\n }\n }\n\n // Prevent scrolling when space is pressed\n if (event.key === ' ') {\n event.preventDefault();\n }\n\n // Move the selection when pressing down or up\n if (['ArrowDown', 'ArrowUp', 'Home', 'End'].includes(event.key)) {\n const items = this.items === null ? this.getItems() : this.extractItemsFromDOM();\n\n let indexOfActiveItem = this.getActiveItemIndex();\n\n if (items.length > 0) {\n event.preventDefault();\n\n if (event.key === 'ArrowDown') {\n indexOfActiveItem++;\n } else if (event.key === 'ArrowUp') {\n indexOfActiveItem--;\n } else if (event.key === 'Home') {\n indexOfActiveItem = 0;\n } else if (event.key === 'End') {\n indexOfActiveItem = items.length - 1;\n }\n\n if (indexOfActiveItem < 0) indexOfActiveItem = 0;\n if (indexOfActiveItem > items.length - 1) indexOfActiveItem = items.length - 1;\n\n this.setActiveItem(items[indexOfActiveItem]);\n\n return;\n }\n }\n\n void this.typeToSelect(event.key);\n }\n\n private getMenuWrapperStyle() {\n const styles: Partial<StyleDeclaration> = {};\n if (this.getItemsShown() > 0) {\n // calculate the proper height to show the correct number of items\n styles.height = `${(this.getItemsShown() ?? 0) * this.sixMenuItemHeight}px`;\n }\n return {\n ...styles,\n };\n }\n\n private getMenuContainerStyle() {\n const styles: Partial<StyleDeclaration> = {};\n\n if (this.virtualScroll) {\n // calculate height of content are if all items would be rendered so the scrollbar has the proper size\n styles.transform = `translateY(${this.sixMenuItemHeight * this.scrollingIndex}px)`;\n }\n\n return {\n ...styles,\n };\n }\n\n private getScrollbarGhostStyle() {\n const styles: Partial<StyleDeclaration> = {};\n\n if (this.virtualScroll && this.items !== null) {\n styles.height = `${this.items.length * this.sixMenuItemHeight - this.itemSize * this.sixMenuItemHeight}px`;\n }\n\n return {\n ...styles,\n };\n }\n\n private renderItems() {\n if (this.items === undefined || this.items === null) {\n return;\n }\n\n if (!this.virtualScroll) {\n return this.items.map(mapToMenuItem);\n }\n\n return this.items\n .slice(this.scrollingIndex, Math.min(this.items.length, this.itemSize + this.scrollingIndex))\n .map(({ value, label }: SixMenuItemData) => (\n <six-menu-item checkType=\"check\" key={value} value={value}>\n {label}\n </six-menu-item>\n ));\n }\n\n render() {\n return (\n <div\n ref={(el) => (this.menuWrapper = el)}\n style={this.getMenuWrapperStyle()}\n part=\"wrapper\"\n class={{\n menu: true,\n '.no-shadow': this.removeBoxShadow,\n }}\n >\n <div\n ref={(el) => (this.menu = el)}\n part=\"base\"\n role=\"menu\"\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n tabIndex={0}\n style={this.getMenuContainerStyle()}\n >\n <slot />\n {this.renderItems()}\n </div>\n {this.virtualScroll && <div style={this.getScrollbarGhostStyle()} />}\n </div>\n );\n }\n}\n"],"version":3}
@@ -2,8 +2,8 @@ import type { Components, JSX } from "../types/components";
2
2
 
3
3
  interface SixPicto extends Components.SixPicto, HTMLElement {}
4
4
  export const SixPicto: {
5
- prototype: SixPicto;
6
- new (): SixPicto;
5
+ prototype: SixPicto;
6
+ new (): SixPicto;
7
7
  };
8
8
  /**
9
9
  * Used to define this component and all nested components recursively.