From aa4a5e56f90ca364688a04f9b0070aa4aba2a51c Mon Sep 17 00:00:00 2001 From: Henry <akhenry@gmail.com> Date: Tue, 26 Jul 2016 16:55:00 -0400 Subject: [PATCH] Improved support from plot --- main.js | 3 +- .../src/ConductorTelemetryDecorator.js | 38 +++++++++++++------ 2 files changed, 29 insertions(+), 12 deletions(-) diff --git a/main.js b/main.js index f2b0395f3e..f5f05e95a6 100644 --- a/main.js +++ b/main.js @@ -103,7 +103,8 @@ define([ './platform/entanglement/bundle', './platform/search/bundle', './platform/status/bundle', - './platform/commonUI/regions/bundle' + './platform/commonUI/regions/bundle', + './example/msl/bundle' ], function (Main, legacyRegistry) { return { legacyRegistry: legacyRegistry, diff --git a/platform/features/conductor-v2-compatibility/src/ConductorTelemetryDecorator.js b/platform/features/conductor-v2-compatibility/src/ConductorTelemetryDecorator.js index e661091b54..31b4ed5934 100644 --- a/platform/features/conductor-v2-compatibility/src/ConductorTelemetryDecorator.js +++ b/platform/features/conductor-v2-compatibility/src/ConductorTelemetryDecorator.js @@ -39,21 +39,26 @@ define( function ConductorTelemetryDecorator(conductor, telemetryService) { this.conductor = conductor; this.telemetryService = telemetryService; + + this.amendRequests = ConductorTelemetryDecorator.prototype.amendRequests.bind(this); + } + + function amendRequest(request, bounds, timeSystem) { + request = request || {}; + request.start = bounds.start; + request.end = bounds.end; + request.domain = timeSystem.metadata.key; + + return request; } ConductorTelemetryDecorator.prototype.amendRequests = function (requests) { var bounds = this.conductor.bounds(), timeSystem = this.conductor.timeSystem(); - function amendRequest(request) { - request = request || {}; - request.start = bounds.start; - request.end = bounds.end; - request.domain = timeSystem.metadata.key; - return request; - } - - return (requests || []).map(amendRequest); + return (requests || []).map(function (request) { + return amendRequest(request, bounds, timeSystem); + }); }; ConductorTelemetryDecorator.prototype.requestTelemetry = function (requests) { @@ -62,8 +67,19 @@ define( }; ConductorTelemetryDecorator.prototype.subscribe = function (callback, requests) { - return this.telemetryService - .subscribe(callback, requests); + var unsubscribeFunc = this.telemetryService.subscribe(callback, this.amendRequests(requests)), + conductor = this.conductor, + self = this; + + function amendRequests() { + return self.amendRequests(requests); + } + + conductor.on('bounds', amendRequests); + return function() { + unsubscribeFunc(); + conductor.off('bounds', amendRequests); + } }; return ConductorTelemetryDecorator;