@six-group/ui-library 4.0.0-beta.1 → 4.0.0-beta.2

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 (973) hide show
  1. package/dist/cjs/event-listeners-fdfe838c.js +61 -0
  2. package/dist/cjs/event-listeners-fdfe838c.js.map +1 -0
  3. package/dist/cjs/{execution-control-46f388e0.js → execution-control-b4707294.js} +6 -3
  4. package/dist/cjs/execution-control-b4707294.js.map +1 -0
  5. package/dist/cjs/{focus-visible-0b352c74.js → focus-visible-ae2470dd.js} +3 -3
  6. package/dist/cjs/focus-visible-ae2470dd.js.map +1 -0
  7. package/dist/cjs/form-2df8c5bb.js +20 -0
  8. package/dist/cjs/form-2df8c5bb.js.map +1 -0
  9. package/dist/cjs/{form-control-2c17c573.js → form-control-d369af14.js} +10 -11
  10. package/dist/cjs/form-control-d369af14.js.map +1 -0
  11. package/dist/cjs/{index-2f6daa5b.js → index-900437fc.js} +186 -53
  12. package/dist/cjs/index-900437fc.js.map +1 -0
  13. package/dist/cjs/index.cjs.js +94 -0
  14. package/dist/cjs/index.cjs.js.map +1 -1
  15. package/dist/cjs/loader.cjs.js +3 -12
  16. package/dist/cjs/loader.cjs.js.map +1 -1
  17. package/dist/cjs/{modal-48d42228.js → modal-d5f074c7.js} +4 -3
  18. package/dist/cjs/modal-d5f074c7.js.map +1 -0
  19. package/dist/cjs/{popover-f743f62b.js → popover-2df7e154.js} +39 -31
  20. package/dist/cjs/popover-2df7e154.js.map +1 -0
  21. package/dist/cjs/popup-f1d9910f.js +103 -0
  22. package/dist/cjs/popup-f1d9910f.js.map +1 -0
  23. package/dist/cjs/{scroll-76e6f5d7.js → scroll-03678de1.js} +1 -1
  24. package/dist/cjs/scroll-03678de1.js.map +1 -0
  25. package/dist/cjs/set-attributes_2.cjs.entry.js +4 -2
  26. package/dist/cjs/set-attributes_2.cjs.entry.js.map +1 -1
  27. package/dist/cjs/six-alert.cjs.entry.js +18 -23
  28. package/dist/cjs/six-alert.cjs.entry.js.map +1 -1
  29. package/dist/cjs/six-avatar.cjs.entry.js +5 -8
  30. package/dist/cjs/six-avatar.cjs.entry.js.map +1 -1
  31. package/dist/cjs/six-badge.cjs.entry.js +2 -2
  32. package/dist/cjs/six-badge.cjs.entry.js.map +1 -1
  33. package/dist/cjs/six-button.cjs.entry.js +36 -34
  34. package/dist/cjs/six-button.cjs.entry.js.map +1 -1
  35. package/dist/cjs/six-card.cjs.entry.js +1 -1
  36. package/dist/cjs/six-card.cjs.entry.js.map +1 -1
  37. package/dist/cjs/six-checkbox.cjs.entry.js +50 -85
  38. package/dist/cjs/six-checkbox.cjs.entry.js.map +1 -1
  39. package/dist/cjs/six-datepicker.cjs.entry.js +154 -280
  40. package/dist/cjs/six-datepicker.cjs.entry.js.map +1 -1
  41. package/dist/cjs/six-details.cjs.entry.js +48 -47
  42. package/dist/cjs/six-details.cjs.entry.js.map +1 -1
  43. package/dist/cjs/six-dialog.cjs.entry.js +37 -41
  44. package/dist/cjs/six-dialog.cjs.entry.js.map +1 -1
  45. package/dist/cjs/six-drawer.cjs.entry.js +34 -38
  46. package/dist/cjs/six-drawer.cjs.entry.js.map +1 -1
  47. package/dist/cjs/six-dropdown_2.cjs.entry.js +215 -196
  48. package/dist/cjs/six-dropdown_2.cjs.entry.js.map +1 -1
  49. package/dist/cjs/six-error-page.cjs.entry.js +20 -22
  50. package/dist/cjs/six-error-page.cjs.entry.js.map +1 -1
  51. package/dist/cjs/six-file-list-item.cjs.entry.js +2 -2
  52. package/dist/cjs/six-file-list-item.cjs.entry.js.map +1 -1
  53. package/dist/cjs/six-file-list.cjs.entry.js +1 -1
  54. package/dist/cjs/six-file-list.cjs.entry.js.map +1 -1
  55. package/dist/cjs/six-file-upload.cjs.entry.js +21 -21
  56. package/dist/cjs/six-file-upload.cjs.entry.js.map +1 -1
  57. package/dist/cjs/six-footer.cjs.entry.js +1 -1
  58. package/dist/cjs/six-footer.cjs.entry.js.map +1 -1
  59. package/dist/cjs/six-group-label.cjs.entry.js +12 -11
  60. package/dist/cjs/six-group-label.cjs.entry.js.map +1 -1
  61. package/dist/cjs/six-header.cjs.entry.js +66 -44
  62. package/dist/cjs/six-header.cjs.entry.js.map +1 -1
  63. package/dist/cjs/six-icon-button.cjs.entry.js +4 -4
  64. package/dist/cjs/six-icon-button.cjs.entry.js.map +1 -1
  65. package/dist/cjs/six-icon.cjs.entry.js +1 -1
  66. package/dist/cjs/six-icon.cjs.entry.js.map +1 -1
  67. package/dist/cjs/six-input.cjs.entry.js +95 -128
  68. package/dist/cjs/six-input.cjs.entry.js.map +1 -1
  69. package/dist/cjs/six-item-picker.cjs.entry.js +62 -81
  70. package/dist/cjs/six-item-picker.cjs.entry.js.map +1 -1
  71. package/dist/cjs/six-language-switcher.cjs.entry.js +2 -2
  72. package/dist/cjs/six-language-switcher.cjs.entry.js.map +1 -1
  73. package/dist/cjs/six-layout-grid.cjs.entry.js +5 -3
  74. package/dist/cjs/six-layout-grid.cjs.entry.js.map +1 -1
  75. package/dist/cjs/six-main-container.cjs.entry.js +1 -1
  76. package/dist/cjs/six-main-container.cjs.entry.js.map +1 -1
  77. package/dist/cjs/six-menu-divider.cjs.entry.js +1 -1
  78. package/dist/cjs/six-menu-divider.cjs.entry.js.map +1 -1
  79. package/dist/cjs/six-menu-item.cjs.entry.js +9 -7
  80. package/dist/cjs/six-menu-item.cjs.entry.js.map +1 -1
  81. package/dist/cjs/six-menu-label.cjs.entry.js +1 -1
  82. package/dist/cjs/six-menu-label.cjs.entry.js.map +1 -1
  83. package/dist/cjs/six-picto.cjs.entry.js +5 -2
  84. package/dist/cjs/six-picto.cjs.entry.js.map +1 -1
  85. package/dist/cjs/six-progress-bar.cjs.entry.js +1 -1
  86. package/dist/cjs/six-progress-bar.cjs.entry.js.map +1 -1
  87. package/dist/cjs/six-progress-ring.cjs.entry.js +4 -4
  88. package/dist/cjs/six-progress-ring.cjs.entry.js.map +1 -1
  89. package/dist/cjs/six-radio.cjs.entry.js +63 -72
  90. package/dist/cjs/six-radio.cjs.entry.js.map +1 -1
  91. package/dist/cjs/six-range.cjs.entry.js +107 -106
  92. package/dist/cjs/six-range.cjs.entry.js.map +1 -1
  93. package/dist/cjs/six-root.cjs.entry.js +2 -2
  94. package/dist/cjs/six-root.cjs.entry.js.map +1 -1
  95. package/dist/cjs/six-search-field.cjs.entry.js +11 -6
  96. package/dist/cjs/six-search-field.cjs.entry.js.map +1 -1
  97. package/dist/cjs/six-select.cjs.entry.js +190 -223
  98. package/dist/cjs/six-select.cjs.entry.js.map +1 -1
  99. package/dist/cjs/six-sidebar-item-group.cjs.entry.js +10 -6
  100. package/dist/cjs/six-sidebar-item-group.cjs.entry.js.map +1 -1
  101. package/dist/cjs/six-sidebar-item.cjs.entry.js +1 -1
  102. package/dist/cjs/six-sidebar-item.cjs.entry.js.map +1 -1
  103. package/dist/cjs/six-sidebar.cjs.entry.js +41 -20
  104. package/dist/cjs/six-sidebar.cjs.entry.js.map +1 -1
  105. package/dist/cjs/six-spinner.cjs.entry.js +1 -1
  106. package/dist/cjs/six-spinner.cjs.entry.js.map +1 -1
  107. package/dist/cjs/six-switch.cjs.entry.js +58 -64
  108. package/dist/cjs/six-switch.cjs.entry.js.map +1 -1
  109. package/dist/cjs/six-tab-group.cjs.entry.js +132 -114
  110. package/dist/cjs/six-tab-group.cjs.entry.js.map +1 -1
  111. package/dist/cjs/six-tab-panel.cjs.entry.js +2 -2
  112. package/dist/cjs/six-tab-panel.cjs.entry.js.map +1 -1
  113. package/dist/cjs/six-tab.cjs.entry.js +5 -3
  114. package/dist/cjs/six-tab.cjs.entry.js.map +1 -1
  115. package/dist/cjs/six-tag.cjs.entry.js +6 -9
  116. package/dist/cjs/six-tag.cjs.entry.js.map +1 -1
  117. package/dist/cjs/six-textarea.cjs.entry.js +82 -108
  118. package/dist/cjs/six-textarea.cjs.entry.js.map +1 -1
  119. package/dist/cjs/six-tile.cjs.entry.js +14 -17
  120. package/dist/cjs/six-tile.cjs.entry.js.map +1 -1
  121. package/dist/cjs/six-timepicker.cjs.entry.js +159 -215
  122. package/dist/cjs/six-timepicker.cjs.entry.js.map +1 -1
  123. package/dist/cjs/six-tooltip.cjs.entry.js +54 -57
  124. package/dist/cjs/six-tooltip.cjs.entry.js.map +1 -1
  125. package/dist/cjs/{slot-ad537f24.js → slot-6e6a400f.js} +11 -10
  126. package/dist/cjs/slot-6e6a400f.js.map +1 -0
  127. package/dist/cjs/{types-64878648.js → types-47199040.js} +1 -1
  128. package/dist/cjs/types-47199040.js.map +1 -0
  129. package/dist/cjs/ui-library.cjs.js +3 -6
  130. package/dist/cjs/ui-library.cjs.js.map +1 -1
  131. package/dist/collection/collection-manifest.json +54 -55
  132. package/dist/collection/components/six-alert/six-alert.js +32 -30
  133. package/dist/collection/components/six-alert/six-alert.js.map +1 -1
  134. package/dist/collection/components/six-alert/test/six-alert.spec.js +25 -0
  135. package/dist/collection/components/six-alert/test/six-alert.spec.js.map +1 -0
  136. package/dist/collection/components/six-avatar/six-avatar.js +5 -8
  137. package/dist/collection/components/six-avatar/six-avatar.js.map +1 -1
  138. package/dist/collection/components/six-avatar/test/six-avatar.spec.js +26 -0
  139. package/dist/collection/components/six-avatar/test/six-avatar.spec.js.map +1 -0
  140. package/dist/collection/components/six-badge/six-badge.js +2 -2
  141. package/dist/collection/components/six-badge/six-badge.js.map +1 -1
  142. package/dist/collection/components/six-badge/test/six-badge.spec.js +20 -0
  143. package/dist/collection/components/six-badge/test/six-badge.spec.js.map +1 -0
  144. package/dist/collection/components/six-button/six-button.js +56 -47
  145. package/dist/collection/components/six-button/six-button.js.map +1 -1
  146. package/dist/collection/components/six-button/test/six-button.spec.js +69 -0
  147. package/dist/collection/components/six-button/test/six-button.spec.js.map +1 -0
  148. package/dist/collection/components/six-card/six-card.js +1 -1
  149. package/dist/collection/components/six-card/six-card.js.map +1 -1
  150. package/dist/collection/components/six-card/test/six-card.spec.js +18 -0
  151. package/dist/collection/components/six-card/test/six-card.spec.js.map +1 -0
  152. package/dist/collection/components/six-checkbox/six-checkbox.js +81 -194
  153. package/dist/collection/components/six-checkbox/six-checkbox.js.map +1 -1
  154. package/dist/collection/components/six-checkbox/test/six-checkbox.spec.js +79 -0
  155. package/dist/collection/components/six-checkbox/test/six-checkbox.spec.js.map +1 -0
  156. package/dist/collection/components/six-datepicker/components/day-selection.js +3 -3
  157. package/dist/collection/components/six-datepicker/components/day-selection.js.map +1 -1
  158. package/dist/collection/components/six-datepicker/components/month-selection.js +6 -5
  159. package/dist/collection/components/six-datepicker/components/month-selection.js.map +1 -1
  160. package/dist/collection/components/six-datepicker/components/year-selection.js +11 -8
  161. package/dist/collection/components/six-datepicker/components/year-selection.js.map +1 -1
  162. package/dist/collection/components/six-datepicker/six-datepicker.js +219 -395
  163. package/dist/collection/components/six-datepicker/six-datepicker.js.map +1 -1
  164. package/dist/collection/components/six-datepicker/test/six-datepicker.spec.js +26 -0
  165. package/dist/collection/components/six-datepicker/test/six-datepicker.spec.js.map +1 -0
  166. package/dist/collection/components/six-details/six-details.js +65 -58
  167. package/dist/collection/components/six-details/six-details.js.map +1 -1
  168. package/dist/collection/components/six-details/test/six-details.spec.js +36 -0
  169. package/dist/collection/components/six-details/test/six-details.spec.js.map +1 -0
  170. package/dist/collection/components/six-dialog/six-dialog.js +55 -51
  171. package/dist/collection/components/six-dialog/six-dialog.js.map +1 -1
  172. package/dist/collection/components/six-dialog/test/six-dialog.spec.js +34 -0
  173. package/dist/collection/components/six-dialog/test/six-dialog.spec.js.map +1 -0
  174. package/dist/collection/components/six-drawer/six-drawer.js +52 -48
  175. package/dist/collection/components/six-drawer/six-drawer.js.map +1 -1
  176. package/dist/collection/components/six-drawer/test/six-drawer.spec.js +34 -0
  177. package/dist/collection/components/six-drawer/test/six-drawer.spec.js.map +1 -0
  178. package/dist/collection/components/six-dropdown/six-dropdown.js +215 -191
  179. package/dist/collection/components/six-dropdown/six-dropdown.js.map +1 -1
  180. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js +122 -0
  181. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js.map +1 -0
  182. package/dist/collection/components/six-error-page/six-error-page.js +26 -28
  183. package/dist/collection/components/six-error-page/six-error-page.js.map +1 -1
  184. package/dist/collection/components/six-error-page/test/six-error-page.spec.js +240 -0
  185. package/dist/collection/components/six-error-page/test/six-error-page.spec.js.map +1 -0
  186. package/dist/collection/components/six-file-list/six-file-list.js +1 -1
  187. package/dist/collection/components/six-file-list/test/six-file-list.spec.js +67 -0
  188. package/dist/collection/components/six-file-list/test/six-file-list.spec.js.map +1 -0
  189. package/dist/collection/components/six-file-list-item/six-file-list-item.js +8 -6
  190. package/dist/collection/components/six-file-list-item/six-file-list-item.js.map +1 -1
  191. package/dist/collection/components/six-file-list-item/test/six-file-list-item.spec.js +169 -0
  192. package/dist/collection/components/six-file-list-item/test/six-file-list-item.spec.js.map +1 -0
  193. package/dist/collection/components/six-file-upload/six-file-upload.js +37 -35
  194. package/dist/collection/components/six-file-upload/six-file-upload.js.map +1 -1
  195. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js +103 -0
  196. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js.map +1 -0
  197. package/dist/collection/components/six-footer/six-footer.js +1 -1
  198. package/dist/collection/components/six-footer/test/six-footer.spec.js +21 -0
  199. package/dist/collection/components/six-footer/test/six-footer.spec.js.map +1 -0
  200. package/dist/collection/components/six-group-label/six-group-label.js +15 -13
  201. package/dist/collection/components/six-group-label/six-group-label.js.map +1 -1
  202. package/dist/collection/components/six-group-label/test/six-group-label.spec.js +43 -0
  203. package/dist/collection/components/six-group-label/test/six-group-label.spec.js.map +1 -0
  204. package/dist/collection/components/six-header/six-header.js +82 -52
  205. package/dist/collection/components/six-header/six-header.js.map +1 -1
  206. package/dist/collection/components/six-header/test/six-header.spec.js +133 -0
  207. package/dist/collection/components/six-header/test/six-header.spec.js.map +1 -0
  208. package/dist/collection/components/six-icon/six-icon.js +1 -1
  209. package/dist/collection/components/six-icon/test/six-icon.spec.js +20 -0
  210. package/dist/collection/components/six-icon/test/six-icon.spec.js.map +1 -0
  211. package/dist/collection/components/six-icon-button/six-icon-button.js +10 -10
  212. package/dist/collection/components/six-icon-button/six-icon-button.js.map +1 -1
  213. package/dist/collection/components/six-icon-button/test/six-icon-button.spec.js +23 -0
  214. package/dist/collection/components/six-icon-button/test/six-icon-button.spec.js.map +1 -0
  215. package/dist/collection/components/six-input/six-input.css +1 -1
  216. package/dist/collection/components/six-input/six-input.js +189 -362
  217. package/dist/collection/components/six-input/six-input.js.map +1 -1
  218. package/dist/collection/components/six-input/test/six-input.spec.js +37 -0
  219. package/dist/collection/components/six-input/test/six-input.spec.js.map +1 -0
  220. package/dist/collection/components/six-item-picker/six-item-picker.js +79 -94
  221. package/dist/collection/components/six-item-picker/six-item-picker.js.map +1 -1
  222. package/dist/collection/components/six-item-picker/test/six-item-picker.spec.js +90 -0
  223. package/dist/collection/components/six-item-picker/test/six-item-picker.spec.js.map +1 -0
  224. package/dist/collection/components/six-language-switcher/six-language-switcher.js +7 -5
  225. package/dist/collection/components/six-language-switcher/six-language-switcher.js.map +1 -1
  226. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js +196 -0
  227. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js.map +1 -0
  228. package/dist/collection/components/six-layout-grid/six-layout-grid.js +10 -8
  229. package/dist/collection/components/six-layout-grid/six-layout-grid.js.map +1 -1
  230. package/dist/collection/components/six-layout-grid/test/six-layout-grid.spec.js +18 -0
  231. package/dist/collection/components/six-layout-grid/test/six-layout-grid.spec.js.map +1 -0
  232. package/dist/collection/components/six-main-container/six-main-container.js +1 -1
  233. package/dist/collection/components/six-main-container/six-main-container.js.map +1 -1
  234. package/dist/collection/components/six-main-container/test/six-main-container.spec.js +22 -0
  235. package/dist/collection/components/six-main-container/test/six-main-container.spec.js.map +1 -0
  236. package/dist/collection/components/six-menu/six-menu.js +41 -31
  237. package/dist/collection/components/six-menu/six-menu.js.map +1 -1
  238. package/dist/collection/components/six-menu/test/six-menu.spec.js +93 -0
  239. package/dist/collection/components/six-menu/test/six-menu.spec.js.map +1 -0
  240. package/dist/collection/components/six-menu-divider/six-menu-divider.js +1 -1
  241. package/dist/collection/components/six-menu-divider/test/six-menu-divider.spec.js +18 -0
  242. package/dist/collection/components/six-menu-divider/test/six-menu-divider.spec.js.map +1 -0
  243. package/dist/collection/components/six-menu-item/six-menu-item.js +17 -11
  244. package/dist/collection/components/six-menu-item/six-menu-item.js.map +1 -1
  245. package/dist/collection/components/six-menu-item/test/six-menu-item.spec.js +33 -0
  246. package/dist/collection/components/six-menu-item/test/six-menu-item.spec.js.map +1 -0
  247. package/dist/collection/components/six-menu-label/six-menu-label.js +1 -1
  248. package/dist/collection/components/six-menu-label/test/six-menu-label.spec.js +20 -0
  249. package/dist/collection/components/six-menu-label/test/six-menu-label.spec.js.map +1 -0
  250. package/dist/collection/components/six-picto/six-picto.js +5 -2
  251. package/dist/collection/components/six-picto/six-picto.js.map +1 -1
  252. package/dist/collection/components/six-picto/test/six-picto.spec.js +33 -0
  253. package/dist/collection/components/six-picto/test/six-picto.spec.js.map +1 -0
  254. package/dist/collection/components/six-progress-bar/six-progress-bar.js +1 -1
  255. package/dist/collection/components/six-progress-bar/test/six-progress-bar.spec.js +24 -0
  256. package/dist/collection/components/six-progress-bar/test/six-progress-bar.spec.js.map +1 -0
  257. package/dist/collection/components/six-progress-ring/six-progress-ring.js +6 -5
  258. package/dist/collection/components/six-progress-ring/six-progress-ring.js.map +1 -1
  259. package/dist/collection/components/six-progress-ring/test/six-progress-ring.spec.js +26 -0
  260. package/dist/collection/components/six-progress-ring/test/six-progress-ring.spec.js.map +1 -0
  261. package/dist/collection/components/six-radio/six-radio.js +82 -148
  262. package/dist/collection/components/six-radio/six-radio.js.map +1 -1
  263. package/dist/collection/components/six-radio/test/six-radio.spec.js +63 -0
  264. package/dist/collection/components/six-radio/test/six-radio.spec.js.map +1 -0
  265. package/dist/collection/components/six-range/six-range.js +149 -190
  266. package/dist/collection/components/six-range/six-range.js.map +1 -1
  267. package/dist/collection/components/six-range/test/six-range.spec.js +32 -0
  268. package/dist/collection/components/six-range/test/six-range.spec.js.map +1 -0
  269. package/dist/collection/components/six-root/six-root.js +9 -7
  270. package/dist/collection/components/six-root/six-root.js.map +1 -1
  271. package/dist/collection/components/six-root/test/six-root.spec.js +43 -0
  272. package/dist/collection/components/six-root/test/six-root.spec.js.map +1 -0
  273. package/dist/collection/components/six-search-field/six-search-field.js +15 -9
  274. package/dist/collection/components/six-search-field/six-search-field.js.map +1 -1
  275. package/dist/collection/components/six-search-field/test/six-search-field.spec.js +22 -0
  276. package/dist/collection/components/six-search-field/test/six-search-field.spec.js.map +1 -0
  277. package/dist/collection/components/six-select/six-select.css +6 -9
  278. package/dist/collection/components/six-select/six-select.js +235 -349
  279. package/dist/collection/components/six-select/six-select.js.map +1 -1
  280. package/dist/collection/components/six-select/test/six-select.spec.js +82 -0
  281. package/dist/collection/components/six-select/test/six-select.spec.js.map +1 -0
  282. package/dist/collection/components/six-select/test/util.spec.js +81 -0
  283. package/dist/collection/components/six-select/test/util.spec.js.map +1 -0
  284. package/dist/collection/components/six-select/util.js +52 -0
  285. package/dist/collection/components/six-select/util.js.map +1 -0
  286. package/dist/collection/components/six-sidebar/six-sidebar.js +66 -33
  287. package/dist/collection/components/six-sidebar/six-sidebar.js.map +1 -1
  288. package/dist/collection/components/six-sidebar/test/six-sidebar.spec.js +22 -0
  289. package/dist/collection/components/six-sidebar/test/six-sidebar.spec.js.map +1 -0
  290. package/dist/collection/components/six-sidebar-item/six-sidebar-item.js +1 -1
  291. package/dist/collection/components/six-sidebar-item/test/six-sidebar-item.spec.js +50 -0
  292. package/dist/collection/components/six-sidebar-item/test/six-sidebar-item.spec.js.map +1 -0
  293. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js +14 -10
  294. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js.map +1 -1
  295. package/dist/collection/components/six-sidebar-item-group/test/six-sidebar-item-group.spec.js +53 -0
  296. package/dist/collection/components/six-sidebar-item-group/test/six-sidebar-item-group.spec.js.map +1 -0
  297. package/dist/collection/components/six-spinner/six-spinner.js +1 -1
  298. package/dist/collection/components/six-spinner/six-spinner.js.map +1 -1
  299. package/dist/collection/components/six-spinner/test/six-spinner.spec.js +37 -0
  300. package/dist/collection/components/six-spinner/test/six-spinner.spec.js.map +1 -0
  301. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js +4 -3
  302. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js.map +1 -1
  303. package/dist/collection/components/six-stage-indicator/test/six-stage-indicator.spec.js +117 -0
  304. package/dist/collection/components/six-stage-indicator/test/six-stage-indicator.spec.js.map +1 -0
  305. package/dist/collection/components/six-switch/six-switch.css +77 -0
  306. package/dist/collection/components/six-switch/six-switch.js +108 -139
  307. package/dist/collection/components/six-switch/six-switch.js.map +1 -1
  308. package/dist/collection/components/six-switch/test/six-switch.spec.js +69 -0
  309. package/dist/collection/components/six-switch/test/six-switch.spec.js.map +1 -0
  310. package/dist/collection/components/six-tab/six-tab.js +13 -7
  311. package/dist/collection/components/six-tab/six-tab.js.map +1 -1
  312. package/dist/collection/components/six-tab/test/six-tab.spec.js +20 -0
  313. package/dist/collection/components/six-tab/test/six-tab.spec.js.map +1 -0
  314. package/dist/collection/components/six-tab-group/six-tab-group.js +140 -119
  315. package/dist/collection/components/six-tab-group/six-tab-group.js.map +1 -1
  316. package/dist/collection/components/six-tab-group/test/six-tab-group.spec.js +45 -0
  317. package/dist/collection/components/six-tab-group/test/six-tab-group.spec.js.map +1 -0
  318. package/dist/collection/components/six-tab-panel/six-tab-panel.js +2 -2
  319. package/dist/collection/components/six-tab-panel/six-tab-panel.js.map +1 -1
  320. package/dist/collection/components/six-tab-panel/test/six-tab-panel.spec.js +20 -0
  321. package/dist/collection/components/six-tab-panel/test/six-tab-panel.spec.js.map +1 -0
  322. package/dist/collection/components/six-tag/six-tag.css +6 -0
  323. package/dist/collection/components/six-tag/six-tag.js +7 -9
  324. package/dist/collection/components/six-tag/six-tag.js.map +1 -1
  325. package/dist/collection/components/six-tag/test/six-tag.spec.js +42 -0
  326. package/dist/collection/components/six-tag/test/six-tag.spec.js.map +1 -0
  327. package/dist/collection/components/six-textarea/six-textarea.js +167 -282
  328. package/dist/collection/components/six-textarea/six-textarea.js.map +1 -1
  329. package/dist/collection/components/six-textarea/test/six-textarea.spec.js +117 -0
  330. package/dist/collection/components/six-textarea/test/six-textarea.spec.js.map +1 -0
  331. package/dist/collection/components/six-tile/six-tile.js +26 -25
  332. package/dist/collection/components/six-tile/six-tile.js.map +1 -1
  333. package/dist/collection/components/six-tile/test/six-tile.spec.js +69 -0
  334. package/dist/collection/components/six-tile/test/six-tile.spec.js.map +1 -0
  335. package/dist/collection/components/six-timepicker/six-timepicker.js +169 -264
  336. package/dist/collection/components/six-timepicker/six-timepicker.js.map +1 -1
  337. package/dist/collection/components/six-timepicker/test/six-timepicker.spec.js +496 -0
  338. package/dist/collection/components/six-timepicker/test/six-timepicker.spec.js.map +1 -0
  339. package/dist/collection/components/six-tooltip/six-tooltip.js +69 -66
  340. package/dist/collection/components/six-tooltip/six-tooltip.js.map +1 -1
  341. package/dist/collection/components/six-tooltip/test/six-tooltip.spec.js +28 -0
  342. package/dist/collection/components/six-tooltip/test/six-tooltip.spec.js.map +1 -0
  343. package/dist/collection/functional-components/form-control/form-control.js +9 -10
  344. package/dist/collection/functional-components/form-control/form-control.js.map +1 -1
  345. package/dist/collection/index.js +1 -1
  346. package/dist/collection/index.js.map +1 -1
  347. package/dist/collection/testUtil/delay.js.map +1 -1
  348. package/dist/collection/utils/date-util.js +25 -16
  349. package/dist/collection/utils/date-util.js.map +1 -1
  350. package/dist/collection/utils/date-util.spec.js +995 -0
  351. package/dist/collection/utils/date-util.spec.js.map +1 -0
  352. package/dist/collection/utils/error-messages.js +91 -0
  353. package/dist/collection/utils/error-messages.js.map +1 -0
  354. package/dist/collection/utils/event-listeners.js +22 -6
  355. package/dist/collection/utils/event-listeners.js.map +1 -1
  356. package/dist/collection/utils/execution-control.js +5 -4
  357. package/dist/collection/utils/execution-control.js.map +1 -1
  358. package/dist/collection/utils/focus-visible.js +2 -2
  359. package/dist/collection/utils/focus-visible.js.map +1 -1
  360. package/dist/collection/utils/form.js +15 -0
  361. package/dist/collection/utils/form.js.map +1 -0
  362. package/dist/collection/utils/modal.js +3 -2
  363. package/dist/collection/utils/modal.js.map +1 -1
  364. package/dist/collection/utils/popover.js +33 -19
  365. package/dist/collection/utils/popover.js.map +1 -1
  366. package/dist/collection/utils/popup.js +95 -0
  367. package/dist/collection/utils/popup.js.map +1 -0
  368. package/dist/collection/utils/scroll.js +1 -1
  369. package/dist/collection/utils/scroll.spec.js +122 -0
  370. package/dist/collection/utils/scroll.spec.js.map +1 -0
  371. package/dist/collection/utils/slot.js +9 -24
  372. package/dist/collection/utils/slot.js.map +1 -1
  373. package/dist/collection/utils/tabbable.js +6 -6
  374. package/dist/collection/utils/tabbable.js.map +1 -1
  375. package/dist/collection/utils/time.util.js +48 -34
  376. package/dist/collection/utils/time.util.js.map +1 -1
  377. package/dist/collection/utils/time.util.spec.js +368 -0
  378. package/dist/collection/utils/time.util.spec.js.map +1 -0
  379. package/dist/collection/utils/type-check.js +0 -1
  380. package/dist/collection/utils/type-check.js.map +1 -1
  381. package/dist/collection/wrappers/set-attributes/set-attributes.js +4 -2
  382. package/dist/collection/wrappers/set-attributes/set-attributes.js.map +1 -1
  383. package/dist/collection/wrappers/set-attributes/test/set-attributes.spec.js +16 -0
  384. package/dist/collection/wrappers/set-attributes/test/set-attributes.spec.js.map +1 -0
  385. package/dist/components/event-listeners.js +22 -6
  386. package/dist/components/event-listeners.js.map +1 -1
  387. package/dist/components/execution-control.js +5 -2
  388. package/dist/components/execution-control.js.map +1 -1
  389. package/dist/components/focus-visible.js +2 -2
  390. package/dist/components/focus-visible.js.map +1 -1
  391. package/dist/components/form-control.js +8 -9
  392. package/dist/components/form-control.js.map +1 -1
  393. package/dist/components/form.js +18 -0
  394. package/dist/components/form.js.map +1 -0
  395. package/dist/components/index.js +92 -3
  396. package/dist/components/index.js.map +1 -1
  397. package/dist/components/modal.js +3 -2
  398. package/dist/components/modal.js.map +1 -1
  399. package/dist/components/popover.js +38 -30
  400. package/dist/components/popover.js.map +1 -1
  401. package/dist/components/scroll.js.map +1 -1
  402. package/dist/components/set-attributes2.js +3 -1
  403. package/dist/components/set-attributes2.js.map +1 -1
  404. package/dist/components/six-alert.js +17 -22
  405. package/dist/components/six-alert.js.map +1 -1
  406. package/dist/components/six-avatar.js +4 -7
  407. package/dist/components/six-avatar.js.map +1 -1
  408. package/dist/components/six-badge.js +1 -1
  409. package/dist/components/six-badge.js.map +1 -1
  410. package/dist/components/six-button.js +34 -32
  411. package/dist/components/six-button.js.map +1 -1
  412. package/dist/components/six-card.js.map +1 -1
  413. package/dist/components/six-checkbox.js +48 -89
  414. package/dist/components/six-checkbox.js.map +1 -1
  415. package/dist/components/six-datepicker.js +153 -282
  416. package/dist/components/six-datepicker.js.map +1 -1
  417. package/dist/components/six-details2.js +46 -45
  418. package/dist/components/six-details2.js.map +1 -1
  419. package/dist/components/six-dialog.js +33 -37
  420. package/dist/components/six-dialog.js.map +1 -1
  421. package/dist/components/six-drawer.js +30 -34
  422. package/dist/components/six-drawer.js.map +1 -1
  423. package/dist/components/six-dropdown2.js +185 -173
  424. package/dist/components/six-dropdown2.js.map +1 -1
  425. package/dist/components/six-error-page.js +19 -21
  426. package/dist/components/six-error-page.js.map +1 -1
  427. package/dist/components/six-file-list-item.js +1 -1
  428. package/dist/components/six-file-list-item.js.map +1 -1
  429. package/dist/components/six-file-list.js.map +1 -1
  430. package/dist/components/six-file-upload.js +20 -20
  431. package/dist/components/six-file-upload.js.map +1 -1
  432. package/dist/components/six-footer.js.map +1 -1
  433. package/dist/components/six-group-label.js +10 -9
  434. package/dist/components/six-group-label.js.map +1 -1
  435. package/dist/components/six-header.js +64 -42
  436. package/dist/components/six-header.js.map +1 -1
  437. package/dist/components/six-icon-button2.js +2 -2
  438. package/dist/components/six-icon-button2.js.map +1 -1
  439. package/dist/components/six-icon2.js.map +1 -1
  440. package/dist/components/six-input2.js +96 -138
  441. package/dist/components/six-input2.js.map +1 -1
  442. package/dist/components/six-item-picker2.js +58 -77
  443. package/dist/components/six-item-picker2.js.map +1 -1
  444. package/dist/components/six-language-switcher.js +1 -1
  445. package/dist/components/six-language-switcher.js.map +1 -1
  446. package/dist/components/six-layout-grid.js +5 -3
  447. package/dist/components/six-layout-grid.js.map +1 -1
  448. package/dist/components/six-main-container.js.map +1 -1
  449. package/dist/components/six-menu-divider.js.map +1 -1
  450. package/dist/components/six-menu-item2.js +7 -5
  451. package/dist/components/six-menu-item2.js.map +1 -1
  452. package/dist/components/six-menu-label.js.map +1 -1
  453. package/dist/components/six-menu2.js +25 -18
  454. package/dist/components/six-menu2.js.map +1 -1
  455. package/dist/components/six-picto2.js +4 -1
  456. package/dist/components/six-picto2.js.map +1 -1
  457. package/dist/components/six-progress-bar.js.map +1 -1
  458. package/dist/components/six-progress-ring.js +3 -3
  459. package/dist/components/six-progress-ring.js.map +1 -1
  460. package/dist/components/six-radio.js +65 -78
  461. package/dist/components/six-radio.js.map +1 -1
  462. package/dist/components/six-range.js +108 -111
  463. package/dist/components/six-range.js.map +1 -1
  464. package/dist/components/six-root.js +1 -1
  465. package/dist/components/six-root.js.map +1 -1
  466. package/dist/components/six-search-field.js +8 -3
  467. package/dist/components/six-search-field.js.map +1 -1
  468. package/dist/components/six-select.js +190 -229
  469. package/dist/components/six-select.js.map +1 -1
  470. package/dist/components/six-sidebar-item-group.js +8 -4
  471. package/dist/components/six-sidebar-item-group.js.map +1 -1
  472. package/dist/components/six-sidebar-item.js.map +1 -1
  473. package/dist/components/six-sidebar.js +39 -18
  474. package/dist/components/six-sidebar.js.map +1 -1
  475. package/dist/components/six-spinner2.js.map +1 -1
  476. package/dist/components/six-stage-indicator2.js.map +1 -1
  477. package/dist/components/six-switch.js +61 -69
  478. package/dist/components/six-switch.js.map +1 -1
  479. package/dist/components/six-tab-group.js +129 -111
  480. package/dist/components/six-tab-group.js.map +1 -1
  481. package/dist/components/six-tab-panel.js +1 -1
  482. package/dist/components/six-tab-panel.js.map +1 -1
  483. package/dist/components/six-tab.js +4 -2
  484. package/dist/components/six-tab.js.map +1 -1
  485. package/dist/components/six-tag2.js +5 -8
  486. package/dist/components/six-tag2.js.map +1 -1
  487. package/dist/components/six-textarea.js +83 -115
  488. package/dist/components/six-textarea.js.map +1 -1
  489. package/dist/components/six-tile.js +14 -17
  490. package/dist/components/six-tile.js.map +1 -1
  491. package/dist/components/six-timepicker.js +1 -1
  492. package/dist/components/six-timepicker2.js +247 -258
  493. package/dist/components/six-timepicker2.js.map +1 -1
  494. package/dist/components/six-tooltip2.js +52 -55
  495. package/dist/components/six-tooltip2.js.map +1 -1
  496. package/dist/components/slot.js +10 -9
  497. package/dist/components/slot.js.map +1 -1
  498. package/dist/components.d.ts +361 -88
  499. package/dist/components.json +4265 -1020
  500. package/dist/esm/event-listeners-f6e5b0ab.js +59 -0
  501. package/dist/esm/event-listeners-f6e5b0ab.js.map +1 -0
  502. package/dist/esm/{execution-control-1a60d709.js → execution-control-e0892a05.js} +6 -3
  503. package/dist/esm/execution-control-e0892a05.js.map +1 -0
  504. package/dist/esm/{focus-visible-97933ea9.js → focus-visible-fc6ac671.js} +3 -3
  505. package/dist/esm/focus-visible-fc6ac671.js.map +1 -0
  506. package/dist/esm/form-81252534.js +18 -0
  507. package/dist/esm/form-81252534.js.map +1 -0
  508. package/dist/esm/{form-control-3b440ea1.js → form-control-32cb533f.js} +10 -11
  509. package/dist/esm/form-control-32cb533f.js.map +1 -0
  510. package/dist/esm/{index-5c0f6628.js → index-8a74f992.js} +186 -53
  511. package/dist/esm/index-8a74f992.js.map +1 -0
  512. package/dist/esm/index.js +91 -0
  513. package/dist/esm/index.js.map +1 -1
  514. package/dist/esm/loader.js +4 -13
  515. package/dist/esm/loader.js.map +1 -1
  516. package/dist/esm/{modal-5ebdc320.js → modal-7d32e141.js} +4 -3
  517. package/dist/esm/modal-7d32e141.js.map +1 -0
  518. package/dist/esm/{popover-bd2c2fca.js → popover-136d1f73.js} +39 -31
  519. package/dist/esm/popover-136d1f73.js.map +1 -0
  520. package/dist/esm/popup-7f89a001.js +98 -0
  521. package/dist/esm/popup-7f89a001.js.map +1 -0
  522. package/dist/esm/{scroll-180b53fd.js → scroll-3fb087a2.js} +1 -1
  523. package/dist/esm/scroll-3fb087a2.js.map +1 -0
  524. package/dist/esm/set-attributes_2.entry.js +4 -2
  525. package/dist/esm/set-attributes_2.entry.js.map +1 -1
  526. package/dist/esm/six-alert.entry.js +18 -23
  527. package/dist/esm/six-alert.entry.js.map +1 -1
  528. package/dist/esm/six-avatar.entry.js +5 -8
  529. package/dist/esm/six-avatar.entry.js.map +1 -1
  530. package/dist/esm/six-badge.entry.js +2 -2
  531. package/dist/esm/six-badge.entry.js.map +1 -1
  532. package/dist/esm/six-button.entry.js +36 -34
  533. package/dist/esm/six-button.entry.js.map +1 -1
  534. package/dist/esm/six-card.entry.js +1 -1
  535. package/dist/esm/six-card.entry.js.map +1 -1
  536. package/dist/esm/six-checkbox.entry.js +50 -85
  537. package/dist/esm/six-checkbox.entry.js.map +1 -1
  538. package/dist/esm/six-datepicker.entry.js +152 -278
  539. package/dist/esm/six-datepicker.entry.js.map +1 -1
  540. package/dist/esm/six-details.entry.js +48 -47
  541. package/dist/esm/six-details.entry.js.map +1 -1
  542. package/dist/esm/six-dialog.entry.js +37 -41
  543. package/dist/esm/six-dialog.entry.js.map +1 -1
  544. package/dist/esm/six-drawer.entry.js +34 -38
  545. package/dist/esm/six-drawer.entry.js.map +1 -1
  546. package/dist/esm/six-dropdown_2.entry.js +215 -196
  547. package/dist/esm/six-dropdown_2.entry.js.map +1 -1
  548. package/dist/esm/six-error-page.entry.js +20 -22
  549. package/dist/esm/six-error-page.entry.js.map +1 -1
  550. package/dist/esm/six-file-list-item.entry.js +2 -2
  551. package/dist/esm/six-file-list-item.entry.js.map +1 -1
  552. package/dist/esm/six-file-list.entry.js +1 -1
  553. package/dist/esm/six-file-list.entry.js.map +1 -1
  554. package/dist/esm/six-file-upload.entry.js +21 -21
  555. package/dist/esm/six-file-upload.entry.js.map +1 -1
  556. package/dist/esm/six-footer.entry.js +1 -1
  557. package/dist/esm/six-footer.entry.js.map +1 -1
  558. package/dist/esm/six-group-label.entry.js +12 -11
  559. package/dist/esm/six-group-label.entry.js.map +1 -1
  560. package/dist/esm/six-header.entry.js +66 -44
  561. package/dist/esm/six-header.entry.js.map +1 -1
  562. package/dist/esm/six-icon-button.entry.js +4 -4
  563. package/dist/esm/six-icon-button.entry.js.map +1 -1
  564. package/dist/esm/six-icon.entry.js +1 -1
  565. package/dist/esm/six-icon.entry.js.map +1 -1
  566. package/dist/esm/six-input.entry.js +95 -128
  567. package/dist/esm/six-input.entry.js.map +1 -1
  568. package/dist/esm/six-item-picker.entry.js +62 -81
  569. package/dist/esm/six-item-picker.entry.js.map +1 -1
  570. package/dist/esm/six-language-switcher.entry.js +2 -2
  571. package/dist/esm/six-language-switcher.entry.js.map +1 -1
  572. package/dist/esm/six-layout-grid.entry.js +5 -3
  573. package/dist/esm/six-layout-grid.entry.js.map +1 -1
  574. package/dist/esm/six-main-container.entry.js +1 -1
  575. package/dist/esm/six-main-container.entry.js.map +1 -1
  576. package/dist/esm/six-menu-divider.entry.js +1 -1
  577. package/dist/esm/six-menu-divider.entry.js.map +1 -1
  578. package/dist/esm/six-menu-item.entry.js +9 -7
  579. package/dist/esm/six-menu-item.entry.js.map +1 -1
  580. package/dist/esm/six-menu-label.entry.js +1 -1
  581. package/dist/esm/six-menu-label.entry.js.map +1 -1
  582. package/dist/esm/six-picto.entry.js +5 -2
  583. package/dist/esm/six-picto.entry.js.map +1 -1
  584. package/dist/esm/six-progress-bar.entry.js +1 -1
  585. package/dist/esm/six-progress-bar.entry.js.map +1 -1
  586. package/dist/esm/six-progress-ring.entry.js +4 -4
  587. package/dist/esm/six-progress-ring.entry.js.map +1 -1
  588. package/dist/esm/six-radio.entry.js +63 -72
  589. package/dist/esm/six-radio.entry.js.map +1 -1
  590. package/dist/esm/six-range.entry.js +107 -106
  591. package/dist/esm/six-range.entry.js.map +1 -1
  592. package/dist/esm/six-root.entry.js +2 -2
  593. package/dist/esm/six-root.entry.js.map +1 -1
  594. package/dist/esm/six-search-field.entry.js +11 -6
  595. package/dist/esm/six-search-field.entry.js.map +1 -1
  596. package/dist/esm/six-select.entry.js +190 -223
  597. package/dist/esm/six-select.entry.js.map +1 -1
  598. package/dist/esm/six-sidebar-item-group.entry.js +10 -6
  599. package/dist/esm/six-sidebar-item-group.entry.js.map +1 -1
  600. package/dist/esm/six-sidebar-item.entry.js +1 -1
  601. package/dist/esm/six-sidebar-item.entry.js.map +1 -1
  602. package/dist/esm/six-sidebar.entry.js +41 -20
  603. package/dist/esm/six-sidebar.entry.js.map +1 -1
  604. package/dist/esm/six-spinner.entry.js +1 -1
  605. package/dist/esm/six-spinner.entry.js.map +1 -1
  606. package/dist/esm/six-switch.entry.js +58 -64
  607. package/dist/esm/six-switch.entry.js.map +1 -1
  608. package/dist/esm/six-tab-group.entry.js +132 -114
  609. package/dist/esm/six-tab-group.entry.js.map +1 -1
  610. package/dist/esm/six-tab-panel.entry.js +2 -2
  611. package/dist/esm/six-tab-panel.entry.js.map +1 -1
  612. package/dist/esm/six-tab.entry.js +5 -3
  613. package/dist/esm/six-tab.entry.js.map +1 -1
  614. package/dist/esm/six-tag.entry.js +6 -9
  615. package/dist/esm/six-tag.entry.js.map +1 -1
  616. package/dist/esm/six-textarea.entry.js +82 -108
  617. package/dist/esm/six-textarea.entry.js.map +1 -1
  618. package/dist/esm/six-tile.entry.js +14 -17
  619. package/dist/esm/six-tile.entry.js.map +1 -1
  620. package/dist/esm/six-timepicker.entry.js +159 -215
  621. package/dist/esm/six-timepicker.entry.js.map +1 -1
  622. package/dist/esm/six-tooltip.entry.js +54 -57
  623. package/dist/esm/six-tooltip.entry.js.map +1 -1
  624. package/dist/esm/{slot-6f3984c7.js → slot-ad36df3a.js} +11 -10
  625. package/dist/esm/slot-ad36df3a.js.map +1 -0
  626. package/dist/esm/{types-4b10b413.js → types-59b455aa.js} +1 -1
  627. package/dist/esm/types-59b455aa.js.map +1 -0
  628. package/dist/esm/ui-library.js +4 -7
  629. package/dist/esm/ui-library.js.map +1 -1
  630. package/dist/types/components/six-alert/six-alert.d.ts +5 -7
  631. package/dist/types/components/six-avatar/six-avatar.d.ts +1 -2
  632. package/dist/types/components/six-badge/six-badge.d.ts +0 -1
  633. package/dist/types/components/six-button/six-button.d.ts +8 -9
  634. package/dist/types/components/six-checkbox/six-checkbox.d.ts +23 -35
  635. package/dist/types/components/six-datepicker/components/day-selection.d.ts +9 -5
  636. package/dist/types/components/six-datepicker/components/month-selection.d.ts +8 -5
  637. package/dist/types/components/six-datepicker/components/year-selection.d.ts +7 -5
  638. package/dist/types/components/six-datepicker/six-datepicker.d.ts +41 -52
  639. package/dist/types/components/six-details/six-details.d.ts +12 -12
  640. package/dist/types/components/six-dialog/six-dialog.d.ts +12 -13
  641. package/dist/types/components/six-drawer/six-drawer.d.ts +12 -13
  642. package/dist/types/components/six-dropdown/six-dropdown.d.ts +28 -32
  643. package/dist/types/components/six-error-page/six-error-page.d.ts +1 -1
  644. package/dist/types/components/six-file-list-item/six-file-list-item.d.ts +3 -3
  645. package/dist/types/components/six-file-upload/six-file-upload.d.ts +11 -11
  646. package/dist/types/components/six-group-label/six-group-label.d.ts +5 -5
  647. package/dist/types/components/six-header/six-header.d.ts +16 -27
  648. package/dist/types/components/six-icon-button/six-icon-button.d.ts +4 -4
  649. package/dist/types/components/six-input/six-input.d.ts +32 -67
  650. package/dist/types/components/six-item-picker/six-item-picker.d.ts +13 -16
  651. package/dist/types/components/six-layout-grid/six-layout-grid.d.ts +1 -1
  652. package/dist/types/components/six-menu/six-menu.d.ts +10 -11
  653. package/dist/types/components/six-menu-item/six-menu-item.d.ts +6 -6
  654. package/dist/types/components/six-progress-ring/six-progress-ring.d.ts +2 -2
  655. package/dist/types/components/six-radio/six-radio.d.ts +14 -25
  656. package/dist/types/components/six-range/six-range.d.ts +27 -38
  657. package/dist/types/components/six-root/six-root.d.ts +3 -3
  658. package/dist/types/components/six-search-field/six-search-field.d.ts +4 -5
  659. package/dist/types/components/six-select/six-select.d.ts +41 -58
  660. package/dist/types/components/six-select/util.d.ts +7 -0
  661. package/dist/types/components/six-sidebar/six-sidebar.d.ts +5 -5
  662. package/dist/types/components/six-sidebar-item-group/six-sidebar-item-group.d.ts +7 -6
  663. package/dist/types/components/six-spinner/six-spinner.d.ts +2 -2
  664. package/dist/types/components/six-switch/six-switch.d.ts +18 -21
  665. package/dist/types/components/six-tab/six-tab.d.ts +3 -3
  666. package/dist/types/components/six-tab-group/six-tab-group.d.ts +20 -21
  667. package/dist/types/components/six-tab-panel/six-tab-panel.d.ts +1 -1
  668. package/dist/types/components/six-tag/six-tag.d.ts +1 -3
  669. package/dist/types/components/six-textarea/six-textarea.d.ts +27 -55
  670. package/dist/types/components/six-tile/six-tile.d.ts +2 -3
  671. package/dist/types/components/six-timepicker/six-timepicker.d.ts +26 -43
  672. package/dist/types/components/six-tooltip/six-tooltip.d.ts +19 -21
  673. package/dist/types/components.d.ts +209 -452
  674. package/dist/types/functional-components/form-control/form-control.d.ts +5 -6
  675. package/dist/types/index.d.ts +1 -0
  676. package/dist/types/stencil-public-runtime.d.ts +15 -2
  677. package/dist/types/testUtil/delay.d.ts +1 -1
  678. package/dist/types/types.d.ts +2 -0
  679. package/dist/types/utils/date-util.d.ts +18 -10
  680. package/dist/types/utils/error-messages.d.ts +42 -0
  681. package/dist/types/utils/event-listeners.d.ts +4 -3
  682. package/dist/types/utils/execution-control.d.ts +1 -3
  683. package/dist/types/utils/form.d.ts +1 -0
  684. package/dist/types/utils/modal.d.ts +2 -2
  685. package/dist/types/utils/popover.d.ts +5 -5
  686. package/dist/types/utils/popup.d.ts +9 -0
  687. package/dist/types/utils/slot.d.ts +2 -7
  688. package/dist/types/utils/tabbable.d.ts +1 -1
  689. package/dist/types/utils/time.util.d.ts +18 -9
  690. package/dist/types/utils/type-check.d.ts +3 -4
  691. package/dist/types/wrappers/set-attributes/set-attributes.d.ts +1 -1
  692. package/dist/ui-library/index.esm.js +1 -1
  693. package/dist/ui-library/index.esm.js.map +1 -1
  694. package/dist/ui-library/p-02981b91.entry.js +2 -0
  695. package/dist/ui-library/p-02981b91.entry.js.map +1 -0
  696. package/dist/ui-library/{p-25a3bf57.js → p-0f510624.js} +1 -1
  697. package/dist/ui-library/p-0f510624.js.map +1 -0
  698. package/dist/ui-library/p-0fdb185d.js +2 -0
  699. package/dist/ui-library/p-0fdb185d.js.map +1 -0
  700. package/dist/ui-library/{p-611e1978.entry.js → p-1256cc0a.entry.js} +2 -2
  701. package/dist/ui-library/p-1256cc0a.entry.js.map +1 -0
  702. package/dist/ui-library/{p-19364560.entry.js → p-13b43e04.entry.js} +2 -2
  703. package/dist/ui-library/p-13b43e04.entry.js.map +1 -0
  704. package/dist/ui-library/p-15559d38.js +2 -0
  705. package/dist/ui-library/p-15559d38.js.map +1 -0
  706. package/dist/ui-library/p-19ed7a4c.entry.js +2 -0
  707. package/dist/ui-library/p-19ed7a4c.entry.js.map +1 -0
  708. package/dist/ui-library/{p-97323ad7.entry.js → p-1d5ee1a0.entry.js} +2 -2
  709. package/dist/ui-library/p-1d5ee1a0.entry.js.map +1 -0
  710. package/dist/ui-library/{p-eb8f05a9.js → p-1f18768a.js} +1 -1
  711. package/dist/ui-library/p-1f18768a.js.map +1 -0
  712. package/dist/ui-library/p-21b3b321.entry.js +2 -0
  713. package/dist/ui-library/p-21b3b321.entry.js.map +1 -0
  714. package/dist/ui-library/p-264d4ea8.entry.js +2 -0
  715. package/dist/ui-library/p-264d4ea8.entry.js.map +1 -0
  716. package/dist/ui-library/{p-c30f9e0b.entry.js → p-29ac3d7d.entry.js} +2 -2
  717. package/dist/ui-library/p-29ac3d7d.entry.js.map +1 -0
  718. package/dist/ui-library/p-314b2096.entry.js +2 -0
  719. package/dist/ui-library/p-314b2096.entry.js.map +1 -0
  720. package/dist/ui-library/p-330a4988.entry.js +2 -0
  721. package/dist/ui-library/p-330a4988.entry.js.map +1 -0
  722. package/dist/ui-library/{p-21859bca.entry.js → p-346f9557.entry.js} +2 -2
  723. package/dist/ui-library/p-346f9557.entry.js.map +1 -0
  724. package/dist/ui-library/p-37557787.entry.js +2 -0
  725. package/dist/ui-library/p-37557787.entry.js.map +1 -0
  726. package/dist/ui-library/{p-baa03951.entry.js → p-3cc5addb.entry.js} +2 -2
  727. package/dist/ui-library/p-3cc5addb.entry.js.map +1 -0
  728. package/dist/ui-library/p-3d9de119.entry.js +2 -0
  729. package/dist/ui-library/p-3d9de119.entry.js.map +1 -0
  730. package/dist/ui-library/p-411ed539.entry.js +2 -0
  731. package/dist/ui-library/p-411ed539.entry.js.map +1 -0
  732. package/dist/ui-library/p-4705a51e.entry.js +2 -0
  733. package/dist/ui-library/p-4705a51e.entry.js.map +1 -0
  734. package/dist/ui-library/p-4abed9df.entry.js +2 -0
  735. package/dist/ui-library/p-4abed9df.entry.js.map +1 -0
  736. package/dist/ui-library/p-5654e4c7.js +2 -0
  737. package/dist/ui-library/p-5654e4c7.js.map +1 -0
  738. package/dist/ui-library/p-59210f0b.js +2 -0
  739. package/dist/ui-library/p-59210f0b.js.map +1 -0
  740. package/dist/ui-library/{p-19b50b5a.entry.js → p-5af44076.entry.js} +2 -2
  741. package/dist/ui-library/p-5af44076.entry.js.map +1 -0
  742. package/dist/ui-library/p-5d6b7353.entry.js +2 -0
  743. package/dist/ui-library/p-5d6b7353.entry.js.map +1 -0
  744. package/dist/ui-library/{p-097cced4.entry.js → p-613283a7.entry.js} +2 -2
  745. package/dist/ui-library/p-613283a7.entry.js.map +1 -0
  746. package/dist/ui-library/p-6153045b.js +3 -0
  747. package/dist/ui-library/p-6153045b.js.map +1 -0
  748. package/dist/ui-library/{p-e19a6c95.entry.js → p-6197fe2f.entry.js} +2 -2
  749. package/dist/ui-library/p-6197fe2f.entry.js.map +1 -0
  750. package/dist/ui-library/p-698bb2c8.js +2 -0
  751. package/dist/ui-library/p-698bb2c8.js.map +1 -0
  752. package/dist/ui-library/{p-d5633a29.entry.js → p-72254eef.entry.js} +2 -2
  753. package/dist/ui-library/p-72254eef.entry.js.map +1 -0
  754. package/dist/ui-library/p-724875b0.entry.js +2 -0
  755. package/dist/ui-library/p-724875b0.entry.js.map +1 -0
  756. package/dist/ui-library/{p-dd3c76f1.entry.js → p-7afafb9d.entry.js} +2 -2
  757. package/dist/ui-library/p-7afafb9d.entry.js.map +1 -0
  758. package/dist/ui-library/p-7d95def3.js +2 -0
  759. package/dist/ui-library/p-7d95def3.js.map +1 -0
  760. package/dist/ui-library/{p-63703ba3.entry.js → p-7e3ad38a.entry.js} +2 -2
  761. package/dist/ui-library/p-7e3ad38a.entry.js.map +1 -0
  762. package/dist/ui-library/p-83864cfe.entry.js +2 -0
  763. package/dist/ui-library/p-83864cfe.entry.js.map +1 -0
  764. package/dist/ui-library/{p-9328e5bc.entry.js → p-878226a0.entry.js} +2 -2
  765. package/dist/ui-library/p-878226a0.entry.js.map +1 -0
  766. package/dist/ui-library/p-8c0971e0.js +2 -0
  767. package/dist/ui-library/p-8c0971e0.js.map +1 -0
  768. package/dist/ui-library/p-91b51800.entry.js +2 -0
  769. package/dist/ui-library/p-91b51800.entry.js.map +1 -0
  770. package/dist/ui-library/p-95fbdd0b.entry.js +2 -0
  771. package/dist/ui-library/p-95fbdd0b.entry.js.map +1 -0
  772. package/dist/ui-library/p-99e24daf.entry.js +2 -0
  773. package/dist/ui-library/p-99e24daf.entry.js.map +1 -0
  774. package/dist/ui-library/{p-4f8394d7.js → p-9ace84c7.js} +2 -2
  775. package/dist/ui-library/p-9ace84c7.js.map +1 -0
  776. package/dist/ui-library/p-9b354f5d.entry.js +2 -0
  777. package/dist/ui-library/p-9b354f5d.entry.js.map +1 -0
  778. package/dist/ui-library/{p-c349d1d4.entry.js → p-9c1be3fb.entry.js} +2 -2
  779. package/dist/ui-library/p-9c1be3fb.entry.js.map +1 -0
  780. package/dist/ui-library/p-9f0b43f9.entry.js +2 -0
  781. package/dist/ui-library/p-9f0b43f9.entry.js.map +1 -0
  782. package/dist/ui-library/{p-af793d04.entry.js → p-a0f290d0.entry.js} +2 -2
  783. package/dist/ui-library/p-a0f290d0.entry.js.map +1 -0
  784. package/dist/ui-library/p-a55c7258.entry.js +2 -0
  785. package/dist/ui-library/p-a55c7258.entry.js.map +1 -0
  786. package/dist/ui-library/{p-6d75f216.entry.js → p-a6a9ee96.entry.js} +2 -2
  787. package/dist/ui-library/p-a6a9ee96.entry.js.map +1 -0
  788. package/dist/ui-library/{p-73597d13.entry.js → p-ac099e6b.entry.js} +2 -2
  789. package/dist/ui-library/p-ac099e6b.entry.js.map +1 -0
  790. package/dist/ui-library/p-ae601a0f.entry.js +2 -0
  791. package/dist/ui-library/p-ae601a0f.entry.js.map +1 -0
  792. package/dist/ui-library/p-b351f889.entry.js +2 -0
  793. package/dist/ui-library/p-b351f889.entry.js.map +1 -0
  794. package/dist/ui-library/{p-6433c0da.entry.js → p-b550a258.entry.js} +2 -2
  795. package/dist/ui-library/p-b550a258.entry.js.map +1 -0
  796. package/dist/ui-library/{p-90dc6af4.entry.js → p-bf87464b.entry.js} +2 -2
  797. package/dist/ui-library/p-bf87464b.entry.js.map +1 -0
  798. package/dist/ui-library/p-c03ebf7d.entry.js +2 -0
  799. package/dist/ui-library/p-c03ebf7d.entry.js.map +1 -0
  800. package/dist/ui-library/{p-a1d4f6cf.entry.js → p-cd67da3d.entry.js} +2 -2
  801. package/dist/ui-library/p-cd67da3d.entry.js.map +1 -0
  802. package/dist/ui-library/p-cdaed936.entry.js +2 -0
  803. package/dist/ui-library/p-cdaed936.entry.js.map +1 -0
  804. package/dist/ui-library/{p-8a970a40.entry.js → p-d367f4f9.entry.js} +2 -2
  805. package/dist/ui-library/p-d367f4f9.entry.js.map +1 -0
  806. package/dist/ui-library/p-d42c2025.js +2 -0
  807. package/dist/ui-library/p-d42c2025.js.map +1 -0
  808. package/dist/ui-library/{p-820c23f0.entry.js → p-dfed33c5.entry.js} +2 -2
  809. package/dist/ui-library/p-dfed33c5.entry.js.map +1 -0
  810. package/dist/ui-library/p-ed381ad9.entry.js +2 -0
  811. package/dist/ui-library/p-ed381ad9.entry.js.map +1 -0
  812. package/dist/ui-library/p-ee8342e1.entry.js +2 -0
  813. package/dist/ui-library/p-ee8342e1.entry.js.map +1 -0
  814. package/dist/ui-library/p-ee950ce2.entry.js +2 -0
  815. package/dist/ui-library/p-ee950ce2.entry.js.map +1 -0
  816. package/dist/ui-library/{p-7e0cc4ae.entry.js → p-ff90ffd1.entry.js} +2 -2
  817. package/dist/ui-library/p-ff90ffd1.entry.js.map +1 -0
  818. package/dist/ui-library/ui-library.esm.js +1 -1
  819. package/dist/ui-library/ui-library.esm.js.map +1 -1
  820. package/loader/index.d.ts +1 -1
  821. package/package.json +19 -20
  822. package/dist/cjs/event-listeners-74715e62.js +0 -45
  823. package/dist/cjs/event-listeners-74715e62.js.map +0 -1
  824. package/dist/cjs/execution-control-46f388e0.js.map +0 -1
  825. package/dist/cjs/focus-visible-0b352c74.js.map +0 -1
  826. package/dist/cjs/form-control-2c17c573.js.map +0 -1
  827. package/dist/cjs/index-2f6daa5b.js.map +0 -1
  828. package/dist/cjs/modal-48d42228.js.map +0 -1
  829. package/dist/cjs/popover-f743f62b.js.map +0 -1
  830. package/dist/cjs/scroll-76e6f5d7.js.map +0 -1
  831. package/dist/cjs/six-form.cjs.entry.js +0 -231
  832. package/dist/cjs/six-form.cjs.entry.js.map +0 -1
  833. package/dist/cjs/six-timepicker.types-c19ebff3.js +0 -56
  834. package/dist/cjs/six-timepicker.types-c19ebff3.js.map +0 -1
  835. package/dist/cjs/slot-ad537f24.js.map +0 -1
  836. package/dist/cjs/types-64878648.js.map +0 -1
  837. package/dist/collection/components/six-form/six-form.css +0 -11
  838. package/dist/collection/components/six-form/six-form.js +0 -419
  839. package/dist/collection/components/six-form/six-form.js.map +0 -1
  840. package/dist/collection/components/six-timepicker/six-time-format.js +0 -15
  841. package/dist/collection/components/six-timepicker/six-time-format.js.map +0 -1
  842. package/dist/collection/components/six-timepicker/six-timepicker.types.js +0 -41
  843. package/dist/collection/components/six-timepicker/six-timepicker.types.js.map +0 -1
  844. package/dist/collection/utils/as-array.js +0 -2
  845. package/dist/collection/utils/as-array.js.map +0 -1
  846. package/dist/collection/utils/matchers.js +0 -3
  847. package/dist/collection/utils/matchers.js.map +0 -1
  848. package/dist/collection/utils/testing.js +0 -39
  849. package/dist/collection/utils/testing.js.map +0 -1
  850. package/dist/components/six-form.d.ts +0 -11
  851. package/dist/components/six-form.js +0 -252
  852. package/dist/components/six-form.js.map +0 -1
  853. package/dist/esm/event-listeners-570a24ea.js +0 -43
  854. package/dist/esm/event-listeners-570a24ea.js.map +0 -1
  855. package/dist/esm/execution-control-1a60d709.js.map +0 -1
  856. package/dist/esm/focus-visible-97933ea9.js.map +0 -1
  857. package/dist/esm/form-control-3b440ea1.js.map +0 -1
  858. package/dist/esm/index-5c0f6628.js.map +0 -1
  859. package/dist/esm/modal-5ebdc320.js.map +0 -1
  860. package/dist/esm/polyfills/css-shim.js +0 -1
  861. package/dist/esm/popover-bd2c2fca.js.map +0 -1
  862. package/dist/esm/scroll-180b53fd.js.map +0 -1
  863. package/dist/esm/six-form.entry.js +0 -227
  864. package/dist/esm/six-form.entry.js.map +0 -1
  865. package/dist/esm/six-timepicker.types-e161a447.js +0 -50
  866. package/dist/esm/six-timepicker.types-e161a447.js.map +0 -1
  867. package/dist/esm/slot-6f3984c7.js.map +0 -1
  868. package/dist/esm/types-4b10b413.js.map +0 -1
  869. package/dist/types/components/six-form/six-form.d.ts +0 -69
  870. package/dist/types/components/six-timepicker/six-time-format.d.ts +0 -13
  871. package/dist/types/components/six-timepicker/six-timepicker.types.d.ts +0 -36
  872. package/dist/types/utils/as-array.d.ts +0 -1
  873. package/dist/types/utils/matchers.d.ts +0 -2
  874. package/dist/types/utils/popper.d.ts +0 -33
  875. package/dist/types/utils/testing.d.ts +0 -2
  876. package/dist/ui-library/p-054e12cc.entry.js +0 -2
  877. package/dist/ui-library/p-054e12cc.entry.js.map +0 -1
  878. package/dist/ui-library/p-0786fa7c.js +0 -2
  879. package/dist/ui-library/p-0786fa7c.js.map +0 -1
  880. package/dist/ui-library/p-097cced4.entry.js.map +0 -1
  881. package/dist/ui-library/p-0d79b0c6.entry.js +0 -2
  882. package/dist/ui-library/p-0d79b0c6.entry.js.map +0 -1
  883. package/dist/ui-library/p-14f20bbb.entry.js +0 -2
  884. package/dist/ui-library/p-14f20bbb.entry.js.map +0 -1
  885. package/dist/ui-library/p-18e5f772.entry.js +0 -2
  886. package/dist/ui-library/p-18e5f772.entry.js.map +0 -1
  887. package/dist/ui-library/p-18ea0c56.js +0 -2
  888. package/dist/ui-library/p-18ea0c56.js.map +0 -1
  889. package/dist/ui-library/p-19364560.entry.js.map +0 -1
  890. package/dist/ui-library/p-19b50b5a.entry.js.map +0 -1
  891. package/dist/ui-library/p-21859bca.entry.js.map +0 -1
  892. package/dist/ui-library/p-25a3bf57.js.map +0 -1
  893. package/dist/ui-library/p-2e48c8d2.entry.js +0 -2
  894. package/dist/ui-library/p-2e48c8d2.entry.js.map +0 -1
  895. package/dist/ui-library/p-308261c4.entry.js +0 -2
  896. package/dist/ui-library/p-308261c4.entry.js.map +0 -1
  897. package/dist/ui-library/p-33f7e22b.entry.js +0 -2
  898. package/dist/ui-library/p-33f7e22b.entry.js.map +0 -1
  899. package/dist/ui-library/p-4ae91795.entry.js +0 -2
  900. package/dist/ui-library/p-4ae91795.entry.js.map +0 -1
  901. package/dist/ui-library/p-4f8394d7.js.map +0 -1
  902. package/dist/ui-library/p-53a13db5.entry.js +0 -2
  903. package/dist/ui-library/p-53a13db5.entry.js.map +0 -1
  904. package/dist/ui-library/p-559c87f0.entry.js +0 -2
  905. package/dist/ui-library/p-559c87f0.entry.js.map +0 -1
  906. package/dist/ui-library/p-611e1978.entry.js.map +0 -1
  907. package/dist/ui-library/p-63703ba3.entry.js.map +0 -1
  908. package/dist/ui-library/p-6403fd87.entry.js +0 -2
  909. package/dist/ui-library/p-6403fd87.entry.js.map +0 -1
  910. package/dist/ui-library/p-6433c0da.entry.js.map +0 -1
  911. package/dist/ui-library/p-6d75f216.entry.js.map +0 -1
  912. package/dist/ui-library/p-73597d13.entry.js.map +0 -1
  913. package/dist/ui-library/p-79eee01b.js +0 -2
  914. package/dist/ui-library/p-79eee01b.js.map +0 -1
  915. package/dist/ui-library/p-7e0cc4ae.entry.js.map +0 -1
  916. package/dist/ui-library/p-820c23f0.entry.js.map +0 -1
  917. package/dist/ui-library/p-835c3ff7.entry.js +0 -2
  918. package/dist/ui-library/p-835c3ff7.entry.js.map +0 -1
  919. package/dist/ui-library/p-8a970a40.entry.js.map +0 -1
  920. package/dist/ui-library/p-90824648.entry.js +0 -2
  921. package/dist/ui-library/p-90824648.entry.js.map +0 -1
  922. package/dist/ui-library/p-90dc6af4.entry.js.map +0 -1
  923. package/dist/ui-library/p-9328e5bc.entry.js.map +0 -1
  924. package/dist/ui-library/p-97323ad7.entry.js.map +0 -1
  925. package/dist/ui-library/p-9a860acc.js +0 -2
  926. package/dist/ui-library/p-9a860acc.js.map +0 -1
  927. package/dist/ui-library/p-9d1d222f.entry.js +0 -2
  928. package/dist/ui-library/p-9d1d222f.entry.js.map +0 -1
  929. package/dist/ui-library/p-a1d4f6cf.entry.js.map +0 -1
  930. package/dist/ui-library/p-ac4f4d45.js +0 -3
  931. package/dist/ui-library/p-ac4f4d45.js.map +0 -1
  932. package/dist/ui-library/p-af793d04.entry.js.map +0 -1
  933. package/dist/ui-library/p-b0e5658f.entry.js +0 -2
  934. package/dist/ui-library/p-b0e5658f.entry.js.map +0 -1
  935. package/dist/ui-library/p-b1e66136.js +0 -2
  936. package/dist/ui-library/p-b1e66136.js.map +0 -1
  937. package/dist/ui-library/p-b4dfb7cf.js +0 -2
  938. package/dist/ui-library/p-b4dfb7cf.js.map +0 -1
  939. package/dist/ui-library/p-b997e43c.entry.js +0 -2
  940. package/dist/ui-library/p-b997e43c.entry.js.map +0 -1
  941. package/dist/ui-library/p-baa03951.entry.js.map +0 -1
  942. package/dist/ui-library/p-c0cb6436.entry.js +0 -2
  943. package/dist/ui-library/p-c0cb6436.entry.js.map +0 -1
  944. package/dist/ui-library/p-c30f9e0b.entry.js.map +0 -1
  945. package/dist/ui-library/p-c349d1d4.entry.js.map +0 -1
  946. package/dist/ui-library/p-c53a63f9.entry.js +0 -2
  947. package/dist/ui-library/p-c53a63f9.entry.js.map +0 -1
  948. package/dist/ui-library/p-c640c2d8.entry.js +0 -2
  949. package/dist/ui-library/p-c640c2d8.entry.js.map +0 -1
  950. package/dist/ui-library/p-c94d0b07.entry.js +0 -2
  951. package/dist/ui-library/p-c94d0b07.entry.js.map +0 -1
  952. package/dist/ui-library/p-d12c6092.js +0 -2
  953. package/dist/ui-library/p-d12c6092.js.map +0 -1
  954. package/dist/ui-library/p-d5633a29.entry.js.map +0 -1
  955. package/dist/ui-library/p-dd3c76f1.entry.js.map +0 -1
  956. package/dist/ui-library/p-df655bc9.entry.js +0 -2
  957. package/dist/ui-library/p-df655bc9.entry.js.map +0 -1
  958. package/dist/ui-library/p-e19a6c95.entry.js.map +0 -1
  959. package/dist/ui-library/p-eb8f05a9.js.map +0 -1
  960. package/dist/ui-library/p-edc96efc.entry.js +0 -2
  961. package/dist/ui-library/p-edc96efc.entry.js.map +0 -1
  962. package/dist/ui-library/p-f18ba86f.entry.js +0 -2
  963. package/dist/ui-library/p-f18ba86f.entry.js.map +0 -1
  964. package/dist/ui-library/p-f4938771.entry.js +0 -2
  965. package/dist/ui-library/p-f4938771.entry.js.map +0 -1
  966. package/dist/ui-library/p-f70e2403.entry.js +0 -2
  967. package/dist/ui-library/p-f70e2403.entry.js.map +0 -1
  968. package/dist/ui-library/p-f9d345e0.entry.js +0 -2
  969. package/dist/ui-library/p-f9d345e0.entry.js.map +0 -1
  970. package/dist/ui-library/p-fed07a1f.entry.js +0 -2
  971. package/dist/ui-library/p-fed07a1f.entry.js.map +0 -1
  972. package/dist/ui-library/p-ff0257bf.entry.js +0 -2
  973. package/dist/ui-library/p-ff0257bf.entry.js.map +0 -1
