@elastic/eui 116.2.0 → 116.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (234) hide show
  1. package/es/components/avatar/avatar.js +18 -5
  2. package/es/components/avatar/avatar.styles.js +16 -16
  3. package/es/components/banner/banner.js +202 -0
  4. package/es/components/banner/banner.styles.js +76 -0
  5. package/es/components/banner/index.js +9 -0
  6. package/es/components/basic_table/basic_table.js +21 -10
  7. package/es/components/basic_table/collapsed_item_actions.js +5 -4
  8. package/es/components/basic_table/default_item_action.js +3 -5
  9. package/es/components/breadcrumbs/_breadcrumb_content.js +29 -19
  10. package/es/components/combo_box/combo_box_options_list/combo_box_options_list.js +2 -1
  11. package/es/components/context_menu/context_menu_panel_title.js +0 -12
  12. package/es/components/datagrid/body/cell/data_grid_cell_actions.js +11 -7
  13. package/es/components/datagrid/controls/display_selector.js +2 -1
  14. package/es/components/datagrid/controls/keyboard_shortcuts.js +2 -1
  15. package/es/components/date_picker/auto_refresh/auto_refresh.js +7 -4
  16. package/es/components/date_picker/react-datepicker/src/index.js +1 -5
  17. package/es/components/date_picker/super_date_picker/date_popover/absolute_tab.js +6 -3
  18. package/es/components/date_picker/super_date_picker/date_popover/date_popover_button.js +10 -2
  19. package/es/components/date_picker/super_date_picker/date_popover/date_popover_button.styles.js +2 -1
  20. package/es/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +8 -5
  21. package/es/components/form/field_password/field_password.js +6 -3
  22. package/es/components/header/header.a11y.js +1 -1
  23. package/es/components/index.js +1 -0
  24. package/es/components/markdown_editor/markdown_editor_help_button.js +7 -4
  25. package/es/components/pagination/pagination_button_arrow.js +6 -2
  26. package/es/components/panel/panel.styles.js +4 -4
  27. package/es/components/panel/split_panel/split_panel.styles.js +1 -1
  28. package/es/components/search_bar/search_bar.js +20 -16
  29. package/es/components/search_bar/search_box.js +4 -2
  30. package/es/components/selectable/selectable_list/selectable_list.js +1 -1
  31. package/es/components/selectable/selectable_list/selectable_list.styles.js +1 -1
  32. package/es/components/selectable/selectable_templates/selectable_template_sitewide.js +2 -1
  33. package/es/components/table/sticky_header/context.js +32 -0
  34. package/es/components/table/sticky_header/index.js +10 -0
  35. package/es/components/table/sticky_header/sticky_header.js +151 -0
  36. package/es/components/table/sticky_header/sticky_header.styles.js +43 -0
  37. package/es/components/table/store/provider.js +37 -0
  38. package/es/components/table/store/store.js +82 -0
  39. package/es/components/table/store/use_unique_column_id.js +25 -0
  40. package/es/components/table/table.js +28 -3
  41. package/es/components/table/table.styles.js +4 -4
  42. package/es/components/table/table_header_cell.js +115 -48
  43. package/es/components/table/table_header_cell_checkbox.js +58 -25
  44. package/es/components/text_truncate/text_truncate.js +8 -3
  45. package/es/components/tool_tip/tool_tip.js +1 -1
  46. package/es/components/tool_tip/tool_tip.styles.js +14 -5
  47. package/es/utils/publisher.js +53 -0
  48. package/eui.d.ts +1284 -975
  49. package/i18ntokens.json +2390 -2372
  50. package/lib/components/avatar/avatar.js +18 -5
  51. package/lib/components/avatar/avatar.styles.js +16 -16
  52. package/lib/components/banner/banner.js +211 -0
  53. package/lib/components/banner/banner.styles.js +80 -0
  54. package/lib/components/banner/index.js +12 -0
  55. package/lib/components/basic_table/basic_table.js +21 -10
  56. package/lib/components/basic_table/collapsed_item_actions.js +5 -4
  57. package/lib/components/basic_table/default_item_action.js +3 -5
  58. package/lib/components/breadcrumbs/_breadcrumb_content.js +29 -19
  59. package/lib/components/combo_box/combo_box_options_list/combo_box_options_list.js +2 -1
  60. package/lib/components/context_menu/context_menu_panel_title.js +0 -12
  61. package/lib/components/datagrid/body/cell/data_grid_cell_actions.js +11 -7
  62. package/lib/components/datagrid/controls/display_selector.js +2 -1
  63. package/lib/components/datagrid/controls/keyboard_shortcuts.js +2 -1
  64. package/lib/components/date_picker/auto_refresh/auto_refresh.js +7 -4
  65. package/lib/components/date_picker/react-datepicker/src/index.js +0 -4
  66. package/lib/components/date_picker/super_date_picker/date_popover/absolute_tab.js +6 -3
  67. package/lib/components/date_picker/super_date_picker/date_popover/date_popover_button.js +10 -2
  68. package/lib/components/date_picker/super_date_picker/date_popover/date_popover_button.styles.js +2 -1
  69. package/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +8 -5
  70. package/lib/components/form/field_password/field_password.js +6 -3
  71. package/lib/components/header/header.a11y.js +1 -1
  72. package/lib/components/index.js +11 -0
  73. package/lib/components/markdown_editor/markdown_editor_help_button.js +7 -4
  74. package/lib/components/pagination/pagination_button_arrow.js +6 -2
  75. package/lib/components/panel/panel.styles.js +4 -4
  76. package/lib/components/panel/split_panel/split_panel.styles.js +1 -1
  77. package/lib/components/search_bar/search_bar.js +20 -16
  78. package/lib/components/search_bar/search_box.js +4 -2
  79. package/lib/components/selectable/selectable_list/selectable_list.js +1 -1
  80. package/lib/components/selectable/selectable_list/selectable_list.styles.js +1 -1
  81. package/lib/components/selectable/selectable_templates/selectable_template_sitewide.js +2 -1
  82. package/lib/components/table/sticky_header/context.js +41 -0
  83. package/lib/components/table/sticky_header/index.js +19 -0
  84. package/lib/components/table/sticky_header/sticky_header.js +156 -0
  85. package/lib/components/table/sticky_header/sticky_header.styles.js +47 -0
  86. package/lib/components/table/store/provider.js +46 -0
  87. package/lib/components/table/store/store.js +87 -0
  88. package/lib/components/table/store/use_unique_column_id.js +34 -0
  89. package/lib/components/table/table.js +28 -3
  90. package/lib/components/table/table.styles.js +4 -4
  91. package/lib/components/table/table_header_cell.js +117 -48
  92. package/lib/components/table/table_header_cell_checkbox.js +61 -25
  93. package/lib/components/text_truncate/text_truncate.js +8 -3
  94. package/lib/components/tool_tip/tool_tip.js +1 -1
  95. package/lib/components/tool_tip/tool_tip.styles.js +14 -5
  96. package/lib/utils/publisher.js +59 -0
  97. package/optimize/es/components/avatar/avatar.js +16 -4
  98. package/optimize/es/components/avatar/avatar.styles.js +16 -16
  99. package/optimize/es/components/banner/banner.js +112 -0
  100. package/optimize/es/components/banner/banner.styles.js +76 -0
  101. package/optimize/es/components/banner/index.js +9 -0
  102. package/optimize/es/components/basic_table/basic_table.js +21 -10
  103. package/optimize/es/components/basic_table/collapsed_item_actions.js +5 -4
  104. package/optimize/es/components/basic_table/default_item_action.js +3 -5
  105. package/optimize/es/components/breadcrumbs/_breadcrumb_content.js +27 -18
  106. package/optimize/es/components/combo_box/combo_box_options_list/combo_box_options_list.js +2 -1
  107. package/optimize/es/components/datagrid/body/cell/data_grid_cell_actions.js +11 -7
  108. package/optimize/es/components/datagrid/controls/display_selector.js +2 -1
  109. package/optimize/es/components/datagrid/controls/keyboard_shortcuts.js +2 -1
  110. package/optimize/es/components/date_picker/auto_refresh/auto_refresh.js +7 -4
  111. package/optimize/es/components/date_picker/react-datepicker/src/index.js +1 -5
  112. package/optimize/es/components/date_picker/super_date_picker/date_popover/absolute_tab.js +6 -3
  113. package/optimize/es/components/date_picker/super_date_picker/date_popover/date_popover_button.js +10 -2
  114. package/optimize/es/components/date_picker/super_date_picker/date_popover/date_popover_button.styles.js +2 -1
  115. package/optimize/es/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +8 -5
  116. package/optimize/es/components/form/field_password/field_password.js +6 -3
  117. package/optimize/es/components/header/header.a11y.js +1 -1
  118. package/optimize/es/components/index.js +1 -0
  119. package/optimize/es/components/markdown_editor/markdown_editor_help_button.js +7 -4
  120. package/optimize/es/components/pagination/pagination_button_arrow.js +6 -2
  121. package/optimize/es/components/panel/panel.styles.js +4 -4
  122. package/optimize/es/components/panel/split_panel/split_panel.styles.js +1 -1
  123. package/optimize/es/components/search_bar/search_bar.js +20 -16
  124. package/optimize/es/components/search_bar/search_box.js +4 -2
  125. package/optimize/es/components/selectable/selectable_list/selectable_list.js +1 -1
  126. package/optimize/es/components/selectable/selectable_list/selectable_list.styles.js +1 -1
  127. package/optimize/es/components/table/sticky_header/context.js +32 -0
  128. package/optimize/es/components/table/sticky_header/index.js +10 -0
  129. package/optimize/es/components/table/sticky_header/sticky_header.js +146 -0
  130. package/optimize/es/components/table/sticky_header/sticky_header.styles.js +43 -0
  131. package/optimize/es/components/table/store/provider.js +37 -0
  132. package/optimize/es/components/table/store/store.js +82 -0
  133. package/optimize/es/components/table/store/use_unique_column_id.js +25 -0
  134. package/optimize/es/components/table/table.js +15 -3
  135. package/optimize/es/components/table/table.styles.js +4 -4
  136. package/optimize/es/components/table/table_header_cell.js +115 -48
  137. package/optimize/es/components/table/table_header_cell_checkbox.js +58 -25
  138. package/optimize/es/components/text_truncate/text_truncate.js +8 -3
  139. package/optimize/es/components/tool_tip/tool_tip.js +1 -1
  140. package/optimize/es/components/tool_tip/tool_tip.styles.js +14 -5
  141. package/optimize/es/utils/publisher.js +53 -0
  142. package/optimize/lib/components/avatar/avatar.js +16 -4
  143. package/optimize/lib/components/avatar/avatar.styles.js +16 -16
  144. package/optimize/lib/components/banner/banner.js +121 -0
  145. package/optimize/lib/components/banner/banner.styles.js +80 -0
  146. package/optimize/lib/components/banner/index.js +12 -0
  147. package/optimize/lib/components/basic_table/basic_table.js +21 -10
  148. package/optimize/lib/components/basic_table/collapsed_item_actions.js +5 -4
  149. package/optimize/lib/components/basic_table/default_item_action.js +3 -5
  150. package/optimize/lib/components/breadcrumbs/_breadcrumb_content.js +27 -18
  151. package/optimize/lib/components/combo_box/combo_box_options_list/combo_box_options_list.js +2 -1
  152. package/optimize/lib/components/datagrid/body/cell/data_grid_cell_actions.js +11 -7
  153. package/optimize/lib/components/datagrid/controls/display_selector.js +2 -1
  154. package/optimize/lib/components/datagrid/controls/keyboard_shortcuts.js +2 -1
  155. package/optimize/lib/components/date_picker/auto_refresh/auto_refresh.js +7 -4
  156. package/optimize/lib/components/date_picker/react-datepicker/src/index.js +0 -4
  157. package/optimize/lib/components/date_picker/super_date_picker/date_popover/absolute_tab.js +6 -3
  158. package/optimize/lib/components/date_picker/super_date_picker/date_popover/date_popover_button.js +10 -2
  159. package/optimize/lib/components/date_picker/super_date_picker/date_popover/date_popover_button.styles.js +2 -1
  160. package/optimize/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +8 -5
  161. package/optimize/lib/components/form/field_password/field_password.js +6 -3
  162. package/optimize/lib/components/header/header.a11y.js +1 -1
  163. package/optimize/lib/components/index.js +11 -0
  164. package/optimize/lib/components/markdown_editor/markdown_editor_help_button.js +7 -4
  165. package/optimize/lib/components/pagination/pagination_button_arrow.js +6 -2
  166. package/optimize/lib/components/panel/panel.styles.js +4 -4
  167. package/optimize/lib/components/panel/split_panel/split_panel.styles.js +1 -1
  168. package/optimize/lib/components/search_bar/search_bar.js +20 -16
  169. package/optimize/lib/components/search_bar/search_box.js +4 -2
  170. package/optimize/lib/components/selectable/selectable_list/selectable_list.js +1 -1
  171. package/optimize/lib/components/selectable/selectable_list/selectable_list.styles.js +1 -1
  172. package/optimize/lib/components/table/sticky_header/context.js +41 -0
  173. package/optimize/lib/components/table/sticky_header/index.js +19 -0
  174. package/optimize/lib/components/table/sticky_header/sticky_header.js +156 -0
  175. package/optimize/lib/components/table/sticky_header/sticky_header.styles.js +47 -0
  176. package/optimize/lib/components/table/store/provider.js +46 -0
  177. package/optimize/lib/components/table/store/store.js +87 -0
  178. package/optimize/lib/components/table/store/use_unique_column_id.js +34 -0
  179. package/optimize/lib/components/table/table.js +15 -3
  180. package/optimize/lib/components/table/table.styles.js +4 -4
  181. package/optimize/lib/components/table/table_header_cell.js +118 -48
  182. package/optimize/lib/components/table/table_header_cell_checkbox.js +61 -25
  183. package/optimize/lib/components/text_truncate/text_truncate.js +8 -3
  184. package/optimize/lib/components/tool_tip/tool_tip.js +1 -1
  185. package/optimize/lib/components/tool_tip/tool_tip.styles.js +14 -5
  186. package/optimize/lib/utils/publisher.js +59 -0
  187. package/package.json +2 -2
  188. package/test-env/components/avatar/avatar.js +18 -5
  189. package/test-env/components/avatar/avatar.styles.js +16 -16
  190. package/test-env/components/banner/banner.js +210 -0
  191. package/test-env/components/banner/banner.styles.js +80 -0
  192. package/test-env/components/banner/index.js +12 -0
  193. package/test-env/components/basic_table/basic_table.js +21 -10
  194. package/test-env/components/basic_table/collapsed_item_actions.js +5 -4
  195. package/test-env/components/basic_table/default_item_action.js +3 -5
  196. package/test-env/components/breadcrumbs/_breadcrumb_content.js +29 -19
  197. package/test-env/components/combo_box/combo_box_options_list/combo_box_options_list.js +2 -1
  198. package/test-env/components/context_menu/context_menu_panel_title.js +0 -12
  199. package/test-env/components/datagrid/body/cell/data_grid_cell_actions.js +11 -7
  200. package/test-env/components/datagrid/controls/display_selector.js +2 -1
  201. package/test-env/components/datagrid/controls/keyboard_shortcuts.js +2 -1
  202. package/test-env/components/date_picker/auto_refresh/auto_refresh.js +7 -4
  203. package/test-env/components/date_picker/react-datepicker/src/index.js +0 -4
  204. package/test-env/components/date_picker/super_date_picker/date_popover/absolute_tab.js +6 -3
  205. package/test-env/components/date_picker/super_date_picker/date_popover/date_popover_button.js +10 -2
  206. package/test-env/components/date_picker/super_date_picker/date_popover/date_popover_button.styles.js +2 -1
  207. package/test-env/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +8 -5
  208. package/test-env/components/form/field_password/field_password.js +6 -3
  209. package/test-env/components/header/header.a11y.js +1 -1
  210. package/test-env/components/index.js +11 -0
  211. package/test-env/components/markdown_editor/markdown_editor_help_button.js +7 -4
  212. package/test-env/components/pagination/pagination_button_arrow.js +6 -2
  213. package/test-env/components/panel/panel.styles.js +4 -4
  214. package/test-env/components/panel/split_panel/split_panel.styles.js +1 -1
  215. package/test-env/components/search_bar/search_bar.js +20 -16
  216. package/test-env/components/search_bar/search_box.js +4 -2
  217. package/test-env/components/selectable/selectable_list/selectable_list.js +1 -1
  218. package/test-env/components/selectable/selectable_list/selectable_list.styles.js +1 -1
  219. package/test-env/components/selectable/selectable_templates/selectable_template_sitewide.js +2 -1
  220. package/test-env/components/table/sticky_header/context.js +41 -0
  221. package/test-env/components/table/sticky_header/index.js +19 -0
  222. package/test-env/components/table/sticky_header/sticky_header.js +156 -0
  223. package/test-env/components/table/sticky_header/sticky_header.styles.js +47 -0
  224. package/test-env/components/table/store/provider.js +46 -0
  225. package/test-env/components/table/store/store.js +87 -0
  226. package/test-env/components/table/store/use_unique_column_id.js +34 -0
  227. package/test-env/components/table/table.js +28 -3
  228. package/test-env/components/table/table.styles.js +4 -4
  229. package/test-env/components/table/table_header_cell.js +118 -48
  230. package/test-env/components/table/table_header_cell_checkbox.js +61 -25
  231. package/test-env/components/text_truncate/text_truncate.js +8 -3
  232. package/test-env/components/tool_tip/tool_tip.js +1 -1
  233. package/test-env/components/tool_tip/tool_tip.styles.js +14 -5
  234. package/test-env/utils/publisher.js +59 -0
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.createPublisher = void 0;
7
+ function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; }
8
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
9
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
10
+ /*
11
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
12
+ * or more contributor license agreements. Licensed under the Elastic License
13
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
14
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
15
+ * Side Public License, v 1.
16
+ */
17
+
18
+ /**
19
+ * @internal
20
+ */
21
+
22
+ /**
23
+ * @internal
24
+ */
25
+
26
+ /**
27
+ * @internal
28
+ */
29
+ var createPublisher = exports.createPublisher = function createPublisher() {
30
+ var subscribers = new Set();
31
+ var unsubscribe = function unsubscribe(subscriber) {
32
+ subscribers.delete(subscriber);
33
+ };
34
+ var subscribe = function subscribe(subscriber) {
35
+ subscribers.add(subscriber);
36
+ return function () {
37
+ return unsubscribe(subscriber);
38
+ };
39
+ };
40
+ var notify = function notify(subject) {
41
+ var _iterator = _createForOfIteratorHelper(subscribers),
42
+ _step;
43
+ try {
44
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
45
+ var _subscriber = _step.value;
46
+ _subscriber(subject);
47
+ }
48
+ } catch (err) {
49
+ _iterator.e(err);
50
+ } finally {
51
+ _iterator.f();
52
+ }
53
+ };
54
+ return {
55
+ subscribe: subscribe,
56
+ unsubscribe: unsubscribe,
57
+ notify: notify
58
+ };
59
+ };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@elastic/eui",
3
3
  "description": "Elastic UI Component Library",
