2020-10-26 02:32:04 +03:00
|
|
|
import mapValues from 'lodash/mapValues';
|
|
|
|
import jsan from 'jsan';
|
2020-12-21 23:46:28 +03:00
|
|
|
import { immutableSerialize } from '@redux-devtools/serialize';
|
2020-10-26 02:32:04 +03:00
|
|
|
import { Action } from 'redux';
|
|
|
|
import Immutable from 'immutable';
|
2020-12-22 20:02:14 +03:00
|
|
|
import { PerformAction } from '@redux-devtools/instrument';
|
|
|
|
|
|
|
|
interface State {
|
|
|
|
actionsById: { [actionId: number]: PerformAction<Action<unknown>> };
|
|
|
|
computedStates: { state: unknown; error?: string }[];
|
|
|
|
committedState?: unknown;
|
|
|
|
}
|
2020-10-26 02:32:04 +03:00
|
|
|
|
|
|
|
function deprecate(param: string) {
|
|
|
|
// eslint-disable-next-line no-console
|
|
|
|
console.warn(
|
|
|
|
`\`${param}\` parameter for Redux DevTools Extension is deprecated. Use \`serialize\` parameter instead:` +
|
|
|
|
' https://github.com/zalmoxisus/redux-devtools-extension/releases/tag/v2.12.1'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export default function importState(
|
|
|
|
state: string,
|
|
|
|
{
|
|
|
|
deserializeState,
|
|
|
|
deserializeAction,
|
|
|
|
serialize,
|
|
|
|
}: {
|
|
|
|
deserializeState?: (state: string) => unknown;
|
|
|
|
deserializeAction?: (action: string) => Action<unknown>;
|
|
|
|
serialize?: {
|
|
|
|
immutable?: typeof Immutable;
|
|
|
|
refs?: (new (data: any) => unknown)[] | null;
|
|
|
|
reviver?: (key: string, value: unknown) => unknown;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
) {
|
|
|
|
if (!state) return undefined;
|
|
|
|
let parse = jsan.parse;
|
|
|
|
if (serialize) {
|
|
|
|
if (serialize.immutable) {
|
|
|
|
parse = (v) =>
|
|
|
|
jsan.parse(
|
|
|
|
v,
|
|
|
|
immutableSerialize(serialize.immutable!, serialize.refs).reviver
|
|
|
|
);
|
|
|
|
} else if (serialize.reviver) {
|
|
|
|
parse = (v) => jsan.parse(v, serialize.reviver);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
let preloadedState: State | undefined;
|
|
|
|
let nextLiftedState: State = parse(state) as State;
|
|
|
|
if (
|
2021-06-18 06:56:36 +03:00
|
|
|
(
|
|
|
|
nextLiftedState as unknown as {
|
|
|
|
payload?: string;
|
|
|
|
preloadedState?: string;
|
|
|
|
}
|
|
|
|
).payload
|
2020-10-26 02:32:04 +03:00
|
|
|
) {
|
|
|
|
if (
|
2021-06-18 06:56:36 +03:00
|
|
|
(
|
|
|
|
nextLiftedState as unknown as {
|
|
|
|
payload: string;
|
|
|
|
preloadedState?: string;
|
|
|
|
}
|
|
|
|
).preloadedState
|
2020-10-26 02:32:04 +03:00
|
|
|
)
|
|
|
|
preloadedState = parse(
|
2021-06-18 06:56:36 +03:00
|
|
|
(
|
|
|
|
nextLiftedState as unknown as {
|
|
|
|
payload: string;
|
|
|
|
preloadedState: string;
|
|
|
|
}
|
|
|
|
).preloadedState
|
2020-10-26 02:32:04 +03:00
|
|
|
) as State;
|
|
|
|
nextLiftedState = parse(
|
2021-06-18 06:56:36 +03:00
|
|
|
(
|
|
|
|
nextLiftedState as unknown as {
|
|
|
|
payload: string;
|
|
|
|
}
|
|
|
|
).payload
|
2020-10-26 02:32:04 +03:00
|
|
|
) as State;
|
|
|
|
}
|
|
|
|
if (deserializeState) {
|
|
|
|
deprecate('deserializeState');
|
|
|
|
if (typeof nextLiftedState.computedStates !== 'undefined') {
|
|
|
|
nextLiftedState.computedStates = nextLiftedState.computedStates.map(
|
|
|
|
(computedState) => ({
|
|
|
|
...computedState,
|
|
|
|
state: deserializeState(computedState.state as string),
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if (typeof nextLiftedState.committedState !== 'undefined') {
|
|
|
|
nextLiftedState.committedState = deserializeState(
|
|
|
|
nextLiftedState.committedState as string
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if (typeof preloadedState !== 'undefined') {
|
|
|
|
preloadedState = deserializeState(
|
2021-06-18 06:56:36 +03:00
|
|
|
preloadedState as unknown as string
|
2020-10-26 02:32:04 +03:00
|
|
|
) as State;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (deserializeAction) {
|
|
|
|
deprecate('deserializeAction');
|
|
|
|
nextLiftedState.actionsById = mapValues(
|
|
|
|
nextLiftedState.actionsById,
|
|
|
|
(liftedAction) => ({
|
|
|
|
...liftedAction,
|
2021-06-18 06:56:36 +03:00
|
|
|
action: deserializeAction(liftedAction.action as unknown as string),
|
2020-10-26 02:32:04 +03:00
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return { nextLiftedState, preloadedState };
|
|
|
|
}
|