@elastic/eui 95.10.1 → 95.12.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 (371) hide show
  1. package/README.md +1 -69
  2. package/dist/eui_theme_dark.css +0 -924
  3. package/dist/eui_theme_dark.min.css +1 -1
  4. package/dist/eui_theme_light.css +0 -924
  5. package/dist/eui_theme_light.min.css +1 -1
  6. package/es/components/basic_table/basic_table.js +43 -35
  7. package/es/components/basic_table/collapsed_item_actions.js +24 -31
  8. package/es/components/datagrid/body/cell/data_grid_cell.js +212 -94
  9. package/es/components/datagrid/body/cell/data_grid_cell.styles.js +110 -0
  10. package/es/components/datagrid/body/cell/data_grid_cell_actions.js +13 -3
  11. package/es/components/datagrid/body/cell/data_grid_cell_actions.styles.js +33 -0
  12. package/es/components/datagrid/body/cell/data_grid_cell_popover.js +21 -12
  13. package/es/components/datagrid/body/cell/data_grid_cell_popover.styles.js +19 -0
  14. package/es/components/datagrid/body/cell/focus_utils.js +18 -20
  15. package/es/components/datagrid/body/data_grid_body.js +20 -4
  16. package/es/components/datagrid/body/data_grid_body.styles.js +26 -0
  17. package/es/components/datagrid/body/data_grid_body_custom.js +23 -8
  18. package/es/components/datagrid/body/data_grid_body_virtualized.js +23 -8
  19. package/es/components/datagrid/body/footer/data_grid_footer.styles.js +24 -0
  20. package/es/components/datagrid/body/footer/data_grid_footer_row.js +24 -11
  21. package/es/components/datagrid/body/header/column_actions.js +16 -4
  22. package/es/components/datagrid/body/header/data_grid_column_resizer.js +14 -7
  23. package/es/components/datagrid/body/header/data_grid_column_resizer.styles.js +36 -0
  24. package/es/components/datagrid/body/header/data_grid_control_header_cell.js +6 -5
  25. package/es/components/datagrid/body/header/data_grid_header_cell.js +42 -66
  26. package/es/components/datagrid/body/header/data_grid_header_cell.styles.js +27 -0
  27. package/es/components/datagrid/body/header/data_grid_header_cell_wrapper.js +9 -3
  28. package/es/components/datagrid/body/header/data_grid_header_cell_wrapper.styles.js +27 -0
  29. package/es/components/datagrid/body/header/data_grid_header_row.js +12 -2
  30. package/es/components/datagrid/body/header/data_grid_header_row.styles.js +21 -0
  31. package/es/components/datagrid/controls/column_selector.js +17 -8
  32. package/es/components/datagrid/controls/column_selector.styles.js +22 -0
  33. package/es/components/datagrid/controls/column_sorting.js +7 -2
  34. package/es/components/datagrid/controls/column_sorting.styles.js +35 -0
  35. package/es/components/datagrid/controls/column_sorting_draggable.js +19 -14
  36. package/es/components/datagrid/controls/data_grid_toolbar.js +8 -1
  37. package/es/components/datagrid/controls/data_grid_toolbar.styles.js +18 -0
  38. package/es/components/datagrid/controls/data_grid_toolbar_control.js +27 -27
  39. package/es/components/datagrid/controls/display_selector.js +14 -3
  40. package/es/components/datagrid/controls/fullscreen_selector.js +8 -5
  41. package/es/components/datagrid/controls/fullscreen_selector.styles.js +20 -0
  42. package/es/components/datagrid/controls/keyboard_shortcuts.js +7 -3
  43. package/es/components/datagrid/controls/keyboard_shortcuts.styles.js +18 -0
  44. package/es/components/datagrid/data_grid.a11y.js +1 -0
  45. package/es/components/datagrid/data_grid.js +17 -9
  46. package/es/components/datagrid/data_grid.stories.utils.js +1422 -0
  47. package/es/components/datagrid/data_grid.styles.js +88 -0
  48. package/es/components/datagrid/{utils → pagination}/data_grid_pagination.js +30 -30
  49. package/es/components/datagrid/pagination/data_grid_pagination.styles.js +16 -0
  50. package/es/components/datagrid/pagination/index.js +9 -0
  51. package/es/components/datagrid/utils/row_heights.js +10 -36
  52. package/es/components/datagrid/utils/scrolling.js +14 -7
  53. package/es/components/datagrid/utils/scrolling.styles.js +30 -0
  54. package/es/components/date_picker/date_picker.js +1 -1
  55. package/es/components/flyout/flyout_resizable.js +6 -2
  56. package/es/components/flyout/flyout_resizable.styles.js +34 -5
  57. package/es/components/popover/popover.js +1 -1
  58. package/es/components/provider/provider.js +16 -13
  59. package/es/components/provider/system_color_mode/index.js +9 -0
  60. package/es/components/provider/system_color_mode/system_color_mode_provider.js +49 -0
  61. package/es/components/resizable_container/resizable_button.js +9 -2
  62. package/es/components/resizable_container/resizable_button.styles.js +19 -6
  63. package/es/components/table/table_header_cell.js +10 -3
  64. package/es/components/table/table_header_cell_checkbox.js +5 -3
  65. package/es/components/table/table_row_cell.js +10 -3
  66. package/es/components/table/table_row_cell_checkbox.js +5 -3
  67. package/es/components/text/text.js +25 -9
  68. package/es/components/text/text_align.js +19 -6
  69. package/es/components/text/text_color.js +14 -11
  70. package/es/components/text/types.js +1 -0
  71. package/es/services/copy/index.js +10 -0
  72. package/es/services/copy/tabular_copy.js +103 -0
  73. package/es/services/index.js +1 -1
  74. package/eui.d.ts +692 -124
  75. package/i18ntokens.json +432 -396
  76. package/lib/components/basic_table/basic_table.js +42 -34
  77. package/lib/components/basic_table/collapsed_item_actions.js +23 -30
  78. package/lib/components/datagrid/body/cell/data_grid_cell.js +209 -91
  79. package/lib/components/datagrid/body/cell/data_grid_cell.styles.js +114 -0
  80. package/lib/components/datagrid/body/cell/data_grid_cell_actions.js +13 -3
  81. package/lib/components/datagrid/body/cell/data_grid_cell_actions.styles.js +38 -0
  82. package/lib/components/datagrid/body/cell/data_grid_cell_popover.js +20 -11
  83. package/lib/components/datagrid/body/cell/data_grid_cell_popover.styles.js +24 -0
  84. package/lib/components/datagrid/body/cell/focus_utils.js +17 -19
  85. package/lib/components/datagrid/body/data_grid_body.js +20 -4
  86. package/lib/components/datagrid/body/data_grid_body.styles.js +30 -0
  87. package/lib/components/datagrid/body/data_grid_body_custom.js +23 -8
  88. package/lib/components/datagrid/body/data_grid_body_virtualized.js +23 -8
  89. package/lib/components/datagrid/body/footer/data_grid_footer.styles.js +30 -0
  90. package/lib/components/datagrid/body/footer/data_grid_footer_row.js +23 -10
  91. package/lib/components/datagrid/body/header/column_actions.js +16 -4
  92. package/lib/components/datagrid/body/header/data_grid_column_resizer.js +14 -7
  93. package/lib/components/datagrid/body/header/data_grid_column_resizer.styles.js +39 -0
  94. package/lib/components/datagrid/body/header/data_grid_control_header_cell.js +6 -5
  95. package/lib/components/datagrid/body/header/data_grid_header_cell.js +49 -74
  96. package/lib/components/datagrid/body/header/data_grid_header_cell.styles.js +32 -0
  97. package/lib/components/datagrid/body/header/data_grid_header_cell_wrapper.js +8 -2
  98. package/lib/components/datagrid/body/header/data_grid_header_cell_wrapper.styles.js +32 -0
  99. package/lib/components/datagrid/body/header/data_grid_header_row.js +12 -2
  100. package/lib/components/datagrid/body/header/data_grid_header_row.styles.js +27 -0
  101. package/lib/components/datagrid/controls/column_selector.js +17 -8
  102. package/lib/components/datagrid/controls/column_selector.styles.js +28 -0
  103. package/lib/components/datagrid/controls/column_sorting.js +7 -2
  104. package/lib/components/datagrid/controls/column_sorting.styles.js +41 -0
  105. package/lib/components/datagrid/controls/column_sorting_draggable.js +19 -14
  106. package/lib/components/datagrid/controls/data_grid_toolbar.js +8 -1
  107. package/lib/components/datagrid/controls/data_grid_toolbar.styles.js +24 -0
  108. package/lib/components/datagrid/controls/data_grid_toolbar_control.js +27 -27
  109. package/lib/components/datagrid/controls/display_selector.js +13 -2
  110. package/lib/components/datagrid/controls/fullscreen_selector.js +7 -4
  111. package/lib/components/datagrid/controls/fullscreen_selector.styles.js +26 -0
  112. package/lib/components/datagrid/controls/keyboard_shortcuts.js +6 -2
  113. package/lib/components/datagrid/controls/keyboard_shortcuts.styles.js +24 -0
  114. package/lib/components/datagrid/data_grid.a11y.js +1 -0
  115. package/lib/components/datagrid/data_grid.js +16 -8
  116. package/lib/components/datagrid/data_grid.stories.utils.js +1426 -0
  117. package/lib/components/datagrid/data_grid.styles.js +94 -0
  118. package/lib/components/datagrid/{utils → pagination}/data_grid_pagination.js +30 -30
  119. package/lib/components/datagrid/pagination/data_grid_pagination.styles.js +22 -0
  120. package/lib/components/datagrid/pagination/index.js +18 -0
  121. package/lib/components/datagrid/utils/row_heights.js +11 -36
  122. package/lib/components/datagrid/utils/scrolling.js +14 -7
  123. package/lib/components/datagrid/utils/scrolling.styles.js +36 -0
  124. package/lib/components/date_picker/date_picker.js +1 -1
  125. package/lib/components/flyout/flyout_resizable.js +6 -2
  126. package/lib/components/flyout/flyout_resizable.styles.js +34 -5
  127. package/lib/components/popover/popover.js +1 -1
  128. package/lib/components/provider/provider.js +16 -13
  129. package/lib/components/provider/system_color_mode/index.js +12 -0
  130. package/lib/components/provider/system_color_mode/system_color_mode_provider.js +54 -0
  131. package/lib/components/resizable_container/resizable_button.js +9 -2
  132. package/lib/components/resizable_container/resizable_button.styles.js +19 -6
  133. package/lib/components/table/table_header_cell.js +10 -3
  134. package/lib/components/table/table_header_cell_checkbox.js +5 -3
  135. package/lib/components/table/table_row_cell.js +10 -3
  136. package/lib/components/table/table_row_cell_checkbox.js +5 -3
  137. package/lib/components/text/text.js +25 -9
  138. package/lib/components/text/text_align.js +19 -6
  139. package/lib/components/text/text_color.js +14 -11
  140. package/lib/components/text/types.js +5 -0
  141. package/lib/services/copy/index.js +25 -0
  142. package/lib/services/copy/tabular_copy.js +111 -0
  143. package/lib/services/index.js +12 -8
  144. package/optimize/es/components/basic_table/basic_table.js +43 -35
  145. package/optimize/es/components/basic_table/collapsed_item_actions.js +24 -31
  146. package/optimize/es/components/datagrid/body/cell/data_grid_cell.js +98 -88
  147. package/optimize/es/components/datagrid/body/cell/data_grid_cell.styles.js +110 -0
  148. package/optimize/es/components/datagrid/body/cell/data_grid_cell_actions.js +13 -3
  149. package/optimize/es/components/datagrid/body/cell/data_grid_cell_actions.styles.js +33 -0
  150. package/optimize/es/components/datagrid/body/cell/data_grid_cell_popover.js +21 -12
  151. package/optimize/es/components/datagrid/body/cell/data_grid_cell_popover.styles.js +19 -0
  152. package/optimize/es/components/datagrid/body/cell/focus_utils.js +18 -20
  153. package/optimize/es/components/datagrid/body/data_grid_body.js +9 -2
  154. package/optimize/es/components/datagrid/body/data_grid_body.styles.js +26 -0
  155. package/optimize/es/components/datagrid/body/data_grid_body_custom.js +12 -6
  156. package/optimize/es/components/datagrid/body/data_grid_body_virtualized.js +12 -6
  157. package/optimize/es/components/datagrid/body/footer/data_grid_footer.styles.js +24 -0
  158. package/optimize/es/components/datagrid/body/footer/data_grid_footer_row.js +24 -11
  159. package/optimize/es/components/datagrid/body/header/column_actions.js +16 -4
  160. package/optimize/es/components/datagrid/body/header/data_grid_column_resizer.js +14 -7
  161. package/optimize/es/components/datagrid/body/header/data_grid_column_resizer.styles.js +36 -0
  162. package/optimize/es/components/datagrid/body/header/data_grid_control_header_cell.js +5 -5
  163. package/optimize/es/components/datagrid/body/header/data_grid_header_cell.js +42 -61
  164. package/optimize/es/components/datagrid/body/header/data_grid_header_cell.styles.js +27 -0
  165. package/optimize/es/components/datagrid/body/header/data_grid_header_cell_wrapper.js +8 -3
  166. package/optimize/es/components/datagrid/body/header/data_grid_header_cell_wrapper.styles.js +27 -0
  167. package/optimize/es/components/datagrid/body/header/data_grid_header_row.js +12 -2
  168. package/optimize/es/components/datagrid/body/header/data_grid_header_row.styles.js +21 -0
  169. package/optimize/es/components/datagrid/controls/column_selector.js +17 -8
  170. package/optimize/es/components/datagrid/controls/column_selector.styles.js +22 -0
  171. package/optimize/es/components/datagrid/controls/column_sorting.js +7 -2
  172. package/optimize/es/components/datagrid/controls/column_sorting.styles.js +35 -0
  173. package/optimize/es/components/datagrid/controls/column_sorting_draggable.js +19 -14
  174. package/optimize/es/components/datagrid/controls/data_grid_toolbar.js +8 -1
  175. package/optimize/es/components/datagrid/controls/data_grid_toolbar.styles.js +18 -0
  176. package/optimize/es/components/datagrid/controls/data_grid_toolbar_control.js +27 -27
  177. package/optimize/es/components/datagrid/controls/display_selector.js +14 -3
  178. package/optimize/es/components/datagrid/controls/fullscreen_selector.js +8 -5
  179. package/optimize/es/components/datagrid/controls/fullscreen_selector.styles.js +20 -0
  180. package/optimize/es/components/datagrid/controls/keyboard_shortcuts.js +7 -3
  181. package/optimize/es/components/datagrid/controls/keyboard_shortcuts.styles.js +18 -0
  182. package/optimize/es/components/datagrid/data_grid.a11y.js +1 -0
  183. package/optimize/es/components/datagrid/data_grid.js +17 -9
  184. package/optimize/es/components/datagrid/data_grid.stories.utils.js +369 -0
  185. package/optimize/es/components/datagrid/data_grid.styles.js +88 -0
  186. package/optimize/es/components/datagrid/{utils → pagination}/data_grid_pagination.js +30 -30
  187. package/optimize/es/components/datagrid/pagination/data_grid_pagination.styles.js +16 -0
  188. package/optimize/es/components/datagrid/pagination/index.js +9 -0
  189. package/optimize/es/components/datagrid/utils/row_heights.js +10 -36
  190. package/optimize/es/components/datagrid/utils/scrolling.js +14 -7
  191. package/optimize/es/components/datagrid/utils/scrolling.styles.js +30 -0
  192. package/optimize/es/components/date_picker/date_picker.js +1 -1
  193. package/optimize/es/components/flyout/flyout_resizable.js +6 -2
  194. package/optimize/es/components/flyout/flyout_resizable.styles.js +34 -5
  195. package/optimize/es/components/popover/popover.js +1 -1
  196. package/optimize/es/components/provider/provider.js +16 -13
  197. package/optimize/es/components/provider/system_color_mode/index.js +9 -0
  198. package/optimize/es/components/provider/system_color_mode/system_color_mode_provider.js +40 -0
  199. package/optimize/es/components/resizable_container/resizable_button.js +3 -2
  200. package/optimize/es/components/resizable_container/resizable_button.styles.js +19 -6
  201. package/optimize/es/components/table/table_header_cell.js +3 -2
  202. package/optimize/es/components/table/table_header_cell_checkbox.js +3 -2
  203. package/optimize/es/components/table/table_row_cell.js +4 -3
  204. package/optimize/es/components/table/table_row_cell_checkbox.js +3 -2
  205. package/optimize/es/components/text/text.js +9 -4
  206. package/optimize/es/components/text/text_align.js +4 -2
  207. package/optimize/es/components/text/text_color.js +1 -2
  208. package/optimize/es/components/text/types.js +1 -0
  209. package/optimize/es/services/copy/index.js +10 -0
  210. package/optimize/es/services/copy/tabular_copy.js +103 -0
  211. package/optimize/es/services/index.js +1 -1
  212. package/optimize/lib/components/basic_table/basic_table.js +42 -34
  213. package/optimize/lib/components/basic_table/collapsed_item_actions.js +23 -30
  214. package/optimize/lib/components/datagrid/body/cell/data_grid_cell.js +95 -85
  215. package/optimize/lib/components/datagrid/body/cell/data_grid_cell.styles.js +114 -0
  216. package/optimize/lib/components/datagrid/body/cell/data_grid_cell_actions.js +13 -3
  217. package/optimize/lib/components/datagrid/body/cell/data_grid_cell_actions.styles.js +39 -0
  218. package/optimize/lib/components/datagrid/body/cell/data_grid_cell_popover.js +20 -11
  219. package/optimize/lib/components/datagrid/body/cell/data_grid_cell_popover.styles.js +25 -0
  220. package/optimize/lib/components/datagrid/body/cell/focus_utils.js +17 -19
  221. package/optimize/lib/components/datagrid/body/data_grid_body.js +9 -2
  222. package/optimize/lib/components/datagrid/body/data_grid_body.styles.js +30 -0
  223. package/optimize/lib/components/datagrid/body/data_grid_body_custom.js +12 -6
  224. package/optimize/lib/components/datagrid/body/data_grid_body_virtualized.js +12 -6
  225. package/optimize/lib/components/datagrid/body/footer/data_grid_footer.styles.js +30 -0
  226. package/optimize/lib/components/datagrid/body/footer/data_grid_footer_row.js +22 -9
  227. package/optimize/lib/components/datagrid/body/header/column_actions.js +16 -4
  228. package/optimize/lib/components/datagrid/body/header/data_grid_column_resizer.js +14 -7
  229. package/optimize/lib/components/datagrid/body/header/data_grid_column_resizer.styles.js +39 -0
  230. package/optimize/lib/components/datagrid/body/header/data_grid_control_header_cell.js +5 -5
  231. package/optimize/lib/components/datagrid/body/header/data_grid_header_cell.js +45 -63
  232. package/optimize/lib/components/datagrid/body/header/data_grid_header_cell.styles.js +32 -0
  233. package/optimize/lib/components/datagrid/body/header/data_grid_header_cell_wrapper.js +7 -2
  234. package/optimize/lib/components/datagrid/body/header/data_grid_header_cell_wrapper.styles.js +32 -0
  235. package/optimize/lib/components/datagrid/body/header/data_grid_header_row.js +12 -2
  236. package/optimize/lib/components/datagrid/body/header/data_grid_header_row.styles.js +27 -0
  237. package/optimize/lib/components/datagrid/controls/column_selector.js +17 -8
  238. package/optimize/lib/components/datagrid/controls/column_selector.styles.js +28 -0
  239. package/optimize/lib/components/datagrid/controls/column_sorting.js +7 -2
  240. package/optimize/lib/components/datagrid/controls/column_sorting.styles.js +41 -0
  241. package/optimize/lib/components/datagrid/controls/column_sorting_draggable.js +19 -14
  242. package/optimize/lib/components/datagrid/controls/data_grid_toolbar.js +8 -1
  243. package/optimize/lib/components/datagrid/controls/data_grid_toolbar.styles.js +24 -0
  244. package/optimize/lib/components/datagrid/controls/data_grid_toolbar_control.js +27 -27
  245. package/optimize/lib/components/datagrid/controls/display_selector.js +13 -2
  246. package/optimize/lib/components/datagrid/controls/fullscreen_selector.js +7 -4
  247. package/optimize/lib/components/datagrid/controls/fullscreen_selector.styles.js +26 -0
  248. package/optimize/lib/components/datagrid/controls/keyboard_shortcuts.js +6 -2
  249. package/optimize/lib/components/datagrid/controls/keyboard_shortcuts.styles.js +24 -0
  250. package/optimize/lib/components/datagrid/data_grid.a11y.js +1 -0
  251. package/optimize/lib/components/datagrid/data_grid.js +16 -8
  252. package/optimize/lib/components/datagrid/data_grid.stories.utils.js +374 -0
  253. package/optimize/lib/components/datagrid/data_grid.styles.js +94 -0
  254. package/{test-env/components/datagrid/utils → optimize/lib/components/datagrid/pagination}/data_grid_pagination.js +29 -31
  255. package/optimize/lib/components/datagrid/pagination/data_grid_pagination.styles.js +22 -0
  256. package/optimize/lib/components/datagrid/pagination/index.js +18 -0
  257. package/optimize/lib/components/datagrid/utils/row_heights.js +11 -36
  258. package/optimize/lib/components/datagrid/utils/scrolling.js +14 -7
  259. package/optimize/lib/components/datagrid/utils/scrolling.styles.js +36 -0
  260. package/optimize/lib/components/date_picker/date_picker.js +1 -1
  261. package/optimize/lib/components/flyout/flyout_resizable.js +6 -2
  262. package/optimize/lib/components/flyout/flyout_resizable.styles.js +34 -5
  263. package/optimize/lib/components/popover/popover.js +1 -1
  264. package/optimize/lib/components/provider/provider.js +16 -13
  265. package/optimize/lib/components/provider/system_color_mode/index.js +12 -0
  266. package/optimize/lib/components/provider/system_color_mode/system_color_mode_provider.js +47 -0
  267. package/optimize/lib/components/resizable_container/resizable_button.js +3 -2
  268. package/optimize/lib/components/resizable_container/resizable_button.styles.js +19 -6
  269. package/optimize/lib/components/table/table_header_cell.js +3 -2
  270. package/optimize/lib/components/table/table_header_cell_checkbox.js +3 -2
  271. package/optimize/lib/components/table/table_row_cell.js +4 -3
  272. package/optimize/lib/components/table/table_row_cell_checkbox.js +3 -2
  273. package/optimize/lib/components/text/text.js +9 -4
  274. package/optimize/lib/components/text/text_align.js +4 -2
  275. package/optimize/lib/components/text/text_color.js +1 -2
  276. package/optimize/lib/components/text/types.js +5 -0
  277. package/optimize/lib/services/copy/index.js +25 -0
  278. package/optimize/lib/services/copy/tabular_copy.js +111 -0
  279. package/optimize/lib/services/index.js +12 -8
  280. package/package.json +3 -3
  281. package/src/themes/amsterdam/theme_dark.scss +0 -7
  282. package/src/themes/amsterdam/theme_light.scss +0 -7
  283. package/test-env/components/basic_table/basic_table.js +42 -34
  284. package/test-env/components/basic_table/collapsed_item_actions.js +23 -30
  285. package/test-env/components/datagrid/body/cell/data_grid_cell.js +204 -91
  286. package/test-env/components/datagrid/body/cell/data_grid_cell.styles.js +114 -0
  287. package/test-env/components/datagrid/body/cell/data_grid_cell_actions.js +13 -3
  288. package/test-env/components/datagrid/body/cell/data_grid_cell_actions.styles.js +39 -0
  289. package/test-env/components/datagrid/body/cell/data_grid_cell_popover.js +20 -11
  290. package/test-env/components/datagrid/body/cell/data_grid_cell_popover.styles.js +25 -0
  291. package/test-env/components/datagrid/body/cell/focus_utils.js +17 -19
  292. package/test-env/components/datagrid/body/data_grid_body.js +20 -4
  293. package/test-env/components/datagrid/body/data_grid_body.styles.js +30 -0
  294. package/test-env/components/datagrid/body/data_grid_body_custom.js +23 -8
  295. package/test-env/components/datagrid/body/data_grid_body_virtualized.js +23 -8
  296. package/test-env/components/datagrid/body/footer/data_grid_footer.styles.js +30 -0
  297. package/test-env/components/datagrid/body/footer/data_grid_footer_row.js +22 -9
  298. package/test-env/components/datagrid/body/header/column_actions.js +16 -4
  299. package/test-env/components/datagrid/body/header/data_grid_column_resizer.js +14 -7
  300. package/test-env/components/datagrid/body/header/data_grid_column_resizer.styles.js +39 -0
  301. package/test-env/components/datagrid/body/header/data_grid_control_header_cell.js +6 -5
  302. package/test-env/components/datagrid/body/header/data_grid_header_cell.js +45 -67
  303. package/test-env/components/datagrid/body/header/data_grid_header_cell.styles.js +32 -0
  304. package/test-env/components/datagrid/body/header/data_grid_header_cell_wrapper.js +8 -2
  305. package/test-env/components/datagrid/body/header/data_grid_header_cell_wrapper.styles.js +32 -0
  306. package/test-env/components/datagrid/body/header/data_grid_header_row.js +12 -2
  307. package/test-env/components/datagrid/body/header/data_grid_header_row.styles.js +27 -0
  308. package/test-env/components/datagrid/controls/column_selector.js +17 -8
  309. package/test-env/components/datagrid/controls/column_selector.styles.js +28 -0
  310. package/test-env/components/datagrid/controls/column_sorting.js +7 -2
  311. package/test-env/components/datagrid/controls/column_sorting.styles.js +41 -0
  312. package/test-env/components/datagrid/controls/column_sorting_draggable.js +19 -14
  313. package/test-env/components/datagrid/controls/data_grid_toolbar.js +8 -1
  314. package/test-env/components/datagrid/controls/data_grid_toolbar.styles.js +24 -0
  315. package/test-env/components/datagrid/controls/data_grid_toolbar_control.js +27 -27
  316. package/test-env/components/datagrid/controls/display_selector.js +13 -2
  317. package/test-env/components/datagrid/controls/fullscreen_selector.js +7 -4
  318. package/test-env/components/datagrid/controls/fullscreen_selector.styles.js +26 -0
  319. package/test-env/components/datagrid/controls/keyboard_shortcuts.js +6 -2
  320. package/test-env/components/datagrid/controls/keyboard_shortcuts.styles.js +24 -0
  321. package/test-env/components/datagrid/data_grid.a11y.js +1 -0
  322. package/test-env/components/datagrid/data_grid.js +16 -8
  323. package/test-env/components/datagrid/data_grid.stories.utils.js +1419 -0
  324. package/test-env/components/datagrid/data_grid.styles.js +94 -0
  325. package/{optimize/lib/components/datagrid/utils → test-env/components/datagrid/pagination}/data_grid_pagination.js +29 -31
  326. package/test-env/components/datagrid/pagination/data_grid_pagination.styles.js +22 -0
  327. package/test-env/components/datagrid/pagination/index.js +18 -0
  328. package/test-env/components/datagrid/utils/row_heights.js +11 -36
  329. package/test-env/components/datagrid/utils/scrolling.js +14 -7
  330. package/test-env/components/datagrid/utils/scrolling.styles.js +36 -0
  331. package/test-env/components/date_picker/date_picker.js +1 -1
  332. package/test-env/components/flyout/flyout_resizable.js +6 -2
  333. package/test-env/components/flyout/flyout_resizable.styles.js +34 -5
  334. package/test-env/components/popover/popover.js +1 -1
  335. package/test-env/components/provider/provider.js +16 -13
  336. package/test-env/components/provider/system_color_mode/index.js +12 -0
  337. package/test-env/components/provider/system_color_mode/system_color_mode_provider.js +51 -0
  338. package/test-env/components/resizable_container/resizable_button.js +9 -2
  339. package/test-env/components/resizable_container/resizable_button.styles.js +19 -6
  340. package/test-env/components/table/table_header_cell.js +10 -3
  341. package/test-env/components/table/table_header_cell_checkbox.js +5 -3
  342. package/test-env/components/table/table_row_cell.js +10 -3
  343. package/test-env/components/table/table_row_cell_checkbox.js +5 -3
  344. package/test-env/components/text/text.js +25 -9
  345. package/test-env/components/text/text_align.js +19 -6
  346. package/test-env/components/text/text_color.js +14 -11
  347. package/test-env/components/text/types.js +5 -0
  348. package/test-env/services/copy/index.js +25 -0
  349. package/test-env/services/copy/tabular_copy.js +30 -0
  350. package/test-env/services/index.js +12 -8
  351. package/src/components/datagrid/_data_grid.scss +0 -121
  352. package/src/components/datagrid/_data_grid_data_row.scss +0 -303
  353. package/src/components/datagrid/_index.scss +0 -12
  354. package/src/components/datagrid/_mixins.scss +0 -84
  355. package/src/components/datagrid/_variables.scss +0 -11
  356. package/src/components/datagrid/body/footer/_data_grid_footer_row.scss +0 -47
  357. package/src/components/datagrid/body/header/_data_grid_column_resizer.scss +0 -48
  358. package/src/components/datagrid/body/header/_data_grid_header_row.scss +0 -221
  359. package/src/components/datagrid/controls/_data_grid_column_selector.scss +0 -19
  360. package/src/components/datagrid/controls/_data_grid_column_sorting.scss +0 -43
  361. package/src/components/datagrid/controls/_data_grid_display.scss +0 -3
  362. package/src/components/datagrid/controls/_data_grid_keyboard_shortcuts.scss +0 -11
  363. package/src/components/datagrid/controls/_data_grid_toolbar.scss +0 -55
  364. package/src/components/index.scss +0 -3
  365. package/src/themes/amsterdam/overrides/_data_grid.scss +0 -5
  366. package/src/themes/amsterdam/overrides/_index.scss +0 -1
  367. /package/es/services/{copy_to_clipboard.js → copy/copy_to_clipboard.js} +0 -0
  368. /package/lib/services/{copy_to_clipboard.js → copy/copy_to_clipboard.js} +0 -0
  369. /package/optimize/es/services/{copy_to_clipboard.js → copy/copy_to_clipboard.js} +0 -0
  370. /package/optimize/lib/services/{copy_to_clipboard.js → copy/copy_to_clipboard.js} +0 -0
  371. /package/test-env/services/{copy_to_clipboard.js → copy/copy_to_clipboard.js} +0 -0
@@ -0,0 +1,19 @@
1
+ import _taggedTemplateLiteral from "@babel/runtime/helpers/taggedTemplateLiteral";
2
+ var _templateObject;
3
+ /*
4
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
5
+ * or more contributor license agreements. Licensed under the Elastic License
6
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
7
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
8
+ * Side Public License, v 1.
9
+ */
10
+
11
+ import { css, keyframes } from '@emotion/react';
12
+ import { euiScrollBarStyles, euiCanAnimate } from '../../../../global_styling';
13
+ export var euiDataGridCellPopoverStyles = function euiDataGridCellPopoverStyles(euiThemeContext) {
14
+ var euiTheme = euiThemeContext.euiTheme;
15
+ return {
16
+ euiDataGridRowCell__popover: /*#__PURE__*/css(euiScrollBarStyles(euiThemeContext), " overflow:auto;", euiCanAnimate, "{animation-duration:", euiTheme.animation.normal, ";animation-name:", fadeIn, ";};label:euiDataGridRowCell__popover;")
17
+ };
18
+ };
19
+ var fadeIn = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n from { opacity: 0; }\n to { opacity: 1; }\n"])));
@@ -9,11 +9,10 @@ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
9
9
 
10
10
  import React, { useEffect, useState, useMemo } from 'react';
11
11
  import { tabbable } from 'tabbable';
12
- import { keys } from '../../../../services';
13
- import { useGeneratedHtmlId } from '../../../../services/accessibility';
12
+ import classNames from 'classnames';
13
+ import { keys, useGeneratedHtmlId } from '../../../../services';
14
14
  import { isDOMNode } from '../../../../utils';
15
15
  import { EuiFocusTrap } from '../../../focus_trap';
16
- import { EuiScreenReaderOnly } from '../../../accessibility';
17
16
  import { EuiI18n } from '../../../i18n';
18
17
 
19
18
  /**
@@ -87,20 +86,22 @@ export var FocusTrappedChildren = function FocusTrappedChildren(_ref2) {
87
86
  _useState6 = _slicedToArray(_useState5, 2),
88
87
  isExited = _useState6[0],
89
88
  setExited = _useState6[1];
90
- var keyboardHintAriaId = useGeneratedHtmlId({
91
- prefix: 'euiDataGridCellHeader',
92
- suffix: 'keyboardHint'
93
- });
94
- var exitedHintAriaId = useGeneratedHtmlId({
95
- prefix: 'euiDataGridCellHeader',
96
- suffix: 'exited'
89
+ var ariaDescribedById = useGeneratedHtmlId({
90
+ suffix: 'focusTrapHint'
97
91
  });
98
92
 
99
93
  // direct DOM manipulation as workaround to attach required hints
100
94
  useEffect(function () {
101
95
  var currentAriaDescribedbyId = cellEl.getAttribute('aria-describedby');
102
- cellEl.setAttribute('aria-describedby', "".concat(currentAriaDescribedbyId, " ").concat(exitedHintAriaId, " ").concat(keyboardHintAriaId, " "));
103
- }, [cellEl, keyboardHintAriaId, exitedHintAriaId]);
96
+ cellEl.setAttribute('aria-describedby', classNames(currentAriaDescribedbyId, ariaDescribedById));
97
+ return function () {
98
+ if (currentAriaDescribedbyId) {
99
+ cellEl.setAttribute('aria-descibedby', currentAriaDescribedbyId);
100
+ } else {
101
+ cellEl.removeAttribute('aria-describedby');
102
+ }
103
+ };
104
+ }, [cellEl, ariaDescribedById]);
104
105
  useEffect(function () {
105
106
  if (isCellEntered) {
106
107
  enableAndFocusInteractives(cellEl);
@@ -154,23 +155,20 @@ export var FocusTrappedChildren = function FocusTrappedChildren(_ref2) {
154
155
  onDeactivation: function onDeactivation() {
155
156
  return setIsCellEntered(false);
156
157
  }
157
- }, children, ___EmotionJSX(EuiScreenReaderOnly, null, ___EmotionJSX("p", {
158
- id: exitedHintAriaId,
159
- "aria-hidden": "true"
158
+ }, children, ___EmotionJSX("p", {
159
+ id: ariaDescribedById,
160
+ hidden: true
160
161
  }, isExited && ___EmotionJSX(EuiI18n
161
162
  // eslint-disable-next-line local/i18n
162
163
  , {
163
164
  token: "euiDataGridCell.focusTrapExitPrompt",
164
165
  default: "Exited cell content."
165
- }))), ___EmotionJSX(EuiScreenReaderOnly, null, ___EmotionJSX("p", {
166
- id: keyboardHintAriaId,
167
- "aria-hidden": "true"
168
- }, !isCellEntered && ___EmotionJSX(EuiI18n
166
+ }), !isCellEntered && ___EmotionJSX(EuiI18n
169
167
  // eslint-disable-next-line local/i18n
170
168
  , {
171
169
  token: "euiDataGridCell.focusTrapEnterPrompt",
172
170
  default: "Press the Enter key to interact with this cell's contents."
173
- }))));
171
+ })));
174
172
  };
175
173
 
176
174
  /**
@@ -10,8 +10,10 @@ var _excluded = ["renderCustomGridBody"];
10
10
  */
11
11
 
12
12
  import React from 'react';
13
+ import { useEuiMemoizedStyles } from '../../../services';
13
14
  import { EuiDataGridBodyVirtualized } from './data_grid_body_virtualized';
14
15
  import { EuiDataGridBodyCustomRender } from './data_grid_body_custom';
16
+ import { euiDataGridBodyStyles } from './data_grid_body.styles';
15
17
  import { jsx as ___EmotionJSX } from "@emotion/react";
16
18
  export var EuiDataGridBody = function EuiDataGridBody(_ref) {
17
19
  var renderCustomGridBody = _ref.renderCustomGridBody,
@@ -21,7 +23,12 @@ export var EuiDataGridBody = function EuiDataGridBody(_ref) {
21
23
  * + virtualization library for rendering content, or if consumers have
22
24
  * passed their own custom renderer
23
25
  */
26
+ var styles = useEuiMemoizedStyles(euiDataGridBodyStyles);
27
+ var cssStyles = [styles.euiDataGridBody, renderCustomGridBody ? styles.customRender : styles.virtualized];
24
28
  return renderCustomGridBody ? ___EmotionJSX(EuiDataGridBodyCustomRender, _extends({
25
- renderCustomGridBody: renderCustomGridBody
26
- }, props)) : ___EmotionJSX(EuiDataGridBodyVirtualized, props);
29
+ renderCustomGridBody: renderCustomGridBody,
30
+ css: cssStyles
31
+ }, props)) : ___EmotionJSX(EuiDataGridBodyVirtualized, _extends({
32
+ css: cssStyles
33
+ }, props));
27
34
  };
@@ -0,0 +1,26 @@
1
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
2
+ /*
3
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
4
+ * or more contributor license agreements. Licensed under the Elastic License
5
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
6
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
7
+ * Side Public License, v 1.
8
+ */
9
+
10
+ import { css } from '@emotion/react';
11
+ import { euiScrollBarStyles, logicalSizeCSS } from '../../../global_styling';
12
+ var _ref = process.env.NODE_ENV === "production" ? {
13
+ name: "jawla0-virtualized",
14
+ styles: "scroll-padding:0;label:virtualized;"
15
+ } : {
16
+ name: "jawla0-virtualized",
17
+ styles: "scroll-padding:0;label:virtualized;",
18
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
19
+ };
20
+ export var euiDataGridBodyStyles = function euiDataGridBodyStyles(euiThemeContext) {
21
+ return {
22
+ euiDataGridBody: /*#__PURE__*/css(euiScrollBarStyles(euiThemeContext), ";;label:euiDataGridBody;"),
23
+ virtualized: _ref,
24
+ customRender: /*#__PURE__*/css(logicalSizeCSS('100%'), " overflow:auto;;label:customRender;")
25
+ };
26
+ };
@@ -43,7 +43,8 @@ export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_r
43
43
  pagination = _ref.pagination,
44
44
  rowHeightsOptions = _ref.rowHeightsOptions,
45
45
  gridWidth = _ref.gridWidth,
46
- gridStyles = _ref.gridStyles;
46
+ gridStyles = _ref.gridStyles,
47
+ className = _ref.className;
47
48
  /**
48
49
  * Columns & widths
49
50
  */
@@ -88,11 +89,13 @@ export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_r
88
89
  columnWidths: columnWidths,
89
90
  defaultColumnWidth: defaultColumnWidth,
90
91
  setColumnWidth: setColumnWidth,
92
+ visibleColCount: visibleColCount,
91
93
  setVisibleColumns: setVisibleColumns,
92
94
  switchColumnPos: switchColumnPos,
93
95
  sorting: sorting,
94
96
  schema: schema,
