2019-09-19 13:28:57 +00:00
|
|
|
// @flow
|
|
|
|
|
|
|
|
import { getLocalVideoTrack } from '../../features/base/tracks';
|
2020-05-20 10:57:03 +00:00
|
|
|
import { createScreenshotCaptureEffect } from '../stream-effects/screenshot-capture';
|
|
|
|
|
2019-09-19 13:28:57 +00:00
|
|
|
import { SET_SCREENSHOT_CAPTURE } from './actionTypes';
|
2020-05-20 10:57:03 +00:00
|
|
|
import logger from './logger';
|
2019-09-19 13:28:57 +00:00
|
|
|
|
2020-02-26 15:50:54 +00:00
|
|
|
let ongoingEffect;
|
|
|
|
|
2019-09-19 13:28:57 +00:00
|
|
|
/**
|
|
|
|
* Marks the on-off state of screenshot captures.
|
|
|
|
*
|
|
|
|
* @param {boolean} enabled - Whether to turn screen captures on or off.
|
|
|
|
* @returns {{
|
|
|
|
* type: START_SCREENSHOT_CAPTURE,
|
|
|
|
* payload: enabled
|
|
|
|
* }}
|
|
|
|
*/
|
|
|
|
function setScreenshotCapture(enabled) {
|
|
|
|
return {
|
|
|
|
type: SET_SCREENSHOT_CAPTURE,
|
|
|
|
payload: enabled
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Action that toggles the screenshot captures.
|
|
|
|
*
|
|
|
|
* @param {boolean} enabled - Bool that represents the intention to start/stop screenshot captures.
|
|
|
|
* @returns {Promise}
|
|
|
|
*/
|
|
|
|
export function toggleScreenshotCaptureEffect(enabled: boolean) {
|
2020-02-26 15:50:54 +00:00
|
|
|
return async function(dispatch: (Object) => Object, getState: () => any) {
|
2019-09-19 13:28:57 +00:00
|
|
|
const state = getState();
|
|
|
|
|
|
|
|
if (state['features/screenshot-capture'].capturesEnabled !== enabled) {
|
|
|
|
const { jitsiTrack } = getLocalVideoTrack(state['features/base/tracks']);
|
|
|
|
|
2020-02-26 15:50:54 +00:00
|
|
|
if (!ongoingEffect) {
|
|
|
|
ongoingEffect = await createScreenshotCaptureEffect(state);
|
|
|
|
}
|
|
|
|
|
2020-02-25 15:22:10 +00:00
|
|
|
// Screenshot capture effect doesn't return a modified stream. Therefore, we don't have to
|
|
|
|
// switch the stream at the conference level, starting/stopping the effect will suffice here.
|
2020-02-26 15:50:54 +00:00
|
|
|
if (enabled) {
|
|
|
|
try {
|
|
|
|
await ongoingEffect.startEffect(
|
|
|
|
jitsiTrack.getOriginalStream(),
|
|
|
|
jitsiTrack.videoType
|
|
|
|
);
|
2020-02-25 15:22:10 +00:00
|
|
|
dispatch(setScreenshotCapture(enabled));
|
2020-02-26 15:50:54 +00:00
|
|
|
} catch {
|
|
|
|
|
|
|
|
// Handle promise rejection from {@code startEffect} due to stream type not being desktop.
|
|
|
|
logger.error('Unsupported stream type.');
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ongoingEffect.stopEffect();
|
|
|
|
dispatch(setScreenshotCapture(enabled));
|
|
|
|
}
|
2019-09-19 13:28:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return Promise.resolve();
|
|
|
|
};
|
|
|
|
}
|