@elastic/eui 71.1.0 → 72.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (224) hide show
  1. package/dist/eui_charts_theme.js +13 -1
  2. package/dist/eui_charts_theme.js.map +1 -1
  3. package/dist/eui_theme_dark.css +20 -176
  4. package/dist/eui_theme_dark.min.css +1 -1
  5. package/dist/eui_theme_light.css +20 -176
  6. package/dist/eui_theme_light.min.css +1 -1
  7. package/es/components/basic_table/basic_table.js +2 -2
  8. package/es/components/basic_table/in_memory_table.js +3 -6
  9. package/es/components/basic_table/table.a11y.js +128 -0
  10. package/es/components/color_picker/color_picker.styles.js +16 -0
  11. package/es/components/color_picker/color_stops/color_stop_thumb.js +19 -7
  12. package/es/components/color_picker/color_stops/color_stop_thumb.styles.js +59 -0
  13. package/es/components/color_picker/color_stops/color_stops.js +25 -15
  14. package/es/components/color_picker/color_stops/color_stops.styles.js +65 -0
  15. package/es/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  16. package/es/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  17. package/es/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  18. package/es/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +160 -173
  19. package/es/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  20. package/es/components/date_picker/super_date_picker/super_date_picker.js +16 -0
  21. package/es/components/error_boundary/error_boundary.a11y.js +67 -0
  22. package/es/components/expression/expression.a11y.js +254 -0
  23. package/es/components/filter_group/filter_group.a11y.js +281 -0
  24. package/es/components/focus_trap/focus_trap.a11y.js +131 -0
  25. package/es/components/form/file_picker/file_picker.js +1 -0
  26. package/es/components/form/range/range_highlight.styles.js +1 -1
  27. package/es/components/form/range/range_levels.styles.js +1 -1
  28. package/es/components/form/range/range_track.js +5 -2
  29. package/es/components/header/header.a11y.js +374 -0
  30. package/es/components/icon/icon_ML.a11y.js +33 -0
  31. package/es/components/icon/icon_apps.a11y.js +33 -0
  32. package/es/components/icon/icon_editor.a11y.js +33 -0
  33. package/es/components/icon/icon_elastic.a11y.js +33 -0
  34. package/es/components/icon/icon_glyphs.a11y.js +33 -0
  35. package/es/components/icon/icon_tokens.a11y.js +33 -0
  36. package/es/components/image/image.a11y.js +55 -0
  37. package/es/components/key_pad_menu/key_pad_menu.a11y.js +158 -0
  38. package/es/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +1 -1
  39. package/es/components/popover/popover.js +2 -2
  40. package/es/components/selectable/selectable.js +4 -3
  41. package/es/components/selectable/selectable_list/selectable_list.js +17 -5
  42. package/es/components/table/table_footer_cell.js +1 -1
  43. package/es/components/table/table_header_cell.js +1 -1
  44. package/es/components/table/table_row_cell.js +2 -2
  45. package/es/components/tabs/tab.js +7 -17
  46. package/es/components/tabs/tabbed_content/tabbed_content.js +0 -16
  47. package/es/components/tabs/tabs.js +7 -11
  48. package/es/components/tabs/tabs_context.js +13 -0
  49. package/es/services/color/manipulation.js +9 -0
  50. package/es/services/index.js +11 -11
  51. package/eui.d.ts +195 -138
  52. package/i18ntokens.json +46 -30
  53. package/lib/components/basic_table/basic_table.js +2 -2
  54. package/lib/components/basic_table/in_memory_table.js +3 -6
  55. package/lib/components/basic_table/table.a11y.js +139 -0
  56. package/lib/components/color_picker/color_picker.styles.js +26 -0
  57. package/lib/components/color_picker/color_stops/color_stop_thumb.js +19 -6
  58. package/lib/components/color_picker/color_stops/color_stop_thumb.styles.js +69 -0
  59. package/lib/components/color_picker/color_stops/color_stops.js +25 -14
  60. package/lib/components/color_picker/color_stops/color_stops.styles.js +73 -0
  61. package/lib/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  62. package/lib/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  63. package/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  64. package/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +155 -168
  65. package/lib/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  66. package/lib/components/date_picker/super_date_picker/super_date_picker.js +16 -0
  67. package/lib/components/error_boundary/error_boundary.a11y.js +75 -0
  68. package/lib/components/expression/expression.a11y.js +262 -0
  69. package/lib/components/filter_group/filter_group.a11y.js +287 -0
  70. package/lib/components/focus_trap/focus_trap.a11y.js +140 -0
  71. package/lib/components/form/file_picker/file_picker.js +1 -0
  72. package/lib/components/form/range/range_highlight.styles.js +1 -1
  73. package/lib/components/form/range/range_levels.styles.js +1 -1
  74. package/lib/components/form/range/range_track.js +6 -2
  75. package/lib/components/header/header.a11y.js +385 -0
  76. package/lib/components/icon/icon_ML.a11y.js +40 -0
  77. package/lib/components/icon/icon_apps.a11y.js +40 -0
  78. package/lib/components/icon/icon_editor.a11y.js +40 -0
  79. package/lib/components/icon/icon_elastic.a11y.js +40 -0
  80. package/lib/components/icon/icon_glyphs.a11y.js +40 -0
  81. package/lib/components/icon/icon_tokens.a11y.js +40 -0
  82. package/lib/components/image/image.a11y.js +61 -0
  83. package/lib/components/key_pad_menu/key_pad_menu.a11y.js +163 -0
  84. package/lib/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -2
  85. package/lib/components/popover/popover.js +2 -2
  86. package/lib/components/selectable/selectable.js +4 -3
  87. package/lib/components/selectable/selectable_list/selectable_list.js +17 -5
  88. package/lib/components/table/table_footer_cell.js +1 -1
  89. package/lib/components/table/table_header_cell.js +1 -1
  90. package/lib/components/table/table_row_cell.js +2 -2
  91. package/lib/components/tabs/tab.js +14 -17
  92. package/lib/components/tabs/tabbed_content/tabbed_content.js +0 -16
  93. package/lib/components/tabs/tabs.js +8 -14
  94. package/lib/components/tabs/tabs_context.js +23 -0
  95. package/lib/services/color/manipulation.js +14 -2
  96. package/lib/services/index.js +65 -58
  97. package/optimize/es/components/basic_table/table.a11y.js +128 -0
  98. package/optimize/es/components/color_picker/color_picker.styles.js +16 -0
  99. package/optimize/es/components/color_picker/color_stops/color_stop_thumb.js +19 -7
  100. package/optimize/es/components/color_picker/color_stops/color_stop_thumb.styles.js +59 -0
  101. package/optimize/es/components/color_picker/color_stops/color_stops.js +25 -15
  102. package/optimize/es/components/color_picker/color_stops/color_stops.styles.js +65 -0
  103. package/optimize/es/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  104. package/optimize/es/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  105. package/optimize/es/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  106. package/optimize/es/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +145 -169
  107. package/optimize/es/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  108. package/optimize/es/components/date_picker/super_date_picker/super_date_picker.js +2 -0
  109. package/optimize/es/components/error_boundary/error_boundary.a11y.js +67 -0
  110. package/optimize/es/components/expression/expression.a11y.js +243 -0
  111. package/optimize/es/components/filter_group/filter_group.a11y.js +271 -0
  112. package/optimize/es/components/focus_trap/focus_trap.a11y.js +120 -0
  113. package/optimize/es/components/form/file_picker/file_picker.js +1 -0
  114. package/optimize/es/components/form/range/range_highlight.styles.js +1 -1
  115. package/optimize/es/components/form/range/range_levels.styles.js +1 -1
  116. package/optimize/es/components/form/range/range_track.js +5 -2
  117. package/optimize/es/components/header/header.a11y.js +364 -0
  118. package/optimize/es/components/icon/icon_ML.a11y.js +33 -0
  119. package/optimize/es/components/icon/icon_apps.a11y.js +33 -0
  120. package/optimize/es/components/icon/icon_editor.a11y.js +33 -0
  121. package/optimize/es/components/icon/icon_elastic.a11y.js +33 -0
  122. package/optimize/es/components/icon/icon_glyphs.a11y.js +33 -0
  123. package/optimize/es/components/icon/icon_tokens.a11y.js +33 -0
  124. package/optimize/es/components/image/image.a11y.js +55 -0
  125. package/optimize/es/components/key_pad_menu/key_pad_menu.a11y.js +148 -0
  126. package/optimize/es/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +1 -1
  127. package/optimize/es/components/popover/popover.js +2 -2
  128. package/optimize/es/components/selectable/selectable.js +2 -2
  129. package/optimize/es/components/selectable/selectable_list/selectable_list.js +15 -4
  130. package/optimize/es/components/tabs/tab.js +7 -5
  131. package/optimize/es/components/tabs/tabs.js +7 -11
  132. package/optimize/es/components/tabs/tabs_context.js +13 -0
  133. package/optimize/es/services/color/manipulation.js +9 -0
  134. package/optimize/es/services/index.js +11 -11
  135. package/optimize/lib/components/basic_table/table.a11y.js +139 -0
  136. package/optimize/lib/components/color_picker/color_picker.styles.js +26 -0
  137. package/optimize/lib/components/color_picker/color_stops/color_stop_thumb.js +19 -6
  138. package/optimize/lib/components/color_picker/color_stops/color_stop_thumb.styles.js +69 -0
  139. package/optimize/lib/components/color_picker/color_stops/color_stops.js +25 -14
  140. package/optimize/lib/components/color_picker/color_stops/color_stops.styles.js +73 -0
  141. package/optimize/lib/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  142. package/optimize/lib/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  143. package/optimize/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  144. package/optimize/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +146 -167
  145. package/optimize/lib/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  146. package/optimize/lib/components/date_picker/super_date_picker/super_date_picker.js +2 -0
  147. package/optimize/lib/components/error_boundary/error_boundary.a11y.js +75 -0
  148. package/optimize/lib/components/expression/expression.a11y.js +254 -0
  149. package/optimize/lib/components/filter_group/filter_group.a11y.js +287 -0
  150. package/optimize/lib/components/focus_trap/focus_trap.a11y.js +140 -0
  151. package/optimize/lib/components/form/file_picker/file_picker.js +1 -0
  152. package/optimize/lib/components/form/range/range_highlight.styles.js +1 -1
  153. package/optimize/lib/components/form/range/range_levels.styles.js +1 -1
  154. package/optimize/lib/components/form/range/range_track.js +6 -2
  155. package/optimize/lib/components/header/header.a11y.js +385 -0
  156. package/optimize/lib/components/icon/icon_ML.a11y.js +40 -0
  157. package/optimize/lib/components/icon/icon_apps.a11y.js +40 -0
  158. package/optimize/lib/components/icon/icon_editor.a11y.js +40 -0
  159. package/optimize/lib/components/icon/icon_elastic.a11y.js +40 -0
  160. package/optimize/lib/components/icon/icon_glyphs.a11y.js +40 -0
  161. package/optimize/lib/components/icon/icon_tokens.a11y.js +40 -0
  162. package/optimize/lib/components/image/image.a11y.js +61 -0
  163. package/optimize/lib/components/key_pad_menu/key_pad_menu.a11y.js +163 -0
  164. package/optimize/lib/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -2
  165. package/optimize/lib/components/popover/popover.js +2 -2
  166. package/optimize/lib/components/selectable/selectable.js +2 -2
  167. package/optimize/lib/components/selectable/selectable_list/selectable_list.js +15 -4
  168. package/optimize/lib/components/tabs/tab.js +15 -5
  169. package/optimize/lib/components/tabs/tabs.js +8 -14
  170. package/optimize/lib/components/tabs/tabs_context.js +23 -0
  171. package/optimize/lib/services/color/manipulation.js +14 -2
  172. package/optimize/lib/services/index.js +65 -58
  173. package/package.json +4 -6
  174. package/src/components/color_picker/_index.scss +0 -1
  175. package/src/components/date_picker/super_date_picker/quick_select_popover/_quick_select_popover.scss +14 -0
  176. package/src/components/form/file_picker/_file_picker.scss +14 -14
  177. package/src/themes/amsterdam/overrides/_index.scss +0 -1
  178. package/test-env/components/basic_table/basic_table.js +2 -2
  179. package/test-env/components/basic_table/in_memory_table.js +3 -6
  180. package/test-env/components/basic_table/table.a11y.js +139 -0
  181. package/test-env/components/color_picker/color_picker.styles.js +26 -0
  182. package/test-env/components/color_picker/color_stops/color_stop_thumb.js +19 -6
  183. package/test-env/components/color_picker/color_stops/color_stop_thumb.styles.js +69 -0
  184. package/test-env/components/color_picker/color_stops/color_stops.js +25 -14
  185. package/test-env/components/color_picker/color_stops/color_stops.styles.js +73 -0
  186. package/test-env/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  187. package/test-env/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  188. package/test-env/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  189. package/test-env/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +153 -166
  190. package/test-env/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  191. package/test-env/components/date_picker/super_date_picker/super_date_picker.js +16 -0
  192. package/test-env/components/error_boundary/error_boundary.a11y.js +75 -0
  193. package/test-env/components/expression/expression.a11y.js +254 -0
  194. package/test-env/components/filter_group/filter_group.a11y.js +287 -0
  195. package/test-env/components/focus_trap/focus_trap.a11y.js +140 -0
  196. package/test-env/components/form/file_picker/file_picker.js +1 -0
  197. package/test-env/components/form/range/range_highlight.styles.js +1 -1
  198. package/test-env/components/form/range/range_levels.styles.js +1 -1
  199. package/test-env/components/form/range/range_track.js +6 -2
  200. package/test-env/components/header/header.a11y.js +385 -0
  201. package/test-env/components/icon/icon_ML.a11y.js +40 -0
  202. package/test-env/components/icon/icon_apps.a11y.js +40 -0
  203. package/test-env/components/icon/icon_editor.a11y.js +40 -0
  204. package/test-env/components/icon/icon_elastic.a11y.js +40 -0
  205. package/test-env/components/icon/icon_glyphs.a11y.js +40 -0
  206. package/test-env/components/icon/icon_tokens.a11y.js +40 -0
  207. package/test-env/components/image/image.a11y.js +61 -0
  208. package/test-env/components/key_pad_menu/key_pad_menu.a11y.js +163 -0
  209. package/test-env/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -2
  210. package/test-env/components/popover/popover.js +2 -2
  211. package/test-env/components/selectable/selectable.js +4 -3
  212. package/test-env/components/selectable/selectable_list/selectable_list.js +17 -5
  213. package/test-env/components/table/table_footer_cell.js +1 -1
  214. package/test-env/components/table/table_header_cell.js +1 -1
  215. package/test-env/components/table/table_row_cell.js +2 -2
  216. package/test-env/components/tabs/tab.js +15 -17
  217. package/test-env/components/tabs/tabbed_content/tabbed_content.js +0 -16
  218. package/test-env/components/tabs/tabs.js +8 -14
  219. package/test-env/components/tabs/tabs_context.js +23 -0
  220. package/test-env/services/color/manipulation.js +14 -2
  221. package/test-env/services/index.js +65 -58
  222. package/src/components/color_picker/color_stops/_color_stops.scss +0 -101
  223. package/src/components/color_picker/color_stops/_index.scss +0 -1
  224. package/src/themes/amsterdam/overrides/_color_stops.scss +0 -58
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _icon = require("./icon");
8
+
9
+ var _react2 = require("@emotion/react");
10
+
11
+ /*
12
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
13
+ * or more contributor license agreements. Licensed under the Elastic License
14
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
15
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
16
+ * Side Public License, v 1.
17
+ */
18
+ /// <reference types="../../../cypress/support"/>
19
+ describe('EuiIcons', function () {
20
+ describe('Automated accessibility check for editor icons', function () {
21
+ var EditorIcons = ['editorAlignCenter', 'editorAlignLeft', 'editorAlignRight', 'editorBold', 'editorChecklist', 'editorCodeBlock', 'editorComment', 'editorDistributeHorizontal', 'editorDistributeVertical', 'editorHeading', 'editorItalic', 'editorItemAlignBottom', 'editorItemAlignCenter', 'editorItemAlignLeft', 'editorItemAlignMiddle', 'editorItemAlignRight', 'editorItemAlignTop', 'editorLink', 'editorOrderedList', 'editorPositionBottomLeft', 'editorPositionBottomRight', 'editorPositionTopLeft', 'editorPositionTopRight', 'editorRedo', 'editorStrike', 'editorTable', 'editorUnderline', 'editorUndo', 'editorUnorderedList'];
22
+
23
+ var EditorGrid = function EditorGrid() {
24
+ return (0, _react2.jsx)("div", null, EditorIcons.map(function (glyph) {
25
+ return (0, _react2.jsx)(_icon.EuiIcon, {
26
+ className: "eui-alignMiddle",
27
+ type: glyph
28
+ });
29
+ }));
30
+ };
31
+
32
+ it('has zero violations on first render', function () {
33
+ cy.mount((0, _react2.jsx)(EditorGrid, null));
34
+ cy.get('div[data-cy-root]').find('svg', {
35
+ timeout: 5000
36
+ }).should('have.length', 29);
37
+ cy.checkAxe();
38
+ });
39
+ });
40
+ });
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _icon = require("./icon");
8
+
9
+ var _react2 = require("@emotion/react");
10
+
11
+ /*
12
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
13
+ * or more contributor license agreements. Licensed under the Elastic License
14
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
15
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
16
+ * Side Public License, v 1.
17
+ */
18
+ /// <reference types="../../../cypress/support"/>
19
+ describe('EuiIcons', function () {
20
+ describe('Automated accessibility check for Elastic logos', function () {
21
+ var ElasticLogos = ['logoElastic', 'logoElasticStack', 'logoElasticsearch', 'logoAppSearch', 'logoBeats', 'logoBusinessAnalytics', 'logoCloud', 'logoCloudEnterprise', 'logoEnterpriseSearch', 'logoKibana', 'logoLogging', 'logoLogstash', 'logoMaps', 'logoMetrics', 'logoObservability', 'logoSecurity', 'logoSiteSearch', 'logoUptime', 'logoWorkplaceSearch'];
22
+
23
+ var ElasticGrid = function ElasticGrid() {
24
+ return (0, _react2.jsx)("div", null, ElasticLogos.map(function (glyph) {
25
+ return (0, _react2.jsx)(_icon.EuiIcon, {
26
+ className: "eui-alignMiddle",
27
+ type: glyph
28
+ });
29
+ }));
30
+ };
31
+
32
+ it('has zero violations on first render', function () {
33
+ cy.mount((0, _react2.jsx)(ElasticGrid, null));
34
+ cy.get('div[data-cy-root]').find('svg', {
35
+ timeout: 5000
36
+ }).should('have.length', 19);
37
+ cy.checkAxe();
38
+ });
39
+ });
40
+ });
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _icon = require("./icon");
8
+
9
+ var _react2 = require("@emotion/react");
10
+
11
+ /*
12
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
13
+ * or more contributor license agreements. Licensed under the Elastic License
14
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
15
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
16
+ * Side Public License, v 1.
17
+ */
18
+ /// <reference types="../../../cypress/support"/>
19
+ describe('EuiIcons', function () {
20
+ describe('Automated accessibility check for glyph icons', function () {
21
+ var GlyphIcons = ['accessibility', 'aggregate', 'alert', 'analyzeEvent', 'annotation', 'apmTrace', 'apps', 'arrowDown', 'arrowLeft', 'arrowRight', 'arrowUp', 'arrowStart', 'arrowEnd', 'article', 'asterisk', 'beaker', 'bell', 'bellSlash', 'beta', 'bolt', 'boxesHorizontal', 'boxesVertical', 'branch', 'branchUser', 'broom', 'brush', 'bug', 'bullseye', 'calendar', 'check', 'checkInCircleFilled', 'cheer', 'clock', 'cloudDrizzle', 'cloudStormy', 'cloudSunny', 'cluster', 'color', 'compute', 'console', 'container', 'continuityAbove', 'continuityAboveBelow', 'continuityBelow', 'continuityWithin', 'controlsHorizontal', 'controlsVertical', 'copy', 'copyClipboard', 'cross', 'crosshairs', 'crossInACircleFilled', 'currency', 'cut', 'database', 'desktop', 'discuss', 'document', 'documents', 'documentEdit', 'documentation', 'dot', 'dotInCircle', 'doubleArrowLeft', 'doubleArrowRight', 'download', 'email', 'empty', 'eql', 'eraser', 'exit', 'expand', 'expandMini', 'exportAction', 'eye', 'eyeClosed', 'faceHappy', 'faceNeutral', 'faceSad', 'filter', 'filterExclude', 'filterIgnore', 'filterInclude', 'filterInCircle', 'flag', 'fold', 'folderCheck', 'folderClosed', 'folderExclamation', 'folderOpen', 'frameNext', 'framePrevious', 'fullScreen', 'fullScreenExit', 'function', 'gear', 'glasses', 'globe', 'grab', 'grabHorizontal', 'grid', 'heart', 'heatmap', 'help', 'home', 'iInCircle', 'image', 'importAction', 'indexClose', 'indexEdit', 'indexFlush', 'indexMapping', 'indexOpen', 'indexRuntime', 'indexSettings', 'indexTemporary', 'infinity', 'inputOutput', 'inspect', 'invert', 'ip', 'keyboard', 'kqlField', 'kqlFunction', 'kqlOperand', 'kqlSelector', 'kqlValue', 'kubernetesNode', 'kubernetesPod', 'launch', 'layers', 'lettering', 'lineDashed', 'lineDotted', 'lineSolid', 'link', 'list', 'listAdd', 'lock', 'lockOpen', 'logstashFilter', 'logstashIf', 'logstashInput', 'logstashOutput', 'logstashQueue', 'magnifyWithExclamation', 'magnifyWithMinus', 'magnifyWithPlus', 'magnet', 'mapMarker', 'memory', 'merge', 'menu', 'menuDown', 'menuLeft', 'menuRight', 'menuUp', 'minimize', 'minus', 'minusInCircle', 'minusInCircleFilled', 'mobile', 'moon', 'namespace', 'nested', 'node', 'number', 'offline', 'online', 'package', 'pageSelect', 'pagesSelect', 'paperClip', 'partial', 'pause', 'payment', 'pencil', 'percent', 'pin', 'pinFilled', 'play', 'playFilled', 'plus', 'plusInCircle', 'plusInCircleFilled', 'popout', 'push', 'questionInCircle', 'quote', 'refresh', 'reporter', 'returnKey', 'save', 'scale', 'search', 'securitySignal', 'securitySignalDetected', 'securitySignalResolved', 'sessionViewer', 'shard', 'share', 'snowflake', 'sortable', 'sortAscending', 'sortDescending', 'sortDown', 'sortLeft', 'sortRight', 'sortUp', 'spaces', 'starEmpty', 'starEmptySpace', 'starFilled', 'starFilledSpace', 'starMinusEmpty', 'starMinusFilled', 'starPlusEmpty', 'starPlusFilled', 'stats', 'stop', 'stopFilled', 'stopSlash', 'storage', 'string', 'submodule', 'sun', 'symlink', 'tableOfContents', 'tableDensityExpanded', 'tableDensityCompact', 'tableDensityNormal', 'tag', 'tear', 'temperature', 'timeline', 'timeRefresh', 'timeslider', 'training', 'trash', 'unfold', 'unlink', 'user', 'userAvatar', 'users', 'vector', 'videoPlayer', 'visArea', 'visAreaStacked', 'visBarHorizontal', 'visBarHorizontalStacked', 'visBarVertical', 'visBarVerticalStacked', 'visGauge', 'visGoal', 'visLine', 'visMapCoordinate', 'visMapRegion', 'visMetric', 'visPie', 'visTable', 'visTagCloud', 'visText', 'visTimelion', 'visVega', 'visVisualBuilder', 'wordWrap', 'wordWrapDisabled', 'wrench'];
22
+
23
+ var GlyphGrid = function GlyphGrid() {
24
+ return (0, _react2.jsx)("div", null, GlyphIcons.map(function (glyph) {
25
+ return (0, _react2.jsx)(_icon.EuiIcon, {
26
+ className: "eui-alignMiddle",
27
+ type: glyph
28
+ });
29
+ }));
30
+ };
31
+
32
+ it('has zero violations on first render', function () {
33
+ cy.mount((0, _react2.jsx)(GlyphGrid, null));
34
+ cy.get('svg[data-icon-type="wrench"]', {
35
+ timeout: 5000
36
+ }).should('exist');
37
+ cy.checkAxe();
38
+ });
39
+ });
40
+ });
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _icon = require("./icon");
8
+
9
+ var _react2 = require("@emotion/react");
10
+
11
+ /*
12
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
13
+ * or more contributor license agreements. Licensed under the Elastic License
14
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
15
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
16
+ * Side Public License, v 1.
17
+ */
18
+ /// <reference types="../../../cypress/support"/>
19
+ describe('EuiIcons', function () {
20
+ describe('Automated accessibility check for token icons', function () {
21
+ var TokenIcons = ['tokenAlias', 'tokenAnnotation', 'tokenArray', 'tokenBinary', 'tokenBoolean', 'tokenClass', 'tokenCompletionSuggester', 'tokenConstant', 'tokenDate', 'tokenDenseVector', 'tokenElement', 'tokenEnum', 'tokenEnumMember', 'tokenEvent', 'tokenException', 'tokenField', 'tokenFile', 'tokenFlattened', 'tokenFunction', 'tokenGeo', 'tokenHistogram', 'tokenInterface', 'tokenIP', 'tokenJoin', 'tokenKey', 'tokenKeyword', 'tokenMethod', 'tokenMetricCounter', 'tokenMetricGauge', 'tokenModule', 'tokenNamespace', 'tokenNested', 'tokenNull', 'tokenNumber', 'tokenObject', 'tokenOperator', 'tokenPackage', 'tokenParameter', 'tokenPercolator', 'tokenProperty', 'tokenRange', 'tokenRankFeature', 'tokenRankFeatures', 'tokenRepo', 'tokenSearchType', 'tokenShape', 'tokenString', 'tokenStruct', 'tokenSymbol', 'tokenTag', 'tokenText', 'tokenTokenCount', 'tokenVariable'];
22
+
23
+ var TokenGrid = function TokenGrid() {
24
+ return (0, _react2.jsx)("div", null, TokenIcons.map(function (glyph) {
25
+ return (0, _react2.jsx)(_icon.EuiIcon, {
26
+ className: "eui-alignMiddle",
27
+ type: glyph
28
+ });
29
+ }));
30
+ };
31
+
32
+ it('has zero violations on first render', function () {
33
+ cy.mount((0, _react2.jsx)(TokenGrid, null));
34
+ cy.get('div[data-cy-root]').find('svg', {
35
+ timeout: 5000
36
+ }).should('have.length', 53);
37
+ cy.checkAxe();
38
+ });
39
+ });
40
+ });
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _image = require("./image");
8
+
9
+ var _react2 = require("@emotion/react");
10
+
11
+ /*
12
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
13
+ * or more contributor license agreements. Licensed under the Elastic License
14
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
15
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
16
+ * Side Public License, v 1.
17
+ */
18
+ /// <reference types="../../../cypress/support"/>
19
+ var Image = function Image() {
20
+ return (0, _react2.jsx)(_image.EuiImage, {
21
+ size: "m",
22
+ hasShadow: true,
23
+ allowFullScreen: true,
24
+ caption: "Albert Einstein, theoretical physicist",
25
+ alt: "" // Because this image is sufficiently described by its caption, there is no need to repeat it via alt text
26
+ ,
27
+ src: "https://upload.wikimedia.org/wikipedia/commons/d/d3/Albert_Einstein_Head.jpg"
28
+ });
29
+ };
30
+
31
+ beforeEach(function () {
32
+ cy.viewport(1024, 768); // medium breakpoint
33
+
34
+ cy.realMount((0, _react2.jsx)(Image, null));
35
+ cy.get('figure[aria-label="Albert Einstein, theoretical physicist"]').should('exist');
36
+ });
37
+ describe('EuiImage', function () {
38
+ describe('Automated accessibility check', function () {
39
+ it('has zero violations on first render', function () {
40
+ cy.checkAxe();
41
+ });
42
+ it('has zero violations on fullscreen render', function () {
43
+ cy.get('button[data-test-subj="activateFullScreenButton"]').realClick();
44
+ cy.get('button[data-test-subj="deactivateFullScreenButton"]').should('exist');
45
+ cy.checkAxe();
46
+ cy.get('div[data-test-subj="fullScreenOverlayMask"]').realClick();
47
+ cy.checkAxe();
48
+ });
49
+ it('has zero violations on keyboard interaction', function () {
50
+ cy.realPress('Tab');
51
+ cy.get('button[data-test-subj="activateFullScreenButton"]').should('have.focus');
52
+ cy.realPress('Enter');
53
+ cy.get('button[data-test-subj="deactivateFullScreenButton"]').should('exist');
54
+ cy.get('button[data-test-subj="deactivateFullScreenButton"]').should('have.focus');
55
+ cy.checkAxe();
56
+ cy.realPress('Escape');
57
+ cy.get('button[data-test-subj="activateFullScreenButton"]').should('have.focus');
58
+ cy.checkAxe();
59
+ });
60
+ });
61
+ });
@@ -0,0 +1,163 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
8
+
9
+ var _react = _interopRequireWildcard(require("react"));
10
+
11
+ var _key_pad_menu = require("./key_pad_menu");
12
+
13
+ var _key_pad_menu_item = require("./key_pad_menu_item");
14
+
15
+ var _icon = require("../icon");
16
+
17
+ var _services = require("../../services");
18
+
19
+ var _react2 = require("@emotion/react");
20
+
21
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
22
+
23
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
24
+
25
+ /*
26
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
27
+ * or more contributor license agreements. Licensed under the Elastic License
28
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
29
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
30
+ * Side Public License, v 1.
31
+ */
32
+ /// <reference types="../../../cypress/support"/>
33
+ var KeyPadMenu = function KeyPadMenu() {
34
+ var keypadButtonId__1 = (0, _services.useGeneratedHtmlId)({
35
+ prefix: 'keypadButton',
36
+ suffix: 'first'
37
+ });
38
+ var keypadButtonId__2 = (0, _services.useGeneratedHtmlId)({
39
+ prefix: 'keypadButton',
40
+ suffix: 'second'
41
+ });
42
+ var keypadButtonId__3 = (0, _services.useGeneratedHtmlId)({
43
+ prefix: 'keypadButton',
44
+ suffix: 'third'
45
+ });
46
+ var keypadButtonId__4 = (0, _services.useGeneratedHtmlId)({
47
+ prefix: 'keypadButton',
48
+ suffix: 'fourth'
49
+ });
50
+ var keypadButtonId__5 = (0, _services.useGeneratedHtmlId)({
51
+ prefix: 'keypadButton',
52
+ suffix: 'fifth'
53
+ });
54
+ var keypadButtonId__6 = (0, _services.useGeneratedHtmlId)({
55
+ prefix: 'keypadButton',
56
+ suffix: 'sixth'
57
+ });
58
+
59
+ var _useState = (0, _react.useState)(keypadButtonId__6),
60
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
61
+ selectedID = _useState2[0],
62
+ setSelectedID = _useState2[1];
63
+
64
+ return (0, _react2.jsx)("div", {
65
+ "aria-label": "Menu keypad"
66
+ }, (0, _react2.jsx)(_key_pad_menu.EuiKeyPadMenu, null, (0, _react2.jsx)(_key_pad_menu_item.EuiKeyPadMenuItem, {
67
+ "data-test-subj": "cy-keypad-button-1",
68
+ id: keypadButtonId__1,
69
+ label: "Button 1",
70
+ isSelected: selectedID === keypadButtonId__1,
71
+ onClick: function onClick() {
72
+ return setSelectedID(keypadButtonId__1);
73
+ }
74
+ }, (0, _react2.jsx)(_icon.EuiIcon, {
75
+ type: "grid",
76
+ size: "l"
77
+ })), (0, _react2.jsx)(_key_pad_menu_item.EuiKeyPadMenuItem, {
78
+ "data-test-subj": "cy-keypad-button-2",
79
+ id: keypadButtonId__2,
80
+ label: "Button 2",
81
+ isSelected: selectedID === keypadButtonId__2,
82
+ onClick: function onClick() {
83
+ return setSelectedID(keypadButtonId__2);
84
+ }
85
+ }, (0, _react2.jsx)(_icon.EuiIcon, {
86
+ type: "grid",
87
+ size: "l"
88
+ })), (0, _react2.jsx)(_key_pad_menu_item.EuiKeyPadMenuItem, {
89
+ "data-test-subj": "cy-keypad-button-3",
90
+ id: keypadButtonId__3,
91
+ label: "Button 3",
92
+ isSelected: selectedID === keypadButtonId__3,
93
+ onClick: function onClick() {
94
+ return setSelectedID(keypadButtonId__3);
95
+ }
96
+ }, (0, _react2.jsx)(_icon.EuiIcon, {
97
+ type: "grid",
98
+ size: "l"
99
+ })), (0, _react2.jsx)(_key_pad_menu_item.EuiKeyPadMenuItem, {
100
+ "data-test-subj": "cy-keypad-link-1",
101
+ id: keypadButtonId__4,
102
+ label: "Link 1",
103
+ href: "#/navigation/key-pad-menu",
104
+ isSelected: selectedID === keypadButtonId__4,
105
+ onClick: function onClick() {
106
+ return setSelectedID(keypadButtonId__4);
107
+ }
108
+ }, (0, _react2.jsx)(_icon.EuiIcon, {
109
+ type: "link",
110
+ size: "l"
111
+ })), (0, _react2.jsx)(_key_pad_menu_item.EuiKeyPadMenuItem, {
112
+ "data-test-subj": "cy-keypad-link-2",
113
+ id: keypadButtonId__5,
114
+ label: "Link 2",
115
+ href: "#/navigation/key-pad-menu",
116
+ isSelected: selectedID === keypadButtonId__5,
117
+ onClick: function onClick() {
118
+ return setSelectedID(keypadButtonId__5);
119
+ }
120
+ }, (0, _react2.jsx)(_icon.EuiIcon, {
121
+ type: "link",
122
+ size: "l"
123
+ })), (0, _react2.jsx)(_key_pad_menu_item.EuiKeyPadMenuItem, {
124
+ "data-test-subj": "cy-keypad-link-3",
125
+ id: keypadButtonId__6,
126
+ label: "Disabled Link 3",
127
+ isDisabled: true,
128
+ isSelected: selectedID === keypadButtonId__6
129
+ }, (0, _react2.jsx)(_icon.EuiIcon, {
130
+ type: "link",
131
+ size: "l"
132
+ }))));
133
+ };
134
+
135
+ beforeEach(function () {
136
+ cy.realMount((0, _react2.jsx)(KeyPadMenu, null));
137
+ cy.get('div[aria-label="Menu keypad"]').should('exist');
138
+ });
139
+ describe('EuiKeyPadMenu', function () {
140
+ describe('Automated accessibility check', function () {
141
+ it('has zero violations on first render', function () {
142
+ cy.checkAxe();
143
+ });
144
+ it('has zero violations on item click', function () {
145
+ cy.get('a[data-test-subj="cy-keypad-link-2"]').realClick();
146
+ cy.get('a[data-test-subj="cy-keypad-link-2"]').should('have.class', 'euiKeyPadMenuItem-isSelected');
147
+ cy.checkAxe();
148
+ });
149
+ it('has zero violations on item keypress', function () {
150
+ cy.repeatRealPress('Tab', 3);
151
+ cy.get('button[data-test-subj="cy-keypad-button-3"]').should('have.focus');
152
+ cy.realPress('Space');
153
+ cy.get('button[data-test-subj="cy-keypad-button-3"]').should('have.class', 'euiKeyPadMenuItem-isSelected');
154
+ cy.checkAxe();
155
+ cy.realPress(['Shift', 'Tab']);
156
+ cy.get('button[data-test-subj="cy-keypad-button-2"]').should('have.focus');
157
+ cy.realPress('Space');
158
+ cy.get('button[data-test-subj="cy-keypad-button-2"]').should('have.class', 'euiKeyPadMenuItem-isSelected');
159
+ cy.get('button[data-test-subj="cy-keypad-button-3"]').should('not.have.class', 'euiKeyPadMenuItem-isSelected');
160
+ cy.checkAxe();
161
+ });
162
+ });
163
+ });
@@ -9,7 +9,7 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports.getDefaultEuiMarkdownParsingPlugins = exports.defaultParsingPlugins = void 0;
11
11
 
