@elastic/eui 91.0.0 → 91.1.0

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 (382) hide show
  1. package/dist/eui_theme_dark.css +191 -124
  2. package/dist/eui_theme_dark.min.css +1 -1
  3. package/dist/eui_theme_light.css +191 -124
  4. package/dist/eui_theme_light.min.css +1 -1
  5. package/es/components/accordion/accordion.a11y.js +1 -3
  6. package/es/components/basic_table/action_types.js +5 -0
  7. package/es/components/basic_table/basic_table.a11y.js +1 -2
  8. package/es/components/basic_table/basic_table.js +8 -8
  9. package/es/components/basic_table/collapsed_item_actions.js +120 -249
  10. package/es/components/basic_table/custom_item_action.js +9 -95
  11. package/es/components/basic_table/default_item_action.js +23 -14
  12. package/es/components/basic_table/in_memory_table.a11y.js +13 -11
  13. package/es/components/basic_table/in_memory_table.js +8 -8
  14. package/es/components/breadcrumbs/breadcrumb.js +11 -7
  15. package/es/components/breadcrumbs/breadcrumb.styles.js +5 -0
  16. package/es/components/button/button_display/_button_display.js +5 -3
  17. package/es/components/button/button_display/_button_display_content.js +8 -4
  18. package/es/components/button/button_empty/button_empty.js +9 -7
  19. package/es/components/button/button_group/button_group.js +5 -3
  20. package/es/components/button/button_group/button_group_button.js +5 -3
  21. package/es/components/card/card.a11y.js +5 -18
  22. package/es/components/collapsible_nav_beta/collapsible_nav_beta.styles.js +2 -2
  23. package/es/components/collapsible_nav_beta/collapsible_nav_body_footer.js +4 -1
  24. package/es/components/collapsible_nav_beta/collapsible_nav_body_footer.styles.js +12 -9
  25. package/es/components/collapsible_nav_beta/collapsible_nav_group/collapsible_nav_group.js +1 -101
  26. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_button.js +20 -58
  27. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_item.js +89 -37
  28. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.js +67 -81
  29. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.styles.js +1 -19
  30. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.js +7 -102
  31. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.styles.js +4 -4
  32. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_group.js +7 -90
  33. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_item.js +150 -130
  34. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_link.js +0 -10
  35. package/es/components/combo_box/combo_box.js +1 -1
  36. package/es/components/context_menu/context_menu_item.js +16 -8
  37. package/es/components/context_menu/context_menu_item.styles.js +1 -1
  38. package/es/components/datagrid/body/data_grid_body.js +16 -6
  39. package/es/components/datagrid/body/data_grid_body_custom.js +16 -6
  40. package/es/components/datagrid/body/data_grid_body_virtualized.js +16 -6
  41. package/es/components/datagrid/body/data_grid_cell.js +67 -44
  42. package/es/components/datagrid/body/data_grid_cell_actions.js +12 -12
  43. package/es/components/datagrid/body/data_grid_cell_popover.js +43 -10
  44. package/es/components/datagrid/body/header/data_grid_header_cell.js +65 -34
  45. package/es/components/datagrid/body/header/data_grid_header_row.js +16 -6
  46. package/es/components/datagrid/controls/column_selector.js +19 -39
  47. package/es/components/datagrid/controls/column_sorting.js +18 -29
  48. package/es/components/datagrid/controls/data_grid_toolbar_control.js +154 -0
  49. package/es/components/datagrid/controls/display_selector.js +0 -1
  50. package/es/components/datagrid/controls/fullscreen_selector.js +2 -6
  51. package/es/components/datagrid/controls/index.js +2 -1
  52. package/es/components/datagrid/index.js +1 -1
  53. package/es/components/datagrid/utils/in_memory.js +16 -6
  54. package/es/components/datagrid/utils/row_heights.js +1 -1
  55. package/es/components/date_picker/auto_refresh/auto_refresh.js +6 -4
  56. package/es/components/date_picker/super_date_picker/super_update_button.js +1 -1
  57. package/es/components/error_boundary/error_boundary.a11y.js +1 -1
  58. package/es/components/expression/expression.a11y.js +2 -4
  59. package/es/components/facet/facet_button.js +5 -3
  60. package/es/components/filter_group/filter_button.js +2 -2
  61. package/es/components/focus_trap/focus_trap.a11y.js +3 -3
  62. package/es/components/form/range/range.a11y.js +5 -10
  63. package/es/components/form/super_select/super_select.js +3 -2
  64. package/es/components/form/super_select/super_select_control.js +13 -20
  65. package/es/components/header/header.a11y.js +1 -1
  66. package/es/components/header/header_links/header_link.js +7 -5
  67. package/es/components/header/header_section/header_section_item_button.js +7 -5
  68. package/es/components/image/image.a11y.js +1 -2
  69. package/es/components/key_pad_menu/key_pad_menu.a11y.js +5 -5
  70. package/es/components/link/external_link_icon.js +51 -0
  71. package/es/components/link/link.js +6 -20
  72. package/es/components/link/link.styles.js +2 -5
  73. package/es/components/list_group/list_group.js +6 -1
  74. package/es/components/list_group/list_group_item.js +14 -4
  75. package/es/components/list_group/list_group_item.styles.js +2 -1
  76. package/es/components/list_group/pinnable_list_group/pinnable_list_group.js +12 -2
  77. package/es/components/notification/notification_event.a11y.js +1 -2
  78. package/es/components/notification/notification_event.js +7 -5
  79. package/es/components/pagination/pagination_button.js +7 -5
  80. package/es/components/popover/popover.js +4 -1
  81. package/es/components/resizable_container/resizable_container.a11y.js +4 -8
  82. package/es/components/search_bar/search_bar.a11y.js +3 -6
  83. package/es/components/selectable/selectable.js +16 -1
  84. package/es/components/selectable/selectable_list/selectable_list.js +227 -78
  85. package/es/components/selectable/selectable_templates/selectable_template_sitewide.js +16 -1
  86. package/es/components/text/text.styles.js +2 -2
  87. package/es/components/text_truncate/text_truncate.js +33 -10
  88. package/eui.d.ts +466 -136
  89. package/i18ntokens.json +224 -260
  90. package/lib/components/accordion/accordion.a11y.js +1 -3
  91. package/lib/components/basic_table/action_types.js +8 -2
  92. package/lib/components/basic_table/basic_table.a11y.js +1 -2
  93. package/lib/components/basic_table/basic_table.js +8 -8
  94. package/lib/components/basic_table/collapsed_item_actions.js +128 -257
  95. package/lib/components/basic_table/custom_item_action.js +18 -104
  96. package/lib/components/basic_table/default_item_action.js +23 -14
  97. package/lib/components/basic_table/in_memory_table.a11y.js +13 -11
  98. package/lib/components/basic_table/in_memory_table.js +8 -8
  99. package/lib/components/breadcrumbs/breadcrumb.js +11 -7
  100. package/lib/components/breadcrumbs/breadcrumb.styles.js +5 -0
  101. package/lib/components/button/button_display/_button_display.js +5 -3
  102. package/lib/components/button/button_display/_button_display_content.js +8 -4
  103. package/lib/components/button/button_empty/button_empty.js +9 -7
  104. package/lib/components/button/button_group/button_group.js +5 -3
  105. package/lib/components/button/button_group/button_group_button.js +5 -3
  106. package/lib/components/card/card.a11y.js +5 -18
  107. package/lib/components/collapsible_nav_beta/collapsible_nav_beta.styles.js +1 -1
  108. package/lib/components/collapsible_nav_beta/collapsible_nav_body_footer.js +4 -1
  109. package/lib/components/collapsible_nav_beta/collapsible_nav_body_footer.styles.js +12 -9
  110. package/lib/components/collapsible_nav_beta/collapsible_nav_group/collapsible_nav_group.js +1 -101
  111. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_button.js +20 -58
  112. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_item.js +89 -37
  113. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.js +66 -80
  114. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.styles.js +11 -28
  115. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.js +7 -104
  116. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.styles.js +4 -4
  117. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_group.js +7 -90
  118. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_item.js +150 -130
  119. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_link.js +0 -10
  120. package/lib/components/combo_box/combo_box.js +1 -1
  121. package/lib/components/context_menu/context_menu_item.js +16 -8
  122. package/lib/components/context_menu/context_menu_item.styles.js +1 -1
  123. package/lib/components/datagrid/body/data_grid_body.js +16 -6
  124. package/lib/components/datagrid/body/data_grid_body_custom.js +16 -6
  125. package/lib/components/datagrid/body/data_grid_body_virtualized.js +16 -6
  126. package/lib/components/datagrid/body/data_grid_cell.js +67 -44
  127. package/lib/components/datagrid/body/data_grid_cell_actions.js +12 -13
  128. package/lib/components/datagrid/body/data_grid_cell_popover.js +43 -10
  129. package/lib/components/datagrid/body/header/data_grid_header_cell.js +65 -34
  130. package/lib/components/datagrid/body/header/data_grid_header_row.js +16 -6
  131. package/lib/components/datagrid/controls/column_selector.js +19 -39
  132. package/lib/components/datagrid/controls/column_sorting.js +18 -30
  133. package/lib/components/datagrid/controls/data_grid_toolbar_control.js +159 -0
  134. package/lib/components/datagrid/controls/display_selector.js +0 -1
  135. package/lib/components/datagrid/controls/fullscreen_selector.js +2 -7
  136. package/lib/components/datagrid/controls/index.js +8 -1
  137. package/lib/components/datagrid/index.js +8 -1
  138. package/lib/components/datagrid/utils/in_memory.js +16 -6
  139. package/lib/components/datagrid/utils/row_heights.js +1 -1
  140. package/lib/components/date_picker/auto_refresh/auto_refresh.js +6 -4
  141. package/lib/components/date_picker/super_date_picker/super_update_button.js +1 -1
  142. package/lib/components/error_boundary/error_boundary.a11y.js +1 -1
  143. package/lib/components/expression/expression.a11y.js +2 -4
  144. package/lib/components/facet/facet_button.js +5 -3
  145. package/lib/components/filter_group/filter_button.js +2 -2
  146. package/lib/components/focus_trap/focus_trap.a11y.js +3 -3
  147. package/lib/components/form/range/range.a11y.js +5 -10
  148. package/lib/components/form/super_select/super_select.js +3 -2
  149. package/lib/components/form/super_select/super_select_control.js +12 -19
  150. package/lib/components/header/header.a11y.js +1 -1
  151. package/lib/components/header/header_links/header_link.js +7 -5
  152. package/lib/components/header/header_section/header_section_item_button.js +7 -5
  153. package/lib/components/image/image.a11y.js +1 -2
  154. package/lib/components/key_pad_menu/key_pad_menu.a11y.js +5 -5
  155. package/lib/components/link/external_link_icon.js +57 -0
  156. package/lib/components/link/link.js +6 -20
  157. package/lib/components/link/link.styles.js +1 -4
  158. package/lib/components/list_group/list_group.js +6 -1
  159. package/lib/components/list_group/list_group_item.js +14 -4
  160. package/lib/components/list_group/list_group_item.styles.js +2 -1
  161. package/lib/components/list_group/pinnable_list_group/pinnable_list_group.js +12 -2
  162. package/lib/components/notification/notification_event.a11y.js +1 -2
  163. package/lib/components/notification/notification_event.js +7 -5
  164. package/lib/components/popover/popover.js +4 -1
  165. package/lib/components/resizable_container/resizable_container.a11y.js +4 -8
  166. package/lib/components/search_bar/search_bar.a11y.js +3 -6
  167. package/lib/components/selectable/selectable.js +16 -1
  168. package/lib/components/selectable/selectable_list/selectable_list.js +227 -78
  169. package/lib/components/selectable/selectable_templates/selectable_template_sitewide.js +16 -1
  170. package/lib/components/text/text.styles.js +2 -2
  171. package/lib/components/text_truncate/text_truncate.js +32 -9
  172. package/optimize/es/components/accordion/accordion.a11y.js +1 -3
  173. package/optimize/es/components/basic_table/action_types.js +5 -0
  174. package/optimize/es/components/basic_table/basic_table.a11y.js +1 -2
  175. package/optimize/es/components/basic_table/collapsed_item_actions.js +116 -169
  176. package/optimize/es/components/basic_table/custom_item_action.js +10 -83
  177. package/optimize/es/components/basic_table/default_item_action.js +23 -14
  178. package/optimize/es/components/basic_table/in_memory_table.a11y.js +13 -11
  179. package/optimize/es/components/breadcrumbs/breadcrumb.js +11 -7
  180. package/optimize/es/components/breadcrumbs/breadcrumb.styles.js +5 -0
  181. package/optimize/es/components/button/button_display/_button_display_content.js +3 -1
  182. package/optimize/es/components/button/button_empty/button_empty.js +2 -2
  183. package/optimize/es/components/card/card.a11y.js +5 -18
  184. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_beta.styles.js +2 -2
  185. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_body_footer.js +4 -1
  186. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_body_footer.styles.js +12 -9
  187. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_button.js +1 -3
  188. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_item.js +10 -5
  189. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.js +8 -36
  190. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.styles.js +1 -19
  191. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.js +6 -23
  192. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.styles.js +4 -4
  193. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_group.js +6 -10
  194. package/optimize/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_item.js +9 -5
  195. package/optimize/es/components/context_menu/context_menu_item.js +9 -6
  196. package/optimize/es/components/context_menu/context_menu_item.styles.js +1 -1
  197. package/optimize/es/components/datagrid/body/data_grid_cell.js +38 -30
  198. package/optimize/es/components/datagrid/body/data_grid_cell_actions.js +12 -12
  199. package/optimize/es/components/datagrid/body/data_grid_cell_popover.js +43 -10
  200. package/optimize/es/components/datagrid/body/header/data_grid_header_cell.js +49 -28
  201. package/optimize/es/components/datagrid/controls/column_selector.js +19 -39
  202. package/optimize/es/components/datagrid/controls/column_sorting.js +18 -29
  203. package/optimize/es/components/datagrid/controls/data_grid_toolbar_control.js +70 -0
  204. package/optimize/es/components/datagrid/controls/display_selector.js +0 -1
  205. package/optimize/es/components/datagrid/controls/fullscreen_selector.js +2 -6
  206. package/optimize/es/components/datagrid/controls/index.js +2 -1
  207. package/optimize/es/components/datagrid/index.js +1 -1
  208. package/optimize/es/components/datagrid/utils/row_heights.js +1 -1
  209. package/optimize/es/components/date_picker/super_date_picker/super_update_button.js +1 -1
  210. package/optimize/es/components/error_boundary/error_boundary.a11y.js +1 -1
  211. package/optimize/es/components/expression/expression.a11y.js +2 -4
  212. package/optimize/es/components/filter_group/filter_button.js +2 -2
  213. package/optimize/es/components/focus_trap/focus_trap.a11y.js +3 -3
  214. package/optimize/es/components/form/range/range.a11y.js +5 -10
  215. package/optimize/es/components/form/super_select/super_select.js +3 -2
  216. package/optimize/es/components/form/super_select/super_select_control.js +13 -20
  217. package/optimize/es/components/header/header.a11y.js +1 -1
  218. package/optimize/es/components/image/image.a11y.js +1 -2
  219. package/optimize/es/components/key_pad_menu/key_pad_menu.a11y.js +5 -5
  220. package/optimize/es/components/link/external_link_icon.js +41 -0
  221. package/optimize/es/components/link/link.js +6 -20
  222. package/optimize/es/components/link/link.styles.js +2 -5
  223. package/optimize/es/components/list_group/list_group_item.js +8 -3
  224. package/optimize/es/components/list_group/list_group_item.styles.js +2 -1
  225. package/optimize/es/components/notification/notification_event.a11y.js +1 -2
  226. package/optimize/es/components/popover/popover.js +4 -1
  227. package/optimize/es/components/resizable_container/resizable_container.a11y.js +4 -8
  228. package/optimize/es/components/search_bar/search_bar.a11y.js +3 -6
  229. package/optimize/es/components/selectable/selectable_list/selectable_list.js +199 -76
  230. package/optimize/es/components/text/text.styles.js +2 -2
  231. package/optimize/es/components/text_truncate/text_truncate.js +26 -9
  232. package/optimize/lib/components/accordion/accordion.a11y.js +1 -3
  233. package/optimize/lib/components/basic_table/action_types.js +8 -2
  234. package/optimize/lib/components/basic_table/basic_table.a11y.js +1 -2
  235. package/optimize/lib/components/basic_table/collapsed_item_actions.js +123 -174
  236. package/optimize/lib/components/basic_table/custom_item_action.js +17 -91
  237. package/optimize/lib/components/basic_table/default_item_action.js +23 -14
  238. package/optimize/lib/components/basic_table/in_memory_table.a11y.js +13 -11
  239. package/optimize/lib/components/breadcrumbs/breadcrumb.js +11 -7
  240. package/optimize/lib/components/breadcrumbs/breadcrumb.styles.js +5 -0
  241. package/optimize/lib/components/button/button_display/_button_display_content.js +3 -1
  242. package/optimize/lib/components/button/button_empty/button_empty.js +2 -2
  243. package/optimize/lib/components/card/card.a11y.js +5 -18
  244. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_beta.styles.js +1 -1
  245. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_body_footer.js +4 -1
  246. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_body_footer.styles.js +12 -9
  247. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_button.js +1 -3
  248. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_item.js +10 -5
  249. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.js +8 -36
  250. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.styles.js +11 -28
  251. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.js +6 -26
  252. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.styles.js +4 -4
  253. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_group.js +6 -10
  254. package/optimize/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_item.js +9 -5
  255. package/optimize/lib/components/context_menu/context_menu_item.js +9 -6
  256. package/optimize/lib/components/context_menu/context_menu_item.styles.js +1 -1
  257. package/optimize/lib/components/datagrid/body/data_grid_cell.js +38 -30
  258. package/optimize/lib/components/datagrid/body/data_grid_cell_actions.js +12 -12
  259. package/optimize/lib/components/datagrid/body/data_grid_cell_popover.js +43 -10
  260. package/optimize/lib/components/datagrid/body/header/data_grid_header_cell.js +55 -36
  261. package/optimize/lib/components/datagrid/controls/column_selector.js +19 -39
  262. package/optimize/lib/components/datagrid/controls/column_sorting.js +18 -29
  263. package/optimize/lib/components/datagrid/controls/data_grid_toolbar_control.js +75 -0
  264. package/optimize/lib/components/datagrid/controls/display_selector.js +0 -1
  265. package/optimize/lib/components/datagrid/controls/fullscreen_selector.js +2 -6
  266. package/optimize/lib/components/datagrid/controls/index.js +8 -1
  267. package/optimize/lib/components/datagrid/index.js +8 -1
  268. package/optimize/lib/components/datagrid/utils/row_heights.js +1 -1
  269. package/optimize/lib/components/date_picker/super_date_picker/super_update_button.js +1 -1
  270. package/optimize/lib/components/error_boundary/error_boundary.a11y.js +1 -1
  271. package/optimize/lib/components/expression/expression.a11y.js +2 -4
  272. package/optimize/lib/components/filter_group/filter_button.js +2 -2
  273. package/optimize/lib/components/focus_trap/focus_trap.a11y.js +3 -3
  274. package/optimize/lib/components/form/range/range.a11y.js +5 -10
  275. package/optimize/lib/components/form/super_select/super_select.js +3 -2
  276. package/optimize/lib/components/form/super_select/super_select_control.js +12 -19
  277. package/optimize/lib/components/header/header.a11y.js +1 -1
  278. package/optimize/lib/components/image/image.a11y.js +1 -2
  279. package/optimize/lib/components/key_pad_menu/key_pad_menu.a11y.js +5 -5
  280. package/optimize/lib/components/link/external_link_icon.js +47 -0
  281. package/optimize/lib/components/link/link.js +6 -20
  282. package/optimize/lib/components/link/link.styles.js +1 -4
  283. package/optimize/lib/components/list_group/list_group_item.js +8 -3
  284. package/optimize/lib/components/list_group/list_group_item.styles.js +2 -1
  285. package/optimize/lib/components/notification/notification_event.a11y.js +1 -2
  286. package/optimize/lib/components/popover/popover.js +4 -1
  287. package/optimize/lib/components/resizable_container/resizable_container.a11y.js +4 -8
  288. package/optimize/lib/components/search_bar/search_bar.a11y.js +3 -6
  289. package/optimize/lib/components/selectable/selectable_list/selectable_list.js +199 -76
  290. package/optimize/lib/components/text/text.styles.js +2 -2
  291. package/optimize/lib/components/text_truncate/text_truncate.js +25 -8
  292. package/package.json +4 -4
  293. package/src/components/datagrid/_data_grid_data_row.scss +139 -100
  294. package/src/components/datagrid/_mixins.scss +2 -2
  295. package/src/components/datagrid/body/header/_data_grid_header_row.scss +36 -28
  296. package/src/components/datagrid/controls/_data_grid_toolbar.scss +0 -5
  297. package/src/components/form/form_row/_form_row.scss +1 -1
  298. package/src/components/table/_responsive.scss +19 -0
  299. package/src/components/table/_table.scss +4 -9
  300. package/test-env/components/accordion/accordion.a11y.js +1 -3
  301. package/test-env/components/auto_sizer/auto_sizer.js +10 -3
  302. package/test-env/components/basic_table/action_types.js +8 -2
  303. package/test-env/components/basic_table/basic_table.a11y.js +1 -2
  304. package/test-env/components/basic_table/basic_table.js +8 -8
  305. package/test-env/components/basic_table/collapsed_item_actions.js +124 -251
  306. package/test-env/components/basic_table/custom_item_action.js +18 -100
  307. package/test-env/components/basic_table/default_item_action.js +23 -14
  308. package/test-env/components/basic_table/in_memory_table.a11y.js +13 -11
  309. package/test-env/components/basic_table/in_memory_table.js +8 -8
  310. package/test-env/components/breadcrumbs/breadcrumb.js +11 -7
  311. package/test-env/components/breadcrumbs/breadcrumb.styles.js +5 -0
  312. package/test-env/components/button/button_display/_button_display.js +5 -3
  313. package/test-env/components/button/button_display/_button_display_content.js +8 -4
  314. package/test-env/components/button/button_empty/button_empty.js +9 -7
  315. package/test-env/components/button/button_group/button_group.js +5 -3
  316. package/test-env/components/button/button_group/button_group_button.js +5 -3
  317. package/test-env/components/card/card.a11y.js +5 -18
  318. package/test-env/components/collapsible_nav_beta/collapsible_nav_beta.styles.js +1 -1
  319. package/test-env/components/collapsible_nav_beta/collapsible_nav_body_footer.js +4 -1
  320. package/test-env/components/collapsible_nav_beta/collapsible_nav_body_footer.styles.js +12 -9
  321. package/test-env/components/collapsible_nav_beta/collapsible_nav_group/collapsible_nav_group.js +1 -101
  322. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_button.js +20 -58
  323. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_item.js +89 -37
  324. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.js +66 -80
  325. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.styles.js +11 -28
  326. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.js +7 -105
  327. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_accordion.styles.js +4 -4
  328. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_group.js +7 -90
  329. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_item.js +150 -130
  330. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_link.js +0 -10
  331. package/test-env/components/combo_box/combo_box.js +1 -1
  332. package/test-env/components/context_menu/context_menu_item.js +16 -8
  333. package/test-env/components/context_menu/context_menu_item.styles.js +1 -1
  334. package/test-env/components/datagrid/body/data_grid_body.js +16 -6
  335. package/test-env/components/datagrid/body/data_grid_body_custom.js +16 -6
  336. package/test-env/components/datagrid/body/data_grid_body_virtualized.js +16 -6
  337. package/test-env/components/datagrid/body/data_grid_cell.js +67 -44
  338. package/test-env/components/datagrid/body/data_grid_cell_actions.js +12 -12
  339. package/test-env/components/datagrid/body/data_grid_cell_popover.js +43 -10
  340. package/test-env/components/datagrid/body/header/data_grid_header_cell.js +71 -42
  341. package/test-env/components/datagrid/body/header/data_grid_header_row.js +16 -6
  342. package/test-env/components/datagrid/controls/column_selector.js +19 -39
  343. package/test-env/components/datagrid/controls/column_sorting.js +18 -29
  344. package/test-env/components/datagrid/controls/data_grid_toolbar_control.js +158 -0
  345. package/test-env/components/datagrid/controls/display_selector.js +0 -1
  346. package/test-env/components/datagrid/controls/fullscreen_selector.js +2 -6
  347. package/test-env/components/datagrid/controls/index.js +8 -1
  348. package/test-env/components/datagrid/index.js +8 -1
  349. package/test-env/components/datagrid/utils/in_memory.js +16 -6
  350. package/test-env/components/datagrid/utils/row_heights.js +1 -1
  351. package/test-env/components/date_picker/auto_refresh/auto_refresh.js +6 -4
  352. package/test-env/components/date_picker/super_date_picker/super_update_button.js +1 -1
  353. package/test-env/components/error_boundary/error_boundary.a11y.js +1 -1
  354. package/test-env/components/expression/expression.a11y.js +2 -4
  355. package/test-env/components/facet/facet_button.js +5 -3
  356. package/test-env/components/filter_group/filter_button.js +2 -2
  357. package/test-env/components/focus_trap/focus_trap.a11y.js +3 -3
  358. package/test-env/components/form/range/range.a11y.js +5 -10
  359. package/test-env/components/form/super_select/super_select.js +3 -2
  360. package/test-env/components/form/super_select/super_select_control.js +12 -19
  361. package/test-env/components/header/header.a11y.js +1 -1
  362. package/test-env/components/header/header_links/header_link.js +7 -5
  363. package/test-env/components/header/header_section/header_section_item_button.js +7 -5
  364. package/test-env/components/image/image.a11y.js +1 -2
  365. package/test-env/components/key_pad_menu/key_pad_menu.a11y.js +5 -5
  366. package/test-env/components/link/external_link_icon.js +56 -0
  367. package/test-env/components/link/link.js +6 -20
  368. package/test-env/components/link/link.styles.js +1 -4
  369. package/test-env/components/list_group/list_group.js +6 -1
  370. package/test-env/components/list_group/list_group_item.js +14 -4
  371. package/test-env/components/list_group/list_group_item.styles.js +2 -1
  372. package/test-env/components/list_group/pinnable_list_group/pinnable_list_group.js +12 -2
  373. package/test-env/components/notification/notification_event.a11y.js +1 -2
  374. package/test-env/components/notification/notification_event.js +7 -5
  375. package/test-env/components/popover/popover.js +4 -1
  376. package/test-env/components/resizable_container/resizable_container.a11y.js +4 -8
  377. package/test-env/components/search_bar/search_bar.a11y.js +3 -6
  378. package/test-env/components/selectable/selectable.js +16 -1
  379. package/test-env/components/selectable/selectable_list/selectable_list.js +227 -78
  380. package/test-env/components/selectable/selectable_templates/selectable_template_sitewide.js +16 -1
  381. package/test-env/components/text/text.styles.js +2 -2
  382. package/test-env/components/text_truncate/text_truncate.js +32 -9
