// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 import { DefaultBrowserBehavior } from 'amazon-chime-sdk-js'; import React, { useEffect, useState } from 'react'; import { useAudioOutputs } from '../../../providers/DevicesProvider'; import { useLocalAudioOutput } from '../../../providers/LocalAudioOutputProvider'; import { useLogger } from '../../../providers/LoggerProvider'; import { useMeetingManager } from '../../../providers/MeetingProvider'; import { isOptionActive } from '../../../utils/device-utils'; import { ControlBarButton } from '../../ui/ControlBar/ControlBarButton'; import { Sound } from '../../ui/icons'; import { PopOverItemProps } from '../../ui/PopOver/PopOverItem'; import { BaseSdkProps } from '../Base'; interface Props extends BaseSdkProps { /** The label that will be shown for audio output speaker control, it defaults to `Speaker`. */ label?: string; } export const AudioOutputControl: React.FC> = ({ label = 'Speaker', ...rest }) => { const logger = useLogger(); const meetingManager = useMeetingManager(); const { devices, selectedDevice } = useAudioOutputs(); const { isAudioOn, toggleAudio } = useLocalAudioOutput(); const [dropdownOptions, setDropdownOptions] = useState( [] ); useEffect(() => { const handleClick = async (deviceId: string): Promise => { try { if (new DefaultBrowserBehavior().supportsSetSinkId()) { await meetingManager.startAudioOutputDevice(deviceId); } else { logger.error( 'AudioOutputControl cannot select audio output device because browser does not support setSinkId operation.' ); } } catch (error) { logger.error('AudioOutputControl failed to select audio output device'); } }; const getDropdownOptions = async (): Promise => { const dropdownOptions = await Promise.all( devices.map(async (device) => ({ children: {device.label}, checked: await isOptionActive(selectedDevice, device.deviceId), onClick: async () => await handleClick(device.deviceId), })) ); setDropdownOptions(dropdownOptions); }; getDropdownOptions(); }, [ devices, selectedDevice, meetingManager, meetingManager.startAudioOutputDevice, ]); return ( <> } onClick={toggleAudio} label={label} popOver={dropdownOptions.length ? dropdownOptions : null} {...rest} /> ); }; export default AudioOutputControl;