|
42 | 42 | app.router.navigate(path, {'trigger': true});
|
43 | 43 | },
|
44 | 44 | 'join': function() {
|
| 45 | + /** Before use WebRTC checking WebRTC is avaible */ |
| 46 | + if (!QB.webrtc) { |
| 47 | + alert('Error: ' + CONFIG.MESSAGES.webrtc_not_avaible); |
| 48 | + return; |
| 49 | + } |
| 50 | + |
45 | 51 | this.container
|
46 | 52 | .removeClass('page-dashboard')
|
47 | 53 | .addClass('page-join');
|
|
53 | 59 | app.calleesAnwered = [];
|
54 | 60 | app.users = [];
|
55 | 61 | app.videoMain = 0;
|
| 62 | + |
| 63 | + |
56 | 64 | },
|
57 | 65 | 'dashboard': function() {
|
58 | 66 | if (_.isEmpty(app.caller)) {
|
|
69 | 77 | /** render skelet */
|
70 | 78 | $('.j-dashboard').append( $('#dashboard_tpl').html() );
|
71 | 79 |
|
72 |
| - /** Before use WebRTC checking WebRTC is avaible */ |
73 |
| - if (!QB.webrtc) { |
74 |
| - app.helpers.stateBoard = new app.helpers.StateBoard('.j-state_board', { |
75 |
| - title: 'webrtc_not_avaible', |
76 |
| - isError: 'qb-error' |
77 |
| - }); |
78 |
| - |
79 |
| - alert('Error: ' + CONFIG.MESSAGES.webrtc_not_avaible); |
80 |
| - return; |
81 |
| - } |
82 |
| - |
83 | 80 | /** render stateBoard */
|
84 | 81 | app.helpers.stateBoard = new app.helpers.StateBoard('.j-state_board', {
|
85 | 82 | title: 'tpl_default',
|
|
115 | 112 | if(devices.length > 1) {
|
116 | 113 | var $select = $('.j-source');
|
117 | 114 |
|
| 115 | + for (var i = 0; i !== devices.length; ++i) { |
| 116 | + var deviceInfo = devices[i], |
| 117 | + option = document.createElement('option'); |
| 118 | + |
| 119 | + option.value = deviceInfo.deviceId; |
| 120 | + |
| 121 | + if (deviceInfo.kind === 'videoinput') { |
| 122 | + option.text = deviceInfo.label || 'Camera ' + (i + 1); |
| 123 | + $select.append(option); |
| 124 | + } |
| 125 | + } |
| 126 | + |
118 | 127 | $select.removeClass('invisible');
|
119 | 128 | }
|
120 | 129 | }).catch(function(error) {
|
|
226 | 235 | /** Call / End of call */
|
227 | 236 | $(document).on('click', '.j-actions', function() {
|
228 | 237 | var $btn = $(this),
|
| 238 | + $videoSourceFilter = $(ui.sourceFilter), |
229 | 239 | videoElems = '',
|
230 | 240 | mediaParams = {
|
231 | 241 | audio: true,
|
232 |
| - video: true, |
| 242 | + video: { |
| 243 | + optional: [ |
| 244 | + {sourceId: $videoSourceFilter.val() ? $videoSourceFilter.val() : undefined} |
| 245 | + ] |
| 246 | + }, |
233 | 247 | options: {
|
234 | 248 | muted: true,
|
235 | 249 | mirror: true
|
|
302 | 316 |
|
303 | 317 | $('.j-callees').append(videoElems);
|
304 | 318 |
|
| 319 | + $videoSourceFilter.attr('disabled', true); |
305 | 320 | $btn.addClass('hangup');
|
306 | 321 | app.helpers.setFooterPosition();
|
307 | 322 | }
|
|
522 | 537 |
|
523 | 538 | $('.j-actions').removeClass('hangup');
|
524 | 539 | $('.j-caller__ctrl').removeClass('active');
|
| 540 | + $(ui.sourceFilter).attr('disabled', false); |
525 | 541 | $('.j-callees').empty();
|
526 | 542 |
|
527 | 543 | app.currentSession.detachMediaStream('main_video');
|
|
0 commit comments