UNPKG

videogular2

Version:

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

88 lines 12 kB
"use strict"; var core_1 = require('@angular/core'); var vg_api_1 = require('../../core/services/vg-api'); // Workaround until we can use UTC with Angular Date Pipe var VgUtcPipe = (function () { function VgUtcPipe() { } VgUtcPipe.prototype.transform = function (value, format) { var date = new Date(value); var result = format; var ss = date.getUTCSeconds(); var mm = date.getUTCMinutes(); var hh = date.getUTCHours(); if (ss < 10) { ss = '0' + ss; } if (mm < 10) { mm = '0' + mm; } if (hh < 10) { hh = '0' + hh; } result = result.replace(/ss/g, ss); result = result.replace(/mm/g, mm); result = result.replace(/hh/g, hh); return result; }; VgUtcPipe.decorators = [ { type: core_1.Pipe, args: [{ name: 'vgUtc' },] }, ]; /** @nocollapse */ VgUtcPipe.ctorParameters = []; return VgUtcPipe; }()); exports.VgUtcPipe = VgUtcPipe; var VgTimeDisplay = (function () { function VgTimeDisplay(ref, API) { this.API = API; this.vgProperty = 'current'; this.vgFormat = 'mm:ss'; this.subscriptions = []; this.elem = ref.nativeElement; } VgTimeDisplay.prototype.ngOnInit = function () { var _this = this; if (this.API.isPlayerReady) { this.onPlayerReady(); } else { this.subscriptions.push(this.API.playerReadyEvent.subscribe(function () { return _this.onPlayerReady(); })); } }; VgTimeDisplay.prototype.onPlayerReady = function () { this.target = this.API.getMediaById(this.vgFor); }; VgTimeDisplay.prototype.getTime = function () { var t = 0; if (this.target) { t = Math.round(this.target.time[this.vgProperty]); t = isNaN(t) || this.target.isLive ? 0 : t; } return t; }; VgTimeDisplay.prototype.ngOnDestroy = function () { this.subscriptions.forEach(function (s) { return s.unsubscribe(); }); }; VgTimeDisplay.decorators = [ { type: core_1.Component, args: [{ selector: 'vg-time-display', encapsulation: core_1.ViewEncapsulation.None, template: "\n <span *ngIf=\"target?.isLive\">LIVE</span>\n <span *ngIf=\"!target?.isLive\">{{ getTime() | vgUtc:vgFormat }}</span>\n <ng-content></ng-content>\n ", styles: ["\n vg-time-display {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n display: flex;\n justify-content: center;\n height: 50px;\n width: 60px;\n cursor: pointer;\n color: white;\n line-height: 50px;\n pointer-events: none;\n font-family: Helvetica Neue, Helvetica, Arial, sans-serif;\n }\n "] },] }, ]; /** @nocollapse */ VgTimeDisplay.ctorParameters = [ { type: core_1.ElementRef, }, { type: vg_api_1.VgAPI, }, ]; VgTimeDisplay.propDecorators = { 'vgFor': [{ type: core_1.Input },], 'vgProperty': [{ type: core_1.Input },], 'vgFormat': [{ type: core_1.Input },], }; return VgTimeDisplay; }()); exports.VgTimeDisplay = VgTimeDisplay; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-time-display.js","sourceRoot":"","sources":["vg-time-display.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ElementRef, OnInit, PipeTransform, Pipe, ViewEncapsulation, OnDestroy } from '@angular/core';\nimport { VgAPI } from '../../core/services/vg-api';\nimport { Subscription } from 'rxjs/Subscription';\n\n// Workaround until we can use UTC with Angular Date Pipe\n\nexport class VgUtcPipe implements PipeTransform {\n    transform(value: number, format: string): string {\n        let date = new Date(value);\n        let result = format;\n        let ss: string|number = date.getUTCSeconds();\n        let mm: string|number = date.getUTCMinutes();\n        let hh: string|number = date.getUTCHours();\n\n        if (ss < 10) {\n            ss = '0' + ss;\n        }\n        if (mm < 10) {\n            mm = '0' + mm;\n        }\n        if (hh < 10) {\n            hh = '0' + hh;\n        }\n\n        result = result.replace(/ss/g, <string>ss);\n        result = result.replace(/mm/g, <string>mm);\n        result = result.replace(/hh/g, <string>hh);\n\n        return result;\n    }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Pipe, args: [{ name: 'vgUtc' }, ] },\n];\n/** @nocollapse */\nstatic ctorParameters: ({type: any, decorators?: DecoratorInvocation[]}|null)[] = [\n];\n}\n\n\nexport class VgTimeDisplay implements OnInit, OnDestroy {\n     vgFor: string;\n     vgProperty: string = 'current';\n     vgFormat: string = 'mm:ss';\n\n    elem: HTMLElement;\n    target: any;\n\n    subscriptions: Subscription[] = [];\n\n    constructor(ref: ElementRef, public API: VgAPI) {\n        this.elem = ref.nativeElement;\n    }\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.target = this.API.getMediaById(this.vgFor);\n    }\n\n    getTime() {\n        let t = 0;\n\n        if (this.target) {\n            t = Math.round(this.target.time[ this.vgProperty ]);\n            t = isNaN(t) || this.target.isLive ? 0 : t;\n        }\n\n        return t;\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Component, args: [{\n    selector: 'vg-time-display',\n    encapsulation: ViewEncapsulation.None,\n    template: `\n        <span *ngIf=\"target?.isLive\">LIVE</span>\n        <span *ngIf=\"!target?.isLive\">{{ getTime() | vgUtc:vgFormat }}</span>\n        <ng-content></ng-content>\n    `,\n    styles: [ `\n        vg-time-display {\n            -webkit-touch-callout: none;\n            -webkit-user-select: none;\n            -moz-user-select: none;\n            -ms-user-select: none;\n            user-select: none;\n            display: flex;\n            justify-content: center;\n            height: 50px;\n            width: 60px;\n            cursor: pointer;\n            color: white;\n            line-height: 50px;\n            pointer-events: none;\n            font-family: Helvetica Neue, Helvetica, Arial, sans-serif;\n        }\n    ` ]\n}, ] },\n];\n/** @nocollapse */\nstatic ctorParameters: ({type: any, decorators?: DecoratorInvocation[]}|null)[] = [\n{type: ElementRef, },\n{type: VgAPI, },\n];\nstatic propDecorators: {[key: string]: DecoratorInvocation[]} = {\n'vgFor': [{ type: Input },],\n'vgProperty': [{ type: Input },],\n'vgFormat': [{ type: Input },],\n};\n}\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}