@elastic/eui 71.1.0 → 72.0.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 (132) hide show
  1. package/dist/eui_theme_dark.css +20 -28
  2. package/dist/eui_theme_dark.min.css +1 -1
  3. package/dist/eui_theme_light.css +20 -28
  4. package/dist/eui_theme_light.min.css +1 -1
  5. package/es/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  6. package/es/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  7. package/es/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  8. package/es/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +160 -173
  9. package/es/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  10. package/es/components/date_picker/super_date_picker/super_date_picker.js +16 -0
  11. package/es/components/error_boundary/error_boundary.a11y.js +67 -0
  12. package/es/components/expression/expression.a11y.js +254 -0
  13. package/es/components/filter_group/filter_group.a11y.js +281 -0
  14. package/es/components/focus_trap/focus_trap.a11y.js +131 -0
  15. package/es/components/form/file_picker/file_picker.js +1 -0
  16. package/es/components/header/header.a11y.js +374 -0
  17. package/es/components/icon/icon_ML.a11y.js +33 -0
  18. package/es/components/icon/icon_apps.a11y.js +33 -0
  19. package/es/components/icon/icon_editor.a11y.js +33 -0
  20. package/es/components/icon/icon_elastic.a11y.js +33 -0
  21. package/es/components/icon/icon_glyphs.a11y.js +33 -0
  22. package/es/components/icon/icon_tokens.a11y.js +33 -0
  23. package/es/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +1 -1
  24. package/es/components/selectable/selectable.js +4 -3
  25. package/es/components/selectable/selectable_list/selectable_list.js +17 -5
  26. package/es/components/tabs/tab.js +7 -17
  27. package/es/components/tabs/tabbed_content/tabbed_content.js +0 -16
  28. package/es/components/tabs/tabs.js +7 -11
  29. package/es/components/tabs/tabs_context.js +13 -0
  30. package/eui.d.ts +41 -32
  31. package/i18ntokens.json +30 -14
  32. package/lib/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  33. package/lib/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  34. package/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  35. package/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +155 -168
  36. package/lib/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  37. package/lib/components/date_picker/super_date_picker/super_date_picker.js +16 -0
  38. package/lib/components/error_boundary/error_boundary.a11y.js +75 -0
  39. package/lib/components/expression/expression.a11y.js +262 -0
  40. package/lib/components/filter_group/filter_group.a11y.js +287 -0
  41. package/lib/components/focus_trap/focus_trap.a11y.js +140 -0
  42. package/lib/components/form/file_picker/file_picker.js +1 -0
  43. package/lib/components/header/header.a11y.js +385 -0
  44. package/lib/components/icon/icon_ML.a11y.js +40 -0
  45. package/lib/components/icon/icon_apps.a11y.js +40 -0
  46. package/lib/components/icon/icon_editor.a11y.js +40 -0
  47. package/lib/components/icon/icon_elastic.a11y.js +40 -0
  48. package/lib/components/icon/icon_glyphs.a11y.js +40 -0
  49. package/lib/components/icon/icon_tokens.a11y.js +40 -0
  50. package/lib/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -2
  51. package/lib/components/selectable/selectable.js +4 -3
  52. package/lib/components/selectable/selectable_list/selectable_list.js +17 -5
  53. package/lib/components/tabs/tab.js +14 -17
  54. package/lib/components/tabs/tabbed_content/tabbed_content.js +0 -16
  55. package/lib/components/tabs/tabs.js +8 -14
  56. package/lib/components/tabs/tabs_context.js +23 -0
  57. package/optimize/es/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  58. package/optimize/es/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  59. package/optimize/es/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  60. package/optimize/es/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +145 -169
  61. package/optimize/es/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  62. package/optimize/es/components/date_picker/super_date_picker/super_date_picker.js +2 -0
  63. package/optimize/es/components/error_boundary/error_boundary.a11y.js +67 -0
  64. package/optimize/es/components/expression/expression.a11y.js +243 -0
  65. package/optimize/es/components/filter_group/filter_group.a11y.js +271 -0
  66. package/optimize/es/components/focus_trap/focus_trap.a11y.js +120 -0
  67. package/optimize/es/components/form/file_picker/file_picker.js +1 -0
  68. package/optimize/es/components/header/header.a11y.js +364 -0
  69. package/optimize/es/components/icon/icon_ML.a11y.js +33 -0
  70. package/optimize/es/components/icon/icon_apps.a11y.js +33 -0
  71. package/optimize/es/components/icon/icon_editor.a11y.js +33 -0
  72. package/optimize/es/components/icon/icon_elastic.a11y.js +33 -0
  73. package/optimize/es/components/icon/icon_glyphs.a11y.js +33 -0
  74. package/optimize/es/components/icon/icon_tokens.a11y.js +33 -0
  75. package/optimize/es/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +1 -1
  76. package/optimize/es/components/selectable/selectable.js +2 -2
  77. package/optimize/es/components/selectable/selectable_list/selectable_list.js +15 -4
  78. package/optimize/es/components/tabs/tab.js +7 -5
  79. package/optimize/es/components/tabs/tabs.js +7 -11
  80. package/optimize/es/components/tabs/tabs_context.js +13 -0
  81. package/optimize/lib/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  82. package/optimize/lib/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  83. package/optimize/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  84. package/optimize/lib/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +146 -167
  85. package/optimize/lib/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  86. package/optimize/lib/components/date_picker/super_date_picker/super_date_picker.js +2 -0
  87. package/optimize/lib/components/error_boundary/error_boundary.a11y.js +75 -0
  88. package/optimize/lib/components/expression/expression.a11y.js +254 -0
  89. package/optimize/lib/components/filter_group/filter_group.a11y.js +287 -0
  90. package/optimize/lib/components/focus_trap/focus_trap.a11y.js +140 -0
  91. package/optimize/lib/components/form/file_picker/file_picker.js +1 -0
  92. package/optimize/lib/components/header/header.a11y.js +385 -0
  93. package/optimize/lib/components/icon/icon_ML.a11y.js +40 -0
  94. package/optimize/lib/components/icon/icon_apps.a11y.js +40 -0
  95. package/optimize/lib/components/icon/icon_editor.a11y.js +40 -0
  96. package/optimize/lib/components/icon/icon_elastic.a11y.js +40 -0
  97. package/optimize/lib/components/icon/icon_glyphs.a11y.js +40 -0
  98. package/optimize/lib/components/icon/icon_tokens.a11y.js +40 -0
  99. package/optimize/lib/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -2
  100. package/optimize/lib/components/selectable/selectable.js +2 -2
  101. package/optimize/lib/components/selectable/selectable_list/selectable_list.js +15 -4
  102. package/optimize/lib/components/tabs/tab.js +15 -5
  103. package/optimize/lib/components/tabs/tabs.js +8 -14
  104. package/optimize/lib/components/tabs/tabs_context.js +23 -0
  105. package/package.json +4 -6
  106. package/src/components/date_picker/super_date_picker/quick_select_popover/_quick_select_popover.scss +14 -0
  107. package/src/components/form/file_picker/_file_picker.scss +14 -14
  108. package/test-env/components/date_picker/auto_refresh/refresh_interval.js +3 -1
  109. package/test-env/components/date_picker/super_date_picker/quick_select_popover/commonly_used_time_ranges.js +5 -2
  110. package/test-env/components/date_picker/super_date_picker/quick_select_popover/quick_select.js +3 -1
  111. package/test-env/components/date_picker/super_date_picker/quick_select_popover/quick_select_popover.js +153 -166
  112. package/test-env/components/date_picker/super_date_picker/quick_select_popover/recently_used.js +5 -2
  113. package/test-env/components/date_picker/super_date_picker/super_date_picker.js +16 -0
  114. package/test-env/components/error_boundary/error_boundary.a11y.js +75 -0
  115. package/test-env/components/expression/expression.a11y.js +254 -0
  116. package/test-env/components/filter_group/filter_group.a11y.js +287 -0
  117. package/test-env/components/focus_trap/focus_trap.a11y.js +140 -0
  118. package/test-env/components/form/file_picker/file_picker.js +1 -0
  119. package/test-env/components/header/header.a11y.js +385 -0
  120. package/test-env/components/icon/icon_ML.a11y.js +40 -0
  121. package/test-env/components/icon/icon_apps.a11y.js +40 -0
  122. package/test-env/components/icon/icon_editor.a11y.js +40 -0
  123. package/test-env/components/icon/icon_elastic.a11y.js +40 -0
  124. package/test-env/components/icon/icon_glyphs.a11y.js +40 -0
  125. package/test-env/components/icon/icon_tokens.a11y.js +40 -0
  126. package/test-env/components/markdown_editor/plugins/markdown_default_plugins/parsing_plugins.js +2 -2
  127. package/test-env/components/selectable/selectable.js +4 -3
  128. package/test-env/components/selectable/selectable_list/selectable_list.js +17 -5
  129. package/test-env/components/tabs/tab.js +15 -17
  130. package/test-env/components/tabs/tabbed_content/tabbed_content.js +0 -16
  131. package/test-env/components/tabs/tabs.js +8 -14
  132. package/test-env/components/tabs/tabs_context.js +23 -0
@@ -0,0 +1,364 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
+
3
+ /*
4
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
5
+ * or more contributor license agreements. Licensed under the Elastic License
6
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
7
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
8
+ * Side Public License, v 1.
9
+ */
10
+ /// <reference types="../../../cypress/support"/>
11
+ import React, { useState } from 'react';
12
+ import { EuiAvatar } from '../avatar';
13
+ import { EuiFlexGroup, EuiFlexItem } from '../flex';
14
+ import { EuiHeaderBreadcrumbs } from './header_breadcrumbs';
15
+ import { EuiHeader } from './header';
16
+ import { EuiHeaderLogo } from './header_logo';
17
+ import { EuiHeaderSectionItemButton, EuiHeaderSectionItem, EuiHeaderSection } from './header_section';
18
+ import { EuiIcon } from '../icon';
19
+ import { EuiKeyPadMenu, EuiKeyPadMenuItem } from '../key_pad_menu';
20
+ import { EuiLink } from '../link';
21
+ import { EuiPopover, EuiPopoverTitle } from '../popover';
22
+ import { EuiSelectable, EuiSelectableMessage, EuiSelectableTemplateSitewide } from '../selectable';
23
+ import { EuiSpacer } from '../spacer';
24
+ import { EuiText } from '../text';
25
+ import { useGeneratedHtmlId } from '../../services';
26
+ import { jsx as ___EmotionJSX } from "@emotion/react";
27
+
28
+ var Header = function Header() {
29
+ var renderLogo = function renderLogo() {
30
+ return ___EmotionJSX(EuiHeaderLogo, {
31
+ iconType: "logoElastic",
32
+ href: "#",
33
+ onClick: function onClick(e) {
34
+ return e.preventDefault();
35
+ },
36
+ "aria-label": "Go to home page"
37
+ });
38
+ };
39
+
40
+ var renderBreadcrumbs = function renderBreadcrumbs() {
41
+ var breadcrumbs = [{
42
+ text: 'Management',
43
+ href: '#',
44
+ onClick: function onClick(e) {
45
+ e.preventDefault();
46
+ },
47
+ 'data-test-subj': 'breadcrumbsAnimals',
48
+ className: 'customClass'
49
+ }, {
50
+ text: 'Truncation test is here for a really long item',
51
+ href: '#',
52
+ onClick: function onClick(e) {
53
+ e.preventDefault();
54
+ }
55
+ }, {
56
+ text: 'Hidden',
57
+ 'data-test-subj': 'cy-breadcrumb-hidden',
58
+ href: '#',
59
+ onClick: function onClick(e) {
60
+ e.preventDefault();
61
+ }
62
+ }, {
63
+ text: 'Users',
64
+ href: '#',
65
+ onClick: function onClick(e) {
66
+ e.preventDefault();
67
+ }
68
+ }, {
69
+ text: 'Create'
70
+ }];
71
+ return ___EmotionJSX(EuiHeaderBreadcrumbs, {
72
+ "aria-label": "Header breadcrumbs example",
73
+ breadcrumbs: breadcrumbs
74
+ });
75
+ };
76
+
77
+ var search = ___EmotionJSX(EuiSelectableTemplateSitewide, {
78
+ options: [],
79
+ searchProps: {
80
+ compressed: true
81
+ },
82
+ popoverButton: ___EmotionJSX(EuiHeaderSectionItemButton, {
83
+ "aria-label": "Sitewide search"
84
+ }, ___EmotionJSX(EuiIcon, {
85
+ type: "search",
86
+ size: "m"
87
+ })),
88
+ emptyMessage: ___EmotionJSX(EuiSelectableMessage, {
89
+ style: {
90
+ minHeight: 300
91
+ },
92
+ "data-test-subj": "cy-search-menu"
93
+ }, ___EmotionJSX("p", null, "Please see the component page for", ' ', ___EmotionJSX("strong", null, "EuiSelectableTemplateSitewide"), "on how to configure your sitewide search."))
94
+ });
95
+
96
+ return ___EmotionJSX(EuiHeader, null, ___EmotionJSX(EuiHeaderSection, {
97
+ grow: false
98
+ }, ___EmotionJSX(EuiHeaderSectionItem, {
99
+ border: "right"
100
+ }, renderLogo()), ___EmotionJSX(EuiHeaderSectionItem, {
101
+ border: "right"
102
+ }, ___EmotionJSX(HeaderSpacesMenu, null))), renderBreadcrumbs(), ___EmotionJSX(EuiHeaderSection, {
103
+ side: "right"
104
+ }, ___EmotionJSX(EuiHeaderSectionItem, null, search), ___EmotionJSX(EuiHeaderSectionItem, null, ___EmotionJSX(HeaderUserMenu, null)), ___EmotionJSX(EuiHeaderSectionItem, null, ___EmotionJSX(HeaderAppMenu, null))));
105
+ };
106
+
107
+ var HeaderUserMenu = function HeaderUserMenu() {
108
+ var headerUserPopoverId = useGeneratedHtmlId({
109
+ prefix: 'headerUserPopover'
110
+ });
111
+
112
+ var _useState = useState(false),
113
+ _useState2 = _slicedToArray(_useState, 2),
114
+ isOpen = _useState2[0],
115
+ setIsOpen = _useState2[1];
116
+
117
+ var onMenuButtonClick = function onMenuButtonClick() {
118
+ setIsOpen(!isOpen);
119
+ };
120
+
121
+ var closeMenu = function closeMenu() {
122
+ setIsOpen(false);
123
+ };
124
+
125
+ var button = ___EmotionJSX(EuiHeaderSectionItemButton, {
126
+ "aria-controls": headerUserPopoverId,
127
+ "aria-expanded": isOpen,
128
+ "aria-haspopup": "true",
129
+ "aria-label": "Account menu",
130
+ onClick: onMenuButtonClick
131
+ }, ___EmotionJSX(EuiAvatar, {
132
+ name: "John Username",
133
+ size: "s"
134
+ }));
135
+
136
+ return ___EmotionJSX(EuiPopover, {
137
+ id: headerUserPopoverId,
138
+ button: button,
139
+ isOpen: isOpen,
140
+ anchorPosition: "downRight",
141
+ closePopover: closeMenu,
142
+ panelPaddingSize: "none",
143
+ "data-test-subj": "cy-account-menu"
144
+ }, ___EmotionJSX("div", {
145
+ style: {
146
+ width: 320
147
+ }
148
+ }, ___EmotionJSX(EuiFlexGroup, {
149
+ gutterSize: "m",
150
+ className: "euiHeaderProfile",
151
+ responsive: false
152
+ }, ___EmotionJSX(EuiFlexItem, {
153
+ grow: false
154
+ }, ___EmotionJSX(EuiAvatar, {
155
+ name: "John Username",
156
+ size: "xl"
157
+ })), ___EmotionJSX(EuiFlexItem, null, ___EmotionJSX(EuiText, null, ___EmotionJSX("p", null, "John Username")), ___EmotionJSX(EuiSpacer, {
158
+ size: "m"
159
+ }), ___EmotionJSX(EuiFlexGroup, null, ___EmotionJSX(EuiFlexItem, null, ___EmotionJSX(EuiFlexGroup, {
160
+ justifyContent: "spaceBetween"
161
+ }, ___EmotionJSX(EuiFlexItem, {
162
+ grow: false
163
+ }, ___EmotionJSX(EuiLink, null, "Edit profile")), ___EmotionJSX(EuiFlexItem, {
164
+ grow: false
165
+ }, ___EmotionJSX(EuiLink, null, "Log out")))))))));
166
+ };
167
+
168
+ var HeaderSpacesMenu = function HeaderSpacesMenu() {
169
+ var headerSpacesPopoverId = useGeneratedHtmlId({
170
+ prefix: 'headerSpacesPopover'
171
+ });
172
+ var spacesValues = [{
173
+ label: 'Sales team',
174
+ prepend: ___EmotionJSX(EuiAvatar, {
175
+ type: "space",
176
+ name: "Sales Team",
177
+ size: "s"
178
+ }),
179
+ checked: 'on'
180
+ }, {
181
+ label: 'Engineering',
182
+ prepend: ___EmotionJSX(EuiAvatar, {
183
+ type: "space",
184
+ name: "Engineering",
185
+ size: "s"
186
+ })
187
+ }];
188
+
189
+ var _useState3 = useState(spacesValues),
190
+ _useState4 = _slicedToArray(_useState3, 2),
191
+ spaces = _useState4[0],
192
+ setSpaces = _useState4[1];
193
+
194
+ var _useState5 = useState(spaces.filter(function (option) {
195
+ return option.checked;
196
+ })[0]),
197
+ _useState6 = _slicedToArray(_useState5, 2),
198
+ selectedSpace = _useState6[0],
199
+ setSelectedSpace = _useState6[1];
200
+
201
+ var _useState7 = useState(false),
202
+ _useState8 = _slicedToArray(_useState7, 2),
203
+ isOpen = _useState8[0],
204
+ setIsOpen = _useState8[1];
205
+
206
+ var isListExtended = function isListExtended() {
207
+ return spaces.length > 4 ? true : false;
208
+ };
209
+
210
+ var onMenuButtonClick = function onMenuButtonClick() {
211
+ setIsOpen(!isOpen);
212
+ };
213
+
214
+ var closePopover = function closePopover() {
215
+ setIsOpen(false);
216
+ };
217
+
218
+ var onChange = function onChange(options) {
219
+ setSpaces(options);
220
+ setSelectedSpace(options.filter(function (option) {
221
+ return option.checked;
222
+ })[0]);
223
+ setIsOpen(false);
224
+ };
225
+
226
+ var button = ___EmotionJSX(EuiHeaderSectionItemButton, {
227
+ "aria-controls": headerSpacesPopoverId,
228
+ "aria-expanded": isOpen,
229
+ "aria-haspopup": "true",
230
+ "aria-label": "Spaces menu",
231
+ onClick: onMenuButtonClick
232
+ }, selectedSpace.prepend);
233
+
234
+ return ___EmotionJSX(EuiPopover, {
235
+ id: headerSpacesPopoverId,
236
+ button: button,
237
+ isOpen: isOpen,
238
+ anchorPosition: "downLeft",
239
+ closePopover: closePopover,
240
+ panelPaddingSize: "none"
241
+ }, ___EmotionJSX(EuiSelectable, {
242
+ searchable: isListExtended(),
243
+ searchProps: {
244
+ placeholder: 'Find a space',
245
+ compressed: true
246
+ },
247
+ options: spaces,
248
+ singleSelection: "always",
249
+ style: {
250
+ width: 300
251
+ },
252
+ onChange: onChange,
253
+ listProps: {
254
+ rowHeight: 40,
255
+ showIcons: false
256
+ },
257
+ "data-test-subj": "cy-spaces-menu"
258
+ }, function (list, search) {
259
+ return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(EuiPopoverTitle, {
260
+ paddingSize: "s"
261
+ }, search || 'Your spaces'), list);
262
+ }));
263
+ };
264
+
265
+ var HeaderAppMenu = function HeaderAppMenu() {
266
+ var headerAppPopoverId = useGeneratedHtmlId({
267
+ prefix: 'headerAppPopover'
268
+ });
269
+ var headerAppKeyPadMenuId = useGeneratedHtmlId({
270
+ prefix: 'headerAppKeyPadMenu'
271
+ });
272
+
273
+ var _useState9 = useState(false),
274
+ _useState10 = _slicedToArray(_useState9, 2),
275
+ isOpen = _useState10[0],
276
+ setIsOpen = _useState10[1];
277
+
278
+ var onMenuButtonClick = function onMenuButtonClick() {
279
+ setIsOpen(!isOpen);
280
+ };
281
+
282
+ var closeMenu = function closeMenu() {
283
+ setIsOpen(false);
284
+ };
285
+
286
+ var button = ___EmotionJSX(EuiHeaderSectionItemButton, {
287
+ "aria-controls": headerAppKeyPadMenuId,
288
+ "aria-expanded": isOpen,
289
+ "aria-haspopup": "true",
290
+ "aria-label": "Apps menu with 1 new app",
291
+ notification: "1",
292
+ onClick: onMenuButtonClick
293
+ }, ___EmotionJSX(EuiIcon, {
294
+ type: "apps",
295
+ size: "m"
296
+ }));
297
+
298
+ return ___EmotionJSX(EuiPopover, {
299
+ id: headerAppPopoverId,
300
+ button: button,
301
+ isOpen: isOpen,
302
+ anchorPosition: "downRight",
303
+ closePopover: closeMenu
304
+ }, ___EmotionJSX(EuiKeyPadMenu, {
305
+ id: headerAppKeyPadMenuId,
306
+ style: {
307
+ width: 288
308
+ },
309
+ "data-test-subj": "cy-apps-menu"
310
+ }, ___EmotionJSX(EuiKeyPadMenuItem, {
311
+ label: "Discover"
312
+ }, ___EmotionJSX(EuiIcon, {
313
+ type: "discoverApp",
314
+ size: "l"
315
+ })), ___EmotionJSX(EuiKeyPadMenuItem, {
316
+ label: "Dashboard"
317
+ }, ___EmotionJSX(EuiIcon, {
318
+ type: "dashboardApp",
319
+ size: "l"
320
+ })), ___EmotionJSX(EuiKeyPadMenuItem, {
321
+ label: "Dev Tools"
322
+ }, ___EmotionJSX(EuiIcon, {
323
+ type: "devToolsApp",
324
+ size: "l"
325
+ }))));
326
+ };
327
+
328
+ beforeEach(function () {
329
+ cy.viewport(1024, 768); // medium breakpoint
330
+
331
+ cy.realMount(___EmotionJSX(Header, null));
332
+ });
333
+ describe('EuiHeader', function () {
334
+ describe('Automated accessibility check', function () {
335
+ it('has zero violations on first render', function () {
336
+ cy.checkAxe();
337
+ });
338
+ it('has zero violations when Spaces menu is expanded', function () {
339
+ cy.get('button[aria-label="Spaces menu"]').realClick();
340
+ cy.get('div[data-test-subj="cy-spaces-menu"]').should('exist');
341
+ cy.checkAxe();
342
+ });
343
+ it('has zero violations when Account menu is expanded', function () {
344
+ cy.get('button[aria-label="Account menu"]').realClick();
345
+ cy.get('div[data-test-subj="cy-account-menu"]').should('exist');
346
+ cy.checkAxe();
347
+ });
348
+ it('has zero violations when Sitewide search is expanded', function () {
349
+ cy.get('button[aria-label="Sitewide search"]').realClick();
350
+ cy.get('div[data-test-subj="cy-search-menu"]').should('exist');
351
+ cy.checkAxe();
352
+ });
353
+ it('has zero violations when Apps menu is expanded', function () {
354
+ cy.get('button[aria-label="Apps menu with 1 new app"]').realClick();
355
+ cy.get('ul[data-test-subj="cy-apps-menu"]').should('exist');
356
+ cy.checkAxe();
357
+ });
358
+ it('has zero violations when a hidden breadcrumb is expanded', function () {
359
+ cy.get('button[aria-label="See collapsed breadcrumbs"]').realClick();
360
+ cy.get('a[data-test-subj="cy-breadcrumb-hidden"]').should('exist');
361
+ cy.checkAxe();
362
+ });
363
+ });
364
+ });
@@ -0,0 +1,33 @@
1
+ /*
2
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
3
+ * or more contributor license agreements. Licensed under the Elastic License
4
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
5
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
6
+ * Side Public License, v 1.
7
+ */
8
+ /// <reference types="../../../cypress/support"/>
9
+ import React from 'react';
10
+ import { EuiIcon } from './icon';
11
+ import { jsx as ___EmotionJSX } from "@emotion/react";
12
+ describe('EuiIcons', function () {
13
+ describe('Automated accessibility check for ML icons', function () {
14
+ var MLIcons = ['dataVisualizer', 'createAdvancedJob', 'classificationJob', 'createMultiMetricJob', 'outlierDetectionJob', 'createPopulationJob', 'regressionJob', 'createSingleMetricJob'];
15
+
16
+ var MLGrid = function MLGrid() {
17
+ return ___EmotionJSX("div", null, MLIcons.map(function (glyph) {
18
+ return ___EmotionJSX(EuiIcon, {
19
+ className: "eui-alignMiddle",
20
+ type: glyph
21
+ });
22
+ }));
23
+ };
24
+
25
+ it('has zero violations on first render', function () {
26
+ cy.mount(___EmotionJSX(MLGrid, null));
27
+ cy.get('div[data-cy-root]').find('svg', {
28
+ timeout: 5000
29
+ }).should('have.length', 8);
30
+ cy.checkAxe();
31
+ });
32
+ });
33
+ });
@@ -0,0 +1,33 @@
1
+ /*
2
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
3
+ * or more contributor license agreements. Licensed under the Elastic License
4
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
5
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
6
+ * Side Public License, v 1.
7
+ */
8
+ /// <reference types="../../../cypress/support"/>
9
+ import React from 'react';
10
+ import { EuiIcon } from './icon';
11
+ import { jsx as ___EmotionJSX } from "@emotion/react";
12
+ describe('EuiIcons', function () {
13
+ describe('Automated accessibility check for app icons', function () {
14
+ var AppIcons = ['addDataApp', 'advancedSettingsApp', 'agentApp', 'apmApp', 'appSearchApp', 'auditbeatApp', 'canvasApp', 'casesApp', 'codeApp', 'consoleApp', 'crossClusterReplicationApp', 'dashboardApp', 'devToolsApp', 'discoverApp', 'emsApp', 'filebeatApp', 'fleetApp', 'gisApp', 'graphApp', 'grokApp', 'heartbeatApp', 'indexManagementApp', 'indexPatternApp', 'indexRollupApp', 'lensApp', 'logsApp', 'machineLearningApp', 'managementApp', 'metricbeatApp', 'metricsApp', 'monitoringApp', 'notebookApp', 'packetbeatApp', 'pipelineApp', 'recentlyViewedApp', 'reportingApp', 'savedObjectsApp', 'searchProfilerApp', 'securityAnalyticsApp', 'securityApp', 'spacesApp', 'sqlApp', 'timelionApp', 'upgradeAssistantApp', 'uptimeApp', 'usersRolesApp', 'visualizeApp', 'watchesApp', 'workplaceSearchApp'];
15
+
16
+ var AppGrid = function AppGrid() {
17
+ return ___EmotionJSX("div", null, AppIcons.map(function (glyph) {
18
+ return ___EmotionJSX(EuiIcon, {
19
+ className: "eui-alignMiddle",
20
+ type: glyph
21
+ });
22
+ }));
23
+ };
24
+
25
+ it('has zero violations on first render', function () {
26
+ cy.mount(___EmotionJSX(AppGrid, null));
27
+ cy.get('div[data-cy-root]').find('svg', {
28
+ timeout: 5000
29
+ }).should('have.length', 49);
30
+ cy.checkAxe();
31
+ });
32
+ });
33
+ });
@@ -0,0 +1,33 @@
1
+ /*
2
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
3
+ * or more contributor license agreements. Licensed under the Elastic License
4
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
5
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
6
+ * Side Public License, v 1.
7
+ */
8
+ /// <reference types="../../../cypress/support"/>
9
+ import React from 'react';
10
+ import { EuiIcon } from './icon';
11
+ import { jsx as ___EmotionJSX } from "@emotion/react";
12
+ describe('EuiIcons', function () {
13
+ describe('Automated accessibility check for editor icons', function () {
14
+ 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'];
15
+
16
+ var EditorGrid = function EditorGrid() {
17
+ return ___EmotionJSX("div", null, EditorIcons.map(function (glyph) {
18
+ return ___EmotionJSX(EuiIcon, {
19
+ className: "eui-alignMiddle",
20
+ type: glyph
21
+ });
22
+ }));
23
+ };
24
+
25
+ it('has zero violations on first render', function () {
26
+ cy.mount(___EmotionJSX(EditorGrid, null));
27
+ cy.get('div[data-cy-root]').find('svg', {
28
+ timeout: 5000
29
+ }).should('have.length', 29);
30
+ cy.checkAxe();
31
+ });
32
+ });
33
+ });
@@ -0,0 +1,33 @@
1
+ /*
2
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
3
+ * or more contributor license agreements. Licensed under the Elastic License
4
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
5
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
6
+ * Side Public License, v 1.
7
+ */
8
+ /// <reference types="../../../cypress/support"/>
9
+ import React from 'react';
10
+ import { EuiIcon } from './icon';
11
+ import { jsx as ___EmotionJSX } from "@emotion/react";
12
+ describe('EuiIcons', function () {
13
+ describe('Automated accessibility check for Elastic logos', function () {
14
+ var ElasticLogos = ['logoElastic', 'logoElasticStack', 'logoElasticsearch', 'logoAppSearch', 'logoBeats', 'logoBusinessAnalytics', 'logoCloud', 'logoCloudEnterprise', 'logoEnterpriseSearch', 'logoKibana', 'logoLogging', 'logoLogstash', 'logoMaps', 'logoMetrics', 'logoObservability', 'logoSecurity', 'logoSiteSearch', 'logoUptime', 'logoWorkplaceSearch'];
15
+
16
+ var ElasticGrid = function ElasticGrid() {
17
+ return ___EmotionJSX("div", null, ElasticLogos.map(function (glyph) {
18
+ return ___EmotionJSX(EuiIcon, {
19
+ className: "eui-alignMiddle",
20
+ type: glyph
21
+ });
22
+ }));
23
+ };
24
+
25
+ it('has zero violations on first render', function () {
26
+ cy.mount(___EmotionJSX(ElasticGrid, null));
27
+ cy.get('div[data-cy-root]').find('svg', {
28
+ timeout: 5000
29
+ }).should('have.length', 19);
30
+ cy.checkAxe();
31
+ });
32
+ });
33
+ });
@@ -0,0 +1,33 @@
1
+ /*
2
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
3
+ * or more contributor license agreements. Licensed under the Elastic License
4
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
5
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
6
+ * Side Public License, v 1.
7
+ */
8
+ /// <reference types="../../../cypress/support"/>
9
+ import React from 'react';
10
+ import { EuiIcon } from './icon';
11
+ import { jsx as ___EmotionJSX } from "@emotion/react";
12
+ describe('EuiIcons', function () {
13
+ describe('Automated accessibility check for glyph icons', function () {
14
+ 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'];
15
+
16
+ var GlyphGrid = function GlyphGrid() {
17
+ return ___EmotionJSX("div", null, GlyphIcons.map(function (glyph) {
18
+ return ___EmotionJSX(EuiIcon, {
19
+ className: "eui-alignMiddle",
20
+ type: glyph
21
+ });
22
+ }));
23
+ };
24
+
25
+ it('has zero violations on first render', function () {
26
+ cy.mount(___EmotionJSX(GlyphGrid, null));
27
+ cy.get('svg[data-icon-type="wrench"]', {
28
+ timeout: 5000
29
+ }).should('exist');
30
+ cy.checkAxe();
31
+ });
32
+ });
33
+ });
@@ -0,0 +1,33 @@
1
+ /*
2
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
3
+ * or more contributor license agreements. Licensed under the Elastic License
4
+ * 2.0 and the Server Side Public License, v 1; you may not use this file except
5
+ * in compliance with, at your election, the Elastic License 2.0 or the Server
6
+ * Side Public License, v 1.
7
+ */
8
+ /// <reference types="../../../cypress/support"/>
9
+ import React from 'react';
10
+ import { EuiIcon } from './icon';
11
+ import { jsx as ___EmotionJSX } from "@emotion/react";
12
+ describe('EuiIcons', function () {
13
+ describe('Automated accessibility check for token icons', function () {
14
+ 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'];
15
+
16
+ var TokenGrid = function TokenGrid() {
17
+ return ___EmotionJSX("div", null, TokenIcons.map(function (glyph) {
18
+ return ___EmotionJSX(EuiIcon, {
19
+ className: "eui-alignMiddle",
20
+ type: glyph
21
+ });
22
+ }));
23
+ };
24
+
25
+ it('has zero violations on first render', function () {
26
+ cy.mount(___EmotionJSX(TokenGrid, null));
27
+ cy.get('div[data-cy-root]').find('svg', {
28
+ timeout: 5000
29
+ }).should('have.length', 53);
30
+ cy.checkAxe();
31
+ });
32
+ });
33
+ });
@@ -9,7 +9,7 @@
9
9
  // are exported for two versions of TypeScript (3.4, 4.0) and implicit
