Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Unified Search] Change filter styling #200675

Closed
Show file tree
Hide file tree
Changes from 16 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@

import React, { Fragment } from 'react';
import type { Filter, BooleanRelation, DataViewBase } from '@kbn/es-query';
import { EuiTextColor } from '@elastic/eui';
import { EuiBadge, useEuiTheme } from '@elastic/eui';
import { css } from '@emotion/react';
import { FilterBadgeErrorBoundary } from './filter_badge_error_boundary';
import { FilterExpressionBadge } from './filter_badge_expression';
import { conditionCss } from './filter_badge.styles';

export interface FilterBadgeGroupProps {
filters: Filter[];
Expand All @@ -23,10 +23,15 @@ export interface FilterBadgeGroupProps {
}

const BooleanRelationDelimiter = ({ conditional }: { conditional: BooleanRelation }) => {
const { euiTheme } = useEuiTheme();
const horizontalMargin = css`
margin-inline: ${euiTheme.size.s};
`;

/**
* Spaces have been added to make the title readable.
*/
return <EuiTextColor className={conditionCss}>{` ${conditional} `}</EuiTextColor>;
return <EuiBadge color="hollow" css={horizontalMargin}>{` ${conditional} `}</EuiBadge>;
};

export function FilterBadgeGroup({
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -8,20 +8,36 @@
*/

import React from 'react';
import { EuiTextColor } from '@elastic/eui';
import { EuiTextColor, useEuiTheme } from '@elastic/eui';
import type { Filter } from '@kbn/es-query';
import { FILTERS } from '@kbn/es-query';
import { css } from '@emotion/react';
import { existsOperator, isOneOfOperator } from '../../filter_bar/filter_editor';
import { strings } from '../i18n';

const FilterValue = ({ value }: { value: string | number }) => {
const FilterValue = ({ value, operator }: { value?: string | number; operator?: string }) => {
const { euiTheme } = useEuiTheme();
const operatorStyles = css`
font-weight: ${euiTheme.font.weight.medium};
color: ${euiTheme.colors.textPrimary};
`;
const valueFontWeight = css`
font-weight: ${euiTheme.font.weight.regular};
`;

return (
<EuiTextColor
color={typeof value === 'string' ? 'success' : 'accent'}
className="globalFilterLabel__value"
>
{` ${value}`}
</EuiTextColor>
<>
{operator ? (
<EuiTextColor color="primary" css={operatorStyles} className="globalFilterLabel__value">
{` ${operator}`}
</EuiTextColor>
) : null}
{value ? (
<EuiTextColor color="success" css={valueFontWeight} className="globalFilterLabel__value">
{` ${value}`}
</EuiTextColor>
) : null}
</>
);
};

Expand All @@ -32,16 +48,31 @@ const FilterField = ({
filter: Filter;
fieldLabel?: string | undefined;
}) => {
const { euiTheme } = useEuiTheme();
const fontWeight = css`
font-weight: ${euiTheme.font.weight.medium};
`;

return (
<>
<Prefix prefix={filter.meta.negate} />
{fieldLabel || filter.meta.key}:
<EuiTextColor css={fontWeight}>{fieldLabel || filter.meta.key}:</EuiTextColor>
</>
);
};

const Prefix = ({ prefix }: { prefix?: boolean }) =>
prefix ? <EuiTextColor color="danger">{strings.getNotLabel()}</EuiTextColor> : null;
const Prefix = ({ prefix }: { prefix?: boolean }) => {
const { euiTheme } = useEuiTheme();
const fontWeight = css`
font-weight: ${euiTheme.font.weight.medium};
`;

return prefix ? (
<EuiTextColor color="danger" css={fontWeight}>
{strings.getNotLabel()}
</EuiTextColor>
) : null;
};

export interface FilterContentProps {
filter: Filter;
Expand All @@ -65,14 +96,14 @@ export function FilterContent({ filter, valueLabel, fieldLabel, hideAlias }: Fil
return (
<>
<FilterField filter={filter} fieldLabel={fieldLabel} />
<FilterValue value={`${existsOperator.message}`} />
<FilterValue operator={existsOperator.message} />
</>
);
case FILTERS.PHRASES:
return (
<>
<FilterField filter={filter} fieldLabel={fieldLabel} />
<FilterValue value={`${isOneOfOperator.message} ${valueLabel}`} />
<FilterValue operator={isOneOfOperator.message} value={valueLabel} />
</>
);
case FILTERS.QUERY_STRING:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -408,18 +408,21 @@ class FilterEditorComponent extends Component<FilterEditorProps, State> {
hasEmptyLabelSpace={true}
className={cx(filterBadgeStyle, filterPreviewLabelStyle)}
label={
<strong>
<FormattedMessage
id="unifiedSearch.filter.filterBar.preview"
defaultMessage="{icon} Preview"
values={{
icon: <EuiIcon type="inspect" size="s" />,
}}
/>
</strong>
<>
<EuiSpacer size="m" />
<strong>
<FormattedMessage
id="unifiedSearch.filter.filterBar.preview"
defaultMessage="{icon} Preview"
values={{
icon: <EuiIcon type="inspect" size="s" />,
}}
/>
</strong>
kowalczyk-krzysztof marked this conversation as resolved.
Show resolved Hide resolved
</>
}
>
<EuiText size="xs" data-test-subj="filter-preview" css={{ overflowWrap: 'break-word' }}>
<EuiText size="s" data-test-subj="filter-preview" css={{ overflowWrap: 'break-word' }}>
<FilterBadgeGroup
filters={[localFilter]}
dataViews={this.state.indexPatterns}
Expand Down
8 changes: 4 additions & 4 deletions test/functional/apps/context/_filters.ts
Original file line number Diff line number Diff line change
Expand Up @@ -176,7 +176,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
await filterBar.clickEditFilterById('0');

expect(await filterBar.getFilterEditorPreview()).to.equal(
'extension: png OR bytes: 1,000B to 2KB'
'extension: png\nOR\nbytes: 1,000B to 2KB'
);
});

Expand All @@ -196,7 +196,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
await filterBar.clickEditFilterById('0');

expect(await filterBar.getFilterEditorPreview()).to.equal(
'extension: is one of png, jpeg AND bytes: 1,000B to 2KB'
'extension: is one of png, jpeg\nAND\nbytes: 1,000B to 2KB'
);
});

Expand All @@ -222,7 +222,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
await filterBar.clickEditFilterById('0');

expect(await filterBar.getFilterEditorPreview()).to.equal(
'(NOT clientip: exists OR extension: is one of png, jpeg) AND bytes: 1,000B to 2KB'
'(NOT clientip: exists\nOR\nextension: is one of png, jpeg)\nAND\nbytes: 1,000B to 2KB'
);
});

Expand Down Expand Up @@ -252,7 +252,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
await testSubjects.clickWhenNotDisabled('saveFilter');

const filterLabelUpdated = await filterBar.getFiltersLabel();
expect(filterLabelUpdated[0]).to.be('NOT extension: png AND extension: jpeg');
expect(filterLabelUpdated[0]).to.be('NOT extension: png\nAND\nextension: jpeg');
});
});
}
4 changes: 2 additions & 2 deletions x-pack/test/functional/apps/infra/hosts_view.ts
Original file line number Diff line number Diff line change
Expand Up @@ -607,8 +607,8 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => {
const hostRowsAfterFilter = await pageObjects.infraHostsView.getHostsTableData();
expect(hostRowsAfterFilter.length).to.equal(2);

const deleteFilterButton = await find.byCssSelector(
`[title="Delete host.name: host-1 OR host.name: host-2"]`
const deleteFilterButton = await find.byXPath(
`//button[normalize-space(@title) = "Delete host.name: host-1 OR host.name: host-2"]`
);
await deleteFilterButton.click();
await pageObjects.header.waitUntilLoadingHasFinished();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -176,7 +176,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
await filterBar.clickEditFilterById('0');

expect(await filterBar.getFilterEditorPreview()).to.equal(
'extension: png OR bytes: 1,000B to 2KB'
'extension: png\nOR\nbytes: 1,000B to 2KB'
);
});

Expand All @@ -196,7 +196,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
await filterBar.clickEditFilterById('0');

expect(await filterBar.getFilterEditorPreview()).to.equal(
'extension: is one of png, jpeg AND bytes: 1,000B to 2KB'
'extension: is one of png, jpeg\nAND\nbytes: 1,000B to 2KB'
);
});

Expand All @@ -222,7 +222,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
await filterBar.clickEditFilterById('0');

expect(await filterBar.getFilterEditorPreview()).to.equal(
'(NOT clientip: exists OR extension: is one of png, jpeg) AND bytes: 1,000B to 2KB'
'(NOT clientip: exists\nOR\nextension: is one of png, jpeg)\nAND\nbytes: 1,000B to 2KB'
);
});

Expand Down Expand Up @@ -252,7 +252,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
await testSubjects.clickWhenNotDisabled('saveFilter');

const filterLabelUpdated = await filterBar.getFiltersLabel();
expect(filterLabelUpdated[0]).to.be('NOT extension: png AND extension: jpeg');
expect(filterLabelUpdated[0]).to.be('NOT extension: png\nAND\nextension: jpeg');
});
});
}