12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- var JitsiConnection = require("./JitsiConnection");
- var JitsiConferenceEvents = require("./JitsiConferenceEvents");
- var JitsiConnectionEvents = require("./JitsiConnectionEvents");
- var JitsiConnectionErrors = require("./JitsiConnectionErrors");
- var JitsiConferenceErrors = require("./JitsiConferenceErrors");
- var JitsiTrackEvents = require("./JitsiTrackEvents");
- var JitsiTrackErrors = require("./JitsiTrackErrors");
- var Logger = require("jitsi-meet-logger");
- var RTC = require("./modules/RTC/RTC");
- var Statistics = require("./modules/statistics/statistics");
-
- /**
- * Namespace for the interface of Jitsi Meet Library.
- */
- var LibJitsiMeet = {
-
- JitsiConnection: JitsiConnection,
- events: {
- conference: JitsiConferenceEvents,
- connection: JitsiConnectionEvents,
- track: JitsiTrackEvents
- },
- errors: {
- conference: JitsiConferenceErrors,
- connection: JitsiConnectionErrors,
- track: JitsiTrackErrors
- },
- logLevels: Logger.levels,
- init: function (options) {
- return RTC.init(options || {});
- },
- setLogLevel: function (level) {
- Logger.setLogLevel(level);
- },
- /**
- * Creates the media tracks and returns them trough the callback.
- * @param options Object with properties / settings specifying the tracks which should be created.
- * should be created or some additional configurations about resolution for example.
- * @param {Array} options.devices the devices that will be requested
- * @param {string} options.resolution resolution constraints
- * @param {bool} options.dontCreateJitsiTrack if <tt>true</tt> objects with the following structure {stream: the Media Stream,
- * type: "audio" or "video", videoType: "camera" or "desktop"}
- * will be returned trough the Promise, otherwise JitsiTrack objects will be returned.
- * @param {string} options.cameraDeviceId
- * @param {string} options.micDeviceId
- * @returns {Promise.<{Array.<JitsiTrack>}, JitsiConferenceError>}
- * A promise that returns an array of created JitsiTracks if resolved,
- * or a JitsiConferenceError if rejected.
- */
- createLocalTracks: function (options) {
- return RTC.obtainAudioAndVideoPermissions(options || {}).then(
- function(tracks) {
- if(!RTC.options.disableAudioLevels)
- for(var i = 0; i < tracks.length; i++) {
- var track = tracks[i];
- var mStream = track.getOriginalStream();
- if(track.getType() === "audio"){
- Statistics.startLocalStats(mStream,
- track.setAudioLevel.bind(track));
- track.addEventListener(
- JitsiTrackEvents.TRACK_STOPPED,
- function(){
- Statistics.stopLocalStats(mStream);
- });
- }
- }
- return tracks;
- });
- },
- isDeviceListAvailable: function () {
- return RTC.isDeviceListAvailable();
- },
- enumerateDevices: function (callback) {
- RTC.enumerateDevices(callback);
- }
- };
-
- require("es6-promise").polyfill()
- //Setups the promise object.
- window.Promise = window.Promise || require("es6-promise").Promise;
-
- module.exports = LibJitsiMeet;
|