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

Revert "[Backport 2.x] [BUG][Data Explorer][Discover] Automatically load solo added default index pattern" #5199

Merged
merged 1 commit into from
Oct 4, 2023
Merged
Show file tree
Hide file tree
Changes from all 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
8 changes: 1 addition & 7 deletions src/plugins/data_explorer/public/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,4 @@ export function plugin() {
}
export { DataExplorerPluginSetup, DataExplorerPluginStart, DataExplorerServices } from './types';
export { ViewProps, ViewDefinition, DefaultViewState } from './services/view_service';
export {
RootState,
Store,
useTypedSelector,
useTypedDispatch,
setIndexPattern,
} from './utils/state_management';
export { RootState, useTypedSelector, useTypedDispatch } from './utils/state_management';
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,7 @@
*/

import { TypedUseSelectorHook } from 'react-redux';
import {
RootState,
Store as StoreType,
setIndexPattern as updateIndexPattern,
useTypedDispatch,
useTypedSelector,
} from '../../../../../data_explorer/public';
import { RootState, useTypedDispatch, useTypedSelector } from '../../../../../data_explorer/public';
import { DiscoverState } from './discover_slice';

export * from './discover_slice';
Expand All @@ -21,4 +15,3 @@ export interface DiscoverRootState extends RootState {

export const useSelector: TypedUseSelectorHook<DiscoverRootState> = useTypedSelector;
export const useDispatch = useTypedDispatch;
export { StoreType, updateIndexPattern };
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ export const DiscoverTable = ({ history }: Props) => {
query: { filterManager },
},
} = services;
const { data$, refetch$, indexPattern, savedSearch } = useDiscoverContext();
const { data$, refetch$, indexPattern } = useDiscoverContext();
const [fetchState, setFetchState] = useState<SearchData>({
status: data$.getValue().status,
rows: [],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,72 +6,46 @@
import { useEffect, useState } from 'react';
import { i18n } from '@osd/i18n';
import { IndexPattern } from '../../../../../data/public';
import { useSelector, updateIndexPattern, StoreType } from '../../utils/state_management';
import { useSelector } from '../../utils/state_management';
import { DiscoverServices } from '../../../build_services';
import { getIndexPatternId } from '../../helpers/get_index_pattern_id';

/**
* Custom hook to fetch and manage the index pattern based on the provided services.
*
* This hook does the following:
* 1. Check if there's an `indexPatternId` from the state.
* 2. If not, fetch a list of index patterns, determine the default, and update the store with it.
* 3. Once an `indexPatternId` is determined (either from the state or by fetching the default),
* it fetches the details of the index pattern.
* 4. If there's any error fetching the index pattern details, a warning notification is shown.
*
* @param services - The services needed to fetch the index patterns and show notifications.
* @param store - The redux store in data_explorer to dispatch actions.
* @returns - The fetched index pattern.
*/
export const useIndexPattern = (services: DiscoverServices, store: StoreType) => {
const indexPatternIdFromState = useSelector((state) => state.metadata.indexPattern);
export const useIndexPattern = (services: DiscoverServices) => {
const indexPatternId = useSelector((state) => state.metadata.indexPattern);
const [indexPattern, setIndexPattern] = useState<IndexPattern | undefined>(undefined);
const { data, toastNotifications, uiSettings: config } = services;
const { data, toastNotifications } = services;

useEffect(() => {
let isMounted = true;
if (!indexPatternId) return;
const indexPatternMissingWarning = i18n.translate(
'discover.valueIsNotConfiguredIndexPatternIDWarningTitle',
{
defaultMessage: '{id} is not a configured index pattern ID',
values: {
id: `"${indexPatternId}"`,
},
}
);

const fetchIndexPatternDetails = (id: string) => {
data.indexPatterns
.get(id)
.then((result) => {
if (isMounted) {
setIndexPattern(result);
}
})
.catch(() => {
if (isMounted) {
const indexPatternMissingWarning = i18n.translate(
'discover.valueIsNotConfiguredIndexPatternIDWarningTitle',
{
defaultMessage: '{id} is not a configured index pattern ID',
values: {
id: `"${id}"`,
},
}
);
toastNotifications.addDanger({
title: indexPatternMissingWarning,
});
}
});
};

if (!indexPatternIdFromState) {
data.indexPatterns.getCache().then((indexPatternList) => {
const newId = getIndexPatternId('', indexPatternList, config.get('defaultIndex'));
store!.dispatch(updateIndexPattern(newId));
fetchIndexPatternDetails(newId);
data.indexPatterns
.get(indexPatternId)
.then((result) => {
if (isMounted) {
setIndexPattern(result);
}
})
.catch(() => {
if (isMounted) {
toastNotifications.addDanger({
title: indexPatternMissingWarning,
});
}
});
} else {
fetchIndexPatternDetails(indexPatternIdFromState);
}

return () => {
isMounted = false;
};
}, [indexPatternIdFromState, data.indexPatterns, toastNotifications, config, store]);
}, [indexPatternId, data.indexPatterns, toastNotifications]);

return indexPattern;
};
Original file line number Diff line number Diff line change
Expand Up @@ -69,8 +69,8 @@ export type RefetchSubject = Subject<SearchRefetch>;
export const useSearch = (services: DiscoverServices) => {
const [savedSearch, setSavedSearch] = useState<SavedSearch | undefined>(undefined);
const { savedSearch: savedSearchId, sort, interval } = useSelector((state) => state.discover);
const { data, filterManager, getSavedSearchById, core, toastNotifications, store } = services;
const indexPattern = useIndexPattern(services, store);
const indexPattern = useIndexPattern(services);
const { data, filterManager, getSavedSearchById, core, toastNotifications } = services;
const timefilter = data.query.timefilter.timefilter;
const fetchStateRef = useRef<{
abortController: AbortController | undefined;
Expand Down
Loading