mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-04-02 19:29:31 +00:00
120 lines
5.1 KiB
JavaScript
120 lines
5.1 KiB
JavaScript
|
(function(window) {
|
||
|
var createModule = function(angular) {
|
||
|
var module = angular.module('FBAngular', []);
|
||
|
|
||
|
module.factory('Fullscreen', ['$document', '$rootScope', function ($document,$rootScope) {
|
||
|
var document = $document[0];
|
||
|
|
||
|
// ensure ALLOW_KEYBOARD_INPUT is available and enabled
|
||
|
var isKeyboardAvailbleOnFullScreen = (typeof Element !== 'undefined' && 'ALLOW_KEYBOARD_INPUT' in Element) && Element.ALLOW_KEYBOARD_INPUT;
|
||
|
|
||
|
var emitter = $rootScope.$new();
|
||
|
|
||
|
// listen event on document instead of element to avoid firefox limitation
|
||
|
// see https://developer.mozilla.org/en-US/docs/Web/Guide/API/DOM/Using_full_screen_mode
|
||
|
$document.on('fullscreenchange webkitfullscreenchange mozfullscreenchange MSFullscreenChange', function(){
|
||
|
emitter.$emit('FBFullscreen.change', serviceInstance.isEnabled());
|
||
|
});
|
||
|
|
||
|
var serviceInstance = {
|
||
|
$on: angular.bind(emitter, emitter.$on),
|
||
|
all: function() {
|
||
|
serviceInstance.enable( document.documentElement );
|
||
|
},
|
||
|
enable: function(element) {
|
||
|
if(element.requestFullScreen) {
|
||
|
element.requestFullScreen();
|
||
|
} else if(element.mozRequestFullScreen) {
|
||
|
element.mozRequestFullScreen();
|
||
|
} else if(element.webkitRequestFullscreen) {
|
||
|
// Safari temporary fix
|
||
|
if (/Version\/[\d]{1,2}(\.[\d]{1,2}){1}(\.(\d){1,2}){0,1} Safari/.test(navigator.userAgent)) {
|
||
|
element.webkitRequestFullscreen();
|
||
|
} else {
|
||
|
element.webkitRequestFullscreen(isKeyboardAvailbleOnFullScreen);
|
||
|
}
|
||
|
} else if (element.msRequestFullscreen) {
|
||
|
element.msRequestFullscreen();
|
||
|
}
|
||
|
},
|
||
|
cancel: function() {
|
||
|
if(document.cancelFullScreen) {
|
||
|
document.cancelFullScreen();
|
||
|
} else if(document.mozCancelFullScreen) {
|
||
|
document.mozCancelFullScreen();
|
||
|
} else if(document.webkitExitFullscreen) {
|
||
|
document.webkitExitFullscreen();
|
||
|
} else if (document.msExitFullscreen) {
|
||
|
document.msExitFullscreen();
|
||
|
}
|
||
|
},
|
||
|
isEnabled: function(){
|
||
|
var fullscreenElement = document.fullscreenElement || document.mozFullScreenElement || document.webkitFullscreenElement || document.msFullscreenElement;
|
||
|
return fullscreenElement ? true : false;
|
||
|
},
|
||
|
toggleAll: function(){
|
||
|
serviceInstance.isEnabled() ? serviceInstance.cancel() : serviceInstance.all();
|
||
|
},
|
||
|
isSupported: function(){
|
||
|
var docElm = document.documentElement;
|
||
|
var requestFullscreen = docElm.requestFullScreen || docElm.mozRequestFullScreen || docElm.webkitRequestFullscreen || docElm.msRequestFullscreen;
|
||
|
return requestFullscreen ? true : false;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
return serviceInstance;
|
||
|
}]);
|
||
|
|
||
|
module.directive('fullscreen', ['Fullscreen', function(Fullscreen) {
|
||
|
return {
|
||
|
link : function ($scope, $element, $attrs) {
|
||
|
// Watch for changes on scope if model is provided
|
||
|
if ($attrs.fullscreen) {
|
||
|
$scope.$watch($attrs.fullscreen, function(value) {
|
||
|
var isEnabled = Fullscreen.isEnabled();
|
||
|
if (value && !isEnabled) {
|
||
|
Fullscreen.enable($element[0]);
|
||
|
$element.addClass('isInFullScreen');
|
||
|
} else if (!value && isEnabled) {
|
||
|
Fullscreen.cancel();
|
||
|
$element.removeClass('isInFullScreen');
|
||
|
}
|
||
|
});
|
||
|
|
||
|
// Listen on the `FBFullscreen.change`
|
||
|
// the event will fire when anything changes the fullscreen mode
|
||
|
var removeFullscreenHandler = Fullscreen.$on('FBFullscreen.change', function(evt, isFullscreenEnabled){
|
||
|
if(!isFullscreenEnabled){
|
||
|
$scope.$evalAsync(function(){
|
||
|
$scope.$eval($attrs.fullscreen + '= false');
|
||
|
$element.removeClass('isInFullScreen');
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
|
||
|
$scope.$on('$destroy', function() {
|
||
|
removeFullscreenHandler();
|
||
|
});
|
||
|
|
||
|
} else {
|
||
|
if ($attrs.onlyWatchedProperty !== undefined) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$element.on('click', function (ev) {
|
||
|
Fullscreen.enable( $element[0] );
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
}]);
|
||
|
return module;
|
||
|
};
|
||
|
|
||
|
if (typeof define === "function" && define.amd) {
|
||
|
define("FBAngular", ['angular'], function (angular) { return createModule(angular); } );
|
||
|
} else {
|
||
|
createModule(window.angular);
|
||
|
}
|
||
|
})(window);
|