95
- schemaDetectors: schemaDetectors
97
+ schemaDetectors: schemaDetectors,
98
+ gridStyles: gridStyles
96
99
  }),
97
100
  headerRow = _useDataGridHeader.headerRow;
98
101
  var _useDataGridFooter = useDataGridFooter({
@@ -100,13 +103,15 @@ export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_r
100
103
  renderCellPopover: renderCellPopover,
101
104
  rowIndex: visibleRows.visibleRowCount,
102
105
  visibleRowIndex: visibleRows.visibleRowCount,
106
+ visibleColCount: visibleColCount,
103
107
  interactiveCellId: interactiveCellId,
104
108
  leadingControlColumns: leadingControlColumns,
105
109
  trailingControlColumns: trailingControlColumns,
106
110
  columns: columns,
107
111
  columnWidths: columnWidths,
108
112
  defaultColumnWidth: defaultColumnWidth,
109
- schema: schema
113
+ schema: schema,
114
+ gridStyles: gridStyles
110
115
  }),
111
116
  footerRow = _useDataGridFooter.footerRow;
112
117
 
@@ -130,9 +135,10 @@ export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_r
130
135
  interactiveCellId: interactiveCellId,
131
136
  setRowHeight: setRowHeight,
132
137
  rowHeightsOptions: rowHeightsOptions,
133
- rowHeightUtils: rowHeightUtils
138
+ rowHeightUtils: rowHeightUtils,
139
+ gridStyles: gridStyles
134
140
  };
