This version is not supposed to properly work, this is a work in progress. Main changes: * Completely removed the PTT logic (for simplicity, it could be introduced later). * Abstracted away the work with the media devices. * Defined confined interfaces of the affected components so that they only get the data that they need without importing Matris JS SDK or LiveKit SDK, so that we can exchange their "backend" at any time. * Started using JS/TS SDK from LiveKit as well as their React SDK to define the state of the local media devices and local streams.
106 lines
3.0 KiB
TypeScript
106 lines
3.0 KiB
TypeScript
/*
|
|
Copyright 2021-2022 New Vector Ltd
|
|
|
|
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.
|
|
*/
|
|
|
|
import React, { FC, useEffect, useState, useCallback } from "react";
|
|
import { useTranslation } from "react-i18next";
|
|
|
|
import type { GroupCall } from "matrix-js-sdk/src/webrtc/groupCall";
|
|
import { useClient } from "../ClientContext";
|
|
import { ErrorView, LoadingView } from "../FullScreenView";
|
|
import { RoomAuthView } from "./RoomAuthView";
|
|
import { GroupCallLoader } from "./GroupCallLoader";
|
|
import { GroupCallView } from "./GroupCallView";
|
|
import { useUrlParams } from "../UrlParams";
|
|
import { useRegisterPasswordlessUser } from "../auth/useRegisterPasswordlessUser";
|
|
import { translatedError } from "../TranslatedError";
|
|
|
|
export const RoomPage: FC = () => {
|
|
const { t } = useTranslation();
|
|
const { loading, isAuthenticated, error, client, isPasswordlessUser } =
|
|
useClient();
|
|
|
|
const {
|
|
roomAlias,
|
|
roomId,
|
|
viaServers,
|
|
isEmbedded,
|
|
preload,
|
|
hideHeader,
|
|
isPtt,
|
|
displayName,
|
|
} = useUrlParams();
|
|
const roomIdOrAlias = roomId ?? roomAlias;
|
|
if (!roomIdOrAlias) throw translatedError("No room specified", t);
|
|
|
|
const { registerPasswordlessUser } = useRegisterPasswordlessUser();
|
|
const [isRegistering, setIsRegistering] = useState(false);
|
|
|
|
useEffect(() => {
|
|
// If we've finished loading, are not already authed and we've been given a display name as
|
|
// a URL param, automatically register a passwordless user
|
|
if (!loading && !isAuthenticated && displayName) {
|
|
setIsRegistering(true);
|
|
registerPasswordlessUser(displayName).finally(() => {
|
|
setIsRegistering(false);
|
|
});
|
|
}
|
|
}, [
|
|
isAuthenticated,
|
|
displayName,
|
|
setIsRegistering,
|
|
registerPasswordlessUser,
|
|
loading,
|
|
]);
|
|
|
|
const groupCallView = useCallback(
|
|
(groupCall: GroupCall) => (
|
|
<GroupCallView
|
|
client={client}
|
|
roomIdOrAlias={roomIdOrAlias}
|
|
groupCall={groupCall}
|
|
isPasswordlessUser={isPasswordlessUser}
|
|
isEmbedded={isEmbedded}
|
|
preload={preload}
|
|
hideHeader={hideHeader}
|
|
/>
|
|
),
|
|
[client, roomIdOrAlias, isPasswordlessUser, isEmbedded, preload, hideHeader]
|
|
);
|
|
|
|
if (loading || isRegistering) {
|
|
return <LoadingView />;
|
|
}
|
|
|
|
if (error) {
|
|
return <ErrorView error={error} />;
|
|
}
|
|
|
|
if (!isAuthenticated) {
|
|
return <RoomAuthView />;
|
|
}
|
|
|
|
return (
|
|
<GroupCallLoader
|
|
client={client}
|
|
roomIdOrAlias={roomIdOrAlias}
|
|
viaServers={viaServers}
|
|
createPtt={isPtt}
|
|
>
|
|
{groupCallView}
|
|
</GroupCallLoader>
|
|
);
|
|
};
|