@six-group/ui-library 0.0.0-insider.562dfe9 → 0.0.0-insider.5c41912

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 (829) hide show
  1. package/dist/cjs/app-globals-3a1e7e63.js +7 -0
  2. package/dist/cjs/app-globals-3a1e7e63.js.map +1 -0
  3. package/dist/cjs/error-messages-6e8049a4.js +119 -0
  4. package/dist/cjs/error-messages-6e8049a4.js.map +1 -0
  5. package/dist/cjs/{form-control-f9bc25dd.js → form-control-de259450.js} +2 -2
  6. package/dist/cjs/{form-control-f9bc25dd.js.map → form-control-de259450.js.map} +1 -1
  7. package/dist/cjs/{index-3baddcdc.js → index-1f707a55.js} +127 -76
  8. package/dist/cjs/index-1f707a55.js.map +1 -0
  9. package/dist/cjs/index.cjs.js +54 -101
  10. package/dist/cjs/index.cjs.js.map +1 -1
  11. package/dist/cjs/loader.cjs.js +5 -3
  12. package/dist/cjs/loader.cjs.js.map +1 -1
  13. package/dist/cjs/{modal-3ce015be.js → modal-bd7fc5bc.js} +1 -18
  14. package/dist/cjs/modal-bd7fc5bc.js.map +1 -0
  15. package/dist/cjs/six-alert.cjs.entry.js +42 -9
  16. package/dist/cjs/six-alert.cjs.entry.js.map +1 -1
  17. package/dist/cjs/six-avatar.cjs.entry.js +5 -4
  18. package/dist/cjs/six-avatar.cjs.entry.js.map +1 -1
  19. package/dist/cjs/six-badge.cjs.entry.js +6 -5
  20. package/dist/cjs/six-badge.cjs.entry.js.map +1 -1
  21. package/dist/cjs/six-button.cjs.entry.js +7 -6
  22. package/dist/cjs/six-button.cjs.entry.js.map +1 -1
  23. package/dist/cjs/six-card.cjs.entry.js +5 -4
  24. package/dist/cjs/six-card.cjs.entry.js.map +1 -1
  25. package/dist/cjs/six-checkbox_2.cjs.entry.js +192 -0
  26. package/dist/cjs/six-checkbox_2.cjs.entry.js.map +1 -0
  27. package/dist/cjs/six-datepicker.cjs.entry.js +33 -6
  28. package/dist/cjs/six-datepicker.cjs.entry.js.map +1 -1
  29. package/dist/cjs/six-details.cjs.entry.js +7 -6
  30. package/dist/cjs/six-details.cjs.entry.js.map +1 -1
  31. package/dist/cjs/six-dialog.cjs.entry.js +16 -32
  32. package/dist/cjs/six-dialog.cjs.entry.js.map +1 -1
  33. package/dist/cjs/six-drawer.cjs.entry.js +15 -32
  34. package/dist/cjs/six-drawer.cjs.entry.js.map +1 -1
  35. package/dist/cjs/six-dropdown_2.cjs.entry.js +204 -130
  36. package/dist/cjs/six-dropdown_2.cjs.entry.js.map +1 -1
  37. package/dist/cjs/six-error-page.cjs.entry.js +4 -3
  38. package/dist/cjs/six-error-page.cjs.entry.js.map +1 -1
  39. package/dist/cjs/six-error.cjs.entry.js +4 -3
  40. package/dist/cjs/six-error.cjs.entry.js.map +1 -1
  41. package/dist/cjs/six-file-list-item.cjs.entry.js +6 -5
  42. package/dist/cjs/six-file-list-item.cjs.entry.js.map +1 -1
  43. package/dist/cjs/six-file-list.cjs.entry.js +4 -3
  44. package/dist/cjs/six-file-list.cjs.entry.js.map +1 -1
  45. package/dist/cjs/six-file-upload.cjs.entry.js +34 -9
  46. package/dist/cjs/six-file-upload.cjs.entry.js.map +1 -1
  47. package/dist/cjs/six-footer.cjs.entry.js +5 -4
  48. package/dist/cjs/six-footer.cjs.entry.js.map +1 -1
  49. package/dist/cjs/six-group-label.cjs.entry.js +7 -6
  50. package/dist/cjs/six-group-label.cjs.entry.js.map +1 -1
  51. package/dist/cjs/six-header.cjs.entry.js +25 -17
  52. package/dist/cjs/six-header.cjs.entry.js.map +1 -1
  53. package/dist/cjs/six-icon-button.cjs.entry.js +7 -6
  54. package/dist/cjs/six-icon-button.cjs.entry.js.map +1 -1
  55. package/dist/cjs/six-icon.cjs.entry.js +6 -5
  56. package/dist/cjs/six-icon.cjs.entry.js.map +1 -1
  57. package/dist/cjs/six-input.cjs.entry.js +11 -8
  58. package/dist/cjs/six-input.cjs.entry.js.map +1 -1
  59. package/dist/cjs/six-item-picker.cjs.entry.js +7 -6
  60. package/dist/cjs/six-item-picker.cjs.entry.js.map +1 -1
  61. package/dist/cjs/six-language-switcher.cjs.entry.js +11 -6
  62. package/dist/cjs/six-language-switcher.cjs.entry.js.map +1 -1
  63. package/dist/cjs/six-layout-grid.cjs.entry.js +4 -3
  64. package/dist/cjs/six-layout-grid.cjs.entry.js.map +1 -1
  65. package/dist/cjs/six-main-container.cjs.entry.js +4 -3
  66. package/dist/cjs/six-main-container.cjs.entry.js.map +1 -1
  67. package/dist/cjs/six-menu-divider.cjs.entry.js +5 -4
  68. package/dist/cjs/six-menu-divider.cjs.entry.js.map +1 -1
  69. package/dist/cjs/six-menu-label.cjs.entry.js +5 -4
  70. package/dist/cjs/six-menu-label.cjs.entry.js.map +1 -1
  71. package/dist/cjs/six-picto.cjs.entry.js +4 -3
  72. package/dist/cjs/six-picto.cjs.entry.js.map +1 -1
  73. package/dist/cjs/six-progress-bar.cjs.entry.js +6 -5
  74. package/dist/cjs/six-progress-bar.cjs.entry.js.map +1 -1
  75. package/dist/cjs/six-progress-ring.cjs.entry.js +5 -4
  76. package/dist/cjs/six-progress-ring.cjs.entry.js.map +1 -1
  77. package/dist/cjs/six-radio.cjs.entry.js +6 -5
  78. package/dist/cjs/six-radio.cjs.entry.js.map +1 -1
  79. package/dist/cjs/six-range.cjs.entry.js +18 -7
  80. package/dist/cjs/six-range.cjs.entry.js.map +1 -1
  81. package/dist/cjs/six-root.cjs.entry.js +4 -22
  82. package/dist/cjs/six-root.cjs.entry.js.map +1 -1
  83. package/dist/cjs/six-search-field.cjs.entry.js +5 -4
  84. package/dist/cjs/six-search-field.cjs.entry.js.map +1 -1
  85. package/dist/cjs/six-select.cjs.entry.js +305 -170
  86. package/dist/cjs/six-select.cjs.entry.js.map +1 -1
  87. package/dist/cjs/six-sidebar-item-group.cjs.entry.js +5 -4
  88. package/dist/cjs/six-sidebar-item-group.cjs.entry.js.map +1 -1
  89. package/dist/cjs/six-sidebar-item.cjs.entry.js +5 -4
  90. package/dist/cjs/six-sidebar-item.cjs.entry.js.map +1 -1
  91. package/dist/cjs/six-sidebar.cjs.entry.js +6 -5
  92. package/dist/cjs/six-sidebar.cjs.entry.js.map +1 -1
  93. package/dist/cjs/six-spinner.cjs.entry.js +4 -3
  94. package/dist/cjs/six-spinner.cjs.entry.js.map +1 -1
  95. package/dist/cjs/six-stage-indicator.cjs.entry.js +23 -0
  96. package/dist/cjs/six-stage-indicator.cjs.entry.js.map +1 -0
  97. package/dist/cjs/six-switch.cjs.entry.js +8 -7
  98. package/dist/cjs/six-switch.cjs.entry.js.map +1 -1
  99. package/dist/cjs/six-tab-group.cjs.entry.js +35 -9
  100. package/dist/cjs/six-tab-group.cjs.entry.js.map +1 -1
  101. package/dist/cjs/six-tab-panel.cjs.entry.js +5 -4
  102. package/dist/cjs/six-tab-panel.cjs.entry.js.map +1 -1
  103. package/dist/cjs/six-tab.cjs.entry.js +6 -5
  104. package/dist/cjs/six-tab.cjs.entry.js.map +1 -1
  105. package/dist/cjs/six-tag.cjs.entry.js +7 -6
  106. package/dist/cjs/six-tag.cjs.entry.js.map +1 -1
  107. package/dist/cjs/six-textarea.cjs.entry.js +8 -7
  108. package/dist/cjs/six-textarea.cjs.entry.js.map +1 -1
  109. package/dist/cjs/six-tile.cjs.entry.js +8 -7
  110. package/dist/cjs/six-tile.cjs.entry.js.map +1 -1
  111. package/dist/cjs/six-timepicker.cjs.entry.js +7 -6
  112. package/dist/cjs/six-timepicker.cjs.entry.js.map +1 -1
  113. package/dist/cjs/six-tooltip.cjs.entry.js +6 -5
  114. package/dist/cjs/six-tooltip.cjs.entry.js.map +1 -1
  115. package/dist/cjs/{slot-9821749e.js → slot-1b1232a1.js} +1 -3
  116. package/dist/cjs/slot-1b1232a1.js.map +1 -0
  117. package/dist/cjs/{types-0a6d66f6.js → types-d3da200b.js} +3 -1
  118. package/dist/cjs/types-d3da200b.js.map +1 -0
  119. package/dist/cjs/ui-library.cjs.js +6 -4
  120. package/dist/cjs/ui-library.cjs.js.map +1 -1
  121. package/dist/collection/assets/TRADEMARKS.md +3 -3
  122. package/dist/collection/collection-manifest.json +5 -6
  123. package/dist/collection/components/six-alert/six-alert.css +5 -1
  124. package/dist/collection/components/six-alert/six-alert.js +57 -12
  125. package/dist/collection/components/six-alert/six-alert.js.map +1 -1
  126. package/dist/collection/components/six-avatar/six-avatar.css +2 -2
  127. package/dist/collection/components/six-avatar/six-avatar.js +1 -1
  128. package/dist/collection/components/six-avatar/six-avatar.js.map +1 -1
  129. package/dist/collection/components/six-badge/six-badge.css +1 -1
  130. package/dist/collection/components/six-badge/six-badge.js +2 -2
  131. package/dist/collection/components/six-badge/six-badge.js.map +1 -1
  132. package/dist/collection/components/six-button/six-button.css +2 -1
  133. package/dist/collection/components/six-button/six-button.js +5 -4
  134. package/dist/collection/components/six-button/six-button.js.map +1 -1
  135. package/dist/collection/components/six-button/test/six-button.spec.js.map +1 -1
  136. package/dist/collection/components/six-card/six-card.css +4 -5
  137. package/dist/collection/components/six-card/six-card.js +1 -1
  138. package/dist/collection/components/six-card/six-card.js.map +1 -1
  139. package/dist/collection/components/six-checkbox/six-checkbox.css +3 -1
  140. package/dist/collection/components/six-checkbox/six-checkbox.js +5 -4
  141. package/dist/collection/components/six-checkbox/six-checkbox.js.map +1 -1
  142. package/dist/collection/components/six-datepicker/six-date-formats.js +1 -0
  143. package/dist/collection/components/six-datepicker/six-date-formats.js.map +1 -1
  144. package/dist/collection/components/six-datepicker/six-datepicker.css +1 -1
  145. package/dist/collection/components/six-datepicker/six-datepicker.js +10 -8
  146. package/dist/collection/components/six-datepicker/six-datepicker.js.map +1 -1
  147. package/dist/collection/components/six-details/six-details.css +1 -5
  148. package/dist/collection/components/six-details/six-details.js +3 -3
  149. package/dist/collection/components/six-details/six-details.js.map +1 -1
  150. package/dist/collection/components/six-dialog/six-dialog.css +2 -2
  151. package/dist/collection/components/six-dialog/six-dialog.js +10 -28
  152. package/dist/collection/components/six-dialog/six-dialog.js.map +1 -1
  153. package/dist/collection/components/six-drawer/six-drawer.css +2 -2
  154. package/dist/collection/components/six-drawer/six-drawer.js +9 -28
  155. package/dist/collection/components/six-drawer/six-drawer.js.map +1 -1
  156. package/dist/collection/components/six-dropdown/six-dropdown.css +22 -7
  157. package/dist/collection/components/six-dropdown/six-dropdown.js +216 -124
  158. package/dist/collection/components/six-dropdown/six-dropdown.js.map +1 -1
  159. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js +54 -29
  160. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js.map +1 -1
  161. package/dist/collection/components/six-error/six-error.js +1 -1
  162. package/dist/collection/components/six-error/six-error.js.map +1 -1
  163. package/dist/collection/components/six-error-page/six-error-page.js +1 -1
  164. package/dist/collection/components/six-error-page/six-error-page.js.map +1 -1
  165. package/dist/collection/components/six-file-list/six-file-list.js +1 -1
  166. package/dist/collection/components/six-file-list/six-file-list.js.map +1 -1
  167. package/dist/collection/components/six-file-list-item/six-file-list-item.css +1 -1
  168. package/dist/collection/components/six-file-list-item/six-file-list-item.js +2 -2
  169. package/dist/collection/components/six-file-list-item/six-file-list-item.js.map +1 -1
  170. package/dist/collection/components/six-file-upload/six-file-upload.css +12 -4
  171. package/dist/collection/components/six-file-upload/six-file-upload.js +87 -7
  172. package/dist/collection/components/six-file-upload/six-file-upload.js.map +1 -1
  173. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js +187 -24
  174. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js.map +1 -1
  175. package/dist/collection/components/six-footer/six-footer.css +2 -2
  176. package/dist/collection/components/six-footer/six-footer.js +1 -1
  177. package/dist/collection/components/six-footer/six-footer.js.map +1 -1
  178. package/dist/collection/components/six-group-label/six-group-label.css +1 -1
  179. package/dist/collection/components/six-group-label/six-group-label.js +1 -1
  180. package/dist/collection/components/six-group-label/six-group-label.js.map +1 -1
  181. package/dist/collection/components/six-header/six-header.css +11 -2
  182. package/dist/collection/components/six-header/six-header.js +41 -15
  183. package/dist/collection/components/six-header/six-header.js.map +1 -1
  184. package/dist/collection/components/six-icon/six-icon.css +3 -7
  185. package/dist/collection/components/six-icon/six-icon.js +2 -2
  186. package/dist/collection/components/six-icon/six-icon.js.map +1 -1
  187. package/dist/collection/components/six-icon-button/six-icon-button.css +1 -1
  188. package/dist/collection/components/six-icon-button/six-icon-button.js +3 -3
  189. package/dist/collection/components/six-icon-button/six-icon-button.js.map +1 -1
  190. package/dist/collection/components/six-input/six-input.css +10 -1
  191. package/dist/collection/components/six-input/six-input.js +47 -19
  192. package/dist/collection/components/six-input/six-input.js.map +1 -1
  193. package/dist/collection/components/six-item-picker/six-item-picker.js +3 -3
  194. package/dist/collection/components/six-item-picker/six-item-picker.js.map +1 -1
  195. package/dist/collection/components/six-item-picker/types.js +2 -0
  196. package/dist/collection/components/six-item-picker/types.js.map +1 -1
  197. package/dist/collection/components/six-language-switcher/six-language-switcher.css +7 -2
  198. package/dist/collection/components/six-language-switcher/six-language-switcher.js +7 -3
  199. package/dist/collection/components/six-language-switcher/six-language-switcher.js.map +1 -1
  200. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js +20 -20
  201. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js.map +1 -1
  202. package/dist/collection/components/six-layout-grid/six-layout-grid.js +1 -1
  203. package/dist/collection/components/six-layout-grid/six-layout-grid.js.map +1 -1
  204. package/dist/collection/components/six-main-container/six-main-container.js +1 -1
  205. package/dist/collection/components/six-main-container/six-main-container.js.map +1 -1
  206. package/dist/collection/components/six-menu/six-menu.css +8 -7
  207. package/dist/collection/components/six-menu/six-menu.js +30 -8
  208. package/dist/collection/components/six-menu/six-menu.js.map +1 -1
  209. package/dist/collection/components/six-menu/test/six-menu.spec.js +6 -6
  210. package/dist/collection/components/six-menu/test/six-menu.spec.js.map +1 -1
  211. package/dist/collection/components/six-menu-divider/six-menu-divider.css +3 -2
  212. package/dist/collection/components/six-menu-divider/six-menu-divider.js +1 -1
  213. package/dist/collection/components/six-menu-divider/six-menu-divider.js.map +1 -1
  214. package/dist/collection/components/six-menu-item/six-menu-item.css +13 -2
  215. package/dist/collection/components/six-menu-item/six-menu-item.js +37 -8
  216. package/dist/collection/components/six-menu-item/six-menu-item.js.map +1 -1
  217. package/dist/collection/components/six-menu-label/six-menu-label.css +1 -1
  218. package/dist/collection/components/six-menu-label/six-menu-label.js +1 -1
  219. package/dist/collection/components/six-menu-label/six-menu-label.js.map +1 -1
  220. package/dist/collection/components/six-picto/six-picto.js +1 -1
  221. package/dist/collection/components/six-picto/six-picto.js.map +1 -1
  222. package/dist/collection/components/six-progress-bar/six-progress-bar.css +1 -1
  223. package/dist/collection/components/six-progress-bar/six-progress-bar.js +2 -2
  224. package/dist/collection/components/six-progress-bar/six-progress-bar.js.map +1 -1
  225. package/dist/collection/components/six-progress-ring/six-progress-ring.css +1 -1
  226. package/dist/collection/components/six-progress-ring/six-progress-ring.js +1 -1
  227. package/dist/collection/components/six-progress-ring/six-progress-ring.js.map +1 -1
  228. package/dist/collection/components/six-radio/six-radio.css +1 -1
  229. package/dist/collection/components/six-radio/six-radio.js +5 -4
  230. package/dist/collection/components/six-radio/six-radio.js.map +1 -1
  231. package/dist/collection/components/six-range/six-range.css +2 -2
  232. package/dist/collection/components/six-range/six-range.js +15 -4
  233. package/dist/collection/components/six-range/six-range.js.map +1 -1
  234. package/dist/collection/components/six-root/six-root.js +1 -69
  235. package/dist/collection/components/six-root/six-root.js.map +1 -1
  236. package/dist/collection/components/six-root/test/six-root.spec.js +0 -7
  237. package/dist/collection/components/six-root/test/six-root.spec.js.map +1 -1
  238. package/dist/collection/components/six-search-field/six-search-field.css +1 -1
  239. package/dist/collection/components/six-search-field/six-search-field.js +1 -1
  240. package/dist/collection/components/six-search-field/six-search-field.js.map +1 -1
  241. package/dist/collection/components/six-select/six-select.css +54 -66
  242. package/dist/collection/components/six-select/six-select.js +346 -168
  243. package/dist/collection/components/six-select/six-select.js.map +1 -1
  244. package/dist/collection/components/six-select/test/six-select.spec.js +31 -15
  245. package/dist/collection/components/six-select/test/six-select.spec.js.map +1 -1
  246. package/dist/collection/components/six-select/util.js.map +1 -1
  247. package/dist/collection/components/six-sidebar/six-sidebar.css +2 -2
  248. package/dist/collection/components/six-sidebar/six-sidebar.js +8 -6
  249. package/dist/collection/components/six-sidebar/six-sidebar.js.map +1 -1
  250. package/dist/collection/components/six-sidebar-item/six-sidebar-item.js +2 -2
  251. package/dist/collection/components/six-sidebar-item/six-sidebar-item.js.map +1 -1
  252. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.css +2 -1
  253. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js.map +1 -1
  254. package/dist/collection/components/six-spinner/six-spinner.css +1 -1
  255. package/dist/collection/components/six-stage-indicator/six-stage-indicator.css +1 -1
  256. package/dist/collection/components/six-switch/six-switch.css +1 -1
  257. package/dist/collection/components/six-switch/six-switch.js +5 -4
  258. package/dist/collection/components/six-switch/six-switch.js.map +1 -1
  259. package/dist/collection/components/six-tab/six-tab.css +1 -1
  260. package/dist/collection/components/six-tab/six-tab.js +5 -4
  261. package/dist/collection/components/six-tab/six-tab.js.map +1 -1
  262. package/dist/collection/components/six-tab-group/six-tab-group.css +1 -1
  263. package/dist/collection/components/six-tab-group/six-tab-group.js +36 -9
  264. package/dist/collection/components/six-tab-group/six-tab-group.js.map +1 -1
  265. package/dist/collection/components/six-tab-panel/six-tab-panel.css +1 -1
  266. package/dist/collection/components/six-tab-panel/six-tab-panel.js +1 -1
  267. package/dist/collection/components/six-tab-panel/six-tab-panel.js.map +1 -1
  268. package/dist/collection/components/six-tag/six-tag.css +1 -1
  269. package/dist/collection/components/six-tag/six-tag.js +2 -2
  270. package/dist/collection/components/six-tag/six-tag.js.map +1 -1
  271. package/dist/collection/components/six-textarea/six-textarea.css +1 -1
  272. package/dist/collection/components/six-textarea/six-textarea.js +26 -18
  273. package/dist/collection/components/six-textarea/six-textarea.js.map +1 -1
  274. package/dist/collection/components/six-textarea/test/six-textarea.spec.js.map +1 -1
  275. package/dist/collection/components/six-tile/six-tile.css +2 -2
  276. package/dist/collection/components/six-tile/six-tile.js +3 -3
  277. package/dist/collection/components/six-tile/six-tile.js.map +1 -1
  278. package/dist/collection/components/six-timepicker/six-timepicker.css +1 -1
  279. package/dist/collection/components/six-timepicker/six-timepicker.js +4 -3
  280. package/dist/collection/components/six-timepicker/six-timepicker.js.map +1 -1
  281. package/dist/collection/components/six-timepicker/test/six-timepicker.spec.js.map +1 -1
  282. package/dist/collection/components/six-tooltip/six-tooltip.css +1 -1
  283. package/dist/collection/components/six-tooltip/six-tooltip.js +2 -2
  284. package/dist/collection/components/six-tooltip/six-tooltip.js.map +1 -1
  285. package/dist/collection/index.js +1 -0
  286. package/dist/collection/index.js.map +1 -1
  287. package/dist/collection/utils/alert.js +54 -0
  288. package/dist/collection/utils/alert.js.map +1 -0
  289. package/dist/collection/utils/date-util.js +25 -0
  290. package/dist/collection/utils/date-util.js.map +1 -1
  291. package/dist/collection/utils/date-util.spec.js.map +1 -1
  292. package/dist/collection/utils/error-messages.js +7 -0
  293. package/dist/collection/utils/error-messages.js.map +1 -1
  294. package/dist/collection/utils/event-listeners.js.map +1 -1
  295. package/dist/collection/utils/focus-visible.js.map +1 -1
  296. package/dist/collection/utils/form.js.map +1 -1
  297. package/dist/collection/utils/modal.js.map +1 -1
  298. package/dist/collection/utils/popover.js.map +1 -1
  299. package/dist/collection/utils/popup.js.map +1 -1
  300. package/dist/collection/utils/scroll.js.map +1 -1
  301. package/dist/collection/utils/slot.js +0 -1
  302. package/dist/collection/utils/slot.js.map +1 -1
  303. package/dist/collection/utils/tabbable.js.map +1 -1
  304. package/dist/collection/utils/time.util.js.map +1 -1
  305. package/dist/collection/utils/time.util.spec.js.map +1 -1
  306. package/dist/components/index.js +50 -102
  307. package/dist/components/index.js.map +1 -1
  308. package/dist/components/modal.js +1 -17
  309. package/dist/components/modal.js.map +1 -1
  310. package/dist/components/six-alert.js +41 -8
  311. package/dist/components/six-alert.js.map +1 -1
  312. package/dist/components/six-avatar.js +4 -3
  313. package/dist/components/six-avatar.js.map +1 -1
  314. package/dist/components/six-badge.js +5 -4
  315. package/dist/components/six-badge.js.map +1 -1
  316. package/dist/components/six-button.js +1 -142
  317. package/dist/components/six-button.js.map +1 -1
  318. package/dist/components/six-button2.js +147 -0
  319. package/dist/components/six-button2.js.map +1 -0
  320. package/dist/components/six-card.js +4 -3
  321. package/dist/components/six-card.js.map +1 -1
  322. package/dist/components/six-checkbox.js +1 -161
  323. package/dist/components/six-checkbox.js.map +1 -1
  324. package/dist/components/six-checkbox2.js +166 -0
  325. package/dist/components/six-checkbox2.js.map +1 -0
  326. package/dist/components/six-datepicker.js +31 -4
  327. package/dist/components/six-datepicker.js.map +1 -1
  328. package/dist/components/six-details2.js +6 -5
  329. package/dist/components/six-details2.js.map +1 -1
  330. package/dist/components/six-dialog.js +14 -30
  331. package/dist/components/six-dialog.js.map +1 -1
  332. package/dist/components/six-drawer.js +13 -30
  333. package/dist/components/six-drawer.js.map +1 -1
  334. package/dist/components/six-dropdown2.js +204 -127
  335. package/dist/components/six-dropdown2.js.map +1 -1
  336. package/dist/components/six-error-page.js +3 -2
  337. package/dist/components/six-error-page.js.map +1 -1
  338. package/dist/components/six-error2.js +3 -2
  339. package/dist/components/six-error2.js.map +1 -1
  340. package/dist/components/six-file-list-item.js +5 -4
  341. package/dist/components/six-file-list-item.js.map +1 -1
  342. package/dist/components/six-file-list.js +3 -2
  343. package/dist/components/six-file-list.js.map +1 -1
  344. package/dist/components/six-file-upload.js +53 -12
  345. package/dist/components/six-file-upload.js.map +1 -1
  346. package/dist/components/six-footer.js +4 -3
  347. package/dist/components/six-footer.js.map +1 -1
  348. package/dist/components/six-group-label.js +4 -3
  349. package/dist/components/six-group-label.js.map +1 -1
  350. package/dist/components/six-header.js +31 -16
  351. package/dist/components/six-header.js.map +1 -1
  352. package/dist/components/six-icon-button2.js +6 -5
  353. package/dist/components/six-icon-button2.js.map +1 -1
  354. package/dist/components/six-icon2.js +5 -4
  355. package/dist/components/six-icon2.js.map +1 -1
  356. package/dist/components/six-input2.js +9 -5
  357. package/dist/components/six-input2.js.map +1 -1
  358. package/dist/components/six-item-picker2.js +7 -4
  359. package/dist/components/six-item-picker2.js.map +1 -1
  360. package/dist/components/six-language-switcher.js +10 -5
  361. package/dist/components/six-language-switcher.js.map +1 -1
  362. package/dist/components/six-layout-grid.js +3 -2
  363. package/dist/components/six-layout-grid.js.map +1 -1
  364. package/dist/components/six-main-container.js +3 -2
  365. package/dist/components/six-main-container.js.map +1 -1
  366. package/dist/components/six-menu-divider.js +4 -3
  367. package/dist/components/six-menu-divider.js.map +1 -1
  368. package/dist/components/six-menu-item2.js +31 -7
  369. package/dist/components/six-menu-item2.js.map +1 -1
  370. package/dist/components/six-menu-label.js +4 -3
  371. package/dist/components/six-menu-label.js.map +1 -1
  372. package/dist/components/six-menu2.js +26 -9
  373. package/dist/components/six-menu2.js.map +1 -1
  374. package/dist/components/six-picto2.js +3 -2
  375. package/dist/components/six-picto2.js.map +1 -1
  376. package/dist/components/six-progress-bar.js +5 -4
  377. package/dist/components/six-progress-bar.js.map +1 -1
  378. package/dist/components/six-progress-ring.js +4 -3
  379. package/dist/components/six-progress-ring.js.map +1 -1
  380. package/dist/components/six-radio.js +5 -4
  381. package/dist/components/six-radio.js.map +1 -1
  382. package/dist/components/six-range.js +15 -4
  383. package/dist/components/six-range.js.map +1 -1
  384. package/dist/components/six-root.js +6 -34
  385. package/dist/components/six-root.js.map +1 -1
  386. package/dist/components/six-search-field.js +4 -3
  387. package/dist/components/six-search-field.js.map +1 -1
  388. package/dist/components/six-select.js +440 -186
  389. package/dist/components/six-select.js.map +1 -1
  390. package/dist/components/six-sidebar-item-group.js +3 -2
  391. package/dist/components/six-sidebar-item-group.js.map +1 -1
  392. package/dist/components/six-sidebar-item.js +4 -3
  393. package/dist/components/six-sidebar-item.js.map +1 -1
  394. package/dist/components/six-sidebar.js +5 -4
  395. package/dist/components/six-sidebar.js.map +1 -1
  396. package/dist/components/six-spinner2.js +3 -2
  397. package/dist/components/six-spinner2.js.map +1 -1
  398. package/dist/components/six-stage-indicator2.js +3 -2
  399. package/dist/components/six-stage-indicator2.js.map +1 -1
  400. package/dist/components/six-switch.js +5 -4
  401. package/dist/components/six-switch.js.map +1 -1
  402. package/dist/components/six-tab-group.js +36 -9
  403. package/dist/components/six-tab-group.js.map +1 -1
  404. package/dist/components/six-tab-panel.js +4 -3
  405. package/dist/components/six-tab-panel.js.map +1 -1
  406. package/dist/components/six-tab.js +5 -4
  407. package/dist/components/six-tab.js.map +1 -1
  408. package/dist/components/six-tag.js +99 -1
  409. package/dist/components/six-tag.js.map +1 -1
  410. package/dist/components/six-textarea.js +5 -4
  411. package/dist/components/six-textarea.js.map +1 -1
  412. package/dist/components/six-tile.js +6 -5
  413. package/dist/components/six-tile.js.map +1 -1
  414. package/dist/components/six-timepicker2.js +4 -3
  415. package/dist/components/six-timepicker2.js.map +1 -1
  416. package/dist/components/six-tooltip2.js +5 -4
  417. package/dist/components/six-tooltip2.js.map +1 -1
  418. package/dist/components/slot.js +1 -2
  419. package/dist/components/slot.js.map +1 -1
  420. package/dist/components.d.ts +1 -21
  421. package/dist/components.json +704 -239
  422. package/dist/esm/app-globals-0f993ce5.js +5 -0
  423. package/dist/esm/app-globals-0f993ce5.js.map +1 -0
  424. package/dist/esm/error-messages-1eaaad23.js +115 -0
  425. package/dist/esm/error-messages-1eaaad23.js.map +1 -0
  426. package/dist/esm/{form-control-6b30894f.js → form-control-30c5bd8b.js} +2 -2
  427. package/dist/esm/{form-control-6b30894f.js.map → form-control-30c5bd8b.js.map} +1 -1
  428. package/dist/esm/{index-17d8173e.js → index-5390c1d6.js} +127 -76
  429. package/dist/esm/index-5390c1d6.js.map +1 -0
  430. package/dist/esm/index.js +51 -100
  431. package/dist/esm/index.js.map +1 -1
  432. package/dist/esm/loader.js +6 -4
  433. package/dist/esm/loader.js.map +1 -1
  434. package/dist/esm/{modal-96526245.js → modal-6c1288e3.js} +2 -18
  435. package/dist/esm/modal-6c1288e3.js.map +1 -0
  436. package/dist/esm/six-alert.entry.js +42 -9
  437. package/dist/esm/six-alert.entry.js.map +1 -1
  438. package/dist/esm/six-avatar.entry.js +5 -4
  439. package/dist/esm/six-avatar.entry.js.map +1 -1
  440. package/dist/esm/six-badge.entry.js +6 -5
  441. package/dist/esm/six-badge.entry.js.map +1 -1
  442. package/dist/esm/six-button.entry.js +7 -6
  443. package/dist/esm/six-button.entry.js.map +1 -1
  444. package/dist/esm/six-card.entry.js +5 -4
  445. package/dist/esm/six-card.entry.js.map +1 -1
  446. package/dist/esm/six-checkbox_2.entry.js +187 -0
  447. package/dist/esm/six-checkbox_2.entry.js.map +1 -0
  448. package/dist/esm/six-datepicker.entry.js +33 -6
  449. package/dist/esm/six-datepicker.entry.js.map +1 -1
  450. package/dist/esm/six-details.entry.js +7 -6
  451. package/dist/esm/six-details.entry.js.map +1 -1
  452. package/dist/esm/six-dialog.entry.js +16 -32
  453. package/dist/esm/six-dialog.entry.js.map +1 -1
  454. package/dist/esm/six-drawer.entry.js +15 -32
  455. package/dist/esm/six-drawer.entry.js.map +1 -1
  456. package/dist/esm/six-dropdown_2.entry.js +205 -131
  457. package/dist/esm/six-dropdown_2.entry.js.map +1 -1
  458. package/dist/esm/six-error-page.entry.js +4 -3
  459. package/dist/esm/six-error-page.entry.js.map +1 -1
  460. package/dist/esm/six-error.entry.js +4 -3
  461. package/dist/esm/six-error.entry.js.map +1 -1
  462. package/dist/esm/six-file-list-item.entry.js +6 -5
  463. package/dist/esm/six-file-list-item.entry.js.map +1 -1
  464. package/dist/esm/six-file-list.entry.js +4 -3
  465. package/dist/esm/six-file-list.entry.js.map +1 -1
  466. package/dist/esm/six-file-upload.entry.js +34 -9
  467. package/dist/esm/six-file-upload.entry.js.map +1 -1
  468. package/dist/esm/six-footer.entry.js +5 -4
  469. package/dist/esm/six-footer.entry.js.map +1 -1
  470. package/dist/esm/six-group-label.entry.js +7 -6
  471. package/dist/esm/six-group-label.entry.js.map +1 -1
  472. package/dist/esm/six-header.entry.js +25 -17
  473. package/dist/esm/six-header.entry.js.map +1 -1
  474. package/dist/esm/six-icon-button.entry.js +7 -6
  475. package/dist/esm/six-icon-button.entry.js.map +1 -1
  476. package/dist/esm/six-icon.entry.js +6 -5
  477. package/dist/esm/six-icon.entry.js.map +1 -1
  478. package/dist/esm/six-input.entry.js +11 -8
  479. package/dist/esm/six-input.entry.js.map +1 -1
  480. package/dist/esm/six-item-picker.entry.js +7 -6
  481. package/dist/esm/six-item-picker.entry.js.map +1 -1
  482. package/dist/esm/six-language-switcher.entry.js +11 -6
  483. package/dist/esm/six-language-switcher.entry.js.map +1 -1
  484. package/dist/esm/six-layout-grid.entry.js +4 -3
  485. package/dist/esm/six-layout-grid.entry.js.map +1 -1
  486. package/dist/esm/six-main-container.entry.js +4 -3
  487. package/dist/esm/six-main-container.entry.js.map +1 -1
  488. package/dist/esm/six-menu-divider.entry.js +5 -4
  489. package/dist/esm/six-menu-divider.entry.js.map +1 -1
  490. package/dist/esm/six-menu-label.entry.js +5 -4
  491. package/dist/esm/six-menu-label.entry.js.map +1 -1
  492. package/dist/esm/six-picto.entry.js +4 -3
  493. package/dist/esm/six-picto.entry.js.map +1 -1
  494. package/dist/esm/six-progress-bar.entry.js +6 -5
  495. package/dist/esm/six-progress-bar.entry.js.map +1 -1
  496. package/dist/esm/six-progress-ring.entry.js +5 -4
  497. package/dist/esm/six-progress-ring.entry.js.map +1 -1
  498. package/dist/esm/six-radio.entry.js +6 -5
  499. package/dist/esm/six-radio.entry.js.map +1 -1
  500. package/dist/esm/six-range.entry.js +18 -7
  501. package/dist/esm/six-range.entry.js.map +1 -1
  502. package/dist/esm/six-root.entry.js +4 -22
  503. package/dist/esm/six-root.entry.js.map +1 -1
  504. package/dist/esm/six-search-field.entry.js +5 -4
  505. package/dist/esm/six-search-field.entry.js.map +1 -1
  506. package/dist/esm/six-select.entry.js +305 -170
  507. package/dist/esm/six-select.entry.js.map +1 -1
  508. package/dist/esm/six-sidebar-item-group.entry.js +5 -4
  509. package/dist/esm/six-sidebar-item-group.entry.js.map +1 -1
  510. package/dist/esm/six-sidebar-item.entry.js +5 -4
  511. package/dist/esm/six-sidebar-item.entry.js.map +1 -1
  512. package/dist/esm/six-sidebar.entry.js +6 -5
  513. package/dist/esm/six-sidebar.entry.js.map +1 -1
  514. package/dist/esm/six-spinner.entry.js +4 -3
  515. package/dist/esm/six-spinner.entry.js.map +1 -1
  516. package/dist/esm/six-stage-indicator.entry.js +19 -0
  517. package/dist/esm/six-stage-indicator.entry.js.map +1 -0
  518. package/dist/esm/six-switch.entry.js +8 -7
  519. package/dist/esm/six-switch.entry.js.map +1 -1
  520. package/dist/esm/six-tab-group.entry.js +35 -9
  521. package/dist/esm/six-tab-group.entry.js.map +1 -1
  522. package/dist/esm/six-tab-panel.entry.js +5 -4
  523. package/dist/esm/six-tab-panel.entry.js.map +1 -1
  524. package/dist/esm/six-tab.entry.js +6 -5
  525. package/dist/esm/six-tab.entry.js.map +1 -1
  526. package/dist/esm/six-tag.entry.js +7 -6
  527. package/dist/esm/six-tag.entry.js.map +1 -1
  528. package/dist/esm/six-textarea.entry.js +8 -7
  529. package/dist/esm/six-textarea.entry.js.map +1 -1
  530. package/dist/esm/six-tile.entry.js +8 -7
  531. package/dist/esm/six-tile.entry.js.map +1 -1
  532. package/dist/esm/six-timepicker.entry.js +7 -6
  533. package/dist/esm/six-timepicker.entry.js.map +1 -1
  534. package/dist/esm/six-tooltip.entry.js +6 -5
  535. package/dist/esm/six-tooltip.entry.js.map +1 -1
  536. package/dist/esm/{slot-41bc439a.js → slot-56531341.js} +2 -3
  537. package/dist/esm/slot-56531341.js.map +1 -0
  538. package/dist/esm/{types-07748c42.js → types-a07bb999.js} +3 -1
  539. package/dist/esm/types-a07bb999.js.map +1 -0
  540. package/dist/esm/ui-library.js +7 -5
  541. package/dist/esm/ui-library.js.map +1 -1
  542. package/dist/types/components/six-alert/six-alert.d.ts +13 -6
  543. package/dist/types/components/six-datepicker/six-datepicker.d.ts +1 -1
  544. package/dist/types/components/six-dialog/six-dialog.d.ts +1 -0
  545. package/dist/types/components/six-dropdown/six-dropdown.d.ts +28 -9
  546. package/dist/types/components/six-file-upload/six-file-upload.d.ts +10 -0
  547. package/dist/types/components/six-header/six-header.d.ts +3 -1
  548. package/dist/types/components/six-input/six-input.d.ts +4 -0
  549. package/dist/types/components/six-menu/six-menu.d.ts +4 -0
  550. package/dist/types/components/six-menu-item/six-menu-item.d.ts +7 -1
  551. package/dist/types/components/six-range/six-range.d.ts +2 -0
  552. package/dist/types/components/six-root/six-root.d.ts +0 -13
  553. package/dist/types/components/six-select/six-select.d.ts +27 -12
  554. package/dist/types/components/six-tab-group/six-tab-group.d.ts +4 -1
  555. package/dist/types/components.d.ts +96 -60
  556. package/dist/types/index.d.ts +1 -0
  557. package/dist/types/types.d.ts +1 -0
  558. package/dist/types/utils/alert.d.ts +10 -0
  559. package/dist/types/utils/date-util.d.ts +9 -1
  560. package/dist/types/utils/error-messages.d.ts +1 -0
  561. package/dist/types/utils/slot.d.ts +0 -1
  562. package/dist/ui-library/assets/TRADEMARKS.md +3 -3
  563. package/dist/ui-library/index.esm.js +1 -1
  564. package/dist/ui-library/index.esm.js.map +1 -1
  565. package/dist/ui-library/p-030fa1fa.entry.js +2 -0
  566. package/dist/ui-library/p-030fa1fa.entry.js.map +1 -0
  567. package/dist/ui-library/p-03d1b956.entry.js +2 -0
  568. package/dist/ui-library/p-03d1b956.entry.js.map +1 -0
  569. package/dist/ui-library/p-047d02ad.entry.js +2 -0
  570. package/dist/ui-library/p-047d02ad.entry.js.map +1 -0
  571. package/dist/ui-library/p-05eb1bab.js +3 -0
  572. package/dist/ui-library/p-05eb1bab.js.map +1 -0
  573. package/dist/ui-library/p-060069d4.entry.js +2 -0
  574. package/dist/ui-library/p-060069d4.entry.js.map +1 -0
  575. package/dist/ui-library/p-06ba653e.entry.js +2 -0
  576. package/dist/ui-library/p-06ba653e.entry.js.map +1 -0
  577. package/dist/ui-library/p-07c8de65.entry.js +2 -0
  578. package/dist/ui-library/p-07c8de65.entry.js.map +1 -0
  579. package/dist/ui-library/p-0cebf1d2.js +2 -0
  580. package/dist/ui-library/p-0cebf1d2.js.map +1 -0
  581. package/dist/ui-library/p-0fb3fb30.entry.js +2 -0
  582. package/dist/ui-library/p-0fb3fb30.entry.js.map +1 -0
  583. package/dist/ui-library/p-14e5fccc.entry.js +2 -0
  584. package/dist/ui-library/p-14e5fccc.entry.js.map +1 -0
  585. package/dist/ui-library/p-16fb5aad.entry.js +2 -0
  586. package/dist/ui-library/p-16fb5aad.entry.js.map +1 -0
  587. package/dist/ui-library/p-189602e4.entry.js +2 -0
  588. package/dist/ui-library/p-189602e4.entry.js.map +1 -0
  589. package/dist/ui-library/p-19560508.entry.js +2 -0
  590. package/dist/ui-library/p-19560508.entry.js.map +1 -0
  591. package/dist/ui-library/p-2386627e.entry.js +2 -0
  592. package/dist/ui-library/p-2386627e.entry.js.map +1 -0
  593. package/dist/ui-library/p-2c25cb61.entry.js +2 -0
  594. package/dist/ui-library/p-2c25cb61.entry.js.map +1 -0
  595. package/dist/ui-library/p-3603dd96.entry.js +2 -0
  596. package/dist/ui-library/p-3603dd96.entry.js.map +1 -0
  597. package/dist/ui-library/p-39ff5f61.entry.js +2 -0
  598. package/dist/ui-library/p-39ff5f61.entry.js.map +1 -0
  599. package/dist/ui-library/p-3b5a76ea.entry.js +2 -0
  600. package/dist/ui-library/p-3b5a76ea.entry.js.map +1 -0
  601. package/dist/ui-library/p-419ed003.entry.js +2 -0
  602. package/dist/ui-library/p-419ed003.entry.js.map +1 -0
  603. package/dist/ui-library/p-45003bae.entry.js +2 -0
  604. package/dist/ui-library/p-45003bae.entry.js.map +1 -0
  605. package/dist/ui-library/p-4963f03c.entry.js +2 -0
  606. package/dist/ui-library/p-4963f03c.entry.js.map +1 -0
  607. package/dist/ui-library/p-4d89932f.entry.js +2 -0
  608. package/dist/ui-library/p-4d89932f.entry.js.map +1 -0
  609. package/dist/ui-library/{p-6907a7dc.js → p-605bdd81.js} +2 -2
  610. package/dist/ui-library/p-63acceb6.entry.js +2 -0
  611. package/dist/ui-library/p-63acceb6.entry.js.map +1 -0
  612. package/dist/ui-library/p-651293e7.js +2 -0
  613. package/dist/ui-library/p-651293e7.js.map +1 -0
  614. package/dist/ui-library/p-6888b9ee.entry.js +2 -0
  615. package/dist/ui-library/p-6888b9ee.entry.js.map +1 -0
  616. package/dist/ui-library/p-6f9153be.entry.js +2 -0
  617. package/dist/ui-library/p-6f9153be.entry.js.map +1 -0
  618. package/dist/ui-library/p-73be87a7.entry.js +2 -0
  619. package/dist/ui-library/p-73be87a7.entry.js.map +1 -0
  620. package/dist/ui-library/p-7561b336.entry.js +2 -0
  621. package/dist/ui-library/p-7561b336.entry.js.map +1 -0
  622. package/dist/ui-library/p-7c18b8ca.entry.js +2 -0
  623. package/dist/ui-library/p-7c18b8ca.entry.js.map +1 -0
  624. package/dist/ui-library/p-82bd8781.entry.js +2 -0
  625. package/dist/ui-library/p-82bd8781.entry.js.map +1 -0
  626. package/dist/ui-library/{p-0861899a.js → p-862d474e.js} +1 -1
  627. package/dist/ui-library/p-862d474e.js.map +1 -0
  628. package/dist/ui-library/p-89db9a8b.entry.js +2 -0
  629. package/dist/ui-library/p-89db9a8b.entry.js.map +1 -0
  630. package/dist/ui-library/{p-d310a6dd.entry.js → p-8f1d3461.entry.js} +2 -2
  631. package/dist/ui-library/p-8f1d3461.entry.js.map +1 -0
  632. package/dist/ui-library/p-96d441e9.entry.js +2 -0
  633. package/dist/ui-library/p-96d441e9.entry.js.map +1 -0
  634. package/dist/ui-library/p-9bc1639b.entry.js +2 -0
  635. package/dist/ui-library/p-9bc1639b.entry.js.map +1 -0
  636. package/dist/ui-library/p-9cb83369.entry.js +2 -0
  637. package/dist/ui-library/p-9cb83369.entry.js.map +1 -0
  638. package/dist/ui-library/p-a398e3eb.entry.js +2 -0
  639. package/dist/ui-library/p-a398e3eb.entry.js.map +1 -0
  640. package/dist/ui-library/p-a7e2f511.entry.js +2 -0
  641. package/dist/ui-library/p-a7e2f511.entry.js.map +1 -0
  642. package/dist/ui-library/p-a8863197.entry.js +2 -0
  643. package/dist/ui-library/p-a8863197.entry.js.map +1 -0
  644. package/dist/ui-library/p-a9e009af.entry.js +2 -0
  645. package/dist/ui-library/p-a9e009af.entry.js.map +1 -0
  646. package/dist/ui-library/p-ac00076d.entry.js +2 -0
  647. package/dist/ui-library/p-ac00076d.entry.js.map +1 -0
  648. package/dist/ui-library/p-b4bc4915.entry.js +2 -0
  649. package/dist/ui-library/p-b4bc4915.entry.js.map +1 -0
  650. package/dist/ui-library/p-b5acf54d.entry.js +2 -0
  651. package/dist/ui-library/p-b5acf54d.entry.js.map +1 -0
  652. package/dist/ui-library/p-b60c20aa.entry.js +2 -0
  653. package/dist/ui-library/p-b60c20aa.entry.js.map +1 -0
  654. package/dist/ui-library/p-b60c632a.entry.js +2 -0
  655. package/dist/ui-library/p-b60c632a.entry.js.map +1 -0
  656. package/dist/ui-library/p-c1d68730.entry.js +2 -0
  657. package/dist/ui-library/p-c1d68730.entry.js.map +1 -0
  658. package/dist/ui-library/p-c35a7cef.entry.js +2 -0
  659. package/dist/ui-library/p-c35a7cef.entry.js.map +1 -0
  660. package/dist/ui-library/p-c62893e5.entry.js +2 -0
  661. package/dist/ui-library/p-c62893e5.entry.js.map +1 -0
  662. package/dist/ui-library/p-c6464bfe.entry.js +2 -0
  663. package/dist/ui-library/p-c6464bfe.entry.js.map +1 -0
  664. package/dist/ui-library/p-cf109cbf.entry.js +2 -0
  665. package/dist/ui-library/p-cf109cbf.entry.js.map +1 -0
  666. package/dist/ui-library/p-d07b549f.entry.js +2 -0
  667. package/dist/ui-library/p-d07b549f.entry.js.map +1 -0
  668. package/dist/ui-library/p-d42f1ea9.entry.js +2 -0
  669. package/dist/ui-library/p-d42f1ea9.entry.js.map +1 -0
  670. package/dist/ui-library/p-e080d5b6.js +2 -0
  671. package/dist/ui-library/p-e080d5b6.js.map +1 -0
  672. package/dist/ui-library/p-e1255160.js +2 -0
  673. package/dist/ui-library/p-e1255160.js.map +1 -0
  674. package/dist/ui-library/p-fe37dadf.entry.js +2 -0
  675. package/dist/ui-library/p-fe37dadf.entry.js.map +1 -0
  676. package/dist/ui-library/p-fe89a7c4.entry.js +2 -0
  677. package/dist/ui-library/p-fe89a7c4.entry.js.map +1 -0
  678. package/dist/ui-library/ui-library.css +1 -10
  679. package/dist/ui-library/ui-library.esm.js +1 -1
  680. package/dist/ui-library/ui-library.esm.js.map +1 -1
  681. package/package.json +10 -13
  682. package/dist/cjs/index-3baddcdc.js.map +0 -1
  683. package/dist/cjs/modal-3ce015be.js.map +0 -1
  684. package/dist/cjs/set-attributes_2.cjs.entry.js +0 -73
  685. package/dist/cjs/set-attributes_2.cjs.entry.js.map +0 -1
  686. package/dist/cjs/six-checkbox.cjs.entry.js +0 -127
  687. package/dist/cjs/six-checkbox.cjs.entry.js.map +0 -1
  688. package/dist/cjs/six-menu-item.cjs.entry.js +0 -63
  689. package/dist/cjs/six-menu-item.cjs.entry.js.map +0 -1
  690. package/dist/cjs/slot-9821749e.js.map +0 -1
  691. package/dist/cjs/types-0a6d66f6.js.map +0 -1
  692. package/dist/collection/components/six-header/assets/six-logo.svg +0 -1
  693. package/dist/collection/components/six-header/test/six-header.spec.js +0 -177
  694. package/dist/collection/components/six-header/test/six-header.spec.js.map +0 -1
  695. package/dist/collection/utils/support.js +0 -16
  696. package/dist/collection/utils/support.js.map +0 -1
  697. package/dist/collection/wrappers/set-attributes/set-attributes.js +0 -74
  698. package/dist/collection/wrappers/set-attributes/set-attributes.js.map +0 -1
  699. package/dist/collection/wrappers/set-attributes/test/set-attributes.spec.js +0 -16
  700. package/dist/collection/wrappers/set-attributes/test/set-attributes.spec.js.map +0 -1
  701. package/dist/components/set-attributes.d.ts +0 -11
  702. package/dist/components/set-attributes.js +0 -8
  703. package/dist/components/set-attributes.js.map +0 -1
  704. package/dist/components/set-attributes2.js +0 -73
  705. package/dist/components/set-attributes2.js.map +0 -1
  706. package/dist/components/six-tag2.js +0 -102
  707. package/dist/components/six-tag2.js.map +0 -1
  708. package/dist/esm/index-17d8173e.js.map +0 -1
  709. package/dist/esm/modal-96526245.js.map +0 -1
  710. package/dist/esm/set-attributes_2.entry.js +0 -68
  711. package/dist/esm/set-attributes_2.entry.js.map +0 -1
  712. package/dist/esm/six-checkbox.entry.js +0 -123
  713. package/dist/esm/six-checkbox.entry.js.map +0 -1
  714. package/dist/esm/six-menu-item.entry.js +0 -59
  715. package/dist/esm/six-menu-item.entry.js.map +0 -1
  716. package/dist/esm/slot-41bc439a.js.map +0 -1
  717. package/dist/esm/types-07748c42.js.map +0 -1
  718. package/dist/types/utils/support.d.ts +0 -1
  719. package/dist/types/wrappers/set-attributes/set-attributes.d.ts +0 -9
  720. package/dist/ui-library/assets/six-logo.svg +0 -1
  721. package/dist/ui-library/p-0861899a.js.map +0 -1
  722. package/dist/ui-library/p-0a81b42c.entry.js +0 -2
  723. package/dist/ui-library/p-0a81b42c.entry.js.map +0 -1
  724. package/dist/ui-library/p-0beec94f.js +0 -3
  725. package/dist/ui-library/p-0beec94f.js.map +0 -1
  726. package/dist/ui-library/p-0e7332db.entry.js +0 -2
  727. package/dist/ui-library/p-0e7332db.entry.js.map +0 -1
  728. package/dist/ui-library/p-178f5782.entry.js +0 -2
  729. package/dist/ui-library/p-178f5782.entry.js.map +0 -1
  730. package/dist/ui-library/p-19a61686.entry.js +0 -2
  731. package/dist/ui-library/p-19a61686.entry.js.map +0 -1
  732. package/dist/ui-library/p-1d0c5929.entry.js +0 -2
  733. package/dist/ui-library/p-1d0c5929.entry.js.map +0 -1
  734. package/dist/ui-library/p-23c02c98.entry.js +0 -2
  735. package/dist/ui-library/p-23c02c98.entry.js.map +0 -1
  736. package/dist/ui-library/p-28221447.entry.js +0 -2
  737. package/dist/ui-library/p-28221447.entry.js.map +0 -1
  738. package/dist/ui-library/p-2eed9d8d.entry.js +0 -2
  739. package/dist/ui-library/p-2eed9d8d.entry.js.map +0 -1
  740. package/dist/ui-library/p-3187bc23.entry.js +0 -2
  741. package/dist/ui-library/p-3187bc23.entry.js.map +0 -1
  742. package/dist/ui-library/p-32e1a5ab.entry.js +0 -2
  743. package/dist/ui-library/p-32e1a5ab.entry.js.map +0 -1
  744. package/dist/ui-library/p-3d54ecf2.entry.js +0 -2
  745. package/dist/ui-library/p-3d54ecf2.entry.js.map +0 -1
  746. package/dist/ui-library/p-4229f7e8.entry.js +0 -2
  747. package/dist/ui-library/p-4229f7e8.entry.js.map +0 -1
  748. package/dist/ui-library/p-4468dd26.entry.js +0 -2
  749. package/dist/ui-library/p-4468dd26.entry.js.map +0 -1
  750. package/dist/ui-library/p-479d8087.entry.js +0 -2
  751. package/dist/ui-library/p-479d8087.entry.js.map +0 -1
  752. package/dist/ui-library/p-49aa8d1e.entry.js +0 -2
  753. package/dist/ui-library/p-49aa8d1e.entry.js.map +0 -1
  754. package/dist/ui-library/p-58661675.entry.js +0 -2
  755. package/dist/ui-library/p-58661675.entry.js.map +0 -1
  756. package/dist/ui-library/p-5d43ea07.entry.js +0 -2
  757. package/dist/ui-library/p-5d43ea07.entry.js.map +0 -1
  758. package/dist/ui-library/p-6aa2929a.entry.js +0 -2
  759. package/dist/ui-library/p-6aa2929a.entry.js.map +0 -1
  760. package/dist/ui-library/p-7432d409.entry.js +0 -2
  761. package/dist/ui-library/p-7432d409.entry.js.map +0 -1
  762. package/dist/ui-library/p-74a714c0.entry.js +0 -2
  763. package/dist/ui-library/p-74a714c0.entry.js.map +0 -1
  764. package/dist/ui-library/p-76825395.entry.js +0 -2
  765. package/dist/ui-library/p-76825395.entry.js.map +0 -1
  766. package/dist/ui-library/p-816f857d.entry.js +0 -2
  767. package/dist/ui-library/p-816f857d.entry.js.map +0 -1
  768. package/dist/ui-library/p-882fbf6f.entry.js +0 -2
  769. package/dist/ui-library/p-882fbf6f.entry.js.map +0 -1
  770. package/dist/ui-library/p-88fd4973.entry.js +0 -2
  771. package/dist/ui-library/p-88fd4973.entry.js.map +0 -1
  772. package/dist/ui-library/p-8b750c9e.entry.js +0 -2
  773. package/dist/ui-library/p-8b750c9e.entry.js.map +0 -1
  774. package/dist/ui-library/p-911eb578.entry.js +0 -2
  775. package/dist/ui-library/p-911eb578.entry.js.map +0 -1
  776. package/dist/ui-library/p-93fcda4a.entry.js +0 -2
  777. package/dist/ui-library/p-93fcda4a.entry.js.map +0 -1
  778. package/dist/ui-library/p-981b3228.entry.js +0 -2
  779. package/dist/ui-library/p-981b3228.entry.js.map +0 -1
  780. package/dist/ui-library/p-998de05d.js +0 -2
  781. package/dist/ui-library/p-998de05d.js.map +0 -1
  782. package/dist/ui-library/p-9b1ff147.entry.js +0 -2
  783. package/dist/ui-library/p-9b1ff147.entry.js.map +0 -1
  784. package/dist/ui-library/p-a0658b26.entry.js +0 -2
  785. package/dist/ui-library/p-a0658b26.entry.js.map +0 -1
  786. package/dist/ui-library/p-a4e4620c.entry.js +0 -2
  787. package/dist/ui-library/p-a4e4620c.entry.js.map +0 -1
  788. package/dist/ui-library/p-ada23fe3.entry.js +0 -2
  789. package/dist/ui-library/p-ada23fe3.entry.js.map +0 -1
  790. package/dist/ui-library/p-b5ac1219.entry.js +0 -2
  791. package/dist/ui-library/p-b5ac1219.entry.js.map +0 -1
  792. package/dist/ui-library/p-ba247565.entry.js +0 -2
  793. package/dist/ui-library/p-ba247565.entry.js.map +0 -1
  794. package/dist/ui-library/p-bdb79948.entry.js +0 -2
  795. package/dist/ui-library/p-bdb79948.entry.js.map +0 -1
  796. package/dist/ui-library/p-bee65dd9.entry.js +0 -2
  797. package/dist/ui-library/p-bee65dd9.entry.js.map +0 -1
  798. package/dist/ui-library/p-c07b1240.entry.js +0 -2
  799. package/dist/ui-library/p-c07b1240.entry.js.map +0 -1
  800. package/dist/ui-library/p-c12a94ce.entry.js +0 -2
  801. package/dist/ui-library/p-c12a94ce.entry.js.map +0 -1
  802. package/dist/ui-library/p-c1675a45.entry.js +0 -2
  803. package/dist/ui-library/p-c1675a45.entry.js.map +0 -1
  804. package/dist/ui-library/p-c2df8c27.entry.js +0 -2
  805. package/dist/ui-library/p-c2df8c27.entry.js.map +0 -1
  806. package/dist/ui-library/p-c86aa5b3.entry.js +0 -2
  807. package/dist/ui-library/p-c86aa5b3.entry.js.map +0 -1
  808. package/dist/ui-library/p-cd35b3c6.entry.js +0 -2
  809. package/dist/ui-library/p-cd35b3c6.entry.js.map +0 -1
  810. package/dist/ui-library/p-ce373da5.entry.js +0 -2
  811. package/dist/ui-library/p-ce373da5.entry.js.map +0 -1
  812. package/dist/ui-library/p-d2cf4280.entry.js +0 -2
  813. package/dist/ui-library/p-d2cf4280.entry.js.map +0 -1
  814. package/dist/ui-library/p-d310a6dd.entry.js.map +0 -1
  815. package/dist/ui-library/p-dfb6bff6.entry.js +0 -2
  816. package/dist/ui-library/p-dfb6bff6.entry.js.map +0 -1
  817. package/dist/ui-library/p-ee71e3a3.entry.js +0 -2
  818. package/dist/ui-library/p-ee71e3a3.entry.js.map +0 -1
  819. package/dist/ui-library/p-ef317d69.entry.js +0 -2
  820. package/dist/ui-library/p-ef317d69.entry.js.map +0 -1
  821. package/dist/ui-library/p-f385f1c2.entry.js +0 -2
  822. package/dist/ui-library/p-f385f1c2.entry.js.map +0 -1
  823. package/dist/ui-library/p-f73a6bdc.entry.js +0 -2
  824. package/dist/ui-library/p-f73a6bdc.entry.js.map +0 -1
  825. package/dist/ui-library/p-faa04bb5.js +0 -2
  826. package/dist/ui-library/p-faa04bb5.js.map +0 -1
  827. package/dist/ui-library/p-fcd57e0a.entry.js +0 -2
  828. package/dist/ui-library/p-fcd57e0a.entry.js.map +0 -1
  829. /package/dist/ui-library/{p-6907a7dc.js.map → p-605bdd81.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"six-main-container.js","sourceRoot":"","sources":["../../../src/components/six-main-container/six-main-container.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAElE;;;;;;;;;GASG;AAOH,MAAM,OAAO,gBAAgB;;sBAIV,IAAI;;IAErB,MAAM;QACJ,OAAO,CACL,EAAC,IAAI;YACH,WAAK,IAAI,EAAC,aAAa,EAAC,KAAK,EAAC,aAAa,GAAG;YAC9C,WAAK,IAAI,EAAC,SAAS,EAAC,KAAK,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,iBAAiB,EAAE,IAAI,CAAC,MAAM,EAAE;gBAC1E,eAAQ,CACJ;YACN,WAAK,IAAI,EAAC,cAAc,EAAC,KAAK,EAAC,cAAc,GAAG,CAC3C,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Element, h, Host, Prop } from '@stencil/core';\n\n/**\n * @since 1.01\n * @status stable\n *\n * @slot - The main container's content.\n *\n * @part left-margin - The component's left margin area.\n * @part content - The component's content area.\n * @part right-margin - The component's right margin area.\n */\n\n@Component({\n tag: 'six-main-container',\n styleUrl: 'six-main-container.scss',\n shadow: true,\n})\nexport class SixMainContainer {\n @Element() host!: HTMLSixMainContainerElement;\n\n /** Set to false to remove top and bottom padding. */\n @Prop() padded = true;\n\n render() {\n return (\n <Host>\n <div part=\"left-margin\" class=\"left-margin\" />\n <div part=\"content\" class={{ content: true, 'content--padded': this.padded }}>\n <slot />\n </div>\n <div part=\"right-margin\" class=\"right-margin\" />\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"six-main-container.js","sourceRoot":"","sources":["../../../src/components/six-main-container/six-main-container.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAElE;;;;;;;;;GASG;AAOH,MAAM,OAAO,gBAAgB;;sBAKV,IAAI;;IAErB,MAAM;QACJ,OAAO,CACL,EAAC,IAAI;YACH,4DAAK,IAAI,EAAC,aAAa,EAAC,KAAK,EAAC,aAAa,GAAG;YAC9C,4DAAK,IAAI,EAAC,SAAS,EAAC,KAAK,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,iBAAiB,EAAE,IAAI,CAAC,MAAM,EAAE;gBAC1E,8DAAQ,CACJ;YACN,4DAAK,IAAI,EAAC,cAAc,EAAC,KAAK,EAAC,cAAc,GAAG,CAC3C,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Element, h, Host, Prop } from '@stencil/core';\n\n/**\n * @since 1.01\n * @status stable\n *\n * @slot - The main container's content.\n *\n * @part left-margin - The component's left margin area.\n * @part content - The component's content area.\n * @part right-margin - The component's right margin area.\n */\n\n@Component({\n tag: 'six-main-container',\n styleUrl: 'six-main-container.scss',\n shadow: true,\n})\nexport class SixMainContainer {\n @Element() host!: HTMLSixMainContainerElement;\n\n /** Set to false to remove top and bottom padding. */\n // eslint-disable-next-line @stencil-community/ban-default-true\n @Prop() padded = true;\n\n render() {\n return (\n <Host>\n <div part=\"left-margin\" class=\"left-margin\" />\n <div part=\"content\" class={{ content: true, 'content--padded': this.padded }}>\n <slot />\n </div>\n <div part=\"right-margin\" class=\"right-margin\" />\n </Host>\n );\n }\n}\n"]}
@@ -3,7 +3,7 @@
3
3
  box-sizing: border-box;
4
4
  }
5
5
  :host *, :host *:before, :host *:after {
6
- box-sizing: inherit;
6
+ box-sizing: border-box;
7
7
  }
8
8
 
9
9
  :host {
@@ -11,16 +11,17 @@
11
11
  }
12
12
 
13
13
  .menu {
14
- padding: 0 0;
14
+ padding: var(--six-spacing-xx-small) 0;
15
15
  border: none;
16
- box-shadow: var(--six-elevation-2dp);
16
+ box-shadow: var(--six-shadow-small);
17
+ overflow-y: auto;
18
+ overflow-x: hidden;
17
19
  }
20
+
18
21
  .menu:focus {
19
22
  outline: none;
20
23
  }
21
- .menu--noshadow {
24
+
25
+ .no-shadow {
22
26
  box-shadow: none;
23
- }
24
- .menu__wrapper--scrollable {
25
- overflow-y: auto;
26
27
  }
@@ -4,7 +4,7 @@ import { EventListeners } from "../../utils/event-listeners";
4
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
- const mapToMenuItem = ({ value, label }) => h("six-menu-item", { value: value }, label);
7
+ const mapToMenuItem = ({ value, label }) => (h("six-menu-item", { key: value, 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
10
  /**
@@ -33,6 +33,7 @@ export class SixMenu {
33
33
  this.virtualScroll = false;
34
34
  this.itemSize = 10;
35
35
  this.scrollingDebounce = 15;
36
+ this.disableKeyboardHandling = false;
36
37
  this.scrollingIndex = 0;
37
38
  this.sixMenuItemHeight = DEFAULT_SIX_MENU_ITEM_HEIGHT;
38
39
  }
@@ -136,6 +137,9 @@ export class SixMenu {
136
137
  }
137
138
  }
138
139
  handleKeyDown(event) {
140
+ if (this.disableKeyboardHandling) {
141
+ return;
142
+ }
139
143
  // Make a selection when pressing enter
140
144
  if (event.key === 'Enter') {
141
145
  const activeItem = this.getActiveItem();
@@ -209,14 +213,13 @@ export class SixMenu {
209
213
  }
210
214
  return this.items
211
215
  .slice(this.scrollingIndex, Math.min(this.items.length, this.itemSize + this.scrollingIndex))
212
- .map(mapToMenuItem);
216
+ .map(({ value, label }) => (h("six-menu-item", { checkType: "check", key: value, value: value }, label)));
213
217
  }
214
218
  render() {
215
- return (h("div", { ref: (el) => (this.menuWrapper = el), style: this.getMenuWrapperStyle(), part: "wrapper", class: {
219
+ return (h("div", { key: 'a8806ec6aee657eb677931fc1ba1405caec3e96e', ref: (el) => (this.menuWrapper = el), style: this.getMenuWrapperStyle(), part: "wrapper", class: {
216
220
  menu: true,
217
- 'menu--noshadow': this.removeBoxShadow,
218
- 'menu__wrapper--scrollable': this.getItemsShown() > 0,
219
- } }, h("div", { ref: (el) => (this.menu = el), part: "base", role: "menu", onClick: this.handleClick, onKeyDown: this.handleKeyDown, tabIndex: 0, style: this.getMenuContainerStyle() }, h("slot", null), this.renderItems()), this.virtualScroll && h("div", { style: this.getScrollbarGhostStyle() })));
221
+ '.no-shadow': this.removeBoxShadow,
222
+ } }, h("div", { key: '34b85eb38385f88e87f49a6689cf6ad082723a87', ref: (el) => (this.menu = el), part: "base", role: "menu", onClick: this.handleClick, onKeyDown: this.handleKeyDown, tabIndex: 0, style: this.getMenuContainerStyle() }, h("slot", { key: 'a62dcc8bd5d97a8d479f4a4270aedcb77b729aea' }), this.renderItems()), this.virtualScroll && h("div", { style: this.getScrollbarGhostStyle() })));
220
223
  }
221
224
  static get is() { return "six-menu"; }
222
225
  static get encapsulation() { return "shadow"; }
@@ -342,6 +345,24 @@ export class SixMenu {
342
345
  "attribute": "scrolling-debounce",
343
346
  "reflect": false,
344
347
  "defaultValue": "15"
348
+ },
349
+ "disableKeyboardHandling": {
350
+ "type": "boolean",
351
+ "mutable": false,
352
+ "complexType": {
353
+ "original": "boolean",
354
+ "resolved": "boolean",
355
+ "references": {}
356
+ },
357
+ "required": false,
358
+ "optional": false,
359
+ "docs": {
360
+ "tags": [],
361
+ "text": "Internal: Disables handling of key presses."
362
+ },
363
+ "attribute": "disable-keyboard-handling",
364
+ "reflect": false,
365
+ "defaultValue": "false"
345
366
  }
346
367
  };
347
368
  }
@@ -381,8 +402,9 @@ export class SixMenu {
381
402
  "complexType": {
382
403
  "signature": "(key: string) => Promise<void>",
383
404
  "parameters": [{
384
- "tags": [],
385
- "text": ""
405
+ "name": "key",
406
+ "type": "string",
407
+ "docs": ""
386
408
  }],
387
409
  "references": {
388
410
  "Promise": {
@@ -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 }: 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"]}
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) => (\n <six-menu-item key={value} value={value}>\n {label}\n </six-menu-item>\n);\n\nconst DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING = 5;\n\nconst DEFAULT_SIX_MENU_ITEM_HEIGHT = 64;\n\n/**\n * @since 1.0\n * @status stable\n *\n * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.\n *\n * @slot - The menu's content, including menu items, menu dividers, and menu labels.\n *\n * @part base - The component's base wrapper.\n */\n@Component({\n tag: 'six-menu',\n styleUrl: 'six-menu.scss',\n shadow: true,\n})\nexport class SixMenu {\n private readonly eventListeners = new EventListeners();\n\n private menu?: HTMLElement;\n private menuWrapper?: HTMLElement;\n private typeToSelectString = '';\n private typeToSelectTimeout?: number;\n\n @Element() host!: HTMLSixMenuElement;\n\n /** Emitted when a menu item is selected. */\n @Event({ eventName: 'six-menu-item-selected' }) sixMenuItemSelected!: EventEmitter<SixMenuItemSelectedPayload>;\n\n /** Set to true to remove the box-shadow */\n @Prop() removeBoxShadow = false;\n\n /** Set the options to be shown in the dropdown */\n @Prop() items: SixMenuItemData[] | null = null;\n\n /** Defines how many items should be shown. If the number of items is larger than this property a scrollbar will be shown */\n @Prop() itemsShown?: number;\n\n /** Defines whether the menu list will be rendered virtually i.e. only the elements actually shown (and a couple around)\n * are actually rendered in the DOM. If you use virtual scrolling pass the elements via prop instead of via slot. */\n @Prop() virtualScroll = false;\n\n /**\n * Used for virtual scrolling\n * Define how many items should be rendered in the DOM when using virtual scrolling\n */\n @Prop() itemSize = 10;\n\n /**\n * Used for virtual scrolling\n * Define the debounce for listening on scrolling changes in milliseconds.\n * The lower the number the more sensitive the component reacts to scrolling changes.\n */\n @Prop() scrollingDebounce = 15;\n\n /**\n * Internal: Disables handling of key presses.\n */\n @Prop() disableKeyboardHandling = false;\n\n /**\n * Used to calculate which items should be rendered in the DOM\n */\n @State()\n private scrollingIndex = 0;\n\n // set a default item height, this variable will be updated with the real value after the first render.\n // However, it's necessary to have a default value because we can only fetch the proper height after the first render\n @State()\n sixMenuItemHeight = DEFAULT_SIX_MENU_ITEM_HEIGHT;\n\n connectedCallback() {\n this.handleClick = this.handleClick.bind(this);\n this.handleKeyDown = this.handleKeyDown.bind(this);\n }\n\n componentWillLoad() {\n if (this.items === null) {\n return;\n }\n }\n\n private handleScrolling = () => {\n if (this.menuWrapper == null) return;\n // for performance improvements we only update the DOM if the scrollRatio change \"enough\"\n this.scrollingIndex = Math.floor(this.menuWrapper.scrollTop / this.sixMenuItemHeight);\n };\n\n componentDidLoad() {\n this.setupForVirtualScrollingAfterRendering();\n }\n\n disconnectedCallback() {\n this.eventListeners.removeAll();\n }\n\n /**\n * Initiates type-to-select logic, which automatically selects an option based on what the user is currently typing.\n * The key passed will be appended to the internal query and the selection will be updated. After a brief period, the\n * internal query is cleared automatically. This method is intended to be used with the keydown event. Useful for\n * enabling type-to-select when the menu doesn't have focus.\n */\n @Method()\n async typeToSelect(key: string) {\n clearTimeout(this.typeToSelectTimeout);\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n this.typeToSelectTimeout = setTimeout(() => (this.typeToSelectString = ''), 750);\n this.typeToSelectString += key.toLowerCase();\n const items = this.getItems();\n for (const item of items) {\n const slot = item.shadowRoot?.querySelector('slot:not([name])') as HTMLSlotElement;\n const label = getTextContent(slot).toLowerCase().trim();\n if (label.substring(0, this.typeToSelectString.length) === this.typeToSelectString) {\n item.setFocus();\n break;\n }\n }\n }\n\n private getItemsShown(): number {\n const defaultItemsShown = this.virtualScroll ? DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING : 0;\n return this.itemsShown ?? defaultItemsShown;\n }\n\n private setupForVirtualScrollingAfterRendering() {\n if (!this.virtualScroll || this.menuWrapper == null) return;\n\n this.eventListeners.add(this.menuWrapper, 'scroll', debounce(this.handleScrolling, this.scrollingDebounce));\n\n // set menu height to proper height once the item is rendered.\n const menuItemHeight = this.menu?.querySelector('six-menu-item')?.clientHeight;\n if (menuItemHeight != null && menuItemHeight > 0) {\n this.sixMenuItemHeight = menuItemHeight;\n }\n }\n\n private getItems(): HTMLSixMenuItemElement[] {\n if (this.menu == null) return [];\n\n if (this.items != null) {\n return this.items.map(mapToMenuItem);\n }\n\n const slot = this.menu.querySelector('slot');\n if (slot == null) return [];\n return [...slot.assignedElements({ flatten: true })].filter(\n (el): el is HTMLSixMenuItemElement => isSIXMenuItemElement(el) && !el.disabled\n );\n }\n\n private getActiveItemIndex() {\n const items = this.getItems();\n const selectedItem = this.getActiveItem();\n if (selectedItem != null) {\n const itemIndex = items.indexOf(selectedItem);\n if (itemIndex > -1) {\n return itemIndex;\n }\n }\n const sixMenuItems = this.extractItemsFromDOM();\n return sixMenuItems.findIndex(isFocusedMenuItem);\n }\n\n private getActiveItem(): HTMLSixMenuItemElement | undefined {\n const activeElement = this.getItems().find((i) => i === document.activeElement);\n if (activeElement != null) {\n return activeElement;\n }\n return this.extractItemsFromDOM()?.find(isFocusedMenuItem);\n }\n\n private extractItemsFromDOM() {\n return Array.from(this.host.shadowRoot?.querySelectorAll('six-menu-item') ?? []);\n }\n\n private setActiveItem(item: HTMLSixMenuItemElement) {\n item?.setFocus();\n }\n\n private handleClick(event: MouseEvent) {\n const target = event.target as HTMLElement;\n const clickedItem = target.closest('six-menu-item');\n if (clickedItem && !clickedItem.disabled) {\n this.sixMenuItemSelected.emit({ name: clickedItem.value, item: clickedItem });\n }\n }\n\n private handleKeyDown(event: KeyboardEvent) {\n if (this.disableKeyboardHandling) {\n return;\n }\n\n // Make a selection when pressing enter\n if (event.key === 'Enter') {\n const activeItem = this.getActiveItem();\n event.preventDefault();\n\n if (activeItem != null) {\n this.sixMenuItemSelected.emit({ name: activeItem.value, item: activeItem });\n }\n }\n\n // Prevent scrolling when space is pressed\n if (event.key === ' ') {\n event.preventDefault();\n }\n\n // Move the selection when pressing down or up\n if (['ArrowDown', 'ArrowUp', 'Home', 'End'].includes(event.key)) {\n const items = this.items === null ? this.getItems() : this.extractItemsFromDOM();\n\n let indexOfActiveItem = this.getActiveItemIndex();\n\n if (items.length > 0) {\n event.preventDefault();\n\n if (event.key === 'ArrowDown') {\n indexOfActiveItem++;\n } else if (event.key === 'ArrowUp') {\n indexOfActiveItem--;\n } else if (event.key === 'Home') {\n indexOfActiveItem = 0;\n } else if (event.key === 'End') {\n indexOfActiveItem = items.length - 1;\n }\n\n if (indexOfActiveItem < 0) indexOfActiveItem = 0;\n if (indexOfActiveItem > items.length - 1) indexOfActiveItem = items.length - 1;\n\n this.setActiveItem(items[indexOfActiveItem]);\n\n return;\n }\n }\n\n void this.typeToSelect(event.key);\n }\n\n private getMenuWrapperStyle() {\n const styles: Partial<StyleDeclaration> = {};\n if (this.getItemsShown() > 0) {\n // calculate the proper height to show the correct number of items\n styles.height = `${(this.getItemsShown() ?? 0) * this.sixMenuItemHeight}px`;\n }\n return {\n ...styles,\n };\n }\n\n private getMenuContainerStyle() {\n const styles: Partial<StyleDeclaration> = {};\n\n if (this.virtualScroll) {\n // calculate height of content are if all items would be rendered so the scrollbar has the proper size\n styles.transform = `translateY(${this.sixMenuItemHeight * this.scrollingIndex}px)`;\n }\n\n return {\n ...styles,\n };\n }\n\n private getScrollbarGhostStyle() {\n const styles: Partial<StyleDeclaration> = {};\n\n if (this.virtualScroll && this.items !== null) {\n styles.height = `${this.items.length * this.sixMenuItemHeight - this.itemSize * this.sixMenuItemHeight}px`;\n }\n\n return {\n ...styles,\n };\n }\n\n private renderItems() {\n if (this.items === undefined || this.items === null) {\n return;\n }\n\n if (!this.virtualScroll) {\n return this.items.map(mapToMenuItem);\n }\n\n return this.items\n .slice(this.scrollingIndex, Math.min(this.items.length, this.itemSize + this.scrollingIndex))\n .map(({ value, label }: SixMenuItemData) => (\n <six-menu-item checkType=\"check\" key={value} value={value}>\n {label}\n </six-menu-item>\n ));\n }\n\n render() {\n return (\n <div\n ref={(el) => (this.menuWrapper = el)}\n style={this.getMenuWrapperStyle()}\n part=\"wrapper\"\n class={{\n menu: true,\n '.no-shadow': this.removeBoxShadow,\n }}\n >\n <div\n ref={(el) => (this.menu = el)}\n part=\"base\"\n role=\"menu\"\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n tabIndex={0}\n style={this.getMenuContainerStyle()}\n >\n <slot />\n {this.renderItems()}\n </div>\n {this.virtualScroll && <div style={this.getScrollbarGhostStyle()} />}\n </div>\n );\n }\n}\n"]}
@@ -24,13 +24,13 @@ describe('six-menu', () => {
24
24
  html: `<six-menu remove-box-shadow></six-menu>`,
25
25
  });
26
26
  expect(page.root).toEqualHtml(`
27
- <six-menu remove-box-shadow>
27
+ <six-menu remove-box-shadow="">
28
28
  <mock:shadow-root>
29
- <div class="menu menu--noshadow" part="wrapper">
30
- <div part="base" role="menu" tabindex="0">
31
- <slot></slot>
29
+ <div class=".no-shadow menu" part="wrapper">
30
+ <div part="base" role="menu" tabindex="0">
31
+ <slot></slot>
32
+ </div>
32
33
  </div>
33
- </div>
34
34
  </mock:shadow-root>
35
35
  </six-menu>
36
36
  `);
@@ -43,7 +43,7 @@ describe('six-menu', () => {
43
43
  expect(page.root).toEqualHtml(`
44
44
  <six-menu virtual-scroll="">
45
45
  <mock:shadow-root>
46
- <div class="menu menu__wrapper--scrollable" part="wrapper" style="height: 320px;">
46
+ <div class="menu" part="wrapper" style="height: 320px;">
47
47
  <div part="base" role="menu" tabindex="0" style="transform: translateY(0px);">
48
48
  <slot></slot>
49
49
  </div>
@@ -1 +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;IACxB,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;QACvB,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;YACrB,IAAI,EAAE,uBAAuB;SAC9B,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;KAU7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;QAC1C,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;YACrB,IAAI,EAAE,yCAAyC;SAChD,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;KAU7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QACzC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;YACrB,IAAI,EAAE,sCAAsC;SAC7C,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;KAW7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QAC/C,QAAQ;QACR,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;YACrB,IAAI,EAAE,uBAAuB;SAC9B,CAAC,CAAC;QAEH,OAAO;QACP,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,EAAE;YACrB,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;gBAC1D,KAAK,EAAE,SAAS,GAAG,EAAE;gBACrB,KAAK,EAAE,SAAS,GAAG,EAAE;aACtB,CAAC,CAAC,CAAC;SACL;QACD,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,OAAO;QACP,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;;;;;KAmB7B,CAAC,CAAC;IACL,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
+ {"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;IACxB,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;QACvB,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;YACrB,IAAI,EAAE,uBAAuB;SAC9B,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;KAU7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;QAC1C,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;YACrB,IAAI,EAAE,yCAAyC;SAChD,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;KAU7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QACzC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;YACrB,IAAI,EAAE,sCAAsC;SAC7C,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;KAW7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QAC/C,QAAQ;QACR,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;YACrB,IAAI,EAAE,uBAAuB;SAC9B,CAAC,CAAC;QAEH,OAAO;QACP,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,EAAE,CAAC;YACtB,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;gBAC1D,KAAK,EAAE,SAAS,GAAG,EAAE;gBACrB,KAAK,EAAE,SAAS,GAAG,EAAE;aACtB,CAAC,CAAC,CAAC;QACN,CAAC;QACD,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,OAAO;QACP,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;;;;;KAmB7B,CAAC,CAAC;IACL,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=\".no-shadow 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 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\" 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"]}
@@ -3,7 +3,7 @@
3
3
  box-sizing: border-box;
4
4
  }
5
5
  :host *, :host *:before, :host *:after {
6
- box-sizing: inherit;
6
+ box-sizing: border-box;
7
7
  }
8
8
 
9
9
  :host {
@@ -12,5 +12,6 @@
12
12
 
13
13
  .menu-divider {
14
14
  border-top: solid var(--six-border-width) var(--six-menu-divider-color);
15
- margin: 0;
15
+ margin-top: var(--six-spacing-xx-small);
16
+ margin-bottom: var(--six-spacing-xx-small);
16
17
  }
@@ -9,7 +9,7 @@ import { h } from "@stencil/core";
9
9
  */
10
10
  export class SixMenuDivider {
11
11
  render() {
12
- return h("div", { part: "base", class: "menu-divider", role: "separator", "aria-hidden": "true" });
12
+ return h("div", { key: '41a61bd4110bfb44f10211c350afcebe5c5971df', part: "base", class: "menu-divider", role: "separator", "aria-hidden": "true" });
13
13
  }
14
14
  static get is() { return "six-menu-divider"; }
15
15
  static get encapsulation() { return "shadow"; }
@@ -1 +1 @@
1
- {"version":3,"file":"six-menu-divider.js","sourceRoot":"","sources":["../../../src/components/six-menu-divider/six-menu-divider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAE7C;;;;;;;GAOG;AAOH,MAAM,OAAO,cAAc;IACzB,MAAM;QACJ,OAAO,WAAK,IAAI,EAAC,MAAM,EAAC,KAAK,EAAC,cAAc,EAAC,IAAI,EAAC,WAAW,iBAAa,MAAM,GAAG,CAAC;IACtF,CAAC;;;;;;;;;CACF","sourcesContent":["import { Component, h } from '@stencil/core';\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 * @part base - The component's base wrapper.\n */\n\n@Component({\n tag: 'six-menu-divider',\n styleUrl: 'six-menu-divider.scss',\n shadow: true,\n})\nexport class SixMenuDivider {\n render() {\n return <div part=\"base\" class=\"menu-divider\" role=\"separator\" aria-hidden=\"true\" />;\n }\n}\n"]}
1
+ {"version":3,"file":"six-menu-divider.js","sourceRoot":"","sources":["../../../src/components/six-menu-divider/six-menu-divider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAE7C;;;;;;;GAOG;AAOH,MAAM,OAAO,cAAc;IACzB,MAAM;QACJ,OAAO,4DAAK,IAAI,EAAC,MAAM,EAAC,KAAK,EAAC,cAAc,EAAC,IAAI,EAAC,WAAW,iBAAa,MAAM,GAAG,CAAC;IACtF,CAAC;;;;;;;;;CACF","sourcesContent":["import { Component, h } from '@stencil/core';\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 * @part base - The component's base wrapper.\n */\n\n@Component({\n tag: 'six-menu-divider',\n styleUrl: 'six-menu-divider.scss',\n shadow: true,\n})\nexport class SixMenuDivider {\n render() {\n return <div part=\"base\" class=\"menu-divider\" role=\"separator\" aria-hidden=\"true\" />;\n }\n}\n"]}
@@ -3,13 +3,17 @@
3
3
  box-sizing: border-box;
4
4
  }
5
5
  :host *, :host *:before, :host *:after {
6
- box-sizing: inherit;
6
+ box-sizing: border-box;
7
7
  }
8
8
 
9
9
  :host {
10
10
  display: block;
11
11
  }
12
12
 
13
+ :focus {
14
+ outline: none;
15
+ }
16
+
13
17
  .menu-item {
14
18
  position: relative;
15
19
  display: flex;
@@ -22,7 +26,7 @@
22
26
  text-align: left;
23
27
  color: var(--six-input-color);
24
28
  border-radius: var(--six-border-radius-medium);
25
- padding: var(--six-spacing-medium) var(--six-spacing-medium);
29
+ padding: var(--six-spacing-x-small) var(--six-spacing-medium);
26
30
  transition: var(--six-transition-fast) fill;
27
31
  user-select: none;
28
32
  white-space: nowrap;
@@ -32,6 +36,10 @@
32
36
  outline: none;
33
37
  background-color: var(--six-menu-item-background-color);
34
38
  }
39
+ .menu-item.menu-item--active:not(.menu-item--disabled) {
40
+ outline: none;
41
+ background-color: var(--six-menu-item-background-color);
42
+ }
35
43
  .menu-item.menu-item--disabled {
36
44
  outline: none;
37
45
  color: var(--six-input-color-disabled);
@@ -65,6 +73,9 @@
65
73
  visibility: hidden;
66
74
  font-size: inherit;
67
75
  }
76
+ .menu-item .menu-item__checkbox {
77
+ margin-top: -1px;
78
+ }
68
79
 
69
80
  .menu-item--checked .menu-item__check {
70
81
  visibility: visible;
@@ -18,7 +18,12 @@ import { getTextContent } from "../../utils/slot";
18
18
  */
19
19
  export class SixMenuItem {
20
20
  constructor() {
21
+ this.handleCheckboxChange = () => {
22
+ this.host.dispatchEvent(new Event('click', { bubbles: true, cancelable: true }));
23
+ };
21
24
  this.hasFocus = false;
25
+ this.active = false;
26
+ this.checkType = 'check';
22
27
  this.checked = false;
23
28
  this.value = '';
24
29
  this.disabled = false;
@@ -28,6 +33,7 @@ export class SixMenuItem {
28
33
  this.handleFocus = this.handleFocus.bind(this);
29
34
  this.handleMouseEnter = this.handleMouseEnter.bind(this);
30
35
  this.handleMouseLeave = this.handleMouseLeave.bind(this);
36
+ this.handleCheckboxChange = this.handleCheckboxChange.bind(this);
31
37
  }
32
38
  /** Sets focus on the button. */
33
39
  async setFocus(options) {
@@ -50,18 +56,20 @@ export class SixMenuItem {
50
56
  this.hasFocus = true;
51
57
  }
52
58
  handleMouseEnter() {
53
- return this.setFocus();
59
+ this.active = true;
54
60
  }
55
61
  handleMouseLeave() {
56
- return this.removeFocus();
62
+ this.active = false;
63
+ this.hasFocus = false;
57
64
  }
58
65
  render() {
59
- return (h("div", { ref: (el) => (this.menuItem = el), part: "base", class: {
66
+ return (h("div", { key: 'd8c10ca0fc9bd795b87790337f2cc0c792999685', ref: (el) => (this.menuItem = el), part: "base", class: {
60
67
  'menu-item': true,
61
68
  'menu-item--checked': this.checked,
62
69
  'menu-item--disabled': this.disabled,
63
70
  'menu-item--focused': this.hasFocus,
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"))));
71
+ 'menu-item--active': this.active,
72
+ }, 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 }, this.checkType === 'checkbox' && (h("span", { class: "menu-item__checkbox" }, h("six-checkbox", { "onSix-checkbox-change": this.handleCheckboxChange, disabled: this.disabled, checked: this.checked }))), h("span", { key: '470f2fee47a4120c0dead3b7996220af9e5274d1', part: "prefix", class: "menu-item__prefix" }, h("slot", { key: 'fdddb68cb266d02f6a6a2b46ffcdecb1d8eb32db', name: "prefix" })), h("span", { key: '6d9fe694ce0e07f2aac3604b905f9194f4764057', part: "label", class: "menu-item__label" }, h("slot", { key: 'ef2903a04191f78955802da5edefd32583305068', ref: (el) => (this.defaultSlot = el) })), h("span", { key: 'd4f6ee6c2789c33deaf08eb585ec7ca283b59170', part: "suffix", class: "menu-item__suffix" }, h("slot", { key: '39a1d59be3d1f9deda4c55b1575a72c647600783', name: "suffix" })), this.checkType === 'check' && (h("span", { part: "checked-icon", class: "menu-item__check" }, h("six-icon", { size: "small", "aria-hidden": "true" }, "check")))));
65
73
  }
66
74
  static get is() { return "six-menu-item"; }
67
75
  static get encapsulation() { return "shadow"; }
@@ -77,6 +85,24 @@ export class SixMenuItem {
77
85
  }
78
86
  static get properties() {
79
87
  return {
88
+ "checkType": {
89
+ "type": "string",
90
+ "mutable": false,
91
+ "complexType": {
92
+ "original": "'checkbox' | 'check'",
93
+ "resolved": "\"check\" | \"checkbox\"",
94
+ "references": {}
95
+ },
96
+ "required": false,
97
+ "optional": false,
98
+ "docs": {
99
+ "tags": [],
100
+ "text": "Defines if the checked state is displayed as a checkbox or a check-icon"
101
+ },
102
+ "attribute": "check-type",
103
+ "reflect": false,
104
+ "defaultValue": "'check'"
105
+ },
80
106
  "checked": {
81
107
  "type": "boolean",
82
108
  "mutable": false,
@@ -89,7 +115,7 @@ export class SixMenuItem {
89
115
  "optional": false,
90
116
  "docs": {
91
117
  "tags": [],
92
- "text": "Set to true to draw the item in a checked state."
118
+ "text": "Internal: Draws the item in a checked state. CheckType needs to be set to 'checkbox' or 'check' to show the\nchecked state"
93
119
  },
94
120
  "attribute": "checked",
95
121
  "reflect": true,
@@ -135,7 +161,8 @@ export class SixMenuItem {
135
161
  }
136
162
  static get states() {
137
163
  return {
138
- "hasFocus": {}
164
+ "hasFocus": {},
165
+ "active": {}
139
166
  };
140
167
  }
141
168
  static get methods() {
@@ -144,8 +171,9 @@ export class SixMenuItem {
144
171
  "complexType": {
145
172
  "signature": "(options?: FocusOptions) => Promise<void>",
146
173
  "parameters": [{
147
- "tags": [],
148
- "text": ""
174
+ "name": "options",
175
+ "type": "FocusOptions | undefined",
176
+ "docs": ""
149
177
  }],
150
178
  "references": {
151
179
  "Promise": {
@@ -200,5 +228,6 @@ export class SixMenuItem {
200
228
  }
201
229
  };
202
230
  }
231
+ static get elementRef() { return "host"; }
203
232
  }
204
233
  //# sourceMappingURL=six-menu-item.js.map
@@ -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, 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"]}
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, Element, 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 @Element() host!: HTMLSixMenuItemElement;\n\n @State() hasFocus = false;\n\n @State() active = false;\n\n /** Defines if the checked state is displayed as a checkbox or a check-icon */\n @Prop() checkType: 'checkbox' | 'check' = 'check';\n\n /** Internal: Draws the item in a checked state. CheckType needs to be set to 'checkbox' or 'check' to show the\n * 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 this.handleCheckboxChange = this.handleCheckboxChange.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 this.active = true;\n }\n\n private handleMouseLeave() {\n this.active = false;\n this.hasFocus = false;\n }\n\n private handleCheckboxChange = () => {\n this.host.dispatchEvent(new Event('click', { bubbles: true, cancelable: true }));\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 'menu-item--active': this.active,\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 {this.checkType === 'checkbox' && (\n <span class=\"menu-item__checkbox\">\n <six-checkbox\n onSix-checkbox-change={this.handleCheckboxChange}\n disabled={this.disabled}\n checked={this.checked}\n ></six-checkbox>\n </span>\n )}\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 {this.checkType === 'check' && (\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 )}\n </div>\n );\n }\n}\n"]}
@@ -3,7 +3,7 @@
3
3
  box-sizing: border-box;
4
4
  }
5
5
  :host *, :host *:before, :host *:after {
6
- box-sizing: inherit;
6
+ box-sizing: border-box;
7
7
  }
8
8
 
9
9
  :host {
@@ -11,7 +11,7 @@ import { h } from "@stencil/core";
11
11
  */
12
12
  export class SixMenuLabel {
13
13
  render() {
14
- return (h("div", { part: "base", class: "menu-label" }, h("slot", null)));
14
+ return (h("div", { key: '5183d165a877bd2ca0c25d4ff61d55200b66132d', part: "base", class: "menu-label" }, h("slot", { key: '5adecf55a82a78de5eee401aeec442f7e60e0874' })));
15
15
  }
16
16
  static get is() { return "six-menu-label"; }
17
17
  static get encapsulation() { return "shadow"; }
@@ -1 +1 @@
1
- {"version":3,"file":"six-menu-label.js","sourceRoot":"","sources":["../../../src/components/six-menu-label/six-menu-label.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAE7C;;;;;;;;;GASG;AAOH,MAAM,OAAO,YAAY;IACvB,MAAM;QACJ,OAAO,CACL,WAAK,IAAI,EAAC,MAAM,EAAC,KAAK,EAAC,YAAY;YACjC,eAAQ,CACJ,CACP,CAAC;IACJ,CAAC;;;;;;;;;CACF","sourcesContent":["import { Component, h } from '@stencil/core';\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 label's content.\n *\n * @part base - The component's base wrapper.\n */\n\n@Component({\n tag: 'six-menu-label',\n styleUrl: 'six-menu-label.scss',\n shadow: true,\n})\nexport class SixMenuLabel {\n render() {\n return (\n <div part=\"base\" class=\"menu-label\">\n <slot />\n </div>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"six-menu-label.js","sourceRoot":"","sources":["../../../src/components/six-menu-label/six-menu-label.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAE7C;;;;;;;;;GASG;AAOH,MAAM,OAAO,YAAY;IACvB,MAAM;QACJ,OAAO,CACL,4DAAK,IAAI,EAAC,MAAM,EAAC,KAAK,EAAC,YAAY;YACjC,8DAAQ,CACJ,CACP,CAAC;IACJ,CAAC;;;;;;;;;CACF","sourcesContent":["import { Component, h } from '@stencil/core';\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 label's content.\n *\n * @part base - The component's base wrapper.\n */\n\n@Component({\n tag: 'six-menu-label',\n styleUrl: 'six-menu-label.scss',\n shadow: true,\n})\nexport class SixMenuLabel {\n render() {\n return (\n <div part=\"base\" class=\"menu-label\">\n <slot />\n </div>\n );\n }\n}\n"]}
@@ -12,7 +12,7 @@ export class SixPicto {
12
12
  render() {
13
13
  var _a;
14
14
  const iconName = (_a = this.host.innerHTML) === null || _a === void 0 ? void 0 : _a.trim();
15
- return (h(Host, null, h("div", { part: "icon", class: {
15
+ return (h(Host, { key: 'adec8f35b8501390c0831495ea9f915f6616aa04' }, h("div", { key: '92bcee923694c027ed93554d4d93924b58803b82', part: "icon", class: {
16
16
  [`is-size-${this.size}`]: typeof this.size != null || this.size.trim() !== '',
17
17
  [`${iconName}`]: true,
18
18
  } })));
@@ -1 +1 @@
1
- {"version":3,"file":"six-picto.js","sourceRoot":"","sources":["../../../src/components/six-picto/six-picto.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAElE;;;;;GAKG;AAOH,MAAM,OAAO,QAAQ;;oBAMiF,QAAQ;;IAE5G,MAAM;;QACJ,MAAM,QAAQ,GAAG,MAAA,IAAI,CAAC,IAAI,CAAC,SAAS,0CAAE,IAAI,EAAE,CAAC;QAC7C,OAAO,CACL,EAAC,IAAI;YACH,WACE,IAAI,EAAC,MAAM,EACX,KAAK,EAAE;oBACL,CAAC,WAAW,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE;oBAC7E,CAAC,GAAG,QAAQ,EAAE,CAAC,EAAE,IAAI;iBACtB,GACD,CACG,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Element, h, Host, Prop } from '@stencil/core';\n\n/**\n * @since 1.1\n * @status stable\n *\n * @part icon - The component's icon wrapper.\n */\n\n@Component({\n tag: 'six-picto',\n styleUrl: 'six-picto.scss',\n shadow: true,\n})\nexport class SixPicto {\n @Element() host!: HTMLSixPictoElement;\n\n /**\n * Defines the size of the icon.\n */\n @Prop() size: 'xSmall' | 'small' | 'medium' | 'large' | 'xLarge' | 'xxLarge' | 'xxxLarge' | '4xl' = 'medium';\n\n render() {\n const iconName = this.host.innerHTML?.trim();\n return (\n <Host>\n <div\n part=\"icon\"\n class={{\n [`is-size-${this.size}`]: typeof this.size != null || this.size.trim() !== '',\n [`${iconName}`]: true,\n }}\n />\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"six-picto.js","sourceRoot":"","sources":["../../../src/components/six-picto/six-picto.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAElE;;;;;GAKG;AAOH,MAAM,OAAO,QAAQ;;oBAMiF,QAAQ;;IAE5G,MAAM;;QACJ,MAAM,QAAQ,GAAG,MAAA,IAAI,CAAC,IAAI,CAAC,SAAS,0CAAE,IAAI,EAAE,CAAC;QAC7C,OAAO,CACL,EAAC,IAAI;YACH,4DACE,IAAI,EAAC,MAAM,EACX,KAAK,EAAE;oBACL,CAAC,WAAW,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE;oBAC7E,CAAC,GAAG,QAAQ,EAAE,CAAC,EAAE,IAAI;iBACtB,GACD,CACG,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Element, h, Host, Prop } from '@stencil/core';\n\n/**\n * @since 1.1\n * @status stable\n *\n * @part icon - The component's icon wrapper.\n */\n\n@Component({\n tag: 'six-picto',\n styleUrl: 'six-picto.scss',\n shadow: true,\n})\nexport class SixPicto {\n @Element() host!: HTMLSixPictoElement;\n\n /**\n * Defines the size of the icon.\n */\n @Prop() size: 'xSmall' | 'small' | 'medium' | 'large' | 'xLarge' | 'xxLarge' | 'xxxLarge' | '4xl' = 'medium';\n\n render() {\n const iconName = this.host.innerHTML?.trim();\n return (\n <Host>\n <div\n part=\"icon\"\n class={{\n [`is-size-${this.size}`]: typeof this.size != null || this.size.trim() !== '',\n [`${iconName}`]: true,\n }}\n />\n </Host>\n );\n }\n}\n"]}
@@ -3,7 +3,7 @@
3
3
  box-sizing: border-box;
4
4
  }
5
5
  :host *, :host *:before, :host *:after {
6
- box-sizing: inherit;
6
+ box-sizing: border-box;
7
7
  }
8
8
 
9
9
  /**
@@ -17,10 +17,10 @@ export class SixProgressBar {
17
17
  this.indeterminate = false;
18
18
  }
19
19
  render() {
20
- return (h("div", { part: "base", class: {
20
+ return (h("div", { key: '5361da7a78cfcaa6375e078da88209dcd725d832', part: "base", class: {
21
21
  'progress-bar': true,
22
22
  'progress-bar--indeterminate': this.indeterminate,
23
- }, role: "progressbar", "aria-valuemin": "0", "aria-valuemax": "100", "aria-valuenow": this.indeterminate ? null : this.percentage }, h("div", { part: "indicator", class: "progress-bar__indicator", style: {
23
+ }, role: "progressbar", "aria-valuemin": "0", "aria-valuemax": "100", "aria-valuenow": this.indeterminate ? null : this.percentage }, h("div", { key: 'a3dea20c3afea5be2c6c02adf9e6f98cdb038cbb', part: "indicator", class: "progress-bar__indicator", style: {
24
24
  width: `${this.percentage}%`,
25
25
  } }, !this.indeterminate && (h("span", { part: "label", class: "progress-bar__label" }, h("slot", null))))));
26
26
  }
@@ -1 +1 @@
1
- {"version":3,"file":"six-progress-bar.js","sourceRoot":"","sources":["../../../src/components/six-progress-bar/six-progress-bar.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAEnD;;;;;;;;;;;GAWG;AAOH,MAAM,OAAO,cAAc;;0BAEJ,CAAC;6BAGE,KAAK;;IAE7B,MAAM;QACJ,OAAO,CACL,WACE,IAAI,EAAC,MAAM,EACX,KAAK,EAAE;gBACL,cAAc,EAAE,IAAI;gBACpB,6BAA6B,EAAE,IAAI,CAAC,aAAa;aAClD,EACD,IAAI,EAAC,aAAa,mBACJ,GAAG,mBACH,KAAK,mBACJ,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU;YAE1D,WACE,IAAI,EAAC,WAAW,EAChB,KAAK,EAAC,yBAAyB,EAC/B,KAAK,EAAE;oBACL,KAAK,EAAE,GAAG,IAAI,CAAC,UAAU,GAAG;iBAC7B,IAEA,CAAC,IAAI,CAAC,aAAa,IAAI,CACtB,YAAM,IAAI,EAAC,OAAO,EAAC,KAAK,EAAC,qBAAqB;gBAC5C,eAAQ,CACH,CACR,CACG,CACF,CACP,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, h, Prop } from '@stencil/core';\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 - A label to show inside the indicator.\n *\n * @part base - The component's base wrapper.\n * @part indicator - The progress bar indicator.\n * @part label - The progress bar label.\n */\n\n@Component({\n tag: 'six-progress-bar',\n styleUrl: 'six-progress-bar.scss',\n shadow: true,\n})\nexport class SixProgressBar {\n /** The progress bar's percentage, 0 to 100. */\n @Prop() percentage = 0;\n\n /** When true, percentage is ignored, the label is hidden, and the progress bar is drawn in an indeterminate state. */\n @Prop() indeterminate = false;\n\n render() {\n return (\n <div\n part=\"base\"\n class={{\n 'progress-bar': true,\n 'progress-bar--indeterminate': this.indeterminate,\n }}\n role=\"progressbar\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n aria-valuenow={this.indeterminate ? null : this.percentage}\n >\n <div\n part=\"indicator\"\n class=\"progress-bar__indicator\"\n style={{\n width: `${this.percentage}%`,\n }}\n >\n {!this.indeterminate && (\n <span part=\"label\" class=\"progress-bar__label\">\n <slot />\n </span>\n )}\n </div>\n </div>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"six-progress-bar.js","sourceRoot":"","sources":["../../../src/components/six-progress-bar/six-progress-bar.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAEnD;;;;;;;;;;;GAWG;AAOH,MAAM,OAAO,cAAc;;0BAEJ,CAAC;6BAGE,KAAK;;IAE7B,MAAM;QACJ,OAAO,CACL,4DACE,IAAI,EAAC,MAAM,EACX,KAAK,EAAE;gBACL,cAAc,EAAE,IAAI;gBACpB,6BAA6B,EAAE,IAAI,CAAC,aAAa;aAClD,EACD,IAAI,EAAC,aAAa,mBACJ,GAAG,mBACH,KAAK,mBACJ,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU;YAE1D,4DACE,IAAI,EAAC,WAAW,EAChB,KAAK,EAAC,yBAAyB,EAC/B,KAAK,EAAE;oBACL,KAAK,EAAE,GAAG,IAAI,CAAC,UAAU,GAAG;iBAC7B,IAEA,CAAC,IAAI,CAAC,aAAa,IAAI,CACtB,YAAM,IAAI,EAAC,OAAO,EAAC,KAAK,EAAC,qBAAqB;gBAC5C,eAAQ,CACH,CACR,CACG,CACF,CACP,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, h, Prop } from '@stencil/core';\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 - A label to show inside the indicator.\n *\n * @part base - The component's base wrapper.\n * @part indicator - The progress bar indicator.\n * @part label - The progress bar label.\n */\n\n@Component({\n tag: 'six-progress-bar',\n styleUrl: 'six-progress-bar.scss',\n shadow: true,\n})\nexport class SixProgressBar {\n /** The progress bar's percentage, 0 to 100. */\n @Prop() percentage = 0;\n\n /** When true, percentage is ignored, the label is hidden, and the progress bar is drawn in an indeterminate state. */\n @Prop() indeterminate = false;\n\n render() {\n return (\n <div\n part=\"base\"\n class={{\n 'progress-bar': true,\n 'progress-bar--indeterminate': this.indeterminate,\n }}\n role=\"progressbar\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n aria-valuenow={this.indeterminate ? null : this.percentage}\n >\n <div\n part=\"indicator\"\n class=\"progress-bar__indicator\"\n style={{\n width: `${this.percentage}%`,\n }}\n >\n {!this.indeterminate && (\n <span part=\"label\" class=\"progress-bar__label\">\n <slot />\n </span>\n )}\n </div>\n </div>\n );\n }\n}\n"]}
@@ -3,7 +3,7 @@
3
3
  box-sizing: border-box;
4
4
  }
5
5
  :host *, :host *:before, :host *:after {
6
- box-sizing: inherit;
6
+ box-sizing: border-box;
7
7
  }
8
8
 
9
9
  /**