blob: f37018f8bb18bda6d2bcb9e347ca51beeebf0f44 [file] [log] [blame]
/*
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied. See the License for the
specific language governing permissions and limitations
under the License.
*/
/**
* @module QDR
*/
var QDR = (function (QDR) {
/**
* @method ChartsController
*
* Controller that handles displaying a chart on the hawtio dashboard page. Only one chart is displayed per instance of this
* page
*/
QDR.module.controller("QDR.ChartsController", function($scope, QDRService, QDRChartService, $dialog, $location, localStorage, $routeParams) {
var updateTimer = null;
if (!QDRService.connected && !$routeParams.chid) {
// we are not connected. we probably got here from a bookmark or manual page reload
$location.path("/" + QDR.pluginName + "/connect")
$location.search('org', "charts");
return;
}
$scope.svgCharts = [];
// create an svg object for each chart
QDRChartService.charts.some(function (chart) {
// we are generating a chart for the hawtio dashboard
if ( $routeParams.chid == chart.id()) {
var svgChart = new QDRChartService.AreaChart(chart)
svgChart.zoomed = false;
$scope.svgCharts.push(svgChart);
// a hawtio dashboard has requested to view this chart. mark the chart so the request to get the data is made
if ($routeParams.chid && chart.hdash) {
chart.hreq = true;
}
return true;
}
})
// redraw the chart every update period
// this is a $scope function because it is called from the dialog
var updateCharts = function () {
$scope.svgCharts.forEach(function (svgChart) {
svgChart.tick(svgChart.chart.id()); // on this page we are using the chart.id() as the div id in which to render the chart
})
var updateRate = localStorage['updateRate'] ? localStorage['updateRate'] : 5000;
if (updateTimer) {
clearTimeout(updateTimer)
}
updateTimer = setTimeout(updateCharts, updateRate);
}
// we are showing a chart for the hawtio dashboard page, but we are not logged in
// set this to cause a "need to login" prompt on the dashboard
$scope.dashLogin = !QDRService.connected;
// the link that the above login prompt will display
$scope.loginHref = QDR.pluginName + "/connect";
// call by ng-init in the html when the page is loaded
$scope.chartsLoaded = function () {
$scope.svgCharts.forEach(function (svgChart) {
QDRChartService.sendChartRequest(svgChart.chart.request(), true);
})
if (updateTimer)
clearTimeout(updateTimer)
updateTimer = setTimeout(updateCharts, 100);
}
$scope.zoomChart = function (chart) {
chart.zoomed = !chart.zoomed;
chart.zoom(chart.chart.id(), chart.zoomed);
}
$scope.editChart = function (chart) {
doDialog("chart-config-template.html", chart.chart);
};
$scope.delChart = function (chart) {
QDRChartService.unRegisterChart(chart.chart);
// remove from svgCharts
$scope.svgCharts.forEach(function (svgChart, i) {
if (svgChart === chart) {
delete $scope.svgCharts.splice(i, 1);
}
})
};
// called from dialog when we want to clone the dialog chart
// the chart argument here is a QDRChartService chart
$scope.addChart = function (chart) {
$scope.svgCharts.push(new QDRChartService.AreaChart(chart));
};
$scope.$on("removedFromDashboard", function (event) {
QDRChartService.unRegisterChart($scope.svgCharts[0].chart)
})
$scope.$on("$destroy", function( event) {
if (updateTimer) {
clearTimeout(updateTimer);
updateTimer = null;
}
if ($scope.svgCharts.length) {
//if ($scope.svgCharts[0].chart)
// $scope.svgCharts[0].chart.hreq = false; // stops the chart service from making requests for this chart
for (var i=$scope.svgCharts.length-1; i>=0; --i) {
delete $scope.svgCharts.splice(i, 1);
}
}
});
// clicked on add to dashboard
$scope.addHChart = function (chart) {
QDRChartService.addHDash(chart.chart);
}
// href that is generated when the page loads
$scope.addToDashboardLink = function (chart) {
var href = "#" + $location.path();
var size = angular.toJson({
size_x: 2,
size_y: 2
});
var params = angular.toJson({chid: chart.chart.id()});
var title = "Dispatch Router";
return "/hawtio/#/dashboard/add?tab=dashboard" +
"&href=" + encodeURIComponent(href) +
"&routeParams=" + encodeURIComponent(params) +
"&title=" + encodeURIComponent(title) +
"&size=" + encodeURIComponent(size);
};
function doDialog(template, chart) {
$dialog.dialog({
backdrop: true,
keyboard: true,
backdropClick: true,
templateUrl: template,
controller: "QDR.ChartDialogController",
resolve: {
chart: function() {
return chart;
},
updateTick: function () {
return updateCharts;
}
}
}).open();
};
});
// the edit chart properties dialog
QDR.module.controller("QDR.ChartDialogController", function($scope, QDRChartService, $location, dialog, $rootScope, localStorage, chart, updateTick) {
UI.colors[0] = "#cbe7f3"
UI.colors[1] = "#058dc7"
UI.colors[UI.colors.length-1] = "#FFFFFF"
var dialogSvgChart = null;
$scope.svgDivId = "dialogChart"; // the div id for the svg chart
var updateTimer = null;
$scope.chart = chart; // the underlying chart object from the dashboard
$scope.dialogChart = $scope.chart.copy(); // the chart object for this dialog
$scope.userTitle = $scope.chart.title();
$scope.$watch('userTitle', function(newValue, oldValue) {
if (newValue !== oldValue) {
$scope.dialogChart.title(newValue);
dialogSvgChart.tick($scope.svgDivId);
}
})
$scope.$watch("dialogChart.areaColor", function (newValue, oldValue) {
if (newValue !== oldValue) {
if (dialogSvgChart)
dialogSvgChart.tick($scope.svgDivId);
}
})
$scope.$watch("dialogChart.lineColor", function (newValue, oldValue) {
if (newValue !== oldValue) {
if (dialogSvgChart)
dialogSvgChart.tick($scope.svgDivId);
}
})
$scope.$watch("dialogChart.type", function (newValue, oldValue) {
if (newValue !== oldValue) {
if (dialogSvgChart)
dialogSvgChart.tick($scope.svgDivId);
}
})
// the stored rateWindow is in milliseconds, but the slider is in seconds
$scope.rateWindow = $scope.chart.rateWindow / 1000;
var cleanup = function () {
if (updateTimer) {
clearTimeout(updateTimer);
updateTimer = null;
}
QDRChartService.unRegisterChart($scope.dialogChart); // remove the chart
}
$scope.okClick = function () {
cleanup();
dialog.close();
};
var initRateSlider = function () {
if (document.getElementById('rateSlider')) {
$( "#rateSlider" ).slider({
value: $scope.rateWindow,
min: 1,
max: 10,
step: 1,
slide: function( event, ui ) {
$scope.rateWindow = ui.value;
$scope.dialogChart.rateWindow = ui.value * 1000;
$scope.$apply();
if (dialogSvgChart)
dialogSvgChart.tick($scope.svgDivId);
}
});
} else {
setTimeout(initRateSlider, 100)
}
}
initRateSlider();
var initDurationSlider = function () {
if (document.getElementById('durationSlider')) {
$( "#durationSlider" ).slider({
value: $scope.dialogChart.visibleDuration,
min: 1,
max: 10,
step: 1,
slide: function( event, ui ) {
$scope.visibleDuration = $scope.dialogChart.visibleDuration = ui.value;
$scope.$apply();
if (dialogSvgChart)
dialogSvgChart.tick($scope.svgDivId);
}
});
} else {
setTimeout(initDurationSlider, 100)
}
}
initDurationSlider();
// handle the Apply button click
// update the dashboard chart's properties
$scope.apply = function () {
$scope.chart.areaColor = $scope.dialogChart.areaColor;
$scope.chart.lineColor = $scope.dialogChart.lineColor;
$scope.chart.type = $scope.dialogChart.type;
$scope.chart.rateWindow = $scope.rateWindow * 1000;
$scope.chart.title($scope.dialogChart.title());
$scope.chart.visibleDuration = $scope.dialogChart.visibleDuration;
QDRChartService.saveCharts();
if (typeof updateTick === "function")
updateTick();
}
// update the chart on the popup dialog
var updateDialogChart = function () {
// draw the chart using the current data
if (dialogSvgChart)
dialogSvgChart.tick($scope.svgDivId);
// draw the chart again in 1 second
var updateRate = localStorage['updateRate'] ? localStorage['updateRate'] : 5000;
if (updateTimer)
clearTimeout(updateTimer);
updateTimer = setTimeout(updateDialogChart, updateRate);
}
var showChart = function () {
// ensure the div for our chart is loaded in the dom
var div = angular.element("#dialogChart");
if (!div.width()) {
setTimeout(showChart, 100);
return;
}
dialogSvgChart = new QDRChartService.AreaChart($scope.dialogChart);
if (updateTimer)
clearTimeout(updateTimer);
updateDialogChart();
}
showChart();
});
return QDR;
}(QDR || {}));