UNPKG

videogular2

Version:

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

72 lines 11.4 kB
"use strict"; var core_1 = require('@angular/core'); var vg_events_1 = require('../events/vg-events'); var Observable_1 = require('rxjs/Observable'); require('rxjs/add/observable/fromEvent'); var VgCuePoints = (function () { function VgCuePoints(ref) { this.ref = ref; this.onEnterCuePoint = new core_1.EventEmitter(); this.onUpdateCuePoint = new core_1.EventEmitter(); this.onExitCuePoint = new core_1.EventEmitter(); this.onCompleteCuePoint = new core_1.EventEmitter(); this.subscriptions = []; this.cuesSubscriptions = []; this.totalCues = 0; } VgCuePoints.prototype.ngOnInit = function () { var onLoad = Observable_1.Observable.fromEvent(this.ref.nativeElement, vg_events_1.VgEvents.VG_LOAD); this.subscriptions.push(onLoad.subscribe(this.onLoad.bind(this))); }; VgCuePoints.prototype.onLoad = function (event) { var cues = event.target.track.cues; this.ref.nativeElement.cues = cues; this.updateCuePoints(cues); }; VgCuePoints.prototype.updateCuePoints = function (cues) { this.cuesSubscriptions.forEach(function (s) { return s.unsubscribe(); }); for (var i = 0, l = cues.length; i < l; i++) { var onEnter = Observable_1.Observable.fromEvent(cues[i], vg_events_1.VgEvents.VG_ENTER); this.cuesSubscriptions.push(onEnter.subscribe(this.onEnter.bind(this))); var onExit = Observable_1.Observable.fromEvent(cues[i], vg_events_1.VgEvents.VG_EXIT); this.cuesSubscriptions.push(onExit.subscribe(this.onExit.bind(this))); } }; VgCuePoints.prototype.onEnter = function (event) { this.onEnterCuePoint.next(event.target); }; VgCuePoints.prototype.onExit = function (event) { this.onExitCuePoint.next(event.target); }; VgCuePoints.prototype.ngDoCheck = function () { if (this.ref.nativeElement.cues) { var changes = this.totalCues !== this.ref.nativeElement.track.cues.length; if (changes) { this.totalCues = this.ref.nativeElement.track.cues.length; this.ref.nativeElement.cues = this.ref.nativeElement.track.cues; this.updateCuePoints(this.ref.nativeElement.track.cues); } } }; VgCuePoints.prototype.ngOnDestroy = function () { this.subscriptions.forEach(function (s) { return s.unsubscribe(); }); }; VgCuePoints.decorators = [ { type: core_1.Directive, args: [{ selector: '[vgCuePoints]' },] }, ]; /** @nocollapse */ VgCuePoints.ctorParameters = [ { type: core_1.ElementRef, }, ]; VgCuePoints.propDecorators = { 'onEnterCuePoint': [{ type: core_1.Output, args: ['onEnterCuePoint',] },], 'onUpdateCuePoint': [{ type: core_1.Output, args: ['onUpdateCuePoint',] },], 'onExitCuePoint': [{ type: core_1.Output, args: ['onExitCuePoint',] },], 'onCompleteCuePoint': [{ type: core_1.Output, args: ['onCompleteCuePoint',] },], }; return VgCuePoints; }()); exports.VgCuePoints = VgCuePoints; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-cue-points.js","sourceRoot":"","sources":["vg-cue-points.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, OnDestroy, OnInit, Output } from '@angular/core';\nimport { VgEvents } from '../events/vg-events';\nimport { Observable } from 'rxjs/Observable';\nimport 'rxjs/add/observable/fromEvent';\nimport { Subscription } from 'rxjs/Subscription';\n\n\nexport class VgCuePoints implements OnInit, OnDestroy {\n     onEnterCuePoint: EventEmitter<any> = new EventEmitter();\n     onUpdateCuePoint: EventEmitter<any> = new EventEmitter();\n     onExitCuePoint: EventEmitter<any> = new EventEmitter();\n     onCompleteCuePoint: EventEmitter<any> = new EventEmitter();\n\n    subscriptions: Subscription[] = [];\n    cuesSubscriptions: Subscription[] = [];\n\n    totalCues = 0;\n\n    constructor(public ref: ElementRef) {\n    }\n\n    ngOnInit() {\n        let onLoad = Observable.fromEvent(this.ref.nativeElement, VgEvents.VG_LOAD);\n        this.subscriptions.push(onLoad.subscribe(this.onLoad.bind(this)));\n    }\n\n    onLoad(event: any) {\n        let cues: TextTrackCue[] = event.target.track.cues;\n\n        this.ref.nativeElement.cues = cues;\n\n        this.updateCuePoints(cues);\n    }\n\n    updateCuePoints(cues: TextTrackCue[]) {\n        this.cuesSubscriptions.forEach(s => s.unsubscribe());\n\n        for (let i = 0, l = cues.length; i < l; i++) {\n            let onEnter = Observable.fromEvent(cues[ i ], VgEvents.VG_ENTER);\n            this.cuesSubscriptions.push(onEnter.subscribe(this.onEnter.bind(this)));\n\n            let onExit = Observable.fromEvent(cues[ i ], VgEvents.VG_EXIT);\n            this.cuesSubscriptions.push(onExit.subscribe(this.onExit.bind(this)));\n        }\n    }\n\n    onEnter(event: any) {\n        this.onEnterCuePoint.next(event.target);\n    }\n\n    onExit(event: any) {\n        this.onExitCuePoint.next(event.target);\n    }\n\n    ngDoCheck() {\n        if (this.ref.nativeElement.cues) {\n            const changes = this.totalCues !== this.ref.nativeElement.track.cues.length;\n\n            if (changes) {\n                this.totalCues = this.ref.nativeElement.track.cues.length;\n                this.ref.nativeElement.cues = this.ref.nativeElement.track.cues;\n                this.updateCuePoints(this.ref.nativeElement.track.cues);\n            }\n        }\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Directive, args: [{\n    selector: '[vgCuePoints]'\n}, ] },\n];\n/** @nocollapse */\nstatic ctorParameters: ({type: any, decorators?: DecoratorInvocation[]}|null)[] = [\n{type: ElementRef, },\n];\nstatic propDecorators: {[key: string]: DecoratorInvocation[]} = {\n'onEnterCuePoint': [{ type: Output, args: ['onEnterCuePoint', ] },],\n'onUpdateCuePoint': [{ type: Output, args: ['onUpdateCuePoint', ] },],\n'onExitCuePoint': [{ type: Output, args: ['onExitCuePoint', ] },],\n'onCompleteCuePoint': [{ type: Output, args: ['onCompleteCuePoint', ] },],\n};\n}\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}