Skip to content
This repository has been archived by the owner on Sep 11, 2024. It is now read-only.

Add support for screen sharing in 1:1 calls #5992

Merged
merged 97 commits into from
Jul 27, 2021
Merged
Show file tree
Hide file tree
Changes from 20 commits
Commits
Show all changes
97 commits
Select commit Hold shift + click to select a range
4a6d8eb
Add screensharing icons
SimonBrandner May 7, 2021
198722e
Add classes for screensharing buttons
SimonBrandner May 7, 2021
1f27354
Add support for up to 4 feeds
SimonBrandner May 7, 2021
5b2f941
Add button to screenshare
SimonBrandner May 7, 2021
4c9d9dd
Enable screenshare in all video calls
SimonBrandner May 8, 2021
430808a
Simplifie CSS
SimonBrandner May 8, 2021
69b0425
Improve and fix sorting
SimonBrandner May 8, 2021
2749715
Remove screensharing call type
SimonBrandner May 10, 2021
135cdb2
Add dialog with info about the screensharing change
SimonBrandner May 10, 2021
0eeb21d
Remove unnecessary import
SimonBrandner May 10, 2021
228b2cc
Increase z-index of call controls
SimonBrandner May 10, 2021
90f4ad7
Always sort feeds
SimonBrandner May 10, 2021
acd0fa4
Add a comment about when it is possible to screenshare
SimonBrandner May 10, 2021
834579f
Don't render any audio non-primary feeds
SimonBrandner May 11, 2021
adddb0f
Show screensharign button only if connected
SimonBrandner May 13, 2021
5c2abd2
Do not render the audio element if there is no audio track
SimonBrandner May 19, 2021
17fad0e
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner May 19, 2021
4cbec87
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner May 19, 2021
340bbee
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner May 20, 2021
f949526
Add a missing ;
SimonBrandner May 20, 2021
1d3bf91
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jun 4, 2021
6cd7608
Improve wording
SimonBrandner Jun 4, 2021
641c902
i18n
SimonBrandner Jun 4, 2021
befcbf8
Add spaces into curly braces
SimonBrandner Jun 4, 2021
6192318
Add CallViewSidebar
SimonBrandner Jun 12, 2021
5608e92
Add styling for CallViewSidebar
SimonBrandner Jun 12, 2021
97b976b
Adjust for sidebar
SimonBrandner Jun 12, 2021
1b2b471
Properly handle feed prop updates
SimonBrandner Jun 12, 2021
84070bf
Rework how feeds work
SimonBrandner Jun 12, 2021
e431f41
Fix feeds misbehaving
SimonBrandner Jun 12, 2021
176fb9b
Don't show sidebar in PiP
SimonBrandner Jun 12, 2021
0c55a6c
Add presenting text
SimonBrandner Jun 12, 2021
ed148de
Derive mute state from props
SimonBrandner Jun 12, 2021
d62f959
Fix imports
SimonBrandner Jun 12, 2021
6592839
Simplifie some naming
SimonBrandner Jun 12, 2021
e5188a5
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jun 12, 2021
c5ee2a6
Add share button and refoctor
SimonBrandner Jun 12, 2021
6ae1f53
Add min-width
SimonBrandner Jun 12, 2021
9a67851
Hide feeds with muted video in certain cases and fix colors
SimonBrandner Jun 12, 2021
6d29c19
Move call controls into a separate method
SimonBrandner Jun 12, 2021
10e8a1d
Allow fullscreening in all call types
SimonBrandner Jun 12, 2021
65c477f
Add sidebar icons
SimonBrandner Jun 12, 2021
60ab7aa
Support hiding sidebar
SimonBrandner Jun 12, 2021
a933e08
Also turn off camera when hiding sidebar
SimonBrandner Jun 12, 2021
cc46233
Remove emtpy line
SimonBrandner Jun 12, 2021
fc239ff
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jul 7, 2021
657896c
Delint
SimonBrandner Jul 7, 2021
a03b48d
Add missing null guard
SimonBrandner Jul 7, 2021
6ef7ecb
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jul 8, 2021
d512a83
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jul 16, 2021
77c8425
Rewrite using TabbedView and improve TS
SimonBrandner Jul 16, 2021
31f5d01
Improve the look and feel of the picker
SimonBrandner Jul 16, 2021
27b0261
i18n
SimonBrandner Jul 16, 2021
18ba7a2
Give sources a little padding
SimonBrandner Jul 16, 2021
2a2b8ad
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jul 16, 2021
66a3b0f
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jul 20, 2021
6491a00
Add some types
SimonBrandner Jul 20, 2021
c25feb9
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jul 20, 2021
fadb13e
Center all buttons
SimonBrandner Jul 20, 2021
0a282b5
Reorder buttons
SimonBrandner Jul 20, 2021
e5563ac
Update the screen-sharing buttons
SimonBrandner Jul 20, 2021
3751f04
Add "You are presenting toast"
SimonBrandner Jul 20, 2021
15406ea
Put the sidebar to the bottom rather than the top
SimonBrandner Jul 20, 2021
690905d
Show sidebar button only when screen-sharing
SimonBrandner Jul 20, 2021
0af6450
Reverse sidebar order
SimonBrandner Jul 20, 2021
c7a2849
Correct sidebar toggle behaviour
SimonBrandner Jul 20, 2021
cfaf4b8
Correct sidebar behaviour when muting local video
SimonBrandner Jul 20, 2021
4546df7
Update sidebar icons
SimonBrandner Jul 20, 2021
3993e69
Put the call controls close togather
SimonBrandner Jul 20, 2021
9fb872c
Sort feeds
SimonBrandner Jul 20, 2021
be52eba
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jul 21, 2021
51cf426
Update the toast
SimonBrandner Jul 21, 2021
2014517
Always show screensharing feed as primary
SimonBrandner Jul 21, 2021
74649f1
Correct feed ordering
SimonBrandner Jul 21, 2021
337664a
Update sidebar behaviour
SimonBrandner Jul 21, 2021
0a80675
Adjust hiding local feeds
SimonBrandner Jul 21, 2021
dc7f6d8
Show sidebar in PiP mode
SimonBrandner Jul 21, 2021
3fac4ad
Fix feed sizing issues
SimonBrandner Jul 21, 2021
ddd4b4b
Show a "Your camera is turned off" toast
SimonBrandner Jul 21, 2021
9891edd
Rename to toast
SimonBrandner Jul 21, 2021
d243f7b
Move some CSS to a more correct place
SimonBrandner Jul 21, 2021
c2aada6
Clearer avatar sizing
SimonBrandner Jul 21, 2021
7ad62a8
Reorganize some CSS
SimonBrandner Jul 22, 2021
1b9b5fd
Fix sidebar hiding
SimonBrandner Jul 22, 2021
37335b2
Show toast even for non-presenters
SimonBrandner Jul 22, 2021
6429b3c
Only show toast about camera in video calls
SimonBrandner Jul 22, 2021
72948b9
Keep aspect ratio for voice feeds
SimonBrandner Jul 22, 2021
8998382
Fix dumb typo
SimonBrandner Jul 22, 2021
2873bf6
Make feeds bit a smaller
SimonBrandner Jul 22, 2021
8695beb
Fix overflow issues
SimonBrandner Jul 22, 2021
33abe83
Always hide all feeds
SimonBrandner Jul 22, 2021
f4287fc
Simplifie sidebar showing logic
SimonBrandner Jul 22, 2021
2841383
rethemendex
SimonBrandner Jul 22, 2021
b762303
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jul 25, 2021
50c27eb
Add myself to the license header as I need to re-run the CI
SimonBrandner Jul 25, 2021
24f0c76
Merge remote-tracking branch 'upstream/develop' into fix/12652/screen…
SimonBrandner Jul 27, 2021
b9e305d
Delete mistake line
SimonBrandner Jul 27, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 13 additions & 0 deletions res/css/views/voip/_CallView.scss
Original file line number Diff line number Diff line change
Expand Up @@ -291,6 +291,7 @@ limitations under the License.
width: 100%;
opacity: 1;
transition: opacity 0.5s;
z-index: 200; // To be above _all_ feeds
}

