@elastic/eui 113.3.0 → 114.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 (358) hide show
  1. package/es/components/avatar/avatar.js +1 -1
  2. package/es/components/badge/badge.js +1 -1
  3. package/es/components/badge/beta_badge/beta_badge.js +1 -1
  4. package/es/components/basic_table/basic_table.js +4 -4
  5. package/es/components/basic_table/in_memory_table.js +4 -4
  6. package/es/components/button/button_display/_button_display_content.js +1 -1
  7. package/es/components/button/button_empty/button_empty.js +1 -1
  8. package/es/components/button/button_icon/button_icon.js +1 -1
  9. package/es/components/button/split_button/split_button.js +13 -0
  10. package/es/components/button/split_button/split_button_actions.js +15 -0
  11. package/es/components/call_out/call_out.js +1 -1
  12. package/es/components/card/card.js +1 -1
  13. package/es/components/collapsible_nav/collapsible_nav.js +6 -1
  14. package/es/components/collapsible_nav/collapsible_nav_group/collapsible_nav_group.js +1 -1
  15. package/es/components/collapsible_nav_beta/_kibana_solution/collapsible_nav_kibana_solution.js +1 -1
  16. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_button.js +1 -1
  17. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_item.js +2 -2
  18. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.js +2 -2
  19. package/es/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_item.js +4 -4
  20. package/es/components/color_picker/color_picker.js +31 -8
  21. package/es/components/comment_list/comment.js +2 -2
  22. package/es/components/comment_list/comment_event.js +1 -1
  23. package/es/components/comment_list/comment_list.js +2 -2
  24. package/es/components/comment_list/comment_timeline.js +1 -1
  25. package/es/components/context_menu/context_menu_item.js +1 -1
  26. package/es/components/datagrid/body/cell/data_grid_cell.js +12 -12
  27. package/es/components/datagrid/body/data_grid_body.js +7 -7
  28. package/es/components/datagrid/body/data_grid_body_custom.js +7 -7
  29. package/es/components/datagrid/body/data_grid_body_virtualized.js +7 -7
  30. package/es/components/datagrid/body/header/data_grid_header_cell.js +6 -6
  31. package/es/components/datagrid/controls/column_sorting.js +7 -7
  32. package/es/components/datagrid/controls/column_sorting_draggable.js +1 -1
  33. package/es/components/datagrid/controls/data_grid_toolbar_control.js +1 -1
  34. package/es/components/datagrid/utils/in_memory.js +6 -6
  35. package/es/components/datagrid/utils/scrolling.js +39 -10
  36. package/es/components/date_picker/date_picker.js +2 -2
  37. package/es/components/date_picker/date_picker_range.js +1 -1
  38. package/es/components/empty_prompt/empty_prompt.js +1 -1
  39. package/es/components/flyout/_flyout_overlay.js +34 -4
  40. package/es/components/flyout/flyout.component.js +13 -9
  41. package/es/components/flyout/flyout.js +10 -2
  42. package/es/components/flyout/flyout.styles.js +2 -2
  43. package/es/components/flyout/flyout_menu.js +4 -3
  44. package/es/components/flyout/flyout_resizable.js +6 -1
  45. package/es/components/flyout/manager/actions.js +5 -2
  46. package/es/components/flyout/manager/activity_stage.js +45 -43
  47. package/es/components/flyout/manager/flyout_child.js +2 -1
  48. package/es/components/flyout/manager/flyout_managed.js +36 -18
  49. package/es/components/flyout/manager/flyout_managed.styles.js +4 -16
  50. package/es/components/flyout/manager/reducer.js +116 -57
  51. package/es/components/flyout/manager/store.js +13 -6
  52. package/es/components/form/field_number/field_number.js +2 -2
  53. package/es/components/form/field_text/field_text.js +2 -2
  54. package/es/components/form/form_control_button/form_control_button.js +1 -1
  55. package/es/components/form/form_control_layout/append_prepend/form_append_prepend.js +2 -2
  56. package/es/components/form/form_control_layout/form_control_layout.js +2 -2
  57. package/es/components/form/form_control_layout/form_control_layout_custom_icon.js +1 -1
  58. package/es/components/form/form_control_layout/form_control_layout_icons.js +2 -2
  59. package/es/components/form/text_area/text_area.js +2 -2
  60. package/es/components/header/header_links/header_link.js +1 -1
  61. package/es/components/header/header_links/header_links.js +1 -1
  62. package/es/components/header/header_logo/header_logo.js +1 -1
  63. package/es/components/header/header_section/header_section_item_button.js +1 -1
  64. package/es/components/icon/assets/transition_bottom_in.js +37 -0
  65. package/es/components/icon/assets/transition_bottom_out.js +37 -0
  66. package/es/components/icon/icon.js +1 -1
  67. package/es/components/icon/icon_map.js +6 -0
  68. package/es/components/key_pad_menu/key_pad_menu_item.js +1 -1
  69. package/es/components/list_group/list_group.js +2 -2
  70. package/es/components/list_group/list_group_item.js +2 -2
  71. package/es/components/list_group/list_group_item_extra_action.js +1 -1
  72. package/es/components/list_group/pinnable_list_group/pinnable_list_group.js +4 -4
  73. package/es/components/loading/loading_logo.js +1 -1
  74. package/es/components/markdown_editor/markdown_editor.js +1 -1
  75. package/es/components/markdown_editor/markdown_editor_drop_zone.js +1 -1
  76. package/es/components/markdown_editor/markdown_editor_footer.js +1 -1
  77. package/es/components/markdown_editor/markdown_editor_help_button.js +5 -3
  78. package/es/components/markdown_editor/markdown_editor_toolbar.js +1 -1
  79. package/es/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -1
  80. package/es/components/markdown_editor/plugins/remark/remark_intraword_underscore.js +172 -0
  81. package/es/components/overlay_mask/overlay_mask.js +10 -3
  82. package/es/components/page/page_header/page_header_content.js +1 -1
  83. package/es/components/pagination/pagination_button.js +1 -1
  84. package/es/components/search_bar/filters/field_value_toggle_filter.js +42 -99
  85. package/es/components/search_bar/search_filters.js +18 -46
  86. package/es/components/selectable/selectable_list/selectable_list.js +1 -1
  87. package/es/components/selectable/selectable_list/selectable_list_item.js +1 -1
  88. package/es/components/selectable/selectable_templates/selectable_template_sitewide.js +1 -1
  89. package/es/components/table/mobile/table_header_mobile.js +1 -1
  90. package/es/components/table/table_header_cell.js +1 -1
  91. package/es/components/table/utils.js +29 -9
  92. package/es/components/timeline/timeline_item_icon.js +1 -1
  93. package/es/components/toast/global_toast_list.js +1 -1
  94. package/es/components/toast/toast.js +1 -1
  95. package/es/components/tool_tip/icon_tip.js +1 -1
  96. package/es/components/tree_view/tree_view_item.styles.js +1 -1
  97. package/es/services/hooks/index.js +8 -8
  98. package/es/services/hooks/useIsPointerDown.js +6 -15
  99. package/es/services/index.js +1 -1
  100. package/eui.d.ts +130 -71
  101. package/i18ntokens.json +661 -643
  102. package/lib/components/avatar/avatar.js +1 -1
  103. package/lib/components/badge/badge.js +1 -1
  104. package/lib/components/badge/beta_badge/beta_badge.js +1 -1
  105. package/lib/components/basic_table/basic_table.js +4 -4
  106. package/lib/components/basic_table/in_memory_table.js +4 -4
  107. package/lib/components/button/button_display/_button_display_content.js +1 -1
  108. package/lib/components/button/button_empty/button_empty.js +1 -1
  109. package/lib/components/button/button_icon/button_icon.js +1 -1
  110. package/lib/components/button/split_button/split_button.js +13 -0
  111. package/lib/components/button/split_button/split_button_actions.js +15 -0
  112. package/lib/components/call_out/call_out.js +1 -1
  113. package/lib/components/card/card.js +1 -1
  114. package/lib/components/collapsible_nav/collapsible_nav.js +6 -1
  115. package/lib/components/collapsible_nav/collapsible_nav_group/collapsible_nav_group.js +1 -1
  116. package/lib/components/collapsible_nav_beta/_kibana_solution/collapsible_nav_kibana_solution.js +1 -1
  117. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_button.js +1 -1
  118. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_item.js +2 -2
  119. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.js +2 -2
  120. package/lib/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_item.js +4 -4
  121. package/lib/components/color_picker/color_picker.js +30 -7
  122. package/lib/components/comment_list/comment.js +2 -2
  123. package/lib/components/comment_list/comment_event.js +1 -1
  124. package/lib/components/comment_list/comment_list.js +2 -2
  125. package/lib/components/comment_list/comment_timeline.js +1 -1
  126. package/lib/components/context_menu/context_menu_item.js +1 -1
  127. package/lib/components/datagrid/body/cell/data_grid_cell.js +12 -12
  128. package/lib/components/datagrid/body/data_grid_body.js +7 -7
  129. package/lib/components/datagrid/body/data_grid_body_custom.js +7 -7
  130. package/lib/components/datagrid/body/data_grid_body_virtualized.js +7 -7
  131. package/lib/components/datagrid/body/header/data_grid_header_cell.js +6 -6
  132. package/lib/components/datagrid/controls/column_sorting.js +7 -7
  133. package/lib/components/datagrid/controls/column_sorting_draggable.js +1 -1
  134. package/lib/components/datagrid/controls/data_grid_toolbar_control.js +1 -1
  135. package/lib/components/datagrid/utils/in_memory.js +6 -6
  136. package/lib/components/datagrid/utils/scrolling.js +37 -8
  137. package/lib/components/date_picker/date_picker.js +2 -2
  138. package/lib/components/date_picker/date_picker_range.js +1 -1
  139. package/lib/components/empty_prompt/empty_prompt.js +1 -1
  140. package/lib/components/flyout/_flyout_overlay.js +33 -3
  141. package/lib/components/flyout/flyout.component.js +13 -9
  142. package/lib/components/flyout/flyout.js +10 -2
  143. package/lib/components/flyout/flyout.styles.js +2 -2
  144. package/lib/components/flyout/flyout_menu.js +4 -3
  145. package/lib/components/flyout/flyout_resizable.js +6 -1
  146. package/lib/components/flyout/manager/actions.js +5 -2
  147. package/lib/components/flyout/manager/activity_stage.js +45 -43
  148. package/lib/components/flyout/manager/flyout_child.js +2 -1
  149. package/lib/components/flyout/manager/flyout_managed.js +46 -31
  150. package/lib/components/flyout/manager/flyout_managed.styles.js +3 -15
  151. package/lib/components/flyout/manager/reducer.js +116 -57
  152. package/lib/components/flyout/manager/store.js +13 -6
  153. package/lib/components/form/field_number/field_number.js +2 -2
  154. package/lib/components/form/field_text/field_text.js +2 -2
  155. package/lib/components/form/form_control_button/form_control_button.js +1 -1
  156. package/lib/components/form/form_control_layout/append_prepend/form_append_prepend.js +2 -2
  157. package/lib/components/form/form_control_layout/form_control_layout.js +2 -2
  158. package/lib/components/form/form_control_layout/form_control_layout_custom_icon.js +1 -1
  159. package/lib/components/form/form_control_layout/form_control_layout_icons.js +2 -2
  160. package/lib/components/form/text_area/text_area.js +2 -2
  161. package/lib/components/header/header_links/header_link.js +1 -1
  162. package/lib/components/header/header_links/header_links.js +1 -1
  163. package/lib/components/header/header_logo/header_logo.js +1 -1
  164. package/lib/components/header/header_section/header_section_item_button.js +1 -1
  165. package/lib/components/icon/assets/transition_bottom_in.js +44 -0
  166. package/lib/components/icon/assets/transition_bottom_out.js +44 -0
  167. package/lib/components/icon/icon.js +1 -1
  168. package/lib/components/icon/icon_map.js +10 -0
  169. package/lib/components/icon/svgs/transition_bottom_in.svg +1 -0
  170. package/lib/components/icon/svgs/transition_bottom_out.svg +1 -0
  171. package/lib/components/key_pad_menu/key_pad_menu_item.js +1 -1
  172. package/lib/components/list_group/list_group.js +2 -2
  173. package/lib/components/list_group/list_group_item.js +2 -2
  174. package/lib/components/list_group/list_group_item_extra_action.js +1 -1
  175. package/lib/components/list_group/pinnable_list_group/pinnable_list_group.js +4 -4
  176. package/lib/components/loading/loading_logo.js +1 -1
  177. package/lib/components/markdown_editor/markdown_editor.js +1 -1
  178. package/lib/components/markdown_editor/markdown_editor_drop_zone.js +1 -1
  179. package/lib/components/markdown_editor/markdown_editor_footer.js +1 -1
  180. package/lib/components/markdown_editor/markdown_editor_help_button.js +5 -3
  181. package/lib/components/markdown_editor/markdown_editor_toolbar.js +1 -1
  182. package/lib/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -1
  183. package/lib/components/markdown_editor/plugins/remark/remark_intraword_underscore.js +179 -0
  184. package/lib/components/overlay_mask/overlay_mask.js +10 -3
  185. package/lib/components/page/page_header/page_header_content.js +1 -1
  186. package/lib/components/pagination/pagination_button.js +1 -1
  187. package/lib/components/search_bar/filters/field_value_toggle_filter.js +44 -101
  188. package/lib/components/search_bar/search_filters.js +20 -45
  189. package/lib/components/selectable/selectable_list/selectable_list.js +1 -1
  190. package/lib/components/selectable/selectable_list/selectable_list_item.js +1 -1
  191. package/lib/components/selectable/selectable_templates/selectable_template_sitewide.js +1 -1
  192. package/lib/components/table/mobile/table_header_mobile.js +1 -1
  193. package/lib/components/table/table_header_cell.js +1 -1
  194. package/lib/components/table/utils.js +30 -10
  195. package/lib/components/timeline/timeline_item_icon.js +1 -1
  196. package/lib/components/toast/global_toast_list.js +1 -1
  197. package/lib/components/toast/toast.js +1 -1
  198. package/lib/components/tool_tip/icon_tip.js +1 -1
  199. package/lib/components/tree_view/tree_view_item.styles.js +1 -1
  200. package/lib/services/hooks/index.js +60 -91
  201. package/lib/services/hooks/useIsPointerDown.js +7 -14
  202. package/lib/services/index.js +70 -11
  203. package/optimize/es/components/color_picker/color_picker.js +31 -8
  204. package/optimize/es/components/datagrid/utils/scrolling.js +39 -10
  205. package/optimize/es/components/flyout/_flyout_overlay.js +34 -4
  206. package/optimize/es/components/flyout/flyout.component.js +13 -9
  207. package/optimize/es/components/flyout/flyout.js +4 -1
  208. package/optimize/es/components/flyout/flyout.styles.js +2 -2
  209. package/optimize/es/components/flyout/flyout_menu.js +2 -1
  210. package/optimize/es/components/flyout/manager/actions.js +5 -2
  211. package/optimize/es/components/flyout/manager/activity_stage.js +45 -43
  212. package/optimize/es/components/flyout/manager/flyout_managed.js +33 -16
  213. package/optimize/es/components/flyout/manager/flyout_managed.styles.js +4 -16
  214. package/optimize/es/components/flyout/manager/reducer.js +116 -57
  215. package/optimize/es/components/flyout/manager/store.js +13 -6
  216. package/optimize/es/components/icon/assets/transition_bottom_in.js +36 -0
  217. package/optimize/es/components/icon/assets/transition_bottom_out.js +36 -0
  218. package/optimize/es/components/icon/icon_map.js +6 -0
  219. package/optimize/es/components/markdown_editor/markdown_editor_help_button.js +5 -3
  220. package/optimize/es/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -1
  221. package/optimize/es/components/markdown_editor/plugins/remark/remark_intraword_underscore.js +172 -0
  222. package/optimize/es/components/overlay_mask/overlay_mask.js +4 -2
  223. package/optimize/es/components/search_bar/filters/field_value_toggle_filter.js +43 -66
  224. package/optimize/es/components/search_bar/search_filters.js +18 -40
  225. package/optimize/es/components/table/mobile/table_header_mobile.js +1 -1
  226. package/optimize/es/components/table/utils.js +29 -9
  227. package/optimize/es/components/tree_view/tree_view_item.styles.js +1 -1
  228. package/optimize/es/services/hooks/index.js +8 -8
  229. package/optimize/es/services/hooks/useIsPointerDown.js +6 -10
  230. package/optimize/es/services/index.js +1 -1
  231. package/optimize/lib/components/color_picker/color_picker.js +30 -7
  232. package/optimize/lib/components/datagrid/utils/scrolling.js +37 -8
  233. package/optimize/lib/components/flyout/_flyout_overlay.js +33 -3
  234. package/optimize/lib/components/flyout/flyout.component.js +13 -9
  235. package/optimize/lib/components/flyout/flyout.js +4 -1
  236. package/optimize/lib/components/flyout/flyout.styles.js +2 -2
  237. package/optimize/lib/components/flyout/flyout_menu.js +2 -1
  238. package/optimize/lib/components/flyout/manager/actions.js +5 -2
  239. package/optimize/lib/components/flyout/manager/activity_stage.js +45 -43
  240. package/optimize/lib/components/flyout/manager/flyout_managed.js +38 -24
  241. package/optimize/lib/components/flyout/manager/flyout_managed.styles.js +3 -16
  242. package/optimize/lib/components/flyout/manager/reducer.js +116 -57
  243. package/optimize/lib/components/flyout/manager/store.js +13 -6
  244. package/optimize/lib/components/icon/assets/transition_bottom_in.js +44 -0
  245. package/optimize/lib/components/icon/assets/transition_bottom_out.js +44 -0
  246. package/optimize/lib/components/icon/icon_map.js +10 -0
  247. package/optimize/lib/components/icon/svgs/transition_bottom_in.svg +1 -0
  248. package/optimize/lib/components/icon/svgs/transition_bottom_out.svg +1 -0
  249. package/optimize/lib/components/markdown_editor/markdown_editor_help_button.js +5 -3
  250. package/optimize/lib/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -1
  251. package/optimize/lib/components/markdown_editor/plugins/remark/remark_intraword_underscore.js +179 -0
  252. package/optimize/lib/components/overlay_mask/overlay_mask.js +4 -2
  253. package/optimize/lib/components/search_bar/filters/field_value_toggle_filter.js +45 -69
  254. package/optimize/lib/components/search_bar/search_filters.js +19 -40
  255. package/optimize/lib/components/table/mobile/table_header_mobile.js +1 -1
  256. package/optimize/lib/components/table/utils.js +30 -10
  257. package/optimize/lib/components/tree_view/tree_view_item.styles.js +1 -1
  258. package/optimize/lib/services/hooks/index.js +60 -91
  259. package/optimize/lib/services/hooks/useIsPointerDown.js +5 -10
  260. package/optimize/lib/services/index.js +70 -11
  261. package/package.json +5 -4
  262. package/test-env/components/avatar/avatar.js +1 -1
  263. package/test-env/components/badge/badge.js +1 -1
  264. package/test-env/components/badge/beta_badge/beta_badge.js +1 -1
  265. package/test-env/components/basic_table/basic_table.js +4 -4
  266. package/test-env/components/basic_table/in_memory_table.js +4 -4
  267. package/test-env/components/button/button_display/_button_display_content.js +1 -1
  268. package/test-env/components/button/button_empty/button_empty.js +1 -1
  269. package/test-env/components/button/button_icon/button_icon.js +1 -1
  270. package/test-env/components/button/split_button/split_button.js +13 -0
  271. package/test-env/components/button/split_button/split_button_actions.js +15 -0
  272. package/test-env/components/call_out/call_out.js +1 -1
  273. package/test-env/components/card/card.js +1 -1
  274. package/test-env/components/collapsible_nav/collapsible_nav.js +6 -1
  275. package/test-env/components/collapsible_nav/collapsible_nav_group/collapsible_nav_group.js +1 -1
  276. package/test-env/components/collapsible_nav_beta/_kibana_solution/collapsible_nav_kibana_solution.js +1 -1
  277. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_button.js +1 -1
  278. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_item.js +2 -2
  279. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsed/collapsed_nav_popover.js +2 -2
  280. package/test-env/components/collapsible_nav_beta/collapsible_nav_item/collapsible_nav_item.js +4 -4
  281. package/test-env/components/color_picker/color_picker.js +30 -7
  282. package/test-env/components/comment_list/comment.js +2 -2
  283. package/test-env/components/comment_list/comment_event.js +1 -1
  284. package/test-env/components/comment_list/comment_list.js +2 -2
  285. package/test-env/components/comment_list/comment_timeline.js +1 -1
  286. package/test-env/components/context_menu/context_menu_item.js +1 -1
  287. package/test-env/components/datagrid/body/cell/data_grid_cell.js +12 -12
  288. package/test-env/components/datagrid/body/data_grid_body.js +7 -7
  289. package/test-env/components/datagrid/body/data_grid_body_custom.js +7 -7
  290. package/test-env/components/datagrid/body/data_grid_body_virtualized.js +7 -7
  291. package/test-env/components/datagrid/body/header/data_grid_header_cell.js +6 -6
  292. package/test-env/components/datagrid/controls/column_sorting.js +7 -7
  293. package/test-env/components/datagrid/controls/column_sorting_draggable.js +1 -1
  294. package/test-env/components/datagrid/controls/data_grid_toolbar_control.js +1 -1
  295. package/test-env/components/datagrid/utils/in_memory.js +6 -6
  296. package/test-env/components/datagrid/utils/scrolling.js +37 -8
  297. package/test-env/components/date_picker/date_picker.js +2 -2
  298. package/test-env/components/date_picker/date_picker_range.js +1 -1
  299. package/test-env/components/empty_prompt/empty_prompt.js +1 -1
  300. package/test-env/components/flyout/_flyout_overlay.js +33 -3
  301. package/test-env/components/flyout/flyout.component.js +13 -9
  302. package/test-env/components/flyout/flyout.styles.js +2 -2
  303. package/test-env/components/flyout/flyout_menu.js +4 -3
  304. package/test-env/components/flyout/flyout_resizable.js +6 -1
  305. package/test-env/components/flyout/manager/actions.js +5 -2
  306. package/test-env/components/flyout/manager/activity_stage.js +45 -43
  307. package/test-env/components/flyout/manager/flyout_child.js +2 -1
  308. package/test-env/components/flyout/manager/flyout_managed.js +40 -25
  309. package/test-env/components/flyout/manager/flyout_managed.styles.js +3 -16
  310. package/test-env/components/flyout/manager/reducer.js +116 -57
  311. package/test-env/components/flyout/manager/store.js +13 -6
  312. package/test-env/components/form/field_number/field_number.js +2 -2
  313. package/test-env/components/form/field_text/field_text.js +2 -2
  314. package/test-env/components/form/form_control_button/form_control_button.js +1 -1
  315. package/test-env/components/form/form_control_layout/append_prepend/form_append_prepend.js +2 -2
  316. package/test-env/components/form/form_control_layout/form_control_layout.js +2 -2
  317. package/test-env/components/form/form_control_layout/form_control_layout_custom_icon.js +1 -1
  318. package/test-env/components/form/form_control_layout/form_control_layout_icons.js +2 -2
  319. package/test-env/components/form/text_area/text_area.js +2 -2
  320. package/test-env/components/header/header_links/header_link.js +1 -1
  321. package/test-env/components/header/header_links/header_links.js +1 -1
  322. package/test-env/components/header/header_logo/header_logo.js +1 -1
  323. package/test-env/components/header/header_section/header_section_item_button.js +1 -1
  324. package/test-env/components/icon/assets/transition_bottom_in.js +44 -0
  325. package/test-env/components/icon/assets/transition_bottom_out.js +44 -0
  326. package/test-env/components/icon/icon_map.js +10 -0
  327. package/test-env/components/key_pad_menu/key_pad_menu_item.js +1 -1
  328. package/test-env/components/list_group/list_group.js +2 -2
  329. package/test-env/components/list_group/list_group_item.js +2 -2
  330. package/test-env/components/list_group/list_group_item_extra_action.js +1 -1
  331. package/test-env/components/list_group/pinnable_list_group/pinnable_list_group.js +4 -4
  332. package/test-env/components/loading/loading_logo.js +1 -1
  333. package/test-env/components/markdown_editor/markdown_editor.js +1 -1
  334. package/test-env/components/markdown_editor/markdown_editor_drop_zone.js +1 -1
  335. package/test-env/components/markdown_editor/markdown_editor_footer.js +1 -1
  336. package/test-env/components/markdown_editor/markdown_editor_help_button.js +5 -3
  337. package/test-env/components/markdown_editor/markdown_editor_toolbar.js +1 -1
  338. package/test-env/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -1
  339. package/test-env/components/markdown_editor/plugins/remark/remark_intraword_underscore.js +179 -0
  340. package/test-env/components/overlay_mask/overlay_mask.js +10 -3
  341. package/test-env/components/page/page_header/page_header_content.js +1 -1
  342. package/test-env/components/pagination/pagination_button.js +1 -1
  343. package/test-env/components/search_bar/filters/field_value_toggle_filter.js +44 -96
  344. package/test-env/components/search_bar/search_filters.js +19 -39
  345. package/test-env/components/selectable/selectable_list/selectable_list.js +1 -1
  346. package/test-env/components/selectable/selectable_list/selectable_list_item.js +1 -1
  347. package/test-env/components/selectable/selectable_templates/selectable_template_sitewide.js +1 -1
  348. package/test-env/components/table/mobile/table_header_mobile.js +1 -1
  349. package/test-env/components/table/table_header_cell.js +1 -1
  350. package/test-env/components/table/utils.js +30 -10
  351. package/test-env/components/timeline/timeline_item_icon.js +1 -1
  352. package/test-env/components/toast/global_toast_list.js +1 -1
  353. package/test-env/components/toast/toast.js +1 -1
  354. package/test-env/components/tool_tip/icon_tip.js +1 -1
  355. package/test-env/components/tree_view/tree_view_item.styles.js +1 -1
  356. package/test-env/services/hooks/index.js +60 -91
  357. package/test-env/services/hooks/useIsPointerDown.js +5 -10
  358. package/test-env/services/index.js +70 -11