4
- "version": "116.2.0",
4
+ "version": "116.3.1",
5
5
  "license": "SEE LICENSE IN LICENSE.txt",
6
6
  "main": "lib",
7
7
  "module": "es",
@@ -108,7 +108,7 @@
108
108
  "@cypress/webpack-dev-server": "^1.7.0",
109
109
  "@elastic/charts": "^64.1.0",
110
110
  "@elastic/datemath": "^5.0.3",
111
- "@elastic/eslint-plugin-eui": "2.13.0",
111
+ "@elastic/eslint-plugin-eui": "2.14.0",
112
112
  "@elastic/eui-theme-borealis": "8.0.0",
113
113
  "@emotion/babel-preset-css-prop": "^11.11.0",
114
114
  "@emotion/cache": "^11.11.0",
@@ -17,6 +17,7 @@ var _contrast = require("../../services/color/contrast");
17
17
  var _color = require("../../services/color");
18
18
  var _services = require("../../services");
19
19
  var _icon = require("../icon");
20
+ var _tool_tip = require("../tool_tip");
20
21
  var _avatar = require("./avatar.styles");
21
22
  var _react2 = require("@emotion/react");
22
23
  var _excluded = ["className", "color", "imageUrl", "initials", "initialsLength", "iconType", "iconSize", "iconColor", "name", "size", "type", "isDisabled", "style"],
