videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular 2.0
148 lines • 19.4 kB
JavaScript
"use strict";
var core_1 = require('@angular/core');
var vg_utils_1 = require('./vg-utils');
var Observable_1 = require('rxjs/Observable');
var VgFullscreenAPI = (function () {
function VgFullscreenAPI() {
this.nativeFullscreen = true;
this.isFullscreen = false;
this.onChangeFullscreen = new core_1.EventEmitter();
}
VgFullscreenAPI.prototype.init = function (elem, medias) {
var _this = this;
this.videogularElement = elem;
this.medias = medias;
var APIs = {
w3: {
enabled: 'fullscreenEnabled',
element: 'fullscreenElement',
request: 'requestFullscreen',
exit: 'exitFullscreen',
onchange: 'fullscreenchange',
onerror: 'fullscreenerror'
},
newWebkit: {
enabled: 'webkitFullscreenEnabled',
element: 'webkitFullscreenElement',
request: 'webkitRequestFullscreen',
exit: 'webkitExitFullscreen',
onchange: 'webkitfullscreenchange',
onerror: 'webkitfullscreenerror'
},
oldWebkit: {
enabled: 'webkitIsFullScreen',
element: 'webkitCurrentFullScreenElement',
request: 'webkitRequestFullScreen',
exit: 'webkitCancelFullScreen',
onchange: 'webkitfullscreenchange',
onerror: 'webkitfullscreenerror'
},
moz: {
enabled: 'mozFullScreen',
element: 'mozFullScreenElement',
request: 'mozRequestFullScreen',
exit: 'mozCancelFullScreen',
onchange: 'mozfullscreenchange',
onerror: 'mozfullscreenerror'
},
ios: {
enabled: 'webkitFullscreenEnabled',
element: 'webkitFullscreenElement',
request: 'webkitEnterFullscreen',
exit: 'webkitExitFullscreen',
onchange: 'webkitendfullscreen',
onerror: 'webkitfullscreenerror'
},
ms: {
enabled: 'msFullscreenEnabled',
element: 'msFullscreenElement',
request: 'msRequestFullscreen',
exit: 'msExitFullscreen',
onchange: 'MSFullscreenChange',
onerror: 'MSFullscreenError'
}
};
for (var browser in APIs) {
if (APIs[browser].enabled in document) {
this.polyfill = APIs[browser];
break;
}
}
if (vg_utils_1.VgUtils.isiOSDevice()) {
this.polyfill = APIs.ios;
}
var fsElemDispatcher;
switch (this.polyfill.onchange) {
// Mozilla dispatches the fullscreen change event from document, not the element
// See: https://bugzilla.mozilla.org/show_bug.cgi?id=724816#c3
case 'mozfullscreenchange':
fsElemDispatcher = document;
break;
// iOS dispatches the fullscreen change event from video element
case 'webkitendfullscreen':
fsElemDispatcher = this.medias.toArray()[0].elem;
break;
// HTML5 implementation dispatches the fullscreen change event from the element
default:
fsElemDispatcher = elem;
}
this.fsChangeSubscription = Observable_1.Observable.fromEvent(fsElemDispatcher, this.polyfill.onchange).subscribe(function () {
_this.onFullscreenChange();
});
this.isAvailable = (this.polyfill != null);
};
VgFullscreenAPI.prototype.onFullscreenChange = function () {
this.isFullscreen = !!document[this.polyfill.element];
this.onChangeFullscreen.next(this.isFullscreen);
};
VgFullscreenAPI.prototype.toggleFullscreen = function (element) {
if (element === void 0) { element = null; }
if (this.isFullscreen) {
this.exit();
}
else {
this.request(element);
}
};
VgFullscreenAPI.prototype.request = function (elem) {
if (!elem) {
elem = this.videogularElement;
}
this.isFullscreen = true;
this.onChangeFullscreen.next(true);
// Perform native full screen support
if (this.isAvailable && this.nativeFullscreen) {
// Fullscreen for mobile devices
if (vg_utils_1.VgUtils.isMobileDevice()) {
// We should make fullscreen the video object if it doesn't have native fullscreen support
// Fallback! We can't set vg-player on fullscreen, only video/audio objects
if ((!this.polyfill.enabled && elem === this.videogularElement) || vg_utils_1.VgUtils.isiOSDevice()) {
elem = this.medias.toArray()[0].elem;
}
this.enterElementInFullScreen(elem);
}
else {
this.enterElementInFullScreen(this.videogularElement);
}
}
};
VgFullscreenAPI.prototype.enterElementInFullScreen = function (elem) {
elem[this.polyfill.request]();
};
VgFullscreenAPI.prototype.exit = function () {
this.isFullscreen = false;
this.onChangeFullscreen.next(false);
// Exit from native fullscreen
if (this.isAvailable && this.nativeFullscreen) {
document[this.polyfill.exit]();
}
};
VgFullscreenAPI.decorators = [
{ type: core_1.Injectable },
];
/** @nocollapse */
VgFullscreenAPI.ctorParameters = [];
return VgFullscreenAPI;
}());
exports.VgFullscreenAPI = VgFullscreenAPI;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-fullscreen-api.js","sourceRoot":"","sources":["vg-fullscreen-api.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, EventEmitter, QueryList } from '@angular/core';\nimport { VgUtils } from './vg-utils';\nimport { VgMedia } from '../vg-media/vg-media';\nimport { Subscription } from 'rxjs/Subscription';\nimport { Observable } from 'rxjs/Observable';\n\n\nexport class VgFullscreenAPI {\n    polyfill: any;\n    onchange: string;\n    onerror: string;\n    nativeFullscreen: boolean = true;\n    isFullscreen: boolean = false;\n    isAvailable: boolean;\n    videogularElement: HTMLElement;\n    medias: QueryList<VgMedia>;\n\n    fsChangeSubscription: Subscription;\n    onChangeFullscreen: EventEmitter<any> = new EventEmitter();\n\n    constructor() {}\n\n    init(elem: HTMLElement, medias: QueryList<VgMedia>) {\n        this.videogularElement = elem;\n        this.medias = medias;\n\n        const APIs = {\n            w3: {\n                enabled: 'fullscreenEnabled',\n                element: 'fullscreenElement',\n                request: 'requestFullscreen',\n                exit: 'exitFullscreen',\n                onchange: 'fullscreenchange',\n                onerror: 'fullscreenerror'\n            },\n            newWebkit: {\n                enabled: 'webkitFullscreenEnabled',\n                element: 'webkitFullscreenElement',\n                request: 'webkitRequestFullscreen',\n                exit: 'webkitExitFullscreen',\n                onchange: 'webkitfullscreenchange',\n                onerror: 'webkitfullscreenerror'\n            },\n            oldWebkit: {\n                enabled: 'webkitIsFullScreen',\n                element: 'webkitCurrentFullScreenElement',\n                request: 'webkitRequestFullScreen',\n                exit: 'webkitCancelFullScreen',\n                onchange: 'webkitfullscreenchange',\n                onerror: 'webkitfullscreenerror'\n            },\n            moz: {\n                enabled: 'mozFullScreen',\n                element: 'mozFullScreenElement',\n                request: 'mozRequestFullScreen',\n                exit: 'mozCancelFullScreen',\n                onchange: 'mozfullscreenchange',\n                onerror: 'mozfullscreenerror'\n            },\n            ios: {\n                enabled: 'webkitFullscreenEnabled',\n                element: 'webkitFullscreenElement',\n                request: 'webkitEnterFullscreen',\n                exit: 'webkitExitFullscreen',\n                onchange: 'webkitendfullscreen', // Hack for iOS: webkitfullscreenchange it's not firing\n                onerror: 'webkitfullscreenerror'\n            },\n            ms: {\n                enabled: 'msFullscreenEnabled',\n                element: 'msFullscreenElement',\n                request: 'msRequestFullscreen',\n                exit: 'msExitFullscreen',\n                onchange: 'MSFullscreenChange',\n                onerror: 'MSFullscreenError'\n            }\n        };\n\n        for (let browser in APIs) {\n            if (APIs[ browser ].enabled in document) {\n                this.polyfill = APIs[ browser ];\n                break;\n            }\n        }\n\n        if (VgUtils.isiOSDevice()) {\n            this.polyfill = APIs.ios\n        }\n\n        let fsElemDispatcher;\n\n        switch (this.polyfill.onchange) {\n            // Mozilla dispatches the fullscreen change event from document, not the element\n            // See: https://bugzilla.mozilla.org/show_bug.cgi?id=724816#c3\n            case 'mozfullscreenchange':\n                fsElemDispatcher = document;\n                break;\n\n            // iOS dispatches the fullscreen change event from video element\n            case 'webkitendfullscreen':\n                fsElemDispatcher = this.medias.toArray()[ 0 ].elem;\n                break;\n\n            // HTML5 implementation dispatches the fullscreen change event from the element\n            default:\n                fsElemDispatcher = elem;\n        }\n\n        this.fsChangeSubscription = Observable.fromEvent(fsElemDispatcher, this.polyfill.onchange).subscribe(() => {\n            this.onFullscreenChange();\n        });\n\n        this.isAvailable = (this.polyfill != null);\n    }\n\n    onFullscreenChange() {\n        this.isFullscreen = !!document[ this.polyfill.element ];\n        this.onChangeFullscreen.next(this.isFullscreen);\n    }\n\n    toggleFullscreen(element: any = null) {\n        if (this.isFullscreen) {\n            this.exit();\n        }\n        else {\n            this.request(element);\n        }\n    }\n\n    request(elem: any) {\n        if (!elem) {\n            elem = this.videogularElement;\n        }\n\n        this.isFullscreen = true;\n        this.onChangeFullscreen.next(true);\n\n        // Perform native full screen support\n        if (this.isAvailable && this.nativeFullscreen) {\n            // Fullscreen for mobile devices\n            if (VgUtils.isMobileDevice()) {\n                // We should make fullscreen the video object if it doesn't have native fullscreen support\n                // Fallback! We can't set vg-player on fullscreen, only video/audio objects\n                if ((!this.polyfill.enabled && elem === this.videogularElement) || VgUtils.isiOSDevice()) {\n                    elem = this.medias.toArray()[ 0 ].elem;\n                }\n\n                this.enterElementInFullScreen(elem);\n            }\n            else {\n                this.enterElementInFullScreen(this.videogularElement);\n            }\n        }\n    }\n\n    enterElementInFullScreen(elem: any) {\n        elem[ this.polyfill.request ]();\n    }\n\n    exit() {\n        this.isFullscreen = false;\n        this.onChangeFullscreen.next(false);\n\n        // Exit from native fullscreen\n        if (this.isAvailable && this.nativeFullscreen) {\n            document[ this.polyfill.exit ]();\n        }\n    }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Injectable },\n];\n/** @nocollapse */\nstatic ctorParameters: ({type: any, decorators?: DecoratorInvocation[]}|null)[] = [\n];\n}\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}