1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- // @flow
-
- import { createVirtualBackgroundEffect } from '../stream-effects/virtual-background';
-
- import { BACKGROUND_ENABLED, SET_VIRTUAL_BACKGROUND, VIRTUAL_BACKGROUND_TRACK_CHANGED } from './actionTypes';
- import logger from './logger';
-
- /**
- * Signals the local participant activate the virtual background video or not.
- *
- * @param {Object} options - Represents the virtual background setted options.
- * @param {Object} jitsiTrack - Represents the jitsi track that will have backgraund effect applied.
- * @returns {Promise}
- */
- export function toggleBackgroundEffect(options: Object, jitsiTrack: Object) {
- return async function(dispatch: Object => Object, getState: () => any) {
- await dispatch(backgroundEnabled(options.enabled));
- await dispatch(setVirtualBackground(options));
- const state = getState();
- const virtualBackground = state['features/virtual-background'];
-
- if (jitsiTrack) {
- try {
- if (options.enabled) {
- await jitsiTrack.setEffect(await createVirtualBackgroundEffect(virtualBackground, dispatch));
- } else {
- await jitsiTrack.setEffect(undefined);
- dispatch(backgroundEnabled(false));
- }
- } catch (error) {
- dispatch(backgroundEnabled(false));
- logger.error('Error on apply background effect:', error);
- }
- }
- };
- }
-
- /**
- * Sets the selected virtual background image object.
- *
- * @param {Object} options - Represents the virtual background setted options.
- * @returns {{
- * type: SET_VIRTUAL_BACKGROUND,
- * virtualSource: string,
- * blurValue: number,
- * type: string,
- * }}
- */
- export function setVirtualBackground(options: Object) {
- return {
- type: SET_VIRTUAL_BACKGROUND,
- virtualSource: options?.url,
- blurValue: options?.blurValue,
- backgroundType: options?.backgroundType,
- selectedThumbnail: options?.selectedThumbnail
- };
- }
-
- /**
- * Signals the local participant that the background effect has been enabled.
- *
- * @param {boolean} backgroundEffectEnabled - Indicate if virtual background effect is activated.
- * @returns {{
- * type: BACKGROUND_ENABLED,
- * backgroundEffectEnabled: boolean
- * }}
- */
- export function backgroundEnabled(backgroundEffectEnabled: boolean) {
- return {
- type: BACKGROUND_ENABLED,
- backgroundEffectEnabled
- };
- }
-
- /**
- * Signals if the local track was changed due to a changes of the virtual background.
- *
- * @returns {{
- * type: VIRTUAL_BACKGROUND_TRACK_CHANGED
- *}}.
- */
- export function virtualBackgroundTrackChanged() {
- return {
- type: VIRTUAL_BACKGROUND_TRACK_CHANGED
- };
- }
|