2017-02-16 23:02:40 +00:00
|
|
|
/* @flow */
|
|
|
|
|
|
|
|
import type { Dispatch } from 'redux-thunk';
|
|
|
|
|
|
|
|
import {
|
2017-04-01 05:52:40 +00:00
|
|
|
CLEAR_TOOLBOX_TIMEOUT,
|
2017-04-04 11:53:10 +00:00
|
|
|
SET_DEFAULT_TOOLBOX_BUTTONS,
|
2017-02-16 23:02:40 +00:00
|
|
|
SET_SUBJECT,
|
|
|
|
SET_SUBJECT_SLIDE_IN,
|
|
|
|
SET_TOOLBAR_BUTTON,
|
|
|
|
SET_TOOLBAR_HOVERED,
|
2017-04-12 19:06:56 +00:00
|
|
|
SET_TOOLBOX_ALWAYS_VISIBLE,
|
|
|
|
SET_TOOLBOX_ENABLED,
|
2017-04-01 05:52:40 +00:00
|
|
|
SET_TOOLBOX_TIMEOUT,
|
|
|
|
SET_TOOLBOX_TIMEOUT_MS,
|
|
|
|
SET_TOOLBOX_VISIBLE
|
2017-02-16 23:02:40 +00:00
|
|
|
} from './actionTypes';
|
2017-04-04 11:53:10 +00:00
|
|
|
import { getDefaultToolboxButtons } from './functions';
|
2017-02-16 23:02:40 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Event handler for local raise hand changed event.
|
|
|
|
*
|
|
|
|
* @param {boolean} handRaised - Flag showing whether hand is raised.
|
|
|
|
* @returns {Function}
|
|
|
|
*/
|
|
|
|
export function changeLocalRaiseHand(handRaised: boolean): Function {
|
|
|
|
return (dispatch: Dispatch<*>, getState: Function) => {
|
|
|
|
const state = getState();
|
2017-04-01 05:52:40 +00:00
|
|
|
const { secondaryToolbarButtons } = state['features/toolbox'];
|
2017-02-16 23:02:40 +00:00
|
|
|
const buttonName = 'raisehand';
|
|
|
|
const button = secondaryToolbarButtons.get(buttonName);
|
|
|
|
|
|
|
|
button.toggled = handRaised;
|
|
|
|
|
|
|
|
dispatch(setToolbarButton(buttonName, button));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-04-01 05:52:40 +00:00
|
|
|
* Signals that toolbox timeout should be cleared.
|
2017-02-16 23:02:40 +00:00
|
|
|
*
|
|
|
|
* @returns {{
|
2017-04-01 05:52:40 +00:00
|
|
|
* type: CLEAR_TOOLBOX_TIMEOUT
|
2017-02-16 23:02:40 +00:00
|
|
|
* }}
|
|
|
|
*/
|
2017-04-01 05:52:40 +00:00
|
|
|
export function clearToolboxTimeout(): Object {
|
2017-02-16 23:02:40 +00:00
|
|
|
return {
|
2017-04-01 05:52:40 +00:00
|
|
|
type: CLEAR_TOOLBOX_TIMEOUT
|
2017-02-16 23:02:40 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-04-01 05:52:40 +00:00
|
|
|
* Enables/disables audio toolbar button.
|
2017-02-16 23:02:40 +00:00
|
|
|
*
|
2017-04-01 05:52:40 +00:00
|
|
|
* @param {boolean} enabled - True if the button should be enabled; otherwise,
|
|
|
|
* false.
|
2017-02-16 23:02:40 +00:00
|
|
|
* @returns {Function}
|
|
|
|
*/
|
|
|
|
export function setAudioIconEnabled(enabled: boolean = false): Function {
|
|
|
|
return (dispatch: Dispatch<*>) => {
|
|
|
|
const i18nKey = enabled ? 'mute' : 'micDisabled';
|
|
|
|
const i18n = `[content]toolbar.${i18nKey}`;
|
|
|
|
const button = {
|
|
|
|
enabled,
|
|
|
|
i18n,
|
|
|
|
toggled: !enabled
|
|
|
|
};
|
|
|
|
|
|
|
|
dispatch(setToolbarButton('microphone', button));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-04-04 11:53:10 +00:00
|
|
|
/**
|
|
|
|
* Sets the default toolbar buttons of the Toolbox.
|
|
|
|
*
|
|
|
|
* @returns {{
|
|
|
|
* type: SET_DEFAULT_TOOLBOX_BUTTONS,
|
|
|
|
* primaryToolbarButtons: Map,
|
|
|
|
* secondaryToolbarButtons: Map
|
|
|
|
* }}
|
|
|
|
*/
|
|
|
|
export function setDefaultToolboxButtons(): Object {
|
|
|
|
return {
|
|
|
|
type: SET_DEFAULT_TOOLBOX_BUTTONS,
|
|
|
|
...getDefaultToolboxButtons()
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-02-16 23:02:40 +00:00
|
|
|
/**
|
2017-04-01 05:52:40 +00:00
|
|
|
* Signals that value of conference subject should be changed.
|
2017-02-16 23:02:40 +00:00
|
|
|
*
|
2017-04-01 05:52:40 +00:00
|
|
|
* @param {string} subject - Conference subject string.
|
|
|
|
* @returns {Object}
|
2017-02-16 23:02:40 +00:00
|
|
|
*/
|
2017-04-01 05:52:40 +00:00
|
|
|
export function setSubject(subject: string): Object {
|
2017-02-16 23:02:40 +00:00
|
|
|
return {
|
|
|
|
type: SET_SUBJECT,
|
|
|
|
subject
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-04-01 05:52:40 +00:00
|
|
|
* Signals that toolbox subject slide in value should be changed.
|
2017-02-16 23:02:40 +00:00
|
|
|
*
|
2017-04-01 05:52:40 +00:00
|
|
|
* @param {boolean} subjectSlideIn - True if the subject is shown; otherwise,
|
|
|
|
* false.
|
2017-02-16 23:02:40 +00:00
|
|
|
* @returns {{
|
|
|
|
* type: SET_SUBJECT_SLIDE_IN,
|
|
|
|
* subjectSlideIn: boolean
|
|
|
|
* }}
|
|
|
|
*/
|
|
|
|
export function setSubjectSlideIn(subjectSlideIn: boolean): Object {
|
|
|
|
return {
|
|
|
|
type: SET_SUBJECT_SLIDE_IN,
|
|
|
|
subjectSlideIn
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Signals that value of the button specified by key should be changed.
|
|
|
|
*
|
|
|
|
* @param {string} buttonName - Button key.
|
|
|
|
* @param {Object} button - Button object.
|
|
|
|
* @returns {{
|
|
|
|
* type: SET_TOOLBAR_BUTTON,
|
2017-04-01 05:52:40 +00:00
|
|
|
* button: Object,
|
|
|
|
* buttonName: string
|
2017-02-16 23:02:40 +00:00
|
|
|
* }}
|
|
|
|
*/
|
|
|
|
export function setToolbarButton(buttonName: string, button: Object): Object {
|
|
|
|
return {
|
|
|
|
type: SET_TOOLBAR_BUTTON,
|
2017-04-01 05:52:40 +00:00
|
|
|
button,
|
|
|
|
buttonName
|
2017-02-16 23:02:40 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Signals that toolbar is hovered value should be changed.
|
|
|
|
*
|
|
|
|
* @param {boolean} hovered - Flag showing whether toolbar is hovered.
|
|
|
|
* @returns {{
|
|
|
|
* type: SET_TOOLBAR_HOVERED,
|
|
|
|
* hovered: boolean
|
|
|
|
* }}
|
|
|
|
*/
|
|
|
|
export function setToolbarHovered(hovered: boolean): Object {
|
|
|
|
return {
|
|
|
|
type: SET_TOOLBAR_HOVERED,
|
|
|
|
hovered
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-04-04 11:53:10 +00:00
|
|
|
/**
|
|
|
|
* Signals that always visible toolbars value should be changed.
|
|
|
|
*
|
|
|
|
* @param {boolean} alwaysVisible - Value to be set in redux store.
|
|
|
|
* @returns {{
|
|
|
|
* type: SET_TOOLBOX_ALWAYS_VISIBLE,
|
|
|
|
* alwaysVisible: boolean
|
|
|
|
* }}
|
|
|
|
*/
|
|
|
|
export function setToolboxAlwaysVisible(alwaysVisible: boolean): Object {
|
|
|
|
return {
|
|
|
|
type: SET_TOOLBOX_ALWAYS_VISIBLE,
|
|
|
|
alwaysVisible
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-04-01 05:52:40 +00:00
|
|
|
/* eslint-disable flowtype/space-before-type-colon */
|
|
|
|
|
2017-04-12 19:06:56 +00:00
|
|
|
/**
|
|
|
|
* Enables/disables the toolbox.
|
|
|
|
*
|
|
|
|
* @param {boolean} enabled - True to enable the toolbox or false to disable it.
|
|
|
|
* @returns {{
|
|
|
|
* type: SET_TOOLBOX_ENABLED,
|
|
|
|
* enabled: boolean
|
|
|
|
* }}
|
|
|
|
*/
|
|
|
|
export function setToolboxEnabled(enabled: boolean): Object {
|
|
|
|
return {
|
|
|
|
type: SET_TOOLBOX_ENABLED,
|
|
|
|
enabled
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-02-16 23:02:40 +00:00
|
|
|
/**
|
|
|
|
* Dispatches an action which sets new timeout and clears the previous one.
|
|
|
|
*
|
|
|
|
* @param {Function} handler - Function to be invoked after the timeout.
|
2017-04-01 05:52:40 +00:00
|
|
|
* @param {number} timeoutMS - Delay.
|
2017-02-16 23:02:40 +00:00
|
|
|
* @returns {{
|
2017-04-01 05:52:40 +00:00
|
|
|
* type: SET_TOOLBOX_TIMEOUT,
|
|
|
|
* handler: Function,
|
|
|
|
* timeoutMS: number
|
2017-02-16 23:02:40 +00:00
|
|
|
* }}
|
|
|
|
*/
|
2017-04-01 05:52:40 +00:00
|
|
|
export function setToolboxTimeout(handler: Function, timeoutMS: number)
|
|
|
|
: Object {
|
2017-02-16 23:02:40 +00:00
|
|
|
return {
|
2017-04-01 05:52:40 +00:00
|
|
|
type: SET_TOOLBOX_TIMEOUT,
|
2017-02-16 23:02:40 +00:00
|
|
|
handler,
|
2017-04-01 05:52:40 +00:00
|
|
|
timeoutMS
|
2017-02-16 23:02:40 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-04-01 05:52:40 +00:00
|
|
|
/* eslint-enable flowtype/space-before-type-colon */
|
|
|
|
|
2017-02-16 23:02:40 +00:00
|
|
|
/**
|
2017-04-01 05:52:40 +00:00
|
|
|
* Dispatches an action which sets new toolbox timeout value.
|
2017-02-16 23:02:40 +00:00
|
|
|
*
|
2017-04-01 05:52:40 +00:00
|
|
|
* @param {number} timeoutMS - Delay.
|
2017-02-16 23:02:40 +00:00
|
|
|
* @returns {{
|
2017-04-01 05:52:40 +00:00
|
|
|
* type: SET_TOOLBOX_TIMEOUT_MS,
|
|
|
|
* timeoutMS: number
|
2017-02-16 23:02:40 +00:00
|
|
|
* }}
|
|
|
|
*/
|
2017-04-01 05:52:40 +00:00
|
|
|
export function setToolboxTimeoutMS(timeoutMS: number): Object {
|
2017-02-16 23:02:40 +00:00
|
|
|
return {
|
2017-04-01 05:52:40 +00:00
|
|
|
type: SET_TOOLBOX_TIMEOUT_MS,
|
|
|
|
timeoutMS
|
2017-02-16 23:02:40 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-04-01 05:52:40 +00:00
|
|
|
* Shows/hides the toolbox.
|
2017-02-16 23:02:40 +00:00
|
|
|
*
|
2017-04-01 05:52:40 +00:00
|
|
|
* @param {boolean} visible - True to show the toolbox or false to hide it.
|
2017-02-16 23:02:40 +00:00
|
|
|
* @returns {{
|
2017-04-01 05:52:40 +00:00
|
|
|
* type: SET_TOOLBOX_VISIBLE,
|
2017-02-16 23:02:40 +00:00
|
|
|
* visible: boolean
|
|
|
|
* }}
|
|
|
|
*/
|
2017-04-01 05:52:40 +00:00
|
|
|
export function setToolboxVisible(visible: boolean): Object {
|
2017-02-16 23:02:40 +00:00
|
|
|
return {
|
2017-04-01 05:52:40 +00:00
|
|
|
type: SET_TOOLBOX_VISIBLE,
|
2017-02-16 23:02:40 +00:00
|
|
|
visible
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-04-01 05:52:40 +00:00
|
|
|
* Enables/disables audio toolbar button.
|
2017-02-16 23:02:40 +00:00
|
|
|
*
|
2017-04-01 05:52:40 +00:00
|
|
|
* @param {boolean} enabled - True if the button should be enabled; otherwise,
|
|
|
|
* false.
|
2017-02-16 23:02:40 +00:00
|
|
|
* @returns {Function}
|
|
|
|
*/
|
|
|
|
export function setVideoIconEnabled(enabled: boolean = false): Function {
|
|
|
|
return (dispatch: Dispatch<*>) => {
|
|
|
|
const i18nKey = enabled ? 'videomute' : 'cameraDisabled';
|
|
|
|
const i18n = `[content]toolbar.${i18nKey}`;
|
|
|
|
const button = {
|
|
|
|
enabled,
|
|
|
|
i18n,
|
|
|
|
toggled: !enabled
|
|
|
|
};
|
|
|
|
|
|
|
|
dispatch(setToolbarButton('camera', button));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Shows etherpad button if it's not shown.
|
|
|
|
*
|
|
|
|
* @returns {Function}
|
|
|
|
*/
|
|
|
|
export function showEtherpadButton(): Function {
|
|
|
|
return (dispatch: Dispatch<*>) => {
|
|
|
|
dispatch(setToolbarButton('etherpad', {
|
|
|
|
hidden: false
|
|
|
|
}));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Event handler for full screen toggled event.
|
|
|
|
*
|
|
|
|
* @param {boolean} isFullScreen - Flag showing whether app in full
|
|
|
|
* screen mode.
|
|
|
|
* @returns {Function}
|
|
|
|
*/
|
|
|
|
export function toggleFullScreen(isFullScreen: boolean): Function {
|
|
|
|
return (dispatch: Dispatch<*>, getState: Function) => {
|
|
|
|
const state = getState();
|
2017-04-01 05:52:40 +00:00
|
|
|
const { primaryToolbarButtons } = state['features/toolbox'];
|
2017-02-16 23:02:40 +00:00
|
|
|
const buttonName = 'fullscreen';
|
|
|
|
const button = primaryToolbarButtons.get(buttonName);
|
|
|
|
|
|
|
|
button.toggled = isFullScreen;
|
|
|
|
|
|
|
|
dispatch(setToolbarButton(buttonName, button));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets negation of button's toggle property.
|
|
|
|
*
|
|
|
|
* @param {string} buttonName - Button key.
|
|
|
|
* @returns {Function}
|
|
|
|
*/
|
|
|
|
export function toggleToolbarButton(buttonName: string): Function {
|
|
|
|
return (dispatch: Dispatch, getState: Function) => {
|
|
|
|
const state = getState();
|
|
|
|
const {
|
|
|
|
primaryToolbarButtons,
|
|
|
|
secondaryToolbarButtons
|
2017-04-01 05:52:40 +00:00
|
|
|
} = state['features/toolbox'];
|
2017-02-16 23:02:40 +00:00
|
|
|
const button
|
|
|
|
= primaryToolbarButtons.get(buttonName)
|
|
|
|
|| secondaryToolbarButtons.get(buttonName);
|
|
|
|
|
|
|
|
dispatch(setToolbarButton(buttonName, {
|
|
|
|
toggled: !button.toggled
|
|
|
|
}));
|
|
|
|
};
|
|
|
|
}
|