From d1bca3353a71a0c8acef9842e79dbedba4399c74 Mon Sep 17 00:00:00 2001 From: "opensearch-trigger-bot[bot]" <98922864+opensearch-trigger-bot[bot]@users.noreply.github.com> Date: Tue, 3 Oct 2023 15:39:24 -0700 Subject: [PATCH] [BUG][Data Explorer][Discover] Automatically load solo added default index pattern (#5171) (#5189) * [BUG][Data Explorer][Discover] Automatically load solo added default index pattern This fix ensures that when add a default index pattern, Discover will automatically select and load its details. Issue Resolve https://github.com/opensearch-project/OpenSearch-Dashboards/issues/5128 --------- Signed-off-by: ananzh (cherry picked from commit 9601c6c979ac3bac9ddbd9bcee9827b7d1b2cf78) Signed-off-by: github-actions[bot] --- src/plugins/data_explorer/public/index.ts | 8 +- .../utils/state_management/index.ts | 9 +- .../view_components/canvas/discover_table.tsx | 2 +- .../utils/use_index_pattern.ts | 82 ++++++++++++------- .../view_components/utils/use_search.ts | 4 +- 5 files changed, 72 insertions(+), 33 deletions(-) diff --git a/src/plugins/data_explorer/public/index.ts b/src/plugins/data_explorer/public/index.ts index 635a0ec285db..cb33d2b7d90c 100644 --- a/src/plugins/data_explorer/public/index.ts +++ b/src/plugins/data_explorer/public/index.ts @@ -14,4 +14,10 @@ export function plugin() { } export { DataExplorerPluginSetup, DataExplorerPluginStart, DataExplorerServices } from './types'; export { ViewProps, ViewDefinition, DefaultViewState } from './services/view_service'; -export { RootState, useTypedSelector, useTypedDispatch } from './utils/state_management'; +export { + RootState, + Store, + useTypedSelector, + useTypedDispatch, + setIndexPattern, +} from './utils/state_management'; diff --git a/src/plugins/discover/public/application/utils/state_management/index.ts b/src/plugins/discover/public/application/utils/state_management/index.ts index d72cc772e6c4..9e0d5bc64ffd 100644 --- a/src/plugins/discover/public/application/utils/state_management/index.ts +++ b/src/plugins/discover/public/application/utils/state_management/index.ts @@ -4,7 +4,13 @@ */ import { TypedUseSelectorHook } from 'react-redux'; -import { RootState, useTypedDispatch, useTypedSelector } from '../../../../../data_explorer/public'; +import { + RootState, + Store as StoreType, + setIndexPattern as updateIndexPattern, + useTypedDispatch, + useTypedSelector, +} from '../../../../../data_explorer/public'; import { DiscoverState } from './discover_slice'; export * from './discover_slice'; @@ -15,3 +21,4 @@ export interface DiscoverRootState extends RootState { export const useSelector: TypedUseSelectorHook = useTypedSelector; export const useDispatch = useTypedDispatch; +export { StoreType, updateIndexPattern }; diff --git a/src/plugins/discover/public/application/view_components/canvas/discover_table.tsx b/src/plugins/discover/public/application/view_components/canvas/discover_table.tsx index e292303d9f8d..8d9966af0ec0 100644 --- a/src/plugins/discover/public/application/view_components/canvas/discover_table.tsx +++ b/src/plugins/discover/public/application/view_components/canvas/discover_table.tsx @@ -35,7 +35,7 @@ export const DiscoverTable = ({ history }: Props) => { query: { filterManager }, }, } = services; - const { data$, refetch$, indexPattern } = useDiscoverContext(); + const { data$, refetch$, indexPattern, savedSearch } = useDiscoverContext(); const [fetchState, setFetchState] = useState({ status: data$.getValue().status, rows: [], diff --git a/src/plugins/discover/public/application/view_components/utils/use_index_pattern.ts b/src/plugins/discover/public/application/view_components/utils/use_index_pattern.ts index 872639107987..10a795abac37 100644 --- a/src/plugins/discover/public/application/view_components/utils/use_index_pattern.ts +++ b/src/plugins/discover/public/application/view_components/utils/use_index_pattern.ts @@ -6,46 +6,72 @@ import { useEffect, useState } from 'react'; import { i18n } from '@osd/i18n'; import { IndexPattern } from '../../../../../data/public'; -import { useSelector } from '../../utils/state_management'; +import { useSelector, updateIndexPattern, StoreType } from '../../utils/state_management'; import { DiscoverServices } from '../../../build_services'; +import { getIndexPatternId } from '../../helpers/get_index_pattern_id'; -export const useIndexPattern = (services: DiscoverServices) => { - const indexPatternId = useSelector((state) => state.metadata.indexPattern); +/** + * 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); const [indexPattern, setIndexPattern] = useState(undefined); - const { data, toastNotifications } = services; + const { data, toastNotifications, uiSettings: config } = 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}"`, - }, - } - ); - data.indexPatterns - .get(indexPatternId) - .then((result) => { - if (isMounted) { - setIndexPattern(result); - } - }) - .catch(() => { - if (isMounted) { - toastNotifications.addDanger({ - title: indexPatternMissingWarning, - }); - } + 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); }); + } else { + fetchIndexPatternDetails(indexPatternIdFromState); + } return () => { isMounted = false; }; - }, [indexPatternId, data.indexPatterns, toastNotifications]); + }, [indexPatternIdFromState, data.indexPatterns, toastNotifications, config, store]); return indexPattern; }; diff --git a/src/plugins/discover/public/application/view_components/utils/use_search.ts b/src/plugins/discover/public/application/view_components/utils/use_search.ts index 2560fc6d3567..b3fbefcdfad1 100644 --- a/src/plugins/discover/public/application/view_components/utils/use_search.ts +++ b/src/plugins/discover/public/application/view_components/utils/use_search.ts @@ -69,8 +69,8 @@ export type RefetchSubject = Subject; export const useSearch = (services: DiscoverServices) => { const [savedSearch, setSavedSearch] = useState(undefined); const { savedSearch: savedSearchId, sort, interval } = useSelector((state) => state.discover); - const indexPattern = useIndexPattern(services); - const { data, filterManager, getSavedSearchById, core, toastNotifications } = services; + const { data, filterManager, getSavedSearchById, core, toastNotifications, store } = services; + const indexPattern = useIndexPattern(services, store); const timefilter = data.query.timefilter.timefilter; const fetchStateRef = useRef<{ abortController: AbortController | undefined;