@@ -1,13 +1,12 @@
1
- import { h } from '@stencil/core';
2
- import { getTextContent } from '../../utils/slot';
3
- import { EventListeners } from '../../utils/event-listeners';
4
- import { debounce } from '../../utils/execution-control';
1
+ import { h } from "@stencil/core";
2
+ import { getTextContent } from "../../utils/slot";
3
+ import { EventListeners } from "../../utils/event-listeners";
4
+ import { debounce } from "../../utils/execution-control";
5
5
  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'); };
6
6
  const isSIXMenuItemElement = (el) => (el === null || el === void 0 ? void 0 : el.tagName.toLowerCase()) === 'six-menu-item';
7
7
  const mapToMenuItem = ({ value, label }) => h("six-menu-item", { value: value }, label);
8
8
  const DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING = 5;
9
9
  const DEFAULT_SIX_MENU_ITEM_HEIGHT = 64;
10
- const ITEMS_SHOWN_NOT_SET = undefined;
11
10
  /**
12
11
  * @since 1.0
13
12
  * @status stable
@@ -23,12 +22,14 @@ export class SixMenu {
23
22
  this.eventListeners = new EventListeners();
24
23
  this.typeToSelectString = '';
25
24
  this.handleScrolling = () => {
25
+ if (this.menuWrapper == null)
26
+ return;
26
27
  // for performance improvements we only update the DOM if the scrollRatio change "enough"
27
28
  this.scrollingIndex = Math.floor(this.menuWrapper.scrollTop / this.sixMenuItemHeight);
28
29
  };
29
30
  this.removeBoxShadow = false;
30
31
  this.items = null;
31
- this.itemsShown = ITEMS_SHOWN_NOT_SET;
32
+ this.itemsShown = undefined;
32
33
  this.virtualScroll = false;
33
34
  this.itemSize = 10;
34
35
  this.scrollingDebounce = 15;
@@ -59,6 +60,8 @@ export class SixMenu {
59
60
  async typeToSelect(key) {
60
61
  var _a;
61
62
  clearTimeout(this.typeToSelectTimeout);
63
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
64
+ // @ts-ignore
62
65
  this.typeToSelectTimeout = setTimeout(() => (this.typeToSelectString = ''), 750);
63
66
  this.typeToSelectString += key.toLowerCase();
64
67
  const items = this.getItems();
@@ -73,36 +76,39 @@ export class SixMenu {
73
76
  }
74
77
  getItemsShown() {
75
78
  var _a;
76
- const defaultItemsShown = this.virtualScroll
77
- ? DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING
78
- : ITEMS_SHOWN_NOT_SET;
79
+ const defaultItemsShown = this.virtualScroll ? DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING : 0;
79
80
  return (_a = this.itemsShown) !== null && _a !== void 0 ? _a : defaultItemsShown;
80
81
  }
81
82
  setupForVirtualScrollingAfterRendering() {
82
83
  var _a, _b;
83
- if (!this.virtualScroll) {
84
+ if (!this.virtualScroll || this.menuWrapper == null)
84
85
  return;
85
- }
86
86
  this.eventListeners.add(this.menuWrapper, 'scroll', debounce(this.handleScrolling, this.scrollingDebounce));
87
87
  // set menu height to proper height once the item is rendered.
88
88
  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;
89
- if (menuItemHeight && menuItemHeight > 0) {
89
+ if (menuItemHeight != null && menuItemHeight > 0) {
90
90
  this.sixMenuItemHeight = menuItemHeight;
91
91
  }
92
92
  }
93
93
  getItems() {
94
- if (this.items !== null && this.items !== undefined) {
94
+ if (this.menu == null)
95
+ return [];
96
+ if (this.items != null) {
95
97
  return this.items.map(mapToMenuItem);
96
98
  }
97
99
  const slot = this.menu.querySelector('slot');
100
+ if (slot == null)
101
+ return [];
98
102
  return [...slot.assignedElements({ flatten: true })].filter((el) => isSIXMenuItemElement(el) && !el.disabled);
99
103
  }
100
104
  getActiveItemIndex() {
101
105
  const items = this.getItems();
102
106
  const selectedItem = this.getActiveItem();
103
- const itemIndex = items.indexOf(selectedItem);
104
- if (itemIndex > -1) {
105
- return itemIndex;
107
+ if (selectedItem != null) {
108
+ const itemIndex = items.indexOf(selectedItem);
109
+ if (itemIndex > -1) {
110
+ return itemIndex;
111
+ }
106
112
  }
107
113
  const sixMenuItems = this.extractItemsFromDOM();
108
114
  return sixMenuItems.findIndex(isFocusedMenuItem);
@@ -110,17 +116,17 @@ export class SixMenu {
110
116
  getActiveItem() {
111
117
  var _a;
112
118
  const activeElement = this.getItems().find((i) => i === document.activeElement);
113
- if (activeElement) {
119
+ if (activeElement != null) {
114
120
  return activeElement;
115
121
  }
116
122
  return (_a = this.extractItemsFromDOM()) === null || _a === void 0 ? void 0 : _a.find(isFocusedMenuItem);
117
123
  }
118
124
  extractItemsFromDOM() {
119
125
  var _a, _b;
120
- return Array.from((_b = (_a = this.host) === null || _a === void 0 ? void 0 : _a.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelectorAll('six-menu-item'));
126
+ return Array.from((_b = (_a = this.host.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('six-menu-item')) !== null && _b !== void 0 ? _b : []);
121
127
  }
122
128
  setActiveItem(item) {
123
- item.setFocus();
129
+ item === null || item === void 0 ? void 0 : item.setFocus();
124
130
  }
125
131
  handleClick(event) {
126
132
  const target = event.target;
@@ -134,7 +140,7 @@ export class SixMenu {
134
140
  if (event.key === 'Enter') {
135
141
  const activeItem = this.getActiveItem();
136
142
  event.preventDefault();
137
- if (activeItem) {
143
+ if (activeItem != null) {
138
144
  this.sixMenuItemSelected.emit({ name: activeItem.value, item: activeItem });
139
145
  }
140
146
  }
@@ -146,7 +152,7 @@ export class SixMenu {
146
152
  if (['ArrowDown', 'ArrowUp', 'Home', 'End'].includes(event.key)) {
147
153
  const items = this.items === null ? this.getItems() : this.extractItemsFromDOM();
148
154
  let indexOfActiveItem = this.getActiveItemIndex();
149
- if (items.length) {
155
+ if (items.length > 0) {
150
156
  event.preventDefault();
151
157
  if (event.key === 'ArrowDown') {
152
158
  indexOfActiveItem++;
@@ -171,10 +177,11 @@ export class SixMenu {
171
177
  void this.typeToSelect(event.key);
172
178
  }
173
179
  getMenuWrapperStyle() {
180
+ var _a;
174
181
  const styles = {};
175
182
  if (this.getItemsShown() > 0) {
176
183
  // calculate the proper height to show the correct number of items
177
- styles.height = `${this.getItemsShown() * this.sixMenuItemHeight}px`;
184
+ styles.height = `${((_a = this.getItemsShown()) !== null && _a !== void 0 ? _a : 0) * this.sixMenuItemHeight}px`;
178
185
  }
179
186
  return Object.assign({}, styles);
180
187
  }
@@ -248,11 +255,12 @@ export class SixMenu {
248
255
  "mutable": false,
249
256
  "complexType": {
250
257
  "original": "SixMenuItemData[] | null",
251
- "resolved": "SixMenuItemData[]",
258
+ "resolved": "SixMenuItemData[] | null",
252
259
  "references": {
253
260
  "SixMenuItemData": {
254
261
  "location": "local",
255
- "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-menu/six-menu.tsx"
262
+ "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-menu/six-menu.tsx",
263
+ "id": "src/components/six-menu/six-menu.tsx::SixMenuItemData"
256
264
  }
257
265
  }
258
266
  },
@@ -269,18 +277,17 @@ export class SixMenu {
269
277
  "mutable": false,
270
278
  "complexType": {
271
279
  "original": "number",
272
- "resolved": "number",
280
+ "resolved": "number | undefined",
273
281
  "references": {}
274
282
  },
275
283
  "required": false,
276
284
  "optional": true,
277
285
  "docs": {
278
286
  "tags": [],
279
- "text": "Defines how many items should be shown. If the number of items is larger than this properties a scrollbar will be shown"
287
+ "text": "Defines how many items should be shown. If the number of items is larger than this property a scrollbar will be shown"
280
288
  },
281
289
  "attribute": "items-shown",
282
- "reflect": false,
283
- "defaultValue": "ITEMS_SHOWN_NOT_SET"
290
+ "reflect": false
284
291
  },
285
292
  "virtualScroll": {
286
293
  "type": "boolean",
@@ -361,7 +368,8 @@ export class SixMenu {
361
368
  "references": {
362
369
  "SixMenuItemSelectedPayload": {
363
370
  "location": "local",
364
- "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-menu/six-menu.tsx"
371
+ "path": "/home/runner/work/six-webcomponents/six-webcomponents/libraries/ui-library/src/components/six-menu/six-menu.tsx",
372
+ "id": "src/components/six-menu/six-menu.tsx::SixMenuItemSelectedPayload"
365
373
  }
366
374
  }
367
375
  }
@@ -378,10 +386,12 @@ export class SixMenu {
378
386
  }],
379
387
  "references": {
380
388
  "Promise": {
381
- "location": "global"
389
+ "location": "global",
390
+ "id": "global::Promise"
382
391
  },
383
392
  "HTMLSlotElement": {
384
- "location": "global"
393
+ "location": "global",
394
+ "id": "global::HTMLSlotElement"
385
395
  }
386
396
  },
387
397
  "return": "Promise<void>"
@@ -1 +1 @@
1
- {"version":3,"file":"six-menu.js","sourceRoot":"","sources":["../../../src/components/six-menu/six-menu.tsx"],"names":[],"mappings":"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","sourcesContent":["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 }) => <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\nconst ITEMS_SHOWN_NOT_SET = undefined;\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 menu: HTMLElement;\n menuWrapper: HTMLElement;\n typeToSelectString = '';\n typeToSelectTimeout: NodeJS.Timeout;\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: boolean = 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 properties a scrollbar will be shown */\n @Prop() itemsShown?: number = ITEMS_SHOWN_NOT_SET;\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: boolean = 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: number = 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: number = 15;\n\n /**\n * Used to calculate which items should be rendered in the DOM\n */\n @State()\n private scrollingIndex: number = 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 hight 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 // 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 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() {\n const defaultItemsShown = this.virtualScroll\n ? DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING\n : ITEMS_SHOWN_NOT_SET;\n\n return this.itemsShown ?? defaultItemsShown;\n }\n\n private setupForVirtualScrollingAfterRendering() {\n if (!this.virtualScroll) {\n return;\n }\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 && menuItemHeight > 0) {\n this.sixMenuItemHeight = menuItemHeight;\n }\n }\n\n getItems() {\n if (this.items !== null && this.items !== undefined) {\n return this.items.map(mapToMenuItem);\n }\n\n const slot = this.menu.querySelector('slot');\n return [...slot.assignedElements({ flatten: true })].filter((el) => isSIXMenuItemElement(el) && !el.disabled);\n }\n\n private getActiveItemIndex() {\n const items = this.getItems();\n const selectedItem = this.getActiveItem();\n const itemIndex = items.indexOf(selectedItem);\n\n if (itemIndex > -1) {\n return itemIndex;\n }\n\n const sixMenuItems = this.extractItemsFromDOM();\n return sixMenuItems.findIndex(isFocusedMenuItem);\n }\n\n getActiveItem() {\n const activeElement = this.getItems().find((i) => i === document.activeElement);\n\n if (activeElement) {\n return activeElement;\n }\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 setActiveItem(item: HTMLSixMenuItemElement) {\n item.setFocus();\n }\n\n 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 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) {\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) {\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\n if (this.getItemsShown() > 0) {\n // calculate the proper height to show the correct number of items\n styles.height = `${this.getItemsShown() * this.sixMenuItemHeight}px`;\n }\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"]}
1
+ {"version":3,"file":"six-menu.js","sourceRoot":"","sources":["../../../src/components/six-menu/six-menu.tsx"],"names":[],"mappings":"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","sourcesContent":["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"]}
@@ -0,0 +1,93 @@
1
+ import { newSpecPage } from "@stencil/core/testing";
2
+ import { SixMenu } from "../six-menu";
3
+ describe('six-menu', () => {
4
+ it('renders', async () => {
5
+ const page = await newSpecPage({
6
+ components: [SixMenu],
7
+ html: `<six-menu></six-menu>`,
8
+ });
9
+ expect(page.root).toEqualHtml(`
10
+ <six-menu>
11
+ <mock:shadow-root>
12
+ <div class="menu" part="wrapper">
13
+ <div part="base" role="menu" tabindex="0">
14
+ <slot></slot>
15
+ </div>
16
+ </div>
17
+ </mock:shadow-root>
18
+ </six-menu>
19
+ `);
20
+ });
21
+ it('renders without box-shadow', async () => {
22
+ const page = await newSpecPage({
23
+ components: [SixMenu],
24
+ html: `<six-menu remove-box-shadow></six-menu>`,
25
+ });
26
+ expect(page.root).toEqualHtml(`
27
+ <six-menu remove-box-shadow>
28
+ <mock:shadow-root>
29
+ <div class="menu menu--noshadow" part="wrapper">
30
+ <div part="base" role="menu" tabindex="0">
31
+ <slot></slot>
32
+ </div>
33
+ </div>
34
+ </mock:shadow-root>
35
+ </six-menu>
36
+ `);
37
+ });
38
+ it('renders virtual scrolling', async () => {
39
+ const page = await newSpecPage({
40
+ components: [SixMenu],
41
+ html: `<six-menu virtual-scroll></six-menu>`,
42
+ });
43
+ expect(page.root).toEqualHtml(`
44
+ <six-menu virtual-scroll="">
45
+ <mock:shadow-root>
46
+ <div class="menu menu__wrapper--scrollable" part="wrapper" style="height: 320px;">
47
+ <div part="base" role="menu" tabindex="0" style="transform: translateY(0px);">
48
+ <slot></slot>
49
+ </div>
50
+ <div></div>
51
+ </div>
52
+ </mock:shadow-root>
53
+ </six-menu>
54
+ `);
55
+ });
56
+ it('renders dynamically added items', async () => {
57
+ // given
58
+ const page = await newSpecPage({
59
+ components: [SixMenu],
60
+ html: `<six-menu></six-menu>`,
61
+ });
62
+ // when
63
+ if (page.root != null) {
64
+ page.root.items = Array.from(Array(3).keys()).map((idx) => ({
65
+ label: `label ${idx}`,
66
+ value: `value ${idx}`,
67
+ }));
68
+ }
69
+ await page.waitForChanges();
70
+ // then
71
+ expect(page.root).toEqualHtml(`
72
+ <six-menu>
73
+ <mock:shadow-root>
74
+ <div class="menu" part="wrapper">
75
+ <div part="base" role="menu" tabindex="0">
76
+ <slot></slot>
77
+ <six-menu-item value="value 0">
78
+ label 0
79
+ </six-menu-item>
80
+ <six-menu-item value="value 1">
81
+ label 1
82
+ </six-menu-item>
83
+ <six-menu-item value="value 2">
84
+ label 2
85
+ </six-menu-item>
86
+ </div>
87
+ </div>
88
+ </mock:shadow-root>
89
+ </six-menu>
90
+ `);
91
+ });
92
+ });
93
+ //# sourceMappingURL=six-menu.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"six-menu.spec.js","sourceRoot":"","sources":["../../../../src/components/six-menu/test/six-menu.spec.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;EACxB,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;IACvB,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;MACrB,IAAI,EAAE,uBAAuB;KAC9B,CAAC,CAAC;IACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;KAU7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;IAC1C,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;MACrB,IAAI,EAAE,yCAAyC;KAChD,CAAC,CAAC;IACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;KAU7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;IACzC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;MACrB,IAAI,EAAE,sCAAsC;KAC7C,CAAC,CAAC;IACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;KAW7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;IAC/C,QAAQ;IACR,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;MACrB,IAAI,EAAE,uBAAuB;KAC9B,CAAC,CAAC;IAEH,OAAO;IACP,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,EAAE;MACrB,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAC1D,KAAK,EAAE,SAAS,GAAG,EAAE;QACrB,KAAK,EAAE,SAAS,GAAG,EAAE;OACtB,CAAC,CAAC,CAAC;KACL;IACD,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;IAE5B,OAAO;IACP,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;;;;;KAmB7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from '@stencil/core/testing';\nimport { SixMenu } from '../six-menu';\n\ndescribe('six-menu', () => {\n it('renders', async () => {\n const page = await newSpecPage({\n components: [SixMenu],\n html: `<six-menu></six-menu>`,\n });\n expect(page.root).toEqualHtml(`\n <six-menu>\n <mock:shadow-root>\n <div class=\"menu\" part=\"wrapper\">\n <div part=\"base\" role=\"menu\" tabindex=\"0\">\n <slot></slot>\n </div>\n </div>\n </mock:shadow-root>\n </six-menu>\n `);\n });\n\n it('renders without box-shadow', async () => {\n const page = await newSpecPage({\n components: [SixMenu],\n html: `<six-menu remove-box-shadow></six-menu>`,\n });\n expect(page.root).toEqualHtml(`\n <six-menu remove-box-shadow>\n <mock:shadow-root>\n <div class=\"menu menu--noshadow\" part=\"wrapper\">\n <div part=\"base\" role=\"menu\" tabindex=\"0\">\n <slot></slot>\n </div>\n </div>\n </mock:shadow-root>\n </six-menu>\n `);\n });\n\n it('renders virtual scrolling', async () => {\n const page = await newSpecPage({\n components: [SixMenu],\n html: `<six-menu virtual-scroll></six-menu>`,\n });\n expect(page.root).toEqualHtml(`\n <six-menu virtual-scroll=\"\">\n <mock:shadow-root>\n <div class=\"menu menu__wrapper--scrollable\" part=\"wrapper\" style=\"height: 320px;\">\n <div part=\"base\" role=\"menu\" tabindex=\"0\" style=\"transform: translateY(0px);\">\n <slot></slot>\n </div>\n <div></div>\n </div>\n </mock:shadow-root>\n </six-menu>\n `);\n });\n\n it('renders dynamically added items', async () => {\n // given\n const page = await newSpecPage({\n components: [SixMenu],\n html: `<six-menu></six-menu>`,\n });\n\n // when\n if (page.root != null) {\n page.root.items = Array.from(Array(3).keys()).map((idx) => ({\n label: `label ${idx}`,\n value: `value ${idx}`,\n }));\n }\n await page.waitForChanges();\n\n // then\n expect(page.root).toEqualHtml(`\n <six-menu>\n <mock:shadow-root>\n <div class=\"menu\" part=\"wrapper\">\n <div part=\"base\" role=\"menu\" tabindex=\"0\">\n <slot></slot>\n <six-menu-item value=\"value 0\">\n label 0\n </six-menu-item>\n <six-menu-item value=\"value 1\">\n label 1\n </six-menu-item>\n <six-menu-item value=\"value 2\">\n label 2\n </six-menu-item>\n </div>\n </div>\n </mock:shadow-root>\n </six-menu>\n `);\n });\n});\n"]}
@@ -1,4 +1,4 @@
1
- import { h } from '@stencil/core';
1
+ import { h } from "@stencil/core";
2
2
  /**
3
3
  * @since 1.0
4
4
  * @status stable
@@ -0,0 +1,18 @@
1
+ import { newSpecPage } from "@stencil/core/testing";
2
+ import { SixMenuDivider } from "../six-menu-divider";
3
+ describe('six-menu-divider', () => {
4
+ it('renders', async () => {
5
+ const page = await newSpecPage({
6
+ components: [SixMenuDivider],
7
+ html: `<six-menu-divider></six-menu-divider>`,
8
+ });
9
+ expect(page.root).toEqualHtml(`
10
+ <six-menu-divider>
11
+ <mock:shadow-root>
12
+ <div part="base" class="menu-divider" role="separator" aria-hidden="true" />
13
+ </mock:shadow-root>
14
+ </six-menu-divider>
15
+ `);
16
+ });
17
+ });
18
+ //# sourceMappingURL=six-menu-divider.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"six-menu-divider.spec.js","sourceRoot":"","sources":["../../../../src/components/six-menu-divider/test/six-menu-divider.spec.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAErD,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;EAChC,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;IACvB,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,cAAc,CAAC;MAC5B,IAAI,EAAE,uCAAuC;KAC9C,CAAC,CAAC;IACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;KAM7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from '@stencil/core/testing';\nimport { SixMenuDivider } from '../six-menu-divider';\n\ndescribe('six-menu-divider', () => {\n it('renders', async () => {\n const page = await newSpecPage({\n components: [SixMenuDivider],\n html: `<six-menu-divider></six-menu-divider>`,\n });\n expect(page.root).toEqualHtml(`\n <six-menu-divider>\n <mock:shadow-root>\n <div part=\"base\" class=\"menu-divider\" role=\"separator\" aria-hidden=\"true\" />\n </mock:shadow-root>\n </six-menu-divider>\n `);\n });\n});\n"]}
@@ -1,5 +1,5 @@
1
- import { h } from '@stencil/core';
2
- import { getTextContent } from '../../utils/slot';
1
+ import { h } from "@stencil/core";
2
+ import { getTextContent } from "../../utils/slot";
3
3
  /**
4
4
  * @since 1.0
5
5
  * @status stable
@@ -31,11 +31,13 @@ export class SixMenuItem {
31
31
  }
32
32
  /** Sets focus on the button. */
