videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular 2.0
96 lines • 12 kB
JavaScript
"use strict";
var core_1 = require("@angular/core");
var vg_api_1 = require("../../core/services/vg-api");
var VgHLS = (function () {
function VgHLS(ref, API) {
this.ref = ref;
this.API = API;
this.subscriptions = [];
}
VgHLS.prototype.ngOnInit = function () {
var _this = this;
if (this.API.isPlayerReady) {
this.onPlayerReady();
}
else {
this.subscriptions.push(this.API.playerReadyEvent.subscribe(function () { return _this.onPlayerReady(); }));
}
};
VgHLS.prototype.onPlayerReady = function () {
var _this = this;
this.crossorigin = this.ref.nativeElement.getAttribute('crossorigin');
this.preload = this.ref.nativeElement.getAttribute('preload') !== 'none';
this.vgFor = this.ref.nativeElement.getAttribute('vgFor');
this.target = this.API.getMediaById(this.vgFor);
this.config = {
autoStartLoad: this.preload
};
if (this.crossorigin === 'use-credentials') {
this.config.xhrSetup = function (xhr, url) {
// Send cookies
xhr.withCredentials = true;
};
}
this.createPlayer();
if (!this.preload) {
this.subscriptions.push(this.API.subscriptions.play.subscribe(function () {
if (_this.hls) {
_this.hls.startLoad(0);
}
}));
}
};
VgHLS.prototype.ngOnChanges = function (changes) {
if (changes['vgHls'].currentValue) {
this.createPlayer();
}
else {
this.destroyPlayer();
}
};
VgHLS.prototype.createPlayer = function () {
if (this.hls) {
this.destroyPlayer();
}
// It's a HLS source
if (this.vgHls && this.vgHls.indexOf('.m3u8') > -1 && Hls.isSupported()) {
var video = this.ref.nativeElement;
this.hls = new Hls(this.config);
this.hls.loadSource(this.vgHls);
this.hls.attachMedia(video);
}
else {
if (this.target && !!this.target.pause) {
this.target.pause();
this.target.seekTime(0);
this.ref.nativeElement.src = this.vgHls;
}
}
};
VgHLS.prototype.destroyPlayer = function () {
if (this.hls) {
this.hls.destroy();
this.hls = null;
}
};
VgHLS.prototype.ngOnDestroy = function () {
this.subscriptions.forEach(function (s) { return s.unsubscribe(); });
this.destroyPlayer();
};
VgHLS.decorators = [
{ type: core_1.Directive, args: [{
selector: '[vgHls]'
},] },
];
/** @nocollapse */
VgHLS.ctorParameters = [
{ type: core_1.ElementRef, },
{ type: vg_api_1.VgAPI, },
];
VgHLS.propDecorators = {
'vgHls': [{ type: core_1.Input },],
};
return VgHLS;
}());
exports.VgHLS = VgHLS;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-hls.js","sourceRoot":"","sources":["vg-hls.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, SimpleChanges, OnChanges, OnDestroy, OnInit } from \"@angular/core\";\nimport { VgAPI } from \"../../core/services/vg-api\";\nimport { IHLSConfig } from './hls-config';\nimport { Subscription } from 'rxjs/Subscription';\n\ndeclare let Hls;\n\n\nexport class VgHLS implements OnInit, OnChanges, OnDestroy {\n     vgHls:string;\n\n    vgFor: string;\n    target: any;\n    hls: any;\n    preload: boolean;\n    crossorigin: string;\n    config: IHLSConfig;\n\n    subscriptions: Subscription[] = [];\n\n    constructor(private ref:ElementRef, public API:VgAPI) {}\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.crossorigin = this.ref.nativeElement.getAttribute('crossorigin');\n        this.preload = this.ref.nativeElement.getAttribute('preload') !== 'none';\n        this.vgFor = this.ref.nativeElement.getAttribute('vgFor');\n        this.target = this.API.getMediaById(this.vgFor);\n\n        this.config = <IHLSConfig>{\n            autoStartLoad: this.preload\n        };\n\n        if (this.crossorigin === 'use-credentials') {\n            this.config.xhrSetup = (xhr, url) => {\n                // Send cookies\n                xhr.withCredentials = true;\n            };\n        }\n\n        this.createPlayer();\n\n        if (!this.preload) {\n            this.subscriptions.push(\n                this.API.subscriptions.play.subscribe(\n                    () => {\n                        if (this.hls) {\n                            this.hls.startLoad(0);\n                        }\n                    }\n                )\n            );\n        }\n    }\n\n    ngOnChanges(changes:SimpleChanges) {\n        if (changes['vgHls'].currentValue) {\n            this.createPlayer();\n        }\n        else {\n            this.destroyPlayer();\n        }\n    }\n\n    createPlayer() {\n        if (this.hls) {\n            this.destroyPlayer();\n        }\n\n        // It's a HLS source\n        if (this.vgHls && this.vgHls.indexOf('.m3u8') > -1 && Hls.isSupported()) {\n            let video:HTMLVideoElement = this.ref.nativeElement;\n\n            this.hls = new Hls(this.config);\n            this.hls.loadSource(this.vgHls);\n            this.hls.attachMedia(video);\n        }\n        else {\n            if (this.target && !!this.target.pause) {\n                this.target.pause();\n                this.target.seekTime(0);\n                this.ref.nativeElement.src = this.vgHls;\n            }\n        }\n    }\n\n    destroyPlayer() {\n        if (this.hls) {\n            this.hls.destroy();\n            this.hls = null;\n        }\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n        this.destroyPlayer();\n    }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Directive, args: [{\n    selector: '[vgHls]'\n}, ] },\n];\n/** @nocollapse */\nstatic ctorParameters: ({type: any, decorators?: DecoratorInvocation[]}|null)[] = [\n{type: ElementRef, },\n{type: VgAPI, },\n];\nstatic propDecorators: {[key: string]: DecoratorInvocation[]} = {\n'vgHls': [{ type: Input },],\n};\n}\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}