UNPKG

videogular2

Version:

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

157 lines 18.7 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 VgDASH = /** @class */ (function () { function VgDASH(ref, API) { this.ref = ref; this.API = API; this.onGetBitrates = new core_1.EventEmitter(); this.subscriptions = []; } VgDASH.prototype.ngOnInit = function () { var _this = this; if (this.API.isPlayerReady) { this.onPlayerReady(); } else { this.subscriptions.push(this.API.playerReadyEvent.subscribe(function () { return _this.onPlayerReady(); })); } }; VgDASH.prototype.onPlayerReady = function () { this.vgFor = this.ref.nativeElement.getAttribute('vgFor'); this.target = this.API.getMediaById(this.vgFor); this.createPlayer(); }; VgDASH.prototype.ngOnChanges = function (changes) { if (changes['vgDash'] && changes['vgDash'].currentValue) { this.createPlayer(); } else { this.destroyPlayer(); } }; VgDASH.prototype.createPlayer = function () { var _this = this; if (this.dash) { this.destroyPlayer(); } // It's a DASH source if (this.vgDash && ((this.vgDash.indexOf('.mpd') > -1) || (this.vgDash.indexOf('mpd-time-csf') > -1))) { var drmOptions = void 0; if (this.vgDRMLicenseServer) { drmOptions = this.vgDRMLicenseServer; if (this.vgDRMToken) { for (var drmServer in drmOptions) { if (drmServer.hasOwnProperty(drmServer)) { drmOptions[drmServer].httpRequestHeaders = { Authorization: this.vgDRMToken }; } } } } this.dash = dashjs.MediaPlayer().create(); this.dash.getDebug().setLogToBrowserConsole(false); this.dash.initialize(this.ref.nativeElement); this.dash.setAutoPlay(false); this.dash.on(dashjs.MediaPlayer.events.STREAM_INITIALIZED, function () { var audioList = _this.dash.getBitrateInfoListFor('audio'); var videoList = _this.dash.getBitrateInfoListFor('video'); if (audioList.length > 1) { audioList.forEach(function (item) { return item.qualityIndex = ++item.qualityIndex; }); audioList.unshift({ qualityIndex: 0, width: 0, height: 0, bitrate: 0, mediaType: 'video', label: 'AUTO' }); _this.onGetBitrates.emit(audioList); } if (videoList.length > 1) { videoList.forEach(function (item) { return item.qualityIndex = ++item.qualityIndex; }); videoList.unshift({ qualityIndex: 0, width: 0, height: 0, bitrate: 0, mediaType: 'video', label: 'AUTO' }); _this.onGetBitrates.emit(videoList); } }); if (drmOptions) { this.dash.setProtectionData(drmOptions); } this.dash.attachSource(this.vgDash); } else { if (this.target) { this.target.pause(); this.target.seekTime(0); this.ref.nativeElement.src = this.vgDash; } } }; VgDASH.prototype.setBitrate = function (bitrate) { if (this.dash) { if (bitrate.qualityIndex > 0) { if (this.dash.getAutoSwitchQualityFor(bitrate.mediaType)) { this.dash.setAutoSwitchQualityFor(bitrate.mediaType, false); } var nextIndex = bitrate.qualityIndex - 1; this.dash.setQualityFor(bitrate.mediaType, nextIndex); } else { this.dash.setAutoSwitchQualityFor(bitrate.mediaType, true); } } }; VgDASH.prototype.destroyPlayer = function () { if (this.dash) { this.dash.reset(); this.dash = null; } }; VgDASH.prototype.ngOnDestroy = function () { this.subscriptions.forEach(function (s) { return s.unsubscribe(); }); this.destroyPlayer(); }; __decorate([ core_1.Input(), __metadata("design:type", String) ], VgDASH.prototype, "vgDash", void 0); __decorate([ core_1.Input(), __metadata("design:type", String) ], VgDASH.prototype, "vgDRMToken", void 0); __decorate([ core_1.Input(), __metadata("design:type", Object) ], VgDASH.prototype, "vgDRMLicenseServer", void 0); __decorate([ core_1.Output(), __metadata("design:type", core_1.EventEmitter) ], VgDASH.prototype, "onGetBitrates", void 0); VgDASH = __decorate([ core_1.Directive({ selector: '[vgDash]', exportAs: 'vgDash' }), __metadata("design:paramtypes", [core_1.ElementRef, vg_api_1.VgAPI]) ], VgDASH); return VgDASH; }()); exports.VgDASH = VgDASH; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-dash.js","sourceRoot":"","sources":["../../../../src/streaming/vg-dash/vg-dash.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,sCAUuB;AACvB,qDAAmD;AAWnD;IAaI,gBAAoB,GAAc,EAAS,GAAS;QAAhC,QAAG,GAAH,GAAG,CAAW;QAAS,QAAG,GAAH,GAAG,CAAM;QAR1C,kBAAa,GAAkC,IAAI,mBAAY,EAAE,CAAC;QAM5E,kBAAa,GAAmB,EAAE,CAAC;IAEoB,CAAC;IAExD,yBAAQ,GAAR;QAAA,iBAOC;QANG,IAAI,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE;YACxB,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;aACI;YACD,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;SAC5F;IACL,CAAC;IAED,8BAAa,GAAb;QACI,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QAC1D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAED,4BAAW,GAAX,UAAY,OAAqB;QAC7B,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,EAAE;YACrD,IAAI,CAAC,YAAY,EAAE,CAAC;SACvB;aACI;YACD,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;IACL,CAAC;IAED,6BAAY,GAAZ;QAAA,iBA2EC;QA1EG,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;QAED,qBAAqB;QACrB,IAAI,IAAI,CAAC,MAAM,IAAI,CACf,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;YAClC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAC7C;YACE,IAAI,UAAU,SAAA,CAAC;YAEf,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBACzB,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC;gBAErC,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,KAAK,IAAI,SAAS,IAAI,UAAU,EAAE;wBAC9B,IAAG,SAAS,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE;4BACpC,UAAU,CAAC,SAAS,CAAC,CAAC,kBAAkB,GAAG,EAAE,aAAa,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;yBACjF;qBACJ;iBACJ;aACJ;YAED,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,WAAW,EAAE,CAAC,MAAM,EAAE,CAAC;YAC1C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;YACnD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;YAC7C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAE7B,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,kBAAkB,EAAE;gBACvD,IAAM,SAAS,GAAG,KAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;gBAC3D,IAAM,SAAS,GAAG,KAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;gBAE3D,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;oBACtB,SAAS,CAAC,OAAO,CAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,YAAY,GAAG,EAAE,IAAI,CAAC,YAAY,EAAvC,CAAuC,CAAC,CAAC;oBACnE,SAAS,CAAC,OAAO,CAAC;wBACd,YAAY,EAAE,CAAC;wBACf,KAAK,EAAE,CAAC;wBACR,MAAM,EAAE,CAAC;wBACT,OAAO,EAAE,CAAC;wBACV,SAAS,EAAE,OAAO;wBAClB,KAAK,EAAE,MAAM;qBAChB,CAAC,CAAC;oBAEH,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;iBACtC;gBAED,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;oBACtB,SAAS,CAAC,OAAO,CAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,YAAY,GAAG,EAAE,IAAI,CAAC,YAAY,EAAvC,CAAuC,CAAC,CAAC;oBACnE,SAAS,CAAC,OAAO,CAAC;wBACd,YAAY,EAAE,CAAC;wBACf,KAAK,EAAE,CAAC;wBACR,MAAM,EAAE,CAAC;wBACT,OAAO,EAAE,CAAC;wBACV,SAAS,EAAE,OAAO;wBAClB,KAAK,EAAE,MAAM;qBAChB,CAAC,CAAC;oBAEH,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;iBACtC;YACL,CAAC,CAAC,CAAC;YAEH,IAAI,UAAU,EAAE;gBACZ,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;aAC3C;YAED,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACvC;aACI;YACD,IAAI,IAAI,CAAC,MAAM,EAAE;gBACb,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;gBACpB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;gBACxB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC;aAC5C;SACJ;IACL,CAAC;IAED,2BAAU,GAAV,UAAW,OAAsB;QAC7B,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,IAAI,OAAO,CAAC,YAAY,GAAG,CAAC,EAAE;gBAC1B,IAAI,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;oBACtD,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;iBAC/D;gBAED,IAAM,SAAS,GAAG,OAAO,CAAC,YAAY,GAAG,CAAC,CAAC;gBAC3C,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;aACzD;iBAAM;gBACH,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;aAC9D;SACJ;IACL,CAAC;IAED,8BAAa,GAAb;QACI,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAClB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;SACpB;IACL,CAAC;IAED,4BAAW,GAAX;QACI,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,WAAW,EAAE,EAAf,CAAe,CAAC,CAAC;QACjD,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IA5IQ;QAAR,YAAK,EAAE;;0CAAe;IACd;QAAR,YAAK,EAAE;;8CAAmB;IAClB;QAAR,YAAK,EAAE;;sDAAsC;IAEpC;QAAT,aAAM,EAAE;kCAAgB,mBAAY;iDAAuC;IALnE,MAAM;QAJlB,gBAAS,CAAC;YACP,QAAQ,EAAE,UAAU;YACpB,QAAQ,EAAE,QAAQ;SACrB,CAAC;yCAc0B,iBAAU,EAAa,cAAK;OAb3C,MAAM,CA8IlB;IAAD,aAAC;CAAA,AA9ID,IA8IC;AA9IY,wBAAM","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    Input,\n    SimpleChanges,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    EventEmitter\n} from \"@angular/core\";\nimport { VgAPI } from '../../core/services/vg-api';\nimport { Subscription } from 'rxjs';\nimport { IDRMLicenseServer } from '../streaming';\nimport { BitrateOption } from '../../core/core';\n\ndeclare let dashjs;\n\n@Directive({\n    selector: '[vgDash]',\n    exportAs: 'vgDash'\n})\nexport class VgDASH implements OnInit, OnChanges, OnDestroy {\n    @Input() vgDash:string;\n    @Input() vgDRMToken:string;\n    @Input() vgDRMLicenseServer:IDRMLicenseServer;\n\n    @Output() onGetBitrates: EventEmitter<BitrateOption[]> = new EventEmitter();\n\n    vgFor: string;\n    target: any;\n    dash:any;\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.vgFor = this.ref.nativeElement.getAttribute('vgFor');\n        this.target = this.API.getMediaById(this.vgFor);\n        this.createPlayer();\n    }\n\n    ngOnChanges(changes:SimpleChanges) {\n        if (changes['vgDash'] && changes['vgDash'].currentValue) {\n            this.createPlayer();\n        }\n        else {\n            this.destroyPlayer();\n        }\n    }\n\n    createPlayer() {\n        if (this.dash) {\n            this.destroyPlayer();\n        }\n\n        // It's a DASH source\n        if (this.vgDash && (\n            (this.vgDash.indexOf('.mpd') > -1) ||\n            (this.vgDash.indexOf('mpd-time-csf') > -1))\n        ) {\n            let drmOptions;\n\n            if (this.vgDRMLicenseServer) {\n                drmOptions = this.vgDRMLicenseServer;\n\n                if (this.vgDRMToken) {\n                    for (let drmServer in drmOptions) {\n                        if(drmServer.hasOwnProperty(drmServer)) {\n                            drmOptions[drmServer].httpRequestHeaders = { Authorization: this.vgDRMToken };\n                        }\n                    }\n                }\n            }\n\n            this.dash = dashjs.MediaPlayer().create();\n            this.dash.getDebug().setLogToBrowserConsole(false);\n            this.dash.initialize(this.ref.nativeElement);\n            this.dash.setAutoPlay(false);\n\n            this.dash.on(dashjs.MediaPlayer.events.STREAM_INITIALIZED, () => {\n                const audioList = this.dash.getBitrateInfoListFor('audio');\n                const videoList = this.dash.getBitrateInfoListFor('video');\n\n                if (audioList.length > 1) {\n                    audioList.forEach(item => item.qualityIndex = ++item.qualityIndex);\n                    audioList.unshift({\n                        qualityIndex: 0,\n                        width: 0,\n                        height: 0,\n                        bitrate: 0,\n                        mediaType: 'video',\n                        label: 'AUTO'\n                    });\n\n                    this.onGetBitrates.emit(audioList);\n                }\n\n                if (videoList.length > 1) {\n                    videoList.forEach(item => item.qualityIndex = ++item.qualityIndex);\n                    videoList.unshift({\n                        qualityIndex: 0,\n                        width: 0,\n                        height: 0,\n                        bitrate: 0,\n                        mediaType: 'video',\n                        label: 'AUTO'\n                    });\n\n                    this.onGetBitrates.emit(videoList);\n                }\n            });\n\n            if (drmOptions) {\n                this.dash.setProtectionData(drmOptions);\n            }\n\n            this.dash.attachSource(this.vgDash);\n        }\n        else {\n            if (this.target) {\n                this.target.pause();\n                this.target.seekTime(0);\n                this.ref.nativeElement.src = this.vgDash;\n            }\n        }\n    }\n\n    setBitrate(bitrate: BitrateOption) {\n        if (this.dash) {\n            if (bitrate.qualityIndex > 0) {\n                if (this.dash.getAutoSwitchQualityFor(bitrate.mediaType)) {\n                    this.dash.setAutoSwitchQualityFor(bitrate.mediaType, false);\n                }\n\n                const nextIndex = bitrate.qualityIndex - 1;\n                this.dash.setQualityFor(bitrate.mediaType, nextIndex);\n            } else {\n                this.dash.setAutoSwitchQualityFor(bitrate.mediaType, true);\n            }\n        }\n    }\n\n    destroyPlayer() {\n        if (this.dash) {\n            this.dash.reset();\n            this.dash = null;\n        }\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n        this.destroyPlayer();\n    }\n}\n"]}