import clsx from 'clsx'; import React, { useRef } from 'react'; import { IconCheck } from '../../../../base/icons/svg'; import Button from '../../../../base/ui/components/web/Button'; import ContextMenuItem from '../../../../base/ui/components/web/ContextMenuItem'; import { BUTTON_TYPES, TEXT_OVERFLOW_TYPES } from '../../../../base/ui/constants.any'; import logger from '../../../logger'; const TEST_SOUND_PATH = 'sounds/ring.mp3'; /** * The type of the React {@code Component} props of {@link SpeakerEntry}. */ interface IProps { /** * The text label for the entry. */ children: string; /** * The deviceId of the speaker. */ deviceId: string; /** * Flag controlling the selection state of the entry. */ index: number; /** * Flag controlling the selection state of the entry. */ isSelected: boolean; /** * Flag controlling the selection state of the entry. */ length: number; listHeaderId: string; /** * Click handler for the component. */ onClick: Function; } /** * Implements a React {@link Component} which displays an audio * output settings entry. The user can click and play a test sound. * * @param {IProps} props - Component props. * @returns {JSX.Element} */ const SpeakerEntry = (props: IProps) => { const audioRef = useRef(null); /** * Click handler for the entry. * * @returns {void} */ function _onClick() { props.onClick(props.deviceId); } /** * Key pressed handler for the entry. * * @param {Object} e - The event. * @private * * @returns {void} */ function _onKeyPress(e: React.KeyboardEvent) { if (e.key === ' ') { e.preventDefault(); props.onClick(props.deviceId); } } /** * Click handler for Test button. * Sets the current audio output id and plays a sound. * * @param {Object} e - The synthetic event. * @returns {void} */ async function _onTestButtonClick(e: React.KeyboardEvent | React.MouseEvent) { e.stopPropagation(); try { // @ts-ignore await audioRef.current?.setSinkId(props.deviceId); audioRef.current?.play(); } catch (err) { logger.log('Could not set sink id', err); } } const { children, isSelected, index, deviceId, length, listHeaderId } = props; const deviceTextId = `choose_speaker${deviceId}`; const labelledby = `${listHeaderId} ${deviceTextId} `; /* eslint-disable react/jsx-no-bind */ return (
  • ); }; export default SpeakerEntry;