@elastic/eui 93.3.0 → 93.4.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 (286) hide show
  1. package/dist/eui_charts_theme.d.ts +9 -0
  2. package/dist/eui_charts_theme.js +56 -14
  3. package/dist/eui_charts_theme.js.map +1 -1
  4. package/es/components/breadcrumbs/_breadcrumb_content.js +362 -0
  5. package/es/components/breadcrumbs/_breadcrumb_content.styles.js +48 -0
  6. package/es/components/breadcrumbs/breadcrumb.js +10 -327
  7. package/es/components/breadcrumbs/breadcrumb.styles.js +5 -27
  8. package/es/components/breadcrumbs/breadcrumbs.js +4 -4
  9. package/es/components/breadcrumbs/types.js +1 -0
  10. package/es/components/button/button_group/button_group.js +16 -2
  11. package/es/components/button/button_group/button_group.styles.js +1 -1
  12. package/es/components/button/button_group/button_group_button.js +59 -5
  13. package/es/components/button/button_group/button_group_button.styles.js +39 -3
  14. package/es/components/datagrid/body/cell/data_grid_cell.js +97 -58
  15. package/es/components/datagrid/body/cell/data_grid_cell_actions.js +24 -18
  16. package/es/components/datagrid/body/cell/data_grid_cell_popover.js +64 -56
  17. package/es/components/datagrid/body/cell/data_grid_cell_wrapper.js +32 -31
  18. package/es/components/datagrid/body/cell/index.js +1 -1
  19. package/es/components/datagrid/body/data_grid_body.js +13 -0
  20. package/es/components/datagrid/body/data_grid_body_custom.js +52 -36
  21. package/es/components/datagrid/body/data_grid_body_virtualized.js +84 -56
  22. package/es/components/datagrid/body/data_grid_row_manager.js +6 -4
  23. package/es/components/datagrid/body/footer/use_data_grid_footer.js +1 -2
  24. package/es/components/datagrid/body/header/data_grid_control_header_cell.js +5 -4
  25. package/es/components/datagrid/body/header/data_grid_header_cell.js +73 -53
  26. package/es/components/datagrid/body/header/data_grid_header_row.js +15 -551
  27. package/es/components/datagrid/body/header/use_data_grid_header.js +7 -6
  28. package/es/components/datagrid/controls/column_selector.js +126 -123
  29. package/es/components/datagrid/controls/column_sorting.js +605 -103
  30. package/es/components/datagrid/controls/column_sorting_draggable.js +24 -22
  31. package/es/components/datagrid/controls/display_selector.js +109 -107
  32. package/es/components/datagrid/data_grid.a11y.js +13 -12
  33. package/es/components/datagrid/data_grid.js +45 -22
  34. package/es/components/datagrid/utils/col_widths.js +12 -8
  35. package/es/components/datagrid/utils/focus.js +10 -8
  36. package/es/components/datagrid/utils/grid_height_width.js +31 -30
  37. package/es/components/datagrid/utils/ref.js +1 -1
  38. package/es/components/datagrid/utils/row_heights.js +2 -2
  39. package/es/components/datagrid/utils/sorting.js +29 -27
  40. package/es/components/date_picker/super_date_picker/super_date_picker.js +9 -0
  41. package/es/components/date_picker/super_date_picker/super_update_button.js +57 -29
  42. package/es/components/flex/flex_grid.js +22 -8
  43. package/es/components/flex/flex_grid.styles.js +13 -6
  44. package/es/components/flex/flex_group.js +10 -11
  45. package/es/components/flex/flex_item.js +9 -11
  46. package/es/components/flex/flex_item.styles.js +107 -122
  47. package/es/components/flyout/flyout.js +16 -18
  48. package/es/components/header/header_breadcrumbs/header_breadcrumbs.js +3 -5
  49. package/es/components/modal/confirm_modal.js +2 -1
  50. package/es/components/modal/modal.js +12 -3
  51. package/es/components/observer/resize_observer/resize_observer.js +15 -24
  52. package/es/components/spacer/spacer.js +2 -3
  53. package/es/components/toast/global_toast_list.js +70 -73
  54. package/es/components/toast/toast.js +27 -42
  55. package/es/components/toast/toast.styles.js +2 -17
  56. package/es/services/color/eui_palettes.js +21 -13
  57. package/es/services/color/index.js +1 -1
  58. package/es/services/hooks/index.js +1 -0
  59. package/es/services/hooks/useDeepEqual.js +23 -0
  60. package/es/services/index.js +1 -1
  61. package/eui.d.ts +2442 -2337
  62. package/i18ntokens.json +259 -259
  63. package/lib/components/breadcrumbs/_breadcrumb_content.js +372 -0
  64. package/lib/components/breadcrumbs/_breadcrumb_content.styles.js +55 -0
  65. package/lib/components/breadcrumbs/breadcrumb.js +11 -331
  66. package/lib/components/breadcrumbs/breadcrumb.styles.js +5 -29
  67. package/lib/components/breadcrumbs/breadcrumbs.js +3 -3
  68. package/lib/components/breadcrumbs/types.js +5 -0
  69. package/lib/components/button/button_group/button_group.js +16 -2
  70. package/lib/components/button/button_group/button_group.styles.js +1 -1
  71. package/lib/components/button/button_group/button_group_button.js +59 -5
  72. package/lib/components/button/button_group/button_group_button.styles.js +45 -11
  73. package/lib/components/datagrid/body/cell/data_grid_cell.js +95 -57
  74. package/lib/components/datagrid/body/cell/data_grid_cell_actions.js +24 -18
  75. package/lib/components/datagrid/body/cell/data_grid_cell_popover.js +63 -55
  76. package/lib/components/datagrid/body/cell/data_grid_cell_wrapper.js +32 -31
  77. package/lib/components/datagrid/body/cell/index.js +2 -2
  78. package/lib/components/datagrid/body/data_grid_body.js +13 -0
  79. package/lib/components/datagrid/body/data_grid_body_custom.js +51 -35
  80. package/lib/components/datagrid/body/data_grid_body_virtualized.js +83 -55
  81. package/lib/components/datagrid/body/data_grid_row_manager.js +5 -3
  82. package/lib/components/datagrid/body/footer/use_data_grid_footer.js +1 -2
  83. package/lib/components/datagrid/body/header/data_grid_control_header_cell.js +8 -4
  84. package/lib/components/datagrid/body/header/data_grid_header_cell.js +72 -52
  85. package/lib/components/datagrid/body/header/data_grid_header_row.js +14 -550
  86. package/lib/components/datagrid/body/header/use_data_grid_header.js +7 -6
  87. package/lib/components/datagrid/controls/column_selector.js +126 -123
  88. package/lib/components/datagrid/controls/column_sorting.js +615 -110
  89. package/lib/components/datagrid/controls/column_sorting_draggable.js +27 -22
  90. package/lib/components/datagrid/controls/display_selector.js +109 -107
  91. package/lib/components/datagrid/data_grid.a11y.js +13 -12
  92. package/lib/components/datagrid/data_grid.js +43 -20
  93. package/lib/components/datagrid/utils/col_widths.js +12 -8
  94. package/lib/components/datagrid/utils/focus.js +10 -8
  95. package/lib/components/datagrid/utils/grid_height_width.js +29 -28
  96. package/lib/components/datagrid/utils/ref.js +1 -1
  97. package/lib/components/datagrid/utils/row_heights.js +1 -1
  98. package/lib/components/datagrid/utils/sorting.js +31 -29
  99. package/lib/components/date_picker/super_date_picker/super_date_picker.js +9 -0
  100. package/lib/components/date_picker/super_date_picker/super_update_button.js +57 -29
  101. package/lib/components/flex/flex_grid.js +23 -7
  102. package/lib/components/flex/flex_grid.styles.js +13 -6
  103. package/lib/components/flex/flex_group.js +10 -10
  104. package/lib/components/flex/flex_item.js +13 -13
  105. package/lib/components/flex/flex_item.styles.js +107 -122
  106. package/lib/components/flyout/flyout.js +16 -18
  107. package/lib/components/header/header_breadcrumbs/header_breadcrumbs.js +3 -5
  108. package/lib/components/modal/confirm_modal.js +2 -1
  109. package/lib/components/modal/modal.js +12 -3
  110. package/lib/components/observer/resize_observer/resize_observer.js +15 -24
  111. package/lib/components/spacer/spacer.js +1 -2
  112. package/lib/components/toast/global_toast_list.js +68 -71
  113. package/lib/components/toast/toast.js +25 -40
  114. package/lib/components/toast/toast.styles.js +11 -25
  115. package/lib/services/color/eui_palettes.js +24 -14
  116. package/lib/services/color/index.js +14 -0
  117. package/lib/services/hooks/index.js +11 -0
  118. package/lib/services/hooks/useDeepEqual.js +30 -0
  119. package/lib/services/index.js +15 -1
  120. package/optimize/es/components/breadcrumbs/_breadcrumb_content.js +153 -0
  121. package/optimize/es/components/breadcrumbs/_breadcrumb_content.styles.js +48 -0
  122. package/optimize/es/components/breadcrumbs/breadcrumb.js +10 -110
  123. package/optimize/es/components/breadcrumbs/breadcrumb.styles.js +5 -27
  124. package/optimize/es/components/breadcrumbs/breadcrumbs.js +4 -4
  125. package/optimize/es/components/breadcrumbs/types.js +1 -0
  126. package/optimize/es/components/button/button_group/button_group.js +2 -2
  127. package/optimize/es/components/button/button_group/button_group.styles.js +1 -1
  128. package/optimize/es/components/button/button_group/button_group_button.js +36 -4
  129. package/optimize/es/components/button/button_group/button_group_button.styles.js +39 -3
  130. package/optimize/es/components/datagrid/body/cell/data_grid_cell.js +80 -55
  131. package/optimize/es/components/datagrid/body/cell/data_grid_cell_actions.js +24 -18
  132. package/optimize/es/components/datagrid/body/cell/data_grid_cell_popover.js +64 -56
  133. package/optimize/es/components/datagrid/body/cell/data_grid_cell_wrapper.js +32 -31
  134. package/optimize/es/components/datagrid/body/cell/index.js +1 -1
  135. package/optimize/es/components/datagrid/body/data_grid_body_custom.js +39 -36
  136. package/optimize/es/components/datagrid/body/data_grid_body_virtualized.js +69 -49
  137. package/optimize/es/components/datagrid/body/data_grid_row_manager.js +6 -4
  138. package/optimize/es/components/datagrid/body/footer/use_data_grid_footer.js +1 -2
  139. package/optimize/es/components/datagrid/body/header/data_grid_control_header_cell.js +4 -3
  140. package/optimize/es/components/datagrid/body/header/data_grid_header_cell.js +65 -49
  141. package/optimize/es/components/datagrid/body/header/data_grid_header_row.js +15 -13
  142. package/optimize/es/components/datagrid/body/header/use_data_grid_header.js +7 -6
  143. package/optimize/es/components/datagrid/controls/column_selector.js +126 -123
  144. package/optimize/es/components/datagrid/controls/column_sorting.js +121 -103
  145. package/optimize/es/components/datagrid/controls/column_sorting_draggable.js +24 -22
  146. package/optimize/es/components/datagrid/controls/display_selector.js +109 -107
  147. package/optimize/es/components/datagrid/data_grid.a11y.js +13 -12
  148. package/optimize/es/components/datagrid/data_grid.js +45 -22
  149. package/optimize/es/components/datagrid/utils/col_widths.js +9 -5
  150. package/optimize/es/components/datagrid/utils/focus.js +10 -8
  151. package/optimize/es/components/datagrid/utils/grid_height_width.js +31 -30
  152. package/optimize/es/components/datagrid/utils/ref.js +1 -1
  153. package/optimize/es/components/datagrid/utils/row_heights.js +2 -2
  154. package/optimize/es/components/datagrid/utils/sorting.js +29 -27
  155. package/optimize/es/components/date_picker/super_date_picker/super_update_button.js +49 -29
  156. package/optimize/es/components/flex/flex_grid.js +19 -8
  157. package/optimize/es/components/flex/flex_grid.styles.js +13 -6
  158. package/optimize/es/components/flex/flex_group.js +9 -10
  159. package/optimize/es/components/flex/flex_item.js +9 -11
  160. package/optimize/es/components/flex/flex_item.styles.js +107 -122
  161. package/optimize/es/components/flyout/flyout.js +16 -18
  162. package/optimize/es/components/header/header_breadcrumbs/header_breadcrumbs.js +3 -5
  163. package/optimize/es/components/modal/confirm_modal.js +2 -1
  164. package/optimize/es/components/modal/modal.js +6 -2
  165. package/optimize/es/components/observer/resize_observer/resize_observer.js +15 -24
  166. package/optimize/es/components/spacer/spacer.js +2 -3
  167. package/optimize/es/components/toast/global_toast_list.js +70 -73
  168. package/optimize/es/components/toast/toast.js +27 -42
  169. package/optimize/es/components/toast/toast.styles.js +2 -17
  170. package/optimize/es/services/color/eui_palettes.js +21 -13
  171. package/optimize/es/services/color/index.js +1 -1
  172. package/optimize/es/services/hooks/index.js +1 -0
  173. package/optimize/es/services/hooks/useDeepEqual.js +23 -0
  174. package/optimize/es/services/index.js +1 -1
  175. package/optimize/lib/components/breadcrumbs/_breadcrumb_content.js +163 -0
  176. package/optimize/lib/components/breadcrumbs/_breadcrumb_content.styles.js +55 -0
  177. package/optimize/lib/components/breadcrumbs/breadcrumb.js +10 -113
  178. package/optimize/lib/components/breadcrumbs/breadcrumb.styles.js +5 -29
  179. package/optimize/lib/components/breadcrumbs/breadcrumbs.js +3 -3
  180. package/optimize/lib/components/breadcrumbs/types.js +5 -0
  181. package/optimize/lib/components/button/button_group/button_group.js +2 -2
  182. package/optimize/lib/components/button/button_group/button_group.styles.js +1 -1
  183. package/optimize/lib/components/button/button_group/button_group_button.js +37 -5
  184. package/optimize/lib/components/button/button_group/button_group_button.styles.js +45 -11
  185. package/optimize/lib/components/datagrid/body/cell/data_grid_cell.js +78 -54
  186. package/optimize/lib/components/datagrid/body/cell/data_grid_cell_actions.js +24 -18
  187. package/optimize/lib/components/datagrid/body/cell/data_grid_cell_popover.js +63 -55
  188. package/optimize/lib/components/datagrid/body/cell/data_grid_cell_wrapper.js +32 -31
  189. package/optimize/lib/components/datagrid/body/cell/index.js +2 -2
  190. package/optimize/lib/components/datagrid/body/data_grid_body_custom.js +38 -35
  191. package/optimize/lib/components/datagrid/body/data_grid_body_virtualized.js +70 -50
  192. package/optimize/lib/components/datagrid/body/data_grid_row_manager.js +5 -3
  193. package/optimize/lib/components/datagrid/body/footer/use_data_grid_footer.js +1 -2
  194. package/optimize/lib/components/datagrid/body/header/data_grid_control_header_cell.js +8 -4
  195. package/optimize/lib/components/datagrid/body/header/data_grid_header_cell.js +65 -49
  196. package/optimize/lib/components/datagrid/body/header/data_grid_header_row.js +14 -12
  197. package/optimize/lib/components/datagrid/body/header/use_data_grid_header.js +7 -6
  198. package/optimize/lib/components/datagrid/controls/column_selector.js +126 -123
  199. package/optimize/lib/components/datagrid/controls/column_sorting.js +125 -107
  200. package/optimize/lib/components/datagrid/controls/column_sorting_draggable.js +27 -22
  201. package/optimize/lib/components/datagrid/controls/display_selector.js +109 -107
  202. package/optimize/lib/components/datagrid/data_grid.a11y.js +13 -12
  203. package/optimize/lib/components/datagrid/data_grid.js +43 -20
  204. package/optimize/lib/components/datagrid/utils/col_widths.js +9 -5
  205. package/optimize/lib/components/datagrid/utils/focus.js +10 -8
  206. package/optimize/lib/components/datagrid/utils/grid_height_width.js +29 -28
  207. package/optimize/lib/components/datagrid/utils/ref.js +1 -1
  208. package/optimize/lib/components/datagrid/utils/row_heights.js +1 -1
  209. package/optimize/lib/components/datagrid/utils/sorting.js +31 -29
  210. package/optimize/lib/components/date_picker/super_date_picker/super_update_button.js +49 -29
  211. package/optimize/lib/components/flex/flex_grid.js +21 -7
  212. package/optimize/lib/components/flex/flex_grid.styles.js +13 -6
  213. package/optimize/lib/components/flex/flex_group.js +9 -9
  214. package/optimize/lib/components/flex/flex_item.js +13 -13
  215. package/optimize/lib/components/flex/flex_item.styles.js +107 -122
  216. package/optimize/lib/components/flyout/flyout.js +16 -18
  217. package/optimize/lib/components/header/header_breadcrumbs/header_breadcrumbs.js +3 -5
  218. package/optimize/lib/components/modal/confirm_modal.js +2 -1
  219. package/optimize/lib/components/modal/modal.js +6 -2
  220. package/optimize/lib/components/observer/resize_observer/resize_observer.js +15 -24
  221. package/optimize/lib/components/spacer/spacer.js +1 -2
  222. package/optimize/lib/components/toast/global_toast_list.js +68 -71
  223. package/optimize/lib/components/toast/toast.js +25 -40
  224. package/optimize/lib/components/toast/toast.styles.js +11 -25
  225. package/optimize/lib/services/color/eui_palettes.js +24 -14
  226. package/optimize/lib/services/color/index.js +14 -0
  227. package/optimize/lib/services/hooks/index.js +11 -0
  228. package/optimize/lib/services/hooks/useDeepEqual.js +30 -0
  229. package/optimize/lib/services/index.js +15 -1
  230. package/package.json +2 -2
  231. package/test-env/components/breadcrumbs/_breadcrumb_content.js +363 -0
  232. package/test-env/components/breadcrumbs/_breadcrumb_content.styles.js +55 -0
  233. package/test-env/components/breadcrumbs/breadcrumb.js +11 -326
  234. package/test-env/components/breadcrumbs/breadcrumb.styles.js +5 -29
  235. package/test-env/components/breadcrumbs/breadcrumbs.js +3 -3
  236. package/test-env/components/breadcrumbs/types.js +5 -0
  237. package/test-env/components/button/button_group/button_group.js +16 -2
  238. package/test-env/components/button/button_group/button_group.styles.js +1 -1
  239. package/test-env/components/button/button_group/button_group_button.js +56 -5
  240. package/test-env/components/button/button_group/button_group_button.styles.js +45 -11
  241. package/test-env/components/datagrid/body/cell/data_grid_cell.js +95 -57
  242. package/test-env/components/datagrid/body/cell/data_grid_cell_actions.js +24 -18
  243. package/test-env/components/datagrid/body/cell/data_grid_cell_popover.js +63 -55
  244. package/test-env/components/datagrid/body/cell/data_grid_cell_wrapper.js +32 -31
  245. package/test-env/components/datagrid/body/cell/index.js +2 -2
  246. package/test-env/components/datagrid/body/data_grid_body.js +13 -0
  247. package/test-env/components/datagrid/body/data_grid_body_custom.js +51 -35
  248. package/test-env/components/datagrid/body/data_grid_body_virtualized.js +83 -55
  249. package/test-env/components/datagrid/body/data_grid_row_manager.js +5 -3
  250. package/test-env/components/datagrid/body/footer/use_data_grid_footer.js +1 -2
  251. package/test-env/components/datagrid/body/header/data_grid_control_header_cell.js +8 -4
  252. package/test-env/components/datagrid/body/header/data_grid_header_cell.js +72 -52
  253. package/test-env/components/datagrid/body/header/data_grid_header_row.js +14 -550
  254. package/test-env/components/datagrid/body/header/use_data_grid_header.js +7 -6
  255. package/test-env/components/datagrid/controls/column_selector.js +126 -123
  256. package/test-env/components/datagrid/controls/column_sorting.js +607 -106
  257. package/test-env/components/datagrid/controls/column_sorting_draggable.js +27 -22
  258. package/test-env/components/datagrid/controls/display_selector.js +109 -107
  259. package/test-env/components/datagrid/data_grid.a11y.js +13 -12
  260. package/test-env/components/datagrid/data_grid.js +43 -20
  261. package/test-env/components/datagrid/utils/col_widths.js +9 -5
  262. package/test-env/components/datagrid/utils/focus.js +10 -8
  263. package/test-env/components/datagrid/utils/grid_height_width.js +29 -28
  264. package/test-env/components/datagrid/utils/ref.js +1 -1
  265. package/test-env/components/datagrid/utils/row_heights.js +1 -1
  266. package/test-env/components/datagrid/utils/sorting.js +31 -29
  267. package/test-env/components/date_picker/super_date_picker/super_date_picker.js +9 -0
  268. package/test-env/components/date_picker/super_date_picker/super_update_button.js +57 -29
  269. package/test-env/components/flex/flex_grid.js +21 -7
  270. package/test-env/components/flex/flex_grid.styles.js +13 -6
  271. package/test-env/components/flex/flex_group.js +10 -10
  272. package/test-env/components/flex/flex_item.js +13 -13
  273. package/test-env/components/flex/flex_item.styles.js +107 -122
  274. package/test-env/components/header/header_breadcrumbs/header_breadcrumbs.js +3 -5
  275. package/test-env/components/modal/confirm_modal.js +2 -1
  276. package/test-env/components/modal/modal.js +12 -3
  277. package/test-env/components/spacer/spacer.js +1 -2
  278. package/test-env/components/toast/global_toast_list.js +68 -71
  279. package/test-env/components/toast/toast.js +25 -40
  280. package/test-env/components/toast/toast.styles.js +11 -25
  281. package/test-env/services/color/eui_palettes.js +24 -14
  282. package/test-env/services/color/index.js +14 -0
  283. package/test-env/services/hooks/index.js +11 -0
  284. package/test-env/services/hooks/useDeepEqual.js +30 -0
  285. package/test-env/services/index.js +15 -1
  286. package/src/themes/charts/theme.scss +0 -5
