Commit 81bbc5bb by Rashid Khan

Merge pull request #744 from rashidkpc/master

Remove idQueue from services
parents e73ea482 3fe94734
......@@ -479,6 +479,26 @@ function($, _, moment) {
});
};
// Find the smallest missing number in an array
kbn.smallestMissing = function(arr,start,end) {
start = start || 0;
end = end || arr.length-1;
if(start > end) {
return end + 1;
}
if(start !== arr[start]) {
return start;
}
var middle = Math.floor((start + end) / 2);
if (arr[middle] > middle) {
return kbn.smallestMissing(arr, start, middle);
} else {
return kbn.smallestMissing(arr, middle + 1, end);
}
};
kbn.byteFormat = function(size, decimals) {
var ext, steps = 0;
decimals = decimals || 2;
......
......@@ -2,12 +2,6 @@
"title": "New Dashboard",
"services": {
"query": {
"idQueue": [
1,
2,
3,
4
],
"list": {
"0": {
"query": "*",
......@@ -21,11 +15,6 @@
]
},
"filter": {
"idQueue": [
0,
1,
2
],
"list": {},
"ids": []
}
......
......@@ -2,12 +2,6 @@
"title": "Introduction",
"services": {
"query": {
"idQueue": [
1,
2,
3,
4
],
"list": {
"0": {
"query": "*",
......@@ -23,11 +17,6 @@
]
},
"filter": {
"idQueue": [
0,
1,
2
],
"list": {},
"ids": []
}
......
......@@ -2,12 +2,6 @@
"title": "Your Basic Dashboard",
"services": {
"query": {
"idQueue": [
1,
2,
3,
4
],
"list": {
"0": {
"query": "*",
......@@ -23,11 +17,6 @@
]
},
"filter": {
"idQueue": [
0,
1,
2
],
"list": {},
"ids": []
}
......
......@@ -2,9 +2,6 @@
"title": "Logstash Search",
"services": {
"query": {
"idQueue": [
1
],
"list": {
"0": {
"query": "{{ARGS.query || '*'}}",
......@@ -20,9 +17,6 @@
]
},
"filter": {
"idQueue": [
1
],
"list": {
"0": {
"type": "time",
......
......@@ -2,12 +2,6 @@
"title": "A few notes",
"services": {
"query": {
"idQueue": [
1,
2,
3,
4
],
"list": {
"0": {
"query": "*",
......@@ -23,11 +17,6 @@
]
},
"filter": {
"idQueue": [
0,
1,
2
],
"list": {},
"ids": []
}
......
......@@ -14,14 +14,12 @@ define([
// Defaults for it
var _d = {
idQueue : [],
list : {},
ids : []
};
// For convenience
var ejs = ejsResource(config.elasticsearch);
var _f = dashboard.current.services.filter;
// Save a reference to this
var self = this;
......@@ -34,7 +32,6 @@ define([
// Accessors
self.list = dashboard.current.services.filter.list;
self.ids = dashboard.current.services.filter.ids;
_f = dashboard.current.services.filter;
_.each(self.list,function(f) {
self.set(f,f.id,true);
......@@ -97,8 +94,6 @@ define([
delete self.list[id];
// This must happen on the full path also since _.without returns a copy
self.ids = dashboard.current.services.filter.ids = _.without(self.ids,id);
_f.idQueue.unshift(id);
_f.idQueue.sort(function(v,k){return v-k;});
_r = true;
} else {
_r = false;
......@@ -230,10 +225,14 @@ define([
};
var nextId = function() {
if(_f.idQueue.length > 0) {
return _f.idQueue.shift();
var idCount = dashboard.current.services.filter.ids.length;
if(idCount > 0) {
// Make a sorted copy of the ids array
var ids = _.clone(dashboard.current.services.filter.ids).sort();
return kbn.smallestMissing(ids);
} else {
return self.ids.length;
// No ids currently in list
return 0;
}
};
......
......@@ -14,7 +14,6 @@ function (angular, _, config, kbn) {
// Create an object to hold our service state on the dashboard
dashboard.current.services.query = dashboard.current.services.query || {};
_.defaults(dashboard.current.services.query,{
idQueue : [],
list : {},
ids : [],
});
......@@ -31,7 +30,6 @@ function (angular, _, config, kbn) {
// For convenience
var ejs = ejsResource(config.elasticsearch);
var _q = dashboard.current.services.query;
// Holds all actual queries, including all resolved abstract queries
var resolvedQueries = [];
......@@ -176,10 +174,6 @@ function (angular, _, config, kbn) {
delete self.list[id];
// This must happen on the full path also since _.without returns a copy
self.ids = dashboard.current.services.query.ids = _.without(self.ids,id);
_q.idQueue.unshift(id);
_q.idQueue.sort(function(v,k){
return v-k;
});
return true;
} else {
return false;
......@@ -246,10 +240,14 @@ function (angular, _, config, kbn) {
};
var nextId = function() {
if(_q.idQueue.length > 0) {
return _q.idQueue.shift();
var idCount = dashboard.current.services.query.ids.length;
if(idCount > 0) {
// Make a sorted copy of the ids array
var ids = _.clone(dashboard.current.services.query.ids).sort();
return kbn.smallestMissing(ids);
} else {
return self.ids.length;
// No ids currently in list
return 0;
}
};
......
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