2022-05-04 16:09:48 +00:00
|
|
|
/*
|
|
|
|
Copyright 2022 Matrix.org Foundation C.I.C.
|
|
|
|
|
|
|
|
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-01-05 23:35:12 +00:00
|
|
|
import React, { useCallback, useEffect, useState } from "react";
|
|
|
|
import { useHistory } from "react-router-dom";
|
|
|
|
import { GroupCallState } from "matrix-js-sdk/src/webrtc/groupCall";
|
2022-04-07 21:22:36 +00:00
|
|
|
import { useGroupCall } from "./useGroupCall";
|
2022-01-05 23:35:12 +00:00
|
|
|
import { ErrorView, FullScreenView } from "../FullScreenView";
|
|
|
|
import { LobbyView } from "./LobbyView";
|
|
|
|
import { InCallView } from "./InCallView";
|
2022-04-23 01:05:48 +00:00
|
|
|
import { PTTCallView } from "./PTTCallView";
|
2022-01-05 23:35:12 +00:00
|
|
|
import { CallEndedView } from "./CallEndedView";
|
2022-05-18 23:00:59 +00:00
|
|
|
import { useRoomAvatar } from "./useRoomAvatar";
|
2022-01-05 23:35:12 +00:00
|
|
|
import { useSentryGroupCallHandler } from "./useSentryGroupCallHandler";
|
2022-02-04 00:56:13 +00:00
|
|
|
import { useLocationNavigation } from "../useLocationNavigation";
|
2022-01-05 23:35:12 +00:00
|
|
|
|
|
|
|
export function GroupCallView({
|
|
|
|
client,
|
|
|
|
isPasswordlessUser,
|
2022-06-28 14:08:14 +00:00
|
|
|
isEmbedded,
|
2022-01-05 23:35:12 +00:00
|
|
|
roomId,
|
|
|
|
groupCall,
|
|
|
|
}) {
|
|
|
|
const {
|
|
|
|
state,
|
|
|
|
error,
|
|
|
|
activeSpeaker,
|
|
|
|
userMediaFeeds,
|
|
|
|
microphoneMuted,
|
|
|
|
localVideoMuted,
|
|
|
|
localCallFeed,
|
|
|
|
initLocalCallFeed,
|
|
|
|
enter,
|
|
|
|
leave,
|
|
|
|
toggleLocalVideoMuted,
|
|
|
|
toggleMicrophoneMuted,
|
|
|
|
toggleScreensharing,
|
2022-02-04 00:56:13 +00:00
|
|
|
requestingScreenshare,
|
2022-01-05 23:35:12 +00:00
|
|
|
isScreensharing,
|
|
|
|
localScreenshareFeed,
|
|
|
|
screenshareFeeds,
|
|
|
|
hasLocalParticipant,
|
2022-04-23 01:05:48 +00:00
|
|
|
participants,
|
2022-06-09 20:56:58 +00:00
|
|
|
unencryptedEventsFromUsers,
|
2022-01-05 23:35:12 +00:00
|
|
|
} = useGroupCall(groupCall);
|
|
|
|
|
2022-05-18 23:00:59 +00:00
|
|
|
const avatarUrl = useRoomAvatar(groupCall.room);
|
|
|
|
|
2022-01-05 23:35:12 +00:00
|
|
|
useEffect(() => {
|
|
|
|
window.groupCall = groupCall;
|
|
|
|
}, [groupCall]);
|
|
|
|
|
|
|
|
useSentryGroupCallHandler(groupCall);
|
|
|
|
|
2022-02-04 00:56:13 +00:00
|
|
|
useLocationNavigation(requestingScreenshare);
|
|
|
|
|
2022-01-05 23:35:12 +00:00
|
|
|
const [left, setLeft] = useState(false);
|
|
|
|
const history = useHistory();
|
|
|
|
|
|
|
|
const onLeave = useCallback(() => {
|
2022-01-18 22:56:15 +00:00
|
|
|
setLeft(true);
|
2022-01-05 23:35:12 +00:00
|
|
|
leave();
|
|
|
|
|
|
|
|
if (!isPasswordlessUser) {
|
|
|
|
history.push("/");
|
|
|
|
}
|
|
|
|
}, [leave, history]);
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
return <ErrorView error={error} />;
|
|
|
|
} else if (state === GroupCallState.Entered) {
|
2022-04-23 01:05:48 +00:00
|
|
|
if (groupCall.isPtt) {
|
|
|
|
return (
|
|
|
|
<PTTCallView
|
|
|
|
client={client}
|
2022-04-29 00:44:50 +00:00
|
|
|
roomId={roomId}
|
2022-04-23 01:05:48 +00:00
|
|
|
roomName={groupCall.room.name}
|
2022-05-18 23:00:59 +00:00
|
|
|
avatarUrl={avatarUrl}
|
2022-04-29 00:44:50 +00:00
|
|
|
groupCall={groupCall}
|
|
|
|
participants={participants}
|
2022-04-23 01:05:48 +00:00
|
|
|
userMediaFeeds={userMediaFeeds}
|
|
|
|
onLeave={onLeave}
|
2022-06-28 14:08:14 +00:00
|
|
|
isEmbedded={isEmbedded}
|
2022-04-23 01:05:48 +00:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
return (
|
|
|
|
<InCallView
|
|
|
|
groupCall={groupCall}
|
|
|
|
client={client}
|
|
|
|
roomName={groupCall.room.name}
|
2022-05-18 23:00:59 +00:00
|
|
|
avatarUrl={avatarUrl}
|
2022-04-23 01:05:48 +00:00
|
|
|
microphoneMuted={microphoneMuted}
|
|
|
|
localVideoMuted={localVideoMuted}
|
|
|
|
toggleLocalVideoMuted={toggleLocalVideoMuted}
|
|
|
|
toggleMicrophoneMuted={toggleMicrophoneMuted}
|
|
|
|
userMediaFeeds={userMediaFeeds}
|
|
|
|
activeSpeaker={activeSpeaker}
|
|
|
|
onLeave={onLeave}
|
|
|
|
toggleScreensharing={toggleScreensharing}
|
|
|
|
isScreensharing={isScreensharing}
|
|
|
|
localScreenshareFeed={localScreenshareFeed}
|
|
|
|
screenshareFeeds={screenshareFeeds}
|
|
|
|
roomId={roomId}
|
2022-06-09 20:56:58 +00:00
|
|
|
unencryptedEventsFromUsers={unencryptedEventsFromUsers}
|
2022-04-23 01:05:48 +00:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
2022-01-05 23:35:12 +00:00
|
|
|
} else if (state === GroupCallState.Entering) {
|
|
|
|
return (
|
|
|
|
<FullScreenView>
|
|
|
|
<h1>Entering room...</h1>
|
|
|
|
</FullScreenView>
|
|
|
|
);
|
|
|
|
} else if (left) {
|
|
|
|
return <CallEndedView client={client} />;
|
|
|
|
} else {
|
|
|
|
return (
|
|
|
|
<LobbyView
|
|
|
|
client={client}
|
2022-04-27 22:18:55 +00:00
|
|
|
groupCall={groupCall}
|
2022-01-05 23:35:12 +00:00
|
|
|
hasLocalParticipant={hasLocalParticipant}
|
|
|
|
roomName={groupCall.room.name}
|
2022-05-18 23:00:59 +00:00
|
|
|
avatarUrl={avatarUrl}
|
2022-01-05 23:35:12 +00:00
|
|
|
state={state}
|
|
|
|
onInitLocalCallFeed={initLocalCallFeed}
|
|
|
|
localCallFeed={localCallFeed}
|
|
|
|
onEnter={enter}
|
|
|
|
microphoneMuted={microphoneMuted}
|
|
|
|
localVideoMuted={localVideoMuted}
|
|
|
|
toggleLocalVideoMuted={toggleLocalVideoMuted}
|
|
|
|
toggleMicrophoneMuted={toggleMicrophoneMuted}
|
|
|
|
roomId={roomId}
|
2022-07-06 17:27:30 +00:00
|
|
|
isEmbedded={isEmbedded}
|
2022-01-05 23:35:12 +00:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|