mirror of
https://github.com/grafana/grafana.git
synced 2024-12-02 05:29:42 -06:00
45 lines
1.1 KiB
TypeScript
45 lines
1.1 KiB
TypeScript
import angular from 'angular';
|
|
|
|
export class SoloPanelCtrl {
|
|
/** @ngInject */
|
|
constructor($scope, $routeParams, $location, dashboardLoaderSrv, contextSrv) {
|
|
var panelId;
|
|
|
|
$scope.init = function() {
|
|
contextSrv.sidemenu = false;
|
|
|
|
var params = $location.search();
|
|
panelId = parseInt(params.panelId);
|
|
|
|
$scope.onAppEvent('dashboard-initialized', $scope.initPanelScope);
|
|
|
|
dashboardLoaderSrv.loadDashboard($routeParams.type, $routeParams.slug).then(function(result) {
|
|
result.meta.soloMode = true;
|
|
$scope.initDashboard(result, $scope);
|
|
});
|
|
};
|
|
|
|
$scope.initPanelScope = function() {
|
|
let panelInfo = $scope.dashboard.getPanelInfoById(panelId);
|
|
|
|
// fake row ctrl scope
|
|
$scope.ctrl = {
|
|
dashboard: $scope.dashboard,
|
|
};
|
|
|
|
$scope.panel = panelInfo.panel;
|
|
$scope.panel.soloMode = true;
|
|
$scope.$index = 0;
|
|
|
|
if (!$scope.panel) {
|
|
$scope.appEvent('alert-error', ['Panel not found', '']);
|
|
return;
|
|
}
|
|
};
|
|
|
|
$scope.init();
|
|
}
|
|
}
|
|
|
|
angular.module('grafana.routes').controller('SoloPanelCtrl', SoloPanelCtrl);
|