@@ -567,6 +567,19 @@ EuiDataGridBody.propTypes = {
567
567
  renderFooterCellValue: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]),
568
568
  renderCustomGridBody: PropTypes.func,
569
569
  interactiveCellId: PropTypes.string.isRequired,
570
+ sorting: PropTypes.shape({
571
+ /**
572
+ * A function that receives updated column sort details in response to user interactions in the toolbar controls
573
+ */
574
+ onSort: PropTypes.func.isRequired,
575
+ /**
576
+ * An array of the column ids currently being sorted and their sort direction. The array order determines the sort order. `{ id: 'A'; direction: 'asc' }`
577
+ */
578
+ columns: PropTypes.arrayOf(PropTypes.shape({
579
+ id: PropTypes.string.isRequired,
580
+ direction: PropTypes.oneOf(["asc", "desc"]).isRequired
581
+ }).isRequired).isRequired
582
+ }),
570
583
  pagination: PropTypes.any,
571
584
  setVisibleColumns: PropTypes.func.isRequired,
572
585
  switchColumnPos: PropTypes.func.isRequired,
@@ -33,29 +33,30 @@ import { useDefaultColumnWidth, useColumnWidths } from '../utils/col_widths';
33
33
  import { useRowHeightUtils, useDefaultRowHeight } from '../utils/row_heights';
