mirror of
https://github.com/element-hq/element-web.git
synced 2024-12-14 23:41:29 +03:00
f6e0cd9a03
instead, retry with just audio. Also when mounted, check if the user has given enough permissions to return non-empty labels for the devices, something both ff & chrome do if you haven't going through the permissions popup yet. If not, show the permissions button.
87 lines
3.2 KiB
JavaScript
87 lines
3.2 KiB
JavaScript
/*
|
|
Copyright 2017 Michael Telatynski <7t3chguy@gmail.com>
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
import * as Matrix from 'matrix-js-sdk';
|
|
import SettingsStore, {SettingLevel} from "./settings/SettingsStore";
|
|
|
|
export default {
|
|
hasAnyLabeledDevices: async function() {
|
|
const devices = await navigator.mediaDevices.enumerateDevices();
|
|
return devices.some(d => !!d.label);
|
|
},
|
|
|
|
getDevices: function() {
|
|
// Only needed for Electron atm, though should work in modern browsers
|
|
// once permission has been granted to the webapp
|
|
return navigator.mediaDevices.enumerateDevices().then(function(devices) {
|
|
const audiooutput = [];
|
|
const audioinput = [];
|
|
const videoinput = [];
|
|
|
|
devices.forEach((device) => {
|
|
switch (device.kind) {
|
|
case 'audiooutput': audiooutput.push(device); break;
|
|
case 'audioinput': audioinput.push(device); break;
|
|
case 'videoinput': videoinput.push(device); break;
|
|
}
|
|
});
|
|
|
|
// console.log("Loaded WebRTC Devices", mediaDevices);
|
|
return {
|
|
audiooutput,
|
|
audioinput,
|
|
videoinput,
|
|
};
|
|
}, (error) => { console.log('Unable to refresh WebRTC Devices: ', error); });
|
|
},
|
|
|
|
loadDevices: function() {
|
|
const audioOutDeviceId = SettingsStore.getValue("webrtc_audiooutput");
|
|
const audioDeviceId = SettingsStore.getValue("webrtc_audioinput");
|
|
const videoDeviceId = SettingsStore.getValue("webrtc_videoinput");
|
|
|
|
Matrix.setMatrixCallAudioOutput(audioOutDeviceId);
|
|
Matrix.setMatrixCallAudioInput(audioDeviceId);
|
|
Matrix.setMatrixCallVideoInput(videoDeviceId);
|
|
},
|
|
|
|
setAudioOutput: function(deviceId) {
|
|
SettingsStore.setValue("webrtc_audiooutput", null, SettingLevel.DEVICE, deviceId);
|
|
Matrix.setMatrixCallAudioOutput(deviceId);
|
|
},
|
|
|
|
setAudioInput: function(deviceId) {
|
|
SettingsStore.setValue("webrtc_audioinput", null, SettingLevel.DEVICE, deviceId);
|
|
Matrix.setMatrixCallAudioInput(deviceId);
|
|
},
|
|
|
|
setVideoInput: function(deviceId) {
|
|
SettingsStore.setValue("webrtc_videoinput", null, SettingLevel.DEVICE, deviceId);
|
|
Matrix.setMatrixCallVideoInput(deviceId);
|
|
},
|
|
|
|
getAudioOutput: function() {
|
|
return SettingsStore.getValueAt(SettingLevel.DEVICE, "webrtc_audiooutput");
|
|
},
|
|
|
|
getAudioInput: function() {
|
|
return SettingsStore.getValueAt(SettingLevel.DEVICE, "webrtc_audioinput");
|
|
},
|
|
|
|
getVideoInput: function() {
|
|
return SettingsStore.getValueAt(SettingLevel.DEVICE, "webrtc_videoinput");
|
|
},
|
|
};
|