2022-07-18 13:16:08 +00:00
|
|
|
/* eslint-disable lines-around-comment */
|
2022-07-11 12:30:37 +00:00
|
|
|
import React, { useCallback, useState } from 'react';
|
2022-05-06 10:14:10 +00:00
|
|
|
import { View, TouchableOpacity } from 'react-native';
|
|
|
|
import { useDispatch, useSelector } from 'react-redux';
|
2022-07-11 12:30:37 +00:00
|
|
|
|
2022-05-06 10:14:10 +00:00
|
|
|
import {
|
|
|
|
createShortcutEvent,
|
|
|
|
ACTION_SHORTCUT_PRESSED as PRESSED,
|
|
|
|
ACTION_SHORTCUT_RELEASED as RELEASED
|
2022-09-07 08:20:05 +00:00
|
|
|
} from '../../../../analytics/AnalyticsEvents';
|
|
|
|
import { sendAnalytics } from '../../../../analytics/functions';
|
2022-09-05 11:24:13 +00:00
|
|
|
import { IState } from '../../../../app/types';
|
2022-07-18 13:16:08 +00:00
|
|
|
// @ts-ignore
|
2022-05-06 10:14:10 +00:00
|
|
|
import { getFeatureFlag, AUDIO_MUTE_BUTTON_ENABLED } from '../../../../base/flags';
|
2022-07-27 09:56:07 +00:00
|
|
|
import Icon from '../../../../base/icons/components/Icon';
|
2022-09-06 17:32:20 +00:00
|
|
|
import { IconMicrophone, IconMicrophoneEmptySlash } from '../../../../base/icons/svg';
|
2022-09-05 11:24:13 +00:00
|
|
|
import { MEDIA_TYPE } from '../../../../base/media/constants';
|
2022-07-18 13:16:08 +00:00
|
|
|
// @ts-ignore
|
2022-05-06 10:14:10 +00:00
|
|
|
import { isLocalTrackMuted } from '../../../../base/tracks';
|
2022-07-18 13:16:08 +00:00
|
|
|
// @ts-ignore
|
2022-05-06 10:14:10 +00:00
|
|
|
import { isAudioMuteButtonDisabled } from '../../../../toolbox/functions.any';
|
2022-07-18 13:16:08 +00:00
|
|
|
// @ts-ignore
|
2022-05-06 10:14:10 +00:00
|
|
|
import { muteLocal } from '../../../../video-menu/actions';
|
|
|
|
|
2022-07-18 13:16:08 +00:00
|
|
|
// @ts-ignore
|
2022-05-06 10:14:10 +00:00
|
|
|
import styles from './styles';
|
|
|
|
|
|
|
|
const LONG_PRESS = 'long.press';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Implements a round audio mute/unmute button of a custom size.
|
|
|
|
*
|
|
|
|
* @returns {JSX.Element} - The audio mute round button.
|
|
|
|
*/
|
2022-09-08 09:52:36 +00:00
|
|
|
const MicrophoneButton = (): JSX.Element | null => {
|
2022-05-06 10:14:10 +00:00
|
|
|
const dispatch = useDispatch();
|
2022-09-05 11:24:13 +00:00
|
|
|
const audioMuted = useSelector((state: IState) => isLocalTrackMuted(state['features/base/tracks'],
|
|
|
|
MEDIA_TYPE.AUDIO));
|
2022-05-06 10:14:10 +00:00
|
|
|
const disabled = useSelector(isAudioMuteButtonDisabled);
|
|
|
|
const enabledFlag = useSelector(state => getFeatureFlag(state, AUDIO_MUTE_BUTTON_ENABLED, true));
|
|
|
|
const [ longPress, setLongPress ] = useState(false);
|
|
|
|
|
|
|
|
if (!enabledFlag) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
const onPressIn = useCallback(() => {
|
|
|
|
!disabled && dispatch(muteLocal(!audioMuted, MEDIA_TYPE.AUDIO));
|
|
|
|
}, [ audioMuted, disabled ]);
|
|
|
|
|
|
|
|
const onLongPress = useCallback(() => {
|
2022-07-11 12:30:37 +00:00
|
|
|
if (!disabled && !audioMuted) {
|
2022-05-06 10:14:10 +00:00
|
|
|
sendAnalytics(createShortcutEvent(
|
|
|
|
'push.to.talk',
|
|
|
|
PRESSED,
|
|
|
|
{},
|
|
|
|
LONG_PRESS));
|
|
|
|
setLongPress(true);
|
|
|
|
}
|
2022-07-11 12:30:37 +00:00
|
|
|
}, [ audioMuted, disabled, setLongPress ]);
|
2022-05-06 10:14:10 +00:00
|
|
|
|
|
|
|
const onPressOut = useCallback(() => {
|
|
|
|
if (longPress) {
|
|
|
|
setLongPress(false);
|
|
|
|
sendAnalytics(createShortcutEvent(
|
|
|
|
'push.to.talk',
|
|
|
|
RELEASED,
|
|
|
|
{},
|
|
|
|
LONG_PRESS
|
|
|
|
));
|
|
|
|
dispatch(muteLocal(true, MEDIA_TYPE.AUDIO));
|
|
|
|
}
|
2022-07-11 12:30:37 +00:00
|
|
|
}, [ longPress, setLongPress ]);
|
2022-05-06 10:14:10 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<TouchableOpacity
|
2022-07-11 12:30:37 +00:00
|
|
|
onLongPress = { onLongPress }
|
2022-05-06 10:14:10 +00:00
|
|
|
onPressIn = { onPressIn }
|
2022-07-11 12:30:37 +00:00
|
|
|
onPressOut = { onPressOut } >
|
2022-05-06 10:14:10 +00:00
|
|
|
<View
|
|
|
|
style = { [
|
|
|
|
styles.microphoneStyles.container,
|
|
|
|
!audioMuted && styles.microphoneStyles.unmuted
|
|
|
|
] }>
|
|
|
|
<View
|
|
|
|
style = { styles.microphoneStyles.iconContainer }>
|
|
|
|
<Icon
|
|
|
|
src = { audioMuted ? IconMicrophoneEmptySlash : IconMicrophone }
|
|
|
|
style = { styles.microphoneStyles.icon } />
|
|
|
|
</View>
|
|
|
|
</View>
|
|
|
|
</TouchableOpacity>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default MicrophoneButton;
|