33
33
  async setFocus(options) {
34
- this.menuItem.focus(options);
34
+ var _a;
35
+ (_a = this.menuItem) === null || _a === void 0 ? void 0 : _a.focus(options);
35
36
  }
36
37
  /** Removes focus from the button. */
37
38
  async removeFocus() {
38
- this.menuItem.blur();
39
+ var _a;
40
+ (_a = this.menuItem) === null || _a === void 0 ? void 0 : _a.blur();
39
41
  }
40
42
  /** Returns a text label based on the contents of the menu item's default slot. */
41
43
  getTextLabel() {
@@ -48,10 +50,10 @@ export class SixMenuItem {
48
50
  this.hasFocus = true;
49
51
  }
50
52
  handleMouseEnter() {
51
- this.setFocus();
53
+ return this.setFocus();
52
54
  }
53
55
  handleMouseLeave() {
54
- this.removeFocus();
56
+ return this.removeFocus();
55
57
  }
56
58
  render() {
57
59
  return (h("div", { ref: (el) => (this.menuItem = el), part: "base", class: {
@@ -59,7 +61,7 @@ export class SixMenuItem {
59
61
  'menu-item--checked': this.checked,
60
62
  'menu-item--disabled': this.disabled,
61
63
  'menu-item--focused': this.hasFocus,
62
- }, role: "menuitem", "aria-disabled": this.disabled ? 'true' : 'false', "aria-checked": this.checked ? 'true' : 'false', tabIndex: !this.disabled ? 0 : null, onFocus: this.handleFocus, onBlur: this.handleBlur, onMouseEnter: this.handleMouseEnter, onMouseLeave: this.handleMouseLeave }, h("span", { part: "prefix", class: "menu-item__prefix" }, h("slot", { name: "prefix" })), h("span", { part: "label", class: "menu-item__label" }, h("slot", { ref: (el) => (this.defaultSlot = el) })), h("span", { part: "suffix", class: "menu-item__suffix" }, h("slot", { name: "suffix" })), h("span", { part: "checked-icon", class: "menu-item__check" }, h("six-icon", { size: "small", "aria-hidden": "true" }, "check"))));
64
+ }, role: "menuitem", "aria-disabled": this.disabled ? 'true' : 'false', "aria-checked": this.checked ? 'true' : 'false', tabIndex: !this.disabled ? 0 : undefined, onFocus: this.handleFocus, onBlur: this.handleBlur, onMouseEnter: this.handleMouseEnter, onMouseLeave: this.handleMouseLeave }, h("span", { part: "prefix", class: "menu-item__prefix" }, h("slot", { name: "prefix" })), h("span", { part: "label", class: "menu-item__label" }, h("slot", { ref: (el) => (this.defaultSlot = el) })), h("span", { part: "suffix", class: "menu-item__suffix" }, h("slot", { name: "suffix" })), h("span", { part: "checked-icon", class: "menu-item__check" }, h("six-icon", { size: "small", "aria-hidden": "true" }, "check"))));
63
65
  }
