UNPKG

@spalger/kibana

Version:

Kibana is an open source (Apache Licensed), browser based analytics and search dashboard for Elasticsearch. Kibana is a snap to setup and start using. Kibana strives to be easy to get started with, while also being flexible and powerful, just like Elastic

81 lines (63 loc) 2.4 kB
define(function (require) { var _ = require('lodash'); var module = require('ui/modules').get('app/discover'); require('ui/filters/short_dots'); module.directive('kbnTableHeader', function (shortDotsFilter) { var headerHtml = require('ui/doc_table/components/table_header.html'); return { restrict: 'A', scope: { columns: '=', sorting: '=', indexPattern: '=', }, template: headerHtml, controller: function ($scope) { var sortableField = function (field) { if (!$scope.indexPattern) return; var sortable = _.get($scope.indexPattern.fields.byName[field], 'sortable'); return sortable; }; $scope.tooltip = function (column) { if (!sortableField(column)) return ''; return 'Sort by ' + shortDotsFilter(column); }; $scope.canRemove = function (name) { return (name !== '_source' || $scope.columns.length !== 1); }; $scope.headerClass = function (column) { if (!sortableField(column)) return; var sorting = $scope.sorting; var defaultClass = ['fa', 'fa-sort-up', 'table-header-sortchange']; if (!sorting || column !== sorting[0]) return defaultClass; return ['fa', sorting[1] === 'asc' ? 'fa-sort-up' : 'fa-sort-down']; }; $scope.moveLeft = function (column) { var index = _.indexOf($scope.columns, column); if (index === 0) return; _.move($scope.columns, index, --index); }; $scope.moveRight = function (column) { var index = _.indexOf($scope.columns, column); if (index === $scope.columns.length - 1) return; _.move($scope.columns, index, ++index); }; $scope.toggleColumn = function (fieldName) { _.toggleInOut($scope.columns, fieldName); }; $scope.sort = function (column) { if (!column || !sortableField(column)) return; var sorting = $scope.sorting = $scope.sorting || []; var direction = sorting[1] || 'asc'; if (sorting[0] !== column) { direction = 'asc'; } else { direction = sorting[1] === 'asc' ? 'desc' : 'asc'; } $scope.sorting[0] = column; $scope.sorting[1] = direction; }; } }; }); });