135
- }, [schema, schemaDetectors, pagination, columns, leadingControlColumns, trailingControlColumns, visibleColCount, columnWidths, defaultColumnWidth, renderCellValue, cellContext, renderCellPopover, interactiveCellId, setRowHeight, rowHeightsOptions, rowHeightUtils]);
141
+ }, [schema, schemaDetectors, pagination, columns, leadingControlColumns, trailingControlColumns, visibleColCount, columnWidths, defaultColumnWidth, renderCellValue, cellContext, renderCellPopover, interactiveCellId, setRowHeight, rowHeightsOptions, rowHeightUtils, gridStyles]);
136
142
  var Cell = useCallback(function (_ref2) {
137
143
  var colIndex = _ref2.colIndex,
138
144
  visibleRowIndex = _ref2.visibleRowIndex,
@@ -154,7 +160,7 @@ export var EuiDataGridBodyCustomRender = function EuiDataGridBodyCustomRender(_r
154
160
  customGridBodyProps = _useState2[0],
155
161
  setCustomGridBodyProps = _useState2[1];
156
162
  return ___EmotionJSX("div", _extends({}, customGridBodyProps, {
157
- className: classNames('euiDataGrid__customRenderBody', customGridBodyProps === null || customGridBodyProps === void 0 ? void 0 : customGridBodyProps.className)
163
+ className: classNames('euiDataGrid__customRenderBody', className, customGridBodyProps === null || customGridBodyProps === void 0 ? void 0 : customGridBodyProps.className)
158
164
  }), headerRow, renderCustomGridBody({
159
165
  visibleColumns: visibleColumns,
160
166
  visibleRowData: visibleRows,
@@ -103,7 +103,8 @@ export var EuiDataGridBodyVirtualized = /*#__PURE__*/memo(function (_ref3) {
103
103
  gridWidth = _ref3.gridWidth,
104
104
  gridRef = _ref3.gridRef,
105
105
  gridItemsRendered = _ref3.gridItemsRendered,
106
- wrapperRef = _ref3.wrapperRef;
106
+ wrapperRef = _ref3.wrapperRef,
107
+ className = _ref3.className;
107
108
  /**
108
109
  * Grid refs & observers
109
110
  */
@@ -148,11 +149,13 @@ export var EuiDataGridBodyVirtualized = /*#__PURE__*/memo(function (_ref3) {
148
149
  columnWidths: columnWidths,
149
150
  defaultColumnWidth: defaultColumnWidth,
150
151
  setColumnWidth: setColumnWidth,
152
+ visibleColCount: visibleColCount,
151
153
  setVisibleColumns: setVisibleColumns,
152
154
  switchColumnPos: switchColumnPos,
153
155
  sorting: sorting,
154
156
  schema: schema,
155
- schemaDetectors: schemaDetectors
157
+ schemaDetectors: schemaDetectors,
158
+ gridStyles: gridStyles
156
159
  }),
157
160
  headerRow = _useDataGridHeader.headerRow,
158
161
  headerRowHeight = _useDataGridHeader.headerRowHeight;
@@ -161,13 +164,15 @@ export var EuiDataGridBodyVirtualized = /*#__PURE__*/memo(function (_ref3) {
161
164
  renderCellPopover: renderCellPopover,
162
165
  rowIndex: visibleRowCount,
163
166
  visibleRowIndex: visibleRowCount,
167
+ visibleColCount: visibleColCount,
164
168
  interactiveCellId: interactiveCellId,
165
169
  leadingControlColumns: leadingControlColumns,
166
170
  trailingControlColumns: trailingControlColumns,
167
171
  columns: columns,
168
172
  columnWidths: columnWidths,
169
173
  defaultColumnWidth: defaultColumnWidth,
170
- schema: schema
174
+ schema: schema,
175
+ gridStyles: gridStyles
171
176
  }),
172
177
  footerRow = _useDataGridFooter.footerRow,
173
178
  footerRowHeight = _useDataGridFooter.footerRowHeight;
@@ -282,9 +287,10 @@ export var EuiDataGridBodyVirtualized = /*#__PURE__*/memo(function (_ref3) {
282
287
  rowHeightUtils: rowHeightUtils,
283
288
  rowManager: rowManager,
284
289
  pagination: pagination,
285
- headerRowHeight: headerRowHeight
290
+ headerRowHeight: headerRowHeight,
291
+ gridStyles: gridStyles
286
292
  };
287
- }, [schemaDetectors, setRowHeight, leadingControlColumns, trailingControlColumns, columns, visibleColCount, schema, columnWidths, defaultColumnWidth, renderCellValue, cellContext, renderCellPopover, interactiveCellId, rowHeightsOptions, rowHeightUtils, rowManager, pagination, headerRowHeight]);
293
+ }, [schemaDetectors, setRowHeight, leadingControlColumns, trailingControlColumns, columns, visibleColCount, schema, columnWidths, defaultColumnWidth, renderCellValue, cellContext, renderCellPopover, interactiveCellId, rowHeightsOptions, rowHeightUtils, rowManager, pagination, headerRowHeight, gridStyles]);
288
294
  var rowWrapperContextValue = useMemo(function () {
289
295
  return {
290
296
  headerRowHeight: headerRowHeight,
@@ -296,7 +302,7 @@ export var EuiDataGridBodyVirtualized = /*#__PURE__*/memo(function (_ref3) {
296
302
  value: rowWrapperContextValue
297
303
  }, ___EmotionJSX(Grid, _extends({}, virtualizationOptions, {
298
304
  ref: gridRef,
299
- className: classNames('euiDataGrid__virtualized', virtualizationOptions === null || virtualizationOptions === void 0 ? void 0 : virtualizationOptions.className),
305
+ className: classNames('euiDataGrid__virtualized', className, virtualizationOptions === null || virtualizationOptions === void 0 ? void 0 : virtualizationOptions.className),
300
306
  onItemsRendered: onItemsRendered,
301
307
  innerElementType: InnerElement,
302
308
  outerRef: outerGridRef,
@@ -0,0 +1,24 @@
1
+ /*
2
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
3
+ * or more contributor license agreements. Licensed under the Elastic License
4
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
5
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
6
+ * Side Public License, v 1.
7
+ */
8
+
9
+ import { css } from '@emotion/react';
10
+ import { logicalCSS } from '../../../../global_styling';
11
+ import { euiDataGridVariables } from '../../data_grid.styles';
12
+ export var euiDataGridFooterStyles = function euiDataGridFooterStyles(euiThemeContext) {
13
+ var euiTheme = euiThemeContext.euiTheme;
14
+ var _euiDataGridVariables = euiDataGridVariables(euiThemeContext),
15
+ levels = _euiDataGridVariables.levels;
16
+ return {
17
+ euiDataGridFooter: /*#__PURE__*/css("display:flex;", logicalCSS('width', 'fit-content'), " background-color:", euiTheme.colors.emptyShade, ";;label:euiDataGridFooter;"),
18
+ sticky: /*#__PURE__*/css("z-index:", levels.stickyHeader, ";position:sticky;", logicalCSS('bottom', 0), ";;label:sticky;"),
19
+ overline: /*#__PURE__*/css(logicalCSS('border-top', "".concat(euiTheme.border.width.thick, " solid ").concat(euiTheme.colors.text)), ";;label:overline;"),
20
+ shade: /*#__PURE__*/css("background-color:", euiTheme.colors.lightestShade, ";;label:shade;"),
21
+ striped: /*#__PURE__*/css(".euiDataGrid--stripes &{background-color:", euiTheme.colors.lightestShade, ";};label:striped;"),
22
+ euiDataGridFooterCell: /*#__PURE__*/css("flex:0 0 auto;font-weight:", euiTheme.font.weight.bold, ";;label:euiDataGridFooterCell;")
23
+ };
24
+ };
@@ -1,6 +1,6 @@
1
1
  import _extends from "@babel/runtime/helpers/extends";
2
2
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
3
- var _excluded = ["leadingControlColumns", "trailingControlColumns", "columns", "schema", "columnWidths", "defaultColumnWidth", "className", "renderCellValue", "renderCellPopover", "rowIndex", "interactiveCellId", "data-test-subj", "visibleRowIndex"];
3
+ var _excluded = ["leadingControlColumns", "trailingControlColumns", "columns", "schema", "columnWidths", "defaultColumnWidth", "className", "renderCellValue", "renderCellPopover", "rowIndex", "interactiveCellId", "data-test-subj", "visibleRowIndex", "visibleColCount", "gridStyles"];
4
4
  /*
5
5
  * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
6
6
  * or more contributor license agreements. Licensed under the Elastic License
@@ -9,9 +9,11 @@ var _excluded = ["leadingControlColumns", "trailingControlColumns", "columns", "
9
9
  * Side Public License, v 1.
10
10
  */
11
11
 
12
- import classnames from 'classnames';
13
- import React, { forwardRef, memo, useContext } from 'react';
12
+ import React, { forwardRef, memo, useCallback, useContext } from 'react';
13
+ import classNames from 'classnames';
14
+ import { useEuiMemoizedStyles } from '../../../../services';
14
15
  import { EuiDataGridCell, DataGridCellPopoverContext } from '../cell';
16
+ import { euiDataGridFooterStyles } from './data_grid_footer.styles';
15
17
  import { jsx as ___EmotionJSX } from "@emotion/react";
16
18
  var renderEmpty = function renderEmpty() {
17
19
  return null;
@@ -31,21 +33,32 @@ var EuiDataGridFooterRow = /*#__PURE__*/memo( /*#__PURE__*/forwardRef(function (
31
33
  _dataTestSubj = _ref['data-test-subj'],
32
34
  _ref$visibleRowIndex = _ref.visibleRowIndex,
33
35
  visibleRowIndex = _ref$visibleRowIndex === void 0 ? rowIndex : _ref$visibleRowIndex,
36
+ visibleColCount = _ref.visibleColCount,
37
+ gridStyles = _ref.gridStyles,
34
38
  rest = _objectWithoutProperties(_ref, _excluded);
35
- var classes = classnames('euiDataGridRow', {
36
- 'euiDataGridRow--striped': visibleRowIndex % 2 !== 0
37
- }, 'euiDataGridFooter', className);
38
- var dataTestSubj = classnames('dataGridRow', 'dataGridFooterRow', _dataTestSubj);
39
+ var styles = useEuiMemoizedStyles(euiDataGridFooterStyles);
40
+ var cssStyles = [styles.euiDataGridFooter, gridStyles.stickyFooter && styles.sticky, gridStyles.footer === 'striped' ? visibleRowIndex % 2 !== 0 && styles.striped : styles[gridStyles.footer]];
41
+ var classes = classNames('euiDataGridFooter', className);
42
+ var dataTestSubj = classNames('dataGridRow', 'dataGridFooterRow', _dataTestSubj);
43
+ var getCellClasses = useCallback(function (columnIndex, classes) {
44
+ return classNames('euiDataGridFooterCell', {
45
+ 'euiDataGridRowCell--firstColumn': columnIndex === 0,
46
+ 'euiDataGridRowCell--lastColumn': columnIndex === visibleColCount - 1
47
+ }, classes);
48
+ }, [visibleColCount]);
39
49
  var popoverContext = useContext(DataGridCellPopoverContext);
40
50
  var sharedCellProps = {
51
+ css: styles.euiDataGridFooterCell,
41
52
  rowIndex: rowIndex,
42
53
  visibleRowIndex: visibleRowIndex,
43
54
  interactiveCellId: interactiveCellId,
44
- popoverContext: popoverContext
55
+ popoverContext: popoverContext,
56
+ gridStyles: gridStyles
45
57
  };
46
58
  return ___EmotionJSX("div", _extends({
47
59
  ref: ref,
48
60
  role: "row",
61
+ css: cssStyles,
49
62
  className: classes,
50
63
  "data-test-subj": dataTestSubj
51
64
  }, rest), leadingControlColumns.map(function (_ref2, i) {
@@ -60,7 +73,7 @@ var EuiDataGridFooterRow = /*#__PURE__*/memo( /*#__PURE__*/forwardRef(function (
60
73
  width: width,
61
74
  renderCellValue: footerCellRender !== null && footerCellRender !== void 0 ? footerCellRender : renderEmpty,
62
75
  isExpandable: false,
63
- className: classnames('euiDataGridFooterCell', 'euiDataGridRowCell--controlColumn', footerCellProps === null || footerCellProps === void 0 ? void 0 : footerCellProps.className)
76
+ className: getCellClasses(i, classNames('euiDataGridRowCell--controlColumn', footerCellProps === null || footerCellProps === void 0 ? void 0 : footerCellProps.className))
64
77
  }));
65
78
  }), columns.map(function (_ref3, i) {
66
79
  var id = _ref3.id;
@@ -77,7 +90,7 @@ var EuiDataGridFooterRow = /*#__PURE__*/memo( /*#__PURE__*/forwardRef(function (
77
90
  renderCellValue: renderCellValue,
78
91
  renderCellPopover: renderCellPopover,
79
92
  isExpandable: true,
80
- className: "euiDataGridFooterCell"
93
+ className: getCellClasses(columnPosition)
81
94
  }));
82
95
  }), trailingControlColumns.map(function (_ref4, i) {
83
96
  var id = _ref4.id,
@@ -92,7 +105,7 @@ var EuiDataGridFooterRow = /*#__PURE__*/memo( /*#__PURE__*/forwardRef(function (
92
105
  width: width,
93
106
  renderCellValue: footerCellRender !== null && footerCellRender !== void 0 ? footerCellRender : renderEmpty,
94
107
  isExpandable: false,
95
- className: classnames('euiDataGridFooterCell', 'euiDataGridRowCell--controlColumn', footerCellProps === null || footerCellProps === void 0 ? void 0 : footerCellProps.className)
108
+ className: getCellClasses(colIndex, classNames('euiDataGridRowCell--controlColumn', footerCellProps === null || footerCellProps === void 0 ? void 0 : footerCellProps.className))
96
109
  }));
97
110
  }));
98
111
  }));
@@ -209,8 +209,15 @@ export var getSortColumnActions = function getSortColumnActions(_ref4) {
209
209
  var onClickSortAsc = function onClickSortAsc() {
210
210
  sortBy('asc');
211
211
  };
212
+ var isSorted = sortingIdx >= 0 && sorting.columns[sortingIdx].direction === 'asc';
212
213
  var action = {
213
- label: ___EmotionJSX(EuiI18n, {
214
+ label: isSorted ? ___EmotionJSX(EuiI18n, {
215
+ token: "euiColumnActions.unsort",
216
+ default: "Unsort {schemaLabel}",
217
+ values: {
218
+ schemaLabel: label
219
+ }
220
+ }) : ___EmotionJSX(EuiI18n, {
214
221
  token: "euiColumnActions.sort",
215
222
  default: "Sort {schemaLabel}",
216
223
  values: {
@@ -219,7 +226,6 @@ export var getSortColumnActions = function getSortColumnActions(_ref4) {
219
226
  }),
220
227
  onClick: onClickSortAsc,
221
228
  isDisabled: column.isSortable === false,
222
- className: sortingIdx >= 0 && sorting.columns[sortingIdx].direction === 'asc' ? 'euiDataGridHeader__action--selected' : '',
223
229
  iconType: 'sortUp',
224
230
  size: 'xs',
225
231
  color: 'text'
@@ -231,8 +237,15 @@ export var getSortColumnActions = function getSortColumnActions(_ref4) {
231
237
  var onClickSortDesc = function onClickSortDesc() {
232
238
  sortBy('desc');
233
239
  };
240
+ var _isSorted = sortingIdx >= 0 && sorting.columns[sortingIdx].direction === 'desc';
234
241
  var _action2 = {
235
- label: ___EmotionJSX(EuiI18n, {
242
+ label: _isSorted ? ___EmotionJSX(EuiI18n, {
243
+ token: "euiColumnActions.unsort",
244
+ default: "Unsort {schemaLabel}",
245
+ values: {
246
+ schemaLabel: _label
247
+ }
248
+ }) : ___EmotionJSX(EuiI18n, {
236
249
  token: "euiColumnActions.sort",
237
250
  default: "Sort {schemaLabel}",
238
251
  values: {
@@ -241,7 +254,6 @@ export var getSortColumnActions = function getSortColumnActions(_ref4) {
241
254
  }),
242
255
  onClick: onClickSortDesc,
243
256
  isDisabled: column.isSortable === false,
244
- className: sortingIdx >= 0 && sorting.columns[sortingIdx].direction === 'desc' ? 'euiDataGridHeader__action--selected' : '',
245
257
  iconType: 'sortDown',
246
258
  size: 'xs',
247
259
  color: 'text'
@@ -15,6 +15,9 @@ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.
15
15
  */
16
16
 
17
17
  import React, { Component } from 'react';
18
+ import { RenderWithEuiStylesMemoizer } from '../../../../services';
19
+ import { logicalStyle } from '../../../../global_styling';
20
+ import { euiDataGridColumnResizerStyles } from './data_grid_column_resizer.styles';
18
21
  import { jsx as ___EmotionJSX } from "@emotion/react";
19
22
  var MINIMUM_COLUMN_WIDTH = 40;
20
23
  export var EuiDataGridColumnResizer = /*#__PURE__*/function (_Component) {
@@ -69,14 +72,18 @@ export var EuiDataGridColumnResizer = /*#__PURE__*/function (_Component) {
69
72
  return _createClass(EuiDataGridColumnResizer, [{
70
73
  key: "render",
71
74
  value: function render() {
75
+ var _this2 = this;
72
76
  var offset = this.state.offset;
73
- return ___EmotionJSX("div", {
74
- className: "euiDataGridColumnResizer",
75
- "data-test-subj": "dataGridColumnResizer",
76
- style: {
77
- marginRight: "".concat(-offset, "px")
78
- },
79
- onMouseDown: this.onMouseDown
77
+ return ___EmotionJSX(RenderWithEuiStylesMemoizer, null, function (stylesMemoizer) {
78
+ var styles = stylesMemoizer(euiDataGridColumnResizerStyles);
79
+ var cssStyles = [styles.euiDataGridColumnResizer, offset && styles.isDragging];
80
+ return ___EmotionJSX("div", {
81
+ css: cssStyles,
82
+ className: "euiDataGridColumnResizer",
83
+ "data-test-subj": "dataGridColumnResizer",
84
+ style: offset ? logicalStyle('margin-right', "".concat(-offset, "px")) : undefined,
85
+ onMouseDown: _this2.onMouseDown
86
+ });
80
87
  });
81
88
  }
82
89
  }]);
@@ -0,0 +1,36 @@
1
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
2
+ /*
3
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
4
+ * or more contributor license agreements. Licensed under the Elastic License
5
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
6
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
7
+ * Side Public License, v 1.
8
+ */
9
+
10
+ import { css } from '@emotion/react';
11
+ import { logicalCSS, mathWithUnits } from '../../../../global_styling';
12
+
13
+ // Resizer straddles the column border and is an invisible hitzone for dragging
14
+ var _ref = process.env.NODE_ENV === "production" ? {
15
+ name: "1i9vv3a-isDragging",
16
+ styles: "opacity:1;label:isDragging;"
17
+ } : {
18
+ name: "1i9vv3a-isDragging",
19
+ styles: "opacity:1;label:isDragging;",
20
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
21
+ };
22
+ export var euiDataGridColumnResizerStyles = function euiDataGridColumnResizerStyles(euiThemeContext) {
23
+ var euiTheme = euiThemeContext.euiTheme;
24
+ var clickableWidth = euiTheme.size.base;
25
+ var positionOffset = mathWithUnits(clickableWidth, function (x) {
26
+ return x / -2;
27
+ });
28
+ var indicatorWidth = mathWithUnits([euiTheme.border.width.thin, euiTheme.border.width.thick], function (x, y) {
29
+ return x + y;
30
+ }); // Odd number because it straddles a border
31
+ var indicatorOffset = "-".concat(euiTheme.border.width.thin);
32
+ return {
33
+ euiDataGridColumnResizer: /*#__PURE__*/css("z-index:2;position:absolute;", logicalCSS('vertical', 0), " ", logicalCSS('right', positionOffset), " cursor:ew-resize;opacity:0;&:hover,&:active{opacity:1;}&::after{content:'';position:absolute;", logicalCSS('vertical', 0), " ", logicalCSS('left', positionOffset), " ", logicalCSS('margin-left', indicatorOffset), " ", logicalCSS('width', indicatorWidth), " background-color:", euiTheme.colors.primary, ";}.euiDataGridHeaderCell:last-child &{", logicalCSS('right', 0), " ", logicalCSS('width', euiTheme.size.s), " &::after{", logicalCSS('left', 'auto'), " ", logicalCSS('right', 0), ";}};label:euiDataGridColumnResizer;"),
34
+ isDragging: _ref
35
+ };
36
+ };
@@ -13,7 +13,8 @@ import { EuiDataGridHeaderCellWrapper } from './data_grid_header_cell_wrapper';
13
13
  import { jsx as ___EmotionJSX } from "@emotion/react";
14
14
  export var EuiDataGridControlHeaderCell = /*#__PURE__*/memo(function (_ref) {
15
15
  var controlColumn = _ref.controlColumn,
16
- index = _ref.index;
16
+ index = _ref.index,
17
+ visibleColCount = _ref.visibleColCount;
17
18
  var HeaderCellRender = controlColumn.headerCellRender,
18
19
  headerCellProps = controlColumn.headerCellProps,
19
20
  width = controlColumn.width,
@@ -22,9 +23,8 @@ export var EuiDataGridControlHeaderCell = /*#__PURE__*/memo(function (_ref) {
22
23
  className: classNames('euiDataGridHeaderCell--controlColumn', headerCellProps === null || headerCellProps === void 0 ? void 0 : headerCellProps.className),
23
24
  id: id,
24
25
  index: index,
25
- width: width
26
- }), ___EmotionJSX("div", {
27
- className: "euiDataGridHeaderCell__content"
28
- }, ___EmotionJSX(HeaderCellRender, null)));
26
+ width: width,
27
+ visibleColCount: visibleColCount
28
+ }), ___EmotionJSX(HeaderCellRender, null));
29
29
  });
30
30
  EuiDataGridControlHeaderCell.displayName = 'EuiDataGridControlHeaderCell';