Skip to content

Commit

Permalink
[RAM} Add refine search prompt to rule execution log (#128982) (#129500)
Browse files Browse the repository at this point in the history
* Refine search prompt

* Add refine prompt to error log table

Co-authored-by: Kibana Machine <[email protected]>
(cherry picked from commit 2fd6772)

Co-authored-by: Jiawei Wu <[email protected]>
  • Loading branch information
kibanamachine and JiaweiWu authored Apr 5, 2022
1 parent 835b61d commit 1931373
Show file tree
Hide file tree
Showing 5 changed files with 148 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import { useKibana } from '../../../../common/lib/kibana';

import { EuiSuperDatePicker } from '@elastic/eui';
import { Rule } from '../../../../types';
import { RefineSearchPrompt } from '../refine_search_prompt';
import { RuleErrorLog } from './rule_error_log';

const useKibanaMock = useKibana as jest.Mocked<typeof useKibana>;
Expand Down Expand Up @@ -309,4 +310,43 @@ describe('rule_error_log', () => {

nowMock.mockRestore();
});

it('does not show the refine search prompt normally', async () => {
const wrapper = mountWithIntl(
<RuleErrorLog
rule={mockRule}
loadExecutionLogAggregations={loadExecutionLogAggregationsMock}
/>
);

await act(async () => {
await nextTick();
wrapper.update();
});

expect(wrapper.find(RefineSearchPrompt).text()).toBeFalsy();
});

it('shows the refine search prompt when our queries return too much data', async () => {
loadExecutionLogAggregationsMock.mockResolvedValue({
...mockLogResponse,
totalErrors: 1000,
});

const wrapper = mountWithIntl(
<RuleErrorLog
rule={mockRule}
loadExecutionLogAggregations={loadExecutionLogAggregationsMock}
/>
);

await act(async () => {
await nextTick();
wrapper.update();
});

expect(wrapper.find(RefineSearchPrompt).text()).toEqual(
'These are the first 1000 matching your search, refine your search to see others. Back to top.'
);
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import {
} from '@elastic/eui';
import { useKibana } from '../../../../common/lib/kibana';

import { RefineSearchPrompt } from '../refine_search_prompt';
import { LoadExecutionLogAggregationsProps } from '../../../lib/rule_api';
import { Rule } from '../../../../types';
import { IExecutionErrors } from '../../../../../../alerting/common';
Expand Down Expand Up @@ -256,6 +257,10 @@ export const RuleErrorLog = (props: RuleErrorLogProps) => {
}
}}
/>
<RefineSearchPrompt
documentSize={pagination.totalItemCount}
backToTopAnchor="rule_error_log_list"
/>
</div>
);
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import { useKibana } from '../../../../common/lib/kibana';
import { EuiSuperDatePicker, EuiDataGrid } from '@elastic/eui';
import { RuleEventLogListStatusFilter } from './rule_event_log_list_status_filter';
import { RuleEventLogList } from './rule_event_log_list';
import { RefineSearchPrompt } from '../refine_search_prompt';
import { RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS } from '../../../constants';
import { Rule } from '../../../../types';

Expand Down Expand Up @@ -501,4 +502,43 @@ describe('rule_event_log_list', () => {
)
).toEqual([...RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS, 'num_active_alerts']);
});

it('does not show the refine search prompt normally', async () => {
const wrapper = mountWithIntl(
<RuleEventLogList
rule={mockRule}
loadExecutionLogAggregations={loadExecutionLogAggregationsMock}
/>
);

await act(async () => {
await nextTick();
wrapper.update();
});

expect(wrapper.find(RefineSearchPrompt).text()).toBeFalsy();
});

it('shows the refine search prompt when our queries return too much data', async () => {
loadExecutionLogAggregationsMock.mockResolvedValue({
...mockLogResponse,
total: 1000,
});

const wrapper = mountWithIntl(
<RuleEventLogList
rule={mockRule}
loadExecutionLogAggregations={loadExecutionLogAggregationsMock}
/>
);

await act(async () => {
await nextTick();
wrapper.update();
});

expect(wrapper.find(RefineSearchPrompt).text()).toEqual(
'These are the first 1000 matching your search, refine your search to see others. Back to top.'
);
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import { RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS } from '../../../constan
import { RuleEventLogListStatusFilter } from './rule_event_log_list_status_filter';
import { RuleEventLogListCellRenderer, ColumnId } from './rule_event_log_list_cell_renderer';

import { RefineSearchPrompt } from '../refine_search_prompt';
import { LoadExecutionLogAggregationsProps } from '../../../lib/rule_api';
import { Rule } from '../../../../types';
import {
Expand Down Expand Up @@ -459,6 +460,10 @@ export const RuleEventLogList = (props: RuleEventLogListProps) => {
sorting={sortingProps}
pagination={paginationProps}
/>
<RefineSearchPrompt
documentSize={pagination.totalItemCount}
backToTopAnchor="rule_event_log_list"
/>
</div>
);
};
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
/*
* 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 React, { useMemo } from 'react';
import { EuiLink, EuiText, useEuiTheme } from '@elastic/eui';
import { FormattedMessage } from '@kbn/i18n-react';

interface RefineSearchFooterProps {
documentSize: number;
visibleDocumentSize?: number;
backToTopAnchor: string;
}

const DEFAULT_VISIBLE_THRESHOLD = 500;

export const RefineSearchPrompt = (props: RefineSearchFooterProps) => {
const {
documentSize = 0,
visibleDocumentSize = DEFAULT_VISIBLE_THRESHOLD,
backToTopAnchor,
} = props;

const { euiTheme } = useEuiTheme();

const textStyles = useMemo(
() => ({
backgroundColor: euiTheme.colors.lightestShade,
padding: `${euiTheme.size.m} ${euiTheme.size.base}`,
marginTop: `${euiTheme.size.xs}`,
}),
[euiTheme]
);

if (documentSize < visibleDocumentSize) {
return null;
}

return (
<EuiText style={textStyles} textAlign="center" size="s">
<FormattedMessage
id="xpack.triggersActionsUI.sections.ruleDetails.refineSearchPrompt.prompt"
defaultMessage="These are the first {documentSize} matching your search, refine your search to see others."
values={{ documentSize }}
/>
&nbsp;
<EuiLink href={`#${backToTopAnchor}`}>
<FormattedMessage
id="xpack.triggersActionsUI.sections.ruleDetails.refineSearchPrompt.backToTop"
defaultMessage="Back to top."
/>
</EuiLink>
</EuiText>
);
};

0 comments on commit 1931373

Please sign in to comment.