UNPKG

videogular2

Version:

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

113 lines 16.8 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_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 = /** @class */ (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(); }); }; __decorate([ core_1.Input(), __metadata("design:type", String) ], VgOverlayPlay.prototype, "vgFor", void 0); __decorate([ core_1.HostBinding('class.is-buffering'), __metadata("design:type", Object) ], VgOverlayPlay.prototype, "isBuffering", void 0); __decorate([ core_1.HostListener('click'), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], VgOverlayPlay.prototype, "onClick", null); VgOverlayPlay = __decorate([ core_1.Component({ 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 "] }), __metadata("design:paramtypes", [core_1.ElementRef, vg_api_1.VgAPI, vg_fullscreen_api_1.VgFullscreenAPI, vg_controls_hidden_1.VgControlsHidden]) ], VgOverlayPlay); return VgOverlayPlay; }()); exports.VgOverlayPlay = VgOverlayPlay; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-overlay-play.js","sourceRoot":"","sources":["../../../src/overlay-play/vg-overlay-play.ts"],"names":[],"mappings":"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","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';\nimport { VgFullscreenAPI } from '../core/services/vg-fullscreen-api';\nimport { VgControlsHidden } from '../core/services/vg-controls-hidden';\n\n@Component({\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})\nexport class VgOverlayPlay implements OnInit, OnDestroy {\n    @Input() vgFor: string;\n    elem: HTMLElement;\n    target: any;\n\n    isNativeFullscreen = false;\n    areControlsHidden = false;\n\n    subscriptions: Subscription[] = [];\n\n    @HostBinding('class.is-buffering') isBuffering = 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    @HostListener('click')\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    }\n}\n"]}