Commit d056b1f1 by Torkel Ödegaard

Search: max_results config.js option & scroll in search results (To show more or…

Search: max_results config.js option & scroll in search results (To show more or all dashboards), Closes #631
parent 14f09e37
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
- [Issue #266](https://github.com/grafana/grafana/issues/266). Graphite: New option cacheTimeout to override graphite default memcache timeout - [Issue #266](https://github.com/grafana/grafana/issues/266). Graphite: New option cacheTimeout to override graphite default memcache timeout
- [Issue #606](https://github.com/grafana/grafana/issues/606). General: New global option in config.js to specify admin password (useful to hinder users from accidentally make changes) - [Issue #606](https://github.com/grafana/grafana/issues/606). General: New global option in config.js to specify admin password (useful to hinder users from accidentally make changes)
- [Issue #201](https://github.com/grafana/grafana/issues/201). Annotations: Elasticsearch datasource support for events - [Issue #201](https://github.com/grafana/grafana/issues/201). Annotations: Elasticsearch datasource support for events
- [Issue #631](https://github.com/grafana/grafana/issues/631). Search: max_results config.js option & scroll in search results (To show more or all dashboards)
**Changes** **Changes**
- [Issue #536](https://github.com/grafana/grafana/issues/536). Graphite: Use unix epoch for Graphite from/to for absolute time ranges - [Issue #536](https://github.com/grafana/grafana/issues/536). Graphite: Use unix epoch for Graphite from/to for absolute time ranges
......
...@@ -19,7 +19,8 @@ function (_, crypto) { ...@@ -19,7 +19,8 @@ function (_, crypto) {
default_route : '/dashboard/file/default.json', default_route : '/dashboard/file/default.json',
playlist_timespan : "1m", playlist_timespan : "1m",
unsaved_changes_warning : true, unsaved_changes_warning : true,
admin: {} search : { max_results: 20 },
admin : {}
}; };
// This initializes a new hash on purpose, to avoid adding parameters to // This initializes a new hash on purpose, to avoid adding parameters to
......
...@@ -60,6 +60,7 @@ ...@@ -60,6 +60,7 @@
</table> </table>
<table class="table table-condensed table-striped" ng-if="!tagsOnly"> <table class="table table-condensed table-striped" ng-if="!tagsOnly">
<tbody style="max-height: 570px; overflow: auto; display: block">
<tr bindonce ng-repeat="row in results.metrics" <tr bindonce ng-repeat="row in results.metrics"
class="grafana-search-metric-result" class="grafana-search-metric-result"
ng-class="{'selected': $index === selectedIndex }"> ng-class="{'selected': $index === selectedIndex }">
...@@ -88,6 +89,7 @@ ...@@ -88,6 +89,7 @@
</td> </td>
<td><a><i class="icon-share" ng-click="shareDashboard(row._id, row._id)" config-modal="app/partials/dashLoaderShare.html"></i></a></td> <td><a><i class="icon-share" ng-click="shareDashboard(row._id, row._id)" config-modal="app/partials/dashLoaderShare.html"></i></a></td>
</tr> </tr>
</tbody>
</table> </table>
</div> </div>
</li> </li>
......
...@@ -23,6 +23,7 @@ function (angular, _, $, config, kbn, moment) { ...@@ -23,6 +23,7 @@ function (angular, _, $, config, kbn, moment) {
this.index = datasource.index; this.index = datasource.index;
this.grafanaDB = datasource.grafanaDB; this.grafanaDB = datasource.grafanaDB;
this.annotationEditorSrc = 'app/partials/elasticsearch/annotation_editor.html'; this.annotationEditorSrc = 'app/partials/elasticsearch/annotation_editor.html';
this.searchMaxResults = config.search.max_results || 20;
} }
ElasticDatasource.prototype._request = function(method, url, index, data) { ElasticDatasource.prototype._request = function(method, url, index, data) {
...@@ -198,7 +199,7 @@ function (angular, _, $, config, kbn, moment) { ...@@ -198,7 +199,7 @@ function (angular, _, $, config, kbn, moment) {
var query = { var query = {
query: { query_string: { query: queryString } }, query: { query_string: { query: queryString } },
facets: { tags: { terms: { field: "tags", order: "term", size: 50 } } }, facets: { tags: { terms: { field: "tags", order: "term", size: 50 } } },
size: 20, size: this.searchMaxResults,
sort: ["_uid"] sort: ["_uid"]
}; };
...@@ -208,7 +209,7 @@ function (angular, _, $, config, kbn, moment) { ...@@ -208,7 +209,7 @@ function (angular, _, $, config, kbn, moment) {
return { dashboards: [], tags: [] }; return { dashboards: [], tags: [] };
} }
return { dashboards: results.hits.hits, tags: results.facets.terms }; return { dashboards: results.hits.hits, tags: results.facets.terms || [] };
}); });
}; };
......
...@@ -9,7 +9,9 @@ function (Settings) { ...@@ -9,7 +9,9 @@ function (Settings) {
return new Settings({ return new Settings({
// datasources, you can add multiple // datasources
// Delete the ones you do not want
// grafanaDB: true marks the datasource for use as dashboard storage
datasources: { datasources: {
graphite: { graphite: {
type: 'graphite', type: 'graphite',
...@@ -22,19 +24,23 @@ function (Settings) { ...@@ -22,19 +24,23 @@ function (Settings) {
username: 'admin', username: 'admin',
password: 'admin' password: 'admin'
}, },
// elasticsearch, used for storing and loading dashboards, annotations
// For Basic authentication use: http://username:password@domain.com:9200
elasticsearch: {
type: 'elasticsearch',
url: "http://"+window.location.hostname+":9200"
index: 'grafana-dash', // index for storing dashboards
grafanaDB: true,
}
}, },
// elasticsearch url search: {
// used for storing and loading dashboards, optional max_results: 20
// For Basic authentication use: http://username:password@domain.com:9200 },
elasticsearch: "http://"+window.location.hostname+":9200",
// default start dashboard // default start dashboard
default_route: '/dashboard/file/default.json', default_route: '/dashboard/file/default.json',
// Elasticsearch index for storing dashboards
grafana_index: "grafana-dash",
// set to false to disable unsaved changes warning // set to false to disable unsaved changes warning
unsaved_changes_warning: true, unsaved_changes_warning: true,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment