| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- /*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 = '<img src="common/img/load.gif" class="panel-loading" ng-show="panel.loading == true">'+
- ' <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>{{panel.title}}</h4>';
- elem.prepend($compile(angular.element(template))(scope));
- }
- };
- })
- .directive('addPanel', function($compile) {
- return {
- restrict: 'A',
- link: function(scope, elem, attrs) {
- scope.$watch('panel.type', function(n,o) {
- if(!_.isUndefined(scope.panel.type)) {
- var template = '<div ng-controller="'+scope.panel.type+'" ng-include src="\''+scope.edit_path(scope.panel.type)+'\'"></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('upload', function(timer){
- 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 = [];
- for (var i = 0, f; f = files[i]; i++) {
- var reader = new FileReader();
- reader.onload = (function(theFile) {
- return function(e) {
- // Render thumbnail.
- scope.dashboards = JSON.parse(e.target.result)
- timer.cancel_all();
- scope.$apply();
- };
- })(f);
- reader.readAsText(f);
- }
- }
- // Check for the various File API support.
- if (window.File && window.FileReader && window.FileList && window.Blob) {
- // Something
- document.getElementById('upload').addEventListener('change', file_selected, false);
- } else {
- alert('Sorry, the HTML5 File APIs are not fully supported in this browser.');
- }
- }
- }
- }).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());
- });
- });
- }
- };
- });
- ;
|