34 lines
1.1 KiB
TypeScript
34 lines
1.1 KiB
TypeScript
import { useCallback } from 'react';
|
|
import useCurrentUser from '/imports/ui/core/hooks/useCurrentUser';
|
|
import logger from '/imports/startup/client/logger';
|
|
import AudioManager from '/imports/ui/services/audio-manager';
|
|
import useToggleVoice from './useToggleVoice';
|
|
import useWhoIsTalking from '/imports/ui/core/hooks/useWhoIsTalking';
|
|
|
|
const useMuteMicrophone = () => {
|
|
const { data: currentUser } = useCurrentUser((u) => ({
|
|
userId: u.userId,
|
|
}));
|
|
const { voices: talkingUsers } = useWhoIsTalking();
|
|
const toggleVoice = useToggleVoice();
|
|
|
|
const currentUserVoice = currentUser?.userId
|
|
? talkingUsers[currentUser.userId]
|
|
: null;
|
|
const muted = Boolean(currentUserVoice?.muted);
|
|
const userId = currentUser?.userId;
|
|
|
|
return useCallback(() => {
|
|
if (!muted) {
|
|
logger.info({
|
|
logCode: 'audiomanager_mute_audio',
|
|
extraInfo: { logType: 'user_action' },
|
|
}, 'User wants to leave conference. Microphone muted');
|
|
AudioManager.setSenderTrackEnabled(false);
|
|
toggleVoice(userId as string, true);
|
|
}
|
|
}, [muted, userId, toggleVoice]);
|
|
};
|
|
|
|
export default useMuteMicrophone;
|