@@ -74,6 +75,7 @@ var EuiAvatar = exports.EuiAvatar = function EuiAvatar(_ref) {
74
75
  var classes = (0, _classnames.default)('euiAvatar', (0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)({}, "euiAvatar--".concat(size), size), "euiAvatar--".concat(type), type), 'euiAvatar-isDisabled', isDisabled), className);
75
76
  var styles = (0, _services.useEuiMemoizedStyles)(_avatar.euiAvatarStyles);
76
77
  var cssStyles = [styles.euiAvatar, styles[type], styles[size], styles[casing], isPlain && styles.plain, isSubdued && styles.subdued, isDisabled && styles.isDisabled];
78
+ var tooltipCssStyles = [styles.tooltip[type]];
77
79
  var avatarStyle = (0, _react.useMemo)(function () {
78
80
  if (imageUrl) {
79
81
  return {
@@ -108,21 +110,31 @@ var EuiAvatar = exports.EuiAvatar = function EuiAvatar(_ref) {
108
110
  // Fall back to the adjusted text color if it exists
109
111
  return avatarStyle === null || avatarStyle === void 0 ? void 0 : avatarStyle.color;
110
112
  }, [iconColor, avatarStyle === null || avatarStyle === void 0 ? void 0 : avatarStyle.color, isForcedColors, euiTheme]);
111
- return (0, _react2.jsx)("div", (0, _extends2.default)({
113
+ var avatarNode = (0, _react2.jsx)("div", (0, _extends2.default)({
112
114
  css: cssStyles,
113
115
  className: classes,
114
116
  style: _objectSpread(_objectSpread(_objectSpread({}, style), avatarStyle), highContrastBorder),
115
117
  "aria-label": isDisabled ? undefined : name,
116
- role: isDisabled ? 'presentation' : 'img',
117
- title: name
118
+ role: isDisabled ? 'presentation' : 'img'
118
119
  }, rest), !imageUrl && (iconType ? (0, _react2.jsx)(_icon.EuiIcon, {
119
120
  className: "euiAvatar__icon",
120
121
  size: iconSize || size,
121
122
  type: iconType,
122
- color: iconCustomColor
123
+ color: iconCustomColor,
124
+ "aria-hidden": true
123
125
  }) : (0, _react2.jsx)("span", {
124
126
  "aria-hidden": "true"
125
127
  }, (0, _services.toInitials)(name, initialsLength, initials))));
128
+
129
+ // `EuiAvatar` is not interactive so we don't need to add a `tabIndex`.
130
+ // It already has `aria-label`, the tooltip is only visual.
131
+ return name ? (0, _react2.jsx)(_tool_tip.EuiToolTip, {
132
+ content: name,
133
+ anchorProps: {
134
+ css: tooltipCssStyles
135
+ },
136
+ disableScreenReaderOutput: true
137
+ }, avatarNode) : avatarNode;
126
138
  };
127
139
 
128
140
  // TODO: Migrate to a service
@@ -158,7 +170,8 @@ EuiAvatar.propTypes = {
158
170
  */
159
171
  iconColor: _propTypes.default.oneOfType([_propTypes.default.oneOfType([_propTypes.default.string.isRequired, _propTypes.default.any.isRequired]).isRequired, _propTypes.default.oneOf([null])]),
160
172
  /**
161
- * Full name of avatar for title attribute and calculating initial if not provided
173
+ * Full name of the avatar. Used as the accessible label (`aria-label`),
174
+ * tooltip content and used to derive initials when `initials` is not provided.
162
175
  */
163
176
  name: _propTypes.default.string.isRequired,
164
177
  /**
@@ -13,9 +13,9 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
13
13
  * in compliance with, at your election, the Elastic License 2.0 or the Server
14
14
  * Side Public License, v 1.
15
15
  */
16
- var _avatarSize = function _avatarSize(_ref7) {
17
- var size = _ref7.size,
18
- fontSize = _ref7.fontSize;
16
+ var _avatarSize = function _avatarSize(_ref6) {
17
+ var size = _ref6.size,
18
+ fontSize = _ref6.fontSize;
19
19
  return "\n ".concat((0, _global_styling.logicalSizeCSS)(size), ";\n font-size: ").concat(fontSize, ";\n ");
20
20
  };
21
21
  var _ref = process.env.NODE_ENV === "production" ? {
@@ -58,24 +58,20 @@ var _ref5 = process.env.NODE_ENV === "production" ? {
58
58
  styles: "cursor:not-allowed;filter:grayscale(100%);label:isDisabled;",
59
59
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
60
60
  };
61
- var _ref6 = process.env.NODE_ENV === "production" ? {
62
- name: "ont6vs-user",
63
- styles: "border-radius:50%;label:user;"
64
- } : {
65
- name: "ont6vs-user",
66
- styles: "border-radius:50%;label:user;",
67
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
68
- };
69
- var euiAvatarStyles = exports.euiAvatarStyles = function euiAvatarStyles(_ref8) {
70
- var euiTheme = _ref8.euiTheme;
61
+ var euiAvatarStyles = exports.euiAvatarStyles = function euiAvatarStyles(_ref7) {
62
+ var euiTheme = _ref7.euiTheme;
63
+ var borderRadius = {
64
+ user: '50%',
65
+ space: euiTheme.border.radius.medium
66
+ };
71
67
  return {
72
68
  // Base
73
69
  euiAvatar: /*#__PURE__*/(0, _react.css)("flex-shrink:0;display:inline-flex;justify-content:center;align-items:center;vertical-align:middle;background-size:cover;background-color:", euiTheme.colors.lightShade, ";overflow:hidden;font-weight:", euiTheme.font.weight.medium, ";;label:euiAvatar;"),
74
70
  // Variants
75
71
  plain: /*#__PURE__*/(0, _react.css)("background-color:", euiTheme.colors.emptyShade, ";;label:plain;"),
76
72
  subdued: /*#__PURE__*/(0, _react.css)("background-color:", euiTheme.colors.lightestShade, ";;label:subdued;"),
77
- user: _ref6,
78
- space: /*#__PURE__*/(0, _react.css)("border-radius:", euiTheme.border.radius.medium, ";;label:space;"),
73
+ user: /*#__PURE__*/(0, _react.css)("border-radius:", borderRadius.user, ";;label:user;"),
74
+ space: /*#__PURE__*/(0, _react.css)("border-radius:", borderRadius.space, ";;label:space;"),
79
75
  // States
80
76
  isDisabled: _ref5,
81
77
  // Sizes
@@ -105,6 +101,10 @@ var euiAvatarStyles = exports.euiAvatarStyles = function euiAvatarStyles(_ref8)
105
101
  capitalize: _ref4,
106
102
  uppercase: _ref3,
107
103
  lowercase: _ref2,
108
- none: _ref
104
+ none: _ref,
105
+ tooltip: {
106
+ user: /*#__PURE__*/(0, _react.css)("border-radius:", borderRadius.user, ";;label:user;"),
107
+ space: /*#__PURE__*/(0, _react.css)("border-radius:", borderRadius.space, ";;label:space;")
108
+ }
109
109
  };
110
110
  };
@@ -0,0 +1,210 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.EuiBanner = void 0;
9
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ var _propTypes = _interopRequireDefault(require("prop-types"));
13
+ var _classnames = _interopRequireDefault(require("classnames"));
14
+ var _services = require("../../services");
15
+ var _global_styling = require("../../global_styling");
16
+ var _i18n = require("../i18n");
17
+ var _title = require("../title");
18
+ var _button = require("../button");
19
+ var _text = require("../text");
20
+ var _accessibility = require("../accessibility");
21
+ var _banner = require("./banner.styles");
22
+ var _react2 = require("@emotion/react");
23
+ var _excluded = ["title", "headingElement", "text", "size", "color", "actionProps", "media", "onDismiss", "dismissButtonProps", "children", "className", "announceOnMount", "data-test-subj"];
24
+ /*
25
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
26
+ * or more contributor license agreements. Licensed under the Elastic License
27
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
28
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
29
+ * Side Public License, v 1.
30
+ */
31
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
32
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
33
+ var EuiBanner = exports.EuiBanner = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
34
+ var title = _ref.title,
35
+ _ref$headingElement = _ref.headingElement,
36
+ headingElement = _ref$headingElement === void 0 ? 'h2' : _ref$headingElement,
37
+ text = _ref.text,
38
+ _ref$size = _ref.size,
39
+ size = _ref$size === void 0 ? 'm' : _ref$size,
40
+ _ref$color = _ref.color,
41
+ color = _ref$color === void 0 ? 'highlighted' : _ref$color,
42
+ actionProps = _ref.actionProps,
43
+ media = _ref.media,
44
+ onDismiss = _ref.onDismiss,
45
+ dismissButtonProps = _ref.dismissButtonProps,
46
+ children = _ref.children,
47
+ className = _ref.className,
48
+ _ref$announceOnMount = _ref.announceOnMount,
49
+ announceOnMount = _ref$announceOnMount === void 0 ? false : _ref$announceOnMount,
50
+ _ref$dataTestSubj = _ref['data-test-subj'],
51
+ dataTestSubj = _ref$dataTestSubj === void 0 ? 'euiBanner' : _ref$dataTestSubj,
52
+ rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
53
+ var styles = (0, _services.useEuiMemoizedStyles)(_banner.euiBannerStyles);
54
+ var dismissAriaLabel = (0, _i18n.useEuiI18n)('euiBanner.dismissAriaLabel', 'Dismiss "{title}" announcement', {
55
+ title: title
56
+ });
57
+ var Heading = headingElement;
58
+ var headingSize = size === 's' ? 'xxs' : 'xs';
59
+ var primaryActionProps = actionProps === null || actionProps === void 0 ? void 0 : actionProps.primary;
60
+ var secondaryActionProps = actionProps === null || actionProps === void 0 ? void 0 : actionProps.secondary;
61
+ // a standalone secondary action is not supported
62
+ var hasActions = Boolean(primaryActionProps);
63
+ var componentClass = 'euiBanner';
64
+ var classes = (0, _classnames.default)(componentClass, className);
65
+ var backgroundColorStyles = (0, _global_styling.useEuiBackgroundColorCSS)()[color];
66
+ var cssStyles = [styles.euiBanner, backgroundColorStyles];
67
+ var containerCssStyles = [styles.container, onDismiss && styles.hasDismiss];
68
+ return (0, _react2.jsx)("div", (0, _extends2.default)({
69
+ ref: ref,
70
+ className: classes,
71
+ css: cssStyles,
72
+ "data-size": size,
73
+ "data-color": color,
74
+ "data-test-subj": dataTestSubj
75
+ }, rest), (0, _react2.jsx)("div", {
76
+ className: "".concat(componentClass, "__container"),
77
+ css: containerCssStyles
78
+ }, media ? (0, _react2.jsx)("div", {
79
+ className: "".concat(componentClass, "__media"),
80
+ css: styles.media,
81
+ "data-test-subj": "".concat(dataTestSubj, "-media")
82
+ }, media) : null, (0, _react2.jsx)("div", {
83
+ className: "".concat(componentClass, "__body"),
84
+ css: styles.body
85
+ }, (0, _react2.jsx)("div", {
86
+ className: "".concat(componentClass, "__content"),
87
+ css: styles.content
88
+ }, (0, _react2.jsx)(_title.EuiTitle, {
89
+ size: headingSize
90
+ }, (0, _react2.jsx)(Heading, {
91
+ css: styles.title,
92
+ "data-test-subj": "".concat(dataTestSubj, "-title")
93
+ }, title)), onDismiss ? (0, _react2.jsx)(_button.EuiButtonIcon, (0, _extends2.default)({
94
+ iconType: "cross",
95
+ color: "text",
96
+ "aria-label": dismissAriaLabel,
97
+ "data-test-subj": "".concat(dataTestSubj, "-dismiss")
98
+ }, dismissButtonProps, {
99
+ css: [styles.dismiss, dismissButtonProps === null || dismissButtonProps === void 0 ? void 0 : dismissButtonProps.css, ";label:EuiBanner;"],
100
+ onClick: onDismiss
101
+ })) : null, text ? (0, _react2.jsx)(_text.EuiText, {
102
+ css: styles.text,
103
+ size: "s",
104
+ color: "subdued",
105
+ "data-test-subj": "".concat(dataTestSubj, "-text")
106
+ }, text) : null, children && children), hasActions ? (0, _react2.jsx)("div", {
107
+ className: "".concat(componentClass, "__actions"),
108
+ css: styles.actions,
109
+ "data-test-subj": "".concat(dataTestSubj, "-actions")
110
+ }, primaryActionProps ? (0, _react2.jsx)(_button.EuiButton, (0, _extends2.default)({
111
+ "data-test-subj": "".concat(dataTestSubj, "-primaryAction")
112
+ }, primaryActionProps, {
113
+ color: "primary",
114
+ size: "s"
115
+ })) : null, secondaryActionProps ? (0, _react2.jsx)(_button.EuiButtonEmpty, (0, _extends2.default)({
116
+ "data-test-subj": "".concat(dataTestSubj, "-secondaryAction")
117
+ }, secondaryActionProps, {
118
+ color: "primary",
119
+ size: "s"
120
+ })) : null) : null)), announceOnMount && (0, _react2.jsx)(_accessibility.EuiLiveAnnouncer, null, title && title, title && text && ",\xA0", text && text, (title || text) && children && ",\xA0", children && children));
121
+ });
122
+ EuiBanner.propTypes = {
123
+ className: _propTypes.default.string,
124
+ "aria-label": _propTypes.default.string,
125
+ "data-test-subj": _propTypes.default.string,
126
+ css: _propTypes.default.any,
127
+ /** Heading shown at the top. */title: _propTypes.default.string.isRequired,
128
+ /**
129
+ * HTML element used to render the title.
130
+ * @default 'h2'
131
+ */
132
+ headingElement: _propTypes.default.oneOf(["h2", "h3", "h4", "h5", "h6"]),
133
+ /** Supporting copy rendered below the title. */text: _propTypes.default.node,
134
+ /** Extra content rendered directly below `text`. */children: _propTypes.default.node,
135
+ /** Illustration slot. Wrapped in a square (1:1) container. */media: _propTypes.default.node.isRequired,
136
+ /**
137
+ * Visual size variant.
138
+ * @default 'm'
139
+ */
140
+ size: _propTypes.default.any,
141
+ /**
142
+ * Defines the announcement background color.
143
+ * @default 'highlighted'
144
+ */
145
+ color: _propTypes.default.oneOf(["highlighted", "plain"]),
146
+ /** Optional action buttons. */actionProps: _propTypes.default.shape({
147
+ /** Primary call-to-action, rendered as an `EuiButton`. */primary: _propTypes.default.any,
148
+ /** Secondary action, rendered as an `EuiButtonEmpty`. Is only rendered when a primary action is available. */secondary: _propTypes.default.any
149
+ }),
150
+ /**
151
+ * When provided, a dismiss button is rendered in the top-right corner and
152
+ * this callback fires when the user activates it.
153
+ */
154
+ onDismiss: _propTypes.default.func,
155
+ /** Extra props spread onto the dismiss `EuiButtonIcon`. */dismissButtonProps: _propTypes.default.shape({
156
+ "aria-label": _propTypes.default.string,
157
+ "aria-labelledby": _propTypes.default.string,
158
+ /**
159
+ * Overall size of button.
160
+ * Matches the sizes of other EuiButtons
161
+ */
162
+ size: _propTypes.default.any,
163
+ /**
164
+ * Size of the icon only.
165
+ * This will not affect the overall size of the button
166
+ */
167
+ iconSize: _propTypes.default.any,
168
+ /**
169
+ * Applies the boolean state as the `aria-pressed` property to create a toggle button.
170
+ * *Only use when the readable text does not change between states.*
171
+ */
172
+ isSelected: _propTypes.default.bool,
173
+ /**
174
+ * Sets the display style for matching other EuiButton types.
175
+ * `base` is equivalent to a typical EuiButton
176
+ * `fill` is equivalent to a filled EuiButton
177
+ * `empty` (default) is equivalent to an EuiButtonEmpty
178
+ */
179
+ display: _propTypes.default.any,
180
+ /**
181
+ * Disables the button and changes the icon to a loading spinner
182
+ */
183
+ isLoading: _propTypes.default.bool,
184
+ className: _propTypes.default.string,
185
+ "data-test-subj": _propTypes.default.string,
186
+ css: _propTypes.default.any,
187
+ /**
188
+ * Controls the disabled behavior via the native `disabled` attribute.
189
+ */
190
+ isDisabled: _propTypes.default.bool,
191
+ /**
192
+ * NOTE: Beta feature, may be changed or removed in the future
193
+ *
194
+ * Changes the native `disabled` attribute to `aria-disabled` to preserve focusability.
195
+ * This results in a semantically disabled button without the default browser handling of the disabled state.
196
+ *
197
+ * Use e.g. when a disabled button should have a tooltip.
198
+ */
199
+ hasAriaDisabled: _propTypes.default.bool
200
+ }),
201
+ /**
202
+ * When set to `true`, the content is announced by screen readers on mount.
203
+ * Use only when the announcement is immediately relevant, e.g. as feedback to user actions.
204
+ * Avoid using on initial page load as it may create noise for assistive technology users.
205
+ *
206
+ * @default false
207
+ */
208
+ announceOnMount: _propTypes.default.bool
209
+ };
210
+ EuiBanner.displayName = 'EuiBanner';
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.euiBannerStyles = void 0;
7
+ var _react = require("@emotion/react");
8
+ 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)."; } /*
9
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
10
+ * or more contributor license agreements. Licensed under the Elastic License
11
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
12
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
13
+ * Side Public License, v 1.
14
+ */
15
+ var CONTAINER_NAME = 'euiBanner';
16
+ var CQC_LAYOUTS = ['narrow', 'wide'];
17
+ var CQC_BREAKPOINTS = {
18
+ s: {
19
+ narrow: '(min-width: 401px)',
20
+ wide: '(min-width: 800px)'
21
+ },
22
+ m: {
23
+ narrow: '(min-width: 601px)',
24
+ wide: '(min-width: 1000px)'
25
+ }
26
+ };
27
+ var CQC_BREAKPOINT_NARROWEST = '(max-width: 400px)';
28
+
29
+ /** Maximum reading width for `text` and `children` slots. */
30
+ var TEXT_MAX_WIDTH = 1200;
31
+ var withContainerQuery = function withContainerQuery(_ref2) {
32
+ var layout = _ref2.layout,
33
+ styles = _ref2.styles;
34
+ return Object.keys(CQC_BREAKPOINTS).map(function (sizeKey) {
35
+ return "\n @container ".concat(CONTAINER_NAME, "--").concat(sizeKey, " ").concat(CQC_BREAKPOINTS[sizeKey][layout], " {\n ").concat(styles, "\n }\n ");
36
+ }).join('\n');
37
+ };
38
+ var _ref = process.env.NODE_ENV === "production" ? {
39
+ name: "qd171g-title",
40
+ styles: "[data-size='s'] &{display:inline;};label:title;"
41
+ } : {
42
+ name: "qd171g-title",
43
+ styles: "[data-size='s'] &{display:inline;};label:title;",
44
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
45
+ };
46
+ var euiBannerStyles = exports.euiBannerStyles = function euiBannerStyles(_ref3) {
47
+ var euiTheme = _ref3.euiTheme;
48
+ return {
49
+ euiBanner: /*#__PURE__*/(0, _react.css)("container-name:", CONTAINER_NAME, ";container-type:inline-size;position:relative;border:", euiTheme.border.thin, ";border-radius:", euiTheme.border.radius.medium, ";&[data-size='s']{container-name:", CONTAINER_NAME, " ", CONTAINER_NAME, "--s;}&[data-size='m']{container-name:", CONTAINER_NAME, " ", CONTAINER_NAME, "--m;};label:euiBanner;"),
50
+ container: /*#__PURE__*/(0, _react.css)("display:flex;flex-direction:column;align-items:stretch;gap:", euiTheme.size.m, ";padding-inline-start:", euiTheme.size.base, ";padding-inline-end:", euiTheme.size.base, ";[data-size='m'] &{padding-block:", euiTheme.size.base, ";}[data-size='s'] &{padding-block:", euiTheme.size.m, ";}", withContainerQuery({
51
+ layout: 'narrow',
52
+ styles: "\n flex-direction: row;\n align-items: flex-start;\n gap: ".concat(euiTheme.size.base, ";\n ")
53
+ }), ";;label:container;"),
54
+ media: /*#__PURE__*/(0, _react.css)("--euiBannerMediaSize:", "calc(".concat(euiTheme.size.base, " * 5)"), ";flex-shrink:0;inline-size:var(--euiBannerMediaSize);block-size:var(--euiBannerMediaSize);aspect-ratio:1/1;[data-size='s'] &{--euiBannerMediaSize:", "calc(".concat(euiTheme.size.base, " * 2)"), ";}", withContainerQuery({
55
+ layout: 'wide',
56
+ styles: "\n align-self: center;\n "
57
+ }), " img,svg{block-size:100%;inline-size:100%;};label:media;"),
58
+ body: /*#__PURE__*/(0, _react.css)("flex:1 1 auto;min-inline-size:0;display:flex;flex-direction:column;align-self:flex-start;inline-size:100%;gap:", euiTheme.size.m, ";", withContainerQuery({
59
+ layout: 'narrow',
60
+ styles: "\n align-self: center;\n inline-size: auto;\n "
61
+ }), " ", withContainerQuery({
62
+ layout: 'wide',
63
+ styles: "\n flex-direction: row;\n align-items: center;\n /* stretch to match the media's height so align-items has space to work */\n align-self: stretch;\n justify-content: space-between;\n gap: ".concat(euiTheme.size.xxl, ";\n ")
64
+ }), ";;label:body;"),
65
+ // At size `s` the content slot becomes a block container so the title and
66
+ // text flow inline. Other sizes keep the flex column with a fixed gap.
67
+ content: /*#__PURE__*/(0, _react.css)("flex:1 1 auto;min-inline-size:0;max-inline-size:", TEXT_MAX_WIDTH, "px;display:flex;flex-direction:column;gap:", euiTheme.size.xs, ";[data-size='s'] &{display:block;>*+*:not(.euiButtonIcon){margin-block-start:", euiTheme.size.s, ";}};label:content;"),
68
+ title: _ref,
69
+ text: /*#__PURE__*/(0, _react.css)("[data-size='s'] &{display:inline;&::before{content:'\xB7';display:inline-block;inline-size:calc(", euiTheme.size.s, " + ", euiTheme.size.xxs, ");text-align:center;color:", euiTheme.colors.textHeading, ";}};label:text;"),
70
+ actions: /*#__PURE__*/(0, _react.css)("display:flex;flex-direction:row;align-items:center;flex-wrap:nowrap;gap:", euiTheme.size.s, ";@container ", CONTAINER_NAME, " ", CQC_BREAKPOINT_NARROWEST, "{flex-wrap:wrap;>*{inline-size:100%;}}", withContainerQuery({
71
+ layout: 'wide',
72
+ styles: "\n /* Reverses source order so primary appears last (rightmost). */\n flex-direction: row-reverse;\n flex-shrink: 0;\n align-self: center;\n "
73
+ }), ";;label:actions;"),
74
+ hasDismiss: /*#__PURE__*/(0, _react.css)(withContainerQuery({
75
+ layout: 'narrow',
76
+ styles: "\n padding-inline-end: calc(".concat(euiTheme.size.s, " * 5);\n ")
77
+ }), ";;label:hasDismiss;"),
78
+ dismiss: /*#__PURE__*/(0, _react.css)("position:absolute;inset-block-start:", euiTheme.size.s, ";inset-inline-end:", euiTheme.size.s, ";color:", euiTheme.colors.textSubdued, ";;label:dismiss;")
79
+ };
80
+ };
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "EuiBanner", {
7
+ enumerable: true,
8
+ get: function get() {
9
+ return _banner.EuiBanner;
10
+ }
11
+ });
12
+ var _banner = require("./banner");
@@ -37,8 +37,9 @@ var _i18n = require("../i18n");
37
37
  var _delay_render = require("../delay_render");
38
38
  var _accessibility2 = require("../../services/accessibility");
39
39
  var _basic_table = require("./basic_table.styles");
40
+ var _tool_tip = require("../tool_tip");
40
41
  var _react2 = require("@emotion/react");
41
- var _excluded = ["className", "loading", "items", "itemId", "columns", "pagination", "sorting", "selection", "onChange", "error", "noItemsMessage", "compressed", "itemIdToExpandedRowMap", "responsiveBreakpoint", "rowProps", "cellProps", "tableCaption", "rowHeader", "tableLayout", "hasBackground", "scrollableInline", "stickyScrollbar"],
42
+ var _excluded = ["className", "loading", "items", "itemId", "columns", "pagination", "sorting", "selection", "onChange", "error", "noItemsMessage", "compressed", "itemIdToExpandedRowMap", "responsiveBreakpoint", "rowProps", "cellProps", "tableCaption", "rowHeader", "tableLayout", "hasBackground", "scrollableInline", "stickyScrollbar", "stickyHeader"],
42
43
  _excluded2 = ["align", "render", "dataType", "isExpander", "textOnly", "name", "field", "description", "sortable", "footer", "mobileOptions", "nameTooltip"];
43
44
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
44
45
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
@@ -165,7 +166,11 @@ var EuiBasicTable = exports.EuiBasicTable = /*#__PURE__*/function (_Component) {
165
166
  var _ref4 = (0, _slicedToArray2.default)(_ref3, 2),
166
167
  selectAllRows = _ref4[0],
167
168
  deselectRows = _ref4[1];
168
- return (0, _react2.jsx)(_form.EuiCheckbox, {
169
+ return (0, _react2.jsx)(_tool_tip.EuiToolTip, {
170
+ content: checked || indeterminate ? deselectRows : selectAllRows,
171
+ display: "block",
172
+ disableScreenReaderOutput: true
173
+ }, (0, _react2.jsx)(_form.EuiCheckbox, {
169
174
  id: _this.selectAllIdGenerator(),
170
175
  checked: checked,
171
176
  indeterminate: indeterminate,
@@ -173,9 +178,8 @@ var EuiBasicTable = exports.EuiBasicTable = /*#__PURE__*/function (_Component) {
173
178
  onChange: onChange,
174
179
  "data-test-subj": "checkboxSelectAll",
175
180
  "aria-label": checked || indeterminate ? deselectRows : selectAllRows,
176
- title: checked || indeterminate ? deselectRows : selectAllRows,
177
181
  label: isMobile ? selectAllRows : null
178
- });
182
+ }));
179
183
  });
180
184
  });
181
185
  (0, _defineProperty2.default)(_this, "renderCopyChar", function (columnIndex) {
@@ -365,6 +369,7 @@ var EuiBasicTable = exports.EuiBasicTable = /*#__PURE__*/function (_Component) {
365
369
  hasBackground = _this$props2.hasBackground,
366
370
  scrollableInline = _this$props2.scrollableInline,
367
371
  stickyScrollbar = _this$props2.stickyScrollbar,
372
+ stickyHeader = _this$props2.stickyHeader,
368
373
  rest = (0, _objectWithoutProperties2.default)(_this$props2, _excluded);
369
374
  var classes = (0, _classnames.default)('euiBasicTable', {
370
375
  'euiBasicTable-loading': loading
@@ -385,7 +390,8 @@ var EuiBasicTable = exports.EuiBasicTable = /*#__PURE__*/function (_Component) {
385
390
  hasBackground = _this$props3.hasBackground,
386
391
  loading = _this$props3.loading,
387
392
  scrollableInline = _this$props3.scrollableInline,
388
- stickyScrollbar = _this$props3.stickyScrollbar;
393
+ stickyScrollbar = _this$props3.stickyScrollbar,
394
+ stickyHeader = _this$props3.stickyHeader;
389
395
  return (0, _react2.jsx)(_react.default.Fragment, null, (0, _react2.jsx)(_table.EuiTableHeaderMobile, {
390
396
  responsiveBreakpoint: responsiveBreakpoint
391
397
  }, this.renderSelectAll(true), this.renderTableMobileSort()), (0, _react2.jsx)(_services.OverrideCopiedTabularContent, null, (0, _react2.jsx)(_table.EuiTable, {
@@ -396,6 +402,7 @@ var EuiBasicTable = exports.EuiBasicTable = /*#__PURE__*/function (_Component) {
396
402
  hasBackground: hasBackground,
397
403
  scrollableInline: scrollableInline,
398
404
  stickyScrollbar: stickyScrollbar,
405
+ stickyHeader: stickyHeader,
399
406
  css: loading && _basic_table.safariLoadingWorkaround
400
407
  }, this.renderTableCaption(), this.renderTableHead(), this.renderTableBody(), this.renderTableFooter())));
401
408
  }
@@ -664,8 +671,9 @@ var EuiBasicTable = exports.EuiBasicTable = /*#__PURE__*/function (_Component) {
664
671
  }
665
672
  }, (0, _react2.jsx)(_icon.EuiIcon, {
666
673
  type: "minusCircle",
667
- color: "danger"
668
- }), " ", error));
674
+ color: "danger",
675
+ "aria-hidden": true
676
+ }), ' ', error));
669
677
  }
670
678
  }, {
671
679
  key: "renderEmptyMessage",
@@ -792,15 +800,18 @@ var EuiBasicTable = exports.EuiBasicTable = /*#__PURE__*/function (_Component) {
792
800
  index: displayedRowIndex + 1
793
801
  }
794
802
  }, function (selectThisRow) {
795
- return (0, _react2.jsx)(_form.EuiCheckbox, {
803
+ return (0, _react2.jsx)(_tool_tip.EuiToolTip, {
804
+ content: title || selectThisRow,
805
+ display: "block",
806
+ disableScreenReaderOutput: true
807
+ }, (0, _react2.jsx)(_form.EuiCheckbox, {
796
808
  id: "".concat(_this6.tableId).concat(key, "-checkbox"),
797
809
  disabled: disabled,
798
810
  checked: checked,
799
811
  onChange: onChange,
800
- title: title || selectThisRow,
801
812
  "aria-label": title || selectThisRow,
802
813
  "data-test-subj": "checkboxSelectRow-".concat(itemId)
803
- });
814
+ }));
804
815
  })), disabled];
