Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[VisBuilder ] Fix filter and query bugs in the saved objects (#6460)
Browse files Browse the repository at this point in the history
* [VisBuilder] Fix filter and query bugs

In this PR:
add filter and query in vb
clean filterManager when start vb
add opensearch_dashboards_context to embeddable. This can add filter and query in the expression.

Issue Resolve
#5643
#5644
#5646
#6512

Signed-off-by: Anan Zhuang <[email protected]>

---------

Signed-off-by: Anan Zhuang <[email protected]>
Co-authored-by: Miki <[email protected]>
(cherry picked from commit 0ac9db3)
Signed-off-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

# Conflicts:
#	CHANGELOG.md
github-actions[bot] committed Apr 30, 2024
1 parent fef867f commit ce26f7b
Showing 7 changed files with 58 additions and 11 deletions.
Original file line number Diff line number Diff line change
@@ -95,7 +95,10 @@ describe('getOnSave', () => {
},
],
},
"searchSourceFields": Object {},
"searchSourceFields": Object {
"filter": null,
"query": null,
},
"styleState": "",
"title": "new title",
"version": 0,
Original file line number Diff line number Diff line change
@@ -172,7 +172,7 @@ export const getOnSave = (
returnToOrigin: boolean;
newDescription?: string;
}) => {
const { embeddable, toastNotifications, application, history } = services;
const { data, embeddable, toastNotifications, application, history } = services;
const stateTransfer = embeddable.getStateTransfer();

if (!savedVisBuilderVis) {
@@ -183,6 +183,9 @@ export const getOnSave = (
savedVisBuilderVis.title = newTitle;
savedVisBuilderVis.description = newDescription;
savedVisBuilderVis.copyOnSave = newCopyOnSave;
const searchSourceInstance = savedVisBuilderVis.searchSourceFields;
searchSourceInstance.query = data.query.queryString.getQuery() || null;
searchSourceInstance.filter = data.query.filterManager.getFilters() || null;
const newlyCreated = !savedVisBuilderVis.id || savedVisBuilderVis.copyOnSave;

try {
Original file line number Diff line number Diff line change
@@ -35,6 +35,7 @@ export const useSavedVisBuilderVis = (visualizationIdFromUrl: string | undefined
const {
application: { navigateToApp },
chrome,
data,
history,
http: { basePath },
toastNotifications,
@@ -61,6 +62,17 @@ export const useSavedVisBuilderVis = (visualizationIdFromUrl: string | undefined
const { title, state } = getStateFromSavedObject(savedVisBuilderVis);
chrome.setBreadcrumbs(getEditBreadcrumbs(title, navigateToApp));
chrome.docTitle.change(title);
// sync initial app filters from savedObject to filterManager
const filters = savedVisBuilderVis.searchSourceFields.filter;

Check warning on line 66 in src/plugins/vis_builder/public/application/utils/use/use_saved_vis_builder_vis.ts

Codecov / codecov/patch

src/plugins/vis_builder/public/application/utils/use/use_saved_vis_builder_vis.ts#L66

Added line #L66 was not covered by tests
const query =
savedVisBuilderVis.searchSourceFields.query || data.query.queryString.getDefaultQuery();
const actualFilters = [];

Check warning on line 69 in src/plugins/vis_builder/public/application/utils/use/use_saved_vis_builder_vis.ts

Codecov / codecov/patch

src/plugins/vis_builder/public/application/utils/use/use_saved_vis_builder_vis.ts#L69

Added line #L69 was not covered by tests
const tempFilters = typeof filters === 'function' ? filters() : filters;
(Array.isArray(tempFilters) ? tempFilters : [tempFilters]).forEach((filter) => {
if (filter) actualFilters.push(filter);
});
data.query.filterManager.setAppFilters(actualFilters);
data.query.queryString.setQuery(query);

Check warning on line 75 in src/plugins/vis_builder/public/application/utils/use/use_saved_vis_builder_vis.ts

Codecov / codecov/patch

src/plugins/vis_builder/public/application/utils/use/use_saved_vis_builder_vis.ts#L74-L75

Added lines #L74 - L75 were not covered by tests

dispatch(setUIStateState(state.ui));
dispatch(setStyleState(state.style));
Original file line number Diff line number Diff line change
@@ -35,7 +35,7 @@ import {
getTypeService,
getUIActions,
} from '../plugin_services';
import { PersistedState } from '../../../visualizations/public';
import { PersistedState, prepareJson } from '../../../visualizations/public';
import { VisBuilderSavedVis } from '../saved_visualizations/transforms';
import { handleVisEvent } from '../application/utils/handle_vis_event';
import { VisBuilderEmbeddableFactoryDeps } from './vis_builder_embeddable_factory';
@@ -246,6 +246,28 @@ export class VisBuilderEmbeddable extends Embeddable<VisBuilderInput, VisBuilder
this.autoRefreshFetchSubscription.unsubscribe();
}

private async updateExpression() {
// Construct the initial part of the pipeline with context management.
let pipeline = `opensearchDashboards | opensearch_dashboards_context `;

Check warning on line 251 in src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx

Codecov / codecov/patch

src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx#L251

Added line #L251 was not covered by tests

// Access the query and filters from savedObject if available.
const query = this.savedVis?.searchSourceFields?.query;
const filters = this.savedVis?.searchSourceFields?.filter;

Check warning on line 255 in src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx

Codecov / codecov/patch

src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx#L254-L255

Added lines #L254 - L255 were not covered by tests

// Append query and filters to the pipeline string if they exist.
if (query) {
pipeline += prepareJson('query', query);

Check warning on line 259 in src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx

Codecov / codecov/patch

src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx#L259

Added line #L259 was not covered by tests
}
if (filters) {
pipeline += prepareJson('filters', filters);

Check warning on line 262 in src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx

Codecov / codecov/patch

src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx#L262

Added line #L262 was not covered by tests
}

const currentExpression = (await this.getExpression()) ?? '';

// Replace 'opensearchDashboards' with the constructed pipeline in the existing expression.
return currentExpression.replace('opensearchDashboards', pipeline);

Check warning on line 268 in src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx

Codecov / codecov/patch

src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx#L268

Added line #L268 was not covered by tests
}

private async updateHandler() {
const expressionParams: IExpressionLoaderParams = {
searchContext: {
@@ -261,6 +283,8 @@ export class VisBuilderEmbeddable extends Embeddable<VisBuilderInput, VisBuilder
this.abortController = new AbortController();
const abortController = this.abortController;

this.expression = await this.updateExpression();

Check warning on line 286 in src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx

Codecov / codecov/patch

src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx#L286

Added line #L286 was not covered by tests

if (this.handler && !abortController.signal.aborted) {
this.handler.update(this.expression, expressionParams);
}
@@ -296,12 +320,8 @@ export class VisBuilderEmbeddable extends Embeddable<VisBuilderInput, VisBuilder
dirty = true;
}

if (dirty) {
this.expression = (await this.getExpression()) ?? '';

if (this.handler) {
this.updateHandler();
}
if (this.handler && dirty) {
this.updateHandler();

Check warning on line 324 in src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx

Codecov / codecov/patch

src/plugins/vis_builder/public/embeddable/vis_builder_embeddable.tsx#L324

Added line #L324 was not covered by tests
}
}

4 changes: 4 additions & 0 deletions src/plugins/vis_builder/public/plugin.ts
Original file line number Diff line number Diff line change
@@ -125,6 +125,10 @@ export class VisBuilderPlugin

// make sure the index pattern list is up to date
pluginsStart.data.indexPatterns.clearCache();
// make sure the filterManager is refreshed
const filters = pluginsStart.data.query.filterManager.getFilters();
const pinFilters = filters.filter(opensearchFilters.isFilterPinned);

Check warning on line 130 in src/plugins/vis_builder/public/plugin.ts

Codecov / codecov/patch

src/plugins/vis_builder/public/plugin.ts#L129-L130

Added lines #L129 - L130 were not covered by tests
pluginsStart.data.query.filterManager.setFilters(pinFilters ? pinFilters : []);
// make sure a default index pattern exists
// if not, the page will be redirected to management and visualize won't be rendered
// TODO: Add the redirect
Original file line number Diff line number Diff line change
@@ -33,14 +33,17 @@ export const saveStateToSavedObject = (
};

export interface VisBuilderSavedVis
extends Pick<VisBuilderSavedObjectAttributes, 'id' | 'title' | 'description'> {
extends Pick<
VisBuilderSavedObjectAttributes,
'id' | 'title' | 'description' | 'searchSourceFields'
> {
state: RenderState;
}

export const getStateFromSavedObject = (
obj: VisBuilderSavedObjectAttributes
): VisBuilderSavedVis => {
const { id, title, description } = obj;
const { id, title, description, searchSourceFields } = obj;
const styleState = JSON.parse(obj.styleState || '{}');
const uiState = JSON.parse(obj.uiState || '{}');
const vizStateWithoutIndex = JSON.parse(obj.visualizationState || '');
@@ -74,6 +77,7 @@ export const getStateFromSavedObject = (
id,
title,
description,
searchSourceFields,
state: {
visualization: visualizationState,
style: styleState,
1 change: 1 addition & 0 deletions src/plugins/visualizations/public/index.ts
Original file line number Diff line number Diff line change
@@ -77,3 +77,4 @@ export { ExprVisAPIEvents } from './expressions/vis';
export { VisualizationListItem } from './vis_types/vis_type_alias_registry';
export { VISUALIZE_ENABLE_LABS_SETTING } from '../common/constants';
export { createSavedVisLoader } from './saved_visualizations';
export { prepareJson } from './legacy/build_pipeline';

0 comments on commit ce26f7b

Please sign in to comment.