handle FOCUS_LEFT conference error

This commit is contained in:
isymchych 2016-02-05 17:04:48 +02:00
parent 4228537390
commit 379f786225
4 changed files with 41 additions and 6 deletions

View File

@ -146,7 +146,7 @@ class ConferenceConnector {
break; break;
case ConferenceErrors.GRACEFUL_SHUTDOWN: case ConferenceErrors.GRACEFUL_SHUTDOWN:
APP.UI.notifyGracefulShudown(); APP.UI.notifyGracefulShutdown();
break; break;
case ConferenceErrors.JINGLE_FATAL_ERROR: case ConferenceErrors.JINGLE_FATAL_ERROR:
@ -168,6 +168,10 @@ class ConferenceConnector {
} }
break; break;
case ConferenceErrors.FOCUS_LEFT:
APP.UI.notifyFocusLeft();
break;
default: default:
this._handleConferenceFailed(err, ...params); this._handleConferenceFailed(err, ...params);
} }

View File

@ -143,6 +143,7 @@
"failtoinstall": "Failed to install desktop sharing extension", "failtoinstall": "Failed to install desktop sharing extension",
"failedpermissions": "Failed to obtain permissions to use the local microphone and/or camera.", "failedpermissions": "Failed to obtain permissions to use the local microphone and/or camera.",
"bridgeUnavailable": "Jitsi Videobridge is currently unavailable. Please try again later!", "bridgeUnavailable": "Jitsi Videobridge is currently unavailable. Please try again later!",
"jicofoUnavailable": "Jicofo is currently unavailable. Please try again later!",
"lockTitle": "Lock failed", "lockTitle": "Lock failed",
"lockMessage": "Failed to lock the conference.", "lockMessage": "Failed to lock the conference.",
"warning": "Warning", "warning": "Warning",

View File

@ -18,6 +18,7 @@ import EtherpadManager from './etherpad/Etherpad';
import VideoLayout from "./videolayout/VideoLayout"; import VideoLayout from "./videolayout/VideoLayout";
import SettingsMenu from "./side_pannels/settings/SettingsMenu"; import SettingsMenu from "./side_pannels/settings/SettingsMenu";
import Settings from "./../settings/Settings"; import Settings from "./../settings/Settings";
import { reload } from '../util/helpers';
var EventEmitter = require("events"); var EventEmitter = require("events");
UI.messageHandler = require("./util/MessageHandler"); UI.messageHandler = require("./util/MessageHandler");
@ -136,7 +137,7 @@ function toggleFullScreen () {
/** /**
* Notify user that server has shut down. * Notify user that server has shut down.
*/ */
UI.notifyGracefulShudown = function () { UI.notifyGracefulShutdown = function () {
messageHandler.openMessageDialog( messageHandler.openMessageDialog(
'dialog.serviceUnavailable', 'dialog.serviceUnavailable',
'dialog.gracefulShutdown' 'dialog.gracefulShutdown'
@ -635,7 +636,7 @@ UI.showLoginPopup = function(callback) {
'<input name="password" ' + '<input name="password" ' +
'type="password" data-i18n="[placeholder]dialog.userPassword"' + 'type="password" data-i18n="[placeholder]dialog.userPassword"' +
' placeholder="user password">'; ' placeholder="user password">';
UI.messageHandler.openTwoButtonDialog(null, null, null, message, messageHandler.openTwoButtonDialog(null, null, null, message,
true, true,
"dialog.Ok", "dialog.Ok",
function (e, v, m, f) { function (e, v, m, f) {
@ -965,17 +966,39 @@ UI.notifyTokenAuthFailed = function () {
}; };
UI.notifyInternalError = function () { UI.notifyInternalError = function () {
UI.messageHandler.showError("dialog.sorry", "dialog.internalError"); messageHandler.showError("dialog.sorry", "dialog.internalError");
}; };
UI.notifyFocusDisconnected = function (focus, retrySec) { UI.notifyFocusDisconnected = function (focus, retrySec) {
UI.messageHandler.notify( messageHandler.notify(
null, "notify.focus", null, "notify.focus",
'disconnected', "notify.focusFail", 'disconnected', "notify.focusFail",
{component: focus, ms: retrySec} {component: focus, ms: retrySec}
); );
}; };
/**
* Notify user that focus left the conference so page should be reloaded.
*/
UI.notifyFocusLeft = function () {
let title = APP.translation.generateTranslationHTML(
'dialog.serviceUnavailable'
);
let msg = APP.translation.generateTranslationHTML(
'dialog.jicofoUnavailable'
);
messageHandler.openDialog(
title,
msg,
true, // persistent
[{title: 'retry'}],
function () {
reload();
return false;
}
);
};
/** /**
* Updates auth info on the UI. * Updates auth info on the UI.
* @param {boolean} isAuthEnabled if authentication is enabled * @param {boolean} isAuthEnabled if authentication is enabled
@ -1030,7 +1053,7 @@ UI.getLargeVideoID = function () {
* Shows dialog with a link to FF extension. * Shows dialog with a link to FF extension.
*/ */
UI.showExtensionRequiredDialog = function (url) { UI.showExtensionRequiredDialog = function (url) {
APP.UI.messageHandler.openMessageDialog( messageHandler.openMessageDialog(
"dialog.extensionRequired", "dialog.extensionRequired",
null, null,
null, null,

View File

@ -12,3 +12,10 @@ export function createDeferred () {
return deferred; return deferred;
} }
/**
* Reload page.
*/
export function reload () {
window.location.reload();
}