.mx_CallView_callControls_hidden {
Expand Down Expand Up @@ -353,6 +354,18 @@ limitations under the License.
}
}

.mx_CallView_callControls_button_screensharingOn {
&::before {
background-image: url('$(res)/img/voip/screensharing-on.svg');
}
}

.mx_CallView_callControls_button_screensharingOff {
&::before {
background-image: url('$(res)/img/voip/screensharing-off.svg');
}
}

.mx_CallView_callControls_button_hangup {
&::before {
background-image: url('$(res)/img/voip/hangup.svg');
Expand Down
22 changes: 17 additions & 5 deletions res/css/views/voip/_VideoFeed.scss
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,7 @@ limitations under the License.
background-color: $inverted-bg-color;
}


.mx_VideoFeed_remote {
.mx_VideoFeed_primary {
width: 100%;
height: 100%;
display: flex;
Expand All @@ -33,12 +32,10 @@ limitations under the License.
}
}

.mx_VideoFeed_local {
.mx_VideoFeed_nonPrimary {
max-width: 25%;
max-height: 25%;
position: absolute;
right: 10px;
top: 10px;
z-index: 100;
border-radius: 4px;

Expand All @@ -47,6 +44,21 @@ limitations under the License.
}
}

.mx_VideoFeed_secondary {
right: 10px;
top: 10px;
}

.mx_VideoFeed_tertiary {
right: 10px;
bottom: 10px;
}

.mx_VideoFeed_quaternary {
left: 10px;
top: 10px;
}

.mx_VideoFeed_mirror {
transform: scale(-1, 1);
}
17 changes: 17 additions & 0 deletions res/img/voip/screensharing-off.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
17 changes: 17 additions & 0 deletions res/img/voip/screensharing-on.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
26 changes: 0 additions & 26 deletions src/CallHandler.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,6 @@ limitations under the License.
import React from 'react';

import {MatrixClientPeg} from './MatrixClientPeg';
import PlatformPeg from './PlatformPeg';
import Modal from './Modal';
import { _t } from './languageHandler';
import dis from './dispatcher/dispatcher';
Expand All @@ -80,7 +79,6 @@ import CountlyAnalytics from "./CountlyAnalytics";
import {UIFeature} from "./settings/UIFeature";
import { CallError } from "matrix-js-sdk/src/webrtc/call";
import { logger } from 'matrix-js-sdk/src/logger';
import DesktopCapturerSourcePicker from "./components/views/elements/DesktopCapturerSourcePicker"
import { Action } from './dispatcher/actions';
import VoipUserMapper from './VoipUserMapper';
import { addManagedHybridWidget, isManagedHybridWidgetEnabled } from './widgets/ManagedHybrid';
Expand Down Expand Up @@ -129,14 +127,9 @@ interface ThirdpartyLookupResponse {
fields: ThirdpartyLookupResponseFields,
}

// Unlike 'CallType' in js-sdk, this one includes screen sharing
// (because a screen sharing call is only a screen sharing call to the caller,
// to the callee it's just a video call, at least as far as the current impl
// is concerned).
export enum PlaceCallType {
Voice = 'voice',
Video = 'video',
ScreenSharing = 'screensharing',
}

export enum CallHandlerEvent {
Expand Down Expand Up @@ -689,25 +682,6 @@ export default class CallHandler extends EventEmitter {
call.placeVoiceCall();
} else if (type === 'video') {
call.placeVideoCall();
} else if (type === PlaceCallType.ScreenSharing) {
const screenCapErrorString = PlatformPeg.get().screenCaptureErrorString();
if (screenCapErrorString) {
this.removeCallForRoom(roomId);
console.log("Can't capture screen: " + screenCapErrorString);
Modal.createTrackedDialog('Call Handler', 'Unable to capture screen', ErrorDialog, {
title: _t('Unable to capture screen'),
description: screenCapErrorString,
});
return;
}

call.placeScreenSharingCall(
async (): Promise<DesktopCapturerSource> => {
const {finished} = Modal.createDialog(DesktopCapturerSourcePicker);
const [source] = await finished;
return source;
},
);
} else {
console.error("Unknown conf call type: " + type);
}
Expand Down
14 changes: 12 additions & 2 deletions src/components/views/rooms/RoomHeader.js
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,8 @@ import RoomTopic from "../elements/RoomTopic";
import RoomName from "../elements/RoomName";
import {PlaceCallType} from "../../../CallHandler";
import {replaceableComponent} from "../../../utils/replaceableComponent";
import Modal from '../../../Modal';
import InfoDialog from "../dialogs/InfoDialog";

@replaceableComponent("views.rooms.RoomHeader")
export default class RoomHeader extends React.Component {
Expand Down Expand Up @@ -117,6 +119,14 @@ export default class RoomHeader extends React.Component {
return !(currentPinEvent.getContent().pinned && currentPinEvent.getContent().pinned.length <= 0);
}

_displayInfoDialogAboutScreensharing() {
Modal.createDialog(InfoDialog, {
title: _t("Screensharing has changed"),
description: _t("You don't have to shift-click anymore! You can now share " +
"your screen in any video call and in voice calls if other side supports it."),
SimonBrandner marked this conversation as resolved.
Show resolved Hide resolved
});
}

render() {
let searchStatus = null;
let cancelButton = null;
Expand Down Expand Up @@ -239,8 +249,8 @@ export default class RoomHeader extends React.Component {
videoCallButton =
<AccessibleTooltipButton
className="mx_RoomHeader_button mx_RoomHeader_videoCallButton"
onClick={(ev) => this.props.onCallPlaced(
ev.shiftKey ? PlaceCallType.ScreenSharing : PlaceCallType.Video)}
onClick={(ev) => ev.shiftKey ?
this._displayInfoDialogAboutScreensharing() : this.props.onCallPlaced(PlaceCallType.Video)}
title={_t("Video call")} />;
}

Expand Down
22 changes: 21 additions & 1 deletion src/components/views/voip/AudioFeed.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,21 @@ interface IProps {
feed: CallFeed,
}

export default class AudioFeed extends React.Component<IProps> {
interface IState {
audioMuted: boolean;
}

export default class AudioFeed extends React.Component<IProps, IState> {
private element = createRef<HTMLAudioElement>();

constructor(props: IProps) {
super(props);

this.state = {
audioMuted: this.props.feed.isAudioMuted(),
};
}

componentDidMount() {
this.props.feed.addListener(CallFeedEvent.NewStream, this.onNewStream);
this.playMedia();
Expand All @@ -38,6 +50,7 @@ export default class AudioFeed extends React.Component<IProps> {

private playMedia() {
const element = this.element.current;
if (!element) return;
const audioOutput = CallMediaHandler.getAudioOutput();

if (audioOutput) {
Expand Down Expand Up @@ -75,6 +88,7 @@ export default class AudioFeed extends React.Component<IProps> {

private stopMedia() {
const element = this.element.current;
if (!element) return;

element.pause();
element.src = null;
Expand All @@ -86,10 +100,16 @@ export default class AudioFeed extends React.Component<IProps> {
}

private onNewStream = () => {
this.setState({
audioMuted: this.props.feed.isAudioMuted(),
});
this.playMedia();
};

render() {
// Do not render the audio element if there is no audio track
if (this.state.audioMuted) return null;

return (
<audio ref={this.element} />
);
Expand Down
Loading