mirror of
https://github.com/element-hq/element-web.git
synced 2024-12-16 01:01:41 +03:00
1d9d0cd7be
Turns out a lot of the typescript warnings about improper warnings were correct. TypeScript appears to be pulling in two copies of the js-sdk when we do this, which can lead to type conflicts (or worse: the wrong code entirely). We fix this at the webpack level by explicitly importing from `src`, but some alternative build structures have broken tests because of this - jest ends up pulling in the "wrong" js-sdk, breaking things.
88 lines
3.2 KiB
JavaScript
88 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 SettingsStore from "./settings/SettingsStore";
|
|
import {SettingLevel} from "./settings/SettingLevel";
|
|
import {setMatrixCallAudioInput, setMatrixCallAudioOutput, setMatrixCallVideoInput} from "matrix-js-sdk/src/matrix";
|
|
|
|
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");
|
|
|
|
setMatrixCallAudioOutput(audioOutDeviceId);
|
|
setMatrixCallAudioInput(audioDeviceId);
|
|
setMatrixCallVideoInput(videoDeviceId);
|
|
},
|
|
|
|
setAudioOutput: function(deviceId) {
|
|
SettingsStore.setValue("webrtc_audiooutput", null, SettingLevel.DEVICE, deviceId);
|
|
setMatrixCallAudioOutput(deviceId);
|
|
},
|
|
|
|
setAudioInput: function(deviceId) {
|
|
SettingsStore.setValue("webrtc_audioinput", null, SettingLevel.DEVICE, deviceId);
|
|
setMatrixCallAudioInput(deviceId);
|
|
},
|
|
|
|
setVideoInput: function(deviceId) {
|
|
SettingsStore.setValue("webrtc_videoinput", null, SettingLevel.DEVICE, deviceId);
|
|
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");
|
|
},
|
|
};
|