GitHub

Source

useMediaDeviceSelect

The useMediaDeviceSelect hook is used to implement the MediaDeviceSelect component and returns o.a. the list of devices of a given kind (audioinput or videoinput), the currently active device and a function to set the the active device.

Import

import { useMediaDeviceSelect } from "@livekit/components-react";

Usage

const { devices, activeDeviceId, setActiveMediaDevice } = useMediaDeviceSelect({
kind: "audioinput"
});

Properties

{ kind, room, track, requestPermissions, onError, }.kindMediaDeviceKindRequired
{ kind, room, track, requestPermissions, onError, }.onError(e: Error) => voidOptional

this callback gets called if an error is thrown when failing to select a device and also if a user denied permissions, eventhough the requestPermissions option is set to true. Most commonly this will emit a MediaDeviceError

{ kind, room, track, requestPermissions, onError, }.requestPermissionsbooleanOptional

this will call getUserMedia if the permissions are not yet given to enumerate the devices with device labels. in some browsers multiple calls to getUserMedia result in multiple permission prompts. It's generally advised only flip this to true, once a (preview) track has been acquired successfully with the appropriate permissions.

{ kind, room, track, requestPermissions, onError, }.roomRoomOptional
{ kind, room, track, requestPermissions, onError, }.trackLocalAudioTrack | LocalVideoTrackOptional

Returns

{
devices: MediaDeviceInfo[];
className: string;
activeDeviceId: string;
setActiveMediaDevice: (id: string, options?: import('@livekit/components-core').SetMediaDeviceOptions) => Promise<void>;
}