@@ -26,7 +26,7 @@ export var euiTreeViewItemStyles = function euiTreeViewItemStyles(euiThemeContex
26
26
  euiTreeView__node: _ref,
27
27
  default: /*#__PURE__*/css(logicalCSS('max-height', defaultSize), " line-height:", defaultSize, ";;label:default;"),
28
28
  compressed: /*#__PURE__*/css(logicalCSS('max-height', compressedSize), " line-height:", compressedSize, ";;label:compressed;"),
29
- expanded: /*#__PURE__*/css(logicalCSS('max-height', '100vh'), ";;label:expanded;")
29
+ expanded: /*#__PURE__*/css(logicalCSS('max-height', 'none'), ";;label:expanded;")
30
30
  },
31
31
  button: {
32
32
  euiTreeView__nodeInner: /*#__PURE__*/css(logicalCSS('width', '100%'), " ", logicalCSS('padding-left', euiTheme.size.s), " ", logicalCSS('padding-right', euiTheme.size.xxs), " display:flex;align-items:center;&:focus{", euiFocusRing(euiThemeContext, 'inset'), ";}&:hover,&:active,&:focus{background-color:", euiTheme.components.treeViewItemBackgroundHover, ";};label:euiTreeView__nodeInner;"),
@@ -6,12 +6,12 @@
6
6
  * Side Public License, v 1.
7
7
  */
8
8
 
9
- export * from './useDependentState';
10
- export * from './useCombinedRefs';
11
- export * from './useForceRender';
12
- export * from './useLatest';
13
- export * from './useDeepEqual';
14
- export * from './useMouseMove';
15
- export * from './useIsPointerDown';
16
- export * from './useUpdateEffect';
9
+ export { useDependentState } from './useDependentState';
10
+ export { useCombinedRefs, setMultipleRefs } from './useCombinedRefs';
11
+ export { useForceRender } from './useForceRender';
12
+ export { useLatest } from './useLatest';
13
+ export { useDeepEqual } from './useDeepEqual';
14
+ export { isMouseEvent, useMouseMove } from './useMouseMove';
15
+ export { useIsPointerDown } from './useIsPointerDown';
16
+ export { useUpdateEffect } from './useUpdateEffect';
17
17
  export { useEuiDisabledElement } from './useEuiDisabledElement';
@@ -1,4 +1,3 @@
1
- import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
1
  /*
3
2
  * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
4
3
  * or more contributor license agreements. Licensed under the Elastic License
@@ -7,30 +6,27 @@ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
7
6
  * Side Public License, v 1.
8
7
  */
9
8
 
10
- import { useState, useEffect } from 'react';
9
+ import { useRef, useEffect } from 'react';
11
10
 
12
11
  /**
13
12
  * A hook that tracks whether the pointer is currently down/pressed.
14
13
  * Useful for detecting text selection in progress.
15
14
  */
16
15
  export function useIsPointerDown(container) {
17
- var _useState = useState(false),
18
- _useState2 = _slicedToArray(_useState, 2),
19
- isPointerDown = _useState2[0],
20
- setIsPointerDown = _useState2[1];
16
+ var isPointerDownRef = useRef(false);
21
17
  useEffect(function () {
22
18
  var handlePointerDown = function handlePointerDown(event) {
23
19
  if (container !== null && container !== void 0 && container.current && !container.current.contains(event.target)) {
24
20
  return;
25
21
  }
26
- setIsPointerDown(true);
22
+ isPointerDownRef.current = true;
27
23
  };
28
24
  var handlePointerUpOrCancel = function handlePointerUpOrCancel() {
29
- setIsPointerDown(false);
25
+ isPointerDownRef.current = false;
30
26
  };
31
27
  var handleVisibilityChange = function handleVisibilityChange() {
32
28
  if (document.visibilityState === 'hidden') {
33
- setIsPointerDown(false);
29
+ isPointerDownRef.current = false;
34
30
  }
35
31
  };
36
32
  var controller = new AbortController();
@@ -48,5 +44,5 @@ export function useIsPointerDown(container) {
48
44
  controller.abort();
49
45
  };
50
46
  }, [container]);
51
- return isPointerDown;
47
+ return isPointerDownRef;
52
48
  }
@@ -22,7 +22,7 @@ export * from './emotion';
22
22
  export * from './findElement';
23
23
  export { focusTrapPubSub } from './focus_trap';
24
24
  export { dateFormatAliases, formatAuto, formatBoolean, formatDate, formatNumber, formatText } from './format';
25
- export * from './hooks';
25
+ export { useDependentState, useCombinedRefs, setMultipleRefs, useForceRender, useLatest, useDeepEqual, isMouseEvent, useMouseMove, useUpdateEffect, useEuiDisabledElement } from './hooks';
26
26
  export { isEvenlyDivisibleBy, isWithinRange } from './number';
27
27
  export { Pager } from './paging';
28
28
  export { calculatePopoverPosition, findPopoverPosition } from './popover';
@@ -95,9 +95,12 @@ var EuiColorPicker = exports.EuiColorPicker = function EuiColorPicker(_ref) {
95
95
  _ref$isClearable = _ref.isClearable,
96
96
  isClearable = _ref$isClearable === void 0 ? false : _ref$isClearable,
97
97
  placeholder = _ref.placeholder,
98
- dataTestSubj = _ref['data-test-subj'];
99
- var _useEuiI18n = (0, _i18n.useEuiI18n)(['euiColorPicker.popoverLabel', 'euiColorPicker.colorLabel', 'euiColorPicker.selectedColorLabel', 'euiColorPicker.colorErrorMessage', 'euiColorPicker.transparent', 'euiColorPicker.alphaLabel', 'euiColorPicker.openLabel', 'euiColorPicker.closeLabel'], ['Color selection dialog', 'Color value', 'Selected color', 'Invalid color value', 'Transparent', 'Alpha channel (opacity) value', 'Press the escape key to close the popover', 'Press the down key to open a popover containing color options']),
100
- _useEuiI18n2 = (0, _slicedToArray2.default)(_useEuiI18n, 8),
98
+ dataTestSubj = _ref['data-test-subj'],
99
+ _ariaLabel = _ref['aria-label'],
100
+ ariaLabelledby = _ref['aria-labelledby'],
101
+ ariaDescribedby = _ref['aria-describedby'];
102
+ var _useEuiI18n = (0, _i18n.useEuiI18n)(['euiColorPicker.popoverLabel', 'euiColorPicker.colorLabel', 'euiColorPicker.selectedColorLabel', 'euiColorPicker.colorErrorMessage', 'euiColorPicker.transparent', 'euiColorPicker.alphaLabel', 'euiColorPicker.openLabel', 'euiColorPicker.closeLabel', 'euiColorPicker.ariaLabel'], ['Color selection dialog', 'Color value', 'Selected color', 'Invalid color value', 'Transparent', 'Alpha channel (opacity) value', 'Press the escape key to close the popover', 'Press the down key to open a popover containing color options', 'Select a color']),
103
+ _useEuiI18n2 = (0, _slicedToArray2.default)(_useEuiI18n, 9),
101
104
  popoverLabel = _useEuiI18n2[0],
102
105
  colorLabel = _useEuiI18n2[1],
103
106
  selectedColorLabel = _useEuiI18n2[2],
@@ -105,7 +108,16 @@ var EuiColorPicker = exports.EuiColorPicker = function EuiColorPicker(_ref) {
105
108
  transparent = _useEuiI18n2[4],
106
109
  alphaLabel = _useEuiI18n2[5],
107
110
  openLabel = _useEuiI18n2[6],
108
- closeLabel = _useEuiI18n2[7];
111
+ closeLabel = _useEuiI18n2[7],
112
+ ariaLabel = _useEuiI18n2[8];
113
+ var openLabelId = (0, _services.useGeneratedHtmlId)({
114
+ prefix: 'colorPicker',
115
+ suffix: 'openLabel'
116
+ });
117
+ var closeLabelId = (0, _services.useGeneratedHtmlId)({
118
+ prefix: 'colorPicker',
119
+ suffix: 'closeLabel'
120
+ });
109
121
  var defaultSwatches = (0, _services.useEuiPaletteColorBlind)();
110
122
  var swatches = _swatches !== null && _swatches !== void 0 ? _swatches : defaultSwatches;
111
123
  var preferredFormat = (0, _react.useMemo)(function () {
@@ -434,10 +446,21 @@ var EuiColorPicker = exports.EuiColorPicker = function EuiColorPicker(_ref) {
434
446
  readOnly: readOnly,
435
447
  fullWidth: fullWidth,
436
448
  autoComplete: "off",
437
- "data-test-subj": testSubjAnchor,
438
- "aria-label": isColorSelectorShown ? openLabel : closeLabel,
449
+ "data-test-subj": testSubjAnchor
450
+ // if an id is provided it might be used in combination with `htmlFor` on a label,
451
+ // so we don't want to override it with a fallback `aria-label`
452
+ ,
453
+ "aria-label": _ariaLabel ? _ariaLabel : id || ariaLabelledby ? undefined : ariaLabel,
454
+ "aria-labelledby": ariaLabelledby,
455
+ "aria-describedby": (0, _classnames.default)(isColorSelectorShown ? openLabelId : closeLabelId, ariaDescribedby),
439
456
  controlOnly: true // Don't need two EuiFormControlwrappers
440
- }));
457
+ }), (0, _react2.jsx)(_accessibility.EuiScreenReaderOnly, null, (0, _react2.jsx)("span", null, (0, _react2.jsx)("span", {
458
+ id: openLabelId,
459
+ "aria-hidden": !isColorSelectorShown
460
+ }, openLabel), (0, _react2.jsx)("span", {
461
+ id: closeLabelId,
462
+ "aria-hidden": isColorSelectorShown
463
+ }, closeLabel))));
441
464
  }
