Skip to content

Commit

Permalink
fix(D&D): Handles topnav state update
Browse files Browse the repository at this point in the history
Signed-off-by: Ashwin Pc <[email protected]>
  • Loading branch information
ashwin-pc committed Jul 18, 2022
1 parent e06dbd1 commit b03fe59
Show file tree
Hide file tree
Showing 5 changed files with 26 additions and 61 deletions.
15 changes: 4 additions & 11 deletions src/plugins/wizard/public/application/components/top_nav.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,8 @@ import { WizardServices } from '../../types';

import './top_nav.scss';
import { useIndexPattern } from '../utils/use';
import { useTypedSelector, useTypedDispatch } from '../utils/state_management';
import { useTypedSelector } from '../utils/state_management';
import { useSavedWizardVis } from '../utils/use/use_saved_wizard_vis';
import { setTopNav } from '../utils/state_management/metadata_slice';

export const TopNav = () => {
// id will only be set for the edit route
Expand All @@ -27,7 +26,6 @@ export const TopNav = () => {
},
} = services;
const rootState = useTypedSelector((state) => state);
const dispatch = useTypedDispatch();
const hasUnappliedChanges = useTypedSelector(
(state) => !!state.visualization.activeVisualization?.draftAgg
);
Expand Down Expand Up @@ -60,15 +58,10 @@ export const TopNav = () => {
appName={PLUGIN_ID}
config={config}
setMenuMountPoint={setHeaderActionMenu}
showSearchBar={true}
useDefaultBehaviors={true}
screenTitle="Test"
indexPatterns={indexPattern ? [indexPattern] : []}
onQuerySubmit={(payload, isUpdate) => {
if (isUpdate) {
dispatch(setTopNav(payload));
}
}}
showSearchBar
showSaveQuery
useDefaultBehaviors
/>
</div>
);
Expand Down
29 changes: 22 additions & 7 deletions src/plugins/wizard/public/application/components/workspace.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ import {
EuiPanel,
EuiPopover,
} from '@elastic/eui';
import React, { FC, useState, useMemo, useEffect, Fragment } from 'react';
import React, { FC, useState, useMemo, useEffect, useLayoutEffect } from 'react';
import { useOpenSearchDashboards } from '../../../../opensearch_dashboards_react/public';
import { IExpressionLoaderParams } from '../../../../expressions/public';
import { WizardServices } from '../../types';
Expand All @@ -33,10 +33,16 @@ export const Workspace: FC = ({ children }) => {
services: {
expressions: { ReactExpressionRenderer },
notifications: { toasts },
data,
},
} = useOpenSearchDashboards<WizardServices>();
const { toExpression, ui } = useVisualizationType();
const [expression, setExpression] = useState<string>();
const [searchContext, setSearchContext] = useState<IExpressionLoaderParams['searchContext']>({
query: data.query.queryString.getQuery(),
filters: data.query.filterManager.getFilters(),
timeRange: data.query.timefilter.timefilter.getTime(),
});
const rootState = useTypedSelector((state) => state);

useEffect(() => {
Expand All @@ -58,10 +64,19 @@ export const Workspace: FC = ({ children }) => {
loadExpression();
}, [rootState, toExpression, toasts, ui.containerConfig.data.schemas]);

const searchContext: IExpressionLoaderParams['searchContext'] = {
query: rootState.metadata.query,
timeRange: rootState.metadata.dateRange,
};
useLayoutEffect(() => {
const subscription = data.query.state$.subscribe(({ state }) => {
setSearchContext({
query: state.query,
timeRange: state.time,
filters: state.filters,
});
});

return () => {
subscription.unsubscribe();
};
}, [data.query.state$]);

return (
<section className="wizWorkspace">
Expand All @@ -78,7 +93,7 @@ export const Workspace: FC = ({ children }) => {
<EuiEmptyPrompt
title={<h2>Drop some fields here to start</h2>}
body={
<Fragment>
<>
<p>Drag a field directly to the canvas or axis to generate a visualization.</p>
<span className="wizWorkspace__container">
<EuiIcon className="wizWorkspace__fieldSvg" type={fields_bg} size="original" />
Expand All @@ -88,7 +103,7 @@ export const Workspace: FC = ({ children }) => {
size="original"
/>
</span>
</Fragment>
</>
}
/>
</EuiFlexItem>
Expand Down

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -7,19 +7,16 @@ import { PreloadedState } from '@reduxjs/toolkit';
import { WizardServices } from '../../..';
import { getPreloadedState as getPreloadedStyleState } from './style_slice';
import { getPreloadedState as getPreloadedVisualizationState } from './visualization_slice';
import { getPreloadedState as getPreloadedMetadataState } from './metadata_slice';
import { RootState } from './store';

export const getPreloadedState = async (
services: WizardServices
): Promise<PreloadedState<RootState>> => {
const styleState = await getPreloadedStyleState(services);
const visualizationState = await getPreloadedVisualizationState(services);
const metadataState = await getPreloadedMetadataState(services);

return {
style: styleState,
visualization: visualizationState,
metadata: metadataState,
};
};
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,12 @@
import { combineReducers, configureStore, PreloadedState } from '@reduxjs/toolkit';
import { reducer as styleReducer } from './style_slice';
import { reducer as visualizationReducer } from './visualization_slice';
import { reducer as metadataReducer } from './metadata_slice';
import { WizardServices } from '../../..';
import { getPreloadedState } from './preload';

const rootReducer = combineReducers({
style: styleReducer,
visualization: visualizationReducer,
metadata: metadataReducer,
});

export const configurePreloadedStore = (preloadedState: PreloadedState<RootState>) => {
Expand Down

0 comments on commit b03fe59

Please sign in to comment.