|
|
@@ -1,282 +0,0 @@
|
|
1
|
|
-/* global $, JitsiMeetJS */
|
|
2
|
|
-
|
|
3
|
|
-const options = {
|
|
4
|
|
- hosts: {
|
|
5
|
|
- domain: 'jitsi-meet.example.com',
|
|
6
|
|
- muc: 'conference.jitsi-meet.example.com'
|
|
7
|
|
- },
|
|
8
|
|
- bosh: '//jitsi-meet.example.com/http-bind'
|
|
9
|
|
-};
|
|
10
|
|
-
|
|
11
|
|
-const confOptions = {
|
|
12
|
|
-};
|
|
13
|
|
-
|
|
14
|
|
-let connection = null;
|
|
15
|
|
-let isJoined = false;
|
|
16
|
|
-let room = null;
|
|
17
|
|
-
|
|
18
|
|
-let localTracks = [];
|
|
19
|
|
-const remoteTracks = {};
|
|
20
|
|
-
|
|
21
|
|
-/**
|
|
22
|
|
- * Handles local tracks.
|
|
23
|
|
- * @param tracks Array with JitsiTrack objects
|
|
24
|
|
- */
|
|
25
|
|
-function onLocalTracks(tracks) {
|
|
26
|
|
- localTracks = tracks;
|
|
27
|
|
- for (let i = 0; i < localTracks.length; i++) {
|
|
28
|
|
- localTracks[i].addEventListener(
|
|
29
|
|
- JitsiMeetJS.events.track.TRACK_AUDIO_LEVEL_CHANGED,
|
|
30
|
|
- audioLevel => console.log(`Audio Level local: ${audioLevel}`));
|
|
31
|
|
- localTracks[i].addEventListener(
|
|
32
|
|
- JitsiMeetJS.events.track.TRACK_MUTE_CHANGED,
|
|
33
|
|
- () => console.log('local track muted'));
|
|
34
|
|
- localTracks[i].addEventListener(
|
|
35
|
|
- JitsiMeetJS.events.track.LOCAL_TRACK_STOPPED,
|
|
36
|
|
- () => console.log('local track stoped'));
|
|
37
|
|
- localTracks[i].addEventListener(
|
|
38
|
|
- JitsiMeetJS.events.track.TRACK_AUDIO_OUTPUT_CHANGED,
|
|
39
|
|
- deviceId =>
|
|
40
|
|
- console.log(
|
|
41
|
|
- `track audio output device was changed to ${deviceId}`));
|
|
42
|
|
- if (localTracks[i].getType() === 'video') {
|
|
43
|
|
- $('body').append(`<video autoplay='1' id='localVideo${i}' />`);
|
|
44
|
|
- localTracks[i].attach($(`#localVideo${i}`)[0]);
|
|
45
|
|
- } else {
|
|
46
|
|
- $('body').append(
|
|
47
|
|
- `<audio autoplay='1' muted='true' id='localAudio${i}' />`);
|
|
48
|
|
- localTracks[i].attach($(`#localAudio${i}`)[0]);
|
|
49
|
|
- }
|
|
50
|
|
- if (isJoined) {
|
|
51
|
|
- room.addTrack(localTracks[i]);
|
|
52
|
|
- }
|
|
53
|
|
- }
|
|
54
|
|
-}
|
|
55
|
|
-
|
|
56
|
|
-/**
|
|
57
|
|
- * Handles remote tracks
|
|
58
|
|
- * @param track JitsiTrack object
|
|
59
|
|
- */
|
|
60
|
|
-function onRemoteTrack(track) {
|
|
61
|
|
- if (track.isLocal()) {
|
|
62
|
|
- return;
|
|
63
|
|
- }
|
|
64
|
|
- const participant = track.getParticipantId();
|
|
65
|
|
-
|
|
66
|
|
- if (!remoteTracks[participant]) {
|
|
67
|
|
- remoteTracks[participant] = [];
|
|
68
|
|
- }
|
|
69
|
|
- const idx = remoteTracks[participant].push(track);
|
|
70
|
|
-
|
|
71
|
|
- track.addEventListener(
|
|
72
|
|
- JitsiMeetJS.events.track.TRACK_AUDIO_LEVEL_CHANGED,
|
|
73
|
|
- audioLevel => console.log(`Audio Level remote: ${audioLevel}`));
|
|
74
|
|
- track.addEventListener(
|
|
75
|
|
- JitsiMeetJS.events.track.TRACK_MUTE_CHANGED,
|
|
76
|
|
- () => console.log('remote track muted'));
|
|
77
|
|
- track.addEventListener(
|
|
78
|
|
- JitsiMeetJS.events.track.LOCAL_TRACK_STOPPED,
|
|
79
|
|
- () => console.log('remote track stoped'));
|
|
80
|
|
- track.addEventListener(JitsiMeetJS.events.track.TRACK_AUDIO_OUTPUT_CHANGED,
|
|
81
|
|
- deviceId =>
|
|
82
|
|
- console.log(
|
|
83
|
|
- `track audio output device was changed to ${deviceId}`));
|
|
84
|
|
- const id = participant + track.getType() + idx;
|
|
85
|
|
-
|
|
86
|
|
- if (track.getType() === 'video') {
|
|
87
|
|
- $('body').append(
|
|
88
|
|
- `<video autoplay='1' id='${participant}video${idx}' />`);
|
|
89
|
|
- } else {
|
|
90
|
|
- $('body').append(
|
|
91
|
|
- `<audio autoplay='1' id='${participant}audio${idx}' />`);
|
|
92
|
|
- }
|
|
93
|
|
- track.attach($(`#${id}`)[0]);
|
|
94
|
|
-}
|
|
95
|
|
-
|
|
96
|
|
-/**
|
|
97
|
|
- * That function is executed when the conference is joined
|
|
98
|
|
- */
|
|
99
|
|
-function onConferenceJoined() {
|
|
100
|
|
- console.log('conference joined!');
|
|
101
|
|
- isJoined = true;
|
|
102
|
|
- for (let i = 0; i < localTracks.length; i++) {
|
|
103
|
|
- room.addTrack(localTracks[i]);
|
|
104
|
|
- }
|
|
105
|
|
-}
|
|
106
|
|
-
|
|
107
|
|
-/**
|
|
108
|
|
- *
|
|
109
|
|
- * @param id
|
|
110
|
|
- */
|
|
111
|
|
-function onUserLeft(id) {
|
|
112
|
|
- console.log('user left');
|
|
113
|
|
- if (!remoteTracks[id]) {
|
|
114
|
|
- return;
|
|
115
|
|
- }
|
|
116
|
|
- const tracks = remoteTracks[id];
|
|
117
|
|
-
|
|
118
|
|
- for (let i = 0; i < tracks.length; i++) {
|
|
119
|
|
- tracks[i].detach($(`#${id}${tracks[i].getType()}`));
|
|
120
|
|
- }
|
|
121
|
|
-}
|
|
122
|
|
-
|
|
123
|
|
-/**
|
|
124
|
|
- * That function is called when connection is established successfully
|
|
125
|
|
- */
|
|
126
|
|
-function onConnectionSuccess() {
|
|
127
|
|
- room = connection.initJitsiConference('conference', confOptions);
|
|
128
|
|
- room.on(JitsiMeetJS.events.conference.TRACK_ADDED, onRemoteTrack);
|
|
129
|
|
- room.on(JitsiMeetJS.events.conference.TRACK_REMOVED, track => {
|
|
130
|
|
- console.log(`track removed!!!${track}`);
|
|
131
|
|
- });
|
|
132
|
|
- room.on(
|
|
133
|
|
- JitsiMeetJS.events.conference.CONFERENCE_JOINED,
|
|
134
|
|
- onConferenceJoined);
|
|
135
|
|
- room.on(JitsiMeetJS.events.conference.USER_JOINED, id => {
|
|
136
|
|
- console.log('user join');
|
|
137
|
|
- remoteTracks[id] = [];
|
|
138
|
|
- });
|
|
139
|
|
- room.on(JitsiMeetJS.events.conference.USER_LEFT, onUserLeft);
|
|
140
|
|
- room.on(JitsiMeetJS.events.conference.TRACK_MUTE_CHANGED, track => {
|
|
141
|
|
- console.log(`${track.getType()} - ${track.isMuted()}`);
|
|
142
|
|
- });
|
|
143
|
|
- room.on(
|
|
144
|
|
- JitsiMeetJS.events.conference.DISPLAY_NAME_CHANGED,
|
|
145
|
|
- (userID, displayName) => console.log(`${userID} - ${displayName}`));
|
|
146
|
|
- room.on(
|
|
147
|
|
- JitsiMeetJS.events.conference.TRACK_AUDIO_LEVEL_CHANGED,
|
|
148
|
|
- (userID, audioLevel) => console.log(`${userID} - ${audioLevel}`));
|
|
149
|
|
- room.on(
|
|
150
|
|
- JitsiMeetJS.events.conference.PHONE_NUMBER_CHANGED,
|
|
151
|
|
- () => console.log(`${room.getPhoneNumber()} - ${room.getPhonePin()}`));
|
|
152
|
|
- room.join();
|
|
153
|
|
-}
|
|
154
|
|
-
|
|
155
|
|
-/**
|
|
156
|
|
- * This function is called when the connection fail.
|
|
157
|
|
- */
|
|
158
|
|
-function onConnectionFailed() {
|
|
159
|
|
- console.error('Connection Failed!');
|
|
160
|
|
-}
|
|
161
|
|
-
|
|
162
|
|
-/**
|
|
163
|
|
- * This function is called when the connection fail.
|
|
164
|
|
- */
|
|
165
|
|
-function onDeviceListChanged(devices) {
|
|
166
|
|
- console.info('current devices', devices);
|
|
167
|
|
-}
|
|
168
|
|
-
|
|
169
|
|
-/**
|
|
170
|
|
- * This function is called when we disconnect.
|
|
171
|
|
- */
|
|
172
|
|
-function disconnect() {
|
|
173
|
|
- console.log('disconnect!');
|
|
174
|
|
- connection.removeEventListener(
|
|
175
|
|
- JitsiMeetJS.events.connection.CONNECTION_ESTABLISHED,
|
|
176
|
|
- onConnectionSuccess);
|
|
177
|
|
- connection.removeEventListener(
|
|
178
|
|
- JitsiMeetJS.events.connection.CONNECTION_FAILED,
|
|
179
|
|
- onConnectionFailed);
|
|
180
|
|
- connection.removeEventListener(
|
|
181
|
|
- JitsiMeetJS.events.connection.CONNECTION_DISCONNECTED,
|
|
182
|
|
- disconnect);
|
|
183
|
|
-}
|
|
184
|
|
-
|
|
185
|
|
-/**
|
|
186
|
|
- *
|
|
187
|
|
- */
|
|
188
|
|
-function unload() {
|
|
189
|
|
- for (let i = 0; i < localTracks.length; i++) {
|
|
190
|
|
- localTracks[i].dispose();
|
|
191
|
|
- }
|
|
192
|
|
- room.leave();
|
|
193
|
|
- connection.disconnect();
|
|
194
|
|
-}
|
|
195
|
|
-
|
|
196
|
|
-let isVideo = true;
|
|
197
|
|
-
|
|
198
|
|
-/**
|
|
199
|
|
- *
|
|
200
|
|
- */
|
|
201
|
|
-function switchVideo() { // eslint-disable-line no-unused-vars
|
|
202
|
|
- isVideo = !isVideo;
|
|
203
|
|
- if (localTracks[1]) {
|
|
204
|
|
- localTracks[1].dispose();
|
|
205
|
|
- localTracks.pop();
|
|
206
|
|
- }
|
|
207
|
|
- JitsiMeetJS.createLocalTracks({
|
|
208
|
|
- devices: [ isVideo ? 'video' : 'desktop' ]
|
|
209
|
|
- })
|
|
210
|
|
- .then(tracks => {
|
|
211
|
|
- localTracks.push(tracks[0]);
|
|
212
|
|
- localTracks[1].addEventListener(
|
|
213
|
|
- JitsiMeetJS.events.track.TRACK_MUTE_CHANGED,
|
|
214
|
|
- () => console.log('local track muted'));
|
|
215
|
|
- localTracks[1].addEventListener(
|
|
216
|
|
- JitsiMeetJS.events.track.LOCAL_TRACK_STOPPED,
|
|
217
|
|
- () => console.log('local track stoped'));
|
|
218
|
|
- localTracks[1].attach($('#localVideo1')[0]);
|
|
219
|
|
- room.addTrack(localTracks[1]);
|
|
220
|
|
- })
|
|
221
|
|
- .catch(error => console.log(error));
|
|
222
|
|
-}
|
|
223
|
|
-
|
|
224
|
|
-/**
|
|
225
|
|
- *
|
|
226
|
|
- * @param selected
|
|
227
|
|
- */
|
|
228
|
|
-function changeAudioOutput(selected) { // eslint-disable-line no-unused-vars
|
|
229
|
|
- JitsiMeetJS.mediaDevices.setAudioOutputDevice(selected.value);
|
|
230
|
|
-}
|
|
231
|
|
-
|
|
232
|
|
-$(window).bind('beforeunload', unload);
|
|
233
|
|
-$(window).bind('unload', unload);
|
|
234
|
|
-
|
|
235
|
|
-// JitsiMeetJS.setLogLevel(JitsiMeetJS.logLevels.ERROR);
|
|
236
|
|
-const initOptions = {
|
|
237
|
|
- disableAudioLevels: true
|
|
238
|
|
-};
|
|
239
|
|
-
|
|
240
|
|
-JitsiMeetJS.init(initOptions);
|
|
241
|
|
-
|
|
242
|
|
-connection = new JitsiMeetJS.JitsiConnection(null, null, options);
|
|
243
|
|
-
|
|
244
|
|
-connection.addEventListener(
|
|
245
|
|
- JitsiMeetJS.events.connection.CONNECTION_ESTABLISHED,
|
|
246
|
|
- onConnectionSuccess);
|
|
247
|
|
-connection.addEventListener(
|
|
248
|
|
- JitsiMeetJS.events.connection.CONNECTION_FAILED,
|
|
249
|
|
- onConnectionFailed);
|
|
250
|
|
-connection.addEventListener(
|
|
251
|
|
- JitsiMeetJS.events.connection.CONNECTION_DISCONNECTED,
|
|
252
|
|
- disconnect);
|
|
253
|
|
-
|
|
254
|
|
-JitsiMeetJS.mediaDevices.addEventListener(
|
|
255
|
|
- JitsiMeetJS.events.mediaDevices.DEVICE_LIST_CHANGED,
|
|
256
|
|
- onDeviceListChanged);
|
|
257
|
|
-
|
|
258
|
|
-connection.connect();
|
|
259
|
|
-
|
|
260
|
|
-JitsiMeetJS.createLocalTracks({ devices: [ 'audio', 'video' ] })
|
|
261
|
|
- .then(onLocalTracks)
|
|
262
|
|
- .catch(error => {
|
|
263
|
|
- throw error;
|
|
264
|
|
- });
|
|
265
|
|
-
|
|
266
|
|
-if (JitsiMeetJS.mediaDevices.isDeviceChangeAvailable('output')) {
|
|
267
|
|
- JitsiMeetJS.mediaDevices.enumerateDevices(devices => {
|
|
268
|
|
- const audioOutputDevices
|
|
269
|
|
- = devices.filter(d => d.kind === 'audiooutput');
|
|
270
|
|
-
|
|
271
|
|
- if (audioOutputDevices.length > 1) {
|
|
272
|
|
- $('#audioOutputSelect').html(
|
|
273
|
|
- audioOutputDevices
|
|
274
|
|
- .map(
|
|
275
|
|
- d =>
|
|
276
|
|
- `<option value="${d.deviceId}">${d.label}</option>`)
|
|
277
|
|
- .join('\n'));
|
|
278
|
|
-
|
|
279
|
|
- $('#audioOutputSelectWrapper').show();
|
|
280
|
|
- }
|
|
281
|
|
- });
|
|
282
|
|
-}
|