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:
parent
4a18ab6d1b
commit
afe2ac2ae6
1 changed files with 13 additions and 2 deletions
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue