UNPKG

videogular2

Version:

Videogular is a video application framework for desktop and mobile powered by Angular

160 lines 19.5 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var vg_utils_1 = require("./vg-utils"); var rxjs_1 = require("rxjs"); var VgFullscreenAPI = /** @class */ (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; } this.isAvailable = (this.polyfill != null); if (this.polyfill == null) { return; } 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 = rxjs_1.fromEvent(fsElemDispatcher, this.polyfill.onchange).subscribe(function () { _this.onFullscreenChange(); }); }; VgFullscreenAPI.prototype.onFullscreenChange = function () { this.isFullscreen = !!document[this.polyfill.element]; this.onChangeFullscreen.emit(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.emit(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.emit(false); // Exit from native fullscreen if (this.isAvailable && this.nativeFullscreen) { document[this.polyfill.exit](); } }; VgFullscreenAPI = __decorate([ core_1.Injectable(), __metadata("design:paramtypes", []) ], VgFullscreenAPI); return VgFullscreenAPI; }()); exports.VgFullscreenAPI = VgFullscreenAPI; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-fullscreen-api.js","sourceRoot":"","sources":["../../../../src/core/services/vg-fullscreen-api.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Injectable, QueryList } from '@angular/core';\nimport { VgUtils } from './vg-utils';\nimport { VgMedia } from '../vg-media/vg-media';\nimport { Subscription, fromEvent } from 'rxjs';\n\n@Injectable()\nexport class VgFullscreenAPI {\n    polyfill: any;\n    onchange: string;\n    onerror: string;\n    nativeFullscreen = true;\n    isFullscreen = 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\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        this.isAvailable = (this.polyfill != null);\n\n        if (this.polyfill == null) {\n            return;\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 = fromEvent(fsElemDispatcher, this.polyfill.onchange).subscribe(() => {\n            this.onFullscreenChange();\n        });\n    }\n\n    onFullscreenChange() {\n        this.isFullscreen = !!document[ this.polyfill.element ];\n        this.onChangeFullscreen.emit(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.emit(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.emit(false);\n\n        // Exit from native fullscreen\n        if (this.isAvailable && this.nativeFullscreen) {\n            document[ this.polyfill.exit ]();\n        }\n    }\n}\n"]}