-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathAppStateContext.tsx
95 lines (87 loc) · 3.68 KB
/
AppStateContext.tsx
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
import React, { useContext, useEffect } from 'react';
import { usePreviousDistinct } from 'react-use';
import { HMSVirtualBackgroundTypes } from '@100mslive/hms-virtual-background';
import { match, P } from 'ts-pattern';
import { HMSRoomState, selectRoomState, useHMSActions, useHMSStore } from '@100mslive/react-sdk';
import { VBHandler } from './components/VirtualBackground/VBHandler';
import { useRoomLayout, useSetOriginalLayout } from './provider/roomLayoutProvider';
import { useRedirectToLeave } from './components/hooks/useRedirectToLeave';
import {
useRoomLayoutLeaveScreen,
useRoomLayoutPreviewScreen,
} from './provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
import { APP_DATA } from './common/constants';
export enum PrebuiltStates {
MEETING = 'meeting',
PREVIEW = 'preview',
LEAVE = 'leave',
}
type AppStateContextType = {
rejoin: () => void;
};
export const AppStateContext = React.createContext<AppStateContextType>({
rejoin: () => {
console.log('Rejoin');
},
});
AppStateContext.displayName = 'AppStateContext';
export const useHMSAppStateContext = () => {
const context = useContext(AppStateContext);
if (!context) {
throw Error('Make sure AppStateContext.Provider is present at the top level of your application');
}
return context;
};
export const useAppStateManager = () => {
const roomLayout = useRoomLayout();
const setOriginalLayout = useSetOriginalLayout();
const [activeState, setActiveState] = React.useState<PrebuiltStates | undefined>();
const roomState = useHMSStore(selectRoomState);
const prevRoomState = usePreviousDistinct(roomState);
const hmsActions = useHMSActions();
const { isLeaveScreenEnabled } = useRoomLayoutLeaveScreen();
const { isPreviewScreenEnabled } = useRoomLayoutPreviewScreen();
const { redirectToLeave } = useRedirectToLeave();
const rejoin = () => {
setOriginalLayout?.();
hmsActions.setAppData(APP_DATA.authToken, '');
setActiveState(isPreviewScreenEnabled ? PrebuiltStates.PREVIEW : PrebuiltStates.MEETING);
};
useEffect(() => {
if (!roomLayout) {
return;
}
match([roomState, prevRoomState])
.with([HMSRoomState.Connected, P.any], () => setActiveState(PrebuiltStates.MEETING))
.with(
[HMSRoomState.Disconnecting, HMSRoomState.Connected],
[HMSRoomState.Disconnecting, HMSRoomState.Connecting],
[HMSRoomState.Disconnecting, HMSRoomState.Reconnecting],
[HMSRoomState.Disconnected, HMSRoomState.Connected],
[HMSRoomState.Disconnected, HMSRoomState.Connecting],
[HMSRoomState.Disconnected, HMSRoomState.Reconnecting],
[HMSRoomState.Disconnected, HMSRoomState.Preview],
() => {
setActiveState(prevState => {
return match({ isLeaveScreenEnabled, isPreviewScreenEnabled, prevState })
.when(
({ isLeaveScreenEnabled, prevState }) => isLeaveScreenEnabled && prevState !== PrebuiltStates.LEAVE,
() => PrebuiltStates.LEAVE,
)
.with({ isPreviewScreenEnabled: true }, () => PrebuiltStates.PREVIEW)
.otherwise(() => PrebuiltStates.MEETING);
});
VBHandler.reset();
hmsActions.setAppData(APP_DATA.background, HMSVirtualBackgroundTypes.NONE);
redirectToLeave(1000); // to clear toasts after 1 second
},
)
.with([HMSRoomState.Disconnected, P.nullish], () => {
setActiveState(isPreviewScreenEnabled ? PrebuiltStates.PREVIEW : PrebuiltStates.MEETING);
})
.otherwise(() => {
// do nothing
});
}, [roomLayout, roomState, isLeaveScreenEnabled, isPreviewScreenEnabled, prevRoomState, redirectToLeave, hmsActions]);
return { activeState, rejoin };
};