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

72 lines (63 loc) 2.29 kB
define(function (require) { // we need to load the css ourselves require('plugins/table_vis/table_vis.less'); // we also need to load the controller and used by the template require('plugins/table_vis/table_vis_controller'); // our params are a bit complex so we will manage them with a directive require('plugins/table_vis/table_vis_params'); // require the directives that we use as well require('ui/agg_table'); require('ui/agg_table/agg_table_group'); // register the provider with the visTypes registry require('ui/registry/vis_types').register(TableVisTypeProvider); // define the TableVisType function TableVisTypeProvider(Private) { var TemplateVisType = Private(require('ui/template_vis_type/TemplateVisType')); var Schemas = Private(require('ui/Vis/Schemas')); // define the TableVisController which is used in the template // by angular's ng-controller directive // return the visType object, which kibana will use to display and configure new // Vis object of this type. return new TemplateVisType({ name: 'table', title: 'Data table', icon: 'fa-table', description: 'The data table provides a detailed breakdown, in tabular format, of the results of a composed ' + 'aggregation. Tip, a data table is available from many other charts by clicking grey bar at the bottom of the chart.', template: require('plugins/table_vis/table_vis.html'), params: { defaults: { perPage: 10, showPartialRows: false, showMeticsAtAllLevels: false }, editor: '<table-vis-params></table-vis-params>' }, hierarchicalData: function (vis) { return Boolean(vis.params.showPartialRows || vis.params.showMeticsAtAllLevels); }, schemas: new Schemas([ { group: 'metrics', name: 'metric', title: 'Metric', min: 1, defaults: [ { type: 'count', schema: 'metric' } ] }, { group: 'buckets', name: 'bucket', title: 'Split Rows' }, { group: 'buckets', name: 'split', title: 'Split Table' } ]) }); } return TableVisTypeProvider; });