Maximised widgets always force a call to be shown in PIP mode (#7163)

pull/21833/head
Timo 2021-11-25 22:14:19 +01:00 committed by GitHub
parent ae0dba4e87
commit 37828ab084
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 41 additions and 17 deletions

View File

@ -380,6 +380,16 @@ export default class CallHandler extends EventEmitter {
return callsNotInThatRoom; return callsNotInThatRoom;
} }
public getAllActiveCallsForPip(roomId: string) {
const room = MatrixClientPeg.get().getRoom(roomId);
if (WidgetLayoutStore.instance.hasMaximisedWidget(room)) {
// This checks if there is space for the call view in the aux panel
// If there is no space any call should be displayed in PiP
return this.getAllActiveCalls();
}
return this.getAllActiveCallsNotInRoom(roomId);
}
getTransfereeForCallId(callId: string): MatrixCall { getTransfereeForCallId(callId: string): MatrixCall {
return this.transferees[callId]; return this.transferees[callId];
} }

View File

@ -31,6 +31,7 @@ import { EventSubscription } from 'fbemitter';
import PictureInPictureDragger from './PictureInPictureDragger'; import PictureInPictureDragger from './PictureInPictureDragger';
import { logger } from "matrix-js-sdk/src/logger"; import { logger } from "matrix-js-sdk/src/logger";
import { WidgetLayoutStore } from '../../../stores/widgets/WidgetLayoutStore';
const SHOW_CALL_IN_STATES = [ const SHOW_CALL_IN_STATES = [
CallState.Connected, CallState.Connected,
@ -59,7 +60,9 @@ interface IState {
// (which should be a single element) of other calls. // (which should be a single element) of other calls.
// The primary will be the one not on hold, or an arbitrary one // The primary will be the one not on hold, or an arbitrary one
// if they're all on hold) // if they're all on hold)
function getPrimarySecondaryCalls(calls: MatrixCall[]): [MatrixCall, MatrixCall[]] { function getPrimarySecondaryCallsForPip(roomId: string): [MatrixCall, MatrixCall[]] {
const calls = CallHandler.sharedInstance().getAllActiveCallsForPip(roomId);
let primary: MatrixCall = null; let primary: MatrixCall = null;
let secondaries: MatrixCall[] = []; let secondaries: MatrixCall[] = [];
@ -101,9 +104,7 @@ export default class CallPreview extends React.Component<IProps, IState> {
const roomId = RoomViewStore.getRoomId(); const roomId = RoomViewStore.getRoomId();
const [primaryCall, secondaryCalls] = getPrimarySecondaryCalls( const [primaryCall, secondaryCalls] = getPrimarySecondaryCallsForPip(roomId);
CallHandler.sharedInstance().getAllActiveCallsNotInRoom(roomId),
);
this.state = { this.state = {
roomId, roomId,
@ -117,6 +118,10 @@ export default class CallPreview extends React.Component<IProps, IState> {
this.roomStoreToken = RoomViewStore.addListener(this.onRoomViewStoreUpdate); this.roomStoreToken = RoomViewStore.addListener(this.onRoomViewStoreUpdate);
this.dispatcherRef = dis.register(this.onAction); this.dispatcherRef = dis.register(this.onAction);
MatrixClientPeg.get().on(CallEvent.RemoteHoldUnhold, this.onCallRemoteHold); MatrixClientPeg.get().on(CallEvent.RemoteHoldUnhold, this.onCallRemoteHold);
const room = MatrixClientPeg.get()?.getRoom(this.state.roomId);
if (room) {
WidgetLayoutStore.instance.on(WidgetLayoutStore.emissionForRoom(room), this.updateCalls);
}
} }
public componentWillUnmount() { public componentWillUnmount() {
@ -127,18 +132,29 @@ export default class CallPreview extends React.Component<IProps, IState> {
} }
dis.unregister(this.dispatcherRef); dis.unregister(this.dispatcherRef);
SettingsStore.unwatchSetting(this.settingsWatcherRef); SettingsStore.unwatchSetting(this.settingsWatcherRef);
const room = MatrixClientPeg.get().getRoom(this.state.roomId);
WidgetLayoutStore.instance.off(WidgetLayoutStore.emissionForRoom(room), this.updateCalls);
} }
private onRoomViewStoreUpdate = () => { private onRoomViewStoreUpdate = () => {
if (RoomViewStore.getRoomId() === this.state.roomId) return; const newRoomId = RoomViewStore.getRoomId();
const oldRoomId = this.state.roomId;
const roomId = RoomViewStore.getRoomId(); if (newRoomId === oldRoomId) return;
const [primaryCall, secondaryCalls] = getPrimarySecondaryCalls( // The WidgetLayoutStore observer always tracks the currently viewed Room,
CallHandler.sharedInstance().getAllActiveCallsNotInRoom(roomId), // so we don't end up with multiple observers and know what observer to remove on unmount
); const oldRoom = MatrixClientPeg.get()?.getRoom(oldRoomId);
if (oldRoom) {
WidgetLayoutStore.instance.off(WidgetLayoutStore.emissionForRoom(oldRoom), this.updateCalls);
}
const newRoom = MatrixClientPeg.get()?.getRoom(newRoomId);
if (newRoom) {
WidgetLayoutStore.instance.on(WidgetLayoutStore.emissionForRoom(newRoom), this.updateCalls);
}
if (!newRoomId) return;
const [primaryCall, secondaryCalls] = getPrimarySecondaryCallsForPip(newRoomId);
this.setState({ this.setState({
roomId, roomId: newRoomId,
primaryCall: primaryCall, primaryCall: primaryCall,
secondaryCall: secondaryCalls[0], secondaryCall: secondaryCalls[0],
}); });
@ -157,9 +173,8 @@ export default class CallPreview extends React.Component<IProps, IState> {
}; };
private updateCalls = () => { private updateCalls = () => {
const [primaryCall, secondaryCalls] = getPrimarySecondaryCalls( if (!this.state.roomId) return;
CallHandler.sharedInstance().getAllActiveCallsNotInRoom(this.state.roomId), const [primaryCall, secondaryCalls] = getPrimarySecondaryCallsForPip(this.state.roomId);
);
this.setState({ this.setState({
primaryCall: primaryCall, primaryCall: primaryCall,
@ -168,9 +183,8 @@ export default class CallPreview extends React.Component<IProps, IState> {
}; };
private onCallRemoteHold = () => { private onCallRemoteHold = () => {
const [primaryCall, secondaryCalls] = getPrimarySecondaryCalls( if (!this.state.roomId) return;
CallHandler.sharedInstance().getAllActiveCallsNotInRoom(this.state.roomId), const [primaryCall, secondaryCalls] = getPrimarySecondaryCallsForPip(this.state.roomId);
);
this.setState({ this.setState({
primaryCall: primaryCall, primaryCall: primaryCall,