From 7357af5c1b68b33f528bd27f65b21618a63c4190 Mon Sep 17 00:00:00 2001 From: Cee Chen <549407+cee-chen@users.noreply.github.com> Date: Fri, 5 Jan 2024 08:22:42 -0800 Subject: [PATCH] Upgrade EUI to v91.3.1 (#173569) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit `v91.0.0-backport.0`⏩`v91.3.1` ⚠️ The largest set of changes in this PR that touch source code (as opposed to test code) are related to several **EuiDataGrid** redesigns, particularly around the toolbar, column cell headers, and cell actions. We **strongly** recommend QAing your EuiDataGrid usages, **especially** if you have custom CSS styling on data grid cells. | Changes | Screencap | |--------|--------| | Cell actions and popover | | | Column headers | | | Toolbar | | --- ## [`v91.3.1`](https://github.com/elastic/eui/releases/v91.3.1) **Bug fixes** - Moved `EuiDataGrid`'s header cells' `dataGridHeaderCellActionButton` test subject attribute from to the clickable button, for easier E2E testing ([#7427](https://github.com/elastic/eui/pull/7427)) - Fixed `EuiBasicTable`/`EuiInMemoryTable` actions to correctly show as disabled when rows are being selected ([#7428](https://github.com/elastic/eui/pull/7428)) ## [`v91.3.0`](https://github.com/elastic/eui/releases/v91.3.0) - Added `esqlVis`, `pipeBreaks`, and `pipeNoBreaks` icon glyphs. ([#7399](https://github.com/elastic/eui/pull/7399)) - Updated `EuiDataGridSchemaDetector`'s comparator arguments to include entry indexes ([#7406](https://github.com/elastic/eui/pull/7406)) ## [`v91.2.0`](https://github.com/elastic/eui/releases/v91.2.0) - Added `endpoint` glyph to `EuiIcon` ([#7383](https://github.com/elastic/eui/pull/7383)) **Bug fixes** - Fixed a bug with `EuiSelectable`s with custom `truncationProps`, where scrollbar widths were not being accounted for ([#7392](https://github.com/elastic/eui/pull/7392)) ## [`v91.1.0`](https://github.com/elastic/eui/releases/tag/v91.1.0) - Updated `EuiDataGrid` cell actions to display above cells instead of within them, to avoid content clipping issues ([#7343](https://github.com/elastic/eui/pull/7343)) - Updated `EuiDataGrid` cell expansion popovers to sit on top of cells instead of below/next to them ([#7343](https://github.com/elastic/eui/pull/7343)) - Updated `EuiListGroupItem` to render an external icon and screen reader affordance for links with `target` set to to `_blank` ([#7352](https://github.com/elastic/eui/pull/7352)) - Updated `EuiListGroupItem` with a new `external` prop, which allows enabling or disabling the new external link icon ([#7352](https://github.com/elastic/eui/pull/7352)) - Updated `EuiText` to no longer set any opinionated styles on child `` tags - use `EuiImage` for image display within text instead ([#7360](https://github.com/elastic/eui/pull/7360)) - Improved `EuiBasicTable`/`EuiInMemoryTable`s mobile UI for custom actions ([#7361](https://github.com/elastic/eui/pull/7361)) - Added a new `EuiDataGridToolbarControl` subcomponent, which is useful for rendering your own custom `EuiDataGrid` toolbar buttons while matching the look of the default controls ([#7369](https://github.com/elastic/eui/pull/7369)) - Updated `EuiDataGrid`'s toolbar controls to show active/current counts in badges, and updated the Columns button icon ([#7369](https://github.com/elastic/eui/pull/7369)) - Updated `EuiButtonEmpty` to allow passing `false` to `textProps`, which allows rendering custom button content without an extra text wrapper ([#7369](https://github.com/elastic/eui/pull/7369)) - Updated `EuiDataGrid` column header cells to show the sort arrow after the heading text, instead of before ([#7371](https://github.com/elastic/eui/pull/7371)) - Updated `EuiDataGrid`'s column header actions icon from a chevron to `boxesVertical` ([#7371](https://github.com/elastic/eui/pull/7371)) - Updated the actions column in `EuiBasicTable` and `EuiInMemoryTable`s. Alongside `name`, the `description`, `href`, and `data-test-subj` properties now also accept an optional callback that the current `item` will be passed to ([#7373](https://github.com/elastic/eui/pull/7373)) - Updated `EuiContextMenuItem` with a new `toolTipProps` prop ([#7373](https://github.com/elastic/eui/pull/7373)) - `EuiSelectable` now allows configurable text truncation via `listProps.truncationProps` ([#7388](https://github.com/elastic/eui/pull/7388)) - `EuiTextTruncate` now supports a new `calculationDelayMs` prop for working around font loading or layout shifting scenarios ([#7388](https://github.com/elastic/eui/pull/7388)) **Bug fixes** - Fixed incorrect `EuiPopover` positioning calculations when `hasArrow` was set to false ([#7343](https://github.com/elastic/eui/pull/7343)) - Fixed `EuiSuperSelect` to render options with falsy values (false, 0, and ''), but not nullish values (undefined or null) ([#7362](https://github.com/elastic/eui/pull/7362)) - Fixed `EuiSuperSelect`'s typing to allow non-string values (e.g., booleans or numbers) ([#7362](https://github.com/elastic/eui/pull/7362)) - Fixed `EuiDataGrid`'s numeric and currency column heading cells to be correctly right-aligned ([#7371](https://github.com/elastic/eui/pull/7371)) - Fixed `EuiBasicTable` and `EuiInMemoryTable` actions not showing tooltip descriptions when rendered in the all actions popover menu ([#7373](https://github.com/elastic/eui/pull/7373)) - Fixed missing underlines on `EuiContextMenu` link hover ([#7373](https://github.com/elastic/eui/pull/7373)) - Fixed visual text truncation of `EuiBreadcrumb`s with `popoverContent` ([#7375](https://github.com/elastic/eui/pull/7375)) - Fixed `EuiFormRow`s with `hasEmptyLabelSpace` being very slightly off in vertical alignment ([#7380](https://github.com/elastic/eui/pull/7380)) **Deprecations** - Deprecated `EuiContextMenuItem`'s `toolTipTitle` prop. Use `toolTipProps.title` instead ([#7373](https://github.com/elastic/eui/pull/7373)) - Deprecated `EuiContextMenuItem`'s `toolTipPosition` prop. Use `toolTipProps.position` instead ([#7373](https://github.com/elastic/eui/pull/7373)) **Accessibility** - Fixed custom `EuiBasicTable`/`EuiInMemoryTable` rendering nested interactive custom actions ([#7361](https://github.com/elastic/eui/pull/7361)) - Fixed `EuiBasicTable` and `EuiInMemoryTable` actions not correctly reading out action descriptions to screen readers ([#7373](https://github.com/elastic/eui/pull/7373)) - Fixed `EuiBasicTable` and `EuiInMemoryTable` primary actions not visibly appearing on keyboard focus ([#7373](https://github.com/elastic/eui/pull/7373)) --------- Co-authored-by: Julia Rechkunova --- package.json | 2 +- .../__snapshots__/i18n_service.test.tsx.snap | 9 ++- .../src/i18n_eui_mapping.tsx | 33 +++++------ .../data_table_columns.test.tsx.snap | 33 +++++++++++ .../src/components/data_table.scss | 23 ++++---- .../src/components/data_table_columns.tsx | 8 ++- .../data_table_document_selection.tsx | 33 +++-------- src/dev/license_checker/config.ts | 2 +- .../components/download_options.tsx | 4 +- .../url/__snapshots__/url.test.tsx.snap | 8 +-- .../discover_grid/render_custom_toolbar.scss | 7 +-- .../public/ui/inspector_view_chooser.tsx | 2 +- .../not_found_errors.test.tsx.snap | 16 +++--- .../ml/data_grid/components/column_chart.tsx | 38 +++++-------- .../ml/data_grid/components/data_grid.tsx | 57 +++++++++++++++---- x-pack/packages/ml/data_grid/emotion.d.ts | 14 +++++ x-pack/packages/ml/data_grid/tsconfig.json | 1 + .../components/data_table/index.tsx | 11 +++- .../change_point_detection/fields_config.tsx | 2 +- .../__snapshots__/app.test.tsx.snap | 2 +- .../cloud_security_data_table/use_styles.ts | 18 +++--- .../components/timestamp_table_cell.tsx | 14 ++++- .../pages/vulnerabilities/hooks/use_styles.ts | 21 ++++--- .../severity_map.tsx | 1 + .../extend_index_management.test.tsx.snap | 16 +++--- .../components/alert_dropdown.tsx | 8 +-- .../dataview_picker/toolbar_button.tsx | 2 +- .../request_trial_extension.test.js.snap | 16 +++--- .../revert_to_basic.test.js.snap | 12 ++-- .../__snapshots__/start_trial.test.js.snap | 16 +++--- .../__snapshots__/exporters.test.js.snap | 12 ++-- .../__snapshots__/reason_found.test.js.snap | 12 ++-- .../osquery/cypress/screens/live_query.ts | 1 + .../osquery/cypress/tasks/saved_queries.ts | 10 ++-- .../__snapshots__/prompt_page.test.tsx.snap | 4 +- .../unauthenticated_page.test.tsx.snap | 4 +- .../reset_session_page.test.tsx.snap | 4 +- .../components/formatted_date/index.tsx | 11 +++- .../localized_date_tooltip/index.tsx | 6 +- .../public/common/components/top_n/top_n.tsx | 2 +- .../bulk_actions/use_bulk_actions.tsx | 22 +++---- .../components/alerts_table/index.tsx | 11 ++-- .../artifacts/list/policy_artifacts_list.tsx | 2 +- .../field_renderers.test.tsx.snap | 4 +- .../netflow/__snapshots__/index.test.tsx.snap | 20 +++---- .../components/open_timeline/index.test.tsx | 27 +++++---- .../__snapshots__/index.test.tsx.snap | 4 +- .../body/renderers/formatted_field.tsx | 22 ++++++- .../netflow_row_renderer.test.tsx.snap | 20 +++---- .../components/connectors_callout.tsx | 38 ++++++------- .../translations/translations/fr-FR.json | 5 -- .../translations/translations/ja-JP.json | 5 -- .../translations/translations/zh-CN.json | 5 -- .../rules_list_column_selector.test.tsx | 8 +-- .../__snapshots__/expanded_row.test.tsx.snap | 4 +- .../monitor_status.bar.test.tsx.snap | 4 +- .../apps/transform/actions/reauthorizing.ts | 2 +- .../index_pattern/creation_index_pattern.ts | 2 +- .../permissions/full_transform_access.ts | 5 +- .../permissions/read_transform_access.ts | 5 +- .../test/functional/page_objects/lens_page.ts | 1 + .../page_objects/tag_management_page.ts | 10 ++++ .../services/transform/transform_table.ts | 29 ++++++---- .../apps/cases/group2/upgrade.ts | 2 +- .../functional/tests/feature_control.ts | 8 +++ yarn.lock | 8 +-- 66 files changed, 443 insertions(+), 325 deletions(-) create mode 100644 x-pack/packages/ml/data_grid/emotion.d.ts diff --git a/package.json b/package.json index 22ac585845216..1655f03ace40a 100644 --- a/package.json +++ b/package.json @@ -102,7 +102,7 @@ "@elastic/datemath": "5.0.3", "@elastic/elasticsearch": "npm:@elastic/elasticsearch-canary@8.9.1-canary.1", "@elastic/ems-client": "8.5.1", - "@elastic/eui": "91.0.0-backport.0", + "@elastic/eui": "91.3.1", "@elastic/filesaver": "1.1.2", "@elastic/node-crypto": "1.2.1", "@elastic/numeral": "^2.5.1", diff --git a/packages/core/i18n/core-i18n-browser-internal/src/__snapshots__/i18n_service.test.tsx.snap b/packages/core/i18n/core-i18n-browser-internal/src/__snapshots__/i18n_service.test.tsx.snap index 610656fa96f46..416eba2d6fb6e 100644 --- a/packages/core/i18n/core-i18n-browser-internal/src/__snapshots__/i18n_service.test.tsx.snap +++ b/packages/core/i18n/core-i18n-browser-internal/src/__snapshots__/i18n_service.test.tsx.snap @@ -35,6 +35,7 @@ exports[`#start() returns \`Context\` component 1`] = ` "euiCodeBlockFullScreen.fullscreenCollapse": "Collapse", "euiCodeBlockFullScreen.fullscreenExpand": "Expand", "euiCollapsedItemActions.allActions": "All actions", + "euiCollapsedItemActions.allActionsDisabled": "Individual item actions are disabled when rows are being selected.", "euiCollapsibleNavBeta.ariaLabel": "Site menu", "euiCollapsibleNavButton.ariaLabelClose": "Close navigation", "euiCollapsibleNavButton.ariaLabelCollapse": "Collapse navigation", @@ -53,15 +54,12 @@ exports[`#start() returns \`Context\` component 1`] = ` "euiColumnActions.moveRight": "Move right", "euiColumnActions.sort": [Function], "euiColumnSelector.button": "Columns", - "euiColumnSelector.buttonActivePlural": [Function], - "euiColumnSelector.buttonActiveSingular": [Function], "euiColumnSelector.dragHandleAriaLabel": "Drag handle", "euiColumnSelector.hideAll": "Hide all", "euiColumnSelector.search": "Search", "euiColumnSelector.searchcolumns": "Search columns", "euiColumnSelector.selectAll": "Show all", "euiColumnSorting.button": "Sort fields", - "euiColumnSorting.buttonActive": [Function], "euiColumnSorting.clearAll": "Clear sorting", "euiColumnSorting.emptySorting": "Currently no fields are sorted", "euiColumnSorting.pickFields": "Pick fields to sort by", @@ -110,6 +108,7 @@ exports[`#start() returns \`Context\` component 1`] = ` "euiDataGridSchema.jsonSortTextDesc": "Large-Small", "euiDataGridSchema.numberSortTextAsc": "Low-High", "euiDataGridSchema.numberSortTextDesc": "High-Low", + "euiDataGridToolbarControl.badgeAriaLabel": [Function], "euiDatePopoverButton.invalidTitle": [Function], "euiDatePopoverButton.outdatedTitle": [Function], "euiDatePopoverContent.absoluteTabLabel": "Absolute", @@ -133,6 +132,8 @@ exports[`#start() returns \`Context\` component 1`] = ` "euiDisplaySelector.rowHeightLabel": "Row height", "euiDualRange.sliderScreenReaderInstructions": "You are in a custom range slider. Use the Up and Down arrow keys to change the minimum value. Press Tab to interact with the maximum value.", "euiErrorBoundary.error": "Error", + "euiExternalLinkIcon.ariaLabel": "External link", + "euiExternalLinkIcon.newTarget.screenReaderOnlyText": "(opens in a new tab or window)", "euiFieldPassword.maskPassword": "Mask password", "euiFieldPassword.showPassword": "Show password as plain text. Note: this will visually expose your password on the screen.", "euiFilePicker.clearSelectedFiles": "Clear selected files", @@ -185,8 +186,6 @@ exports[`#start() returns \`Context\` component 1`] = ` "euiKeyboardShortcuts.title": "Keyboard shortcuts", "euiKeyboardShortcuts.upArrowDescription": "Move one cell up", "euiKeyboardShortcuts.upArrowTitle": "Up arrow", - "euiLink.external.ariaLabel": "External link", - "euiLink.newTarget.screenReaderOnlyText": "(opens in a new tab or window)", "euiLoadingChart.ariaLabel": "Loading", "euiLoadingStrings.ariaLabel": "Loading", "euiMark.highlightEnd": "highlight end", diff --git a/packages/core/i18n/core-i18n-browser-internal/src/i18n_eui_mapping.tsx b/packages/core/i18n/core-i18n-browser-internal/src/i18n_eui_mapping.tsx index a669a86bfda1c..f542b59c24850 100644 --- a/packages/core/i18n/core-i18n-browser-internal/src/i18n_eui_mapping.tsx +++ b/packages/core/i18n/core-i18n-browser-internal/src/i18n_eui_mapping.tsx @@ -167,6 +167,13 @@ export const getEuiContextMapping = (): EuiTokensObject => { 'ARIA label and tooltip content describing a button that expands an actions menu', } ), + 'euiCollapsedItemActions.allActionsDisabled': i18n.translate( + 'core.euiCollapsedItemActions.allActionsDisabled', + { + defaultMessage: 'Individual item actions are disabled when rows are being selected.', + description: 'Title content when the actions popover toggle is disabled', + } + ), 'euiCollapsibleNavBeta.ariaLabel': i18n.translate('core.euiCollapsibleNavBeta.ariaLabel', { defaultMessage: 'Site menu', }), @@ -252,16 +259,6 @@ export const getEuiContextMapping = (): EuiTokensObject => { 'euiColumnSelector.searchcolumns': i18n.translate('core.euiColumnSelector.searchcolumns', { defaultMessage: 'Search columns', }), - 'euiColumnSelector.buttonActiveSingular': ({ numberOfHiddenFields }: EuiValues) => - i18n.translate('core.euiColumnSelector.buttonActiveSingular', { - defaultMessage: '{numberOfHiddenFields} column hidden', - values: { numberOfHiddenFields }, - }), - 'euiColumnSelector.buttonActivePlural': ({ numberOfHiddenFields }: EuiValues) => - i18n.translate('core.euiColumnSelector.buttonActivePlural', { - defaultMessage: '{numberOfHiddenFields} columns hidden', - values: { numberOfHiddenFields }, - }), 'euiColumnSorting.clearAll': i18n.translate('core.euiColumnSorting.clearAll', { defaultMessage: 'Clear sorting', }), @@ -280,11 +277,6 @@ export const getEuiContextMapping = (): EuiTokensObject => { 'euiColumnSorting.button': i18n.translate('core.euiColumnSorting.button', { defaultMessage: 'Sort fields', }), - 'euiColumnSorting.buttonActive': ({ numberOfSortedFields }: EuiValues) => - i18n.translate('core.euiColumnSorting.buttonActive', { - defaultMessage: '{numberOfSortedFields, plural, one {# field} other {# fields}} sorted', - values: { numberOfSortedFields }, - }), 'euiColumnSortingDraggable.activeSortLabel': ({ display }: EuiValues) => i18n.translate('core.euiColumnSortingDraggable.activeSortLabel', { defaultMessage: '{display} is sorting this data grid', @@ -673,6 +665,11 @@ export const getEuiContextMapping = (): EuiTokensObject => { description: 'Descending size label', } ), + 'euiDataGridToolbarControl.badgeAriaLabel': ({ count }: EuiValues) => + i18n.translate('core.euiDataGridToolbarControl.badgeAriaLabel', { + defaultMessage: 'Active: {count}', + values: { count }, + }), 'euiDatePopoverButton.invalidTitle': ({ title }: EuiValues) => i18n.translate('core.euiDatePopoverButton.invalidTitle', { defaultMessage: 'Invalid date: {title}', @@ -830,11 +827,11 @@ export const getEuiContextMapping = (): EuiTokensObject => { 'core.euiInlineEditForm.saveButtonAriaLabel', { defaultMessage: 'Save edit' } ), - 'euiLink.external.ariaLabel': i18n.translate('core.euiLink.external.ariaLabel', { + 'euiExternalLinkIcon.ariaLabel': i18n.translate('core.euiExternalLinkIcon.ariaLabel', { defaultMessage: 'External link', }), - 'euiLink.newTarget.screenReaderOnlyText': i18n.translate( - 'core.euiLink.newTarget.screenReaderOnlyText', + 'euiExternalLinkIcon.newTarget.screenReaderOnlyText': i18n.translate( + 'core.euiExternalLinkIcon.newTarget.screenReaderOnlyText', { defaultMessage: '(opens in a new tab or window)', } diff --git a/packages/kbn-unified-data-table/src/components/__snapshots__/data_table_columns.test.tsx.snap b/packages/kbn-unified-data-table/src/components/__snapshots__/data_table_columns.test.tsx.snap index d5cbd1a0d408e..3abfdd59567f5 100644 --- a/packages/kbn-unified-data-table/src/components/__snapshots__/data_table_columns.test.tsx.snap +++ b/packages/kbn-unified-data-table/src/components/__snapshots__/data_table_columns.test.tsx.snap @@ -45,6 +45,17 @@ Array [ ], "display":
+
<> {timeFieldName} diff --git a/packages/kbn-unified-data-table/src/components/data_table_document_selection.tsx b/packages/kbn-unified-data-table/src/components/data_table_document_selection.tsx index 4f660009a232c..db6ed7680b0be 100644 --- a/packages/kbn-unified-data-table/src/components/data_table_document_selection.tsx +++ b/packages/kbn-unified-data-table/src/components/data_table_document_selection.tsx @@ -6,15 +6,13 @@ * Side Public License, v 1. */ import React, { useCallback, useContext, useEffect, useMemo, useState } from 'react'; -import classNames from 'classnames'; import { - EuiButtonEmpty, EuiCheckbox, EuiContextMenuItem, EuiContextMenuPanel, EuiCopy, EuiDataGridCellValueElementProps, - EuiNotificationBadge, + EuiDataGridToolbarControl, EuiPopover, EuiFlexGroup, EuiFlexItem, @@ -183,33 +181,20 @@ export function DataTableDocumentToolbarBtn({ isOpen={isSelectionPopoverOpen} panelPaddingSize="none" button={ - - - - - - - {selectedDocs.length} - - - + + } > {isSelectionPopoverOpen && } diff --git a/src/dev/license_checker/config.ts b/src/dev/license_checker/config.ts index db69bab07e1ea..0d0b59092746e 100644 --- a/src/dev/license_checker/config.ts +++ b/src/dev/license_checker/config.ts @@ -85,7 +85,7 @@ export const LICENSE_OVERRIDES = { 'jsts@1.6.2': ['Eclipse Distribution License - v 1.0'], // cf. https://github.com/bjornharrtell/jsts '@mapbox/jsonlint-lines-primitives@2.0.2': ['MIT'], // license in readme https://github.com/tmcw/jsonlint '@elastic/ems-client@8.5.1': ['Elastic License 2.0'], - '@elastic/eui@91.0.0-backport.0': ['SSPL-1.0 OR Elastic License 2.0'], + '@elastic/eui@91.3.1': ['SSPL-1.0 OR Elastic License 2.0'], 'language-subtag-registry@0.3.21': ['CC-BY-4.0'], // retired ODC‑By license https://github.com/mattcg/language-subtag-registry 'buffers@0.1.1': ['MIT'], // license in importing module https://www.npmjs.com/package/binary '@bufbuild/protobuf@1.2.1': ['Apache-2.0'], // license (Apache-2.0 AND BSD-3-Clause) diff --git a/src/plugins/data/public/utils/table_inspector_view/components/download_options.tsx b/src/plugins/data/public/utils/table_inspector_view/components/download_options.tsx index 599de9e82c58c..ef03d9d9d251e 100644 --- a/src/plugins/data/public/utils/table_inspector_view/components/download_options.tsx +++ b/src/plugins/data/public/utils/table_inspector_view/components/download_options.tsx @@ -141,7 +141,7 @@ class DataDownloadOptions extends Component } - toolTipPosition="left" + toolTipProps={{ position: 'left' }} > } - toolTipPosition="left" + toolTipProps={{ position: 'left' }} > , diff --git a/src/plugins/data_view_field_editor/public/components/field_format_editor/editors/url/__snapshots__/url.test.tsx.snap b/src/plugins/data_view_field_editor/public/components/field_format_editor/editors/url/__snapshots__/url.test.tsx.snap index 3685144b15219..9959f3f97edd9 100644 --- a/src/plugins/data_view_field_editor/public/components/field_format_editor/editors/url/__snapshots__/url.test.tsx.snap +++ b/src/plugins/data_view_field_editor/public/components/field_format_editor/editors/url/__snapshots__/url.test.tsx.snap @@ -179,13 +179,13 @@ exports[`UrlFormatEditor should render normally 1`] = ` URL template help External link (opens in a new tab or window) @@ -244,13 +244,13 @@ exports[`UrlFormatEditor should render normally 1`] = ` Label template help External link (opens in a new tab or window) diff --git a/src/plugins/discover/public/components/discover_grid/render_custom_toolbar.scss b/src/plugins/discover/public/components/discover_grid/render_custom_toolbar.scss index e24f7f8c6fcb1..66a3e9bb4f043 100644 --- a/src/plugins/discover/public/components/discover_grid/render_custom_toolbar.scss +++ b/src/plugins/discover/public/components/discover_grid/render_custom_toolbar.scss @@ -2,7 +2,7 @@ padding: $euiSizeS $euiSizeS $euiSizeXS; } -.dscGridToolbarControlButton .euiDataGrid__controlBtn { +.dscGridToolbarControlButton .euiDataGridToolbarControl { block-size: $euiSizeXL; border: $euiBorderThin; border-radius: $euiBorderRadiusSmall; @@ -13,10 +13,7 @@ block-size: $euiSize; } - // cancel default background and font changes - &.euiDataGrid__controlBtn--active { - font-weight: $euiFontWeightMedium; - } + // cancel default background changes &:active, &:focus { background: transparent; } diff --git a/src/plugins/inspector/public/ui/inspector_view_chooser.tsx b/src/plugins/inspector/public/ui/inspector_view_chooser.tsx index 454bd1917ffd1..d4621be61e73b 100644 --- a/src/plugins/inspector/public/ui/inspector_view_chooser.tsx +++ b/src/plugins/inspector/public/ui/inspector_view_chooser.tsx @@ -60,7 +60,7 @@ export class InspectorViewChooser extends Component { this.closeSelector(); }} toolTipContent={view.help} - toolTipPosition="left" + toolTipProps={{ position: 'left' }} data-test-subj={`inspectorViewChooser${view.title}`} > {view.title} diff --git a/src/plugins/saved_objects_management/public/management_section/object_view/components/__snapshots__/not_found_errors.test.tsx.snap b/src/plugins/saved_objects_management/public/management_section/object_view/components/__snapshots__/not_found_errors.test.tsx.snap index f1ee3dd03f3e5..829472941701c 100644 --- a/src/plugins/saved_objects_management/public/management_section/object_view/components/__snapshots__/not_found_errors.test.tsx.snap +++ b/src/plugins/saved_objects_management/public/management_section/object_view/components/__snapshots__/not_found_errors.test.tsx.snap @@ -35,13 +35,13 @@ exports[`NotFoundErrors component renders correctly for index-pattern type 1`] = > Saved objects APIs External link (opens in a new tab or window) @@ -87,13 +87,13 @@ exports[`NotFoundErrors component renders correctly for index-pattern-field type > Saved objects APIs External link (opens in a new tab or window) @@ -139,13 +139,13 @@ exports[`NotFoundErrors component renders correctly for search type 1`] = ` > Saved objects APIs External link (opens in a new tab or window) @@ -189,13 +189,13 @@ exports[`NotFoundErrors component renders correctly for unknown type 1`] = ` > Saved objects APIs External link (opens in a new tab or window) diff --git a/x-pack/packages/ml/data_grid/components/column_chart.tsx b/x-pack/packages/ml/data_grid/components/column_chart.tsx index 9f8b866bea930..7ebfb6ecaf5d4 100644 --- a/x-pack/packages/ml/data_grid/components/column_chart.tsx +++ b/x-pack/packages/ml/data_grid/components/column_chart.tsx @@ -6,40 +6,27 @@ */ import React, { type FC } from 'react'; -import { css } from '@emotion/react'; import { BarSeries, Chart, Settings, ScaleType, LEGACY_LIGHT_THEME } from '@elastic/charts'; -import { euiTextTruncate, type EuiDataGridColumn } from '@elastic/eui'; - -import { euiThemeVars } from '@kbn/ui-theme'; +import { mathWithUnits, type UseEuiTheme, type EuiDataGridColumn } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import { isUnsupportedChartData, ChartData } from '../lib/field_histograms'; import { useColumnChart } from '../hooks/use_column_chart'; -const cssHistogram = css({ +const cssHistogram = ({ euiTheme }: UseEuiTheme) => ({ width: '100%', - height: `calc(${euiThemeVars.euiSizeXL} + ${euiThemeVars.euiSizeXXL})`, + height: mathWithUnits([euiTheme.size.xl, euiTheme.size.xxl], (x, y) => x + y), }); -const cssHistogramLegend = css([ - css` - ${euiTextTruncate()} - `, - { - color: euiThemeVars.euiColorMediumShade, - display: 'block', - overflowX: 'hidden', - margin: `${euiThemeVars.euiSizeXS} 0 0 0`, - fontSize: euiThemeVars.euiFontSizeXS, +const cssHistogramLegend = ({ euiTheme }: UseEuiTheme) => + ({ + color: euiTheme.colors.mediumShade, + marginTop: euiTheme.size.xs, fontStyle: 'italic', fontWeight: 'normal', - textAlign: 'left', - }, -]); - -const cssHistogramLegendNumeric = css([cssHistogramLegend, { textAlign: 'right' }]); + } as const); interface Props { chartData: ChartData; @@ -100,12 +87,17 @@ export const ColumnChart: FC = ({
)}
{legendText}
- {!hideLabel &&
{columnType.id}
} + {!hideLabel && ( +
+ {columnType.id} +
+ )}
); }; diff --git a/x-pack/packages/ml/data_grid/components/data_grid.tsx b/x-pack/packages/ml/data_grid/components/data_grid.tsx index d90fdc125e6cd..de0f7d8ee9a34 100644 --- a/x-pack/packages/ml/data_grid/components/data_grid.tsx +++ b/x-pack/packages/ml/data_grid/components/data_grid.tsx @@ -7,7 +7,6 @@ import { isEqual } from 'lodash'; import React, { memo, useEffect, useRef, FC } from 'react'; -import { css } from '@emotion/react'; import { EuiButtonEmpty, @@ -24,6 +23,8 @@ import { EuiSpacer, EuiTitle, EuiToolTip, + UseEuiTheme, + mathWithUnits, } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; @@ -35,18 +36,49 @@ import { isPopulatedObject } from '@kbn/ml-is-populated-object'; import { euiDataGridStyle, euiDataGridToolbarSettings, INDEX_STATUS } from '../lib/common'; import { UseIndexDataReturnType } from '../lib/types'; -const cssOverride = css({ - '.euiDataGridRowCell--boolean': { textTransform: 'none' }, - // Overrides to align the sorting arrow, actions icon and the column header when no chart is available, - // to the bottom of the cell when histogram charts are enabled. - // Note that overrides have to be used as currently it is not possible to add a custom class name - // for the EuiDataGridHeaderCell - see https://github.com/elastic/eui/issues/5106 - '.euiDataGridHeaderCell': { - '.euiDataGridHeaderCell__sortingArrow,.euiDataGridHeaderCell__icon,.euiPopover': { - marginTop: 'auto', +const histogramHeaderProps = { className: 'cellHeaderWithHistogramChart' }; +const cssOverride = ({ euiTheme }: UseEuiTheme) => + ({ + '.euiDataGridRowCell--boolean': { textTransform: 'none' }, + // When a histogram chart is present in the column header, absolutely position + // the sorting arrow and actions icon so that the chart can expand to the full width + // of the header + '.cellHeaderWithHistogramChart': { + '.euiDataGridHeaderCell__content': { + width: '100%', + textAlign: 'left', // Should be overridden by EuiDataGrid's base CSS for numeric & currency schema + }, + '.euiDataGridHeaderCell__sortingArrow': { + position: 'absolute', + bottom: 0, + right: euiTheme.size.base, // Positioned to the left of the actions icon + // If the arrow is visible, ensure the icon is as well + '+ .euiPopover .euiDataGridHeaderCell__icon': { + width: 'auto', + opacity: '1', + }, + }, + '.euiDataGridHeaderCell__button > .euiPopover': { + position: 'absolute', + bottom: 0, + right: 0, + }, + // Re-apply cell icon affordances manually (due to absolute positioning) + '.histogramLabel': { + transition: `margin ${euiTheme.animation.fast} ease-in`, + }, + '&:hover, &:focus-within, &:has(.euiPopover-isOpen)': { + '.histogramLabel': { + marginRight: euiTheme.size.base, + }, + }, + '&:has(.euiDataGridHeaderCell__sortingArrow)': { + '.histogramLabel': { + marginRight: mathWithUnits([euiTheme.size.xl, euiTheme.size.xxs], (x, y) => x + y), + }, + }, }, - }, -}); + } as const); export const DataGridTitle: FC<{ title: string }> = ({ title }) => ( @@ -264,6 +296,7 @@ export const DataGrid: FC = memo( aria-label={isWithHeader(props) ? props.title : ''} columns={columnsWithCharts.map((c) => { c.initialWidth = 165; + if (chartsVisible) c.displayHeaderCellProps = histogramHeaderProps; return c; })} columnVisibility={{ visibleColumns, setVisibleColumns }} diff --git a/x-pack/packages/ml/data_grid/emotion.d.ts b/x-pack/packages/ml/data_grid/emotion.d.ts new file mode 100644 index 0000000000000..213178080e536 --- /dev/null +++ b/x-pack/packages/ml/data_grid/emotion.d.ts @@ -0,0 +1,14 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import '@emotion/react'; +import type { UseEuiTheme } from '@elastic/eui'; + +declare module '@emotion/react' { + // eslint-disable-next-line @typescript-eslint/no-empty-interface + export interface Theme extends UseEuiTheme {} +} diff --git a/x-pack/packages/ml/data_grid/tsconfig.json b/x-pack/packages/ml/data_grid/tsconfig.json index f074a13b25696..590cb613b7bf0 100644 --- a/x-pack/packages/ml/data_grid/tsconfig.json +++ b/x-pack/packages/ml/data_grid/tsconfig.json @@ -14,6 +14,7 @@ "include": [ "**/*.ts", "**/*.tsx", + "./emotion.d.ts", // Emotion EUI theme typing ], "exclude": [ "target/**/*" diff --git a/x-pack/packages/security-solution/data_table/components/data_table/index.tsx b/x-pack/packages/security-solution/data_table/components/data_table/index.tsx index 99f2f1006a309..3350263513099 100644 --- a/x-pack/packages/security-solution/data_table/components/data_table/index.tsx +++ b/x-pack/packages/security-solution/data_table/components/data_table/index.tsx @@ -118,14 +118,19 @@ const EuiDataGridContainer = styled.div<{ hideLastPage: boolean }>` ${({ hideLastPage }) => `${hideLastPage ? 'display:none' : ''}`}; } } - div .euiDataGridRowCell__contentWrapper { + div .euiDataGridRowCell { display: flex; align-items: center; } - div .euiDataGridRowCell--lastColumn .euiDataGridRowCell__content { - flex-grow: 0; + div .euiDataGridRowCell > [data-focus-lock-disabled] { + display: flex; + align-items: center; + flex-grow: 1; width: 100%; } + div .euiDataGridRowCell__content { + flex-grow: 1; + } div .siemEventsTable__trSupplement--summary { display: block; } diff --git a/x-pack/plugins/aiops/public/components/change_point_detection/fields_config.tsx b/x-pack/plugins/aiops/public/components/change_point_detection/fields_config.tsx index 0776bbba908a6..7429ad7ba9f0a 100644 --- a/x-pack/plugins/aiops/public/components/change_point_detection/fields_config.tsx +++ b/x-pack/plugins/aiops/public/components/change_point_detection/fields_config.tsx @@ -284,7 +284,7 @@ const FieldPanel: FC = ({ disabled: caseAttachmentButtonDisabled, ...(caseAttachmentButtonDisabled ? { - toolTipPosition: 'left' as const, + toolTipProps: { position: 'left' as const }, toolTipContent: i18n.translate( 'xpack.aiops.changePointDetection.attachToCaseTooltipContent', { diff --git a/x-pack/plugins/canvas/shareable_runtime/components/__snapshots__/app.test.tsx.snap b/x-pack/plugins/canvas/shareable_runtime/components/__snapshots__/app.test.tsx.snap index b661ee6e992e7..4b483b69445e8 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/__snapshots__/app.test.tsx.snap +++ b/x-pack/plugins/canvas/shareable_runtime/components/__snapshots__/app.test.tsx.snap @@ -1,3 +1,3 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[` App renders properly 1`] = `"
markdown mock
markdown mock

Page level controls

My Canvas Workpad

There is a new region landmark with page level controls at the end of the document.

"`; +exports[` App renders properly 1`] = `"
markdown mock
markdown mock

Page level controls

My Canvas Workpad

There is a new region landmark with page level controls at the end of the document.

"`; diff --git a/x-pack/plugins/cloud_security_posture/public/components/cloud_security_data_table/use_styles.ts b/x-pack/plugins/cloud_security_posture/public/components/cloud_security_data_table/use_styles.ts index 7823698ebd5c8..fe16f8c98df7e 100644 --- a/x-pack/plugins/cloud_security_posture/public/components/cloud_security_data_table/use_styles.ts +++ b/x-pack/plugins/cloud_security_posture/public/components/cloud_security_data_table/use_styles.ts @@ -27,22 +27,26 @@ export const useStyles = () => { & .euiDataGrid--headerUnderline .euiDataGridHeaderCell { border-bottom: ${euiTheme.border.width.thick} solid ${euiTheme.colors.fullShade}; } - & .euiDataGridRowCell__contentByHeight + .euiDataGridRowCell__expandActions { - padding: 0; - } & .euiButtonIcon[data-test-subj='docTableExpandToggleColumn'] { color: ${euiTheme.colors.primary}; } & .euiDataGridRowCell { font-size: ${euiTheme.size.m}; - } - & .euiDataGridRowCell__expandFlex { - align-items: center; + + // Vertically center content + .euiDataGridRowCell__content { + display: flex; + align-items: center; + } } & .euiDataGridRowCell.euiDataGridRowCell--numeric { text-align: left; } + & .euiDataGridHeaderCell--numeric .euiDataGridHeaderCell__content { + flex-grow: 0; + text-align: left; + } & .euiDataGrid__controls { gap: ${euiTheme.size.s}; } @@ -55,7 +59,7 @@ export const useStyles = () => { font-size: ${euiTheme.size.m}; font-weight: ${euiTheme.font.weight.bold}; border-right: ${euiTheme.border.thin}; - margin-right: ${euiTheme.size.s}; + margin-inline: ${euiTheme.size.s}; padding-right: ${euiTheme.size.m}; } & .euiDataGrid__rightControls { diff --git a/x-pack/plugins/cloud_security_posture/public/components/timestamp_table_cell.tsx b/x-pack/plugins/cloud_security_posture/public/components/timestamp_table_cell.tsx index 49932d6cf0de3..9b0d8f720dbfb 100644 --- a/x-pack/plugins/cloud_security_posture/public/components/timestamp_table_cell.tsx +++ b/x-pack/plugins/cloud_security_posture/public/components/timestamp_table_cell.tsx @@ -7,11 +7,23 @@ import React from 'react'; import moment, { type MomentInput } from 'moment'; +import { css } from '@emotion/react'; import { EuiToolTip } from '@elastic/eui'; import { CSP_MOMENT_FORMAT } from '../common/constants'; +// Offset top-aligned tooltips so that cell actions are visible +const datagridToolTipOffset = css` + &[data-position='top'] { + margin-block-start: -8px; + } +`; + export const TimestampTableCell = ({ timestamp }: { timestamp: MomentInput }) => ( - + {moment(timestamp).fromNow()} ); diff --git a/x-pack/plugins/cloud_security_posture/public/pages/vulnerabilities/hooks/use_styles.ts b/x-pack/plugins/cloud_security_posture/public/pages/vulnerabilities/hooks/use_styles.ts index 9a353da63e058..c09490d719f1f 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/vulnerabilities/hooks/use_styles.ts +++ b/x-pack/plugins/cloud_security_posture/public/pages/vulnerabilities/hooks/use_styles.ts @@ -45,21 +45,24 @@ export const useStyles = () => { } & .euiDataGridRowCell { font-size: ${euiTheme.size.m}; + + // Vertically center content + .euiDataGridRowCell__content { + display: flex; + align-items: center; + } } - & .euiDataGridRowCell__actions > [data-test-subj='euiDataGridCellExpandButton'] { + /* EUI QUESTION: Why is this being done via CSS instead of setting isExpandable: false in the columns API? */ + & .euiDataGridRowCell__actions > .euiDataGridRowCell__expandCell { display: none; } - & .euiDataGridRowCell__actions--overlay { - padding: 0; - } - - & .euiDataGridRowCell__contentWrapper { - display: flex; - align-items: center; - } & .euiDataGridRowCell.euiDataGridRowCell--numeric { text-align: left; } + & .euiDataGridHeaderCell--numeric .euiDataGridHeaderCell__content { + flex-grow: 0; + text-align: left; + } `; const highlightStyle = css` diff --git a/x-pack/plugins/cloud_security_posture/public/pages/vulnerabilities/vulnerabilities_by_resource/severity_map.tsx b/x-pack/plugins/cloud_security_posture/public/pages/vulnerabilities/vulnerabilities_by_resource/severity_map.tsx index af47c20ddc50f..78e5513271441 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/vulnerabilities/vulnerabilities_by_resource/severity_map.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/vulnerabilities/vulnerabilities_by_resource/severity_map.tsx @@ -88,6 +88,7 @@ export const SeverityMap = ({ severityMap, total }: Props) => { `} anchorClassName={css` height: ${euiTheme.size.xl}; + flex-grow: 1; display: flex; align-items: center; `} diff --git a/x-pack/plugins/index_lifecycle_management/__jest__/__snapshots__/extend_index_management.test.tsx.snap b/x-pack/plugins/index_lifecycle_management/__jest__/__snapshots__/extend_index_management.test.tsx.snap index 3a85403c5649a..219c054709354 100644 --- a/x-pack/plugins/index_lifecycle_management/__jest__/__snapshots__/extend_index_management.test.tsx.snap +++ b/x-pack/plugins/index_lifecycle_management/__jest__/__snapshots__/extend_index_management.test.tsx.snap @@ -130,13 +130,13 @@ exports[`extend index management ilm summary extension should render a phase def > Edit policy in ILM External link (opens in a new tab or window) @@ -301,13 +301,13 @@ exports[`extend index management ilm summary extension should render a step info > Edit policy in ILM External link (opens in a new tab or window) @@ -468,13 +468,13 @@ exports[`extend index management ilm summary extension should render an error pa > Edit policy in ILM External link (opens in a new tab or window) @@ -636,13 +636,13 @@ exports[`extend index management ilm summary extension should render the tab whe > Edit policy in ILM External link (opens in a new tab or window) diff --git a/x-pack/plugins/infra/public/alerting/log_threshold/components/alert_dropdown.tsx b/x-pack/plugins/infra/public/alerting/log_threshold/components/alert_dropdown.tsx index bb2dbc7afdc36..6e3e72c5cc8de 100644 --- a/x-pack/plugins/infra/public/alerting/log_threshold/components/alert_dropdown.tsx +++ b/x-pack/plugins/infra/public/alerting/log_threshold/components/alert_dropdown.tsx @@ -85,13 +85,13 @@ export const AlertDropdown = () => { : inlineLogViewTooltipContent : undefined } - toolTipTitle={ - !canCreateAlerts + toolTipProps={{ + title: !canCreateAlerts ? readOnly ? readOnlyUserTooltipTitle : inlineLogViewTooltipTitle - : undefined - } + : undefined, + }} > = ({ }} textProps={{ ...textProps, - className: classNames('kbnToolbarButton__text', textProps?.className), + className: classNames('kbnToolbarButton__text', textProps && textProps.className), }} {...rest} size={size} diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap index db99b1a10ea8d..9456222eca7aa 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap @@ -38,13 +38,13 @@ exports[`RequestTrialExtension component should display when enterprise license > subscription features External link (opens in a new tab or window) @@ -114,13 +114,13 @@ exports[`RequestTrialExtension component should display when license is active a > subscription features External link (opens in a new tab or window) @@ -190,13 +190,13 @@ exports[`RequestTrialExtension component should display when license is not acti > subscription features External link (opens in a new tab or window) @@ -266,13 +266,13 @@ exports[`RequestTrialExtension component should display when platinum license is > subscription features External link (opens in a new tab or window) diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap index af9fc4be3f0d0..f1e5a50a309c8 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap @@ -38,13 +38,13 @@ exports[`RevertToBasic component should display when license is about to expire > subscription features External link (opens in a new tab or window) @@ -112,13 +112,13 @@ exports[`RevertToBasic component should display when license is expired 1`] = ` > subscription features External link (opens in a new tab or window) @@ -186,13 +186,13 @@ exports[`RevertToBasic component should display when trial is active 1`] = ` > subscription features External link (opens in a new tab or window) diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap index 9d32a3925f852..64221ba1d1d5c 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap @@ -38,13 +38,13 @@ exports[`StartTrial component when trial is allowed display for basic license 1` > subscription features External link (opens in a new tab or window) @@ -112,13 +112,13 @@ exports[`StartTrial component when trial is allowed should display for expired e > subscription features External link (opens in a new tab or window) @@ -186,13 +186,13 @@ exports[`StartTrial component when trial is allowed should display for expired p > subscription features External link (opens in a new tab or window) @@ -260,13 +260,13 @@ exports[`StartTrial component when trial is allowed should display for gold lice > subscription features External link (opens in a new tab or window) diff --git a/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap b/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap index dc54838631c06..b987170ab6e10 100644 --- a/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap +++ b/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap @@ -87,13 +87,13 @@ Array [ > Elasticsearch Service Console External link (opens in a new tab or window) @@ -107,13 +107,13 @@ Array [ > Logs and metrics External link (opens in a new tab or window) @@ -127,13 +127,13 @@ Array [ > the documentation page. External link (opens in a new tab or window) diff --git a/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap b/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap index f0a62472dde83..029a2ebf190d3 100644 --- a/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap +++ b/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap @@ -154,13 +154,13 @@ Array [ > Elasticsearch Service Console External link (opens in a new tab or window) @@ -174,13 +174,13 @@ Array [ > Logs and metrics External link (opens in a new tab or window) @@ -194,13 +194,13 @@ Array [ > the documentation page. External link (opens in a new tab or window) diff --git a/x-pack/plugins/osquery/cypress/screens/live_query.ts b/x-pack/plugins/osquery/cypress/screens/live_query.ts index 04c56fbce44c7..f850cbf9538ad 100644 --- a/x-pack/plugins/osquery/cypress/screens/live_query.ts +++ b/x-pack/plugins/osquery/cypress/screens/live_query.ts @@ -14,6 +14,7 @@ export const SUBMIT_BUTTON = '#submit-button'; export const RESULTS_TABLE = 'osqueryResultsTable'; export const RESULTS_TABLE_BUTTON = 'dataGridFullScreenButton'; +export const RESULTS_TABLE_COLUMNS_BUTTON = 'dataGridColumnSelectorButton'; export const RESULTS_TABLE_CELL_WRRAPER = 'EuiDataGridHeaderCellWrapper'; export const getIdFormField = () => cy.get('input[name="id"]'); diff --git a/x-pack/plugins/osquery/cypress/tasks/saved_queries.ts b/x-pack/plugins/osquery/cypress/tasks/saved_queries.ts index b01effba17e65..4b0e40e577674 100644 --- a/x-pack/plugins/osquery/cypress/tasks/saved_queries.ts +++ b/x-pack/plugins/osquery/cypress/tasks/saved_queries.ts @@ -5,7 +5,7 @@ * 2.0. */ -import { RESULTS_TABLE_BUTTON } from '../screens/live_query'; +import { RESULTS_TABLE_BUTTON, RESULTS_TABLE_COLUMNS_BUTTON } from '../screens/live_query'; import { closeToastIfVisible, generateRandomStringName } from './integrations'; import { checkResults, @@ -45,7 +45,7 @@ export const getSavedQueriesComplexTest = () => cy.contains('Exit fullscreen').should('exist'); // hidden columns - cy.contains('columns hidden').should('not.exist'); + cy.getBySel(RESULTS_TABLE_COLUMNS_BUTTON).should('have.text', 'Columns35'); cy.getBySel('dataGridHeaderCell-osquery.cmdline').click(); cy.contains(/Hide column$/).click(); cy.getBySel('dataGridHeaderCell-osquery.cwd').click(); @@ -54,10 +54,10 @@ export const getSavedQueriesComplexTest = () => cy.getBySel('dataGridHeaderCell-osquery.disk_bytes_written.number').click(); cy.contains(/Hide column$/).click(); - cy.contains('columns hidden').should('exist'); + cy.getBySel(RESULTS_TABLE_COLUMNS_BUTTON).should('have.text', 'Columns32/35'); // change pagination cy.getBySel('pagination-button-next').click().wait(500).click(); - cy.contains('columns hidden').should('exist'); + cy.getBySel(RESULTS_TABLE_COLUMNS_BUTTON).should('have.text', 'Columns32/35'); // enter fullscreen cy.getBySel(RESULTS_TABLE_BUTTON).trigger('mouseover'); @@ -69,7 +69,7 @@ export const getSavedQueriesComplexTest = () => cy.getBySel('dataGridHeaderCell-osquery.egid').click(); cy.contains(/Sort A-Z$/).click(); - cy.contains('columns hidden').should('exist'); + cy.getBySel(RESULTS_TABLE_COLUMNS_BUTTON).should('have.text', 'Columns32/35'); cy.getBySel(RESULTS_TABLE_BUTTON).trigger('mouseover'); cy.contains(/Enter fullscreen$/).should('exist'); diff --git a/x-pack/plugins/security/server/__snapshots__/prompt_page.test.tsx.snap b/x-pack/plugins/security/server/__snapshots__/prompt_page.test.tsx.snap index 8eaa66ee35be9..f24357ae373fa 100644 --- a/x-pack/plugins/security/server/__snapshots__/prompt_page.test.tsx.snap +++ b/x-pack/plugins/security/server/__snapshots__/prompt_page.test.tsx.snap @@ -1,5 +1,5 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`PromptPage renders as expected with additional scripts 1`] = `"ElasticMockedFonts

Some Title

Some Body
Action#1
Action#2
"`; +exports[`PromptPage renders as expected with additional scripts 1`] = `"ElasticMockedFonts

Some Title

Some Body
Action#1
Action#2
"`; -exports[`PromptPage renders as expected without additional scripts 1`] = `"ElasticMockedFonts

Some Title

Some Body
Action#1
Action#2
"`; +exports[`PromptPage renders as expected without additional scripts 1`] = `"ElasticMockedFonts

Some Title

Some Body
Action#1
Action#2
"`; diff --git a/x-pack/plugins/security/server/authentication/__snapshots__/unauthenticated_page.test.tsx.snap b/x-pack/plugins/security/server/authentication/__snapshots__/unauthenticated_page.test.tsx.snap index d7be0e5f720a5..fb377c8a0b924 100644 --- a/x-pack/plugins/security/server/authentication/__snapshots__/unauthenticated_page.test.tsx.snap +++ b/x-pack/plugins/security/server/authentication/__snapshots__/unauthenticated_page.test.tsx.snap @@ -1,5 +1,5 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`UnauthenticatedPage renders as expected 1`] = `"ElasticMockedFonts

We hit an authentication error

Try logging in again, and if the problem persists, contact your system administrator.

"`; +exports[`UnauthenticatedPage renders as expected 1`] = `"ElasticMockedFonts

We hit an authentication error

Try logging in again, and if the problem persists, contact your system administrator.

"`; -exports[`UnauthenticatedPage renders as expected with custom title 1`] = `"My Company NameMockedFonts

We hit an authentication error

Try logging in again, and if the problem persists, contact your system administrator.

"`; +exports[`UnauthenticatedPage renders as expected with custom title 1`] = `"My Company NameMockedFonts

We hit an authentication error

Try logging in again, and if the problem persists, contact your system administrator.

"`; diff --git a/x-pack/plugins/security/server/authorization/__snapshots__/reset_session_page.test.tsx.snap b/x-pack/plugins/security/server/authorization/__snapshots__/reset_session_page.test.tsx.snap index f66f33000de55..0146a55a9970e 100644 --- a/x-pack/plugins/security/server/authorization/__snapshots__/reset_session_page.test.tsx.snap +++ b/x-pack/plugins/security/server/authorization/__snapshots__/reset_session_page.test.tsx.snap @@ -1,5 +1,5 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`ResetSessionPage renders as expected 1`] = `"ElasticMockedFonts

You do not have permission to access the requested page

Either go back to the previous page or log in as a different user.

"`; +exports[`ResetSessionPage renders as expected 1`] = `"ElasticMockedFonts

You do not have permission to access the requested page

Either go back to the previous page or log in as a different user.

"`; -exports[`ResetSessionPage renders as expected with custom page title 1`] = `"My Company NameMockedFonts

You do not have permission to access the requested page

Either go back to the previous page or log in as a different user.

"`; +exports[`ResetSessionPage renders as expected with custom page title 1`] = `"My Company NameMockedFonts

You do not have permission to access the requested page

Either go back to the previous page or log in as a different user.

"`; diff --git a/x-pack/plugins/security_solution/public/common/components/formatted_date/index.tsx b/x-pack/plugins/security_solution/public/common/components/formatted_date/index.tsx index bf7fd230fbfc4..25b7bec640198 100644 --- a/x-pack/plugins/security_solution/public/common/components/formatted_date/index.tsx +++ b/x-pack/plugins/security_solution/public/common/components/formatted_date/index.tsx @@ -8,6 +8,7 @@ import moment from 'moment-timezone'; import React from 'react'; import { FormattedRelative } from '@kbn/i18n-react'; +import type { EuiToolTipProps } from '@elastic/eui'; import { useDateFormat, useTimeZone, useUiSetting$ } from '../../lib/kibana'; import { getOrEmptyTagFromValue } from '../empty_value'; @@ -98,16 +99,22 @@ interface FormattedDateProps { fieldName: string; value?: string | number | null; dateFormat?: string; + tooltipProps?: Partial; } export const FormattedDate = React.memo( - ({ value, fieldName, className = '', dateFormat }): JSX.Element => { + ({ value, fieldName, className = '', dateFormat, tooltipProps }): JSX.Element => { if (value == null) { return getOrEmptyTagFromValue(value); } const maybeDate = getMaybeDate(value); return maybeDate.isValid() ? ( - + ) : ( diff --git a/x-pack/plugins/security_solution/public/common/components/localized_date_tooltip/index.tsx b/x-pack/plugins/security_solution/public/common/components/localized_date_tooltip/index.tsx index 34825dfa5ae9d..8f4ed4d34f5c5 100644 --- a/x-pack/plugins/security_solution/public/common/components/localized_date_tooltip/index.tsx +++ b/x-pack/plugins/security_solution/public/common/components/localized_date_tooltip/index.tsx @@ -5,7 +5,7 @@ * 2.0. */ -import { EuiFlexGroup, EuiFlexItem, EuiToolTip } from '@elastic/eui'; +import { EuiFlexGroup, EuiFlexItem, EuiToolTip, type EuiToolTipProps } from '@elastic/eui'; import { FormattedRelative } from '@kbn/i18n-react'; import moment from 'moment'; import React from 'react'; @@ -15,10 +15,12 @@ export const LocalizedDateTooltip = React.memo<{ date: Date; fieldName?: string; className?: string; -}>(({ children, date, fieldName, className = '' }) => ( + tooltipProps?: Partial; +}>(({ children, date, fieldName, className = '', tooltipProps }) => ( {fieldName != null ? ( diff --git a/x-pack/plugins/security_solution/public/common/components/top_n/top_n.tsx b/x-pack/plugins/security_solution/public/common/components/top_n/top_n.tsx index a93c3fd386382..0dbd55b9bae34 100644 --- a/x-pack/plugins/security_solution/public/common/components/top_n/top_n.tsx +++ b/x-pack/plugins/security_solution/public/common/components/top_n/top_n.tsx @@ -31,7 +31,7 @@ const CloseButton = styled(EuiButtonIcon)` top: 4px; `; -const ViewSelect = styled(EuiSuperSelect)` +const ViewSelect = styled(EuiSuperSelect)` width: 170px; `; diff --git a/x-pack/plugins/security_solution/public/detection_engine/rule_management_ui/components/rules_table/bulk_actions/use_bulk_actions.tsx b/x-pack/plugins/security_solution/public/detection_engine/rule_management_ui/components/rules_table/bulk_actions/use_bulk_actions.tsx index 41802a4738b8d..d66f1b45feb9a 100644 --- a/x-pack/plugins/security_solution/public/detection_engine/rule_management_ui/components/rules_table/bulk_actions/use_bulk_actions.tsx +++ b/x-pack/plugins/security_solution/public/detection_engine/rule_management_ui/components/rules_table/bulk_actions/use_bulk_actions.tsx @@ -299,7 +299,7 @@ export const useBulkActions = ({ toolTipContent: missingActionPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, icon: undefined, }, { @@ -311,7 +311,7 @@ export const useBulkActions = ({ toolTipContent: missingActionPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, icon: undefined, }, { @@ -337,7 +337,7 @@ export const useBulkActions = ({ toolTipContent: !hasActionsPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, icon: undefined, }, { @@ -349,7 +349,7 @@ export const useBulkActions = ({ toolTipContent: missingActionPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, icon: undefined, }, { @@ -361,7 +361,7 @@ export const useBulkActions = ({ toolTipContent: missingActionPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, icon: undefined, }, { @@ -382,7 +382,7 @@ export const useBulkActions = ({ toolTipContent: missingActionPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, icon: undefined, }, { @@ -397,7 +397,7 @@ export const useBulkActions = ({ 'data-test-subj': 'deleteRuleBulk', disabled: isDeleteDisabled, onClick: handleDeleteAction, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, icon: undefined, }, ], @@ -415,7 +415,7 @@ export const useBulkActions = ({ toolTipContent: missingActionPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, }, { key: i18n.BULK_ACTION_DELETE_TAGS, @@ -426,7 +426,7 @@ export const useBulkActions = ({ toolTipContent: missingActionPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, }, ], }, @@ -443,7 +443,7 @@ export const useBulkActions = ({ toolTipContent: missingActionPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, }, { key: i18n.BULK_ACTION_DELETE_INDEX_PATTERNS, @@ -454,7 +454,7 @@ export const useBulkActions = ({ toolTipContent: missingActionPrivileges ? i18n.LACK_OF_KIBANA_ACTIONS_FEATURE_PRIVILEGES : undefined, - toolTipPosition: 'right', + toolTipProps: { position: 'right' }, }, ], }, diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/index.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_table/index.tsx index 97d86deed7a48..e8ea06867c92a 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/index.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/index.tsx @@ -71,15 +71,18 @@ const EuiDataGridContainer = styled.div` }}; } } - div .euiDataGridRowCell__contentWrapper { + div .euiDataGridRowCell { display: flex; align-items: center; } - div .euiDataGridRowCell__content { + div .euiDataGridRowCell > [data-focus-lock-disabled] { + display: flex; + align-items: center; + flex-grow: 1; width: 100%; } - div .euiDataGridRowCell--lastColumn .euiDataGridRowCell__content { - flex-grow: 0; + div .euiDataGridRowCell__content { + flex-grow: 1; } div .siemEventsTable__trSupplement--summary { display: block; diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/list/policy_artifacts_list.tsx b/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/list/policy_artifacts_list.tsx index 22ddd31391977..861e407e80824 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/list/policy_artifacts_list.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/list/policy_artifacts_list.tsx @@ -144,7 +144,7 @@ export const PolicyArtifactsList = React.memo( }, disabled: isGlobal, toolTipContent: isGlobal ? labels.listRemoveActionNotAllowedMessage : undefined, - toolTipPosition: 'top' as const, + toolTipProps: { position: 'top' as const }, 'data-test-subj': 'remove-from-policy-action', }; return { diff --git a/x-pack/plugins/security_solution/public/timelines/components/field_renderers/__snapshots__/field_renderers.test.tsx.snap b/x-pack/plugins/security_solution/public/timelines/components/field_renderers/__snapshots__/field_renderers.test.tsx.snap index 2f11cdf57c3a6..270ca0c6c54b7 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/field_renderers/__snapshots__/field_renderers.test.tsx.snap +++ b/x-pack/plugins/security_solution/public/timelines/components/field_renderers/__snapshots__/field_renderers.test.tsx.snap @@ -284,13 +284,13 @@ exports[`Field Renderers #whoisRenderer it renders correctly against snapshot 1` > iana.org External link (opens in a new tab or window) diff --git a/x-pack/plugins/security_solution/public/timelines/components/netflow/__snapshots__/index.test.tsx.snap b/x-pack/plugins/security_solution/public/timelines/components/netflow/__snapshots__/index.test.tsx.snap index 919d237027815..5b4bb5021a66e 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/netflow/__snapshots__/index.test.tsx.snap +++ b/x-pack/plugins/security_solution/public/timelines/components/netflow/__snapshots__/index.test.tsx.snap @@ -1118,13 +1118,13 @@ tr:hover .c2:focus::before { > 9987 External link (opens in a new tab or window) @@ -1957,13 +1957,13 @@ tr:hover .c2:focus::before { > 80 External link (opens in a new tab or window) @@ -2406,13 +2406,13 @@ tr:hover .c2:focus::before { > tls.fingerprints.ja3.hash-value External link (opens in a new tab or window) @@ -2504,13 +2504,13 @@ tr:hover .c2:focus::before { > tls.client_certificate.fingerprint.sha1-value External link (opens in a new tab or window) @@ -2602,13 +2602,13 @@ tr:hover .c2:focus::before { > tls.server_certificate.fingerprint.sha1-value External link (opens in a new tab or window) diff --git a/x-pack/plugins/security_solution/public/timelines/components/open_timeline/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/open_timeline/index.test.tsx index 91d865960c813..33d9b66f4d6c6 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/open_timeline/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/open_timeline/index.test.tsx @@ -389,8 +389,11 @@ describe('StatefulOpenTimeline', () => { /> ); - wrapper.find('[data-test-subj="euiCollapsedItemActionsButton"]').first().simulate('click'); - wrapper.find('[data-test-subj="delete-timeline"]').first().simulate('click'); + wrapper + .find('button[data-test-subj="euiCollapsedItemActionsButton"]') + .first() + .simulate('click'); + wrapper.find('button[data-test-subj="delete-timeline"]').first().simulate('click'); wrapper.find('button[data-test-subj="confirmModalConfirmButton"]').first().simulate('click'); await waitFor(() => { @@ -666,16 +669,16 @@ describe('StatefulOpenTimeline', () => { /> ); - wrapper.find('[data-test-subj="euiCollapsedItemActionsButton"]').first().simulate('click'); - wrapper.find('[data-test-subj="open-duplicate"]').first().simulate('click'); - await waitFor(() => { - wrapper.update(); - - expect((queryTimelineById as jest.Mock).mock.calls[0][0].timelineId).toEqual( - mockOpenTimelineQueryResults.timeline[0].savedObjectId - ); - expect((queryTimelineById as jest.Mock).mock.calls[0][0].duplicate).toEqual(true); - }); + wrapper + .find('button[data-test-subj="euiCollapsedItemActionsButton"]') + .first() + .simulate('click'); + wrapper.find('button[data-test-subj="open-duplicate"]').first().simulate('click'); + + expect((queryTimelineById as jest.Mock).mock.calls[0][0].timelineId).toEqual( + mockOpenTimelineQueryResults.timeline[0].savedObjectId + ); + expect((queryTimelineById as jest.Mock).mock.calls[0][0].duplicate).toEqual(true); }); describe('Create rule from timeline', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap index 8475b548dd795..463e4a1e2f57a 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap +++ b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap @@ -855,13 +855,13 @@ exports[`Details Panel Component DetailsPanel:NetworkDetails: rendering it shoul > iana.org External link (opens in a new tab or window) diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/formatted_field.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/formatted_field.tsx index ce785cd7b20cb..7062fc7afbb78 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/formatted_field.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/formatted_field.tsx @@ -11,6 +11,7 @@ import type { EuiButtonEmpty, EuiButtonIcon } from '@elastic/eui'; import { EuiFlexGroup, EuiFlexItem, EuiToolTip } from '@elastic/eui'; import { isNumber, isEmpty } from 'lodash/fp'; import React from 'react'; +import { css } from '@emotion/css'; import { SENTINEL_ONE_AGENT_ID_FIELD } from '../../../../../common/utils/sentinelone_alert_check'; import { SentinelOneAgentStatus } from '../../../../../detections/components/host_isolation/sentinel_one_agent_status'; @@ -48,6 +49,13 @@ import { UserName } from './user_name'; // simple black-list to prevent dragging and dropping fields such as message name const columnNamesNotDraggable = [MESSAGE_FIELD_NAME]; +// Offset top-aligned tooltips so that cell actions are more visible +const dataGridToolTipOffset = css` + &[data-position='top'] { + margin-block-start: -8px; + } +`; + const FormattedFieldValueComponent: React.FC<{ asPlainText?: boolean; /** `Component` is only used with `EuiDataGrid`; the grid keeps a reference to `Component` for show / hide functionality */ @@ -109,6 +117,14 @@ const FormattedFieldValueComponent: React.FC<{ return <>{value}; } else if (fieldType === DATE_FIELD_TYPE) { const classNames = truncate ? 'eui-textTruncate eui-alignMiddle' : undefined; + const date = ( + + ); return isDraggable ? ( - + {date} ) : ( - + date ); } else if (PORT_NAMES.some((portName) => fieldName === portName)) { return ( @@ -274,6 +290,8 @@ const FormattedFieldValueComponent: React.FC<{ diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/netflow/__snapshots__/netflow_row_renderer.test.tsx.snap b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/netflow/__snapshots__/netflow_row_renderer.test.tsx.snap index 803a4f84552f2..627b209f0fdbe 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/netflow/__snapshots__/netflow_row_renderer.test.tsx.snap +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/netflow/__snapshots__/netflow_row_renderer.test.tsx.snap @@ -1309,13 +1309,13 @@ tr:hover .c4:focus::before { > 9987 External link (opens in a new tab or window) @@ -2309,13 +2309,13 @@ tr:hover .c4:focus::before { > 80 External link (opens in a new tab or window) @@ -2827,13 +2827,13 @@ tr:hover .c4:focus::before { > tls.fingerprints.ja3.hash-value External link (opens in a new tab or window) @@ -2935,13 +2935,13 @@ tr:hover .c4:focus::before { > tls.client_certificate.fingerprint.sha1-value External link (opens in a new tab or window) @@ -3043,13 +3043,13 @@ tr:hover .c4:focus::before { > tls.server_certificate.fingerprint.sha1-value External link (opens in a new tab or window) diff --git a/x-pack/plugins/serverless_search/public/application/components/connectors_callout.tsx b/x-pack/plugins/serverless_search/public/application/components/connectors_callout.tsx index 85d3db211c479..f321330eda294 100644 --- a/x-pack/plugins/serverless_search/public/application/components/connectors_callout.tsx +++ b/x-pack/plugins/serverless_search/public/application/components/connectors_callout.tsx @@ -55,19 +55,17 @@ export const ConnectorsCallout = () => {

-

- createConnector()} - isLoading={isLoading} - > - {i18n.translate('xpack.serverlessSearch.selectClient.connectorsCallout.cta', { - defaultMessage: 'Create a connector', - })} - -

+ createConnector()} + isLoading={isLoading} + > + {i18n.translate('xpack.serverlessSearch.selectClient.connectorsCallout.cta', { + defaultMessage: 'Create a connector', + })} +
{showConnectors && @@ -85,14 +83,12 @@ export const ConnectorsCallout = () => { ))} {showConnectors && ( -

- - - -

+ + +
)}
diff --git a/x-pack/plugins/translations/translations/fr-FR.json b/x-pack/plugins/translations/translations/fr-FR.json index 495bf957ea490..bf8aef96fcb4f 100644 --- a/x-pack/plugins/translations/translations/fr-FR.json +++ b/x-pack/plugins/translations/translations/fr-FR.json @@ -564,9 +564,6 @@ "core.euiCodeBlockAnnotations.ariaLabel": "Cliquez pour afficher une annotation de code pour la ligne {lineNumber}", "core.euiColorPickerSwatch.ariaLabel": "Sélectionner {color} comme couleur", "core.euiColumnActions.sort": "Trier {schemaLabel}", - "core.euiColumnSelector.buttonActivePlural": "{numberOfHiddenFields} colonnes masquées", - "core.euiColumnSelector.buttonActiveSingular": "{numberOfHiddenFields} colonne masquée", - "core.euiColumnSorting.buttonActive": "{numberOfSortedFields, plural, one {Champ #} many {# champs} other {# champs triés}}", "core.euiColumnSortingDraggable.activeSortLabel": "{display} trie cette grille de données", "core.euiColumnSortingDraggable.removeSortLabel": "Retirer {display} du tri de la grille de données", "core.euiColumnSortingDraggable.toggleLegend": "Sélectionner la méthode de tri pour {display}", @@ -819,8 +816,6 @@ "core.euiKeyboardShortcuts.title": "Raccourcis clavier", "core.euiKeyboardShortcuts.upArrowDescription": "Aller une cellule vers le haut", "core.euiKeyboardShortcuts.upArrowTitle": "Flèche vers le haut", - "core.euiLink.external.ariaLabel": "Lien externe", - "core.euiLink.newTarget.screenReaderOnlyText": "(s’ouvre dans un nouvel onglet ou une nouvelle fenêtre)", "core.euiLoadingChart.ariaLabel": "Chargement", "core.euiLoadingStrings.ariaLabel": "Chargement", "core.euiMark.highlightEnd": "mettre la fin en surbrillance", diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index f7b993b853889..d159282232345 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -564,9 +564,6 @@ "core.euiCodeBlockAnnotations.ariaLabel": "クリックすると、行番号{lineNumber}のコード注釈が表示されます", "core.euiColorPickerSwatch.ariaLabel": "{color}を色として選択します", "core.euiColumnActions.sort": "{schemaLabel}の並べ替え", - "core.euiColumnSelector.buttonActivePlural": "{numberOfHiddenFields}列が非表示です", - "core.euiColumnSelector.buttonActiveSingular": "{numberOfHiddenFields}列が非表示です", - "core.euiColumnSorting.buttonActive": "{numberOfSortedFields, plural, other {#個のフィールド}}が並べ替えられました", "core.euiColumnSortingDraggable.activeSortLabel": "{display}はこのデータグリッドを並べ替えています", "core.euiColumnSortingDraggable.removeSortLabel": "データグリッドの並べ替えから{display}を削除", "core.euiColumnSortingDraggable.toggleLegend": "{display}の並べ替え方法を選択", @@ -833,8 +830,6 @@ "core.euiKeyboardShortcuts.title": "キーボードショートカット", "core.euiKeyboardShortcuts.upArrowDescription": "セルを1つ上に移動", "core.euiKeyboardShortcuts.upArrowTitle": "上向き矢印", - "core.euiLink.external.ariaLabel": "外部リンク", - "core.euiLink.newTarget.screenReaderOnlyText": "(新しいタブまたはウィンドウで開く)", "core.euiLoadingChart.ariaLabel": "読み込み中", "core.euiLoadingStrings.ariaLabel": "読み込み中", "core.euiMark.highlightEnd": "ハイライト終了", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index ea83c57f02b27..0629f497ff743 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -564,9 +564,6 @@ "core.euiCodeBlockAnnotations.ariaLabel": "单击以查看行 {lineNumber} 的代码注释", "core.euiColorPickerSwatch.ariaLabel": "将 {color} 选为颜色", "core.euiColumnActions.sort": "排序 {schemaLabel}", - "core.euiColumnSelector.buttonActivePlural": "{numberOfHiddenFields} 列已隐藏", - "core.euiColumnSelector.buttonActiveSingular": "{numberOfHiddenFields} 列已隐藏", - "core.euiColumnSorting.buttonActive": "{numberOfSortedFields, plural, other {# 个字段}}已排序", "core.euiColumnSortingDraggable.activeSortLabel": "{display} 正在排序此数据网格", "core.euiColumnSortingDraggable.removeSortLabel": "从数据网格排序中移除 {display}", "core.euiColumnSortingDraggable.toggleLegend": "为 {display} 选择排序方法", @@ -833,8 +830,6 @@ "core.euiKeyboardShortcuts.title": "快捷键", "core.euiKeyboardShortcuts.upArrowDescription": "上移一个单元格", "core.euiKeyboardShortcuts.upArrowTitle": "向上箭头键", - "core.euiLink.external.ariaLabel": "外部链接", - "core.euiLink.newTarget.screenReaderOnlyText": "(在新选项卡或窗口中打开)", "core.euiLoadingChart.ariaLabel": "正在加载", "core.euiLoadingStrings.ariaLabel": "正在加载", "core.euiMark.highlightEnd": "高亮显示结尾", diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rules_list/components/rules_list_column_selector.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rules_list/components/rules_list_column_selector.test.tsx index 60f52930ffe91..ad623631fe85e 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/rules_list/components/rules_list_column_selector.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rules_list/components/rules_list_column_selector.test.tsx @@ -108,8 +108,8 @@ describe('useRulesListColumnSelector', () => { { field: 'schedule.interval', name: 'Interval' }, ]); - const { getByText } = render(<>{ColumnSelector}); - expect(getByText('1 column hidden')).toBeInTheDocument(); + const { getByLabelText } = render(<>{ColumnSelector}); + expect(getByLabelText('- Active: 5 out of 6')).toBeInTheDocument(); }); it('Lets hide last lastExecutionDate, Interval and duration columns', () => { @@ -127,7 +127,7 @@ describe('useRulesListColumnSelector', () => { { field: 'notify', name: 'Html Notify' }, ]); - const { getByText } = render(<>{ColumnSelector}); - expect(getByText('3 columns hidden')).toBeInTheDocument(); + const { getByLabelText } = render(<>{ColumnSelector}); + expect(getByLabelText('- Active: 3 out of 6')).toBeInTheDocument(); }); }); diff --git a/x-pack/plugins/uptime/public/legacy_uptime/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap b/x-pack/plugins/uptime/public/legacy_uptime/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap index 60462feb48cab..b4b7a53c69909 100644 --- a/x-pack/plugins/uptime/public/legacy_uptime/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap +++ b/x-pack/plugins/uptime/public/legacy_uptime/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap @@ -178,13 +178,13 @@ exports[`PingListExpandedRow renders link to docs if body is not recorded but it > docs External link (opens in a new tab or window) diff --git a/x-pack/plugins/uptime/public/legacy_uptime/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap b/x-pack/plugins/uptime/public/legacy_uptime/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap index 8a4e0915d4fa3..cae02bf400e2d 100644 --- a/x-pack/plugins/uptime/public/legacy_uptime/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap +++ b/x-pack/plugins/uptime/public/legacy_uptime/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap @@ -65,13 +65,13 @@ Array [ > Set tags External link (opens in a new tab or window) diff --git a/x-pack/test/functional/apps/transform/actions/reauthorizing.ts b/x-pack/test/functional/apps/transform/actions/reauthorizing.ts index f256e902eac97..878a351410396 100644 --- a/x-pack/test/functional/apps/transform/actions/reauthorizing.ts +++ b/x-pack/test/functional/apps/transform/actions/reauthorizing.ts @@ -211,7 +211,7 @@ export default function ({ getService }: FtrProviderContext) { await transform.table.assertTransformRowActionMissing(transformId, 'Reauthorize'); } else { await transform.testExecution.logTestStep('should show disabled action menu button'); - await transform.table.assertTransformRowActionsButtonEnabled(transformId, false); + await transform.table.assertTransformRowActionsEnabled(transformId, false); } await transform.table.clearSearchString(testDataList.length); }); diff --git a/x-pack/test/functional/apps/transform/creation/index_pattern/creation_index_pattern.ts b/x-pack/test/functional/apps/transform/creation/index_pattern/creation_index_pattern.ts index 9e5c1e4f1b081..a18252b47bdbe 100644 --- a/x-pack/test/functional/apps/transform/creation/index_pattern/creation_index_pattern.ts +++ b/x-pack/test/functional/apps/transform/creation/index_pattern/creation_index_pattern.ts @@ -271,7 +271,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { legend: '7 categories', colorStats: [ { color: '#000000', percentage: 20 }, - { color: '#54B399', percentage: 75 }, + { color: '#54B399', percentage: 80 }, ], }, { diff --git a/x-pack/test/functional/apps/transform/permissions/full_transform_access.ts b/x-pack/test/functional/apps/transform/permissions/full_transform_access.ts index e5e24657789a1..5cd04c4e33577 100644 --- a/x-pack/test/functional/apps/transform/permissions/full_transform_access.ts +++ b/x-pack/test/functional/apps/transform/permissions/full_transform_access.ts @@ -97,10 +97,7 @@ export default function ({ getService }: FtrProviderContext) { await transform.table.filterWithSearchString(transformConfigWithPivot.id, 1); await transform.testExecution.logTestStep('should show the actions popover'); - await transform.table.assertTransformRowActionsButtonEnabled( - transformConfigWithPivot.id, - true - ); + await transform.table.assertTransformRowActionsEnabled(transformConfigWithPivot.id, true); await transform.table.assertTransformRowActions(transformConfigWithPivot.id, false); await transform.testExecution.logTestStep('should have the edit action enabled'); diff --git a/x-pack/test/functional/apps/transform/permissions/read_transform_access.ts b/x-pack/test/functional/apps/transform/permissions/read_transform_access.ts index 02cfcfdfba003..216bb287f0e5e 100644 --- a/x-pack/test/functional/apps/transform/permissions/read_transform_access.ts +++ b/x-pack/test/functional/apps/transform/permissions/read_transform_access.ts @@ -97,10 +97,7 @@ export default function ({ getService }: FtrProviderContext) { await transform.table.filterWithSearchString(transformConfigWithPivot.id, 1); await transform.testExecution.logTestStep('should display a disabled actions popover'); - await transform.table.assertTransformRowActionsButtonEnabled( - transformConfigWithPivot.id, - false - ); + await transform.table.assertTransformRowActionsEnabled(transformConfigWithPivot.id, false); await transform.testExecution.logTestStep('should show content in the expanded table row'); await transform.table.assertTransformExpandedRow(); diff --git a/x-pack/test/functional/page_objects/lens_page.ts b/x-pack/test/functional/page_objects/lens_page.ts index 2d3766c137667..2af514b4a1fdc 100644 --- a/x-pack/test/functional/page_objects/lens_page.ts +++ b/x-pack/test/functional/page_objects/lens_page.ts @@ -1187,6 +1187,7 @@ export function LensPageProvider({ getService, getPageObjects }: FtrProviderCont async changeTableSortingBy(colIndex = 0, direction: 'none' | 'ascending' | 'descending') { const el = await this.getDatatableHeader(colIndex); + await el.moveMouseTo({ xOffset: 0, yOffset: -20 }); // Prevent the first data row's cell actions from overlapping/intercepting the header click await el.click(); let buttonEl; if (direction !== 'none') { diff --git a/x-pack/test/functional/page_objects/tag_management_page.ts b/x-pack/test/functional/page_objects/tag_management_page.ts index 30c6689d87b8f..80f64243fe31b 100644 --- a/x-pack/test/functional/page_objects/tag_management_page.ts +++ b/x-pack/test/functional/page_objects/tag_management_page.ts @@ -428,6 +428,16 @@ export class TagManagementPageObject extends FtrService { await checkbox.click(); } + /** + * Select all checkboxes + */ + async selectAllTagRows() { + const checkbox = await this.testSubjects.find( + 'tagsManagementTable table-is-ready > checkboxSelectAll' + ); + await checkbox.click(); + } + /** * Returns true if the tag bulk action menu is displayed, false otherwise. */ diff --git a/x-pack/test/functional/services/transform/transform_table.ts b/x-pack/test/functional/services/transform/transform_table.ts index 7a5f303ba155b..48110a7ec4b21 100644 --- a/x-pack/test/functional/services/transform/transform_table.ts +++ b/x-pack/test/functional/services/transform/transform_table.ts @@ -6,6 +6,7 @@ */ import expect from '@kbn/expect'; +import { asyncForEach } from '@kbn/std'; import { WebElementWrapper } from '@kbn/ftr-common-functional-ui-services'; @@ -426,19 +427,23 @@ export function TransformTableProvider({ getPageObject, getService }: FtrProvide }); } - public async assertTransformRowActionsButtonEnabled( - transformId: string, - expectedValue: boolean - ) { - const isEnabled = await testSubjects.isEnabled( - this.rowSelector(transformId, 'euiCollapsedItemActionsButton') - ); - expect(isEnabled).to.eql( - expectedValue, - `Expected transform row actions button to be '${ - expectedValue ? 'enabled' : 'disabled' - }' (got '${isEnabled ? 'enabled' : 'disabled'}')` + public async assertTransformRowActionsEnabled(transformId: string, expectedValue: boolean) { + await this.ensureTransformActionsMenuOpen(transformId); + + // Check whether all menu actions are disabled + let allDisabled = true; + const actions = await find.allByCssSelector('.euiBasicTable__collapsedAction'); + await asyncForEach(actions, async (action) => { + if (await action.isEnabled()) { + allDisabled = false; + } + }); + expect(allDisabled).to.eql( + !expectedValue, + `Expected all transform row actions to '${expectedValue ? 'not' : ''}' be disabled.` ); + + await this.ensureTransformActionsMenuClosed(); } public async assertTransformRowActions(transformId: string, isTransformRunning = false) { diff --git a/x-pack/test/functional_with_es_ssl/apps/cases/group2/upgrade.ts b/x-pack/test/functional_with_es_ssl/apps/cases/group2/upgrade.ts index ebbace48f6aad..8320ac9707e3a 100644 --- a/x-pack/test/functional_with_es_ssl/apps/cases/group2/upgrade.ts +++ b/x-pack/test/functional_with_es_ssl/apps/cases/group2/upgrade.ts @@ -340,7 +340,7 @@ export default ({ getPageObject, getService }: FtrProviderContext) => { const link = await testSubjects.find('case-table-column-external'); const upToDate = await testSubjects.find('case-table-column-external-upToDate'); - expect(await link.getVisibleText()).equal('ROC-526\n(opens in a new tab or window)'); + expect(await link.getVisibleText()).equal('ROC-526'); expect(await upToDate.getVisibleText()).equal('is up to date'); }); diff --git a/x-pack/test/saved_object_tagging/functional/tests/feature_control.ts b/x-pack/test/saved_object_tagging/functional/tests/feature_control.ts index 90b6e1d360d4e..f226423100451 100644 --- a/x-pack/test/saved_object_tagging/functional/tests/feature_control.ts +++ b/x-pack/test/saved_object_tagging/functional/tests/feature_control.ts @@ -43,6 +43,13 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { } }; + const unselectTags = async () => { + if (await tagManagementPage.isSelectionColumnDisplayed()) { + await tagManagementPage.selectAllTagRows(); + await tagManagementPage.selectAllTagRows(); + } + }; + const addFeatureControlSuite = ({ user, description, privileges }: FeatureControlUserSuite) => { const testPrefix = (allowed: boolean) => (allowed ? `can` : `can't`); @@ -69,6 +76,7 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { it(`${testPrefix(privileges.delete)} bulk delete tags`, async () => { await selectSomeTags(); expect(await tagManagementPage.isBulkActionPresent('delete')).to.be(privileges.delete); + await unselectTags(); }); it(`${testPrefix(privileges.create)} create tag`, async () => { diff --git a/yarn.lock b/yarn.lock index 70df97c2fb219..0457de5cfa53f 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1740,10 +1740,10 @@ resolved "https://registry.yarnpkg.com/@elastic/eslint-plugin-eui/-/eslint-plugin-eui-0.0.2.tgz#56b9ef03984a05cc213772ae3713ea8ef47b0314" integrity sha512-IoxURM5zraoQ7C8f+mJb9HYSENiZGgRVcG4tLQxE61yHNNRDXtGDWTZh8N1KIHcsqN1CEPETjuzBXkJYF/fDiQ== -"@elastic/eui@91.0.0-backport.0": - version "91.0.0-backport.0" - resolved "https://registry.yarnpkg.com/@elastic/eui/-/eui-91.0.0-backport.0.tgz#821306a580cc8fcf1a142106e425f3fcd1bebfbf" - integrity sha512-2T+8JiPs1Ejh2T8l7cwqv/IIlNV6I9RbXtJ60L9U4lJGtS/R8zIoikrR/2SEs8bXwyXXg4i/trhfbYbylAvZpw== +"@elastic/eui@91.3.1": + version "91.3.1" + resolved "https://registry.yarnpkg.com/@elastic/eui/-/eui-91.3.1.tgz#2289b1683f0409c043150c39f5fb7233aa7beb16" + integrity sha512-zxnhBaAsykmDqjbZ3i++CFTyv2dKZSe3UUZKSgYj5MaMnbE86uzeWGjhp3gh1b+LxJZP2672MbNZ6qxVOh1vcQ== dependencies: "@hello-pangea/dnd" "^16.3.0" "@types/lodash" "^4.14.198"