videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular
132 lines • 16 kB
JavaScript
"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_controls_hidden_1 = require("./../core/services/vg-controls-hidden");
var vg_states_1 = require("../core/states/vg-states");
var rxjs_1 = require("rxjs");
var VgControls = /** @class */ (function () {
// @ts-ignore
function VgControls(API, ref, hidden) {
this.API = API;
this.ref = ref;
this.hidden = hidden;
this.isAdsPlaying = 'initial';
this.hideControls = false;
this.vgAutohide = false;
this.vgAutohideTime = 3;
this.subscriptions = [];
this.elem = ref.nativeElement;
}
VgControls.prototype.ngOnInit = function () {
var _this = this;
this.mouseMove$ = rxjs_1.fromEvent(this.API.videogularElement, 'mousemove');
this.subscriptions.push(this.mouseMove$.subscribe(this.show.bind(this)));
this.touchStart$ = rxjs_1.fromEvent(this.API.videogularElement, 'touchstart');
this.subscriptions.push(this.touchStart$.subscribe(this.show.bind(this)));
if (this.API.isPlayerReady) {
this.onPlayerReady();
}
else {
this.subscriptions.push(this.API.playerReadyEvent.subscribe(function () { return _this.onPlayerReady(); }));
}
};
VgControls.prototype.onPlayerReady = function () {
this.target = this.API.getMediaById(this.vgFor);
this.subscriptions.push(this.target.subscriptions.play.subscribe(this.onPlay.bind(this)));
this.subscriptions.push(this.target.subscriptions.pause.subscribe(this.onPause.bind(this)));
this.subscriptions.push(this.target.subscriptions.startAds.subscribe(this.onStartAds.bind(this)));
this.subscriptions.push(this.target.subscriptions.endAds.subscribe(this.onEndAds.bind(this)));
};
VgControls.prototype.ngAfterViewInit = function () {
if (this.vgAutohide) {
this.hide();
}
else {
this.show();
}
};
VgControls.prototype.onPlay = function () {
if (this.vgAutohide) {
this.hide();
}
};
VgControls.prototype.onPause = function () {
clearTimeout(this.timer);
this.hideControls = false;
this.hidden.state(false);
};
VgControls.prototype.onStartAds = function () {
this.isAdsPlaying = 'none';
};
VgControls.prototype.onEndAds = function () {
this.isAdsPlaying = 'initial';
};
VgControls.prototype.hide = function () {
if (this.vgAutohide) {
clearTimeout(this.timer);
this.hideAsync();
}
};
VgControls.prototype.show = function () {
clearTimeout(this.timer);
this.hideControls = false;
this.hidden.state(false);
if (this.vgAutohide) {
this.hideAsync();
}
};
VgControls.prototype.hideAsync = function () {
var _this = this;
if (this.API.state === vg_states_1.VgStates.VG_PLAYING) {
this.timer = setTimeout(function () {
_this.hideControls = true;
_this.hidden.state(true);
}, this.vgAutohideTime * 1000);
}
};
VgControls.prototype.ngOnDestroy = function () {
this.subscriptions.forEach(function (s) { return s.unsubscribe(); });
};
__decorate([
core_1.HostBinding('style.pointer-events'),
__metadata("design:type", Object)
], VgControls.prototype, "isAdsPlaying", void 0);
__decorate([
core_1.HostBinding('class.hide'),
__metadata("design:type", Object)
], VgControls.prototype, "hideControls", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", String)
], VgControls.prototype, "vgFor", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", Object)
], VgControls.prototype, "vgAutohide", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", Object)
], VgControls.prototype, "vgAutohideTime", void 0);
VgControls = __decorate([
core_1.Component({
selector: 'vg-controls',
encapsulation: core_1.ViewEncapsulation.None,
template: "<ng-content></ng-content>",
styles: ["\n vg-controls {\n position: absolute;\n display: flex;\n width: 100%;\n height: 50px;\n z-index: 300;\n bottom: 0;\n background-color: rgba(0, 0, 0, 0.5);\n -webkit-transition: bottom 1s;\n -khtml-transition: bottom 1s;\n -moz-transition: bottom 1s;\n -ms-transition: bottom 1s;\n transition: bottom 1s;\n }\n\n vg-controls.hide {\n bottom: -50px;\n }\n "]
}),
__metadata("design:paramtypes", [vg_api_1.VgAPI, core_1.ElementRef, vg_controls_hidden_1.VgControlsHidden])
], VgControls);
return VgControls;
}());
exports.VgControls = VgControls;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-controls.js","sourceRoot":"","sources":["../../../src/controls/vg-controls.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component, Input, OnInit, ElementRef, HostBinding, AfterViewInit, ViewEncapsulation, OnDestroy\n} from '@angular/core';\nimport { Observable ,  Subscription } from 'rxjs';\nimport { VgAPI } from '../core/services/vg-api';\nimport { VgControlsHidden } from './../core/services/vg-controls-hidden';\n\nimport { VgStates } from '../core/states/vg-states';\nimport {fromEvent} from 'rxjs';\n\n@Component({\n    selector: 'vg-controls',\n    encapsulation: ViewEncapsulation.None,\n    template: `<ng-content></ng-content>`,\n    styles: [ `\n        vg-controls {\n            position: absolute;\n            display: flex;\n            width: 100%;\n            height: 50px;\n            z-index: 300;\n            bottom: 0;\n            background-color: rgba(0, 0, 0, 0.5);\n            -webkit-transition: bottom 1s;\n            -khtml-transition: bottom 1s;\n            -moz-transition: bottom 1s;\n            -ms-transition: bottom 1s;\n            transition: bottom 1s;\n        }\n\n        vg-controls.hide {\n            bottom: -50px;\n        }\n    `]\n})\nexport class VgControls implements OnInit, AfterViewInit, OnDestroy {\n    elem: HTMLElement;\n    target: any;\n\n    @HostBinding('style.pointer-events') isAdsPlaying = 'initial';\n    @HostBinding('class.hide') hideControls = false;\n\n    @Input() vgFor: string;\n    @Input() vgAutohide = false;\n    @Input() vgAutohideTime = 3;\n\n    private timer: any;\n\n    mouseMove$: Observable<any>;\n    touchStart$: Observable<any>;\n\n    subscriptions: Subscription[] = [];\n    // @ts-ignore\n    constructor(private API: VgAPI, private ref: ElementRef, private hidden: VgControlsHidden) {\n        this.elem = ref.nativeElement;\n    }\n\n    ngOnInit() {\n        this.mouseMove$ = fromEvent(this.API.videogularElement, 'mousemove');\n        this.subscriptions.push(this.mouseMove$.subscribe(this.show.bind(this)));\n\n        this.touchStart$ = fromEvent(this.API.videogularElement, 'touchstart');\n        this.subscriptions.push(this.touchStart$.subscribe(this.show.bind(this)));\n\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\n        this.subscriptions.push(this.target.subscriptions.play.subscribe(this.onPlay.bind(this)));\n        this.subscriptions.push(this.target.subscriptions.pause.subscribe(this.onPause.bind(this)));\n        this.subscriptions.push(this.target.subscriptions.startAds.subscribe(this.onStartAds.bind(this)));\n        this.subscriptions.push(this.target.subscriptions.endAds.subscribe(this.onEndAds.bind(this)));\n    }\n\n    ngAfterViewInit() {\n        if (this.vgAutohide) {\n            this.hide();\n        }\n        else {\n            this.show();\n        }\n    }\n\n    onPlay() {\n        if (this.vgAutohide) {\n            this.hide();\n        }\n    }\n\n    onPause() {\n        clearTimeout(this.timer);\n        this.hideControls = false;\n        this.hidden.state(false);\n    }\n\n    onStartAds() {\n        this.isAdsPlaying = 'none';\n    }\n\n    onEndAds() {\n        this.isAdsPlaying = 'initial';\n    }\n\n    hide() {\n        if (this.vgAutohide) {\n            clearTimeout(this.timer);\n            this.hideAsync();\n        }\n    }\n\n    show() {\n        clearTimeout(this.timer);\n        this.hideControls = false;\n        this.hidden.state(false);\n\n        if (this.vgAutohide) {\n            this.hideAsync();\n        }\n    }\n\n    private hideAsync() {\n        if (this.API.state === VgStates.VG_PLAYING) {\n            this.timer = setTimeout(() => {\n                this.hideControls = true;\n                this.hidden.state(true);\n            }, this.vgAutohideTime * 1000);\n        }\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n}\n"]}