Add API params to mute audio and/or video in Jitsi calls by default (#24820)

Signed-off-by: Dominik Henneke <dominik.henneke@nordeck.net>
This commit is contained in:
Dominik Henneke 2023-03-15 13:50:39 +01:00 committed by GitHub
parent 4a18ab6d1b
commit afe2ac2ae6
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -55,6 +55,8 @@ let roomId: string;
let openIdToken: IOpenIDCredentials; let openIdToken: IOpenIDCredentials;
let roomName: string; let roomName: string;
let startAudioOnly: boolean; let startAudioOnly: boolean;
let startWithAudioMuted: boolean | undefined;
let startWithVideoMuted: boolean | undefined;
let isVideoChannel: boolean; let isVideoChannel: boolean;
let supportsScreensharing: boolean; let supportsScreensharing: boolean;
let language: string; let language: string;
@ -80,6 +82,13 @@ const setupCompleted = (async (): Promise<string | void> => {
} }
return vals[0]; return vals[0];
}; };
const parseBooleanOrUndefined = (value: string | undefined): boolean | undefined => {
if (value === undefined) {
return undefined;
}
return value === "true";
};
// If we have these params, expect a widget API to be available (ie. to be in an iframe // If we have these params, expect a widget API to be available (ie. to be in an iframe
// inside a matrix client). Otherwise, assume we're on our own, eg. have been popped // inside a matrix client). Otherwise, assume we're on our own, eg. have been popped
@ -197,6 +206,8 @@ const setupCompleted = (async (): Promise<string | void> => {
roomId = qsParam("roomId", true); roomId = qsParam("roomId", true);
roomName = qsParam("roomName", true); roomName = qsParam("roomName", true);
startAudioOnly = qsParam("isAudioOnly", true) === "true"; startAudioOnly = qsParam("isAudioOnly", true) === "true";
startWithAudioMuted = parseBooleanOrUndefined(qsParam("startWithAudioMuted", true));
startWithVideoMuted = parseBooleanOrUndefined(qsParam("startWithVideoMuted", true));
isVideoChannel = qsParam("isVideoChannel", true) === "true"; isVideoChannel = qsParam("isVideoChannel", true) === "true";
supportsScreensharing = qsParam("supportsScreensharing", true) === "true"; supportsScreensharing = qsParam("supportsScreensharing", true) === "true";
@ -388,8 +399,8 @@ function joinConference(audioInput?: string | null, videoInput?: string | null):
configOverwrite: { configOverwrite: {
subject: roomName, subject: roomName,
startAudioOnly, startAudioOnly,
startWithAudioMuted: audioInput === null, startWithAudioMuted: audioInput === null ? true : startWithAudioMuted,
startWithVideoMuted: videoInput === null, startWithVideoMuted: videoInput === null ? true : startWithVideoMuted,
// Request some log levels for inclusion in rageshakes // Request some log levels for inclusion in rageshakes
// Ideally we would capture all possible log levels, but this can // Ideally we would capture all possible log levels, but this can
// cause Jitsi Meet to try to post various circular data structures // cause Jitsi Meet to try to post various circular data structures