34
34
  import { useDataGridHeader } from './header';
35
35
  import { useDataGridFooter } from './footer';
36
- import { Cell } from './cell';
36
+ import { CellWrapper } from './cell';
37
37
  import { jsx as ___EmotionJSX } from "@emotion/react";
38
38
  export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_ref) {
39
39
  var renderCustomGridBody = _ref.renderCustomGridBody,
40
- leadingControlColumns = _ref.leadingControlColumns,
41
- trailingControlColumns = _ref.trailingControlColumns,
42
- columns = _ref.columns,
43
- visibleColCount = _ref.visibleColCount,
44
- schema = _ref.schema,
45
- schemaDetectors = _ref.schemaDetectors,
46
- visibleRows = _ref.visibleRows,
47
40
  renderCellValue = _ref.renderCellValue,
48
41
  cellContext = _ref.cellContext,
49
42
  renderCellPopover = _ref.renderCellPopover,
50
43
  renderFooterCellValue = _ref.renderFooterCellValue,
51
44
  interactiveCellId = _ref.interactiveCellId,
45
+ visibleRows = _ref.visibleRows,
46
+ visibleColCount = _ref.visibleColCount,
47
+ leadingControlColumns = _ref.leadingControlColumns,
48
+ trailingControlColumns = _ref.trailingControlColumns,
49
+ columns = _ref.columns,
52
50
  setVisibleColumns = _ref.setVisibleColumns,
53
51
  switchColumnPos = _ref.switchColumnPos,
54
52
  onColumnResize = _ref.onColumnResize,
55
- gridWidth = _ref.gridWidth,
56
- gridStyles = _ref.gridStyles,
53
+ schema = _ref.schema,
54
+ schemaDetectors = _ref.schemaDetectors,
55
+ sorting = _ref.sorting,
57
56
  pagination = _ref.pagination,
58
- rowHeightsOptions = _ref.rowHeightsOptions;
57
+ rowHeightsOptions = _ref.rowHeightsOptions,
58
+ gridWidth = _ref.gridWidth,
59
+ gridStyles = _ref.gridStyles;
59
60
  /**
60
61
  * Columns & widths
61
62
  */
@@ -94,14 +95,15 @@ export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_r
94
95
  * Header & footer
95
96
  */
96
97
  var _useDataGridHeader = useDataGridHeader({
97
- switchColumnPos: switchColumnPos,
98
- setVisibleColumns: setVisibleColumns,
99
98
  leadingControlColumns: leadingControlColumns,
100
99
  trailingControlColumns: trailingControlColumns,
101
100
  columns: columns,
102
101
  columnWidths: columnWidths,
103
102
  defaultColumnWidth: defaultColumnWidth,
104
103
  setColumnWidth: setColumnWidth,
104
+ setVisibleColumns: setVisibleColumns,
105
+ switchColumnPos: switchColumnPos,
106
+ sorting: sorting,
105
107
  schema: schema,
106
108
  schemaDetectors: schemaDetectors
107
109
  }),
@@ -124,25 +126,27 @@ export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_r
124
126
  /**
125
127
  * Cell render fn
126
128
  */
127
- var cellProps = {
128
- schema: schema,
129
- schemaDetectors: schemaDetectors,
130
- pagination: pagination,
131
- columns: columns,
132
- leadingControlColumns: leadingControlColumns,
133
- trailingControlColumns: trailingControlColumns,
134
- visibleColCount: visibleColCount,
135
- columnWidths: columnWidths,
136
- defaultColumnWidth: defaultColumnWidth,
137
- renderCellValue: renderCellValue,
138
- cellContext: cellContext,
139
- renderCellPopover: renderCellPopover,
140
- interactiveCellId: interactiveCellId,
141
- setRowHeight: setRowHeight,
142
- rowHeightsOptions: rowHeightsOptions,
143
- rowHeightUtils: rowHeightUtils
144
- };
145
- var _Cell = useCallback(function (_ref2) {
129
+ var cellProps = useMemo(function () {
130
+ return {
131
+ schema: schema,
132
+ schemaDetectors: schemaDetectors,
133
+ pagination: pagination,
134
+ columns: columns,
135
+ leadingControlColumns: leadingControlColumns,
136
+ trailingControlColumns: trailingControlColumns,
137
+ visibleColCount: visibleColCount,
138
+ columnWidths: columnWidths,
139
+ defaultColumnWidth: defaultColumnWidth,
140
+ renderCellValue: renderCellValue,
141
+ cellContext: cellContext,
142
+ renderCellPopover: renderCellPopover,
143
+ interactiveCellId: interactiveCellId,
144
+ setRowHeight: setRowHeight,
145
+ rowHeightsOptions: rowHeightsOptions,
146
+ rowHeightUtils: rowHeightUtils
147
+ };
148
+ }, [schema, schemaDetectors, pagination, columns, leadingControlColumns, trailingControlColumns, visibleColCount, columnWidths, defaultColumnWidth, renderCellValue, cellContext, renderCellPopover, interactiveCellId, setRowHeight, rowHeightsOptions, rowHeightUtils]);
149
+ var Cell = useCallback(function (_ref2) {
146
150
  var colIndex = _ref2.colIndex,
147
151
  visibleRowIndex = _ref2.visibleRowIndex,
148
152
  rest = _objectWithoutProperties(_ref2, _excluded);
@@ -154,9 +158,8 @@ export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_r
154
158
  visibleRowIndex: visibleRowIndex,
155
159
  style: style
156
160
  }, cellProps);
157
- return ___EmotionJSX(Cell, _extends({}, props, rest));
158
- }, [].concat(_toConsumableArray(Object.values(cellProps)), [getRowHeight]) // eslint-disable-line react-hooks/exhaustive-deps
159
- );
161
+ return ___EmotionJSX(CellWrapper, _extends({}, props, rest));
162
+ }, [cellProps, getRowHeight, rowHeightUtils, rowHeightsOptions]);
160
163
 