@@ -12,7 +12,7 @@ var _collapsible_nav_item = require("./collapsible_nav_item");
12
12
  var _collapsible_nav_item2 = require("./collapsible_nav_item.styles");
13
13
  var _collapsible_nav_link = require("./collapsible_nav_link");
14
14
  var _react2 = require("@emotion/react");
15
- var _excluded = ["className", "header", "href", "items", "isSubItem", "isSelected", "linkProps", "children"];
15
+ var _excluded = ["className", "header", "items", "isSubItem", "isSelected", "children"];
16
16
  /*
17
17
  * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
18
18
  * or more contributor license agreements. Licensed under the Elastic License
@@ -35,11 +35,9 @@ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) r
35
35
  var EuiCollapsibleNavGroup = function EuiCollapsibleNavGroup(_ref) {
36
36
  var className = _ref.className,
37
37
  header = _ref.header,
38
- href = _ref.href,
39
38
  items = _ref.items,
40
39
  isSubItem = _ref.isSubItem,
41
40
  isSelected = _ref.isSelected,
42
- linkProps = _ref.linkProps,
43
41
  _children = _ref.children,
44
42
  rest = _objectWithoutProperties(_ref, _excluded);
45
43
  var classes = (0, _classnames.default)('euiCollapsibleNavGroup', className);
@@ -55,19 +53,17 @@ var EuiCollapsibleNavGroup = function EuiCollapsibleNavGroup(_ref) {
55
53
  var labelledById = (0, _services.useGeneratedHtmlId)();
56
54
  return (0, _react2.jsx)("div", _extends({
57
55
  className: classes
58
- }, cssStyles, rest), (0, _react2.jsx)(_collapsible_nav_link.EuiCollapsibleNavLink, _extends({
59
- href: href,
60
- id: labelledById
61
- }, linkProps, {
56
+ }, cssStyles, rest), (0, _react2.jsx)(_collapsible_nav_link.EuiCollapsibleNavLink, {
57
+ id: labelledById,
62
58
  isSelected: isSelected,
63
59
  isSubItem: isSubItem,
64
- isInteractive: !!(href || rest.onClick || linkProps !== null && linkProps !== void 0 && linkProps.onClick)
65
- }), header), (0, _react2.jsx)(_collapsible_nav_item.EuiCollapsibleNavSubItems, {
60
+ isInteractive: false
61
+ }, header), (0, _react2.jsx)(_collapsible_nav_item.EuiCollapsibleNavSubItems, {
66
62
  items: items,
67
63
  isSubItem: isSubItem,
68
64
  className: "euiCollapsibleNavGroup__children",
69
65
  role: "group",
70
- "aria-labelledby": (linkProps === null || linkProps === void 0 ? void 0 : linkProps.id) || labelledById
66
+ "aria-labelledby": labelledById
71
67
  }));
72
68
  };
73
69
  exports.EuiCollapsibleNavGroup = EuiCollapsibleNavGroup;
@@ -76,23 +72,6 @@ EuiCollapsibleNavGroup.propTypes = {
76
72
  "aria-label": _propTypes.default.string,
77
73
  "data-test-subj": _propTypes.default.string,
78
74
  css: _propTypes.default.any,
79
- /**
80
- * The nav item link.
81
- * If not included, and no `onClick` is specified, the nav item
82
- * will render as an non-interactive `<span>`.
83
- */
84
- href: _propTypes.default.string,
85
- /**
86
- * If set to false, will (visually) render an always-open accordion that cannot
87
- * be toggled closed. Ignored if `items` is not passed.
88
- *
89
- * @default true
90
- */
91
- isCollapsible: _propTypes.default.bool,
92
- /**
93
- * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
94
- */
95
- linkProps: _propTypes.default.any,
96
75
  /**
97
76
  * Highlights whether an item is currently selected, e.g.
98
77
  * if the user is on the same page as the nav link
@@ -103,67 +82,5 @@ EuiCollapsibleNavGroup.propTypes = {
103
82
  * or a nested nav subitem. Set internally by EUI
104
83
  */