805
816
  }
806
817
  }, {
@@ -100,10 +100,10 @@ var CollapsedItemActions = exports.CollapsedItemActions = function CollapsedItem
100
100
  var popoverButton = (0, _react2.jsx)(_button.EuiButtonIcon, {
101
101
  className: className,
102
102
  "aria-label": actionsDisabled ? allActionsButtonDisabledAriaLabel : allActionsButtonAriaLabel,
103
- title: actionsDisabled ? allActionsButtonDisabledAriaLabel : undefined,
104
103
  iconType: "boxesVertical",
105
104
  color: "text",
106
105
  isDisabled: actionsDisabled,
106
+ hasAriaDisabled: actionsDisabled,
107
107
  onClick: function onClick() {
108
108
  return setPopoverOpen(function (isOpen) {
109
109
  return !isOpen;
@@ -111,14 +111,15 @@ var CollapsedItemActions = exports.CollapsedItemActions = function CollapsedItem
111
111
  },
112
112
  "data-test-subj": "euiCollapsedItemActionsButton"
113
113
  });
114
- var withTooltip = !actionsDisabled && (0, _react2.jsx)(_tool_tip.EuiToolTip, {
115
- content: allActionsTooltip
114
+ var withTooltip = (0, _react2.jsx)(_tool_tip.EuiToolTip, {
115
+ content: actionsDisabled ? allActionsButtonDisabledAriaLabel : allActionsTooltip,
116
+ disableScreenReaderOutput: true
116
117
  }, popoverButton);
117
118
  return (0, _react2.jsx)(_popover.EuiPopover, {
118
119
  className: className,
119
120
  id: "".concat(itemId, "-actions"),
120
121
  isOpen: popoverOpen,
121
- button: withTooltip || popoverButton,
122
+ button: withTooltip,
122
123
  closePopover: closePopover,
123
124
  panelPaddingSize: "none",
124
125
  anchorPosition: "leftCenter"