161
164
  // Allow consumers to pass custom props/attributes/listeners etc. to the wrapping div
162
165
  var _useState = useState({}),
@@ -168,7 +171,7 @@ export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_r
168
171
  }), headerRow, renderCustomGridBody({
169
172
  visibleColumns: visibleColumns,
170
173
  visibleRowData: visibleRows,
171
- Cell: _Cell,
174
+ Cell: Cell,
172
175
  setCustomGridBodyProps: setCustomGridBodyProps
173
176
  }), footerRow);
174
177
  };
@@ -712,6 +715,19 @@ EuiDataGridBodyCustomRender.propTypes = {
712
715
  renderFooterCellValue: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]),
713
716
  renderCustomGridBody: PropTypes.func,
714
717
  interactiveCellId: PropTypes.string.isRequired,
718
+ sorting: PropTypes.shape({
719
+ /**
720
+ * A function that receives updated column sort details in response to user interactions in the toolbar controls
721
+ */
722
+ onSort: PropTypes.func.isRequired,
723
+ /**
724
+ * An array of the column ids currently being sorted and their sort direction. The array order determines the sort order. `{ id: 'A'; direction: 'asc' }`
725
+ */
726
+ columns: PropTypes.arrayOf(PropTypes.shape({
727
+ id: PropTypes.string.isRequired,
728
+ direction: PropTypes.oneOf(["asc", "desc"]).isRequired
729
+ }).isRequired).isRequired
730
+ }),
715
731
  pagination: PropTypes.any,
