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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (354) hide show
  1. package/dist/cjs/{form-control-8e2ae807.js → form-control-2c17c573.js} +2 -2
  2. package/dist/cjs/{form-control-8e2ae807.js.map → form-control-2c17c573.js.map} +1 -1
  3. package/dist/cjs/{index-b3257a77.js → index-2f6daa5b.js} +1 -3
  4. package/dist/cjs/index-2f6daa5b.js.map +1 -0
  5. package/dist/cjs/loader.cjs.js +2 -2
  6. package/dist/cjs/set-attributes_2.cjs.entry.js +1 -1
  7. package/dist/cjs/six-alert.cjs.entry.js +1 -1
  8. package/dist/cjs/six-avatar.cjs.entry.js +1 -1
  9. package/dist/cjs/six-badge.cjs.entry.js +1 -1
  10. package/dist/cjs/six-button.cjs.entry.js +1 -1
  11. package/dist/cjs/six-card.cjs.entry.js +1 -1
  12. package/dist/cjs/six-checkbox.cjs.entry.js +2 -2
  13. package/dist/cjs/six-datepicker.cjs.entry.js +2 -2
  14. package/dist/cjs/six-datepicker.cjs.entry.js.map +1 -1
  15. package/dist/cjs/six-details.cjs.entry.js +1 -1
  16. package/dist/cjs/six-dialog.cjs.entry.js +1 -1
  17. package/dist/cjs/six-drawer.cjs.entry.js +1 -1
  18. package/dist/cjs/{six-dropdown_3.cjs.entry.js → six-dropdown_2.cjs.entry.js} +2 -54
  19. package/dist/cjs/six-dropdown_2.cjs.entry.js.map +1 -0
  20. package/dist/cjs/six-error-page.cjs.entry.js +1 -1
  21. package/dist/cjs/six-file-list-item.cjs.entry.js +1 -1
  22. package/dist/cjs/six-file-list.cjs.entry.js +1 -1
  23. package/dist/cjs/six-file-upload.cjs.entry.js +1 -1
  24. package/dist/cjs/six-footer.cjs.entry.js +1 -1
  25. package/dist/cjs/six-form.cjs.entry.js +1 -1
  26. package/dist/cjs/six-group-label.cjs.entry.js +2 -2
  27. package/dist/cjs/six-header.cjs.entry.js +1 -1
  28. package/dist/cjs/six-icon-button.cjs.entry.js +1 -1
  29. package/dist/cjs/six-icon.cjs.entry.js +1 -1
  30. package/dist/cjs/six-input.cjs.entry.js +2 -2
  31. package/dist/cjs/six-item-picker.cjs.entry.js +1 -1
  32. package/dist/cjs/six-language-switcher.cjs.entry.js +1 -1
  33. package/dist/cjs/six-layout-grid.cjs.entry.js +1 -1
  34. package/dist/cjs/six-main-container.cjs.entry.js +1 -1
  35. package/dist/cjs/six-menu-divider.cjs.entry.js +1 -1
  36. package/dist/cjs/six-menu-item.cjs.entry.js +61 -0
  37. package/dist/cjs/six-menu-item.cjs.entry.js.map +1 -0
  38. package/dist/cjs/six-menu-label.cjs.entry.js +1 -1
  39. package/dist/cjs/six-picto.cjs.entry.js +1 -1
  40. package/dist/cjs/six-progress-bar.cjs.entry.js +1 -1
  41. package/dist/cjs/six-progress-ring.cjs.entry.js +1 -1
  42. package/dist/cjs/six-radio.cjs.entry.js +1 -1
  43. package/dist/cjs/six-range.cjs.entry.js +2 -2
  44. package/dist/cjs/six-root.cjs.entry.js +1 -1
  45. package/dist/cjs/six-search-field.cjs.entry.js +1 -1
  46. package/dist/cjs/six-select.cjs.entry.js +2 -2
  47. package/dist/cjs/six-sidebar-item-group.cjs.entry.js +1 -1
  48. package/dist/cjs/six-sidebar-item.cjs.entry.js +1 -1
  49. package/dist/cjs/six-sidebar.cjs.entry.js +1 -1
  50. package/dist/cjs/six-spinner.cjs.entry.js +1 -1
  51. package/dist/cjs/six-switch.cjs.entry.js +1 -1
  52. package/dist/cjs/six-tab-group.cjs.entry.js +1 -1
  53. package/dist/cjs/six-tab-panel.cjs.entry.js +1 -1
  54. package/dist/cjs/six-tab.cjs.entry.js +1 -1
  55. package/dist/cjs/six-tag.cjs.entry.js +1 -1
  56. package/dist/cjs/six-textarea.cjs.entry.js +2 -2
  57. package/dist/cjs/six-tile.cjs.entry.js +1 -1
  58. package/dist/cjs/six-timepicker.cjs.entry.js +1 -1
  59. package/dist/cjs/six-tooltip.cjs.entry.js +1 -1
  60. package/dist/cjs/ui-library.cjs.js +2 -2
  61. package/dist/collection/collection-manifest.json +0 -5
  62. package/dist/collection/components/six-datepicker/six-datepicker.css +1 -1
  63. package/dist/collection/components/six-datepicker/six-datepicker.js +2 -2
  64. package/dist/collection/components/six-dropdown/six-dropdown.js +3 -3
  65. package/dist/collection/components/six-file-list-item/six-file-list-item.js +2 -2
  66. package/dist/collection/components/six-file-upload/six-file-upload.js +2 -2
  67. package/dist/collection/components/six-form/six-form.js +2 -2
  68. package/dist/collection/components/six-header/six-header.js +3 -3
  69. package/dist/collection/components/six-item-picker/six-item-picker.js +2 -2
  70. package/dist/collection/components/six-language-switcher/six-language-switcher.js +2 -2
  71. package/dist/collection/components/six-menu/six-menu.js +2 -2
  72. package/dist/collection/components/six-root/six-root.js +1 -1
  73. package/dist/collection/components/six-search-field/six-search-field.js +1 -1
  74. package/dist/collection/components/six-select/six-select.js +1 -1
  75. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js +1 -1
  76. package/dist/collection/components/six-tab-group/six-tab-group.js +2 -2
  77. package/dist/collection/components/six-timepicker/six-timepicker.js +2 -2
  78. package/dist/components/index.js +0 -10
  79. package/dist/components/index.js.map +1 -1
  80. package/dist/components/six-datepicker.js +1 -1
  81. package/dist/components/six-datepicker.js.map +1 -1
  82. package/dist/components.json +3 -488
  83. package/dist/esm/{form-control-bdd1478a.js → form-control-3b440ea1.js} +2 -2
  84. package/dist/esm/{form-control-bdd1478a.js.map → form-control-3b440ea1.js.map} +1 -1
  85. package/dist/esm/{index-96b1af5d.js → index-5c0f6628.js} +2 -3
  86. package/dist/esm/index-5c0f6628.js.map +1 -0
  87. package/dist/esm/loader.js +3 -3
  88. package/dist/esm/set-attributes_2.entry.js +1 -1
  89. package/dist/esm/six-alert.entry.js +1 -1
  90. package/dist/esm/six-avatar.entry.js +1 -1
  91. package/dist/esm/six-badge.entry.js +1 -1
  92. package/dist/esm/six-button.entry.js +1 -1
  93. package/dist/esm/six-card.entry.js +1 -1
  94. package/dist/esm/six-checkbox.entry.js +2 -2
  95. package/dist/esm/six-datepicker.entry.js +2 -2
  96. package/dist/esm/six-datepicker.entry.js.map +1 -1
  97. package/dist/esm/six-details.entry.js +1 -1
  98. package/dist/esm/six-dialog.entry.js +1 -1
  99. package/dist/esm/six-drawer.entry.js +1 -1
  100. package/dist/esm/{six-dropdown_3.entry.js → six-dropdown_2.entry.js} +3 -54
  101. package/dist/esm/six-dropdown_2.entry.js.map +1 -0
  102. package/dist/esm/six-error-page.entry.js +1 -1
  103. package/dist/esm/six-file-list-item.entry.js +1 -1
  104. package/dist/esm/six-file-list.entry.js +1 -1
  105. package/dist/esm/six-file-upload.entry.js +1 -1
  106. package/dist/esm/six-footer.entry.js +1 -1
  107. package/dist/esm/six-form.entry.js +1 -1
  108. package/dist/esm/six-group-label.entry.js +2 -2
  109. package/dist/esm/six-header.entry.js +1 -1
  110. package/dist/esm/six-icon-button.entry.js +1 -1
  111. package/dist/esm/six-icon.entry.js +1 -1
  112. package/dist/esm/six-input.entry.js +2 -2
  113. package/dist/esm/six-item-picker.entry.js +1 -1
  114. package/dist/esm/six-language-switcher.entry.js +1 -1
  115. package/dist/esm/six-layout-grid.entry.js +1 -1
  116. package/dist/esm/six-main-container.entry.js +1 -1
  117. package/dist/esm/six-menu-divider.entry.js +1 -1
  118. package/dist/esm/six-menu-item.entry.js +57 -0
  119. package/dist/esm/six-menu-item.entry.js.map +1 -0
  120. package/dist/esm/six-menu-label.entry.js +1 -1
  121. package/dist/esm/six-picto.entry.js +1 -1
  122. package/dist/esm/six-progress-bar.entry.js +1 -1
  123. package/dist/esm/six-progress-ring.entry.js +1 -1
  124. package/dist/esm/six-radio.entry.js +1 -1
  125. package/dist/esm/six-range.entry.js +2 -2
  126. package/dist/esm/six-root.entry.js +1 -1
  127. package/dist/esm/six-search-field.entry.js +1 -1
  128. package/dist/esm/six-select.entry.js +2 -2
  129. package/dist/esm/six-sidebar-item-group.entry.js +1 -1
  130. package/dist/esm/six-sidebar-item.entry.js +1 -1
  131. package/dist/esm/six-sidebar.entry.js +1 -1
  132. package/dist/esm/six-spinner.entry.js +1 -1
  133. package/dist/esm/six-switch.entry.js +1 -1
  134. package/dist/esm/six-tab-group.entry.js +1 -1
  135. package/dist/esm/six-tab-panel.entry.js +1 -1
  136. package/dist/esm/six-tab.entry.js +1 -1
  137. package/dist/esm/six-tag.entry.js +1 -1
  138. package/dist/esm/six-textarea.entry.js +2 -2
  139. package/dist/esm/six-tile.entry.js +1 -1
  140. package/dist/esm/six-timepicker.entry.js +1 -1
  141. package/dist/esm/six-tooltip.entry.js +1 -1
  142. package/dist/esm/ui-library.js +3 -3
  143. package/dist/types/components.d.ts +0 -232
  144. package/dist/ui-library/{p-b1683e9c.entry.js → p-054e12cc.entry.js} +2 -2
  145. package/dist/ui-library/{p-b3974ad4.entry.js → p-097cced4.entry.js} +2 -2
  146. package/dist/ui-library/{p-0d1fdc4e.entry.js → p-0d79b0c6.entry.js} +2 -2
  147. package/dist/ui-library/{p-9eba5c71.entry.js → p-14f20bbb.entry.js} +2 -2
  148. package/dist/ui-library/{p-3d5cad2d.entry.js → p-18e5f772.entry.js} +2 -2
  149. package/dist/ui-library/{p-14db57aa.entry.js → p-19364560.entry.js} +2 -2
  150. package/dist/ui-library/{p-94ab37b2.entry.js → p-19b50b5a.entry.js} +2 -2
  151. package/dist/ui-library/{p-eb1ec1b7.entry.js → p-21859bca.entry.js} +2 -2
  152. package/dist/ui-library/{p-7cbc261b.entry.js → p-2e48c8d2.entry.js} +2 -2
  153. package/dist/ui-library/{p-80f32909.entry.js → p-308261c4.entry.js} +2 -2
  154. package/dist/ui-library/{p-5eb21538.entry.js → p-33f7e22b.entry.js} +2 -2
  155. package/dist/ui-library/{p-b66c5c48.entry.js → p-4ae91795.entry.js} +2 -2
  156. package/dist/ui-library/{p-1414a242.entry.js → p-53a13db5.entry.js} +2 -2
  157. package/dist/ui-library/{p-f9c50f81.entry.js → p-559c87f0.entry.js} +2 -2
  158. package/dist/ui-library/{p-12000282.entry.js → p-611e1978.entry.js} +2 -2
  159. package/dist/ui-library/{p-524e5804.entry.js → p-63703ba3.entry.js} +2 -2
  160. package/dist/ui-library/{p-c799a6bf.entry.js → p-6403fd87.entry.js} +2 -2
  161. package/dist/ui-library/p-6433c0da.entry.js +2 -0
  162. package/dist/ui-library/{p-f65aa796.entry.js.map → p-6433c0da.entry.js.map} +1 -1
  163. package/dist/ui-library/{p-52cb61bd.entry.js → p-6d75f216.entry.js} +2 -2
  164. package/dist/ui-library/{p-788281d0.entry.js → p-73597d13.entry.js} +2 -2
  165. package/dist/ui-library/{p-3c100309.js → p-79eee01b.js} +2 -2
  166. package/dist/ui-library/{p-9f9bef35.entry.js → p-7e0cc4ae.entry.js} +2 -2
  167. package/dist/ui-library/{p-4d4829db.entry.js → p-820c23f0.entry.js} +2 -2
  168. package/dist/ui-library/{p-232d43a6.entry.js → p-835c3ff7.entry.js} +2 -2
  169. package/dist/ui-library/{p-e4b6264b.entry.js → p-8a970a40.entry.js} +2 -2
  170. package/dist/ui-library/{p-3e3edcbc.entry.js → p-90824648.entry.js} +2 -2
  171. package/dist/ui-library/{p-4bcebd5a.entry.js → p-90dc6af4.entry.js} +2 -2
  172. package/dist/ui-library/{p-16732ac1.entry.js → p-9328e5bc.entry.js} +2 -2
  173. package/dist/ui-library/{p-3efe46cf.entry.js → p-97323ad7.entry.js} +2 -2
  174. package/dist/ui-library/{p-028a2f77.entry.js → p-9d1d222f.entry.js} +2 -2
  175. package/dist/ui-library/{p-f68b5c54.entry.js → p-a1d4f6cf.entry.js} +2 -2
  176. package/dist/ui-library/{p-16b99232.js → p-ac4f4d45.js} +3 -3
  177. package/dist/ui-library/p-ac4f4d45.js.map +1 -0
  178. package/dist/ui-library/{p-57a84d7f.entry.js → p-af793d04.entry.js} +2 -2
  179. package/dist/ui-library/{p-dd0ac344.entry.js → p-b0e5658f.entry.js} +2 -2
  180. package/dist/ui-library/p-b997e43c.entry.js +2 -0
  181. package/dist/ui-library/p-b997e43c.entry.js.map +1 -0
  182. package/dist/ui-library/{p-e1aed7ed.entry.js → p-baa03951.entry.js} +2 -2
  183. package/dist/ui-library/{p-6cc82df5.entry.js → p-c0cb6436.entry.js} +2 -2
  184. package/dist/ui-library/{p-ccee090e.entry.js → p-c30f9e0b.entry.js} +2 -2
  185. package/dist/ui-library/p-c349d1d4.entry.js +2 -0
  186. package/dist/ui-library/p-c349d1d4.entry.js.map +1 -0
  187. package/dist/ui-library/{p-4b44fa83.entry.js → p-c53a63f9.entry.js} +2 -2
  188. package/dist/ui-library/{p-cf2bdd34.entry.js → p-c640c2d8.entry.js} +2 -2
  189. package/dist/ui-library/{p-0c89817e.entry.js → p-c94d0b07.entry.js} +2 -2
  190. package/dist/ui-library/{p-694829b8.entry.js → p-d5633a29.entry.js} +2 -2
  191. package/dist/ui-library/{p-028a2c54.entry.js → p-dd3c76f1.entry.js} +2 -2
  192. package/dist/ui-library/{p-def4a925.entry.js → p-df655bc9.entry.js} +2 -2
  193. package/dist/ui-library/{p-8187701c.entry.js → p-e19a6c95.entry.js} +2 -2
  194. package/dist/ui-library/{p-ba6e1f0e.entry.js → p-edc96efc.entry.js} +2 -2
  195. package/dist/ui-library/p-f18ba86f.entry.js +2 -0
  196. package/dist/ui-library/p-f18ba86f.entry.js.map +1 -0
  197. package/dist/ui-library/{p-2a02734a.entry.js → p-f4938771.entry.js} +2 -2
  198. package/dist/ui-library/{p-e0bda772.entry.js → p-f70e2403.entry.js} +2 -2
  199. package/dist/ui-library/{p-55dc28ad.entry.js → p-f9d345e0.entry.js} +2 -2
  200. package/dist/ui-library/{p-28e6c2eb.entry.js → p-fed07a1f.entry.js} +2 -2
  201. package/dist/ui-library/{p-00507165.entry.js → p-ff0257bf.entry.js} +2 -2
  202. package/dist/ui-library/ui-library.css +2 -2
  203. package/dist/ui-library/ui-library.esm.js +1 -1
  204. package/dist/ui-library/ui-library.esm.js.map +1 -1
  205. package/package.json +1 -1
  206. package/dist/cjs/index-b3257a77.js.map +0 -1
  207. package/dist/cjs/six-dropdown_3.cjs.entry.js.map +0 -1
  208. package/dist/cjs/six-table-cell_4.cjs.entry.js +0 -107
  209. package/dist/cjs/six-table-cell_4.cjs.entry.js.map +0 -1
  210. package/dist/cjs/six-table.cjs.entry.js +0 -167
  211. package/dist/cjs/six-table.cjs.entry.js.map +0 -1
  212. package/dist/collection/components/six-table/six-table.css +0 -44
  213. package/dist/collection/components/six-table/six-table.js +0 -219
  214. package/dist/collection/components/six-table/six-table.js.map +0 -1
  215. package/dist/collection/components/six-table/test/helpers.js +0 -14
  216. package/dist/collection/components/six-table/test/helpers.js.map +0 -1
  217. package/dist/collection/components/six-table/types.js +0 -9
  218. package/dist/collection/components/six-table/types.js.map +0 -1
  219. package/dist/collection/components/six-table/util/filter-by.js +0 -34
  220. package/dist/collection/components/six-table/util/filter-by.js.map +0 -1
  221. package/dist/collection/components/six-table/util/from-data.js +0 -32
  222. package/dist/collection/components/six-table/util/from-data.js.map +0 -1
  223. package/dist/collection/components/six-table/util/is.js +0 -4
  224. package/dist/collection/components/six-table/util/is.js.map +0 -1
  225. package/dist/collection/components/six-table/util/quick-filter-by.js +0 -14
  226. package/dist/collection/components/six-table/util/quick-filter-by.js.map +0 -1
  227. package/dist/collection/components/six-table/util/sort-by.js +0 -25
  228. package/dist/collection/components/six-table/util/sort-by.js.map +0 -1
  229. package/dist/collection/components/six-table-cell/six-table-cell.css +0 -13
  230. package/dist/collection/components/six-table-cell/six-table-cell.js +0 -25
  231. package/dist/collection/components/six-table-cell/six-table-cell.js.map +0 -1
  232. package/dist/collection/components/six-table-header/six-table-header.css +0 -17
  233. package/dist/collection/components/six-table-header/six-table-header.js +0 -25
  234. package/dist/collection/components/six-table-header/six-table-header.js.map +0 -1
  235. package/dist/collection/components/six-table-header-cell/get-next-state.js +0 -7
  236. package/dist/collection/components/six-table-header-cell/get-next-state.js.map +0 -1
  237. package/dist/collection/components/six-table-header-cell/icons.js +0 -12
  238. package/dist/collection/components/six-table-header-cell/icons.js.map +0 -1
  239. package/dist/collection/components/six-table-header-cell/six-table-header-cell.css +0 -37
  240. package/dist/collection/components/six-table-header-cell/six-table-header-cell.js +0 -179
  241. package/dist/collection/components/six-table-header-cell/six-table-header-cell.js.map +0 -1
  242. package/dist/collection/components/six-table-header-cell/types.js +0 -2
  243. package/dist/collection/components/six-table-header-cell/types.js.map +0 -1
  244. package/dist/collection/components/six-table-header-cell/util/create-model.js +0 -7
  245. package/dist/collection/components/six-table-header-cell/util/create-model.js.map +0 -1
  246. package/dist/collection/components/six-table-header-cell/util/get-next-state.js +0 -7
  247. package/dist/collection/components/six-table-header-cell/util/get-next-state.js.map +0 -1
  248. package/dist/collection/components/six-table-row/six-table-row.css +0 -16
  249. package/dist/collection/components/six-table-row/six-table-row.js +0 -25
  250. package/dist/collection/components/six-table-row/six-table-row.js.map +0 -1
  251. package/dist/components/six-table-cell.d.ts +0 -11
  252. package/dist/components/six-table-cell.js +0 -8
  253. package/dist/components/six-table-cell.js.map +0 -1
  254. package/dist/components/six-table-cell2.js +0 -32
  255. package/dist/components/six-table-cell2.js.map +0 -1
  256. package/dist/components/six-table-header-cell.d.ts +0 -11
  257. package/dist/components/six-table-header-cell.js +0 -8
  258. package/dist/components/six-table-header-cell.js.map +0 -1
  259. package/dist/components/six-table-header-cell2.js +0 -120
  260. package/dist/components/six-table-header-cell2.js.map +0 -1
  261. package/dist/components/six-table-header.d.ts +0 -11
  262. package/dist/components/six-table-header.js +0 -8
  263. package/dist/components/six-table-header.js.map +0 -1
  264. package/dist/components/six-table-header2.js +0 -32
  265. package/dist/components/six-table-header2.js.map +0 -1
  266. package/dist/components/six-table-row.d.ts +0 -11
  267. package/dist/components/six-table-row.js +0 -8
  268. package/dist/components/six-table-row.js.map +0 -1
  269. package/dist/components/six-table-row2.js +0 -32
  270. package/dist/components/six-table-row2.js.map +0 -1
  271. package/dist/components/six-table.d.ts +0 -11
  272. package/dist/components/six-table.js +0 -252
  273. package/dist/components/six-table.js.map +0 -1
  274. package/dist/esm/index-96b1af5d.js.map +0 -1
  275. package/dist/esm/six-dropdown_3.entry.js.map +0 -1
  276. package/dist/esm/six-table-cell_4.entry.js +0 -100
  277. package/dist/esm/six-table-cell_4.entry.js.map +0 -1
  278. package/dist/esm/six-table.entry.js +0 -163
  279. package/dist/esm/six-table.entry.js.map +0 -1
  280. package/dist/types/components/six-table/six-table.d.ts +0 -30
  281. package/dist/types/components/six-table/test/helpers.d.ts +0 -2
  282. package/dist/types/components/six-table/types.d.ts +0 -33
  283. package/dist/types/components/six-table/util/filter-by.d.ts +0 -2
  284. package/dist/types/components/six-table/util/from-data.d.ts +0 -8
  285. package/dist/types/components/six-table/util/is.d.ts +0 -3
  286. package/dist/types/components/six-table/util/quick-filter-by.d.ts +0 -2
  287. package/dist/types/components/six-table/util/sort-by.d.ts +0 -2
  288. package/dist/types/components/six-table-cell/six-table-cell.d.ts +0 -9
  289. package/dist/types/components/six-table-header/six-table-header.d.ts +0 -9
  290. package/dist/types/components/six-table-header-cell/get-next-state.d.ts +0 -2
  291. package/dist/types/components/six-table-header-cell/icons.d.ts +0 -3
  292. package/dist/types/components/six-table-header-cell/six-table-header-cell.d.ts +0 -32
  293. package/dist/types/components/six-table-header-cell/types.d.ts +0 -2
  294. package/dist/types/components/six-table-header-cell/util/create-model.d.ts +0 -4
  295. package/dist/types/components/six-table-header-cell/util/get-next-state.d.ts +0 -3
  296. package/dist/types/components/six-table-row/six-table-row.d.ts +0 -9
  297. package/dist/ui-library/p-0d9cbb51.entry.js +0 -2
  298. package/dist/ui-library/p-0d9cbb51.entry.js.map +0 -1
  299. package/dist/ui-library/p-16b99232.js.map +0 -1
  300. package/dist/ui-library/p-2a61cc66.entry.js +0 -2
  301. package/dist/ui-library/p-2a61cc66.entry.js.map +0 -1
  302. package/dist/ui-library/p-60c5395c.entry.js +0 -2
  303. package/dist/ui-library/p-60c5395c.entry.js.map +0 -1
  304. package/dist/ui-library/p-7115416e.entry.js +0 -2
  305. package/dist/ui-library/p-7115416e.entry.js.map +0 -1
  306. package/dist/ui-library/p-f65aa796.entry.js +0 -2
  307. /package/dist/ui-library/{p-b1683e9c.entry.js.map → p-054e12cc.entry.js.map} +0 -0
  308. /package/dist/ui-library/{p-b3974ad4.entry.js.map → p-097cced4.entry.js.map} +0 -0
  309. /package/dist/ui-library/{p-0d1fdc4e.entry.js.map → p-0d79b0c6.entry.js.map} +0 -0
  310. /package/dist/ui-library/{p-9eba5c71.entry.js.map → p-14f20bbb.entry.js.map} +0 -0
  311. /package/dist/ui-library/{p-3d5cad2d.entry.js.map → p-18e5f772.entry.js.map} +0 -0
  312. /package/dist/ui-library/{p-14db57aa.entry.js.map → p-19364560.entry.js.map} +0 -0
  313. /package/dist/ui-library/{p-94ab37b2.entry.js.map → p-19b50b5a.entry.js.map} +0 -0
  314. /package/dist/ui-library/{p-eb1ec1b7.entry.js.map → p-21859bca.entry.js.map} +0 -0
  315. /package/dist/ui-library/{p-7cbc261b.entry.js.map → p-2e48c8d2.entry.js.map} +0 -0
  316. /package/dist/ui-library/{p-80f32909.entry.js.map → p-308261c4.entry.js.map} +0 -0
  317. /package/dist/ui-library/{p-5eb21538.entry.js.map → p-33f7e22b.entry.js.map} +0 -0
  318. /package/dist/ui-library/{p-b66c5c48.entry.js.map → p-4ae91795.entry.js.map} +0 -0
  319. /package/dist/ui-library/{p-1414a242.entry.js.map → p-53a13db5.entry.js.map} +0 -0
  320. /package/dist/ui-library/{p-f9c50f81.entry.js.map → p-559c87f0.entry.js.map} +0 -0
  321. /package/dist/ui-library/{p-12000282.entry.js.map → p-611e1978.entry.js.map} +0 -0
  322. /package/dist/ui-library/{p-524e5804.entry.js.map → p-63703ba3.entry.js.map} +0 -0
  323. /package/dist/ui-library/{p-c799a6bf.entry.js.map → p-6403fd87.entry.js.map} +0 -0
  324. /package/dist/ui-library/{p-52cb61bd.entry.js.map → p-6d75f216.entry.js.map} +0 -0
  325. /package/dist/ui-library/{p-788281d0.entry.js.map → p-73597d13.entry.js.map} +0 -0
  326. /package/dist/ui-library/{p-3c100309.js.map → p-79eee01b.js.map} +0 -0
  327. /package/dist/ui-library/{p-9f9bef35.entry.js.map → p-7e0cc4ae.entry.js.map} +0 -0
  328. /package/dist/ui-library/{p-4d4829db.entry.js.map → p-820c23f0.entry.js.map} +0 -0
  329. /package/dist/ui-library/{p-232d43a6.entry.js.map → p-835c3ff7.entry.js.map} +0 -0
  330. /package/dist/ui-library/{p-e4b6264b.entry.js.map → p-8a970a40.entry.js.map} +0 -0
  331. /package/dist/ui-library/{p-3e3edcbc.entry.js.map → p-90824648.entry.js.map} +0 -0
  332. /package/dist/ui-library/{p-4bcebd5a.entry.js.map → p-90dc6af4.entry.js.map} +0 -0
  333. /package/dist/ui-library/{p-16732ac1.entry.js.map → p-9328e5bc.entry.js.map} +0 -0
  334. /package/dist/ui-library/{p-3efe46cf.entry.js.map → p-97323ad7.entry.js.map} +0 -0
  335. /package/dist/ui-library/{p-028a2f77.entry.js.map → p-9d1d222f.entry.js.map} +0 -0
  336. /package/dist/ui-library/{p-f68b5c54.entry.js.map → p-a1d4f6cf.entry.js.map} +0 -0
  337. /package/dist/ui-library/{p-57a84d7f.entry.js.map → p-af793d04.entry.js.map} +0 -0
  338. /package/dist/ui-library/{p-dd0ac344.entry.js.map → p-b0e5658f.entry.js.map} +0 -0
  339. /package/dist/ui-library/{p-e1aed7ed.entry.js.map → p-baa03951.entry.js.map} +0 -0
  340. /package/dist/ui-library/{p-6cc82df5.entry.js.map → p-c0cb6436.entry.js.map} +0 -0
  341. /package/dist/ui-library/{p-ccee090e.entry.js.map → p-c30f9e0b.entry.js.map} +0 -0
  342. /package/dist/ui-library/{p-4b44fa83.entry.js.map → p-c53a63f9.entry.js.map} +0 -0
  343. /package/dist/ui-library/{p-cf2bdd34.entry.js.map → p-c640c2d8.entry.js.map} +0 -0
  344. /package/dist/ui-library/{p-0c89817e.entry.js.map → p-c94d0b07.entry.js.map} +0 -0
  345. /package/dist/ui-library/{p-694829b8.entry.js.map → p-d5633a29.entry.js.map} +0 -0
  346. /package/dist/ui-library/{p-028a2c54.entry.js.map → p-dd3c76f1.entry.js.map} +0 -0
  347. /package/dist/ui-library/{p-def4a925.entry.js.map → p-df655bc9.entry.js.map} +0 -0
  348. /package/dist/ui-library/{p-8187701c.entry.js.map → p-e19a6c95.entry.js.map} +0 -0
  349. /package/dist/ui-library/{p-ba6e1f0e.entry.js.map → p-edc96efc.entry.js.map} +0 -0
  350. /package/dist/ui-library/{p-2a02734a.entry.js.map → p-f4938771.entry.js.map} +0 -0
  351. /package/dist/ui-library/{p-e0bda772.entry.js.map → p-f70e2403.entry.js.map} +0 -0
  352. /package/dist/ui-library/{p-55dc28ad.entry.js.map → p-f9d345e0.entry.js.map} +0 -0
  353. /package/dist/ui-library/{p-28e6c2eb.entry.js.map → p-fed07a1f.entry.js.map} +0 -0
  354. /package/dist/ui-library/{p-00507165.entry.js.map → p-ff0257bf.entry.js.map} +0 -0
