videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular 2.0
76 lines • 12.7 kB
JavaScript
"use strict";
var core_1 = require('@angular/core');
var vg_api_1 = require('../services/vg-api');
var vg_fullscreen_api_1 = require('../services/vg-fullscreen-api');
var vg_utils_1 = require('../services/vg-utils');
var vg_media_1 = require('../vg-media/vg-media');
var vg_controls_hidden_1 = require('../services/vg-controls-hidden');
var VgPlayer = (function () {
function VgPlayer(ref, api, fsAPI, controlsHidden) {
this.api = api;
this.fsAPI = fsAPI;
this.controlsHidden = controlsHidden;
this.isFullscreen = false;
this.isNativeFullscreen = false;
this.areControlsHidden = false;
this.onPlayerReady = new core_1.EventEmitter();
this.onMediaReady = new core_1.EventEmitter();
this.subscriptions = [];
this.elem = ref.nativeElement;
this.api.registerElement(this.elem);
}
VgPlayer.prototype.ngAfterContentInit = function () {
var _this = this;
this.medias.toArray().forEach(function (media) {
_this.api.registerMedia(media);
});
this.fsAPI.init(this.elem, this.medias);
this.subscriptions.push(this.fsAPI.onChangeFullscreen.subscribe(this.onChangeFullscreen.bind(this)));
this.subscriptions.push(this.controlsHidden.isHidden.subscribe(this.onHideControls.bind(this)));
this.api.onPlayerReady(this.fsAPI);
this.onPlayerReady.next(this.api);
};
VgPlayer.prototype.onChangeFullscreen = function (fsState) {
if (!this.fsAPI.nativeFullscreen) {
this.isFullscreen = fsState;
this.zIndex = fsState ? vg_utils_1.VgUtils.getZIndex().toString() : 'auto';
}
else {
this.isNativeFullscreen = fsState;
}
};
VgPlayer.prototype.onHideControls = function (hidden) {
this.areControlsHidden = hidden;
};
VgPlayer.prototype.ngOnDestroy = function () {
this.subscriptions.forEach(function (s) { return s.unsubscribe(); });
};
VgPlayer.decorators = [
{ type: core_1.Component, args: [{
selector: 'vg-player',
encapsulation: core_1.ViewEncapsulation.None,
template: "<ng-content></ng-content>",
styles: ["\n vg-player {\n font-family: 'videogular';\n position: relative;\n display: flex;\n width: 100%;\n height: 100%;\n overflow: hidden;\n background-color: black;\n }\n\n vg-player.fullscreen {\n position: fixed;\n left: 0;\n top: 0;\n }\n\n vg-player.native-fullscreen.controls-hidden {\n cursor: none;\n }\n "],
providers: [vg_api_1.VgAPI, vg_fullscreen_api_1.VgFullscreenAPI, vg_controls_hidden_1.VgControlsHidden]
},] },
];
/** @nocollapse */
VgPlayer.ctorParameters = [
{ type: core_1.ElementRef, },
{ type: vg_api_1.VgAPI, },
{ type: vg_fullscreen_api_1.VgFullscreenAPI, },
{ type: vg_controls_hidden_1.VgControlsHidden, },
];
VgPlayer.propDecorators = {
'isFullscreen': [{ type: core_1.HostBinding, args: ['class.fullscreen',] },],
'isNativeFullscreen': [{ type: core_1.HostBinding, args: ['class.native-fullscreen',] },],
'areControlsHidden': [{ type: core_1.HostBinding, args: ['class.controls-hidden',] },],
'zIndex': [{ type: core_1.HostBinding, args: ['style.z-index',] },],
'onPlayerReady': [{ type: core_1.Output },],
'onMediaReady': [{ type: core_1.Output },],
'medias': [{ type: core_1.ContentChildren, args: [vg_media_1.VgMedia,] },],
};
return VgPlayer;
}());
exports.VgPlayer = VgPlayer;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-player.js","sourceRoot":"","sources":["vg-player.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Output,\n    Component,\n    EventEmitter,\n    ElementRef,\n    HostBinding,\n    QueryList,\n    AfterContentInit,\n    ContentChildren, ViewEncapsulation, OnDestroy\n} from '@angular/core';\nimport { VgAPI } from '../services/vg-api';\nimport { VgFullscreenAPI } from '../services/vg-fullscreen-api';\nimport { VgUtils } from '../services/vg-utils';\nimport { VgMedia } from '../vg-media/vg-media';\nimport { Subscription } from 'rxjs/Subscription';\nimport { VgControlsHidden } from '../services/vg-controls-hidden';\n\n\nexport class VgPlayer implements AfterContentInit, OnDestroy {\n    elem: HTMLElement;\n\n     isFullscreen: boolean = false;\n     isNativeFullscreen: boolean = false;\n     areControlsHidden: boolean = false;\n     zIndex: string;\n\n    \n    onPlayerReady: EventEmitter<any> = new EventEmitter();\n\n    \n    onMediaReady: EventEmitter<any> = new EventEmitter();\n\n    \n    medias: QueryList<VgMedia>;\n\n    subscriptions: Subscription[] = [];\n\n    constructor(ref: ElementRef, public api: VgAPI, public fsAPI: VgFullscreenAPI, private controlsHidden: VgControlsHidden) {\n        this.elem = ref.nativeElement;\n\n        this.api.registerElement(this.elem);\n    }\n\n    ngAfterContentInit() {\n        this.medias.toArray().forEach((media) => {\n            this.api.registerMedia(media);\n        });\n\n        this.fsAPI.init(this.elem, this.medias);\n\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\n        this.api.onPlayerReady(this.fsAPI);\n        this.onPlayerReady.next(this.api);\n    }\n\n    onChangeFullscreen(fsState: boolean) {\n        if (!this.fsAPI.nativeFullscreen) {\n            this.isFullscreen = fsState;\n            this.zIndex = fsState ? VgUtils.getZIndex().toString() : 'auto';\n        } else {\n            this.isNativeFullscreen = fsState;\n        }\n    }\n\n    onHideControls(hidden: boolean) {\n        this.areControlsHidden = hidden;\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Component, args: [{\n    selector: 'vg-player',\n    encapsulation: ViewEncapsulation.None,\n    template: `<ng-content></ng-content>`,\n    styles: [ `\n        vg-player {\n            font-family: 'videogular';\n            position: relative;\n            display: flex;\n            width: 100%;\n            height: 100%;\n            overflow: hidden;\n            background-color: black;\n        }\n\n        vg-player.fullscreen {\n            position: fixed;\n            left: 0;\n            top: 0;\n        }\n\n        vg-player.native-fullscreen.controls-hidden {\n            cursor: none;\n        }\n    ` ],\n    providers: [ VgAPI, VgFullscreenAPI, VgControlsHidden ]\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'isFullscreen': [{ type: HostBinding, args: ['class.fullscreen', ] },],\n'isNativeFullscreen': [{ type: HostBinding, args: ['class.native-fullscreen', ] },],\n'areControlsHidden': [{ type: HostBinding, args: ['class.controls-hidden', ] },],\n'zIndex': [{ type: HostBinding, args: ['style.z-index', ] },],\n'onPlayerReady': [{ type: Output },],\n'onMediaReady': [{ type: Output },],\n'medias': [{ type: ContentChildren, args: [VgMedia, ] },],\n};\n}\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}