716
732
  setVisibleColumns: PropTypes.func.isRequired,
717
733
  switchColumnPos: PropTypes.func.isRequired,
@@ -1,9 +1,9 @@
1
1
  var _excluded = ["children", "style"];
2
2
  function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
3
3
  function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
4
+ import PropTypes from "prop-types";
4
5
  function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
5
6
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
6
- import PropTypes from "prop-types";
7
7
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
8
8
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
9
9
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
@@ -18,12 +18,13 @@ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input ==
18
18
  */
19
19
 
20
20
  import classNames from 'classnames';
21
- import React, { forwardRef, createContext, useContext, useEffect, useRef } from 'react';
21
+ import React, { forwardRef, createContext, useCallback, useContext, useEffect, useRef, useMemo, memo } from 'react';
22
22
  import { VariableSizeGrid as Grid } from 'react-window';
23
+ import { useDeepEqual } from '../../../services';
23
24
  import { useResizeObserver } from '../../observer/resize_observer';
24
25
  import { useDataGridHeader } from './header';
25
26
  import { useDataGridFooter } from './footer';
26
- import { Cell } from './cell';
27
+ import { CellWrapper } from './cell';
27
28
  import { useRowManager } from './data_grid_row_manager';
28
29
  import { useFinalGridDimensions, useUnconstrainedHeight, useVirtualizeContainerWidth } from '../utils/grid_height_width';