10
10
  // imports during eui.d.ts generation default to the incorrect version (3.4).
11
11
  // Explicit imports here resolve the version mismatch.
12
- import markdown from 'remark-parse';
12
+ import markdown from 'remark-parse-no-trim';
13
13
  import emoji from 'remark-emoji';
14
14
  import breaks from 'remark-breaks';
15
15
  import highlight from '../remark/remark_prismjs';
@@ -246,7 +246,7 @@ export var EuiSelectable = /*#__PURE__*/function (_Component) {
246
246
  });
247
247
  });
248
248
 
249
- _defineProperty(_assertThisInitialized(_this), "onOptionClick", function (options, event) {
249
+ _defineProperty(_assertThisInitialized(_this), "onOptionClick", function (options, event, clickedOption) {
250
250
  var _this$props = _this.props,
251
251
  isPreFiltered = _this$props.isPreFiltered,
252
252
  onChange = _this$props.onChange;
@@ -258,7 +258,7 @@ export var EuiSelectable = /*#__PURE__*/function (_Component) {
258
258
  });
259
259
 
260
260
  if (onChange) {
261
- onChange(options, event);
261
+ onChange(options, event, clickedOption);
262
262
  }
263
263
  });
264
264
 
@@ -209,6 +209,9 @@ export var EuiSelectableList = /*#__PURE__*/function (_Component) {
209
209
  onOptionClick = _this$props4.onOptionClick,
210
210
  options = _this$props4.options,
211
211
  singleSelection = _this$props4.singleSelection;
212
+
213
+ var changedOption = _objectSpread({}, addedOption);
214
+
212
215
  var updatedOptions = options.map(function (option) {
213
216
  // if singleSelection is enabled, uncheck any selected option(s)
214
217
  var updatedOption = _objectSpread({}, option);
@@ -220,11 +223,12 @@ export var EuiSelectableList = /*#__PURE__*/function (_Component) {
220
223
 
221
224
  if (option === addedOption) {
222
225
  updatedOption.checked = 'on';
226
+ changedOption = updatedOption;
223
227
  }
224
228
 
225
229
  return updatedOption;
226
230
  });
227
- onOptionClick(updatedOptions, event);
231
+ onOptionClick(updatedOptions, event, changedOption);
228
232
  });
229
233
 
230
234
  _defineProperty(_assertThisInitialized(_this), "onRemoveOption", function (removedOption, event) {
@@ -232,33 +236,40 @@ export var EuiSelectableList = /*#__PURE__*/function (_Component) {
232
236
  onOptionClick = _this$props5.onOptionClick,
233
237
  singleSelection = _this$props5.singleSelection,
234
238
  options = _this$props5.options;
239
+
240
+ var changedOption = _objectSpread({}, removedOption);
241
+
235
242
  var updatedOptions = options.map(function (option) {
236
243
  var updatedOption = _objectSpread({}, option);
237
244
 
238
245
  if (option === removedOption && singleSelection !== 'always') {
239
246
  delete updatedOption.checked;
247
+ changedOption = updatedOption;
240
248
  }
241
249
 
242
250
  return updatedOption;
243
251
  });
244
- onOptionClick(updatedOptions, event);
252
+ onOptionClick(updatedOptions, event, changedOption);
245
253
  });
246
254
 
247
255
  _defineProperty(_assertThisInitialized(_this), "onExcludeOption", function (excludedOption, event) {
248
256
  var _this$props6 = _this.props,
249
257
  onOptionClick = _this$props6.onOptionClick,
250
258
  options = _this$props6.options;
251
- excludedOption.checked = 'off';
259
+
260
+ var changedOption = _objectSpread({}, excludedOption);
261
+
252
262
  var updatedOptions = options.map(function (option) {
253
263
  var updatedOption = _objectSpread({}, option);
254
264
 
255
265
  if (option === excludedOption) {
256
266
  updatedOption.checked = 'off';
267
+ changedOption = updatedOption;
257
268
  }
258
269
 
259
270
  return updatedOption;
260
271
  });
261
- onOptionClick(updatedOptions, event);
272
+ onOptionClick(updatedOptions, event, changedOption);
262
273
  });
263
274
 
264
275
  return _this;