105
84
  isSubItem: _propTypes.default.bool,
106
- header: _propTypes.default.node.isRequired,
107
- items: _propTypes.default.arrayOf(_propTypes.default.shape({
108
- /**
109
- * Required text to render as the nav item title
110
- */
111
- title: _propTypes.default.string,
112
- /**
113
- * Allows customizing the title element.
114
- * Consider using a heading element for better accessibility.
115
- * Defaults to an unsemantic `span` or `div`, depending on context.
116
- */
117
- titleElement: _propTypes.default.oneOf(["h2", "h3", "h4", "h5", "h6", "span", "div"]),
118
- /**
119
- * Optional icon to render to the left of title content
120
- */
121
- icon: _propTypes.default.oneOfType([_propTypes.default.oneOf(["accessibility", "addDataApp", "advancedSettingsApp", "agentApp", "aggregate", "analyzeEvent", "annotation", "apmApp", "apmTrace", "appSearchApp", "apps", "arrowDown", "arrowLeft", "arrowRight", "arrowUp", "arrowStart", "arrowEnd", "article", "asterisk", "at", "auditbeatApp", "beaker", "bell", "bellSlash", "beta", "bolt", "boxesHorizontal", "boxesVertical", "branch", "branchUser", "broom", "brush", "bug", "bullseye", "calendar", "canvasApp", "casesApp", "check", "checkInCircleFilled", "cheer", "classificationJob", "clock", "cloudDrizzle", "cloudStormy", "cloudSunny", "cluster", "codeApp", "color", "compute", "console", "consoleApp", "container", "continuityAbove", "continuityAboveBelow", "continuityBelow", "continuityWithin", "controlsHorizontal", "controlsVertical", "copy", "copyClipboard", "createAdvancedJob", "createMultiMetricJob", "createPopulationJob", "createSingleMetricJob", "cross", "crossClusterReplicationApp", "crosshairs", "currency", "cut", "dashboardApp", "dataVisualizer", "database", "desktop", "devToolsApp", "discoverApp", "discuss", "document", "documentEdit", "documentation", "documents", "dot", "dotInCircle", "doubleArrowLeft", "doubleArrowRight", "download", "editorAlignCenter", "editorAlignLeft", "editorAlignRight", "editorBold", "editorChecklist", "editorCodeBlock", "editorComment", "editorDistributeHorizontal", "editorDistributeVertical", "editorHeading", "editorItalic", "editorItemAlignBottom", "editorItemAlignCenter", "editorItemAlignLeft", "editorItemAlignMiddle", "editorItemAlignRight", "editorItemAlignTop", "editorLink", "editorOrderedList", "editorPositionBottomLeft", "editorPositionBottomRight", "editorPositionTopLeft", "editorPositionTopRight", "editorRedo", "editorStrike", "editorTable", "editorUnderline", "editorUndo", "editorUnorderedList", "email", "empty", "emsApp", "eql", "eraser", "error", "exit", "expand", "expandMini", "exportAction", "eye", "eyeClosed", "faceHappy", "faceNeutral", "faceSad", "filebeatApp", "filter", "filterExclude", "filterIgnore", "filterInclude", "filterInCircle", "flag", "fleetApp", "fold", "folderCheck", "folderClosed", "folderExclamation", "folderOpen", "frameNext", "framePrevious", "fullScreen", "fullScreenExit", "function", "gear", "gisApp", "glasses", "globe", "grab", "grabHorizontal", "grabOmnidirectional", "gradient", "graphApp", "grid", "grokApp", "heart", "heartbeatApp", "heatmap", "help", "home", "iInCircle", "image", "importAction", "indexClose", "indexEdit", "indexFlush", "indexManagementApp", "indexMapping", "indexOpen", "indexPatternApp", "indexRollupApp", "indexRuntime", "indexSettings", "indexTemporary", "infinity", "inputOutput", "inspect", "invert", "ip", "key", "keyboard", "kqlField", "kqlFunction", "kqlOperand", "kqlSelector", "kqlValue", "kubernetesNode", "kubernetesPod", "launch", "layers", "lensApp", "lettering", "lineDashed", "lineDotted", "lineSolid", "link", "list", "listAdd", "lock", "lockOpen", "logoAWS", "logoAWSMono", "logoAerospike", "logoApache", "logoAppSearch", "logoAzure", "logoAzureMono", "logoBeats", "logoBusinessAnalytics", "logoCeph", "logoCloud", "logoCloudEnterprise", "logoCode", "logoCodesandbox", "logoCouchbase", "logoDocker", "logoDropwizard", "logoElastic", "logoElasticStack", "logoElasticsearch", "logoEnterpriseSearch", "logoEtcd", "logoGCP", "logoGCPMono", "logoGithub", "logoGmail", "logoGolang", "logoGoogleG", "logoHAproxy", "logoIBM", "logoIBMMono", "logoKafka", "logoKibana", "logoKubernetes", "logoLogging", "logoLogstash", "logoMaps", "logoMemcached", "logoMetrics", "logoMongodb", "logoMySQL", "logoNginx", "logoObservability", "logoOsquery", "logoPhp", "logoPostgres", "logoPrometheus", "logoRabbitmq", "logoRedis", "logoSecurity", "logoSiteSearch", "logoSketch", "logoSlack", "logoUptime", "logoVulnerabilityManagement", "logoWebhook", "logoWindows", "logoWorkplaceSearch", "logsApp", "logstashFilter", "logstashIf", "logstashInput", "logstashOutput", "logstashQueue", "machineLearningApp", "magnet", "magnifyWithExclamation", "magnifyWithMinus", "magnifyWithPlus", "managementApp", "mapMarker", "memory", "menu", "menuDown", "menuLeft", "menuRight", "menuUp", "merge", "metricbeatApp", "metricsApp", "minimize", "minus", "minusInCircle", "minusInCircleFilled", "mobile", "monitoringApp", "moon", "namespace", "nested", "node", "notebookApp", "number", "offline", "online", "outlierDetectionJob", "package", "packetbeatApp", "pageSelect", "pagesSelect", "palette", "paperClip", "partial", "pause", "payment", "pencil", "percent", "pin", "pinFilled", "pipelineApp", "pivot", "play", "playFilled", "plus", "plusInCircle", "plusInCircleFilled", "popout", "push", "questionInCircle", "quote", "recentlyViewedApp", "refresh", "regressionJob", "reporter", "reportingApp", "returnKey", "save", "savedObjectsApp", "scale", "search", "searchProfilerApp", "securityAnalyticsApp", "securityApp", "securitySignal", "securitySignalDetected", "securitySignalResolved", "sessionViewer", "shard", "share", "snowflake", "sortAscending", "sortDescending", "sortDown", "sortLeft", "sortRight", "sortUp", "sortable", "spaces", "spacesApp", "sparkles", "sqlApp", "starEmpty", "starEmptySpace", "starFilled", "starFilledSpace", "starMinusEmpty", "starMinusFilled", "starPlusEmpty", "starPlusFilled", "stats", "stop", "stopFilled", "stopSlash", "storage", "string", "submodule", "sun", "swatchInput", "symlink", "tableDensityCompact", "tableDensityExpanded", "tableDensityNormal", "tableOfContents", "tag", "tear", "temperature", "timeline", "timelineWithArrow", "timelionApp", "timeRefresh", "timeslider", "training", "transitionLeftIn", "transitionLeftOut", "transitionTopIn", "transitionTopOut", "trash", "unfold", "unlink", "upgradeAssistantApp", "uptimeApp", "user", "userAvatar", "users", "usersRolesApp", "vector", "videoPlayer", "visArea", "visAreaStacked", "visBarHorizontal", "visBarHorizontalStacked", "visBarVertical", "visBarVerticalStacked", "visGauge", "visGoal", "visLine", "visMapCoordinate", "visMapRegion", "visMetric", "visPie", "visTable", "visTagCloud", "visText", "visTimelion", "visVega", "visVisualBuilder", "visualizeApp", "vulnerabilityManagementApp", "warning", "alert", "watchesApp", "wordWrap", "wordWrapDisabled", "workplaceSearchApp", "wrench", "tokenAlias", "tokenAnnotation", "tokenArray", "tokenBinary", "tokenBoolean", "tokenClass", "tokenCompletionSuggester", "tokenConstant", "tokenDate", "tokenElement", "tokenEnum", "tokenEnumMember", "tokenEvent", "tokenException", "tokenField", "tokenFile", "tokenFlattened", "tokenFunction", "tokenGeo", "tokenHistogram", "tokenInterface", "tokenIP", "tokenJoin", "tokenKey", "tokenKeyword", "tokenMethod", "tokenMetricCounter", "tokenMetricGauge", "tokenModule", "tokenNamespace", "tokenNested", "tokenNull", "tokenNumber", "tokenObject", "tokenOperator", "tokenPackage", "tokenParameter", "tokenPercolator", "tokenProperty", "tokenRange", "tokenRankFeature", "tokenRankFeatures", "tokenRepo", "tokenSearchType", "tokenShape", "tokenString", "tokenStruct", "tokenSymbol", "tokenTag", "tokenText", "tokenTokenCount", "tokenVariable", "tokenVectorDense", "tokenDenseVector", "tokenVectorSparse"]).isRequired, _propTypes.default.string.isRequired, _propTypes.default.elementType.isRequired]),
122
- /**
123
- * Optional props to pass to the title icon
124
- */
125
- iconProps: _propTypes.default.any,
126
- className: _propTypes.default.string,
127
- "aria-label": _propTypes.default.string,
128
- "data-test-subj": _propTypes.default.string,
129
- css: _propTypes.default.any,
130
- /**
131
- * The nav item link.
132
- * If not included, and no `onClick` is specified, the nav item
133
- * will render as an non-interactive `<span>`.
134
- */
135
- href: _propTypes.default.string,
136
- /**
137
- * Will render either an accordion or group of nested child item links.
138
- *
139
- * Accepts any #EuiCollapsibleNavItemProps. Or, to render completely custom
140
- * subitem content, pass an object with a `renderItem` callback.
141
- */
142
- items: _propTypes.default.arrayOf(_propTypes.default.shape({
143
- renderItem: _propTypes.default.func
144
- }).isRequired),
145
- /**
146
- * If set to false, will (visually) render an always-open accordion that cannot
147
- * be toggled closed. Ignored if `items` is not passed.
148
- *
149
- * @default true
150
- */
151
- isCollapsible: _propTypes.default.bool,
152
- /**
153
- * If `items` is specified, and `isCollapsible` is not set to false, you may
154
- * use this prop to pass any prop that `EuiAccordion` accepts, including props
155
- * that control the toggled state of the accordion (e.g. `initialIsOpen`, `forceState`)
156
- */
157
- accordionProps: _propTypes.default.any,
158
- /**
159
- * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
160
- */
161
- linkProps: _propTypes.default.any,
162
- /**
163
- * Highlights whether an item is currently selected, e.g.
164
- * if the user is on the same page as the nav link
165
- */
166
- isSelected: _propTypes.default.bool,
167
- renderItem: _propTypes.default.func
168
- }).isRequired).isRequired
85
+ header: _propTypes.default.node.isRequired
169
86
  };