12
- var _remarkParse = _interopRequireDefault(require("remark-parse"));
12
+ var _remarkParseNoTrim = _interopRequireDefault(require("remark-parse-no-trim"));
13
13
 
14
14
  var _remarkEmoji = _interopRequireDefault(require("remark-emoji"));
15
15
 
@@ -43,7 +43,7 @@ var getDefaultEuiMarkdownParsingPlugins = function getDefaultEuiMarkdownParsingP
43
43
  exclude = _ref.exclude;
44
44
 
45
45
  var excludeSet = new Set(exclude);
46
- var parsingPlugins = [[_remarkParse.default, {}], [_remark_prismjs.default, {}], [_remarkEmoji.default, {
46
+ var parsingPlugins = [[_remarkParseNoTrim.default, {}], [_remark_prismjs.default, {}], [_remarkEmoji.default, {
47
47
  emoticon: false
48
48
  }], [_remarkBreaks.default, {}], [_markdown_link_validator.euiMarkdownLinkValidator, {
49
49
  allowRelative: true,
@@ -489,13 +489,13 @@ var EuiPopover = /*#__PURE__*/function (_Component) {
489
489
  panel = (0, _react.jsx)(_portal.EuiPortal, {
490
490
  insert: insert
491
491
  }, (0, _react.jsx)(_focus_trap.EuiFocusTrap, (0, _extends2.default)({
492
- clickOutsideDisables: true
492
+ clickOutsideDisables: true,
493
+ onClickOutside: this.onClickOutside
493
494
  }, focusTrapProps, {
494
495
  returnFocus: returnFocus // Ignore temporary state of indecisive focus
495
496
  ,
496
497
  initialFocus: initialFocus,
497
498
  onDeactivation: onTrapDeactivation,
498
- onClickOutside: this.onClickOutside,
499
499
  onEscapeKey: this.onEscapeKey,
500
500
  disabled: !ownFocus || !this.state.isOpenStable || this.state.isClosing
501
501
  }), (0, _react.jsx)(_popover_panel.EuiPopoverPanel, (0, _extends2.default)({}, panelProps, {
@@ -261,7 +261,7 @@ var EuiSelectable = /*#__PURE__*/function (_Component) {
261
261
  isFocused: false
262
262
  });
263
263
  });
264
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onOptionClick", function (options, event) {
264
+ (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onOptionClick", function (options, event, clickedOption) {
265
265
  var _this$props = _this.props,
266
266
  isPreFiltered = _this$props.isPreFiltered,
267
267
  onChange = _this$props.onChange;
@@ -273,7 +273,7 @@ var EuiSelectable = /*#__PURE__*/function (_Component) {
273
273
  });
274
274
 
275
275
  if (onChange) {
276
- onChange(options, event);
276
+ onChange(options, event, clickedOption);
277
277
  }
278
278
  });
279
279
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "scrollToItem", function (index, align) {
@@ -223,6 +223,9 @@ var EuiSelectableList = /*#__PURE__*/function (_Component) {
223
223
  onOptionClick = _this$props4.onOptionClick,
224
224
  options = _this$props4.options,
225
225
  singleSelection = _this$props4.singleSelection;
226
+
227
+ var changedOption = _objectSpread({}, addedOption);
228
+
226
229
  var updatedOptions = options.map(function (option) {
227
230
  // if singleSelection is enabled, uncheck any selected option(s)
228
231
  var updatedOption = _objectSpread({}, option);
@@ -234,43 +237,51 @@ var EuiSelectableList = /*#__PURE__*/function (_Component) {
234
237
 
235
238
  if (option === addedOption) {
236
239
  updatedOption.checked = 'on';
240
+ changedOption = updatedOption;
237
241
  }
238
242
 
239
243
  return updatedOption;
240
244
  });
241
- onOptionClick(updatedOptions, event);
245
+ onOptionClick(updatedOptions, event, changedOption);
242
246
  });
243
247
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onRemoveOption", function (removedOption, event) {
244
248
  var _this$props5 = _this.props,
245
249
  onOptionClick = _this$props5.onOptionClick,
246
250
  singleSelection = _this$props5.singleSelection,
247
251
  options = _this$props5.options;
252
+
253
+ var changedOption = _objectSpread({}, removedOption);
254
+
248
255
  var updatedOptions = options.map(function (option) {
249
256
  var updatedOption = _objectSpread({}, option);
250
257
 
251
258
  if (option === removedOption && singleSelection !== 'always') {
252
259
  delete updatedOption.checked;
260
+ changedOption = updatedOption;
253
261
  }
254
262
 
255
263
  return updatedOption;
256
264
  });
257
- onOptionClick(updatedOptions, event);
265
+ onOptionClick(updatedOptions, event, changedOption);
258
266
  });
259
267
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onExcludeOption", function (excludedOption, event) {
260
268
  var _this$props6 = _this.props,
261
269
  onOptionClick = _this$props6.onOptionClick,
262
270
  options = _this$props6.options;
263
- excludedOption.checked = 'off';
271
+
272
+ var changedOption = _objectSpread({}, excludedOption);
273
+
264
274
  var updatedOptions = options.map(function (option) {
265
275
  var updatedOption = _objectSpread({}, option);
266
276
 
267
277
  if (option === excludedOption) {
268
278
  updatedOption.checked = 'off';
279
+ changedOption = updatedOption;
269
280
  }
270
281
 
271
282
  return updatedOption;
272
283
  });
273
- onOptionClick(updatedOptions, event);
284
+ onOptionClick(updatedOptions, event, changedOption);
274
285
  });
275
286
  return _this;
276
287
  }
@@ -2,6 +2,8 @@
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
5
7
  Object.defineProperty(exports, "__esModule", {
6
8
  value: true
7
9
  });
@@ -11,7 +13,7 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
11
13
 
12
14
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
15
 
14
- var _react = _interopRequireDefault(require("react"));
16
+ var _react = _interopRequireWildcard(require("react"));
15
17
 
16
18
  var _classnames = _interopRequireDefault(require("classnames"));
17
19
 
@@ -21,9 +23,15 @@ var _href_validator = require("../../services/security/href_validator");
21
23
 
22
24
  var _tab = require("./tab.styles");
23
25
 
26
+ var _tabs_context = require("./tabs_context");
27
+
24
28
  var _react2 = require("@emotion/react");
25
29
 
26
- var _excluded = ["isSelected", "children", "className", "disabled", "href", "target", "rel", "prepend", "append", "size", "expand"];
30
+ var _excluded = ["isSelected", "children", "className", "disabled", "href", "target", "rel", "prepend", "append"];
31
+
32
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
33
+
34
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
27
35
 
28
36
  var EuiTab = function EuiTab(_ref) {
29
37
  var isSelected = _ref.isSelected,
@@ -35,10 +43,12 @@ var EuiTab = function EuiTab(_ref) {
35
43
  rel = _ref.rel,
36
44
  prepend = _ref.prepend,
37
45
  append = _ref.append,
38
- _ref$size = _ref.size,
39
- size = _ref$size === void 0 ? 'm' : _ref$size,
40
- expand = _ref.expand,
41
46
  rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
47
+
48
+ var _useContext = (0, _react.useContext)(_tabs_context.EuiTabsContext),
49
+ size = _useContext.size,
50
+ expand = _useContext.expand;
51
+
42
52
  var euiTheme = (0, _services.useEuiTheme)();
43
53
  var isHrefValid = !href || (0, _href_validator.validateHref)(href);
44
54
  var disabled = _disabled || !isHrefValid; // Keep CSS classnames for reference
@@ -19,10 +19,10 @@ var _classnames = _interopRequireDefault(require("classnames"));
19
19
 
20
20
  var _services = require("../../services");
21
21
 
22
- var _clone_element = require("../../services/theme/clone_element");
23
-
24
22
  var _tabs = require("./tabs.styles");
25
23
 
24
+ var _tabs_context = require("./tabs_context");
25
+
26
26
  var _react2 = require("@emotion/react");
27
27
 
28
28
  var _excluded = ["children", "className", "bottomBorder", "expand", "size"];
@@ -47,24 +47,18 @@ var EuiTabs = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
47
47
  var classes = (0, _classnames.default)('euiTabs', className);
48
48
  var styles = (0, _tabs.euiTabsStyles)(euiTheme);
49
49
  var cssStyles = [styles.euiTabs, styles[size], bottomBorder && styles.bottomBorder];
50
-
51
- var tabItems = _react.default.Children.map(children, function (child) {
52
- if ( /*#__PURE__*/_react.default.isValidElement(child)) {
53
- return (0, _clone_element.cloneElementWithCss)(child, {
54
- // we're passing the parent `size` and `expand` down to the children
55
- size: size,
56
- expand: expand
57
- });
58
- }
59
- });
60
-
61
50
  return (0, _react2.jsx)("div", (0, _extends2.default)({
62
51
  ref: ref,
63
52
  className: classes,
64
53
  css: cssStyles
65
54
  }, children && {
66
55
  role: 'tablist'
67
- }, rest), tabItems);
56
+ }, rest), (0, _react2.jsx)(_tabs_context.EuiTabsContext.Provider, {
57
+ value: {
58
+ expand: expand,
59
+ size: size
60
+ }
61
+ }, children));
68
62
  });
69
63
  exports.EuiTabs = EuiTabs;
70
64
  EuiTabs.displayName = 'EuiTabs';
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.contextDefaults = exports.EuiTabsContext = void 0;
7
+
8
+ var _react = require("react");
9
+
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
+ var contextDefaults = {
18
+ expand: false,
19
+ size: 'm'
20
+ };
21
+ exports.contextDefaults = contextDefaults;
22
+ var EuiTabsContext = /*#__PURE__*/(0, _react.createContext)(contextDefaults);
23
+ exports.EuiTabsContext = EuiTabsContext;