29
30
  import { useDefaultColumnWidth, useColumnWidths } from '../utils/col_widths';
@@ -31,21 +32,25 @@ import { useRowHeightUtils, useDefaultRowHeight } from '../utils/row_heights';
31
32
  import { useScrollBars, useScroll } from '../utils/scrolling';
32
33
  import { IS_JEST_ENVIRONMENT } from '../../../utils';
33
34
  import { jsx as ___EmotionJSX } from "@emotion/react";
34
- export var _Cell = function _Cell(_ref) {
35
+ export var Cell = /*#__PURE__*/memo(function (_ref) {
35
36
  var columnIndex = _ref.columnIndex,
36
37
  rowIndex = _ref.rowIndex,
37
38
  style = _ref.style,
38
39
  data = _ref.data;
39
- var _useContext = useContext(DataGridWrapperRowsContext),
40
- headerRowHeight = _useContext.headerRowHeight;
41
- return ___EmotionJSX(Cell, _extends({
40
+ var memoizedStyles = useDeepEqual(style);
41
+ var cellStyles = useMemo(function () {
42
+ var headerRowHeight = data.headerRowHeight;
43
+ return _objectSpread(_objectSpread({}, memoizedStyles), {}, {
44
+ top: "".concat(parseFloat(memoizedStyles.top) + headerRowHeight, "px")
45
+ });
46
+ }, [memoizedStyles, data]);
47
+ return ___EmotionJSX(CellWrapper, _extends({
42
48
  colIndex: columnIndex,
43
49
  visibleRowIndex: rowIndex,
44
- style: _objectSpread(_objectSpread({}, style), {}, {
45
- top: "".concat(parseFloat(style.top) + headerRowHeight, "px")
46
- })
50
+ style: cellStyles
47
51
  }, data));
48
- };
52
+ });
53
+ Cell.displayName = 'Cell';
49
54
 
50
55
  // Context is required to pass props to react-window's innerElementType
51
56
  // @see https://github.com/bvaughn/react-window/issues/404
@@ -54,28 +59,27 @@ export var DataGridWrapperRowsContext = /*#__PURE__*/createContext({
54
59
  headerRowHeight: 0,
55
60
  footerRow: null
56
61
  });
57
- var InnerElement = /*#__PURE__*/forwardRef(function (_ref2, ref) {
62
+ var InnerElement = /*#__PURE__*/memo( /*#__PURE__*/forwardRef(function (_ref2, ref) {
58
63
  var children = _ref2.children,
59
64
  style = _ref2.style,
60
65
  rest = _objectWithoutProperties(_ref2, _excluded);
61
- var _useContext2 = useContext(DataGridWrapperRowsContext),
62
- headerRowHeight = _useContext2.headerRowHeight,
63
- headerRow = _useContext2.headerRow,
64
- footerRow = _useContext2.footerRow;
66
+ var _useContext = useContext(DataGridWrapperRowsContext),
67
+ headerRowHeight = _useContext.headerRowHeight,
68
+ headerRow = _useContext.headerRow,
69
+ footerRow = _useContext.footerRow;
70
+ var memoizedStyles = useDeepEqual(style);
71
+ var innerElementStyles = useMemo(function () {
72
+ return _objectSpread(_objectSpread({}, memoizedStyles), {}, {
73
+ height: memoizedStyles.height + headerRowHeight
74
+ });
75
+ }, [memoizedStyles, headerRowHeight]);
65
76
  return ___EmotionJSX(React.Fragment, null, ___EmotionJSX("div", _extends({
66
77
  ref: ref,
67
- style: _objectSpread(_objectSpread({}, style), {}, {
68
- height: style.height + headerRowHeight
69
- })
78
+ style: innerElementStyles
70
79
  }, rest), headerRow, children), footerRow);
71
- });
72
- InnerElement.propTypes = {
73
- style: PropTypes.shape({
74
- height: PropTypes.number.isRequired
75
- }).isRequired
76
- };
80
+ }));
77
81
  InnerElement.displayName = 'EuiDataGridInnerElement';
78
- export var EuiDataGridBodyVirtualized = function EuiDataGridBodyVirtualized(_ref3) {
82
+ export var EuiDataGridBodyVirtualized = /*#__PURE__*/memo(function (_ref3) {
79
83
  var leadingControlColumns = _ref3.leadingControlColumns,
80
84
  trailingControlColumns = _ref3.trailingControlColumns,
81
85
  columns = _ref3.columns,
@@ -93,6 +97,7 @@ export var EuiDataGridBodyVirtualized = function EuiDataGridBodyVirtualized(_ref
93
97
  renderFooterCellValue = _ref3.renderFooterCellValue,
94
98
  interactiveCellId = _ref3.interactiveCellId,
95
99
  pagination = _ref3.pagination,
100
+ sorting = _ref3.sorting,
96
101
  setVisibleColumns = _ref3.setVisibleColumns,
97
102
  switchColumnPos = _ref3.switchColumnPos,
98
103
  onColumnResize = _ref3.onColumnResize,
@@ -142,14 +147,15 @@ export var EuiDataGridBodyVirtualized = function EuiDataGridBodyVirtualized(_ref
142
147
  * Header & footer
143
148
  */
144
149
  var _useDataGridHeader = useDataGridHeader({
145
- switchColumnPos: switchColumnPos,
146
- setVisibleColumns: setVisibleColumns,
147
150
  leadingControlColumns: leadingControlColumns,
148
151
  trailingControlColumns: trailingControlColumns,
149
152
  columns: columns,
150
153
  columnWidths: columnWidths,
151
154
  defaultColumnWidth: defaultColumnWidth,
152
155
  setColumnWidth: setColumnWidth,
156
+ setVisibleColumns: setVisibleColumns,
157
+ switchColumnPos: switchColumnPos,
158
+ sorting: sorting,
153
159
  schema: schema,
154
160
  schemaDetectors: schemaDetectors
155
161
  }),
@@ -257,29 +263,13 @@ export var EuiDataGridBodyVirtualized = function EuiDataGridBodyVirtualized(_ref
257
263
  gridRef.current.resetAfterRowIndex(0);
258
264
  }
259
265
  }, [gridRef, getRowHeight]);
260
- return IS_JEST_ENVIRONMENT || finalWidth > 0 ? ___EmotionJSX(DataGridWrapperRowsContext.Provider, {
261
- value: {
262
- headerRowHeight: headerRowHeight,
263
- headerRow: headerRow,
264
- footerRow: footerRow
265
- }
266
- }, ___EmotionJSX(Grid, _extends({}, virtualizationOptions ? virtualizationOptions : {}, {
267
- ref: gridRef,
268
- className: classNames('euiDataGrid__virtualized', virtualizationOptions === null || virtualizationOptions === void 0 ? void 0 : virtualizationOptions.className),
269
- onItemsRendered: function onItemsRendered(itemsRendered) {
270
- var _virtualizationOption;
271
- gridItemsRendered.current = itemsRendered;
272
- virtualizationOptions === null || virtualizationOptions === void 0 ? void 0 : (_virtualizationOption = virtualizationOptions.onItemsRendered) === null || _virtualizationOption === void 0 ? void 0 : _virtualizationOption.call(virtualizationOptions, itemsRendered);
273
- },
274
- innerElementType: InnerElement,
275
- outerRef: outerGridRef,
276
- innerRef: innerGridRef,
277
- columnCount: visibleColCount,
278
- width: finalWidth,
279
- columnWidth: getColumnWidth,
280
- height: finalHeight,
281
- rowHeight: getRowHeight,
282
- itemData: {
266
+ var onItemsRendered = useCallback(function (itemsRendered) {
267
+ var _virtualizationOption;
268
+ gridItemsRendered.current = itemsRendered;
269
+ virtualizationOptions === null || virtualizationOptions === void 0 ? void 0 : (_virtualizationOption = virtualizationOptions.onItemsRendered) === null || _virtualizationOption === void 0 ? void 0 : _virtualizationOption.call(virtualizationOptions, itemsRendered);
270
+ }, [gridItemsRendered, virtualizationOptions]);
271
+ var itemData = useMemo(function () {
272
+ return {
283
273
  schemaDetectors: schemaDetectors,
284
274
  setRowHeight: setRowHeight,
285
275
  leadingControlColumns: leadingControlColumns,
@@ -296,11 +286,35 @@ export var EuiDataGridBodyVirtualized = function EuiDataGridBodyVirtualized(_ref
296
286
  rowHeightsOptions: rowHeightsOptions,
297
287
  rowHeightUtils: rowHeightUtils,
298
288
  rowManager: rowManager,
299
- pagination: pagination
300
- },
289
+ pagination: pagination,
290
+ headerRowHeight: headerRowHeight
291
+ };
292
+ }, [schemaDetectors, setRowHeight, leadingControlColumns, trailingControlColumns, columns, visibleColCount, schema, columnWidths, defaultColumnWidth, renderCellValue, cellContext, renderCellPopover, interactiveCellId, rowHeightsOptions, rowHeightUtils, rowManager, pagination, headerRowHeight]);
293
+ var rowWrapperContextValue = useMemo(function () {
294
+ return {
295
+ headerRowHeight: headerRowHeight,
296
+ headerRow: headerRow,
297
+ footerRow: footerRow
298
+ };
299
+ }, [headerRowHeight, headerRow, footerRow]);
300
+ return IS_JEST_ENVIRONMENT || finalWidth > 0 ? ___EmotionJSX(DataGridWrapperRowsContext.Provider, {
301
+ value: rowWrapperContextValue
302
+ }, ___EmotionJSX(Grid, _extends({}, virtualizationOptions, {
303
+ ref: gridRef,
304
+ className: classNames('euiDataGrid__virtualized', virtualizationOptions === null || virtualizationOptions === void 0 ? void 0 : virtualizationOptions.className),
305
+ onItemsRendered: onItemsRendered,
306
+ innerElementType: InnerElement,
307
+ outerRef: outerGridRef,
308
+ innerRef: innerGridRef,
309
+ columnCount: visibleColCount,
310
+ width: finalWidth,
311
+ columnWidth: getColumnWidth,
312
+ height: finalHeight,
313
+ rowHeight: getRowHeight,
314
+ itemData: itemData,
301
315
  rowCount: IS_JEST_ENVIRONMENT || headerRowHeight > 0 ? visibleRowCount : 0
302
- }), _Cell), scrollBorderOverlay) : null;
303
- };
316
+ }), Cell), scrollBorderOverlay) : null;
317
+ });
304
318
  EuiDataGridBodyVirtualized.propTypes = {
305
319
  leadingControlColumns: PropTypes.arrayOf(PropTypes.shape({
306
320
  /**
@@ -841,6 +855,19 @@ EuiDataGridBodyVirtualized.propTypes = {
841
855
  renderFooterCellValue: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]),
842
856
  renderCustomGridBody: PropTypes.func,
843
857
  interactiveCellId: PropTypes.string.isRequired,
858
+ sorting: PropTypes.shape({
859
+ /**
860
+ * A function that receives updated column sort details in response to user interactions in the toolbar controls
861
+ */
862
+ onSort: PropTypes.func.isRequired,
863
+ /**
864
+ * An array of the column ids currently being sorted and their sort direction. The array order determines the sort order. `{ id: 'A'; direction: 'asc' }`
865
+ */
866
+ columns: PropTypes.arrayOf(PropTypes.shape({
867
+ id: PropTypes.string.isRequired,
868
+ direction: PropTypes.oneOf(["asc", "desc"]).isRequired
869
+ }).isRequired).isRequired
870
+ }),
844
871
  pagination: PropTypes.any,
845
872
  setVisibleColumns: PropTypes.func.isRequired,
846
873
  switchColumnPos: PropTypes.func.isRequired,
@@ -926,4 +953,5 @@ EuiDataGridBodyVirtualized.propTypes = {
926
953
  gridRef: PropTypes.any.isRequired,
927
954
  gridItemsRendered: PropTypes.any.isRequired,
928
955
  wrapperRef: PropTypes.any.isRequired
929
- };
956
+ };
957
+ EuiDataGridBodyVirtualized.displayName = 'EuiDataGridBodyVirtualized';
@@ -12,7 +12,7 @@ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len
12
12
  * Side Public License, v 1.
13
13
  */
14
14
 
15
- import { useRef, useCallback } from 'react';
15
+ import { useRef, useCallback, useMemo } from 'react';
16
16
  import { useUpdateEffect } from '../../../services';
17
17
  export var useRowManager = function useRowManager(_ref) {
18
18
  var innerGridRef = _ref.innerGridRef,
@@ -93,7 +93,9 @@ export var useRowManager = function useRowManager(_ref) {
93
93
  });
94
94
  }
95
95
  }, [rowClasses]);
96
- return {
97
- getRow: getRow
98
- };
96
+ return useMemo(function () {
97
+ return {
98
+ getRow: getRow
99
+ };
100
+ }, [getRow]);
99
101
  };
@@ -38,8 +38,7 @@ export var useDataGridFooter = function useDataGridFooter(props) {
38
38
  ref: setFooterRowRef,
39
39
  renderCellValue: renderFooterCellValue
40
40
  }, footerProps));