@@ -17,7 +17,7 @@ var _collapsible_nav_group = require("./collapsible_nav_group");
17
17
  var _collapsible_nav_link = require("./collapsible_nav_link");
18
18
  var _collapsible_nav_item = require("./collapsible_nav_item.styles");
19
19
  var _react2 = require("@emotion/react");
20
- var _excluded = ["isSubItem", "title", "titleElement", "icon", "iconProps", "items", "isCollapsible", "accordionProps", "children"],
20
+ var _excluded = ["isSubItem", "title", "titleElement", "icon", "iconProps", "href", "linkProps", "items", "isCollapsible", "accordionProps", "children"],
21
21
  _excluded2 = ["renderItem", "className"],
22
22
  _excluded3 = ["items", "isSubItem", "isGroup", "className"],
23
23
  _excluded4 = ["className"];
@@ -40,12 +40,13 @@ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) r
40
40
  * determine whether to render an accordion or a link
41
41
  */
42
42
  var EuiCollapsibleNavItemDisplay = function EuiCollapsibleNavItemDisplay(_ref) {
43
- var _props$linkProps;
44
43
  var isSubItem = _ref.isSubItem,
45
44
  title = _ref.title,
46
45
  titleElement = _ref.titleElement,
47
46
  icon = _ref.icon,
48
47
  iconProps = _ref.iconProps,
48
+ href = _ref.href,
49
+ linkProps = _ref.linkProps,
49
50
  items = _ref.items,
50
51
  _ref$isCollapsible = _ref.isCollapsible,
51
52
  isCollapsible = _ref$isCollapsible === void 0 ? true : _ref$isCollapsible,
@@ -58,7 +59,7 @@ var EuiCollapsibleNavItemDisplay = function EuiCollapsibleNavItemDisplay(_ref) {
58
59
  icon: icon,
59
60
  iconProps: iconProps
60
61
  });
