|
1 |
| -import { merge, uniqBy } from 'lodash'; |
2 |
| -import React, { CSSProperties, FC, useEffect } from 'react'; |
| 1 | +import { isEqual, uniqBy } from 'lodash'; |
| 2 | +import React, { CSSProperties, FC, useEffect, useRef } from 'react'; |
3 | 3 | // eslint-disable-next-line no-restricted-imports
|
4 | 4 | import { useDispatch, useSelector } from 'react-redux';
|
5 | 5 |
|
@@ -41,24 +41,31 @@ export const Picker: FC<PickerProps> = ({ values, onSaveToStore, pickerProps })
|
41 | 41 | const { fnGlobalTimeRange } = useSelector<StoreState, FnGlobalState>(({ fnGlobalState }) => fnGlobalState);
|
42 | 42 | const dispatch = useDispatch();
|
43 | 43 |
|
| 44 | + const didMountRef = useRef(false); |
44 | 45 | useEffect(() => {
|
45 |
| - if (!fnGlobalTimeRange) { |
46 |
| - return; |
| 46 | + /* The condition below skips the first run of useeffect that happens when this component gets mounted */ |
| 47 | + if (didMountRef.current) { |
| 48 | + /* If the current timerange value has changed, update fnGlobalTimeRange */ |
| 49 | + if (!isEqual(fnGlobalTimeRange?.raw, pickerProps.value.raw)) { |
| 50 | + dispatch( |
| 51 | + updatePartialFnStates({ |
| 52 | + fnGlobalTimeRange: pickerProps.value, |
| 53 | + }) |
| 54 | + ); |
| 55 | + } |
47 | 56 | }
|
48 |
| - onAppendToHistory(fnGlobalTimeRange, values, onSaveToStore); |
49 |
| - pickerProps.onChange(fnGlobalTimeRange); |
50 |
| - }, [fnGlobalTimeRange, onSaveToStore, pickerProps, values]); |
| 57 | + |
| 58 | + didMountRef.current = true; |
| 59 | + }, [dispatch, fnGlobalTimeRange?.raw, pickerProps.value]); |
51 | 60 |
|
52 | 61 | return (
|
53 | 62 | <TimeRangePicker
|
54 |
| - {...merge({}, pickerProps, { value: pickerProps.value })} |
| 63 | + {...pickerProps} |
| 64 | + value={fnGlobalTimeRange || pickerProps.value} |
55 | 65 | history={convertIfJson(values)}
|
56 | 66 | onChange={(value) => {
|
57 |
| - dispatch( |
58 |
| - updatePartialFnStates({ |
59 |
| - fnGlobalTimeRange: value, |
60 |
| - }) |
61 |
| - ); |
| 67 | + onAppendToHistory(value, values, onSaveToStore); |
| 68 | + pickerProps.onChange(value); |
62 | 69 | }}
|
63 | 70 | fnText={<FnText />}
|
64 | 71 | />
|
|
0 commit comments