1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- // @ts-expect-error
- import keyboardShortcut from '../../../modules/keyboardshortcut/keyboardshortcut';
- import { IStateful } from '../base/app/types';
- import { createLocalTrack } from '../base/lib-jitsi-meet/functions';
- import { toState } from '../base/redux/functions';
- import { isPrejoinPageVisible } from '../prejoin/functions';
-
- export * from './functions.any';
-
- /**
- * Returns a promise which resolves with a list of objects containing
- * all the video jitsiTracks and appropriate errors for the given device ids.
- *
- * @param {string[]} ids - The list of the camera ids for which to create tracks.
- * @param {number} [timeout] - A timeout for the createLocalTrack function call.
- *
- * @returns {Promise<Object[]>}
- */
- export function createLocalVideoTracks(ids: string[], timeout?: number) {
- return Promise.all(ids.map(deviceId => createLocalTrack('video', deviceId, timeout)
- .then((jitsiTrack: any) => {
- return {
- jitsiTrack,
- deviceId
- };
- })
- .catch(() => {
- return {
- jitsiTrack: null,
- deviceId,
- error: 'deviceSelection.previewUnavailable'
- };
- })));
- }
-
-
- /**
- * Returns a promise which resolves with a list of objects containing
- * the audio track and the corresponding audio device information.
- *
- * @param {Object[]} devices - A list of microphone devices.
- * @param {number} [timeout] - A timeout for the createLocalTrack function call.
- * @returns {Promise<{
- * deviceId: string,
- * hasError: boolean,
- * jitsiTrack: Object,
- * label: string
- * }[]>}
- */
- export function createLocalAudioTracks(devices: Array<{ deviceId: string; label: string; }>, timeout?: number) {
- return Promise.all(
- devices.map(async ({ deviceId, label }) => {
- let jitsiTrack = null;
- let hasError = false;
-
- try {
- jitsiTrack = await createLocalTrack('audio', deviceId, timeout);
- } catch (err) {
- hasError = true;
- }
-
- return {
- deviceId,
- hasError,
- jitsiTrack,
- label
- };
- }));
- }
-
- /**
- * Returns the properties for the "Shortcuts" tab from settings dialog from Redux
- * state.
- *
- * @param {(Function|Object)} stateful -The (whole) redux state, or redux's
- * {@code getState} function to be used to retrieve the state.
- * @param {boolean} isDisplayedOnWelcomePage - Indicates whether the shortcuts dialog is displayed on the
- * welcome page or not.
- * @returns {Object} - The properties for the "Shortcuts" tab from settings
- * dialog.
- */
- export function getShortcutsTabProps(stateful: IStateful, isDisplayedOnWelcomePage?: boolean) {
- const state = toState(stateful);
-
- return {
- displayShortcuts: !isDisplayedOnWelcomePage && !isPrejoinPageVisible(state),
- keyboardShortcutsEnabled: keyboardShortcut.getEnabled()
- };
- }
|