mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
134 lines
4.0 KiB
JavaScript
134 lines
4.0 KiB
JavaScript
/*jshint globalstrict:true */
|
|
/*global angular:true */
|
|
'use strict';
|
|
|
|
angular.module('kibana.directives', [])
|
|
.directive('kibanaPanel', function($compile) {
|
|
return {
|
|
restrict: 'E',
|
|
link: function(scope, elem, attrs) {
|
|
var template = '<i class="icon-spinner small icon-spin icon-large panel-loading" '+
|
|
'ng-show="panelMeta.loading == true && !panel.title"></i>'+
|
|
' <span class="editlink panelextra pointer" style="right:15px;top:0px" ' +
|
|
'bs-modal="\'partials/paneleditor.html\'" ng-show="panel.editable != false">'+
|
|
'<span class="small">{{panel.type}}</span> <i class="icon-cog pointer"></i> '+
|
|
'</span><h4 ng-show="panel.title">'+
|
|
'{{panel.title}} '+
|
|
'<i class="icon-spinner smaller icon-spin icon-large" ng-show="panelMeta.loading == true && panel.title"></i>'+
|
|
'</h4>';
|
|
elem.prepend($compile(angular.element(template))(scope));
|
|
}
|
|
};
|
|
})
|
|
.directive('tip', function($compile) {
|
|
return {
|
|
restrict: 'E',
|
|
link: function(scope, elem, attrs) {
|
|
var _t = '<i class="icon-'+(attrs.icon||'question-sign')+'" bs-tooltip="\''+
|
|
kbn.addslashes(elem.text())+'\'"></i>';
|
|
elem.replaceWith($compile(angular.element(_t))(scope));
|
|
}
|
|
};
|
|
})
|
|
.directive('addPanel', function($compile) {
|
|
return {
|
|
restrict: 'A',
|
|
link: function($scope, elem, attrs) {
|
|
$scope.$watch('panel.type', function(n,o) {
|
|
var _type = $scope.panel.type;
|
|
$scope.reset_panel(_type);
|
|
if(!_.isUndefined($scope.panel.type)) {
|
|
var template = '<div ng-controller="'+$scope.panel.type+'">'+
|
|
'<span ng-include src="\'partials/paneladd.html\'"></span>'+
|
|
'</div>';
|
|
elem.html($compile(angular.element(template))($scope));
|
|
}
|
|
});
|
|
}
|
|
};
|
|
})
|
|
.directive('arrayJoin', function() {
|
|
return {
|
|
restrict: 'A',
|
|
require: 'ngModel',
|
|
link: function(scope, element, attr, ngModel) {
|
|
|
|
function split_array(text) {
|
|
return (text || '').split(',');
|
|
}
|
|
|
|
function join_array(text) {
|
|
if(_.isArray(text)) {
|
|
return (text || '').join(',');
|
|
} else {
|
|
return text;
|
|
}
|
|
}
|
|
|
|
ngModel.$parsers.push(split_array);
|
|
ngModel.$formatters.push(join_array);
|
|
}
|
|
};
|
|
})
|
|
.directive('ngModelOnblur', function() {
|
|
return {
|
|
restrict: 'A',
|
|
require: 'ngModel',
|
|
link: function(scope, elm, attr, ngModelCtrl) {
|
|
if (attr.type === 'radio' || attr.type === 'checkbox') {
|
|
return;
|
|
}
|
|
|
|
elm.unbind('input').unbind('keydown').unbind('change');
|
|
elm.bind('blur', function() {
|
|
scope.$apply(function() {
|
|
ngModelCtrl.$setViewValue(elm.val());
|
|
});
|
|
});
|
|
}
|
|
};
|
|
})
|
|
.directive('ngBlur', ['$parse', function($parse) {
|
|
return function(scope, element, attr) {
|
|
var fn = $parse(attr['ngBlur']);
|
|
element.bind('blur', function(event) {
|
|
scope.$apply(function() {
|
|
fn(scope, {$event:event});
|
|
});
|
|
});
|
|
};
|
|
}])
|
|
.directive('dashUpload', function(timer, dashboard, alertSrv){
|
|
return {
|
|
restrict: 'A',
|
|
link: function(scope, elem, attrs) {
|
|
function file_selected(evt) {
|
|
var files = evt.target.files; // FileList object
|
|
|
|
// files is a FileList of File objects. List some properties.
|
|
var output = [];
|
|
var readerOnload = function(theFile) {
|
|
return function(e) {
|
|
dashboard.dash_load(JSON.parse(e.target.result));
|
|
scope.$apply();
|
|
};
|
|
};
|
|
for (var i = 0, f; f = files[i]; i++) {
|
|
var reader = new FileReader();
|
|
reader.onload = (readerOnload)(f);
|
|
reader.readAsText(f);
|
|
}
|
|
}
|
|
|
|
// Check for the various File API support.
|
|
if (window.File && window.FileReader && window.FileList && window.Blob) {
|
|
// Something
|
|
document.getElementById('dashupload').addEventListener('change', file_selected, false);
|
|
} else {
|
|
alertSrv.set('Oops','Sorry, the HTML5 File APIs are not fully supported in this browser.','error');
|
|
}
|
|
}
|
|
};
|
|
});
|
|
|