change device data structure to array of objects

so that we can set falsey values, for unsetting device
                               most dolphinately needs testing

Signed-off-by: Michael Telatynski <7t3chguy@gmail.com>
pull/21833/head
Michael Telatynski 2017-06-01 23:25:44 +01:00
parent aa90d6b097
commit dd4480f8c3
3 changed files with 17 additions and 9 deletions

View File

@ -23,15 +23,15 @@ export default {
// Only needed for Electron atm, though should work in modern browsers // Only needed for Electron atm, though should work in modern browsers
// once permission has been granted to the webapp // once permission has been granted to the webapp
return navigator.mediaDevices.enumerateDevices().then(function(devices) { return navigator.mediaDevices.enumerateDevices().then(function(devices) {
const audioIn = {}; const audioIn = [];
const videoIn = {}; const videoIn = [];
if (devices.some((device) => !device.label)) return false; if (devices.some((device) => !device.label)) return false;
devices.forEach((device) => { devices.forEach((device) => {
switch (device.kind) { switch (device.kind) {
case 'audioinput': audioIn[device.deviceId] = device.label; break; case 'audioinput': audioIn.push(device); break;
case 'videoinput': videoIn[device.deviceId] = device.label; break; case 'videoinput': videoIn.push(device); break;
} }
}); });

View File

@ -269,8 +269,8 @@ module.exports = React.createClass({
if (this._unmounted) return; if (this._unmounted) return;
this.setState({ this.setState({
mediaDevices, mediaDevices,
activeAudioInput: this._localSettings['webrtc_audioinput'] || 'default', activeAudioInput: this._localSettings['webrtc_audioinput'],
activeVideoInput: this._localSettings['webrtc_videoinput'] || 'default', activeVideoInput: this._localSettings['webrtc_videoinput'],
}); });
}); });
}, },
@ -902,7 +902,7 @@ module.exports = React.createClass({
}, },
_mapWebRtcDevicesToSpans: function(devices) { _mapWebRtcDevicesToSpans: function(devices) {
return Object.keys(devices).map((deviceId) => <span key={deviceId}>{devices[deviceId]}</span>); return devices.map((device) => <span key={device.deviceId}>{devices[device.deviceId]}</span>);
}, },
_setAudioInput: function(deviceId) { _setAudioInput: function(deviceId) {
@ -951,8 +951,14 @@ module.exports = React.createClass({
let microphoneDropdown = <p>{_t('No Microphones detected')}</p>; let microphoneDropdown = <p>{_t('No Microphones detected')}</p>;
let webcamDropdown = <p>{_t('No Webcams detected')}</p>; let webcamDropdown = <p>{_t('No Webcams detected')}</p>;
const defaultOption = {
deviceId: undefined,
label: _t('Default Device'),
};
const audioInputs = this.state.mediaDevices.audioinput; const audioInputs = this.state.mediaDevices.audioinput;
if (Object.keys(audioInputs).length > 0) { if (audioInputs.length > 0) {
audioInputs.unshift(defaultOption);
microphoneDropdown = <div> microphoneDropdown = <div>
<h4>Microphone</h4> <h4>Microphone</h4>
<Dropdown <Dropdown
@ -965,7 +971,8 @@ module.exports = React.createClass({
} }
const videoInputs = this.state.mediaDevices.videoinput; const videoInputs = this.state.mediaDevices.videoinput;
if (Object.keys(videoInputs).length > 0) { if (videoInputs.length > 0) {
videoInputs.unshift(defaultOption);
webcamDropdown = <div> webcamDropdown = <div>
<h4>Cameras</h4> <h4>Cameras</h4>
<Dropdown <Dropdown

View File

@ -135,6 +135,7 @@
"No Webcams detected": "No Webcams detected", "No Webcams detected": "No Webcams detected",
"No media permissions": "No media permissions", "No media permissions": "No media permissions",
"You may need to manually permit Riot to access your microphone/webcam": "You may need to manually permit Riot to access your microphone/webcam", "You may need to manually permit Riot to access your microphone/webcam": "You may need to manually permit Riot to access your microphone/webcam",
"Default Device": "Default Device",
"Advanced": "Advanced", "Advanced": "Advanced",
"Algorithm": "Algorithm", "Algorithm": "Algorithm",
"Always show message timestamps": "Always show message timestamps", "Always show message timestamps": "Always show message timestamps",