41
- }, Object.values(props)); // eslint-disable-line react-hooks/exhaustive-deps
42
-
41
+ }, [props]);
43
42
  return {
44
43
  footerRow: footerRow,
45
44
  footerRowHeight: footerRowHeight
@@ -7,12 +7,12 @@ function _extends() { _extends = Object.assign ? Object.assign.bind() : function
7
7
  * Side Public License, v 1.
8
8
  */
9
9
 
10
- import React from 'react';
10
+ import React, { memo } from 'react';
11
11
  import PropTypes from "prop-types";
12
12
  import classNames from 'classnames';
13
13
  import { EuiDataGridHeaderCellWrapper } from './data_grid_header_cell_wrapper';
14
14
  import { jsx as ___EmotionJSX } from "@emotion/react";
15
- export var EuiDataGridControlHeaderCell = function EuiDataGridControlHeaderCell(_ref) {
15
+ export var EuiDataGridControlHeaderCell = /*#__PURE__*/memo(function (_ref) {
16
16
  var controlColumn = _ref.controlColumn,
17
17
  index = _ref.index;
18
18
  var HeaderCellRender = controlColumn.headerCellRender,
@@ -27,7 +27,7 @@ export var EuiDataGridControlHeaderCell = function EuiDataGridControlHeaderCell(
27
27
  }), ___EmotionJSX("div", {
28
28
  className: "euiDataGridHeaderCell__content"
29
29
  }, ___EmotionJSX(HeaderCellRender, null)));
30
- };
30
+ });
31
31
  EuiDataGridControlHeaderCell.propTypes = {
32
32
  index: PropTypes.number.isRequired,
33
33
  controlColumn: PropTypes.shape({
@@ -60,4 +60,5 @@ EuiDataGridControlHeaderCell.propTypes = {
60
60
  */
61
61
  footerCellProps: PropTypes.any
62
62
  }).isRequired
63
- };
63
+ };
64
+ EuiDataGridControlHeaderCell.displayName = 'EuiDataGridControlHeaderCell';