@@ -1 +0,0 @@
1
- {"file":"six-dropdown.six-menu.six-menu-item.entry.js","mappings":"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","names":[],"sources":["./src/utils/tabbable.ts","./src/components/six-dropdown/six-dropdown.scss?tag=six-dropdown&encapsulation=shadow","./src/components/six-dropdown/six-dropdown.tsx","./src/components/six-menu/six-menu.scss?tag=six-menu&encapsulation=shadow","./src/components/six-menu/six-menu.tsx","./src/components/six-menu-item/six-menu-item.scss?tag=six-menu-item&encapsulation=shadow","./src/components/six-menu-item/six-menu-item.tsx"],"sourcesContent":["export function isTabbable(el: HTMLElement) {\n const tabIndex = el.tabIndex;\n return tabIndex > -1;\n}\n\nexport function getNearestTabbableElement(el: HTMLElement): HTMLElement {\n // Check the element\n if (isTabbable(el)) {\n return el;\n }\n\n // Check the element's shadow root\n if (el.shadowRoot) {\n const tabbableShadowChild = [...el.shadowRoot.children].find(isTabbable) as HTMLElement;\n if (tabbableShadowChild) {\n return tabbableShadowChild;\n }\n }\n\n // Check the element's children\n if (el.children) {\n return [...el.children].map(getNearestTabbableElement)[0];\n }\n\n return null;\n}\n","@import 'src/global/component';\n@import 'src/global/mixins/scrollbar';\n\n:host {\n display: inline-block;\n}\n\n.dropdown {\n position: relative;\n}\n\n.dropdown__trigger {\n display: block;\n}\n\n.dropdown__positioner {\n position: absolute;\n z-index: var(--six-z-index-dropdown);\n\n &__filtered {\n width: 100%;\n }\n}\n\n.dropdown__panel {\n max-height: 50vh;\n font-family: var(--six-font-sans);\n font-size: var(--six-font-size-small);\n font-weight: var(--six-font-weight-normal);\n color: var(--color);\n background-color: var(--six-panel-background-color);\n border-radius: var(--six-border-radius-medium);\n box-shadow: var(--six-elevation-2dp);\n opacity: 0;\n overflow: auto;\n overscroll-behavior: none;\n pointer-events: none;\n transform: scale(0.9);\n transition: var(--six-transition-fast) opacity, var(--six-transition-fast) transform;\n // fix for firefox scrollbar\n scrollbar-width: thin;\n}\n\n.filter-hidden {\n display: none;\n}\n\n.dropdown__positioner {\n &[data-popper-placement^='top'] .dropdown__panel {\n transform-origin: bottom;\n }\n\n &[data-popper-placement^='bottom'] .dropdown__panel {\n transform-origin: top;\n }\n\n &[data-popper-placement^='left'] .dropdown__panel {\n transform-origin: right;\n }\n\n &[data-popper-placement^='right'] .dropdown__panel {\n transform-origin: left;\n }\n\n &.popover-visible .dropdown__panel {\n opacity: 1;\n transform: none;\n pointer-events: all;\n }\n}\n","import { Component, Element, Event, EventEmitter, h, Method, Prop, State, Watch } from '@stencil/core';\nimport { scrollIntoView } from '../../utils/scroll';\nimport { getNearestTabbableElement } from '../../utils/tabbable';\nimport Popover from '../../utils/popover';\nimport { EventListeners } from '../../utils/event-listeners';\nimport { getSlotChildren } from '../../utils/slot';\nimport { debounce, DEFAULT_DEBOUNCE_FAST } from '../../utils/execution-control';\nimport { EmptyPayload } from '../../utils/types';\nimport { SixMenuItemData } from '../six-menu/six-menu';\n\nexport interface SixDropdownAutoFilterPayload {\n filterValue: string;\n}\n\nexport interface SixDropdownAsyncFilterPayload {\n filterValue: string;\n}\n\nexport interface SixDropdownScrollPayload {\n scrollHeight: number;\n scrollTop: number;\n scrollbarHeight: number;\n scrollRatio: number;\n}\n\nconst isTagName =\n (name: string) =>\n <T extends Element>(el?: T) =>\n el?.tagName.toLowerCase() === name.toLowerCase();\nconst isSixMenu = isTagName('six-menu');\nconst isSixMenuItem = isTagName('six-menu-item');\n\nlet id = 0;\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 trigger - The dropdown's trigger, usually a `<six-button>` element.\n * @slot - The dropdown's content.\n *\n * @part base - The component's base wrapper.\n * @part trigger - The container that wraps the trigger.\n * @part panel - The panel that gets shown when the dropdown is open.\n */\n\n@Component({\n tag: 'six-dropdown',\n styleUrl: 'six-dropdown.scss',\n shadow: true,\n})\nexport class SixDropdown {\n accessibleTrigger: HTMLElement;\n componentId = `dropdown-${++id}`;\n isVisible = false;\n panel: HTMLElement;\n positioner: HTMLElement;\n popover: Popover;\n trigger: HTMLElement;\n hasBeenInitialized = false;\n\n // the input element shown in the dropdown when filter is set to true\n filterInputElement: HTMLSixInputElement;\n\n @Element() host: HTMLSixDropdownElement;\n\n /** Indicates whether or not the dropdown is open. You can use this in lieu of the show/hide methods. */\n @Prop({ mutable: true, reflect: true }) open = false;\n\n /**\n * The preferred placement of the dropdown panel. Note that the actual placement may vary as needed to keep the panel\n * inside of the viewport.\n */\n @Prop() placement:\n | 'top'\n | 'top-start'\n | 'top-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n | 'right'\n | 'right-start'\n | 'right-end'\n | 'left'\n | 'left-start'\n | 'left-end' = 'bottom-start';\n\n /** Determines whether the dropdown should hide when a menu item is selected. */\n @Prop() closeOnSelect = true;\n\n /** The distance in pixels from which to offset the panel away from its trigger. */\n @Prop() distance = 0;\n\n /** The distance in pixels from which to offset the panel along its trigger. */\n @Prop() skidding = 0;\n\n /**\n * Enable this option to prevent the panel from being clipped when the component is placed inside a container with\n * `overflow: auto|scroll`.\n */\n @Prop() hoist = false;\n\n /** The dropdown will close when the user interacts outside of this element (e.g. clicking). */\n @Prop() containingElement: HTMLElement;\n\n /**\n * Set to true to allow auto filtering for entries in the dropdown.\n * With this flag the dropdown will automatically filter itsel.\n * If you need to coordinate the shown elements yourself,\n * e.g. because you need to call an endpoint use asyncFilter instead\n */\n @Prop() filter = false;\n\n /**\n * Set to true to allow async filtering.\n * When you enter something in the search field the component will only emit an event but not filter any elements itself.\n * You can then simply listen to the 'six-async-filter-fired' event to manage the shown menu-items yourself\n */\n @Prop() asyncFilter = false;\n\n /** The filter's placeholder text. */\n @Prop() filterPlaceholder = 'Filter...';\n\n /** By default the search field will be focused when opening a dropdown with filtering enabled. */\n @Prop() autofocusFilter = true;\n\n get hasFilterEnabled() {\n return this.filter || this.asyncFilter;\n }\n\n /** The debounce for the filter callbacks. */\n @Prop() filterDebounce = DEFAULT_DEBOUNCE_FAST;\n\n /** The panel can be opend/closed by pressing the spacebar or the enter key. In some cases you might want to avoid this */\n @Prop() disableHideOnEnterAndSpace = false;\n\n /** Set the options to be shown in the dropdown (alternative to setting the elements via html)*/\n @Prop() options: SixMenuItemData[] | null = null;\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 get container() {\n return this.containingElement || this.host;\n }\n\n /** Emitted when the dropdown opens. Calling `event.preventDefault()` will prevent it from being opened. */\n @Event({ eventName: 'six-dropdown-show' }) sixShow: EventEmitter<EmptyPayload>;\n\n /** Emitted after the dropdown opens and all transitions are complete. */\n @Event({ eventName: 'six-dropdown-after-show' }) sixAfterShow: EventEmitter<EmptyPayload>;\n\n /** Emitted when the dropdown closes. Calling `event.preventDefault()` will prevent it from being closed. */\n @Event({ eventName: 'six-dropdown-hide' }) sixHide: EventEmitter<EmptyPayload>;\n\n /** Emitted after the dropdown closes and all transitions are complete. */\n @Event({ eventName: 'six-dropdown-after-hide' }) sixAfterHide: EventEmitter<EmptyPayload>;\n\n /** Emitted when the auto filter is triggered */\n @Event({ eventName: 'six-dropdown-auto-filter-fired' })\n sixAutoFilterFired: EventEmitter<SixDropdownAutoFilterPayload>;\n\n /** Emitted when the async filter is triggered */\n @Event({ eventName: 'six-async-filter-fired' }) sixAsyncFilterFired: EventEmitter<SixDropdownAsyncFilterPayload>;\n\n /** Emitted when the user scrolls inside dropdown panel.*/\n @Event({ eventName: 'six-dropdown-scroll' }) sixScroll: EventEmitter<SixDropdownScrollPayload>;\n\n readonly eventListeners = new EventListeners();\n\n // internal representation of options, so we don't have to make options mutable\n @State()\n _options: SixMenuItemData[] = null;\n\n @Watch('open')\n handleOpenChange() {\n this.open ? this.show() : this.hide();\n this.updateAccessibleTrigger();\n }\n\n @Watch('distance')\n @Watch('hoist')\n @Watch('placement')\n @Watch('skidding')\n handlePopoverOptionsChange() {\n this.popover.setOptions({\n strategy: this.hoist ? 'fixed' : 'absolute',\n placement: this.placement,\n distance: this.distance,\n skidding: this.skidding,\n });\n }\n\n @Watch('options')\n handleOptionsChange() {\n this._options = [...this.options];\n }\n\n connectedCallback() {\n if (this.virtualScroll && this.options === null) {\n console.error('Options must be defined when using virtual scrolling');\n }\n\n if (this.options !== null) {\n this._options = [...this.options];\n }\n\n this.handleDocumentKeyDown = this.handleDocumentKeyDown.bind(this);\n this.handleDocumentMouseDown = this.handleDocumentMouseDown.bind(this);\n this.handleMenuItemActivate = this.handleMenuItemActivate.bind(this);\n this.handlePanelSelect = this.handlePanelSelect.bind(this);\n this.handleTriggerClick = this.handleTriggerClick.bind(this);\n this.handleTriggerKeyDown = this.handleTriggerKeyDown.bind(this);\n this.handleTriggerKeyUp = this.handleTriggerKeyUp.bind(this);\n this.handleTriggerSlotChange = this.handleTriggerSlotChange.bind(this);\n this.handleDropdownScroll = this.handleDropdownScroll.bind(this);\n\n if (this.hasBeenInitialized && !this.popover) {\n // there was a weird bug when using six-dropdown inside an ag-grid filter. When closing the ag-grid filter\n // disconnectedCallback() is executed. However, since componentDidLoad() will not be rerendered the popover had\n // no longer a connected transitionEnd callback to the dropdown. To fix this, we have this sanity check here,\n // to re-initialize the popover in case the component has already been initialized but the popover is undefined.\n this.initializePopover();\n }\n }\n\n componentDidLoad() {\n this.hasBeenInitialized = true;\n this.initializePopover();\n\n // Show on init if open\n if (this.open) {\n void this.show();\n }\n\n if (this.filter) {\n this.setupFiltering(this.handleFilterInputChange);\n } else if (this.asyncFilter) {\n this.setupFiltering(() => this.sixAsyncFilterFired.emit({ filterValue: this.filterInputElement.value }));\n }\n }\n\n private initializePopover() {\n const onAfterHide = () => {\n if (this.filter) {\n this.filterInputElement.value = '';\n\n if (this._options !== null) {\n this._options = [...this.options];\n } else {\n const menuItems = this.getMenuItems();\n menuItems.forEach((item) => (item.style.display = 'unset'));\n }\n }\n\n this.sixAfterHide.emit();\n };\n\n const onAfterShow = async () => {\n if (this.hasFilterEnabled && this.autofocusFilter) {\n // if dropdown filter is enabled we should autofocus the search field\n await this.filterInputElement.setFocus();\n }\n\n this.sixAfterShow.emit();\n };\n\n const onTransitionEnd = () => {\n if (!this.open) {\n this.panel.scrollTop = 0;\n }\n };\n\n this.popover = new Popover(this.trigger, this.positioner, {\n strategy: this.hoist ? 'fixed' : 'absolute',\n placement: this.placement,\n distance: this.distance,\n skidding: this.skidding,\n transitionElement: this.panel,\n onAfterHide,\n onAfterShow,\n onTransitionEnd,\n });\n }\n\n private setupFiltering(callback: () => void) {\n this.eventListeners.add(this.filterInputElement, 'six-input-input', debounce(callback, this.filterDebounce));\n }\n\n getMenuItems = (): HTMLSixMenuItemElement[] => {\n if (this._options !== null) {\n return this._options.map((option) => <six-menu-item value={option.value}>{option.label}</six-menu-item>);\n }\n\n const [panel] = getSlotChildren<HTMLSixMenuElement>(this.panel);\n\n // the menu-items can be in a slot e.g. in six-select or direct children of the panel\n return getSlotChildren(panel) || Array.from(panel.querySelectorAll('six-menu-item'));\n };\n\n handleFilterInputChange = () => {\n const lowerCaseFilterTerm = this.filterInputElement.value?.toLowerCase()?.trim() || '';\n\n if (this._options) {\n this.handleFilteringForAttributeItems(lowerCaseFilterTerm);\n } else {\n this.handleFilteringForSlotItems(lowerCaseFilterTerm);\n }\n\n this.sixAutoFilterFired.emit({ filterValue: lowerCaseFilterTerm });\n };\n\n private handleFilteringForAttributeItems(lowerCaseFilterTerm: string) {\n if (lowerCaseFilterTerm === '') {\n this._options = [...this.options];\n return;\n }\n\n this._options = this.options.filter(\n (option) =>\n (option.label && String(option.label)?.toLowerCase()?.includes(lowerCaseFilterTerm)) ||\n (option.value && String(option.value)?.toLowerCase()?.includes(lowerCaseFilterTerm))\n );\n }\n\n private handleFilteringForSlotItems(lowerCaseFilterTerm: string) {\n const menuItems = this.getMenuItems();\n menuItems.forEach(async (menuItem) => {\n // hide all elements which don't contain the entered substring\n const elementContainsFilterTerm =\n menuItem?.value?.toLowerCase()?.includes(lowerCaseFilterTerm) ||\n (await menuItem?.getTextLabel())?.toLowerCase()?.includes(lowerCaseFilterTerm);\n\n menuItem.style.display = elementContainsFilterTerm ? 'unset' : 'none';\n });\n }\n\n disconnectedCallback() {\n this.eventListeners.removeAll();\n\n void this.hide();\n this.popover.destroy();\n this.popover = null;\n }\n\n /** Shows the dropdown panel */\n @Method()\n async show() {\n // Prevent subsequent calls to the method, whether manually or triggered by the `open` watcher\n if (this.isVisible) {\n return;\n }\n\n const sixShow = this.sixShow.emit();\n if (sixShow.defaultPrevented) {\n this.open = false;\n return;\n }\n\n this.eventListeners.add(this.panel, 'six-menu-item-selected', this.handlePanelSelect);\n this.eventListeners.add(document, 'keydown', this.handleDocumentKeyDown);\n this.eventListeners.add(document, 'mousedown', this.handleDocumentMouseDown);\n\n this.isVisible = true;\n this.open = true;\n this.popover.show();\n }\n\n /** Hides the dropdown panel */\n @Method()\n async hide() {\n // Prevent subsequent calls to the method, whether manually or triggered by the `open` watcher\n if (!this.isVisible) {\n return;\n }\n\n const sixHide = this.sixHide.emit();\n if (sixHide.defaultPrevented) {\n this.open = true;\n return;\n }\n\n this.eventListeners.remove(this.panel, 'six-menu-item-selected', this.handlePanelSelect);\n this.eventListeners.remove(document, 'keydown', this.handleDocumentKeyDown);\n this.eventListeners.remove(document, 'mousedown', this.handleDocumentMouseDown);\n\n this.isVisible = false;\n this.open = false;\n this.popover.hide();\n }\n\n focusOnTrigger() {\n const [trigger] = getSlotChildren<HTMLSixButtonElement>(this.trigger);\n if (trigger) {\n if (typeof trigger.setFocus === 'function') {\n trigger.setFocus();\n } else if (typeof trigger.focus === 'function') {\n trigger.focus();\n }\n }\n }\n\n getMenu() {\n const [menu] = getSlotChildren<HTMLSixMenuElement>(this.panel).filter(isSixMenu);\n return menu;\n }\n\n /**\n * Instructs the dropdown menu to reposition. Useful when the position or size of the trigger changes when the menu\n * is activated.\n */\n @Method()\n async reposition() {\n if (!this.open) {\n return;\n }\n this.popover.reposition();\n }\n\n handleDocumentKeyDown(event: KeyboardEvent) {\n // Close when escape is pressed\n if (event.key === 'Escape') {\n void this.hide();\n this.focusOnTrigger();\n return;\n }\n\n if (this.filterInputElement === this.host.shadowRoot.activeElement) {\n if (event.key === 'ArrowDown') {\n const item = this.getMenuItems().find((item) => item.style.display !== 'none');\n if (item) {\n item.setFocus();\n }\n }\n }\n\n // Handle tabbing\n if (event.key === 'Tab') {\n // Tabbing within an open menu should close the dropdown and refocus the trigger\n if (this.open && isSixMenuItem(document.activeElement)) {\n event.preventDefault();\n void this.hide();\n this.focusOnTrigger();\n return;\n }\n\n // Tabbing outside of the containing element closes the panel\n //\n // If the dropdown is used within a shadow DOM, we need to obtain the activeElement within that shadowRoot,\n // otherwise `document.activeElement` will only return the name of the parent shadow DOM element.\n setTimeout(() => {\n const activeElement =\n this.container.getRootNode() instanceof ShadowRoot\n ? document.activeElement.shadowRoot?.activeElement\n : document.activeElement;\n\n if (activeElement?.closest(this.container.tagName.toLowerCase()) !== this.container) {\n void this.hide();\n return;\n }\n });\n }\n }\n\n handleDocumentMouseDown(event: MouseEvent) {\n // Close when clicking outside of the containing element\n const path = event.composedPath() as EventTarget[];\n if (!path.includes(this.container)) {\n void this.hide();\n return;\n }\n }\n\n handleMenuItemActivate(event: CustomEvent) {\n const item = event.target as HTMLSixMenuItemElement;\n scrollIntoView(item, this.panel);\n }\n\n handlePanelSelect(event: CustomEvent) {\n const target = event.target as HTMLElement;\n\n // Hide the dropdown when a menu item is selected\n if (this.closeOnSelect && isSixMenu(target)) {\n void this.hide();\n this.focusOnTrigger();\n }\n }\n\n handleTriggerClick() {\n this.open ? this.hide() : this.show();\n }\n\n handleTriggerKeyDown(event: KeyboardEvent) {\n const menu = this.getMenu();\n const menuItems = menu ? [...menu.querySelectorAll('six-menu-item')] : null;\n const firstMenuItem = menuItems[0];\n const lastMenuItem = menuItems[menuItems.length - 1];\n\n // Close when escape or tab is pressed\n if (event.key === 'Escape') {\n this.focusOnTrigger();\n void this.hide();\n return;\n }\n\n // When spacebar/enter is pressed, show the panel but don't focus on the menu. This let's the user press the same\n // key again to hide the menu in case they don't want to make a selection.\n if (!this.disableHideOnEnterAndSpace && [' ', 'Enter'].includes(event.key)) {\n event.preventDefault();\n this.open ? void this.hide() : void this.show();\n return;\n }\n\n // When up/down is pressed, we make the assumption that the user is familiar with the menu and plans to make a\n // selection. Rather than toggle the panel, we focus on the menu (if one exists) and activate the first item for\n // faster navigation.\n if (['ArrowDown', 'ArrowUp'].includes(event.key)) {\n event.preventDefault();\n\n // Show the menu if it's not already open\n if (!this.open) {\n void this.show();\n }\n\n // Focus on a menu item\n if (event.key === 'ArrowDown' && firstMenuItem) {\n firstMenuItem.setFocus();\n return;\n }\n\n if (event.key === 'ArrowUp' && lastMenuItem) {\n lastMenuItem.setFocus();\n return;\n }\n }\n\n // Other keys bring focus to the menu and initiate type-to-select behavior\n const ignoredKeys = ['Tab', 'Shift', 'Meta', 'Ctrl', 'Alt'];\n if (this.open && menu && !ignoredKeys.includes(event.key)) {\n void menu.typeToSelect(event.key);\n return;\n }\n }\n\n handleTriggerKeyUp(event: KeyboardEvent) {\n // Prevent space from triggering a click event in Firefox\n if (event.key === ' ') {\n event.preventDefault();\n }\n }\n\n handleTriggerSlotChange() {\n this.updateAccessibleTrigger();\n }\n\n handleDropdownScroll() {\n this.sixScroll.emit({\n scrollHeight: this.panel.scrollHeight,\n scrollTop: this.panel.scrollTop,\n scrollbarHeight: this.panel.offsetHeight * (this.panel.offsetHeight / this.panel.scrollHeight),\n scrollRatio: this.panel.scrollTop / (this.panel.scrollHeight - this.panel.clientHeight),\n });\n }\n\n //\n // Slotted triggers can be arbitrary content, but we need to link them to the dropdown panel with `aria-haspopup` and\n // `aria-expanded`. These must be applied to the \"accessible trigger\" (the tabbable portion of the trigger element\n // that gets slotted in) so screen readers will understand them. The accessible trigger could be the slotted element,\n // a child of the slotted element, or an element in the slotted element's shadow root.\n //\n // For example, the accessible trigger of an <sl-button> is a <button> located inside its shadow root.\n //\n // To determine this, we assume the first tabbable element in the trigger slot is the \"accessible trigger.\"\n //\n updateAccessibleTrigger() {\n const [accessibleTrigger] = getSlotChildren(this.trigger).map(getNearestTabbableElement);\n\n if (accessibleTrigger) {\n accessibleTrigger.setAttribute('aria-haspopup', 'true');\n accessibleTrigger.setAttribute('aria-expanded', this.open ? 'true' : 'false');\n }\n }\n\n render() {\n return (\n <div\n part=\"base\"\n id={this.componentId}\n class={{\n dropdown: true,\n 'dropdown--open': this.open,\n }}\n >\n <span\n part=\"trigger\"\n class=\"dropdown__trigger\"\n ref={(el) => (this.trigger = el)}\n onClick={this.handleTriggerClick}\n onKeyDown={this.handleTriggerKeyDown}\n onKeyUp={this.handleTriggerKeyUp}\n >\n <slot name=\"trigger\" onSlotchange={this.handleTriggerSlotChange} />\n </span>\n\n {/* Position the panel with a wrapper since the popover makes use of `translate`. This let's us add transitions\n on the panel without interfering with the position. */}\n <div\n ref={(el) => (this.positioner = el)}\n class={{\n dropdown__positioner: true,\n dropdown__positioner__filtered: (this.filter || this.asyncFilter) && !this.hoist,\n }}\n >\n {this.hasFilterEnabled && (\n <six-input\n class={{\n 'filter-hidden': !this.open,\n }}\n aria-hidden={this.open ? 'false' : 'true'}\n ref={(el) => (this.filterInputElement = el)}\n placeholder={this.filterPlaceholder}\n />\n )}\n <div\n ref={(el) => (this.panel = el)}\n part=\"panel\"\n class=\"dropdown__panel\"\n role=\"menu\"\n aria-hidden={this.open ? 'false' : 'true'}\n aria-labelledby={this.componentId}\n onScroll={this.handleDropdownScroll}\n >\n <slot />\n {this._options && (\n <six-menu part=\"menu\" items={this._options} virtualScroll={this.virtualScroll}></six-menu>\n )}\n </div>\n </div>\n </div>\n );\n }\n}\n","@import 'src/global/component';\n\n:host {\n display: block;\n}\n\n.menu {\n padding: 0 0;\n border: none;\n box-shadow: var(--six-elevation-2dp);\n\n &:focus {\n outline: none;\n }\n\n &--noshadow {\n box-shadow: none;\n }\n\n &__wrapper {\n &--scrollable {\n overflow-y: auto;\n }\n }\n}\n","import { Component, Element, Event, EventEmitter, h, Method, Prop, State } from '@stencil/core';\nimport { getTextContent } from '../../utils/slot';\nimport { StyleDeclaration } from '../../utils/types';\nimport { EventListeners } from '../../utils/event-listeners';\nimport { debounce } from '../../utils/execution-control';\n\nexport interface SixMenuItemData {\n label: string;\n value: string;\n}\n\nexport interface SixMenuItemSelectedPayload {\n name: string;\n item: HTMLSixMenuItemElement;\n}\n\nconst isFocusedMenuItem = (menuItem: HTMLSixMenuItemElement) =>\n menuItem?.shadowRoot?.querySelector('.menu-item')?.classList?.contains('menu-item--focused');\n\nconst isSIXMenuItemElement = (el?: Element): el is HTMLSixMenuItemElement =>\n el?.tagName.toLowerCase() === 'six-menu-item';\n\nconst mapToMenuItem = ({ value, label }) => <six-menu-item value={value}>{label}</six-menu-item>;\n\nconst DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING = 5;\n\nconst DEFAULT_SIX_MENU_ITEM_HEIGHT = 64;\n\nconst ITEMS_SHOWN_NOT_SET = undefined;\n\n/**\n * @since 1.0\n * @status stable\n *\n * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.\n *\n * @slot - The menu's content, including menu items, menu dividers, and menu labels.\n *\n * @part base - The component's base wrapper.\n */\n@Component({\n tag: 'six-menu',\n styleUrl: 'six-menu.scss',\n shadow: true,\n})\nexport class SixMenu {\n private readonly eventListeners = new EventListeners();\n\n menu: HTMLElement;\n menuWrapper: HTMLElement;\n typeToSelectString = '';\n typeToSelectTimeout: NodeJS.Timeout;\n\n @Element() host: HTMLSixMenuElement;\n\n /** Emitted when a menu item is selected. */\n @Event({ eventName: 'six-menu-item-selected' }) sixMenuItemSelected: EventEmitter<SixMenuItemSelectedPayload>;\n\n /** Set to true to remove the box-shadow */\n @Prop() removeBoxShadow: boolean = false;\n\n /** Set the options to be shown in the dropdown */\n @Prop() items: SixMenuItemData[] | null = null;\n\n /** Defines how many items should be shown. If the number of items is larger than this properties a scrollbar will be shown */\n @Prop() itemsShown?: number = ITEMS_SHOWN_NOT_SET;\n\n /** Defines whether the menu list will be rendered virtually i.e. only the elements actually shown (and a couple around)\n * are actually rendered in the DOM. If you use virtual scrolling pass the elements via prop instead of via slot. */\n @Prop() virtualScroll: boolean = false;\n\n /**\n * Used for virtual scrolling\n * Define how many items should be rendered in the DOM when using virtual scrolling\n */\n @Prop() itemSize: number = 10;\n\n /**\n * Used for virtual scrolling\n * Define the debounce for listening on scrolling changes in milliseconds.\n * The lower the number the more sensitive the component reacts to scrolling changes.\n */\n @Prop() scrollingDebounce: number = 15;\n\n /**\n * Used to calculate which items should be rendered in the DOM\n */\n @State()\n private scrollingIndex: number = 0;\n\n // set a default item height, this variable will be updated with the real value after the first render.\n // However, it's necessary to have a default value because we can only fetch the proper hight after the first render\n @State()\n sixMenuItemHeight = DEFAULT_SIX_MENU_ITEM_HEIGHT;\n\n connectedCallback() {\n this.handleClick = this.handleClick.bind(this);\n this.handleKeyDown = this.handleKeyDown.bind(this);\n }\n\n componentWillLoad() {\n if (this.items === null) {\n return;\n }\n }\n\n private handleScrolling = () => {\n // for performance improvements we only update the DOM if the scrollRatio change \"enough\"\n this.scrollingIndex = Math.floor(this.menuWrapper.scrollTop / this.sixMenuItemHeight);\n };\n\n componentDidLoad() {\n this.setupForVirtualScrollingAfterRendering();\n }\n\n disconnectedCallback() {\n this.eventListeners.removeAll();\n }\n\n /**\n * Initiates type-to-select logic, which automatically selects an option based on what the user is currently typing.\n * The key passed will be appended to the internal query and the selection will be updated. After a brief period, the\n * internal query is cleared automatically. This method is intended to be used with the keydown event. Useful for\n * enabling type-to-select when the menu doesn't have focus.\n */\n @Method()\n async typeToSelect(key: string) {\n clearTimeout(this.typeToSelectTimeout);\n this.typeToSelectTimeout = setTimeout(() => (this.typeToSelectString = ''), 750);\n this.typeToSelectString += key.toLowerCase();\n const items = this.getItems();\n for (const item of items) {\n const slot = item.shadowRoot?.querySelector('slot:not([name])') as HTMLSlotElement;\n const label = getTextContent(slot).toLowerCase().trim();\n if (label.substring(0, this.typeToSelectString.length) === this.typeToSelectString) {\n item.setFocus();\n break;\n }\n }\n }\n\n private getItemsShown() {\n const defaultItemsShown = this.virtualScroll\n ? DEFAULT_NUMBER_OF_ITEMS_SHOWN_FOR_VIRTUAL_SCROLLING\n : ITEMS_SHOWN_NOT_SET;\n\n return this.itemsShown ?? defaultItemsShown;\n }\n\n private setupForVirtualScrollingAfterRendering() {\n if (!this.virtualScroll) {\n return;\n }\n\n this.eventListeners.add(this.menuWrapper, 'scroll', debounce(this.handleScrolling, this.scrollingDebounce));\n\n // set menu height to proper height once the item is rendered.\n const menuItemHeight = this.menu?.querySelector('six-menu-item')?.clientHeight;\n if (menuItemHeight && menuItemHeight > 0) {\n this.sixMenuItemHeight = menuItemHeight;\n }\n }\n\n getItems() {\n if (this.items !== null && this.items !== undefined) {\n return this.items.map(mapToMenuItem);\n }\n\n const slot = this.menu.querySelector('slot');\n return [...slot.assignedElements({ flatten: true })].filter((el) => isSIXMenuItemElement(el) && !el.disabled);\n }\n\n private getActiveItemIndex() {\n const items = this.getItems();\n const selectedItem = this.getActiveItem();\n const itemIndex = items.indexOf(selectedItem);\n\n if (itemIndex > -1) {\n return itemIndex;\n }\n\n const sixMenuItems = this.extractItemsFromDOM();\n return sixMenuItems.findIndex(isFocusedMenuItem);\n }\n\n getActiveItem() {\n const activeElement = this.getItems().find((i) => i === document.activeElement);\n\n if (activeElement) {\n return activeElement;\n }\n\n return this.extractItemsFromDOM()?.find(isFocusedMenuItem);\n }\n\n private extractItemsFromDOM() {\n return Array.from(this.host?.shadowRoot?.querySelectorAll('six-menu-item'));\n }\n\n setActiveItem(item: HTMLSixMenuItemElement) {\n item.setFocus();\n }\n\n handleClick(event: MouseEvent) {\n const target = event.target as HTMLElement;\n const clickedItem = target.closest('six-menu-item');\n if (clickedItem && !clickedItem.disabled) {\n this.sixMenuItemSelected.emit({ name: clickedItem.value, item: clickedItem });\n }\n }\n\n handleKeyDown(event: KeyboardEvent) {\n // Make a selection when pressing enter\n if (event.key === 'Enter') {\n const activeItem = this.getActiveItem();\n event.preventDefault();\n\n if (activeItem) {\n this.sixMenuItemSelected.emit({ name: activeItem.value, item: activeItem });\n }\n }\n\n // Prevent scrolling when space is pressed\n if (event.key === ' ') {\n event.preventDefault();\n }\n\n // Move the selection when pressing down or up\n if (['ArrowDown', 'ArrowUp', 'Home', 'End'].includes(event.key)) {\n const items = this.items === null ? this.getItems() : this.extractItemsFromDOM();\n\n let indexOfActiveItem = this.getActiveItemIndex();\n\n if (items.length) {\n event.preventDefault();\n\n if (event.key === 'ArrowDown') {\n indexOfActiveItem++;\n } else if (event.key === 'ArrowUp') {\n indexOfActiveItem--;\n } else if (event.key === 'Home') {\n indexOfActiveItem = 0;\n } else if (event.key === 'End') {\n indexOfActiveItem = items.length - 1;\n }\n\n if (indexOfActiveItem < 0) indexOfActiveItem = 0;\n if (indexOfActiveItem > items.length - 1) indexOfActiveItem = items.length - 1;\n\n this.setActiveItem(items[indexOfActiveItem]);\n\n return;\n }\n }\n\n void this.typeToSelect(event.key);\n }\n\n private getMenuWrapperStyle() {\n const styles: Partial<StyleDeclaration> = {};\n\n if (this.getItemsShown() > 0) {\n // calculate the proper height to show the correct number of items\n styles.height = `${this.getItemsShown() * this.sixMenuItemHeight}px`;\n }\n\n return {\n ...styles,\n };\n }\n\n private getMenuContainerStyle() {\n const styles: Partial<StyleDeclaration> = {};\n\n if (this.virtualScroll) {\n // calculate height of content are if all items would be rendered so the scrollbar has the proper size\n styles.transform = `translateY(${this.sixMenuItemHeight * this.scrollingIndex}px)`;\n }\n\n return {\n ...styles,\n };\n }\n\n private getScrollbarGhostStyle() {\n const styles: Partial<StyleDeclaration> = {};\n\n if (this.virtualScroll && this.items !== null) {\n styles.height = `${this.items.length * this.sixMenuItemHeight - this.itemSize * this.sixMenuItemHeight}px`;\n }\n\n return {\n ...styles,\n };\n }\n\n private renderItems() {\n if (this.items === undefined || this.items === null) {\n return;\n }\n\n if (!this.virtualScroll) {\n return this.items.map(mapToMenuItem);\n }\n\n return this.items\n .slice(this.scrollingIndex, Math.min(this.items.length, this.itemSize + this.scrollingIndex))\n .map(mapToMenuItem);\n }\n\n render() {\n return (\n <div\n ref={(el) => (this.menuWrapper = el)}\n style={this.getMenuWrapperStyle()}\n part=\"wrapper\"\n class={{\n menu: true,\n 'menu--noshadow': this.removeBoxShadow,\n 'menu__wrapper--scrollable': this.getItemsShown() > 0,\n }}\n >\n <div\n ref={(el) => (this.menu = el)}\n part=\"base\"\n role=\"menu\"\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n tabIndex={0}\n style={this.getMenuContainerStyle()}\n >\n <slot />\n {this.renderItems()}\n </div>\n {this.virtualScroll && <div style={this.getScrollbarGhostStyle()} />}\n </div>\n );\n }\n}\n","@import 'src/global/component';\n\n:host {\n display: block;\n}\n\n.menu-item {\n position: relative;\n display: flex;\n align-items: stretch;\n font-family: var(--six-font-sans);\n font-size: var(--six-font-size-small);\n font-weight: var(--six-font-weight-normal);\n line-height: var(--six-line-height-normal);\n letter-spacing: var(--six-letter-spacing-normal);\n text-align: left;\n color: var(--six-input-color);\n border-radius: var(--six-border-radius-medium);\n padding: var(--six-spacing-medium) var(--six-spacing-medium);\n transition: var(--six-transition-fast) fill;\n user-select: none;\n white-space: nowrap;\n cursor: pointer;\n\n &.menu-item--focused:not(.menu-item--disabled) {\n outline: none;\n background-color: var(--six-menu-item-background-color);\n }\n\n &.menu-item--disabled {\n outline: none;\n color: var(--six-input-color-disabled);\n cursor: not-allowed;\n }\n\n .menu-item__label {\n flex: 1 1 auto;\n align-self: center;\n }\n\n .menu-item__prefix {\n flex: 0 0 auto;\n display: flex;\n align-items: center;\n\n ::slotted(:last-child) {\n margin-right: 0.5em;\n }\n }\n\n .menu-item__suffix {\n flex: 0 0 auto;\n display: flex;\n align-items: center;\n\n ::slotted(:first-child) {\n margin-left: 0.5em;\n }\n }\n\n .menu-item__check {\n flex: 0 0 auto;\n display: flex;\n align-items: center;\n margin-left: var(--six-spacing-small);\n visibility: hidden;\n font-size: inherit;\n }\n}\n\n.menu-item--checked .menu-item__check {\n visibility: visible;\n}\n","import { Component, Method, Prop, State, h } from '@stencil/core';\nimport { getTextContent } from '../../utils/slot';\n\n/**\n * @since 1.0\n * @status stable\n *\n * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.\n *\n * @slot - The menu item's label.\n * @slot prefix - Used to prepend an icon or similar element to the menu item.\n * @slot suffix - Used to append an icon or similar element to the menu item.\n *\n * @part base - The component's base wrapper.\n * @part checked-icon - The container that wraps the checked icon.\n * @part prefix - The prefix container.\n * @part label - The menu item label.\n * @part suffix - The suffix container.\n */\n\n@Component({\n tag: 'six-menu-item',\n styleUrl: 'six-menu-item.scss',\n shadow: true,\n})\nexport class SixMenuItem {\n menuItem: HTMLElement;\n defaultSlot: HTMLSlotElement;\n\n @State() hasFocus = false;\n\n /** Set to true to draw the item in a checked state. */\n @Prop({ reflect: true }) checked = false;\n\n /** A unique value to store in the menu item. This can be used as a way to identify menu items when selected. */\n @Prop({ reflect: true }) value = '';\n\n /** Set to true to draw the menu item in a disabled state. */\n @Prop({ reflect: true }) disabled = false;\n\n connectedCallback() {\n this.handleBlur = this.handleBlur.bind(this);\n this.handleFocus = this.handleFocus.bind(this);\n this.handleMouseEnter = this.handleMouseEnter.bind(this);\n this.handleMouseLeave = this.handleMouseLeave.bind(this);\n }\n\n /** Sets focus on the button. */\n @Method()\n async setFocus(options?: FocusOptions) {\n this.menuItem.focus(options);\n }\n\n /** Removes focus from the button. */\n @Method()\n async removeFocus() {\n this.menuItem.blur();\n }\n\n /** Returns a text label based on the contents of the menu item's default slot. */\n @Method()\n getTextLabel() {\n return Promise.resolve(getTextContent(this.defaultSlot));\n }\n\n handleBlur() {\n this.hasFocus = false;\n }\n\n handleFocus() {\n this.hasFocus = true;\n }\n\n handleMouseEnter() {\n this.setFocus();\n }\n\n handleMouseLeave() {\n this.removeFocus();\n }\n\n render() {\n return (\n <div\n ref={(el) => (this.menuItem = el)}\n part=\"base\"\n class={{\n 'menu-item': true,\n 'menu-item--checked': this.checked,\n 'menu-item--disabled': this.disabled,\n 'menu-item--focused': this.hasFocus,\n }}\n role=\"menuitem\"\n aria-disabled={this.disabled ? 'true' : 'false'}\n aria-checked={this.checked ? 'true' : 'false'}\n tabIndex={!this.disabled ? 0 : null}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n onMouseEnter={this.handleMouseEnter}\n onMouseLeave={this.handleMouseLeave}\n >\n <span part=\"prefix\" class=\"menu-item__prefix\">\n <slot name=\"prefix\" />\n </span>\n\n <span part=\"label\" class=\"menu-item__label\">\n <slot ref={(el) => (this.defaultSlot = el as HTMLSlotElement)} />\n </span>\n\n <span part=\"suffix\" class=\"menu-item__suffix\">\n <slot name=\"suffix\" />\n </span>\n\n <span part=\"checked-icon\" class=\"menu-item__check\">\n <six-icon size=\"small\" aria-hidden=\"true\">\n check\n </six-icon>\n </span>\n </div>\n );\n }\n}\n"],"version":3}
@@ -1,100 +0,0 @@
1
- import { r as registerInstance, h, H as Host, c as createEvent } from './index-96b1af5d.js';
2
-
3
- const sixTableCellCss = ":host{position:relative;box-sizing:border-box}:host *,:host *:before,:host *:after{box-sizing:inherit}:host{display:table-cell;padding:var(--six-spacing-medium);font-size:var(--six-font-size-small)}";
4
-
5
- const SixTableCell = class {
6
- constructor(hostRef) {
7
- registerInstance(this, hostRef);
8
- }
9
- render() {
10
- return (h(Host, null, h("slot", null)));
11
- }
12
- };
13
- SixTableCell.style = sixTableCellCss;
14
-
15
- const sixTableHeaderCss = ":host{position:relative;box-sizing:border-box}:host *,:host *:before,:host *:after{box-sizing:inherit}:host{display:table-header-group;cursor:pointer;font-family:var(--six-font-family);font-weight:var(--six-font-weight-bold);color:var(--six-table-header-color);border-bottom:solid 2px var(--six-table-header-border-color);padding:0.75rem}";
16
-
17
- const SixTableHeader = class {
18
- constructor(hostRef) {
19
- registerInstance(this, hostRef);
20
- }
21
- render() {
22
- return (h(Host, null, h("slot", null)));
23
- }
24
- };
25
- SixTableHeader.style = sixTableHeaderCss;
26
-
27
- const getNextState = (states) => (current) => {
28
- const next = states.indexOf(current) + 1;
29
- return states[next < states.length ? next : 0];
30
- };
31
- const getNextSortState = getNextState(['none', 'asc', 'desc']);
32
- const getNextFilterState = getNextState(Object.values(['eq', 'ne', 'in', 'ni']));
33
-
34
- const createSortModel = (key, value) => {
35
- return { [key]: value };
36
- };
37
- const createFilterModel = (key, filter, value) => {
38
- return { [key]: { [filter]: value } };
39
- };
40
-
41
- const SortIcon = {
42
- ['asc']: 'arrow_drop_up',
43
- ['desc']: 'arrow_drop_down',
44
- ['none']: 'swap_vert',
45
- };
46
- const FilterIcon = {
47
- ['eq']: '=',
48
- ['ne']: '&ne;',
49
- ['in']: '&isin;',
50
- ['ni']: '&notin;',
51
- };
52
-
53
- const sixTableHeaderCellCss = ":host{position:relative;box-sizing:border-box}:host *,:host *:before,:host *:after{box-sizing:inherit}:host{display:table-cell;padding:var(--six-spacing-medium) var(--six-spacing-medium) var(--six-spacing-x-small);font-size:var(--six-font-size-small)}six-icon{vertical-align:text-top;width:1.5rem}.header:hover .header__trigger-icon,.header--selected .header__trigger-icon{opacity:1}.header__trigger-icon{color:var(--six-color-web-rock-600);opacity:0}.header__trigger-icon-box{float:right}[slot=prefix]{font-size:1.5em}six-dropdown::part(panel){overflow:inherit}";
54
-
55
- const SixTableHeaderCell = class {
56
- constructor(hostRef) {
57
- registerInstance(this, hostRef);
58
- this.sortUpdated = createEvent(this, "six-table-header-cell-sort-updated", 7);
59
- this.filterUpdated = createEvent(this, "six-table-header-cell-filter-updated", 7);
60
- this.handleSortNext = () => {
61
- this.sortUpdated.emit(createSortModel(this.name, getNextSortState(this.sort)));
62
- };
63
- this.handleFilterNext = () => {
64
- this.filterUpdated.emit(createFilterModel(this.name, getNextFilterState(this.filter), this.inputElement.value));
65
- };
66
- this.handleFilterChange = () => {
67
- this.filterUpdated.emit(createFilterModel(this.name, this.filter, this.inputElement.value));
68
- };
69
- this.handleFilterClear = () => {
70
- this.filterUpdated.emit(createFilterModel(this.name, this.filter, undefined));
71
- this.filterRef.hide();
72
- };
73
- this.name = undefined;
74
- this.sort = undefined;
75
- this.filter = undefined;
76
- this.value = undefined;
77
- }
78
- render() {
79
- const sort = this.sort && (h("six-icon", { filled: true, class: { 'header__trigger-icon': this.sort === 'none' }, onClick: this.handleSortNext, "data-testid": `table-sort-${this.name}` }, SortIcon[this.sort]));
80
- const filter = this.filter && (h("six-dropdown", { ref: (el) => (this.filterRef = el), hoist: true, "data-testid": `table-filter-${this.name}` }, h("six-icon", { slot: "trigger", class: "header__trigger-icon" }, "filter_alt"), h("six-input", { ref: (el) => (this.inputElement = el), value: this.value, "onSix-input-input": this.handleFilterChange }, h("six-icon-button", { slot: "prefix", html: FilterIcon[this.filter], onClick: this.handleFilterNext, "data-testid": `table-filter-prefix-${this.name}` }), h("six-icon-button", { slot: "suffix", name: "clear", label: "Clear", onClick: this.handleFilterClear, "data-testid": `table-filter-suffix-${this.name}` }))));
81
- return (h(Host, null, h("div", { class: { header: true, 'header--selected': this.value !== undefined } }, h("slot", null), h("div", { class: "header__trigger-icon-box" }, sort, filter))));
82
- }
83
- };
84
- SixTableHeaderCell.style = sixTableHeaderCellCss;
85
-
86
- const sixTableRowCss = ":host{position:relative;box-sizing:border-box}:host *,:host *:before,:host *:after{box-sizing:inherit}:host{display:table-row;font-family:var(--six-font-family)}:host(:hover){background-color:var(--six-table-row-background-color-hover)}";
87
-
88
- const SixTableRow = class {
89
- constructor(hostRef) {
90
- registerInstance(this, hostRef);
91
- }
92
- render() {
93
- return (h(Host, null, h("slot", null)));
94
- }
95
- };
96
- SixTableRow.style = sixTableRowCss;
97
-
98
- export { SixTableCell as six_table_cell, SixTableHeader as six_table_header, SixTableHeaderCell as six_table_header_cell, SixTableRow as six_table_row };
99
-
100
- //# sourceMappingURL=six-table-cell_4.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"six-table-cell.six-table-header.six-table-header-cell.six-table-row.entry.js","mappings":"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","names":[],"sources":["./src/components/six-table-cell/six-table-cell.scss?tag=six-table-cell&encapsulation=shadow","./src/components/six-table-cell/six-table-cell.tsx","./src/components/six-table-header/six-table-header.scss?tag=six-table-header&encapsulation=shadow","./src/components/six-table-header/six-table-header.tsx","./src/components/six-table-header-cell/util/get-next-state.ts","./src/components/six-table-header-cell/util/create-model.ts","./src/components/six-table-header-cell/icons.ts","./src/components/six-table-header-cell/six-table-header-cell.scss?tag=six-table-header-cell&encapsulation=shadow","./src/components/six-table-header-cell/six-table-header-cell.tsx","./src/components/six-table-row/six-table-row.scss?tag=six-table-row&encapsulation=shadow","./src/components/six-table-row/six-table-row.tsx"],"sourcesContent":["@import 'src/global/component';\n\n:host {\n display: table-cell;\n padding: var(--six-spacing-medium);\n font-size: var(--six-font-size-small);\n}\n","import { Component, h, Host } from '@stencil/core';\n\n/**\n * @since 1.0\n * @status stable\n *\n * @slot - Used to define the content of the cell.\n */\n\n@Component({\n tag: 'six-table-cell',\n styleUrl: 'six-table-cell.scss',\n shadow: true,\n})\nexport class SixTableCell {\n render() {\n return (\n <Host>\n <slot />\n </Host>\n );\n }\n}\n","@import 'src/global/component';\n\n:host {\n display: table-header-group;\n cursor: pointer;\n font-family: var(--six-font-family);\n font-weight: var(--six-font-weight-bold);\n color: var(--six-table-header-color);\n border-bottom: solid 2px var(--six-table-header-border-color);\n padding: 0.75rem;\n}\n","import { Component, Host, h } from '@stencil/core';\n\n/**\n * @since 1.0\n * @status stable\n *\n * @slot - Used to define the cells of the header.\n */\n\n@Component({\n tag: 'six-table-header',\n styleUrl: 'six-table-header.scss',\n shadow: true,\n})\nexport class SixTableHeader {\n render() {\n return (\n <Host>\n <slot />\n </Host>\n );\n }\n}\n","import { FilterMode, SortDirection } from '../types';\n\nconst getNextState =\n <T>(states: T[]) =>\n (current: T): T => {\n const next = states.indexOf(current) + 1;\n return states[next < states.length ? next : 0];\n };\n\nexport const getNextSortState = getNextState(['none', 'asc', 'desc'] as SortDirection[]);\nexport const getNextFilterState = getNextState(Object.values(['eq', 'ne', 'in', 'ni'] as FilterMode[]));\n","import { Item, SortModel, FilterModel } from '../../six-table/types';\nimport { SortDirection, FilterMode } from '../types';\n\nexport const createSortModel = <T extends Item>(key: keyof T, value: SortDirection): SortModel<T> => {\n return { [key]: value } as any;\n};\n\nexport const createFilterModel = <T extends Item>(key: keyof T, filter: FilterMode, value: string): FilterModel<T> => {\n return { [key]: { [filter]: value } } as any;\n};\n","import { FilterMode, SortDirection } from './types';\n\nexport const SortIcon: Record<SortDirection, string> = {\n ['asc']: 'arrow_drop_up',\n ['desc']: 'arrow_drop_down',\n ['none']: 'swap_vert',\n};\n\nexport const FilterIcon: Record<FilterMode, string> = {\n ['eq']: '=',\n ['ne']: '&ne;',\n ['in']: '&isin;',\n ['ni']: '&notin;',\n};\n","@import 'src/global/component';\n\n:host {\n display: table-cell;\n padding: var(--six-spacing-medium) var(--six-spacing-medium) var(--six-spacing-x-small);\n font-size: var(--six-font-size-small);\n}\n\nsix-icon {\n vertical-align: text-top;\n width: 1.5rem;\n}\n\n.header {\n &:hover,\n &--selected {\n .header__trigger-icon {\n opacity: 1;\n }\n }\n\n &__trigger-icon {\n color: var(--six-color-web-rock-600);\n opacity: 0;\n }\n\n &__trigger-icon-box {\n float: right;\n }\n}\n\n[slot='prefix'] {\n font-size: 1.5em;\n}\n\nsix-dropdown::part(panel) {\n overflow: inherit;\n}\n","import { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\nimport { FilterMode, SortDirection } from './types';\nimport { FilterModel, Item, SortModel } from '../six-table/types';\nimport { getNextFilterState, getNextSortState } from './util/get-next-state';\nimport { createFilterModel, createSortModel } from './util/create-model';\nimport { FilterIcon, SortIcon } from './icons';\n\nexport type SixTableHeaderCellSortUpdatedPayload = SortModel<Item>;\nexport type SixTableHeaderCellFilterUpdatedPayload = FilterModel<Item>;\n\n/**\n * @since 1.0\n * @status stable\n *\n * @slot - Used to define the label of the header field.\n */\n\n@Component({\n tag: 'six-table-header-cell',\n styleUrl: 'six-table-header-cell.scss',\n shadow: true,\n})\nexport class SixTableHeaderCell {\n filterRef: HTMLSixDropdownElement;\n\n /** Table row property name. Used in the custom events to identify the row. */\n @Prop() name: keyof Item;\n /** Sort direction. Applied only when set. */\n @Prop() sort: SortDirection;\n /** Filter mode. Applied only when set. */\n @Prop() filter: FilterMode;\n /** Filter value. Applied only when filter mode is set. */\n @Prop() value: string;\n\n /** Emitted when sort model is updated. */\n @Event({ eventName: 'six-table-header-cell-sort-updated' })\n sortUpdated: EventEmitter<SixTableHeaderCellSortUpdatedPayload>;\n /** Emitted when filter model is updated. */\n @Event({ eventName: 'six-table-header-cell-filter-updated' })\n filterUpdated: EventEmitter<SixTableHeaderCellFilterUpdatedPayload>;\n\n inputElement: HTMLSixInputElement;\n\n handleSortNext = () => {\n this.sortUpdated.emit(createSortModel(this.name, getNextSortState(this.sort)));\n };\n\n handleFilterNext = () => {\n this.filterUpdated.emit(createFilterModel(this.name, getNextFilterState(this.filter), this.inputElement.value));\n };\n\n handleFilterChange = () => {\n this.filterUpdated.emit(createFilterModel(this.name, this.filter, this.inputElement.value));\n };\n\n handleFilterClear = () => {\n this.filterUpdated.emit(createFilterModel(this.name, this.filter, undefined));\n this.filterRef.hide();\n };\n\n render() {\n const sort = this.sort && (\n <six-icon\n filled={true}\n class={{ 'header__trigger-icon': this.sort === 'none' }}\n onClick={this.handleSortNext}\n data-testid={`table-sort-${this.name}`}\n >\n {SortIcon[this.sort]}\n </six-icon>\n );\n\n const filter = this.filter && (\n <six-dropdown ref={(el) => (this.filterRef = el)} hoist data-testid={`table-filter-${this.name}`}>\n <six-icon slot=\"trigger\" class=\"header__trigger-icon\">\n filter_alt\n </six-icon>\n <six-input\n ref={(el) => (this.inputElement = el)}\n value={this.value}\n onSix-input-input={this.handleFilterChange}\n >\n <six-icon-button\n slot=\"prefix\"\n html={FilterIcon[this.filter]}\n onClick={this.handleFilterNext}\n data-testid={`table-filter-prefix-${this.name}`}\n />\n <six-icon-button\n slot=\"suffix\"\n name=\"clear\"\n label=\"Clear\"\n onClick={this.handleFilterClear}\n data-testid={`table-filter-suffix-${this.name}`}\n />\n </six-input>\n </six-dropdown>\n );\n\n return (\n <Host>\n <div class={{ header: true, 'header--selected': this.value !== undefined }}>\n <slot />\n <div class=\"header__trigger-icon-box\">\n {sort}\n {filter}\n </div>\n </div>\n </Host>\n );\n }\n}\n","@import 'src/global/component';\n\n:host {\n display: table-row;\n font-family: var(--six-font-family);\n}\n\n:host(:hover) {\n background-color: var(--six-table-row-background-color-hover);\n}\n","import { Component, h, Host } from '@stencil/core';\n\n/**\n * @since 1.0\n * @status stable\n *\n * @slot - Used to define the cells of the row.\n */\n\n@Component({\n tag: 'six-table-row',\n styleUrl: 'six-table-row.scss',\n shadow: true,\n})\nexport class SixTableRow {\n render() {\n return (\n <Host>\n <slot />\n </Host>\n );\n }\n}\n"],"version":3}
@@ -1,163 +0,0 @@
1
- import { h, F as Fragment, r as registerInstance, c as createEvent, H as Host, g as getElement } from './index-96b1af5d.js';
2
-
3
- const assertions = [
4
- (value) => typeof value === 'object',
5
- (value) => typeof value.columns === 'object',
6
- (value) => Array.isArray(value.rows),
7
- (value) => value.sort === undefined || typeof value.sort === 'object',
8
- ];
9
- const apply = (value) => (f) => f(value);
10
- const isData = (value) => assertions.every(apply(value));
11
-
12
- const Invalid = {
13
- Term: (value) => typeof value !== 'string' || value.length < 1,
14
- };
15
-
16
- const modes = {
17
- in: (a, b) => a.includes(b),
18
- ni: (a, b) => !a.includes(b),
19
- eq: (a, b) => a === b,
20
- ne: (a, b) => a !== b,
21
- };
22
- const filterBy = (filterModel = {}) => (item) => {
23
- var _a;
24
- const keys = Object.keys(filterModel);
25
- if (keys.length === 0) {
26
- return true;
27
- }
28
- for (const key of keys) {
29
- const filter = filterModel[key];
30
- if (!filter) {
31
- return true;
32
- }
33
- for (const [mode, term] of Object.entries(filter)) {
34
- if (Invalid.Term(term)) {
35
- continue;
36
- }
37
- const value = String((_a = item[key]) !== null && _a !== void 0 ? _a : '');
38
- if (Invalid.Term(value)) {
39
- continue;
40
- }
41
- if (!modes[mode](value, term)) {
42
- return false;
43
- }
44
- }
45
- }
46
- return true;
47
- };
48
-
49
- const unordered = (value) => value === 'none';
50
- const DEFAULT_COMPARATOR = (a, b) => String(a).localeCompare(String(b));
51
- const sortBy = (sort = {}, compare = {}) => (items) => {
52
- const values = Object.values(sort);
53
- if (values.length === 0 || values.every(unordered)) {
54
- return items;
55
- }
56
- return [...items].sort((a, b) => {
57
- return Object.entries(sort).reduce((acc, [k, v], index) => {
58
- if (v === 'none') {
59
- return acc;
60
- }
61
- const comparator = compare[k];
62
- const direction = {
63
- asc: +1,
64
- desc: -1,
65
- }[v];
66
- if (comparator) {
67
- return acc + direction * (comparator(a, b) << index);
68
- }
69
- return acc + direction * (DEFAULT_COMPARATOR(a[k], b[k]) << index);
70
- }, 0);
71
- });
72
- };
73
-
74
- const quickFilterBy = (keys, value) => (item) => {
75
- if (Invalid.Term(value)) {
76
- return true;
77
- }
78
- const term = value.toLowerCase();
79
- const source = keys
80
- .map((key) => { var _a; return (_a = item[key]) !== null && _a !== void 0 ? _a : ''; })
81
- .map(String)
82
- .join()
83
- .toLowerCase();
84
- return source.includes(term);
85
- };
86
-
87
- const propOr = (k) => (o = {}, defaults) => o[k] || defaults;
88
- const fromData = ({ data, handleRowClick, handleCellClick }) => {
89
- if (!isData(data)) {
90
- return;
91
- }
92
- const keys = Object.keys(data.columns);
93
- const columns = keys.map((key) => {
94
- const byKey = propOr(key);
95
- const sort = byKey(data.sort, undefined);
96
- const [[filter, value] = []] = Object.entries(byKey(data.filter, {}));
97
- return (h("six-table-header-cell", { name: key, sort: sort, filter: filter, value: value }, data.columns[key]));
98
- });
99
- const quickFilter = quickFilterBy(Object.keys(data.columns), data.quickFilter);
100
- const filter = filterBy(data.filter);
101
- const sort = sortBy(data.sort, data.compare);
102
- const rows = sort(data.rows.filter(quickFilter).filter(filter)).map((item, index) => {
103
- const cells = keys.map((key) => {
104
- const renderer = data.render && data.render[key];
105
- // HTML is not escaped, responsibility lays on the caller
106
- const html = typeof renderer === 'function' ? renderer(item) : String(item[key]);
107
- return (h("six-table-cell", { onClick: handleCellClick(item, key), "data-testid": `table-cell-${key}-${index}`, innerHTML: html }));
108
- });
109
- return (h("six-table-row", { onClick: handleRowClick(item), "data-testid": `table-row-${index}` }, cells));
110
- });
111
- return (h(Fragment, null,
112
- h("six-table-header", { "data-testid": "table-header" }, columns),
113
- rows));
114
- };
115
-
116
- const sixTableCss = ":host{position:relative;box-sizing:border-box}:host *,:host *:before,:host *:after{box-sizing:inherit}:host{display:table;border-collapse:collapse;user-select:none;border:none;width:100%;height:100%}:host([loading]){border-collapse:separate}:host([striped]) six-table-row:nth-child(odd):not(:hover),:host([striped]) ::slotted(six-table-row:nth-child(odd):not(:hover)){background-color:var(--six-table-row-background-color)}:host(:not(striped)) ::slotted(six-table-row){border-bottom:solid 1px var(--six-table-row-border-color)}.loading{position:absolute;background-color:var(--six-table-background-color);top:0;left:0;width:100%;height:100%}.loading six-spinner{top:calc(50% - 0.5em);left:50%;transform:scale(3)}";
117
-
118
- const SixTable = class {
119
- handleData({ detail }) {
120
- if (!isData(detail)) {
121
- return;
122
- }
123
- this.data = detail;
124
- }
125
- async setData(value) {
126
- if (!isData(value)) {
127
- return;
128
- }
129
- this.data = value;
130
- }
131
- componentDidLoad() {
132
- this.tableReady.emit();
133
- }
134
- constructor(hostRef) {
135
- registerInstance(this, hostRef);
136
- this.tableReady = createEvent(this, "six-table-ready", 7);
137
- this.tableRowClicked = createEvent(this, "six-table-row-clicked", 7);
138
- this.tableCellClicked = createEvent(this, "six-table-cell-clicked", 7);
139
- this.handleRowClick = (item) => (event) => {
140
- this.tableRowClicked.emit({ event, item });
141
- };
142
- this.handleCellClick = (item, key) => (event) => {
143
- this.tableCellClicked.emit({ event, item, key });
144
- };
145
- this.striped = false;
146
- this.loading = false;
147
- this.data = {
148
- columns: {},
149
- rows: [],
150
- };
151
- console.warn('six-table will be removed with the next table. Use fate table instead. In case of any question contact Daniel Häusler');
152
- }
153
- render() {
154
- const loading = this.loading && (h("div", { class: "loading" }, h("six-spinner", { "data-testid": "loading-spinner" })));
155
- return (h(Host, null, h("slot", null, fromData(this)), loading));
156
- }
157
- get host() { return getElement(this); }
158
- };
159
- SixTable.style = sixTableCss;
160
-
161
- export { SixTable as six_table };
162
-
163
- //# sourceMappingURL=six-table.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"six-table.entry.js","mappings":"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","names":[],"sources":["./src/components/six-table/types.ts","./src/components/six-table/util/is.ts","./src/components/six-table/util/filter-by.ts","./src/components/six-table/util/sort-by.ts","./src/components/six-table/util/quick-filter-by.ts","./src/components/six-table/util/from-data.tsx","./src/components/six-table/six-table.scss?tag=six-table&encapsulation=shadow","./src/components/six-table/six-table.tsx"],"sourcesContent":["import { SortDirection, FilterMode } from '../six-table-header-cell/types';\n\nexport type Item = Record<string, unknown>;\n\nexport type BasedOnKeys<T extends keyof any, B> = {\n [K in T]?: B;\n};\n\nexport type Columns<T> = BasedOnKeys<keyof T, string>;\n\nexport type SortModel<T> = BasedOnKeys<keyof T, SortDirection>;\n\nexport type Comparator<T> = (a: T, b: T) => number;\n\nexport type CompareModel<T> = BasedOnKeys<keyof T, Comparator<T>>;\n\nexport type FilterModel<T> = BasedOnKeys<keyof T, BasedOnKeys<FilterMode, string>>;\n\nexport type Renderer<T> = (value: T) => string;\n\nexport type RenderModel<T> = BasedOnKeys<keyof T, Renderer<T>>;\n\nexport type Data<T> = {\n columns: Columns<T>;\n sort?: SortModel<T>;\n compare?: CompareModel<T>;\n render?: RenderModel<T>;\n filter?: FilterModel<T>;\n quickFilter?: string;\n rows: T[];\n};\n\nconst assertions = [\n (value) => typeof value === 'object',\n (value) => typeof value.columns === 'object',\n (value) => Array.isArray(value.rows),\n (value) => value.sort === undefined || typeof value.sort === 'object',\n];\n\nconst apply =\n <T>(value: T) =>\n (f: (value: T) => boolean) =>\n f(value);\n\nexport const isData = <T>(value?: unknown): value is Data<T> => assertions.every(apply(value));\n\nexport interface TableReadyPayload {}\n\nexport interface TableRowClickedPayload<T extends Item> {\n event: MouseEvent;\n item: T;\n}\n\nexport interface TableCellClickedPayload<T extends Item> {\n event: MouseEvent;\n item: T;\n key: string;\n}\n","export const Invalid = {\n Term: (value?: unknown) => typeof value !== 'string' || value.length < 1,\n};\n","import { FilterModel, Item } from '../types';\nimport { FilterMode } from '../../six-table-header-cell/types';\nimport { Invalid } from './is';\n\ntype Filter = (a: string, b: string) => boolean;\n\nconst modes: Record<FilterMode, Filter> = {\n in: (a, b) => a.includes(b),\n ni: (a, b) => !a.includes(b),\n eq: (a, b) => a === b,\n ne: (a, b) => a !== b,\n};\n\nexport const filterBy =\n <T extends Item>(filterModel: FilterModel<T> = {}) =>\n (item: T): boolean => {\n const keys = Object.keys(filterModel);\n\n if (keys.length === 0) {\n return true;\n }\n\n for (const key of keys) {\n const filter = filterModel[key];\n\n if (!filter) {\n return true;\n }\n\n for (const [mode, term] of Object.entries(filter)) {\n if (Invalid.Term(term)) {\n continue;\n }\n\n const value = String(item[key] ?? '');\n\n if (Invalid.Term(value)) {\n continue;\n }\n\n if (!modes[mode](value, term)) {\n return false;\n }\n }\n }\n\n return true;\n };\n","import { Comparator, CompareModel, Item, SortModel } from '../types';\nimport { SortDirection } from '../../six-table-header-cell/types';\n\nconst unordered = (value: SortDirection) => value === 'none';\n\nconst DEFAULT_COMPARATOR: Comparator<unknown> = (a, b) => String(a).localeCompare(String(b));\n\nexport const sortBy =\n <T extends Item>(sort: SortModel<T> = {}, compare: CompareModel<T> = {}) =>\n (items: T[]) => {\n const values = Object.values(sort);\n\n if (values.length === 0 || values.every(unordered)) {\n return items;\n }\n\n return [...items].sort((a, b) => {\n return Object.entries(sort).reduce((acc, [k, v], index) => {\n if (v === 'none') {\n return acc;\n }\n\n const comparator = compare[k];\n\n const direction = {\n asc: +1,\n desc: -1,\n }[v];\n\n if (comparator) {\n return acc + direction * (comparator(a, b) << index);\n }\n\n return acc + direction * (DEFAULT_COMPARATOR(a[k], b[k]) << index);\n }, 0);\n });\n };\n","import { Item } from '../types';\nimport { Invalid } from './is';\n\nexport const quickFilterBy =\n <T extends Item>(keys: string[], value?: string) =>\n (item: T): boolean => {\n if (Invalid.Term(value)) {\n return true;\n }\n\n const term = value.toLowerCase();\n\n const source = keys\n .map((key) => item[key] ?? '')\n .map(String)\n .join()\n .toLowerCase();\n\n return source.includes(term);\n };\n","import { Data, isData, Item } from '../types';\nimport { filterBy } from './filter-by';\nimport { Fragment, h } from '@stencil/core';\nimport { sortBy } from './sort-by';\nimport { quickFilterBy } from './quick-filter-by';\nimport { FilterMode } from '../../six-table-header-cell/types';\n\ninterface FromDataProps<T extends Item> {\n data: Data<T>;\n handleRowClick: (item: T) => (event: MouseEvent) => void;\n handleCellClick: (item: T, key: string) => (event: MouseEvent) => void;\n}\n\nconst propOr =\n (k: string) =>\n <T extends unknown>(o = {}, defaults: T): T =>\n o[k] || defaults;\n\nexport const fromData = <T extends Item>({ data, handleRowClick, handleCellClick }: FromDataProps<T>) => {\n if (!isData(data)) {\n return;\n }\n\n const keys = Object.keys(data.columns);\n\n const columns = keys.map((key) => {\n const byKey = propOr(key);\n\n const sort = byKey(data.sort, undefined);\n const [[filter, value] = []] = Object.entries<string>(byKey(data.filter, {}));\n\n return (\n <six-table-header-cell name={key} sort={sort} filter={filter as FilterMode} value={value}>\n {data.columns[key]}\n </six-table-header-cell>\n );\n });\n\n const quickFilter = quickFilterBy(Object.keys(data.columns), data.quickFilter);\n const filter = filterBy(data.filter);\n const sort = sortBy(data.sort, data.compare);\n\n const rows = sort(data.rows.filter(quickFilter).filter(filter)).map((item, index) => {\n const cells = keys.map((key) => {\n const renderer = data.render && data.render[key];\n // HTML is not escaped, responsibility lays on the caller\n const html = typeof renderer === 'function' ? renderer(item) : String(item[key]);\n\n return (\n <six-table-cell\n onClick={handleCellClick(item, key)}\n data-testid={`table-cell-${key}-${index}`}\n innerHTML={html}\n />\n );\n });\n\n return (\n <six-table-row onClick={handleRowClick(item)} data-testid={`table-row-${index}`}>\n {cells}\n </six-table-row>\n );\n });\n\n return (\n <Fragment>\n <six-table-header data-testid=\"table-header\">{columns}</six-table-header>\n {rows}\n </Fragment>\n );\n};\n","@import 'src/global/component';\n\n//$six-table-loading-overlay: rgba(0, 0, 0, 0.12);\n$six-table-loading-spinner: scale(3);\n\n:host {\n display: table;\n border-collapse: collapse;\n user-select: none;\n border: none;\n width: 100%;\n height: 100%;\n}\n\n:host([loading]) {\n border-collapse: separate;\n}\n\n:host([striped]) {\n six-table-row:nth-child(odd):not(:hover),\n ::slotted(six-table-row:nth-child(odd):not(:hover)) {\n background-color: var(--six-table-row-background-color);\n }\n}\n\n:host(:not(striped)) {\n ::slotted(six-table-row) {\n border-bottom: solid 1px var(--six-table-row-border-color);\n }\n}\n\n.loading {\n position: absolute;\n //background-color: $six-table-loading-overlay;\n background-color: var(--six-table-background-color);\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n}\n\n.loading six-spinner {\n top: calc(50% - 0.5em);\n left: 50%;\n transform: $six-table-loading-spinner;\n}\n","import { Component, Host, h, Prop, Event, EventEmitter, State, Listen, Method, Element } from '@stencil/core';\nimport { Data, isData, TableReadyPayload, TableRowClickedPayload, TableCellClickedPayload, Item } from './types';\nimport { fromData } from './util/from-data';\n\n/**\n * @since 1.0\n * @status stable\n *\n * @slot - Used to define header and the rows of the table.\n * @Deprecated - six-table will be removed with the next table. Use fate table instead.\n */\n\n@Component({\n tag: 'six-table',\n styleUrl: 'six-table.scss',\n shadow: true,\n})\nexport class SixTable {\n @Element() host: HTMLSixTableElement;\n\n /** Set to true to stripe the table. */\n @Prop() striped = false;\n /** Set to true to display loading indicator. */\n @Prop() loading = false;\n\n /** Emitted when table is ready. */\n @Event({ eventName: 'six-table-ready' }) tableReady: EventEmitter<TableReadyPayload>;\n /** Emitted when table row is clicked. */\n @Event({ eventName: 'six-table-row-clicked' }) tableRowClicked: EventEmitter<TableRowClickedPayload<Item>>;\n /** Emitted when table cell is clicked. */\n @Event({ eventName: 'six-table-cell-clicked' }) tableCellClicked: EventEmitter<TableCellClickedPayload<Item>>;\n\n @Listen('data')\n handleData<T extends Item>({ detail }: CustomEvent<Data<T>>) {\n if (!isData(detail)) {\n return;\n }\n\n this.data = detail;\n }\n\n @Method()\n async setData<T extends Item>(value: Data<T>) {\n if (!isData(value)) {\n return;\n }\n\n this.data = value;\n }\n\n @State() data: Data<Item> = {\n columns: {},\n rows: [],\n };\n\n componentDidLoad() {\n this.tableReady.emit();\n }\n\n handleRowClick =\n <T extends Item>(item: T) =>\n (event: MouseEvent) => {\n this.tableRowClicked.emit({ event, item });\n };\n\n handleCellClick =\n <T extends Item>(item: T, key: string) =>\n (event: MouseEvent) => {\n this.tableCellClicked.emit({ event, item, key });\n };\n\n constructor() {\n console.warn(\n 'six-table will be removed with the next table. Use fate table instead. In case of any question contact Daniel Häusler'\n );\n }\n\n render() {\n const loading = this.loading && (\n <div class=\"loading\">\n <six-spinner data-testid=\"loading-spinner\" />\n </div>\n );\n\n return (\n <Host>\n <slot>{fromData(this)}</slot>\n {loading}\n </Host>\n );\n }\n}\n"],"version":3}
@@ -1,30 +0,0 @@
1
- import { EventEmitter } from '../../stencil-public-runtime';
2
- import { Data, TableReadyPayload, TableRowClickedPayload, TableCellClickedPayload, Item } from './types';
3
- /**
4
- * @since 1.0
5
- * @status stable
6
- *
7
- * @slot - Used to define header and the rows of the table.
8
- * @Deprecated - six-table will be removed with the next table. Use fate table instead.
9
- */
10
- export declare class SixTable {
11
- host: HTMLSixTableElement;
12
- /** Set to true to stripe the table. */
13
- striped: boolean;
14
- /** Set to true to display loading indicator. */
15
- loading: boolean;
16
- /** Emitted when table is ready. */
17
- tableReady: EventEmitter<TableReadyPayload>;
18
- /** Emitted when table row is clicked. */
19
- tableRowClicked: EventEmitter<TableRowClickedPayload<Item>>;
20
- /** Emitted when table cell is clicked. */
21
- tableCellClicked: EventEmitter<TableCellClickedPayload<Item>>;
22
- handleData<T extends Item>({ detail }: CustomEvent<Data<T>>): void;
23
- setData<T extends Item>(value: Data<T>): Promise<void>;
24
- data: Data<Item>;
25
- componentDidLoad(): void;
26
- handleRowClick: <T extends Item>(item: T) => (event: MouseEvent) => void;
27
- handleCellClick: <T extends Item>(item: T, key: string) => (event: MouseEvent) => void;
28
- constructor();
29
- render(): any;
30
- }
@@ -1,2 +0,0 @@
1
- import { E2EPage } from '@stencil/core/testing';
2
- export declare const getTableRows: (page: E2EPage) => Promise<any>;
@@ -1,33 +0,0 @@
1
- import { SortDirection, FilterMode } from '../six-table-header-cell/types';
2
- export type Item = Record<string, unknown>;
3
- export type BasedOnKeys<T extends keyof any, B> = {
4
- [K in T]?: B;
5
- };
6
- export type Columns<T> = BasedOnKeys<keyof T, string>;
7
- export type SortModel<T> = BasedOnKeys<keyof T, SortDirection>;
8
- export type Comparator<T> = (a: T, b: T) => number;
9
- export type CompareModel<T> = BasedOnKeys<keyof T, Comparator<T>>;
10
- export type FilterModel<T> = BasedOnKeys<keyof T, BasedOnKeys<FilterMode, string>>;
11
- export type Renderer<T> = (value: T) => string;
12
- export type RenderModel<T> = BasedOnKeys<keyof T, Renderer<T>>;
13
- export type Data<T> = {
14
- columns: Columns<T>;
15
- sort?: SortModel<T>;
16
- compare?: CompareModel<T>;
17
- render?: RenderModel<T>;
18
- filter?: FilterModel<T>;
19
- quickFilter?: string;
20
- rows: T[];
21
- };
22
- export declare const isData: <T>(value?: unknown) => value is Data<T>;
23
- export interface TableReadyPayload {
24
- }
25
- export interface TableRowClickedPayload<T extends Item> {
26
- event: MouseEvent;
27
- item: T;
28
- }
29
- export interface TableCellClickedPayload<T extends Item> {
30
- event: MouseEvent;
31
- item: T;
32
- key: string;
33
- }
@@ -1,2 +0,0 @@
1
- import { FilterModel, Item } from '../types';
2
- export declare const filterBy: <T extends Item>(filterModel?: FilterModel<T>) => (item: T) => boolean;
@@ -1,8 +0,0 @@
1
- import { Data, Item } from '../types';
2
- interface FromDataProps<T extends Item> {
3
- data: Data<T>;
4
- handleRowClick: (item: T) => (event: MouseEvent) => void;
5
- handleCellClick: (item: T, key: string) => (event: MouseEvent) => void;
6
- }
7
- export declare const fromData: <T extends Item>({ data, handleRowClick, handleCellClick }: FromDataProps<T>) => any;
8
- export {};
@@ -1,3 +0,0 @@
1
- export declare const Invalid: {
2
- Term: (value?: unknown) => boolean;
3
- };
@@ -1,2 +0,0 @@
1
- import { Item } from '../types';
2
- export declare const quickFilterBy: <T extends Item>(keys: string[], value?: string) => (item: T) => boolean;
@@ -1,2 +0,0 @@
1
- import { CompareModel, Item, SortModel } from '../types';
2
- export declare const sortBy: <T extends Item>(sort?: SortModel<T>, compare?: CompareModel<T>) => (items: T[]) => T[];
@@ -1,9 +0,0 @@
1
- /**
2
- * @since 1.0
3
- * @status stable
4
- *
5
- * @slot - Used to define the content of the cell.
6
- */
7
- export declare class SixTableCell {
8
- render(): any;
9
- }
@@ -1,9 +0,0 @@
1
- /**
2
- * @since 1.0
3
- * @status stable
4
- *
5
- * @slot - Used to define the cells of the header.
6
- */
7
- export declare class SixTableHeader {
8
- render(): any;
9
- }
@@ -1,2 +0,0 @@
1
- export declare const getNextSortState: (current: string) => string;
2
- export declare const getNextFilterState: (current: string) => string;
@@ -1,3 +0,0 @@
1
- import { FilterMode, SortDirection } from './types';
2
- export declare const SortIcon: Record<SortDirection, string>;
3
- export declare const FilterIcon: Record<FilterMode, string>;