-
-
Notifications
You must be signed in to change notification settings - Fork 282
/
Copy pathonboardingReducer.ts
110 lines (91 loc) · 3.45 KB
/
onboardingReducer.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import { produce } from 'immer';
import { DEVICE } from '@trezor/connect';
import { OnboardingAnalytics } from '@trezor/suite-analytics';
import { ONBOARDING } from 'src/actions/onboarding/constants';
import * as STEP from 'src/constants/onboarding/steps';
import type { AnyPath, AnyStepId } from 'src/types/onboarding';
import { Action } from 'src/types/suite';
export interface OnboardingRootState {
onboarding: OnboardingState;
}
export type DeviceTutorialStatus = 'active' | 'completed' | 'cancelled' | null;
export const selectBackupTypes = [
'shamir-single',
'shamir-advanced',
'12-words',
'24-words',
] as const;
export type BackupType = (typeof selectBackupTypes)[number];
export interface OnboardingState {
backupType: BackupType;
isActive: boolean;
prevDeviceId: string | null;
activeStepId: AnyStepId;
path: AnyPath[];
onboardingAnalytics: Partial<OnboardingAnalytics>;
tutorialStatus: DeviceTutorialStatus;
}
const initialState: OnboardingState = {
isActive: false,
// todo: prevDevice is now used to solve two different things and it cant work
// would be better to implement field "isMatchingPrevDevice" along with prevDevice
// prevDevice is used only in firmwareUpdate so maybe move it to firmwareUpdate
// and here leave only isMatchingPrevDevice ?
prevDeviceId: null,
activeStepId: STEP.ID_FIRMWARE_STEP,
path: [],
onboardingAnalytics: {},
tutorialStatus: null,
backupType: 'shamir-single',
};
const addPath = (path: AnyPath, state: OnboardingState) => {
if (!state.path.includes(path)) {
return [...state.path, path];
}
return [...state.path];
};
const removePath = (paths: AnyPath[], state: OnboardingState) =>
state.path.filter(p => !paths.includes(p));
const onboarding = (state: OnboardingState = initialState, action: Action) => {
if (
!state.isActive &&
![ONBOARDING.RESET_ONBOARDING, ONBOARDING.ENABLE_ONBOARDING_REDUCER].includes(action.type)
) {
return state;
}
return produce(state, draft => {
switch (action.type) {
case ONBOARDING.ENABLE_ONBOARDING_REDUCER:
draft.isActive = action.payload;
break;
case ONBOARDING.SET_STEP_ACTIVE:
draft.activeStepId = action.stepId;
break;
case ONBOARDING.ADD_PATH:
draft.path = addPath(action.payload, state);
break;
case ONBOARDING.REMOVE_PATH:
draft.path = removePath(action.payload, state);
break;
case DEVICE.DISCONNECT:
draft.prevDeviceId = action.payload.id ?? null;
break;
case ONBOARDING.ANALYTICS:
draft.onboardingAnalytics = { ...state.onboardingAnalytics, ...action.payload };
break;
case ONBOARDING.SET_TUTORIAL_STATUS:
draft.tutorialStatus = action.payload;
break;
case ONBOARDING.SELECT_BACKUP_TYPE:
draft.backupType = action.payload;
break;
case ONBOARDING.RESET_ONBOARDING:
return initialState;
// no default
}
});
};
export const selectOnboardingTutorialStatus = (state: OnboardingRootState) =>
state.onboarding.tutorialStatus;
export const selectIsOnboardingActive = (state: OnboardingRootState) => state.onboarding.isActive;
export default onboarding;