442
465
  return display === 'inline' ? (0, _react2.jsx)("div", {
443
466
  css: styles.euiColorPicker,
@@ -10,6 +10,7 @@ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"))
10
10
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
11
11
  var _react = _interopRequireWildcard(require("react"));
12
12
  var _services = require("../../../services");
13
+ var _hooks = require("../../../services/hooks");
13
14
  var _global_styling = require("../../../global_styling");
14
15
  var _cell = require("../body/cell");
15
16
  var _focus = require("./focus");
@@ -37,20 +38,48 @@ var useScroll = exports.useScroll = function useScroll(args) {
37
38
  scrollCellIntoView = _useScrollCellIntoVie.scrollCellIntoView;
38
39
  var _useContext = (0, _react.useContext)(_focus.DataGridFocusContext),
39
40
  focusedCell = _useContext.focusedCell;
40
- var isPointerDown = (0, _services.useIsPointerDown)(args.outerGridRef);
41
+ var isPointerDownRef = (0, _hooks.useIsPointerDown)(args.outerGridRef);
42
+
43
+ /**
44
+ * Set when `focusedCell` changes while the pointer is held down (e.g. clicking a cell).
45
+ * Allows the `pointerup` listener below to scroll on release without
46
+ * causing snap-back when the user scrolls the grid without changing focus.
47
+ */
48
+ var pendingScrollRef = (0, _react.useRef)(false);
49
+ (0, _react.useEffect)(function () {
50
+ if (!focusedCell) return;
51
+ if (isPointerDownRef.current) {
52
+ // Pointer is down - defer scroll decision to the pointerup listener
53
+ pendingScrollRef.current = true;
54
+ return;
55
+ }
56
+ scrollCellIntoView({
57
+ rowIndex: focusedCell[1],
58
+ colIndex: focusedCell[0]
59
+ });
60
+ }, [focusedCell, scrollCellIntoView, isPointerDownRef]);
41
61
  (0, _react.useEffect)(function () {
42
- if (focusedCell) {
62
+ var handlePointerUp = function handlePointerUp() {
43
63
  var _window;
44
- // do not scroll if text is being selected
45
- if (isPointerDown || ((_window = window) === null || _window === void 0 || (_window = _window.getSelection()) === null || _window === void 0 ? void 0 : _window.type) === 'Range') {
46
- return;
47
- }
64
+ if (!pendingScrollRef.current || !focusedCell) return;
65
+ pendingScrollRef.current = false;
66
+
67
+ // Skip if the interaction resulted in text being selected
68
+ if (((_window = window) === null || _window === void 0 || (_window = _window.getSelection()) === null || _window === void 0 ? void 0 : _window.type) === 'Range') return;
48
69
  scrollCellIntoView({
49
70
  rowIndex: focusedCell[1],
50
71
  colIndex: focusedCell[0]
51
72
  });
52
- }
53
- }, [focusedCell, isPointerDown, scrollCellIntoView]);
73
+ };
74
+ document.addEventListener('pointerup', handlePointerUp, {
75
+ capture: true
76
+ });
77
+ return function () {
78
+ return document.removeEventListener('pointerup', handlePointerUp, {
79
+ capture: true
80
+ });
81
+ };
82
+ }, [focusedCell, scrollCellIntoView]);
54
83
  var _useContext2 = (0, _react.useContext)(_cell.DataGridCellPopoverContext),
55
84
  popoverIsOpen = _useContext2.popoverIsOpen,
56
85
  cellLocation = _useContext2.cellLocation;
@@ -9,6 +9,7 @@ exports.EuiFlyoutOverlay = void 0;
9
9
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
10
  var _react = _interopRequireWildcard(require("react"));
11
11
  var _css = require("@emotion/css");
12
+ var _services = require("../../services");
12
13
  var _overlay_mask = require("../overlay_mask");
13
14
  var _portal = require("../portal");
14
15
  var _react2 = require("@emotion/react");
@@ -26,8 +27,7 @@ var getEuiFlyoutOverlayStyles = function getEuiFlyoutOverlayStyles(zIndex) {
26
27
  /*
27
28
  This needs to have !important to override the default EuiOverlayMask
28
29
  z-index based on the headerZindexLocation prop. Using the style attribute
29
- doesn't work since EuiOverlayMask requires a string style prop that
30
- causes React errors in the test environment.
30
+ doesn't work since EuiOverlayMask requires the styles to be provided via className
31
31
  */
32
32
  return /*#__PURE__*/(0, _css.css)("z-index:", zIndex, "!important;;label:getEuiFlyoutOverlayStyles;");
33
33
  };
@@ -48,10 +48,39 @@ var EuiFlyoutOverlay = exports.EuiFlyoutOverlay = function EuiFlyoutOverlay(_ref
48
48
  hasOverlayMask = _ref.hasOverlayMask,
49
49
  maskZIndex = _ref.maskZIndex,
50
50
  _ref$headerZindexLoca = _ref.headerZindexLocation,
51
- headerZindexLocation = _ref$headerZindexLoca === void 0 ? 'below' : _ref$headerZindexLoca;
51
+ headerZindexLocation = _ref$headerZindexLoca === void 0 ? 'below' : _ref$headerZindexLoca,
52
+ containerRect = _ref.containerRect;
52
53
  var styles = (0, _react.useMemo)(function () {
53
54
  return getEuiFlyoutOverlayStyles(maskZIndex);
54
55
  }, [maskZIndex]);
56
+
57
+ // Internal ref so we can apply containerRect positioning directly on the DOM
58
+ // node, avoiding new Emotion CSS class generation on every scroll/resize.
59
+ var internalMaskRef = (0, _react.useRef)(null);
60
+ var combinedMaskRef = (0, _services.useCombinedRefs)([internalMaskRef, maskProps === null || maskProps === void 0 ? void 0 : maskProps.maskRef]);
61
+ (0, _react.useEffect)(function () {
62
+ var node = internalMaskRef.current;
63
+ if (!node) return;
64
+
65
+ // containerRect positioning must be applied via node.style.setProperty rather than
66
+ // through the style prop - EuiOverlayMask requires styles to be passed via className
67
+ if (containerRect) {
68
+ node.style.setProperty('inset-block-start', "".concat(containerRect.top, "px"));
69
+ node.style.setProperty('inset-inline-start', "".concat(containerRect.left, "px"));
70
+ node.style.setProperty('inline-size', "".concat(containerRect.width, "px"));
71
+ node.style.setProperty('block-size', "".concat(containerRect.height, "px"));
72
+ node.style.setProperty('inset-inline-end', 'auto');
73
+ node.style.setProperty('inset-block-end', 'auto');
74
+ } else {
75
+ node.style.removeProperty('inset-block-start');
76
+ node.style.removeProperty('inset-inline-start');
77
+ node.style.removeProperty('inline-size');
78
+ node.style.removeProperty('block-size');
79
+ node.style.removeProperty('inset-inline-end');
80
+ node.style.removeProperty('inset-block-end');
81
+ }
82
+ }, [containerRect, hasOverlayMask]); // toggling ownFocus while the flyout is already open should cause re-render
83
+
55
84
  var content = children;
56
85
  if (!isPushed || hasOverlayMask) {
57
86
  content = (0, _react2.jsx)(_portal.EuiPortal, null, content);
@@ -60,6 +89,7 @@ var EuiFlyoutOverlay = exports.EuiFlyoutOverlay = function EuiFlyoutOverlay(_ref
60
89
  return (0, _react2.jsx)(_react.default.Fragment, null, hasOverlayMask && (0, _react2.jsx)(_overlay_mask.EuiOverlayMask, (0, _extends2.default)({
61
90
  headerZindexLocation: (_maskProps$headerZind = maskProps === null || maskProps === void 0 ? void 0 : maskProps.headerZindexLocation) !== null && _maskProps$headerZind !== void 0 ? _maskProps$headerZind : headerZindexLocation
62
91
  }, maskProps, {
92
+ maskRef: combinedMaskRef,
63
93
  className: classes
64
94
  })), content);
65
95
  };
@@ -33,7 +33,7 @@ var _use_flyout_z_index = require("./use_flyout_z_index");
33
33
  var _flyout_parent_context = require("./flyout_parent_context");
34
34
  var _use_flyout_menu = require("./use_flyout_menu");
35
35
  var _react2 = require("@emotion/react");
36
- var _excluded = ["className", "children", "as", "hideCloseButton", "flyoutMenuProps", "flyoutMenuDisplayMode", "closeButtonProps", "closeButtonPosition", "onClose", "ownFocus", "side", "size", "paddingSize", "maxWidth", "style", "hasChildBackground", "maskProps", "type", "outsideClickCloses", "pushMinBreakpoint", "pushAnimation", "focusTrapProps", "includeFixedHeadersInFocusTrap", "includeSelectorInFocusTrap", "aria-describedby", "aria-labelledby", "id", "resizable", "minWidth", "onResize", "onAnimationEnd", "container"];
36
+ var _excluded = ["className", "children", "as", "hideCloseButton", "flyoutMenuProps", "flyoutMenuDisplayMode", "closeButtonProps", "closeButtonPosition", "onClose", "ownFocus", "side", "size", "paddingSize", "maxWidth", "style", "hasChildBackground", "maskProps", "type", "outsideClickCloses", "pushMinBreakpoint", "pushAnimation", "hasAnimation", "focusTrapProps", "includeFixedHeadersInFocusTrap", "includeSelectorInFocusTrap", "aria-describedby", "aria-labelledby", "id", "resizable", "minWidth", "onResize", "onAnimationEnd", "container"];
37
37
  /*
38
38
  * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
39
39
  * or more contributor license agreements. Licensed under the Elastic License
@@ -96,23 +96,25 @@ var EuiFlyoutComponent = exports.EuiFlyoutComponent = /*#__PURE__*/(0, _react.fo
96
96
  outsideClickCloses = _usePropsWithComponen.outsideClickCloses,
97
97
  _usePropsWithComponen12 = _usePropsWithComponen.pushMinBreakpoint,
98
98
  pushMinBreakpoint = _usePropsWithComponen12 === void 0 ? _const2.DEFAULT_PUSH_MIN_BREAKPOINT : _usePropsWithComponen12,
99
- _usePropsWithComponen13 = _usePropsWithComponen.pushAnimation,
100
- pushAnimation = _usePropsWithComponen13 === void 0 ? false : _usePropsWithComponen13,
99
+ _pushAnimation = _usePropsWithComponen.pushAnimation,
100
+ _hasAnimation = _usePropsWithComponen.hasAnimation,
101
101
  _focusTrapProps = _usePropsWithComponen.focusTrapProps,
102
- _usePropsWithComponen14 = _usePropsWithComponen.includeFixedHeadersInFocusTrap,
103
- includeFixedHeadersInFocusTrap = _usePropsWithComponen14 === void 0 ? true : _usePropsWithComponen14,
102
+ _usePropsWithComponen13 = _usePropsWithComponen.includeFixedHeadersInFocusTrap,
103
+ includeFixedHeadersInFocusTrap = _usePropsWithComponen13 === void 0 ? true : _usePropsWithComponen13,
104
104
  includeSelectorInFocusTrap = _usePropsWithComponen.includeSelectorInFocusTrap,
105
105
  _ariaDescribedBy = _usePropsWithComponen['aria-describedby'],
106
106
  _ariaLabelledBy = _usePropsWithComponen['aria-labelledby'],
107
107
  id = _usePropsWithComponen.id,
108
- _usePropsWithComponen15 = _usePropsWithComponen.resizable,
109
- resizable = _usePropsWithComponen15 === void 0 ? false : _usePropsWithComponen15,
108
+ _usePropsWithComponen14 = _usePropsWithComponen.resizable,
109
+ resizable = _usePropsWithComponen14 === void 0 ? false : _usePropsWithComponen14,
110
110
  minWidth = _usePropsWithComponen.minWidth,
111
111
  onResize = _usePropsWithComponen.onResize,
112
112
  onAnimationEnd = _usePropsWithComponen.onAnimationEnd,
113
113
  containerProp = _usePropsWithComponen.container,
114
114
  rest = (0, _objectWithoutProperties2.default)(_usePropsWithComponen, _excluded);
115
115
  var container = resolveContainer(containerProp);
116
+ var hasAnimationDefault = type === 'overlay';
117
+ var hasAnimation = _hasAnimation !== null && _hasAnimation !== void 0 ? _hasAnimation : hasAnimationDefault;
116
118
  var _useEuiThemeCSSVariab = (0, _services.useEuiThemeCSSVariables)(),
117
119
  setGlobalCSSVariables = _useEuiThemeCSSVariab.setGlobalCSSVariables;
118
120
  var Element = as || defaultElement;
@@ -533,7 +535,7 @@ var EuiFlyoutComponent = exports.EuiFlyoutComponent = /*#__PURE__*/(0, _react.fo
533
535
  return _objectSpread(_objectSpread(_objectSpread({}, style), composedStyles), containerPositionStyles);
534
536
  }, [style, size, layoutMode, siblingFlyoutId, siblingFlyoutWidth, maxWidth, flyoutZIndex, containerRect, side, isChildFlyout]);
535
537
  var styles = (0, _services.useEuiMemoizedStyles)(_flyout.euiFlyoutStyles);
536
- var cssStyles = [styles.euiFlyout, styles.paddingSizes[paddingSize], (0, _const2.isEuiFlyoutSizeNamed)(size) && styles[size], maxWidth === false && styles.noMaxWidth, isPushed ? styles.push.push : styles.overlay.overlay, isPushed ? styles.push[side] : styles.overlay[side], isPushed && !pushAnimation && styles.push.noAnimation, styles[side]];
538
+ var cssStyles = [styles.euiFlyout, styles.paddingSizes[paddingSize], (0, _const2.isEuiFlyoutSizeNamed)(size) && styles[size], maxWidth === false && styles.noMaxWidth, isPushed ? styles.push.push : styles.overlay.overlay, isPushed ? styles.push[side] : styles.overlay[side], !hasAnimation && styles.noAnimation, styles[side]];
537
539
  var classes = (0, _classnames.default)('euiFlyout', isChildFlyout && hasChildBackground && 'euiFlyout--hasChildBackground', className);
538
540
  var flyoutToggle = (0, _react.useRef)(document.activeElement);
539
541
  var _useState5 = (0, _react.useState)([]),
@@ -669,8 +671,10 @@ var EuiFlyoutComponent = exports.EuiFlyoutComponent = /*#__PURE__*/(0, _react.fo
669
671
  isPushed: isPushed,
670
672
  maskZIndex: maskZIndex,
671
673
  headerZindexLocation: effectiveHeaderZindexLocation,
674
+ containerRect: containerRect,
672
675
  maskProps: _objectSpread(_objectSpread({}, maskProps), {}, {
673
- maskRef: maskCombinedRefs
676
+ maskRef: maskCombinedRefs,
677
+ hasAnimation: hasAnimation
674
678
  })
675
679
  }, (0, _react2.jsx)(_services.EuiWindowEvent, {
676
680
  event: "keydown",
@@ -47,7 +47,7 @@ var _flyout_parent_context = require("./flyout_parent_context");
47
47
  var _const = require("./manager/const");
48
48
  var _react2 = require("@emotion/react");
49
49
  var _const2 = require("./const");
50
- var _excluded = ["as", "onClose", "onActive", "session"];
50
+ var _excluded = ["as", "onClose", "onActive", "session", "historyKey"];
51
51
  /*
52
52
  * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
53
53
  * or more contributor license agreements. Licensed under the Elastic License
@@ -63,6 +63,7 @@ var EuiFlyout = exports.EuiFlyout = /*#__PURE__*/(0, _react.forwardRef)(function
63
63
  onClose = _usePropsWithComponen.onClose,
64
64
  onActive = _usePropsWithComponen.onActive,
65
65
  session = _usePropsWithComponen.session,
66
+ historyKey = _usePropsWithComponen.historyKey,
66
67
  rest = (0, _objectWithoutProperties2.default)(_usePropsWithComponen, _excluded);
67
68
  var hasActiveSession = (0, _manager.useHasActiveSession)();
68
69
  var isInsideParentFlyout = (0, _flyout_parent_context.useIsInsideParentFlyout)();
@@ -89,6 +90,7 @@ var EuiFlyout = exports.EuiFlyout = /*#__PURE__*/(0, _react.forwardRef)(function
89
90
  return null;
90
91
  }
91
92
  return (0, _react2.jsx)(_manager.EuiFlyoutMain, (0, _extends2.default)({}, rest, {
93
+ historyKey: historyKey,
92
94
  onClose: onClose,
93
95
  onActive: onActive,
94
96
  as: "div",
@@ -99,6 +101,7 @@ var EuiFlyout = exports.EuiFlyout = /*#__PURE__*/(0, _react.forwardRef)(function
99
101
  // session=inherit: auto-join existing session as child
100
102
  if (hasActiveSession && effectiveSession === _const.SESSION_INHERIT) {
101
103
  return (0, _react2.jsx)(_manager.EuiFlyoutChild, (0, _extends2.default)({}, rest, {
104
+ historyKey: historyKey,
102
105
  onClose: onClose,
103
106
  onActive: onActive,
104
107
  as: "div",
@@ -74,9 +74,9 @@ var euiFlyoutStyles = exports.euiFlyoutStyles = function euiFlyoutStyles(euiThem
74
74
  push: {
75
75
  push: /*#__PURE__*/(0, _react.css)("clip-path:none;z-index:", Number(euiTheme.levels.flyout) - 1, ";;label:push;"),
76
76
  right: /*#__PURE__*/(0, _react.css)((0, _global_styling.logicalCSS)('border-left', euiTheme.border.thick), ";;label:right;"),
77
- left: /*#__PURE__*/(0, _react.css)((0, _global_styling.logicalCSS)('border-right', euiTheme.border.thick), ";;label:left;"),
78
- noAnimation: _ref
77
+ left: /*#__PURE__*/(0, _react.css)((0, _global_styling.logicalCSS)('border-right', euiTheme.border.thick), ";;label:left;")
79
78
  },
79
+ noAnimation: _ref,
80
80
  // Padding
81
81
  paddingSizes: {
82
82
  none: /*#__PURE__*/(0, _react.css)(composeFlyoutPadding(euiThemeContext, 'none'), ";;label:none;"),
@@ -22,7 +22,7 @@ var _flyout_menu = require("./flyout_menu.styles");
22
22
  var _flyout_menu_context = require("./flyout_menu_context");
23
23
  var _i18n = require("../i18n");
24
24
  var _react2 = require("@emotion/react");
25
- var _excluded = ["className", "title", "titleId", "hideTitle", "hideCloseButton", "historyItems", "showBackButton", "backButtonProps", "customActions"];
25
+ var _excluded = ["className", "title", "titleId", "hideTitle", "hideCloseButton", "historyItems", "showBackButton", "backButtonProps", "customActions", "iconType"];
26
26
  /*
27
27
  * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
28
28
  * or more contributor license agreements. Licensed under the Elastic License
@@ -113,6 +113,7 @@ var EuiFlyoutMenu = exports.EuiFlyoutMenu = function EuiFlyoutMenu(_ref2) {
113
113
  showBackButton = _ref2.showBackButton,
114
114
  backButtonProps = _ref2.backButtonProps,
115
115
  customActions = _ref2.customActions,
116
+ _iconType = _ref2.iconType,
116
117
  rest = (0, _objectWithoutProperties2.default)(_ref2, _excluded);
117
118
  var _useContext = (0, _react.useContext)(_flyout_menu_context.EuiFlyoutMenuContext),
118
119
  onClose = _useContext.onClose;
@@ -75,19 +75,22 @@ var ACTION_CLOSE_UNMANAGED_FLYOUT = exports.ACTION_CLOSE_UNMANAGED_FLYOUT = "".c
75
75
  * - `title` is used for the flyout menu.
76
76
  * - `level` determines whether the flyout is `main` or `child`.
77
77
  * - Optional `size` is the named EUI size (e.g. `s`, `m`, `l`).
78
+ * - Optional `historyKey` (Symbol) scopes history; only flyouts with the same reference share Back/history. Omit for a unique group per session.
78
79
  * - Optional `iconType` is shown next to the session title in the history menu.
79
80
  */
80
81
  var addFlyout = exports.addFlyout = function addFlyout(flyoutId, title) {
81
82
  var level = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _const.LEVEL_MAIN;
82
83
  var size = arguments.length > 3 ? arguments[3] : undefined;
83
- var iconType = arguments.length > 4 ? arguments[4] : undefined;
84
- var minWidth = arguments.length > 5 ? arguments[5] : undefined;
84
+ var historyKey = arguments.length > 4 ? arguments[4] : undefined;
85
+ var iconType = arguments.length > 5 ? arguments[5] : undefined;
86
+ var minWidth = arguments.length > 6 ? arguments[6] : undefined;
85
87
  return {
86
88
  type: ACTION_ADD,
87
89
  flyoutId: flyoutId,
88
90
  title: title,
89
91
  level: level,
90
92
  size: size,
93
+ historyKey: historyKey,
91
94
  iconType: iconType,
92
95
  minWidth: minWidth
93
96
  };
@@ -16,6 +16,24 @@ var _provider = require("./provider");
16
16
  * Side Public License, v 1.
17
17
  */
18
18
 
19
+ /**
20
+ * Returns the final stage after an animation completes.
21
+ * OPENING/RETURNING -> ACTIVE; CLOSING -> INACTIVE; BACKGROUNDING -> BACKGROUNDED.
22
+ */
23
+ var getNextStage = function getNextStage(stage) {
24
+ switch (stage) {
25
+ case _const.STAGE_OPENING:
26
+ case _const.STAGE_RETURNING:
27
+ return _const.STAGE_ACTIVE;
28
+ case _const.STAGE_CLOSING:
29
+ return _const.STAGE_INACTIVE;
30
+ case _const.STAGE_BACKGROUNDING:
31
+ return _const.STAGE_BACKGROUNDED;
32
+ default:
33
+ return null;
34
+ }
35
+ };
36
+
19
37
  /**
20
38
  * Encapsulates all activity-stage transitions and animation-driven updates
21
39
  * for managed flyouts.
@@ -27,7 +45,9 @@ var _provider = require("./provider");
27
45
  var useFlyoutActivityStage = exports.useFlyoutActivityStage = function useFlyoutActivityStage(_ref) {
28
46
  var _sessions, _state$sessions$find, _state$layoutMode, _state$flyouts$find;
29
47
  var flyoutId = _ref.flyoutId,
30
- level = _ref.level;
48
+ level = _ref.level,
49
+ _ref$shouldAnimate = _ref.shouldAnimate,
50
+ shouldAnimate = _ref$shouldAnimate === void 0 ? false : _ref$shouldAnimate;
31
51
  var ctx = (0, _provider.useFlyoutManager)();
32
52
  var state = ctx === null || ctx === void 0 ? void 0 : ctx.state;
33
53
 
@@ -47,64 +67,46 @@ var useFlyoutActivityStage = exports.useFlyoutActivityStage = function useFlyout
47
67
  if (stageRef.current !== stage) {
48
68
  stageRef.current = stage;
49
69
  }
70
+ var transitionTo = (0, _react.useCallback)(function (nextStage) {
71
+ var _ctx$dispatch;
72
+ ctx === null || ctx === void 0 || (_ctx$dispatch = ctx.dispatch) === null || _ctx$dispatch === void 0 || _ctx$dispatch.call(ctx, (0, _actions.setActivityStage)(flyoutId, nextStage));
73
+ stageRef.current = nextStage;
74
+ }, [ctx, flyoutId]);
50
75
 
51
76
  /**
52
- * 1. ACTIVE -> CLOSING when no longer the active flyout.
53
- * 2. INACTIVE -> RETURNING when it becomes active again (e.g., reopened or brought forward).
54
- * 3. (Main flyout only) ACTIVE + stacked + has child -> BACKGROUNDING (begin background animation).
55
- * 4. (Main only) BACKGROUNDED/BACKGROUNDING + (child gone OR side-by-side) -> RETURNING (bring main to foreground).
56
- *
57
- * Any stages that depend on animation end (OPENING, RETURNING, CLOSING, BACKGROUNDING) are finalized in `onAnimationEnd`.
77
+ * 1. ACTIVE -> CLOSING (or INACTIVE when !shouldAnimate) when no longer the active flyout.
78
+ * 2. INACTIVE -> RETURNING (or ACTIVE when !shouldAnimate) when it becomes active again.
79
+ * 3. (Main only) ACTIVE + stacked + has child -> BACKGROUNDING (or BACKGROUNDED when !shouldAnimate).
80
+ * 4. (Main only) BACKGROUNDED/BACKGROUNDING + (child gone OR side-by-side) -> RETURNING (or ACTIVE when !shouldAnimate).
58
81
  */
59
82
  (0, _react.useEffect)(function () {
60
83
  var s = stageRef.current;
61
84
  var next = null;
62
- if (s === _const.STAGE_ACTIVE && !isActive) next = _const.STAGE_CLOSING;else if (s === _const.STAGE_INACTIVE && isActive) {
63
- next = _const.STAGE_RETURNING;
64
- } else if (level === _const.LEVEL_MAIN && isActive && s === _const.STAGE_ACTIVE && hasChild && layoutMode === _const.LAYOUT_MODE_STACKED) next = _const.STAGE_BACKGROUNDING;else if (level === _const.LEVEL_MAIN && (s === _const.STAGE_BACKGROUNDED || s === _const.STAGE_BACKGROUNDING) && (!hasChild || layoutMode === _const.LAYOUT_MODE_SIDE_BY_SIDE)) next = _const.STAGE_RETURNING;
65
- if (next && next !== s) {
66
- var _ctx$dispatch;
67
- ctx === null || ctx === void 0 || (_ctx$dispatch = ctx.dispatch) === null || _ctx$dispatch === void 0 || _ctx$dispatch.call(ctx, (0, _actions.setActivityStage)(flyoutId, next));
68
- stageRef.current = next;
85
+ if (s === _const.STAGE_ACTIVE && !isActive) {
86
+ next = shouldAnimate ? _const.STAGE_CLOSING : _const.STAGE_INACTIVE;
87
+ } else if (s === _const.STAGE_INACTIVE && isActive) {
88
+ next = shouldAnimate ? _const.STAGE_RETURNING : _const.STAGE_ACTIVE;
89
+ } else if (level === _const.LEVEL_MAIN && isActive && s === _const.STAGE_ACTIVE && hasChild && layoutMode === _const.LAYOUT_MODE_STACKED) {
90
+ next = shouldAnimate ? _const.STAGE_BACKGROUNDING : _const.STAGE_BACKGROUNDED;
91
+ } else if (level === _const.LEVEL_MAIN && (s === _const.STAGE_BACKGROUNDED || s === _const.STAGE_BACKGROUNDING) && (!hasChild || layoutMode === _const.LAYOUT_MODE_SIDE_BY_SIDE)) {
92
+ next = shouldAnimate ? _const.STAGE_RETURNING : _const.STAGE_ACTIVE;
69
93
  }
70
- }, [isActive, hasChild, layoutMode, level, ctx, flyoutId, stage]);
71
-
72
- /**
73
- * Get the stage to transition to for given current stage.
74
- * Returns `null` if stage should remain unchanged.
75
- *
76
- * Stage transitions:
77
- * - OPENING / RETURNING -> ACTIVE
78
- * - CLOSING -> INACTIVE
79
- * - BACKGROUNDING -> BACKGROUNDED
80
- */
81
- var getNextStage = function getNextStage(stage) {
82
- switch (stage) {
83
- case _const.STAGE_OPENING:
84
- case _const.STAGE_RETURNING:
85
- return _const.STAGE_ACTIVE;
86
- case _const.STAGE_CLOSING:
87
- return _const.STAGE_INACTIVE;
88
- case _const.STAGE_BACKGROUNDING:
89
- return _const.STAGE_BACKGROUNDED;
94
+ if (next && next !== s) {
95
+ transitionTo(next);
90
96
  }
91
- return null;
92
- };
97
+ }, [isActive, hasChild, layoutMode, level, shouldAnimate, transitionTo, stage]);
93
98
 
94
99
  /**
95
- * onAnimationEnd event handler that must be passed to EuiFlyout.
96
- * It handles transitions between stages and updates activity stage
97
- * in EuiFlyoutManagerContext.
100
+ * onAnimationEnd: browser signal when a CSS animation completes.
101
+ * Calls transitionTo to move to the final stage (e.g. CLOSING -> INACTIVE).
98
102
  */
99
103
  var onAnimationEnd = (0, _react.useCallback)(function () {
100
104
  var currentStage = stageRef.current;
101
105
  var nextStage = getNextStage(currentStage);
102
106
  if (nextStage && nextStage !== currentStage) {
103
- var _ctx$dispatch2;
104
- ctx === null || ctx === void 0 || (_ctx$dispatch2 = ctx.dispatch) === null || _ctx$dispatch2 === void 0 || _ctx$dispatch2.call(ctx, (0, _actions.setActivityStage)(flyoutId, nextStage));
105
- stageRef.current = nextStage;
107
+ transitionTo(nextStage);
106
108
  }
107
- }, [ctx, flyoutId]);
109
+ }, [transitionTo]);
108
110
  return {
109
111
  activityStage: stage,
110
112
  onAnimationEnd: onAnimationEnd