mirror of
https://github.com/grafana/grafana.git
synced 2025-02-11 16:15:42 -06:00
161 lines
4.9 KiB
JavaScript
161 lines
4.9 KiB
JavaScript
define([
|
|
'angular',
|
|
'jquery',
|
|
'lodash',
|
|
'tether',
|
|
],
|
|
function (angular, $, _, Tether) {
|
|
'use strict';
|
|
|
|
angular
|
|
.module('grafana.directives')
|
|
.directive('panelMenu', function($compile) {
|
|
var linkTemplate =
|
|
'<span class="panel-title drag-handle pointer">' +
|
|
'<span class="icon-gf panel-alert-icon"></span>' +
|
|
'<span class="panel-title-text drag-handle">{{ctrl.panel.title | interpolateTemplateVars:this}}</span>' +
|
|
'<span class="panel-time-info" ng-show="ctrl.timeInfo"><i class="fa fa-clock-o"></i> {{ctrl.timeInfo}}</span>' +
|
|
'</span>';
|
|
|
|
function createMenuTemplate(ctrl) {
|
|
var template = '<div class="panel-menu small">';
|
|
|
|
if (ctrl.dashboard.meta.canEdit) {
|
|
template += '<div class="panel-menu-inner">';
|
|
template += '<div class="panel-menu-row">';
|
|
if (!ctrl.dashboard.meta.fullscreen) {
|
|
template += '<a class="panel-menu-icon pull-left" ng-click="ctrl.updateColumnSpan(-1)"><i class="fa fa-minus"></i></a>';
|
|
template += '<a class="panel-menu-icon pull-left" ng-click="ctrl.updateColumnSpan(1)"><i class="fa fa-plus"></i></a>';
|
|
}
|
|
template += '<a class="panel-menu-icon pull-right" ng-click="ctrl.removePanel()"><i class="fa fa-trash"></i></a>';
|
|
template += '<div class="clearfix"></div>';
|
|
template += '</div>';
|
|
}
|
|
|
|
template += '<div class="panel-menu-row">';
|
|
template += '<a class="panel-menu-link" gf-dropdown="extendedMenu"><i class="fa fa-bars"></i></a>';
|
|
|
|
_.each(ctrl.getMenu(), function(item) {
|
|
// skip edit actions if not editor
|
|
if (item.role === 'Editor' && !ctrl.dashboard.meta.canEdit) {
|
|
return;
|
|
}
|
|
|
|
template += '<a class="panel-menu-link" ';
|
|
if (item.click) { template += ' ng-click="' + item.click + '"'; }
|
|
if (item.href) { template += ' href="' + item.href + '"'; }
|
|
template += '>';
|
|
template += item.text + '</a>';
|
|
});
|
|
|
|
template += '</div>';
|
|
template += '</div>';
|
|
template += '</div>';
|
|
return template;
|
|
}
|
|
|
|
function getExtendedMenu(ctrl) {
|
|
return ctrl.getExtendedMenu();
|
|
}
|
|
|
|
return {
|
|
restrict: 'A',
|
|
link: function($scope, elem) {
|
|
var $link = $(linkTemplate);
|
|
var $panelContainer = elem.parents(".panel-container");
|
|
var menuScope = null;
|
|
var ctrl = $scope.ctrl;
|
|
var timeout = null;
|
|
var $menu = null;
|
|
var teather;
|
|
|
|
elem.append($link);
|
|
|
|
function dismiss(time, force) {
|
|
clearTimeout(timeout);
|
|
timeout = null;
|
|
|
|
if (time) {
|
|
timeout = setTimeout(dismiss, time);
|
|
return;
|
|
}
|
|
|
|
// if hovering or draging pospone close
|
|
if (force !== true) {
|
|
if ($menu.is(':hover') || $scope.ctrl.dashboard.$$panelDragging) {
|
|
dismiss(2200);
|
|
return;
|
|
}
|
|
}
|
|
|
|
if (menuScope) {
|
|
teather.destroy();
|
|
$menu.unbind();
|
|
$menu.remove();
|
|
menuScope.$destroy();
|
|
menuScope = null;
|
|
$menu = null;
|
|
$panelContainer.removeClass('panel-highlight');
|
|
}
|
|
}
|
|
|
|
var showMenu = function(e) {
|
|
// if menu item is clicked and menu was just removed from dom ignore this event
|
|
if (!$.contains(document, e.target)) {
|
|
return;
|
|
}
|
|
|
|
if ($menu) {
|
|
dismiss();
|
|
return;
|
|
}
|
|
|
|
var menuTemplate;
|
|
menuTemplate = createMenuTemplate(ctrl);
|
|
|
|
$menu = $(menuTemplate);
|
|
$menu.mouseleave(function() {
|
|
dismiss(1000);
|
|
});
|
|
|
|
menuScope = $scope.$new();
|
|
menuScope.extendedMenu = getExtendedMenu(ctrl);
|
|
menuScope.dismiss = function() {
|
|
dismiss(null, true);
|
|
};
|
|
|
|
$(".panel-container").removeClass('panel-highlight');
|
|
$panelContainer.toggleClass('panel-highlight');
|
|
|
|
$('.panel-menu').remove();
|
|
|
|
elem.append($menu);
|
|
|
|
$scope.$apply(function() {
|
|
$compile($menu.contents())(menuScope);
|
|
|
|
teather = new Tether({
|
|
element: $menu,
|
|
target: $panelContainer,
|
|
attachment: 'bottom center',
|
|
targetAttachment: 'top center',
|
|
constraints: [
|
|
{
|
|
to: 'window',
|
|
attachment: 'together',
|
|
pin: true
|
|
}
|
|
]
|
|
});
|
|
});
|
|
|
|
dismiss(2200);
|
|
};
|
|
|
|
elem.click(showMenu);
|
|
$compile(elem.contents())($scope);
|
|
}
|
|
};
|
|
});
|
|
});
|