2022-05-04 17:09:48 +01:00
|
|
|
/*
|
2023-01-03 16:55:26 +00:00
|
|
|
Copyright 2022 New Vector Ltd
|
2022-05-04 17:09:48 +01:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2022-04-07 14:22:36 -07:00
|
|
|
import { useState, useEffect } from "react";
|
2022-08-12 19:27:34 +02:00
|
|
|
import { CallFeed, CallFeedEvent } from "matrix-js-sdk/src/webrtc/callFeed";
|
|
|
|
import { SDPStreamMetadataPurpose } from "matrix-js-sdk/src/webrtc/callEventTypes";
|
2022-04-07 14:22:36 -07:00
|
|
|
|
2022-08-12 19:27:34 +02:00
|
|
|
interface CallFeedState {
|
2022-11-02 12:34:31 -04:00
|
|
|
callFeed: CallFeed | undefined;
|
2022-08-12 19:27:34 +02:00
|
|
|
isLocal: boolean;
|
|
|
|
speaking: boolean;
|
|
|
|
videoMuted: boolean;
|
|
|
|
audioMuted: boolean;
|
|
|
|
localVolume: number;
|
2023-01-07 10:09:20 +01:00
|
|
|
hasAudio: boolean;
|
2022-11-02 12:34:31 -04:00
|
|
|
disposed: boolean | undefined;
|
|
|
|
stream: MediaStream | undefined;
|
|
|
|
purpose: SDPStreamMetadataPurpose | undefined;
|
2022-08-12 19:27:34 +02:00
|
|
|
}
|
2022-11-02 12:34:31 -04:00
|
|
|
|
|
|
|
function getCallFeedState(callFeed: CallFeed | undefined): CallFeedState {
|
2022-04-07 14:22:36 -07:00
|
|
|
return {
|
2022-10-21 17:24:56 +01:00
|
|
|
callFeed,
|
2022-04-07 14:22:36 -07:00
|
|
|
isLocal: callFeed ? callFeed.isLocal() : false,
|
|
|
|
speaking: callFeed ? callFeed.isSpeaking() : false,
|
|
|
|
videoMuted: callFeed ? callFeed.isVideoMuted() : true,
|
|
|
|
audioMuted: callFeed ? callFeed.isAudioMuted() : true,
|
2022-07-14 16:18:10 +02:00
|
|
|
localVolume: callFeed ? callFeed.getLocalVolume() : 0,
|
2023-01-07 10:09:20 +01:00
|
|
|
hasAudio: callFeed ? callFeed.stream.getAudioTracks().length >= 1 : false,
|
2022-08-19 17:26:02 +02:00
|
|
|
disposed: callFeed ? callFeed.disposed : undefined,
|
2022-04-07 14:22:36 -07:00
|
|
|
stream: callFeed ? callFeed.stream : undefined,
|
|
|
|
purpose: callFeed ? callFeed.purpose : undefined,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-11-02 12:34:31 -04:00
|
|
|
export function useCallFeed(callFeed: CallFeed | undefined): CallFeedState {
|
2022-08-12 19:27:34 +02:00
|
|
|
const [state, setState] = useState<CallFeedState>(() =>
|
|
|
|
getCallFeedState(callFeed)
|
|
|
|
);
|
2022-04-07 14:22:36 -07:00
|
|
|
|
|
|
|
useEffect(() => {
|
2022-08-12 19:27:34 +02:00
|
|
|
function onSpeaking(speaking: boolean) {
|
2022-04-07 14:22:36 -07:00
|
|
|
setState((prevState) => ({ ...prevState, speaking }));
|
|
|
|
}
|
|
|
|
|
2022-08-12 19:27:34 +02:00
|
|
|
function onMuteStateChanged(audioMuted: boolean, videoMuted: boolean) {
|
2022-04-07 14:22:36 -07:00
|
|
|
setState((prevState) => ({ ...prevState, audioMuted, videoMuted }));
|
|
|
|
}
|
|
|
|
|
2022-08-12 19:27:34 +02:00
|
|
|
function onLocalVolumeChanged(localVolume: number) {
|
2022-07-15 11:22:13 +02:00
|
|
|
setState((prevState) => ({ ...prevState, localVolume }));
|
2022-07-14 16:18:10 +02:00
|
|
|
}
|
|
|
|
|
2022-04-07 14:22:36 -07:00
|
|
|
function onUpdateCallFeed() {
|
|
|
|
setState(getCallFeedState(callFeed));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (callFeed) {
|
|
|
|
callFeed.on(CallFeedEvent.Speaking, onSpeaking);
|
|
|
|
callFeed.on(CallFeedEvent.MuteStateChanged, onMuteStateChanged);
|
2022-07-14 16:18:10 +02:00
|
|
|
callFeed.on(CallFeedEvent.LocalVolumeChanged, onLocalVolumeChanged);
|
2022-04-07 14:22:36 -07:00
|
|
|
callFeed.on(CallFeedEvent.NewStream, onUpdateCallFeed);
|
2022-08-19 17:16:57 +02:00
|
|
|
callFeed.on(CallFeedEvent.Disposed, onUpdateCallFeed);
|
2022-04-07 14:22:36 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
onUpdateCallFeed();
|
|
|
|
|
|
|
|
return () => {
|
|
|
|
if (callFeed) {
|
|
|
|
callFeed.removeListener(CallFeedEvent.Speaking, onSpeaking);
|
|
|
|
callFeed.removeListener(
|
|
|
|
CallFeedEvent.MuteStateChanged,
|
|
|
|
onMuteStateChanged
|
|
|
|
);
|
2022-07-15 11:22:13 +02:00
|
|
|
callFeed.removeListener(
|
|
|
|
CallFeedEvent.LocalVolumeChanged,
|
|
|
|
onLocalVolumeChanged
|
|
|
|
);
|
2022-04-07 14:22:36 -07:00
|
|
|
callFeed.removeListener(CallFeedEvent.NewStream, onUpdateCallFeed);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}, [callFeed]);
|
|
|
|
|
|
|
|
return state;
|
|
|
|
}
|