FS-7800 [verto_communicator] - Added an option in user's hover buttons to open another canvas when canvasCount is higher than 1
This commit is contained in:
parent
99ca223f82
commit
d4d4165bac
|
@ -850,6 +850,10 @@ body .modal-body .btn-group .btn.active {
|
||||||
padding-right: 360px;
|
padding-right: 360px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.watcher #wrapper {
|
||||||
|
padding-right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
#wrapper.toggled {
|
#wrapper.toggled {
|
||||||
padding-right: 0;
|
padding-right: 0;
|
||||||
}
|
}
|
||||||
|
@ -1545,3 +1549,42 @@ body:-webkit-full-screen #incall .video-footer {
|
||||||
#preview .refresh {
|
#preview .refresh {
|
||||||
margin: 15px 0px 0px 0px;
|
margin: 15px 0px 0px 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.watcher {
|
||||||
|
padding: 0;
|
||||||
|
background-color: #333333;
|
||||||
|
}
|
||||||
|
|
||||||
|
.watcher .navbar, .watcher #sidebar-wrapper, .watcher #dialpad {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.watcher #wrapper.toggled {
|
||||||
|
padding-right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.watcher #incall .panel {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.watcher #video-tag-wrapper {
|
||||||
|
background: linear-gradient(to bottom, #272627, #27252A);
|
||||||
|
background-color: #27252A;
|
||||||
|
}
|
||||||
|
|
||||||
|
.watcher #incall .video-call {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
padding: 0;
|
||||||
|
max-width: none;
|
||||||
|
max-height: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.watcher #webcam {
|
||||||
|
max-width: 160.78vh;
|
||||||
|
margin: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.watcher .spinner {
|
||||||
|
top: 20%;
|
||||||
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<div class="centered-block-frame" id="incall">
|
<div class="centered-block-frame" id="incall">
|
||||||
<div class="col-md-12 centered-block" ng-class="{'video-call': storage.data.videoCall, 'phone-call': !storage.data.videoCall}">
|
<div class="col-md-12 centered-block" ng-class="storage.data.videoCall || watcher ? 'video-call' : 'phone-call'">
|
||||||
<div class="slide-animate height100" ng-include="callTemplate"></div>
|
<div class="slide-animate height100" ng-include="callTemplate"></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<div class="panel panel-default shadow-z-0">
|
<div class="panel panel-default shadow-z-0">
|
||||||
<div class="video-wrapper">
|
<div class="video-wrapper">
|
||||||
<div class="video-hover-buttons" ng-show="verto.data.callState == 'active'">
|
<div class="video-hover-buttons" ng-show="verto.data.callState == 'active' && !watcher">
|
||||||
<div id="moderator-tools" ng-show="verto.data.confRole == 'moderator'">
|
<div id="moderator-tools" ng-show="verto.data.confRole == 'moderator'">
|
||||||
<button tooltip-placement="bottom" tooltip-title="Play" uib-tooltip="Play"
|
<button tooltip-placement="bottom" tooltip-title="Play" uib-tooltip="Play"
|
||||||
class="btn btn-material-blue-900" ng-click="play()">
|
class="btn btn-material-blue-900" ng-click="play()">
|
||||||
|
@ -68,6 +68,17 @@
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="btn-group" ng-show="conf.canvasCount > 1">
|
||||||
|
<button tooltip-placement="bottom" tooltip-title="Popup" uib-tooltips="Popup" type="button" class="btn btn-material-blue-900 dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
||||||
|
<i class="mdi-image-filter-none"></i>
|
||||||
|
<span class="caret"></span>
|
||||||
|
</button>
|
||||||
|
<ul class="dropdown-menu">
|
||||||
|
<li ng-repeat="canvas in canvases">
|
||||||
|
<a ng-click="confPopup(canvas.id)">{{ canvas.name }}</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="video-tag-wrapper" id="video-tag-wrapper" ng-dblclick="goFullscreen()" show-controls>
|
<div class="video-tag-wrapper" id="video-tag-wrapper" ng-dblclick="goFullscreen()" show-controls>
|
||||||
|
@ -80,13 +91,14 @@
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-6 col-xs-6 text-left">
|
<div class="col-md-6 col-xs-6 text-left">
|
||||||
<div class="video-timer">
|
<div class="video-timer">
|
||||||
<timer start-time="start_time" autostart="false" interval="1000">{{hhours}}:{{mminutes}}:{{sseconds}}</timer>
|
<span ng-show="watcher" style="font-size: 18px">Room {{ extension }} - Canvas {{ canvasID }}</span>
|
||||||
|
<timer start-time="start_time" autostart="false" interval="1000" ng-if="!watcher">{{hhours}}:{{mminutes}}:{{sseconds}}</timer>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-6 col-xs-6 text-right">
|
<div class="col-md-6 col-xs-6 text-right">
|
||||||
<button class="btn btn-danger" ng-click="hangup()">
|
<button class="btn btn-danger" ng-click="hangup()">
|
||||||
<i class="mdi-communication-call-end"></i>
|
<i class="mdi-communication-call-end"></i>
|
||||||
End Call
|
{{ watcher ? 'Close' : 'End Call' }}
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -98,6 +98,11 @@
|
||||||
});
|
});
|
||||||
|
|
||||||
$rootScope.$on('members.del', function(event, uuid) {
|
$rootScope.$on('members.del', function(event, uuid) {
|
||||||
|
if ($rootScope.watcher && $rootScope.master === uuid) {
|
||||||
|
verto.hangup();
|
||||||
|
window.close();
|
||||||
|
}
|
||||||
|
|
||||||
$scope.$apply(function() {
|
$scope.$apply(function() {
|
||||||
var memberIdx = findMemberByUUID(uuid);
|
var memberIdx = findMemberByUUID(uuid);
|
||||||
if (memberIdx != -1) {
|
if (memberIdx != -1) {
|
||||||
|
|
|
@ -10,6 +10,15 @@
|
||||||
|
|
||||||
eventQueue.process();
|
eventQueue.process();
|
||||||
|
|
||||||
|
if ($location.search().autocall) {
|
||||||
|
$rootScope.dialpadNumber = $location.search().autocall;
|
||||||
|
delete $location.search().autocall;
|
||||||
|
call($rootScope.dialpadNumber);
|
||||||
|
if($rootScope.watcher) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$scope.call_history = CallHistory.all();
|
$scope.call_history = CallHistory.all();
|
||||||
$scope.history_control = CallHistory.all_control();
|
$scope.history_control = CallHistory.all_control();
|
||||||
$scope.has_history = Object.keys($scope.call_history).length;
|
$scope.has_history = Object.keys($scope.call_history).length;
|
||||||
|
@ -32,11 +41,6 @@
|
||||||
/**
|
/**
|
||||||
* fill dialpad via querystring [?autocall=\d+]
|
* fill dialpad via querystring [?autocall=\d+]
|
||||||
*/
|
*/
|
||||||
if ($location.search().autocall) {
|
|
||||||
$rootScope.dialpadNumber = $location.search().autocall;
|
|
||||||
delete $location.search().autocall;
|
|
||||||
call($rootScope.dialpadNumber);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* fill in dialpad via config.json
|
* fill in dialpad via config.json
|
||||||
|
@ -83,6 +87,13 @@
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (extension.indexOf('-canvas-') != -1) {
|
||||||
|
$rootScope.watcher = true;
|
||||||
|
verto.call($rootScope.dialpadNumber, null, { useCamera: false, useMic: false, caller_id_name: null, userVariables: {}, caller_id_number: null, mirrorInput: false });
|
||||||
|
$location.path('/incall');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
storage.data.mutedVideo = false;
|
storage.data.mutedVideo = false;
|
||||||
storage.data.mutedMic = false;
|
storage.data.mutedMic = false;
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,6 @@
|
||||||
$scope.dialpadTemplate = '';
|
$scope.dialpadTemplate = '';
|
||||||
$scope.incall = true;
|
$scope.incall = true;
|
||||||
|
|
||||||
|
|
||||||
if (storage.data.videoCall) {
|
if (storage.data.videoCall) {
|
||||||
$scope.callTemplate = 'partials/video_call.html';
|
$scope.callTemplate = 'partials/video_call.html';
|
||||||
}
|
}
|
||||||
|
@ -25,6 +24,7 @@
|
||||||
if($scope.chatStatus) {
|
if($scope.chatStatus) {
|
||||||
$scope.openChat();
|
$scope.openChat();
|
||||||
}
|
}
|
||||||
|
buildCanvasesData();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -80,6 +80,22 @@
|
||||||
$rootScope.$emit('changedSpeaker', speakerId);
|
$rootScope.$emit('changedSpeaker', speakerId);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
$scope.confPopup = function(canvas_id) {
|
||||||
|
var s = window.location.href;
|
||||||
|
var curCall = verto.data.call.callID;
|
||||||
|
var extension = verto.data.call.params.remote_caller_id_number;
|
||||||
|
var width = 465, height = 360;
|
||||||
|
var x = screen.width/2 - width/2
|
||||||
|
var y = screen.height/2 - height/2
|
||||||
|
|
||||||
|
s = s.replace(/\#.*/, '');
|
||||||
|
s += "#/?sessid=random&master=" + curCall + "&watcher=true&extension=" + extension+ "&canvas_id=" + canvas_id;
|
||||||
|
|
||||||
|
console.log("opening new window to " + s);
|
||||||
|
var popup = window.open(s, "canvas_window_" + canvas_id, "toolbar=0,location=0,menubar=0,directories=0,width=" + width + ",height=" + height, + ',left=' + x + ',top=' + y);
|
||||||
|
popup.moveTo(x, y);
|
||||||
|
};
|
||||||
|
|
||||||
$scope.screenshare = function() {
|
$scope.screenshare = function() {
|
||||||
if(verto.data.shareCall) {
|
if(verto.data.shareCall) {
|
||||||
verto.screenshareHangup();
|
verto.screenshareHangup();
|
||||||
|
@ -88,6 +104,14 @@
|
||||||
verto.screenshare(storage.data.called_number);
|
verto.screenshare(storage.data.called_number);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
function buildCanvasesData() {
|
||||||
|
$scope.conf = verto.data.conf.params.laData;
|
||||||
|
$scope.canvases = [{ id: 1, name: 'Super Canvas' }];
|
||||||
|
for (var i = 1; i < $scope.conf.canvasCount; i++) {
|
||||||
|
$scope.canvases.push({ id: i+1, name: 'Canvas ' + (i+1) });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$scope.muteMic = verto.muteMic;
|
$scope.muteMic = verto.muteMic;
|
||||||
$scope.muteVideo = verto.muteVideo;
|
$scope.muteVideo = verto.muteVideo;
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,24 @@
|
||||||
|
|
||||||
console.debug('Executing MainController.');
|
console.debug('Executing MainController.');
|
||||||
|
|
||||||
|
$rootScope.master = $location.search().master;
|
||||||
|
if ($location.search().watcher === 'true') {
|
||||||
|
$rootScope.watcher = true;
|
||||||
|
angular.element(document.body).addClass('watcher');
|
||||||
|
var dialpad;
|
||||||
|
var extension = dialpad = $location.search().extension;
|
||||||
|
var canvasID = $location.search().canvas_id;
|
||||||
|
|
||||||
|
if (dialpad) {
|
||||||
|
if (canvasID) {
|
||||||
|
dialpad += '-canvas-' + canvasID;
|
||||||
|
}
|
||||||
|
$rootScope.extension = extension;
|
||||||
|
$rootScope.canvasID = canvasID;
|
||||||
|
$location.search().autocall = dialpad;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var myVideo = document.getElementById("webcam");
|
var myVideo = document.getElementById("webcam");
|
||||||
$scope.verto = verto;
|
$scope.verto = verto;
|
||||||
$scope.storage = storage;
|
$scope.storage = storage;
|
||||||
|
@ -432,6 +450,11 @@
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($rootScope.watcher) {
|
||||||
|
window.close();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
//var hangupCallback = function(v, hangup) {
|
//var hangupCallback = function(v, hangup) {
|
||||||
// if (hangup) {
|
// if (hangup) {
|
||||||
// $location.path('/dialpad');
|
// $location.path('/dialpad');
|
||||||
|
|
|
@ -32,4 +32,4 @@
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
})();
|
})();
|
||||||
|
|
|
@ -584,6 +584,11 @@ vertoService.service('verto', ['$rootScope', '$cookieStore', '$location', 'stora
|
||||||
|
|
||||||
var that = this;
|
var that = this;
|
||||||
function ourBootstrap() {
|
function ourBootstrap() {
|
||||||
|
var sessid = $location.search().sessid;
|
||||||
|
if (sessid === 'random') {
|
||||||
|
sessid = $.verto.genUUID();
|
||||||
|
$location.search().sessid = sessid;
|
||||||
|
}
|
||||||
// Checking if we have a failed connection attempt before
|
// Checking if we have a failed connection attempt before
|
||||||
// connecting again.
|
// connecting again.
|
||||||
if (data.instance && !data.instance.rpcClient.socketReady()) {
|
if (data.instance && !data.instance.rpcClient.socketReady()) {
|
||||||
|
@ -604,6 +609,7 @@ vertoService.service('verto', ['$rootScope', '$cookieStore', '$location', 'stora
|
||||||
googNoiseSuppression: storage.data.googNoiseSuppression || true,
|
googNoiseSuppression: storage.data.googNoiseSuppression || true,
|
||||||
googHighpassFilter: storage.data.googHighpassFilter || true
|
googHighpassFilter: storage.data.googHighpassFilter || true
|
||||||
},
|
},
|
||||||
|
sessid: sessid,
|
||||||
iceServers: storage.data.useSTUN
|
iceServers: storage.data.useSTUN
|
||||||
}, callbacks);
|
}, callbacks);
|
||||||
|
|
||||||
|
@ -614,6 +620,7 @@ vertoService.service('verto', ['$rootScope', '$cookieStore', '$location', 'stora
|
||||||
jQuery.verto.unloadJobs.push(function() {
|
jQuery.verto.unloadJobs.push(function() {
|
||||||
that.reloaded = true;
|
that.reloaded = true;
|
||||||
});
|
});
|
||||||
|
|
||||||
data.instance.deviceParams({
|
data.instance.deviceParams({
|
||||||
useCamera: storage.data.selectedVideo,
|
useCamera: storage.data.selectedVideo,
|
||||||
useSpeak: storage.data.selectedSpeaker,
|
useSpeak: storage.data.selectedSpeaker,
|
||||||
|
@ -674,10 +681,10 @@ vertoService.service('verto', ['$rootScope', '$cookieStore', '$location', 'stora
|
||||||
*
|
*
|
||||||
* @param callback
|
* @param callback
|
||||||
*/
|
*/
|
||||||
call: function(destination, callback) {
|
call: function(destination, callback, custom) {
|
||||||
console.debug('Attempting to call destination ' + destination + '.');
|
console.debug('Attempting to call destination ' + destination + '.');
|
||||||
|
|
||||||
var call = data.instance.newCall({
|
var call = data.instance.newCall(angular.extend({
|
||||||
destination_number: destination,
|
destination_number: destination,
|
||||||
caller_id_name: data.name,
|
caller_id_name: data.name,
|
||||||
caller_id_number: data.callerid ? data.callerid : data.email,
|
caller_id_number: data.callerid ? data.callerid : data.email,
|
||||||
|
@ -694,7 +701,7 @@ vertoService.service('verto', ['$rootScope', '$cookieStore', '$location', 'stora
|
||||||
email : storage.data.email,
|
email : storage.data.email,
|
||||||
avatar: "http://gravatar.com/avatar/" + md5(storage.data.email) + ".png?s=600"
|
avatar: "http://gravatar.com/avatar/" + md5(storage.data.email) + ".png?s=600"
|
||||||
}
|
}
|
||||||
});
|
}, custom));
|
||||||
|
|
||||||
data.call = call;
|
data.call = call;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue