UNPKG

videogular2

Version:

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

100 lines 17.3 kB
"use strict"; var core_1 = require('@angular/core'); var vg_api_1 = require('../core/services/vg-api'); var vg_states_1 = require('../core/states/vg-states'); var vg_fullscreen_api_1 = require('../core/services/vg-fullscreen-api'); var vg_controls_hidden_1 = require('../core/services/vg-controls-hidden'); var VgOverlayPlay = (function () { function VgOverlayPlay(ref, API, fsAPI, controlsHidden) { this.API = API; this.fsAPI = fsAPI; this.controlsHidden = controlsHidden; this.isNativeFullscreen = false; this.areControlsHidden = false; this.subscriptions = []; this.isBuffering = false; this.elem = ref.nativeElement; } VgOverlayPlay.prototype.ngOnInit = function () { var _this = this; if (this.API.isPlayerReady) { this.onPlayerReady(); } else { this.subscriptions.push(this.API.playerReadyEvent.subscribe(function () { return _this.onPlayerReady(); })); } }; VgOverlayPlay.prototype.onPlayerReady = function () { var _this = this; this.target = this.API.getMediaById(this.vgFor); this.subscriptions.push(this.fsAPI.onChangeFullscreen.subscribe(this.onChangeFullscreen.bind(this))); this.subscriptions.push(this.controlsHidden.isHidden.subscribe(this.onHideControls.bind(this))); this.subscriptions.push(this.target.subscriptions.bufferDetected.subscribe(function (isBuffering) { return _this.onUpdateBuffer(isBuffering); })); }; VgOverlayPlay.prototype.onUpdateBuffer = function (isBuffering) { this.isBuffering = isBuffering; }; VgOverlayPlay.prototype.onChangeFullscreen = function (fsState) { if (this.fsAPI.nativeFullscreen) { this.isNativeFullscreen = fsState; } }; VgOverlayPlay.prototype.onHideControls = function (hidden) { this.areControlsHidden = hidden; }; VgOverlayPlay.prototype.onClick = function () { var state = this.getState(); switch (state) { case vg_states_1.VgStates.VG_PLAYING: this.target.pause(); break; case vg_states_1.VgStates.VG_PAUSED: case vg_states_1.VgStates.VG_ENDED: this.target.play(); break; } }; VgOverlayPlay.prototype.getState = function () { var state = vg_states_1.VgStates.VG_PAUSED; if (this.target) { if (this.target.state instanceof Array) { for (var i = 0, l = this.target.state.length; i < l; i++) { if (this.target.state[i] === vg_states_1.VgStates.VG_PLAYING) { state = vg_states_1.VgStates.VG_PLAYING; break; } } } else { state = this.target.state; } } return state; }; VgOverlayPlay.prototype.ngOnDestroy = function () { this.subscriptions.forEach(function (s) { return s.unsubscribe(); }); }; VgOverlayPlay.decorators = [ { type: core_1.Component, args: [{ selector: 'vg-overlay-play', encapsulation: core_1.ViewEncapsulation.None, template: "<div class=\"vg-overlay-play\"\n [class.native-fullscreen]=\"isNativeFullscreen\"\n [class.controls-hidden]=\"areControlsHidden\">\n <div class=\"overlay-play-container\"\n [class.vg-icon-play_arrow]=\"getState() !== 'playing'\">\n </div>\n </div>", styles: ["\n vg-overlay-play {\n z-index: 200;\n }\n\n vg-overlay-play.is-buffering {\n display: none;\n }\n\n vg-overlay-play .vg-overlay-play {\n transition: all 0.5s;\n cursor: pointer;\n position: absolute;\n display: block;\n color: white;\n width: 100%;\n height: 100%;\n font-size: 80px;\n filter: alpha(opacity=60);\n opacity: 0.6;\n }\n\n vg-overlay-play .vg-overlay-play.native-fullscreen.controls-hidden {\n cursor: none;\n }\n\n vg-overlay-play .vg-overlay-play .overlay-play-container.vg-icon-play_arrow {\n pointer-events: none;\n width: 100%;\n height: 100%;\n position: absolute;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 80px;\n }\n\n vg-overlay-play .vg-overlay-play:hover {\n filter: alpha(opacity=100);\n opacity: 1;\n }\n\n vg-overlay-play .vg-overlay-play:hover .overlay-play-container.vg-icon-play_arrow:before {\n transform: scale(1.2);\n }\n "] },] }, ]; /** @nocollapse */ VgOverlayPlay.ctorParameters = [ { type: core_1.ElementRef, }, { type: vg_api_1.VgAPI, }, { type: vg_fullscreen_api_1.VgFullscreenAPI, }, { type: vg_controls_hidden_1.VgControlsHidden, }, ]; VgOverlayPlay.propDecorators = { 'vgFor': [{ type: core_1.Input },], 'isBuffering': [{ type: core_1.HostBinding, args: ['class.is-buffering',] },], 'onClick': [{ type: core_1.HostListener, args: ['click',] },], }; return VgOverlayPlay; }()); exports.VgOverlayPlay = VgOverlayPlay; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-overlay-play.js","sourceRoot":"","sources":["vg-overlay-play.ts"],"names":[],"mappings":";AAAA,qBAGO,eAAe,CAAC,CAAA;AACvB,uBAAsB,yBAAyB,CAAC,CAAA;AAChD,0BAAyB,0BAA0B,CAAC,CAAA;AAEpD,kCAAgC,oCAAoC,CAAC,CAAA;AACrE,mCAAiC,qCAAqC,CAAC,CAAA;AAGvE;IAYI,uBAAY,GAAe,EAAS,GAAU,EAAS,KAAsB,EAAU,cAAgC;QAAnF,QAAG,GAAH,GAAG,CAAO;QAAS,UAAK,GAAL,KAAK,CAAiB;QAAU,mBAAc,GAAd,cAAc,CAAkB;QAPvH,uBAAkB,GAAY,KAAK,CAAC;QACpC,sBAAiB,GAAY,KAAK,CAAC;QAEnC,kBAAa,GAAmB,EAAE,CAAC;QAElC,gBAAW,GAAY,KAAK,CAAC;QAG1B,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,aAAa,CAAC;IAClC,CAAC;IAED,gCAAQ,GAAR;QAAA,iBAOC;QANG,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC;YACzB,IAAI,CAAC,aAAa,EAAE,CAAC;QACzB,CAAC;QACD,IAAI,CAAC,CAAC;YACF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAM,OAAA,KAAI,CAAC,aAAa,EAAE,EAApB,CAAoB,CAAC,CAAC,CAAC;QAC7F,CAAC;IACL,CAAC;IAED,qCAAa,GAAb;QAAA,iBASC;QARG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,SAAS,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACrG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAChG,IAAI,CAAC,aAAa,CAAC,IAAI,CACnB,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,cAAc,CAAC,SAAS,CAC9C,UAAA,WAAW,IAAI,OAAA,KAAI,CAAC,cAAc,CAAC,WAAW,CAAC,EAAhC,CAAgC,CAClD,CACJ,CAAC;IACN,CAAC;IAED,sCAAc,GAAd,UAAe,WAAW;QACtB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACnC,CAAC;IAED,0CAAkB,GAAlB,UAAmB,OAAgB;QAC/B,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC;QACtC,CAAC;IACL,CAAC;IAED,sCAAc,GAAd,UAAe,MAAe;QAC1B,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC;IACpC,CAAC;IAGD,+BAAO,GAAP;QACI,IAAI,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAE5B,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;YACZ,KAAK,oBAAQ,CAAC,UAAU;gBACpB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;gBACpB,KAAK,CAAC;YAEV,KAAK,oBAAQ,CAAC,SAAS,CAAC;YACxB,KAAK,oBAAQ,CAAC,QAAQ;gBAClB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;gBACnB,KAAK,CAAC;QACd,CAAC;IACL,CAAC;IAED,gCAAQ,GAAR;QACI,IAAI,KAAK,GAAG,oBAAQ,CAAC,SAAS,CAAC;QAE/B,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;YACd,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC;gBACrC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;oBACvD,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAE,CAAC,CAAE,KAAK,oBAAQ,CAAC,UAAU,CAAC,CAAC,CAAC;wBACjD,KAAK,GAAG,oBAAQ,CAAC,UAAU,CAAC;wBAC5B,KAAK,CAAC;oBACV,CAAC;gBACL,CAAC;YACL,CAAC;YACD,IAAI,CAAC,CAAC;gBACF,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;YAC9B,CAAC;QACL,CAAC;QAED,MAAM,CAAC,KAAK,CAAC;IACjB,CAAC;IAED,mCAAW,GAAX;QACI,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,WAAW,EAAE,EAAf,CAAe,CAAC,CAAC;IACrD,CAAC;IACE,wBAAU,GAA0B;QAC3C,EAAE,IAAI,EAAE,gBAAS,EAAE,IAAI,EAAE,CAAC;oBACtB,QAAQ,EAAE,iBAAiB;oBAC3B,aAAa,EAAE,wBAAiB,CAAC,IAAI;oBACrC,QAAQ,EAAE,wWAMQ;oBAClB,MAAM,EAAE,CAAE,8uCA6CT,CAAE;iBACN,EAAG,EAAE;KACL,CAAC;IACF,kBAAkB;IACX,4BAAc,GAA6D;QAClF,EAAC,IAAI,EAAE,iBAAU,GAAG;QACpB,EAAC,IAAI,EAAE,cAAK,GAAG;QACf,EAAC,IAAI,EAAE,mCAAe,GAAG;QACzB,EAAC,IAAI,EAAE,qCAAgB,GAAG;KACzB,CAAC;IACK,4BAAc,GAA2C;QAChE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,YAAK,EAAE,EAAE;QAC3B,aAAa,EAAE,CAAC,EAAE,IAAI,EAAE,kBAAW,EAAE,IAAI,EAAE,CAAC,oBAAoB,EAAG,EAAE,EAAE;QACvE,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,mBAAY,EAAE,IAAI,EAAE,CAAC,OAAO,EAAG,EAAE,EAAE;KACtD,CAAC;IACF,oBAAC;AAAD,CAAC,AAhKD,IAgKC;AAhKY,qBAAa,gBAgKzB,CAAA","sourcesContent":["import {\n    Component, OnInit, Input, ElementRef, HostListener, ViewEncapsulation, OnDestroy,\n    HostBinding\n} from '@angular/core';\nimport { VgAPI } from '../core/services/vg-api';\nimport { VgStates } from '../core/states/vg-states';\nimport { Subscription } from 'rxjs/Subscription';\nimport { VgFullscreenAPI } from '../core/services/vg-fullscreen-api';\nimport { VgControlsHidden } from '../core/services/vg-controls-hidden';\n\n\nexport class VgOverlayPlay implements OnInit, OnDestroy {\n     vgFor: string;\n    elem: HTMLElement;\n    target: any;\n\n    isNativeFullscreen: boolean = false;\n    areControlsHidden: boolean = false;\n\n    subscriptions: Subscription[] = [];\n\n     isBuffering: boolean = false;\n\n    constructor(ref: ElementRef, public API: VgAPI, public fsAPI: VgFullscreenAPI, private controlsHidden: VgControlsHidden) {\n        this.elem = ref.nativeElement;\n    }\n\n    ngOnInit() {\n        if (this.API.isPlayerReady) {\n            this.onPlayerReady();\n        }\n        else {\n            this.subscriptions.push(this.API.playerReadyEvent.subscribe(() => this.onPlayerReady()));\n        }\n    }\n\n    onPlayerReady() {\n        this.target = this.API.getMediaById(this.vgFor);\n        this.subscriptions.push(this.fsAPI.onChangeFullscreen.subscribe(this.onChangeFullscreen.bind(this)));\n        this.subscriptions.push(this.controlsHidden.isHidden.subscribe(this.onHideControls.bind(this)));\n        this.subscriptions.push(\n            this.target.subscriptions.bufferDetected.subscribe(\n                isBuffering => this.onUpdateBuffer(isBuffering)\n            )\n        );\n    }\n\n    onUpdateBuffer(isBuffering) {\n        this.isBuffering = isBuffering;\n    }\n\n    onChangeFullscreen(fsState: boolean) {\n        if (this.fsAPI.nativeFullscreen) {\n            this.isNativeFullscreen = fsState;\n        }\n    }\n\n    onHideControls(hidden: boolean) {\n        this.areControlsHidden = hidden;\n    }\n\n    \n    onClick() {\n        let state = this.getState();\n\n        switch (state) {\n            case VgStates.VG_PLAYING:\n                this.target.pause();\n                break;\n\n            case VgStates.VG_PAUSED:\n            case VgStates.VG_ENDED:\n                this.target.play();\n                break;\n        }\n    }\n\n    getState() {\n        let state = VgStates.VG_PAUSED;\n\n        if (this.target) {\n            if (this.target.state instanceof Array) {\n                for (let i = 0, l = this.target.state.length; i < l; i++) {\n                    if (this.target.state[ i ] === VgStates.VG_PLAYING) {\n                        state = VgStates.VG_PLAYING;\n                        break;\n                    }\n                }\n            }\n            else {\n                state = this.target.state;\n            }\n        }\n\n        return state;\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Component, args: [{\n    selector: 'vg-overlay-play',\n    encapsulation: ViewEncapsulation.None,\n    template: `<div class=\"vg-overlay-play\"\n                    [class.native-fullscreen]=\"isNativeFullscreen\"\n                    [class.controls-hidden]=\"areControlsHidden\">\n                   <div class=\"overlay-play-container\"\n                        [class.vg-icon-play_arrow]=\"getState() !== 'playing'\">\n                   </div>\n               </div>`,\n    styles: [ `\n        vg-overlay-play {\n            z-index: 200;\n        }\n\n        vg-overlay-play.is-buffering {\n            display: none;\n        }\n\n        vg-overlay-play .vg-overlay-play {\n            transition: all 0.5s;\n            cursor: pointer;\n            position: absolute;\n            display: block;\n            color: white;\n            width: 100%;\n            height: 100%;\n            font-size: 80px;\n            filter: alpha(opacity=60);\n            opacity: 0.6;\n        }\n\n        vg-overlay-play .vg-overlay-play.native-fullscreen.controls-hidden {\n            cursor: none;\n        }\n\n        vg-overlay-play .vg-overlay-play .overlay-play-container.vg-icon-play_arrow {\n            pointer-events: none;\n            width: 100%;\n            height: 100%;\n            position: absolute;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n            font-size: 80px;\n        }\n\n        vg-overlay-play .vg-overlay-play:hover {\n            filter: alpha(opacity=100);\n            opacity: 1;\n        }\n\n        vg-overlay-play .vg-overlay-play:hover .overlay-play-container.vg-icon-play_arrow:before {\n            transform: scale(1.2);\n        }\n    ` ]\n}, ] },\n];\n/** @nocollapse */\nstatic ctorParameters: ({type: any, decorators?: DecoratorInvocation[]}|null)[] = [\n{type: ElementRef, },\n{type: VgAPI, },\n{type: VgFullscreenAPI, },\n{type: VgControlsHidden, },\n];\nstatic propDecorators: {[key: string]: DecoratorInvocation[]} = {\n'vgFor': [{ type: Input },],\n'isBuffering': [{ type: HostBinding, args: ['class.is-buffering', ] },],\n'onClick': [{ type: HostListener, args: ['click', ] },],\n};\n}\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}