Calling selectors are now based on the root state

This commit is contained in:
Evan Hahn 2020-12-02 12:11:54 -06:00 committed by GitHub
parent d1866a0e5d
commit be99bbe87a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 47 additions and 19 deletions

View file

@ -89,10 +89,12 @@ export interface ActiveCallStateType {
settingsDialogOpen: boolean;
}
export interface CallsByConversationType {
[conversationId: string]: DirectCallStateType | GroupCallStateType;
}
export type CallingStateType = MediaDeviceSettings & {
callsByConversation: {
[conversationId: string]: DirectCallStateType | GroupCallStateType;
};
callsByConversation: CallsByConversationType;
activeCallState?: ActiveCallStateType;
};

View file

@ -3,17 +3,29 @@
import { createSelector } from 'reselect';
import { CallingStateType, DirectCallStateType } from '../ducks/calling';
import { StateType } from '../reducer';
import {
CallingStateType,
CallsByConversationType,
DirectCallStateType,
} from '../ducks/calling';
import { CallMode, CallState } from '../../types/Calling';
const getCallsByConversation = (state: CallingStateType) =>
state.callsByConversation;
const getCalling = (state: StateType): CallingStateType => state.calling;
const getCallsByConversation = createSelector(
getCalling,
(state: CallingStateType): CallsByConversationType =>
state.callsByConversation
);
// In theory, there could be multiple incoming calls. In practice, neither RingRTC nor the
// UI are ready to handle this.
export const getIncomingCall = createSelector(
getCallsByConversation,
(callsByConversation): undefined | DirectCallStateType => {
(
callsByConversation: CallsByConversationType
): undefined | DirectCallStateType => {
const result = Object.values(callsByConversation).find(
call =>
call.callMode === CallMode.Direct &&

View file

@ -124,7 +124,7 @@ const mapStateToActiveCallProp = (state: StateType) => {
};
const mapStateToIncomingCallProp = (state: StateType) => {
const call = getIncomingCall(state.calling);
const call = getIncomingCall(state);
if (!call) {
return undefined;
}

View file

@ -2,11 +2,20 @@
// SPDX-License-Identifier: AGPL-3.0-only
import { assert } from 'chai';
import { reducer as rootReducer } from '../../../state/reducer';
import { noopAction } from '../../../state/ducks/noop';
import { CallMode, CallState } from '../../../types/Calling';
import { getIncomingCall } from '../../../state/selectors/calling';
import { getEmptyState, CallingStateType } from '../../../state/ducks/calling';
describe('state/selectors/calling', () => {
const getEmptyRootState = () => rootReducer(undefined, noopAction());
const getCallingState = (calling: CallingStateType) => ({
...getEmptyRootState(),
calling,
});
const stateWithDirectCall: CallingStateType = {
...getEmptyState(),
callsByConversation: {
@ -49,23 +58,28 @@ describe('state/selectors/calling', () => {
describe('getIncomingCall', () => {
it('returns undefined if there are no calls', () => {
assert.isUndefined(getIncomingCall(getEmptyState()));
assert.isUndefined(getIncomingCall(getEmptyRootState()));
});
it('returns undefined if there is no incoming call', () => {
assert.isUndefined(getIncomingCall(stateWithDirectCall));
assert.isUndefined(getIncomingCall(stateWithActiveDirectCall));
assert.isUndefined(getIncomingCall(getCallingState(stateWithDirectCall)));
assert.isUndefined(
getIncomingCall(getCallingState(stateWithActiveDirectCall))
);
});
it('returns the incoming call', () => {
assert.deepEqual(getIncomingCall(stateWithIncomingDirectCall), {
callMode: CallMode.Direct,
conversationId: 'fake-direct-call-conversation-id',
callState: CallState.Ringing,
isIncoming: true,
isVideoCall: false,
hasRemoteVideo: false,
});
assert.deepEqual(
getIncomingCall(getCallingState(stateWithIncomingDirectCall)),
{
callMode: CallMode.Direct,
conversationId: 'fake-direct-call-conversation-id',
callState: CallState.Ringing,
isIncoming: true,
isVideoCall: false,
hasRemoteVideo: false,
}
);
});
});
});