2021-03-10 21:26:45 +01:00
|
|
|
|
<html>
|
|
|
|
|
<head>
|
|
|
|
|
<meta charset="utf-8" />
|
|
|
|
|
</head>
|
2021-03-17 00:05:29 +01:00
|
|
|
|
<body style="margin: 0">
|
2021-03-10 21:26:45 +01:00
|
|
|
|
<div id="placeholder" />
|
|
|
|
|
<script src='https://meet.jit.si/external_api.js'></script>
|
|
|
|
|
<script type="text/javascript">
|
2021-06-29 09:44:16 +02:00
|
|
|
|
var api;
|
2021-03-10 21:26:45 +01:00
|
|
|
|
|
2021-06-29 09:44:16 +02:00
|
|
|
|
function startMeeting(credentials) {
|
|
|
|
|
var configOverwrite = {
|
|
|
|
|
disableProfile: true,
|
|
|
|
|
startAudioOnly: '%_AUDIO_ONLY_%',
|
|
|
|
|
startWithAudioMuted: '%_AUDIO_MUTED_%',
|
|
|
|
|
startWithVideoMuted: '%_VIDEO_MUTED_%'
|
|
|
|
|
};
|
|
|
|
|
var interfaceOverwrite = {
|
|
|
|
|
JITSI_WATERMARK_LINK: '',
|
|
|
|
|
SHOW_JITSI_WATERMARK: false,
|
|
|
|
|
TOOLBAR_BUTTONS: [
|
|
|
|
|
'microphone', 'camera', '%%_ALLOW_CLOSED_CAPTIONS_%%', /*'desktop',*/ 'embedmeeting', 'fullscreen',
|
|
|
|
|
'fodeviceselection', /*'hangup',*/ 'profile', '%%_ALLOW_CHAT_%%', '%%_ALLOW_RECORDING_%%',
|
|
|
|
|
'livestreaming', 'etherpad', /*'sharedvideo',*/ 'settings', '%%_ALLOW_RAISE_HAND_%%',
|
|
|
|
|
'videoquality', 'filmstrip', 'invite', 'feedback', 'stats', 'shortcuts',
|
|
|
|
|
'%%_ALLOW_TILE_VIEW_%%', 'select-background', 'download', 'help', /*'mute-everyone',*/ 'mute-video-everyone', 'security'
|
|
|
|
|
]
|
|
|
|
|
};
|
|
|
|
|
var options = {
|
|
|
|
|
configOverwrite: configOverwrite,
|
|
|
|
|
height: '100%',
|
|
|
|
|
interfaceConfigOverwrite: interfaceOverwrite,
|
|
|
|
|
jwt: credentials.token,
|
|
|
|
|
parentNode: document.querySelector('#placeholder'),
|
|
|
|
|
roomName: credentials.roomName,
|
|
|
|
|
width: '100%'
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
api = new JitsiMeetExternalAPI(credentials.domain, options);
|
|
|
|
|
api.addListener('audioMuteStatusChanged', args => {
|
|
|
|
|
if (args.muted) {
|
|
|
|
|
api.executeCommand('toggleAudio');
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
api.addListener('videoMuteStatusChanged', args => {
|
|
|
|
|
if (args.muted) {
|
|
|
|
|
api.executeCommand('toggleVideo');
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
api.executeCommand('subject', credentials.subject);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function webMessageReceived(args) {
|
|
|
|
|
if ('credentials' in args.data) {
|
|
|
|
|
startMeeting(args.data.credentials);
|
2021-05-19 01:35:01 +02:00
|
|
|
|
}
|
2021-06-29 09:44:16 +02:00
|
|
|
|
}
|
2021-05-19 01:35:01 +02:00
|
|
|
|
|
2021-06-29 09:44:16 +02:00
|
|
|
|
window.chrome.webview.addEventListener('message', webMessageReceived);
|
|
|
|
|
window.chrome.webview.postMessage('credentials');
|
2021-03-10 21:26:45 +01:00
|
|
|
|
</script>
|
|
|
|
|
</body>
|
|
|
|
|
</html>
|