Skip to content

Commit

Permalink
clean selected field values when switching data source on create page
Browse files Browse the repository at this point in the history
Signed-off-by: Jackie Han <[email protected]>
  • Loading branch information
jackiehanyang committed Apr 29, 2024
1 parent 48acb93 commit b95e310
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 10 deletions.
10 changes: 8 additions & 2 deletions public/pages/DefineDetector/components/Datasource/DataSource.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
*/

import { EuiComboBox, EuiCallOut, EuiSpacer } from '@elastic/eui';
import { Field, FieldProps, FormikProps } from 'formik';
import { Field, FieldProps, FormikProps, useFormikContext } from 'formik';
import { debounce, get } from 'lodash';
import React, { useEffect, useState } from 'react';
import { useDispatch, useSelector } from 'react-redux';
Expand Down Expand Up @@ -58,7 +58,13 @@ export function DataSource(props: DataSourceProps) {
);
const [queryText, setQueryText] = useState('');
const opensearchState = useSelector((state: AppState) => state.opensearch);
const { setFieldValue } = useFormikContext();

useEffect(() => {
setFieldValue('index', []);
setFieldValue('timeField', undefined);
setFieldValue('filters', []);

const getInitialIndices = async () => {
await dispatch(getIndices(queryText, dataSourceId));
};
Expand Down Expand Up @@ -102,7 +108,7 @@ export function DataSource(props: DataSourceProps) {
const visibleAliases = get(opensearchState, 'aliases', []) as IndexAlias[];

return (
<ContentPanel title="Data Source" titleSize="s">
<ContentPanel title="Select Data" titleSize="s">
{props.isEdit && isDifferentIndex() ? (
<div>
<EuiCallOut
Expand Down
18 changes: 10 additions & 8 deletions public/pages/DefineDetector/containers/DefineDetector.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -165,14 +165,16 @@ export const DefineDetector = (props: DefineDetectorProps) => {

// If no detector found with ID, redirect it to list
useEffect(() => {
const { history, location } = props;
const updatedParams = {
dataSourceId: MDSCreateState.selectedDataSourceId,
};
history.replace({
...location,
search: queryString.stringify(updatedParams),
});
if (dataSourceEnabled) {
const { history, location } = props;
const updatedParams = {
dataSourceId: MDSCreateState.selectedDataSourceId,
};
history.replace({
...location,
search: queryString.stringify(updatedParams),
});
}
if (props.isEdit && hasError) {
core.notifications.toasts.addDanger(
'Unable to find the detector for editing'
Expand Down

0 comments on commit b95e310

Please sign in to comment.