64
66
  static get is() { return "six-menu-item"; }
65
67
  static get encapsulation() { return "shadow"; }
@@ -147,10 +149,12 @@ export class SixMenuItem {
147
149
  }],
148
150
  "references": {
149
151
  "Promise": {
150
- "location": "global"
152
+ "location": "global",
153
+ "id": "global::Promise"
151
154
  },
152
155
  "FocusOptions": {
153
- "location": "global"
156
+ "location": "global",
157
+ "id": "global::FocusOptions"
154
158
  }
155
159
  },
156
160
  "return": "Promise<void>"
@@ -166,7 +170,8 @@ export class SixMenuItem {
166
170
  "parameters": [],
167
171
  "references": {
168
172
  "Promise": {
169
- "location": "global"
173
+ "location": "global",
174
+ "id": "global::Promise"
170
175
  }
171
176
  },
172
177
  "return": "Promise<void>"
@@ -182,7 +187,8 @@ export class SixMenuItem {
182
187
  "parameters": [],
183
188
  "references": {
184
189
  "Promise": {
185
- "location": "global"
190
+ "location": "global",
191
+ "id": "global::Promise"
186
192
  }
187
193
  },
188
194
  "return": "Promise<string>"
@@ -1 +1 @@
1
- {"version":3,"file":"six-menu-item.js","sourceRoot":"","sources":["../../../src/components/six-menu-item/six-menu-item.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Method, Prop, State, h } from '@stencil/core';\nimport { getTextContent } from '../../utils/slot';\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 item's label.\n * @slot prefix - Used to prepend an icon or similar element to the menu item.\n * @slot suffix - Used to append an icon or similar element to the menu item.\n *\n * @part base - The component's base wrapper.\n * @part checked-icon - The container that wraps the checked icon.\n * @part prefix - The prefix container.\n * @part label - The menu item label.\n * @part suffix - The suffix container.\n */\n\n@Component({\n tag: 'six-menu-item',\n styleUrl: 'six-menu-item.scss',\n shadow: true,\n})\nexport class SixMenuItem {\n menuItem: HTMLElement;\n defaultSlot: HTMLSlotElement;\n\n @State() hasFocus = false;\n\n /** Set to true to draw the item in a checked state. */\n @Prop({ reflect: true }) checked = false;\n\n /** A unique value to store in the menu item. This can be used as a way to identify menu items when selected. */\n @Prop({ reflect: true }) value = '';\n\n /** Set to true to draw the menu item in a disabled state. */\n @Prop({ reflect: true }) disabled = false;\n\n connectedCallback() {\n this.handleBlur = this.handleBlur.bind(this);\n this.handleFocus = this.handleFocus.bind(this);\n this.handleMouseEnter = this.handleMouseEnter.bind(this);\n this.handleMouseLeave = this.handleMouseLeave.bind(this);\n }\n\n /** Sets focus on the button. */\n @Method()\n async setFocus(options?: FocusOptions) {\n this.menuItem.focus(options);\n }\n\n /** Removes focus from the button. */\n @Method()\n async removeFocus() {\n this.menuItem.blur();\n }\n\n /** Returns a text label based on the contents of the menu item's default slot. */\n @Method()\n getTextLabel() {\n return Promise.resolve(getTextContent(this.defaultSlot));\n }\n\n handleBlur() {\n this.hasFocus = false;\n }\n\n handleFocus() {\n this.hasFocus = true;\n }\n\n handleMouseEnter() {\n this.setFocus();\n }\n\n handleMouseLeave() {\n this.removeFocus();\n }\n\n render() {\n return (\n <div\n ref={(el) => (this.menuItem = el)}\n part=\"base\"\n class={{\n 'menu-item': true,\n 'menu-item--checked': this.checked,\n 'menu-item--disabled': this.disabled,\n 'menu-item--focused': this.hasFocus,\n }}\n role=\"menuitem\"\n aria-disabled={this.disabled ? 'true' : 'false'}\n aria-checked={this.checked ? 'true' : 'false'}\n tabIndex={!this.disabled ? 0 : null}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n onMouseEnter={this.handleMouseEnter}\n onMouseLeave={this.handleMouseLeave}\n >\n <span part=\"prefix\" class=\"menu-item__prefix\">\n <slot name=\"prefix\" />\n </span>\n\n <span part=\"label\" class=\"menu-item__label\">\n <slot ref={(el) => (this.defaultSlot = el as HTMLSlotElement)} />\n </span>\n\n <span part=\"suffix\" class=\"menu-item__suffix\">\n <slot name=\"suffix\" />\n </span>\n\n <span part=\"checked-icon\" class=\"menu-item__check\">\n <six-icon size=\"small\" aria-hidden=\"true\">\n check\n </six-icon>\n </span>\n </div>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"six-menu-item.js","sourceRoot":"","sources":["../../../src/components/six-menu-item/six-menu-item.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, h, Method, Prop, State } from '@stencil/core';\nimport { getTextContent } from '../../utils/slot';\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 item's label.\n * @slot prefix - Used to prepend an icon or similar element to the menu item.\n * @slot suffix - Used to append an icon or similar element to the menu item.\n *\n * @part base - The component's base wrapper.\n * @part checked-icon - The container that wraps the checked icon.\n * @part prefix - The prefix container.\n * @part label - The menu item label.\n * @part suffix - The suffix container.\n */\n\n@Component({\n tag: 'six-menu-item',\n styleUrl: 'six-menu-item.scss',\n shadow: true,\n})\nexport class SixMenuItem {\n private menuItem?: HTMLElement;\n private defaultSlot?: HTMLSlotElement;\n\n @State() hasFocus = false;\n\n /** Set to true to draw the item in a checked state. */\n @Prop({ reflect: true }) checked = false;\n\n /** A unique value to store in the menu item. This can be used as a way to identify menu items when selected. */\n @Prop({ reflect: true }) value = '';\n\n /** Set to true to draw the menu item in a disabled state. */\n @Prop({ reflect: true }) disabled = false;\n\n connectedCallback() {\n this.handleBlur = this.handleBlur.bind(this);\n this.handleFocus = this.handleFocus.bind(this);\n this.handleMouseEnter = this.handleMouseEnter.bind(this);\n this.handleMouseLeave = this.handleMouseLeave.bind(this);\n }\n\n /** Sets focus on the button. */\n @Method()\n async setFocus(options?: FocusOptions) {\n this.menuItem?.focus(options);\n }\n\n /** Removes focus from the button. */\n @Method()\n async removeFocus() {\n this.menuItem?.blur();\n }\n\n /** Returns a text label based on the contents of the menu item's default slot. */\n @Method()\n getTextLabel() {\n return Promise.resolve(getTextContent(this.defaultSlot));\n }\n\n private handleBlur() {\n this.hasFocus = false;\n }\n\n private handleFocus() {\n this.hasFocus = true;\n }\n\n private handleMouseEnter() {\n return this.setFocus();\n }\n\n private handleMouseLeave() {\n return this.removeFocus();\n }\n\n render() {\n return (\n <div\n ref={(el) => (this.menuItem = el)}\n part=\"base\"\n class={{\n 'menu-item': true,\n 'menu-item--checked': this.checked,\n 'menu-item--disabled': this.disabled,\n 'menu-item--focused': this.hasFocus,\n }}\n role=\"menuitem\"\n aria-disabled={this.disabled ? 'true' : 'false'}\n aria-checked={this.checked ? 'true' : 'false'}\n tabIndex={!this.disabled ? 0 : undefined}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n onMouseEnter={this.handleMouseEnter}\n onMouseLeave={this.handleMouseLeave}\n >\n <span part=\"prefix\" class=\"menu-item__prefix\">\n <slot name=\"prefix\" />\n </span>\n\n <span part=\"label\" class=\"menu-item__label\">\n <slot ref={(el) => (this.defaultSlot = el as HTMLSlotElement)} />\n </span>\n\n <span part=\"suffix\" class=\"menu-item__suffix\">\n <slot name=\"suffix\" />\n </span>\n\n <span part=\"checked-icon\" class=\"menu-item__check\">\n <six-icon size=\"small\" aria-hidden=\"true\">\n check\n </six-icon>\n </span>\n </div>\n );\n }\n}\n"]}
@@ -0,0 +1,33 @@
1
+ import { newSpecPage } from "@stencil/core/testing";
2
+ import { SixMenuItem } from "../six-menu-item";
3
+ describe('six-menu-item', () => {
4
+ it('renders', async () => {
5
+ const page = await newSpecPage({
6
+ components: [SixMenuItem],
7
+ html: `<six-menu-item></six-menu-item>`,
8
+ });
9
+ expect(page.root).toEqualHtml(`
10
+ <six-menu-item value="">
11
+ <mock:shadow-root>
12
+ <div aria-checked="false" aria-disabled="false" class="menu-item" part="base" role="menuitem" tabindex="0">
13
+ <span class="menu-item__prefix" part="prefix">
14
+ <slot name="prefix"></slot>
15
+ </span>
16
+ <span class="menu-item__label" part="label">
17
+ <slot></slot>
18
+ </span>
19
+ <span class="menu-item__suffix" part="suffix">
20
+ <slot name="suffix"></slot>
21
+ </span>
22
+ <span class="menu-item__check" part="checked-icon">
23
+ <six-icon aria-hidden="true" size="small">
24
+ check
25
+ </six-icon>
26
+ </span>
27
+ </div>
28
+ </mock:shadow-root>
29
+ </six-menu-item>
30
+ `);
31
+ });
32
+ });
33
+ //# sourceMappingURL=six-menu-item.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"six-menu-item.spec.js","sourceRoot":"","sources":["../../../../src/components/six-menu-item/test/six-menu-item.spec.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;EAC7B,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;IACvB,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,WAAW,CAAC;MACzB,IAAI,EAAE,iCAAiC;KACxC,CAAC,CAAC;IACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;;;;;;;KAqB7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from '@stencil/core/testing';\nimport { SixMenuItem } from '../six-menu-item';\n\ndescribe('six-menu-item', () => {\n it('renders', async () => {\n const page = await newSpecPage({\n components: [SixMenuItem],\n html: `<six-menu-item></six-menu-item>`,\n });\n expect(page.root).toEqualHtml(`\n <six-menu-item value=\"\">\n <mock:shadow-root>\n <div aria-checked=\"false\" aria-disabled=\"false\" class=\"menu-item\" part=\"base\" role=\"menuitem\" tabindex=\"0\">\n <span class=\"menu-item__prefix\" part=\"prefix\">\n <slot name=\"prefix\"></slot>\n </span>\n <span class=\"menu-item__label\" part=\"label\">\n <slot></slot>\n </span>\n <span class=\"menu-item__suffix\" part=\"suffix\">\n <slot name=\"suffix\"></slot>\n </span>\n <span class=\"menu-item__check\" part=\"checked-icon\">\n <six-icon aria-hidden=\"true\" size=\"small\">\n check\n </six-icon>\n </span>\n </div>\n </mock:shadow-root>\n </six-menu-item>\n `);\n });\n});\n"]}
@@ -1,4 +1,4 @@
1
- import { h } from '@stencil/core';
1
+ import { h } from "@stencil/core";
2
2
  /**
3
3
  * @since 1.0
4
4
  * @status stable
@@ -0,0 +1,20 @@
1
+ import { newSpecPage } from "@stencil/core/testing";
2
+ import { SixMenuLabel } from "../six-menu-label";
3
+ describe('six-menu-label', () => {
4
+ it('renders', async () => {
5
+ const page = await newSpecPage({
6
+ components: [SixMenuLabel],
7
+ html: `<six-menu-label></six-menu-label>`,
8
+ });
9
+ expect(page.root).toEqualHtml(`
10
+ <six-menu-label>
11
+ <mock:shadow-root>
12
+ <div class="menu-label" part="base">
13
+ <slot></slot>
14
+ </div>
15
+ </mock:shadow-root>
16
+ </six-menu-label>
17
+ `);
18
+ });
19
+ });
20
+ //# sourceMappingURL=six-menu-label.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"six-menu-label.spec.js","sourceRoot":"","sources":["../../../../src/components/six-menu-label/test/six-menu-label.spec.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;EAC9B,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;IACvB,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;MAC1B,IAAI,EAAE,mCAAmC;KAC1C,CAAC,CAAC;IACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;KAQ7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from '@stencil/core/testing';\nimport { SixMenuLabel } from '../six-menu-label';\n\ndescribe('six-menu-label', () => {\n it('renders', async () => {\n const page = await newSpecPage({\n components: [SixMenuLabel],\n html: `<six-menu-label></six-menu-label>`,\n });\n expect(page.root).toEqualHtml(`\n <six-menu-label>\n <mock:shadow-root>\n <div class=\"menu-label\" part=\"base\">\n <slot></slot>\n </div>\n </mock:shadow-root>\n </six-menu-label>\n `);\n });\n});\n"]}