1 import { Component, OnInit, OnDestroy } from '@angular/core';
3 import { NotificationsService } from 'angular2-notifications';
5 import { RequestService, RequestStats } from '../shared';
8 selector: 'my-request-stats',
9 templateUrl: './request-stats.component.html',
10 styleUrls: [ './request-stats.component.scss' ]
12 export class RequestStatsComponent implements OnInit, OnDestroy {
14 requestScheduler: 'Basic request scheduler',
15 requestVideoEventScheduler: 'Video events request scheduler',
16 requestVideoQaduScheduler: 'Quick and dirty video updates request scheduler'
19 stats: { [ id: string ]: RequestStats } = {
20 requestScheduler: null,
21 requestVideoEventScheduler: null,
22 requestVideoQaduScheduler: null
25 private intervals: { [ id: string ]: number } = {
26 requestScheduler: null,
27 requestVideoEventScheduler: null,
28 requestVideoQaduScheduler: null
31 private timeouts: { [ id: string ]: number } = {
32 requestScheduler: null,
33 requestVideoEventScheduler: null,
34 requestVideoQaduScheduler: null
39 private notificationsService: NotificationsService,
40 private requestService: RequestService
49 Object.keys(this.stats).forEach(requestSchedulerName => {
50 if (this.intervals[requestSchedulerName] !== null) {
51 window.clearInterval(this.intervals[requestSchedulerName]);
54 if (this.timeouts[requestSchedulerName] !== null) {
55 window.clearTimeout(this.timeouts[requestSchedulerName]);
61 this.requestService.getStats().subscribe(
62 stats => this.stats = stats,
64 err => this.notificationsService.error('Error', err.text)
68 private runIntervals() {
69 Object.keys(this.intervals).forEach(requestSchedulerName => {
70 this.intervals[requestSchedulerName] = window.setInterval(() => {
71 const stats = this.stats[requestSchedulerName];
73 stats.remainingMilliSeconds -= 1000;
75 if (stats.remainingMilliSeconds <= 0) {
76 this.timeouts[requestSchedulerName] = window.setTimeout(() => this.getStats(), stats.remainingMilliSeconds + 100);