diff --git a/src/plugins/data/public/ui/filter_bar/filter_item.tsx b/src/plugins/data/public/ui/filter_bar/filter_item.tsx index 1c64ec7436ac4..788663041fd03 100644 --- a/src/plugins/data/public/ui/filter_bar/filter_item.tsx +++ b/src/plugins/data/public/ui/filter_bar/filter_item.tsx @@ -20,7 +20,7 @@ import { EuiContextMenu, EuiPopover } from '@elastic/eui'; import { InjectedIntl, injectI18n } from '@kbn/i18n/react'; import classNames from 'classnames'; -import React, { Component } from 'react'; +import React, { Component, MouseEvent } from 'react'; import { IUiSettingsClient } from 'src/core/public'; import { FilterEditor } from './filter_editor'; import { FilterView } from './filter_view'; @@ -46,6 +46,13 @@ class FilterItemUI extends Component { isPopoverOpen: false, }; + private handleBadgeClick = (e: MouseEvent) => { + if (e.shiftKey) { + this.onToggleDisabled(); + } else { + this.togglePopover(); + } + }; public render() { const { filter, id } = this.props; const { negate, disabled } = filter.meta; @@ -73,7 +80,7 @@ class FilterItemUI extends Component { valueLabel={valueLabel} className={classes} iconOnClick={() => this.props.onRemove()} - onClick={this.togglePopover} + onClick={this.handleBadgeClick} data-test-subj={`filter ${dataTestSubjDisabled} ${dataTestSubjKey} ${dataTestSubjValue}`} /> );