61
- if (items && items.length > 0) {
62
+ if (items) {
62
63
  if (isCollapsible) {
63
64
  return (0, _react2.jsx)(_collapsible_nav_accordion.EuiCollapsibleNavAccordion, _extends({
64
65
  buttonContent: headerContent,
@@ -76,11 +77,14 @@ var EuiCollapsibleNavItemDisplay = function EuiCollapsibleNavItemDisplay(_ref) {
76
77
  }));
77
78
  }
78
79
  }
79
- return (0, _react2.jsx)(_collapsible_nav_link.EuiCollapsibleNavLink, _extends({}, props, {
80
+ return (0, _react2.jsx)(_collapsible_nav_link.EuiCollapsibleNavLink, _extends({
81
+ href: href,
82
+ linkProps: linkProps
83
+ }, props, {
80
84
  // EuiLink ExclusiveUnion type shenanigans
81
85
  isSubItem: isSubItem,
82
86
  isNotAccordion: true,
83
- isInteractive: !!(props.href || props.onClick || (_props$linkProps = props.linkProps) !== null && _props$linkProps !== void 0 && _props$linkProps.onClick)
87
+ isInteractive: !!(href || props.onClick || linkProps !== null && linkProps !== void 0 && linkProps.onClick)
84
88
  }), headerContent);
85
89
  };
86
90
 
@@ -88,6 +92,15 @@ var EuiCollapsibleNavItemDisplay = function EuiCollapsibleNavItemDisplay(_ref) {
88
92
  * Internal subcomponent for title display
89
93
  */
90
94
  EuiCollapsibleNavItemDisplay.propTypes = {
95
+ className: _propTypes.default.string,
96
+ "aria-label": _propTypes.default.string,
97
+ "data-test-subj": _propTypes.default.string,
98
+ css: _propTypes.default.any,
99
+ /**
100
+ * Highlights whether an item is currently selected, e.g.
101
+ * if the user is on the same page as the nav link
102
+ */
103
+ isSelected: _propTypes.default.bool,
91
104
  /**
92
105
  * Required text to render as the nav item title
93
106
  */
@@ -106,47 +119,42 @@ EuiCollapsibleNavItemDisplay.propTypes = {
106
119
  * Optional props to pass to the title icon
107
120
  */
108
121
  iconProps: _propTypes.default.any,
109
- className: _propTypes.default.string,
110
- "aria-label": _propTypes.default.string,
111
- "data-test-subj": _propTypes.default.string,
112
- css: _propTypes.default.any,
113
122
  /**
114
- * The nav item link.
115
- * If not included, and no `onClick` is specified, the nav item
116
- * will render as an non-interactive `<span>`.
117
- */
123
+ * The nav item link.
124
+ *
125
+ * If not included, and no `onClick` is specified, the nav item
126
+ * will render as an non-interactive `<span>`.
127
+ *
128
+ * Should not be used together with `items`, as the title will
129
+ * trigger the accordion collapse/expand action instead of a link.
130
+ */
118
131
  href: _propTypes.default.string,
119
132
  /**
120
- * Will render either an accordion or group of nested child item links.
121
- *
122
- * Accepts any #EuiCollapsibleNavItemProps. Or, to render completely custom
123
- * subitem content, pass an object with a `renderItem` callback.
124
- */
133
+ * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
134
+ */
135
+ linkProps: _propTypes.default.any,
136
+ /**
137
+ * Will render either an accordion or group of nested child item links.
138
+ *
139
+ * Accepts any #EuiCollapsibleNavItemProps. Or, to render completely custom
140
+ * subitem content, pass an object with a `renderItem` callback.
141
+ */
125
142
  items: _propTypes.default.arrayOf(_propTypes.default.shape({
126
143
  renderItem: _propTypes.default.func
127
144
  }).isRequired),
128
145
  /**
129
- * If set to false, will (visually) render an always-open accordion that cannot
130
- * be toggled closed. Ignored if `items` is not passed.
131
- *
132
- * @default true
133
- */
146
+ * If set to false, will (visually) render an always-open accordion that cannot
147
+ * be toggled closed. Ignored if `items` is not passed.
148
+ *
149
+ * @default true
150
+ */
134
151
  isCollapsible: _propTypes.default.bool,
135
152
  /**
136
- * If `items` is specified, and `isCollapsible` is not set to false, you may
137
- * use this prop to pass any prop that `EuiAccordion` accepts, including props
138
- * that control the toggled state of the accordion (e.g. `initialIsOpen`, `forceState`)
139
- */
153
+ * If `items` is specified, and `isCollapsible` is not set to false, you may
154
+ * use this prop to pass any prop that `EuiAccordion` accepts, including props
155
+ * that control the toggled state of the accordion (e.g. `initialIsOpen`, `forceState`)
156
+ */
140
157
  accordionProps: _propTypes.default.any,
141
- /**
142
- * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
143
- */
144
- linkProps: _propTypes.default.any,
145
- /**
146
- * Highlights whether an item is currently selected, e.g.
147
- * if the user is on the same page as the nav link
148
- */
149
- isSelected: _propTypes.default.bool,
150
158
  /**
151
159
  * Determines whether the item should render as a top-level nav item
152
160
  * or a nested nav subitem. Set internally by EUI
@@ -195,6 +203,15 @@ var EuiCollapsibleNavSubItem = function EuiCollapsibleNavSubItem(_ref3) {
195
203
  */
196
204
  exports.EuiCollapsibleNavSubItem = EuiCollapsibleNavSubItem;
197
205
  EuiCollapsibleNavSubItem.propTypes = {
206
+ className: _propTypes.default.string,
207
+ "aria-label": _propTypes.default.string,
208
+ "data-test-subj": _propTypes.default.string,
209
+ css: _propTypes.default.any,
210
+ /**
211
+ * Highlights whether an item is currently selected, e.g.
212
+ * if the user is on the same page as the nav link
213
+ */
214
+ isSelected: _propTypes.default.bool,
198
215
  /**
199
216
  * Required text to render as the nav item title
200
217
  */
@@ -213,45 +230,40 @@ EuiCollapsibleNavSubItem.propTypes = {
213
230
  * Optional props to pass to the title icon
214
231
  */
215
232
  iconProps: _propTypes.default.any,
216
- className: _propTypes.default.string,
217
- "aria-label": _propTypes.default.string,
218
- "data-test-subj": _propTypes.default.string,
219
- css: _propTypes.default.any,
220
233
  /**
221
- * The nav item link.
222
- * If not included, and no `onClick` is specified, the nav item
223
- * will render as an non-interactive `<span>`.
224
- */
234
+ * The nav item link.
235
+ *
236
+ * If not included, and no `onClick` is specified, the nav item
237
+ * will render as an non-interactive `<span>`.
238
+ *
239
+ * Should not be used together with `items`, as the title will
240
+ * trigger the accordion collapse/expand action instead of a link.
241
+ */
225
242
  href: _propTypes.default.string,
226
243
  /**
227
- * Will render either an accordion or group of nested child item links.
228
- *
229
- * Accepts any #EuiCollapsibleNavItemProps. Or, to render completely custom
230
- * subitem content, pass an object with a `renderItem` callback.
231
- */
244
+ * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
245
+ */
246
+ linkProps: _propTypes.default.any,
247
+ /**
248
+ * Will render either an accordion or group of nested child item links.
249
+ *
250
+ * Accepts any #EuiCollapsibleNavItemProps. Or, to render completely custom
251
+ * subitem content, pass an object with a `renderItem` callback.
252
+ */
232
253
  items: _propTypes.default.arrayOf(_propTypes.default.any.isRequired),
233
254
  /**
234
- * If set to false, will (visually) render an always-open accordion that cannot
235
- * be toggled closed. Ignored if `items` is not passed.
236
- *
237
- * @default true
238
- */
255
+ * If set to false, will (visually) render an always-open accordion that cannot
256
+ * be toggled closed. Ignored if `items` is not passed.
257
+ *
258
+ * @default true
259
+ */
239
260
  isCollapsible: _propTypes.default.bool,
240
261
  /**
241
- * If `items` is specified, and `isCollapsible` is not set to false, you may
242
- * use this prop to pass any prop that `EuiAccordion` accepts, including props
243
- * that control the toggled state of the accordion (e.g. `initialIsOpen`, `forceState`)
244
- */
262
+ * If `items` is specified, and `isCollapsible` is not set to false, you may
263
+ * use this prop to pass any prop that `EuiAccordion` accepts, including props
264
+ * that control the toggled state of the accordion (e.g. `initialIsOpen`, `forceState`)
265
+ */
245
266
  accordionProps: _propTypes.default.any,
246
- /**
247
- * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
248
- */
249
- linkProps: _propTypes.default.any,
250
- /**
251
- * Highlights whether an item is currently selected, e.g.
252
- * if the user is on the same page as the nav link
253
- */
254
- isSelected: _propTypes.default.bool,
255
267
  renderItem: _propTypes.default.func
256
268
  };
257
269
  var EuiCollapsibleNavSubItems = function EuiCollapsibleNavSubItems(_ref4) {
@@ -300,6 +312,15 @@ EuiCollapsibleNavSubItems.propTypes = {
300
312
  */
301
313
  isSubItem: _propTypes.default.bool,
302
314
  items: _propTypes.default.arrayOf(_propTypes.default.shape({
315
+ className: _propTypes.default.string,
316
+ "aria-label": _propTypes.default.string,
317
+ "data-test-subj": _propTypes.default.string,
318
+ css: _propTypes.default.any,
319
+ /**
320
+ * Highlights whether an item is currently selected, e.g.
321
+ * if the user is on the same page as the nav link
322
+ */
323
+ isSelected: _propTypes.default.bool,
303
324
  /**
304
325
  * Required text to render as the nav item title
305
326
  */
@@ -318,45 +339,40 @@ EuiCollapsibleNavSubItems.propTypes = {
318
339
  * Optional props to pass to the title icon
319
340
  */
320
341
  iconProps: _propTypes.default.any,
321
- className: _propTypes.default.string,
322
- "aria-label": _propTypes.default.string,
323
- "data-test-subj": _propTypes.default.string,
324
- css: _propTypes.default.any,
325
342
  /**
326
- * The nav item link.
327
- * If not included, and no `onClick` is specified, the nav item
328
- * will render as an non-interactive `<span>`.
329
- */
343
+ * The nav item link.
344
+ *
345
+ * If not included, and no `onClick` is specified, the nav item
346
+ * will render as an non-interactive `<span>`.
347
+ *
348
+ * Should not be used together with `items`, as the title will
349
+ * trigger the accordion collapse/expand action instead of a link.
350
+ */
330
351
  href: _propTypes.default.string,
331
352
  /**
332
- * Will render either an accordion or group of nested child item links.
333
- *
334
- * Accepts any #EuiCollapsibleNavItemProps. Or, to render completely custom
335
- * subitem content, pass an object with a `renderItem` callback.
336
- */
353
+ * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
354
+ */
355
+ linkProps: _propTypes.default.any,
356
+ /**
357
+ * Will render either an accordion or group of nested child item links.
358
+ *
359
+ * Accepts any #EuiCollapsibleNavItemProps. Or, to render completely custom
360
+ * subitem content, pass an object with a `renderItem` callback.
361
+ */
337
362
  items: _propTypes.default.arrayOf(_propTypes.default.any.isRequired),
338
363
  /**
339
- * If set to false, will (visually) render an always-open accordion that cannot
340
- * be toggled closed. Ignored if `items` is not passed.
341
- *
342
- * @default true
343
- */
364
+ * If set to false, will (visually) render an always-open accordion that cannot
365
+ * be toggled closed. Ignored if `items` is not passed.
366
+ *
367
+ * @default true
368
+ */
344
369
  isCollapsible: _propTypes.default.bool,
345
370
  /**
346
- * If `items` is specified, and `isCollapsible` is not set to false, you may
347
- * use this prop to pass any prop that `EuiAccordion` accepts, including props
348
- * that control the toggled state of the accordion (e.g. `initialIsOpen`, `forceState`)
349
- */
371
+ * If `items` is specified, and `isCollapsible` is not set to false, you may
372
+ * use this prop to pass any prop that `EuiAccordion` accepts, including props
373
+ * that control the toggled state of the accordion (e.g. `initialIsOpen`, `forceState`)
374
+ */
350
375
  accordionProps: _propTypes.default.any,
351
- /**
352
- * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
353
- */
354
- linkProps: _propTypes.default.any,
355
- /**
356
- * Highlights whether an item is currently selected, e.g.
357
- * if the user is on the same page as the nav link
358
- */
359
- isSelected: _propTypes.default.bool,
360
376
  renderItem: _propTypes.default.func
361
377
  }).isRequired).isRequired,
362
378
  isGroup: _propTypes.default.bool
@@ -378,6 +394,15 @@ var EuiCollapsibleNavItem = function EuiCollapsibleNavItem(_ref5) {
378
394
  };
379
395
  exports.EuiCollapsibleNavItem = EuiCollapsibleNavItem;
380
396
  EuiCollapsibleNavItem.propTypes = {
397
+ className: _propTypes.default.string,
398
+ "aria-label": _propTypes.default.string,
399
+ "data-test-subj": _propTypes.default.string,
400
+ css: _propTypes.default.any,
401
+ /**
402
+ * Highlights whether an item is currently selected, e.g.
403
+ * if the user is on the same page as the nav link
404
+ */
405
+ isSelected: _propTypes.default.bool,
381
406
  /**
382
407
  * Required text to render as the nav item title
383
408
  */
@@ -396,45 +421,40 @@ EuiCollapsibleNavItem.propTypes = {
396
421
  * Optional props to pass to the title icon
397
422
  */
398
423
  iconProps: _propTypes.default.any,
399
- className: _propTypes.default.string,
400
- "aria-label": _propTypes.default.string,
401
- "data-test-subj": _propTypes.default.string,
402
- css: _propTypes.default.any,
403
424
  /**
404
- * The nav item link.
405
- * If not included, and no `onClick` is specified, the nav item
406
- * will render as an non-interactive `<span>`.
407
- */
425
+ * The nav item link.
426
+ *
427
+ * If not included, and no `onClick` is specified, the nav item
428
+ * will render as an non-interactive `<span>`.
429
+ *
430
+ * Should not be used together with `items`, as the title will
431
+ * trigger the accordion collapse/expand action instead of a link.
432
+ */
408
433
  href: _propTypes.default.string,
409
434
  /**
410
- * Will render either an accordion or group of nested child item links.
411
- *
412
- * Accepts any #EuiCollapsibleNavItemProps. Or, to render completely custom
413
- * subitem content, pass an object with a `renderItem` callback.
414
- */
435
+ * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
436
+ */
437
+ linkProps: _propTypes.default.any,
438
+ /**
439
+ * Will render either an accordion or group of nested child item links.
440
+ *
441
+ * Accepts any #EuiCollapsibleNavItemProps. Or, to render completely custom
442
+ * subitem content, pass an object with a `renderItem` callback.
443
+ */
415
444
  items: _propTypes.default.arrayOf(_propTypes.default.shape({
416
445
  renderItem: _propTypes.default.func
417
446
  }).isRequired),
418
447
  /**
419
- * If set to false, will (visually) render an always-open accordion that cannot
420
- * be toggled closed. Ignored if `items` is not passed.
421
- *
422
- * @default true
423
- */
448
+ * If set to false, will (visually) render an always-open accordion that cannot
449
+ * be toggled closed. Ignored if `items` is not passed.
450
+ *
451
+ * @default true
452
+ */
424
453
  isCollapsible: _propTypes.default.bool,
425
454
  /**
426
- * If `items` is specified, and `isCollapsible` is not set to false, you may
427
- * use this prop to pass any prop that `EuiAccordion` accepts, including props
428
- * that control the toggled state of the accordion (e.g. `initialIsOpen`, `forceState`)
429
- */
430
- accordionProps: _propTypes.default.any,
431
- /**
432
- * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
433
- */
434
- linkProps: _propTypes.default.any,
435
- /**
436
- * Highlights whether an item is currently selected, e.g.
437
- * if the user is on the same page as the nav link
438
- */
439
- isSelected: _propTypes.default.bool
455
+ * If `items` is specified, and `isCollapsible` is not set to false, you may
456
+ * use this prop to pass any prop that `EuiAccordion` accepts, including props
457
+ * that control the toggled state of the accordion (e.g. `initialIsOpen`, `forceState`)
458
+ */
459
+ accordionProps: _propTypes.default.any
440
460
  };
@@ -74,16 +74,6 @@ EuiCollapsibleNavLink.propTypes = {
74
74
  "aria-label": _propTypes.default.string,
75
75
  "data-test-subj": _propTypes.default.string,
76
76
  css: _propTypes.default.any,
77
- /**
78
- * The nav item link.
79
- * If not included, and no `onClick` is specified, the nav item
80
- * will render as an non-interactive `<span>`.
81
- */
82
- href: _propTypes.default.string,
83
- /**
84
- * If a `href` is specified, use this prop to pass any prop that `EuiLink` accepts
85
- */
86
- linkProps: _propTypes.default.any,
87
77
  /**
88
78
  * Highlights whether an item is currently selected, e.g.
89
79
  * if the user is on the same page as the nav link
@@ -737,7 +737,7 @@ EuiComboBox.propTypes = {
737
737
  /**
738
738
  * By default, EuiComboBox will truncate option labels at the end of
739
739
  * the string. You can use pass in a custom truncation configuration that
740
- * accepts any prop that [EuiTextTruncate](/#/utilities/text-truncate) prop
740
+ * accepts any [EuiTextTruncate](/#/utilities/text-truncation) prop,
741
741
  * except for `text` and `children`.
742
742
  *
743
743
  * Note: when searching, custom truncation props are ignored. The highlighted search
@@ -14,7 +14,7 @@ var _icon = require("../icon");
14
14
  var _tool_tip = require("../tool_tip");
15
15
  var _context_menu_item = require("./context_menu_item.styles");
16
16
  var _react2 = require("@emotion/react");
17
- var _excluded = ["children", "className", "hasPanel", "icon", "buttonRef", "disabled", "layoutAlign", "toolTipTitle", "toolTipContent", "toolTipPosition", "href", "target", "rel", "size"];
17
+ var _excluded = ["children", "className", "hasPanel", "icon", "buttonRef", "disabled", "layoutAlign", "toolTipTitle", "toolTipContent", "toolTipPosition", "toolTipProps", "href", "target", "rel", "size"];
18
18
  /*
19
19
  * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
20
20
  * or more contributor license agreements. Licensed under the Elastic License
@@ -48,6 +48,7 @@ var EuiContextMenuItem = function EuiContextMenuItem(_ref) {
48
48
  toolTipContent = _ref.toolTipContent,
49
49
  _ref$toolTipPosition = _ref.toolTipPosition,
50
50
  toolTipPosition = _ref$toolTipPosition === void 0 ? 'right' : _ref$toolTipPosition,
51
+ toolTipProps = _ref.toolTipProps,
51
52
  href = _ref.href,
52
53
  target = _ref.target,
53
54
  rel = _ref.rel,
@@ -99,7 +100,7 @@ var EuiContextMenuItem = function EuiContextMenuItem(_ref) {
99
100
  rel: secureRel,
100
101
  ref: buttonRef
101
102
  }, rest), buttonContent);
102
- } else if (href || rest.onClick) {
103
+ } else if (href || rest.onClick || toolTipContent) {
103
104
  button = (0, _react2.jsx)("button", _extends({
104
105
  disabled: disabled,
105
106
  css: cssStyles,
@@ -115,12 +116,14 @@ var EuiContextMenuItem = function EuiContextMenuItem(_ref) {
115
116
  }, rest), buttonContent);
116
117
  }
117
118
  if (toolTipContent) {
118
- return (0, _react2.jsx)(_tool_tip.EuiToolTip, {
119
+ var anchorClasses = (0, _classnames.default)('eui-displayBlock', toolTipProps === null || toolTipProps === void 0 ? void 0 : toolTipProps.anchorClassName);
120
+ return (0, _react2.jsx)(_tool_tip.EuiToolTip, _extends({
119
121
  title: toolTipTitle ? toolTipTitle : null,
120
- content: toolTipContent,
121
- anchorClassName: "eui-displayBlock",
122
122
  position: toolTipPosition
123
- }, button);
123
+ }, toolTipProps, {
124
+ anchorClassName: anchorClasses,
125
+ content: toolTipContent
126
+ }), button);
124
127
  } else {
125
128
  return button;
126
129
  }
@@ -141,11 +144,16 @@ EuiContextMenuItem.propTypes = {
141
144
  */
142
145
  toolTipContent: _propTypes.default.node,
143
146
  /**
144
- * Optional title for the tooltip
147
+ * Optional configuration to pass to the underlying [EuiToolTip](/#/display/tooltip).
148
+ * Accepts any prop that EuiToolTip does, except for `content` and `children`.
149
+ */
150
+ toolTipProps: _propTypes.default.any,
151
+ /**
152
+ * @deprecated Use toolTipProps.title instead
145
153
  */
146
154
  toolTipTitle: _propTypes.default.node,
147
155
  /**
148
- * Dictates the position of the tooltip.
156
+ * @deprecated Use tooltipProps.position instead
149
157
  */
150
158
  toolTipPosition: _propTypes.default.oneOf(["top", "right", "bottom", "left"]),
151
159
  href: _propTypes.default.string,