Merge pull request #1173 from umap-project/reverse-sort
Allow to sort reverse
This commit is contained in:
commit
509ff4efed
2 changed files with 59 additions and 3 deletions
|
@ -202,7 +202,12 @@ L.Util.sortFeatures = (features, sortKey) => {
|
|||
const sortKeys = (sortKey || 'name').split(',')
|
||||
|
||||
const sort = (a, b, i) => {
|
||||
const sortKey = sortKeys[i]
|
||||
let sortKey = sortKeys[i],
|
||||
reverse = 1
|
||||
if (sortKey[0] === '-') {
|
||||
reverse = -1
|
||||
sortKey = sortKey.substring(1)
|
||||
}
|
||||
let score
|
||||
const valA = a.properties[sortKey] || ''
|
||||
const valB = b.properties[sortKey] || ''
|
||||
|
@ -221,7 +226,7 @@ L.Util.sortFeatures = (features, sortKey) => {
|
|||
})
|
||||
}
|
||||
if (score === 0 && sortKeys[i + 1]) return sort(a, b, i + 1)
|
||||
return score
|
||||
return score * reverse
|
||||
}
|
||||
|
||||
features.sort((a, b) => {
|
||||
|
@ -553,7 +558,7 @@ L.U.Help = L.Class.extend({
|
|||
permanentCredit: L._(
|
||||
'Will be permanently visible in the bottom left corner of the map'
|
||||
),
|
||||
sortKey: L._('Property to use for sorting features'),
|
||||
sortKey: L._('Comma separated list of properties to use for sorting features. To reverse the sort, put a minus sign (-) before. Eg. mykey,-otherkey.'),
|
||||
slugKey: L._('The name of the property to use as feature unique identifier.'),
|
||||
filterKey: L._('Comma separated list of properties to use when filtering features'),
|
||||
advancedFilterKey: L._(
|
||||
|
|
|
@ -446,4 +446,55 @@ describe('L.Util', function () {
|
|||
assert.ok(L.Util.usableOption({ key: null }, 'key'))
|
||||
})
|
||||
})
|
||||
|
||||
describe("#sortFeatures()", function () {
|
||||
let feat1, feat2, feat3
|
||||
before(function () {
|
||||
feat1 = {properties: {}}
|
||||
feat2 = {properties: {}}
|
||||
feat3 = {properties: {}}
|
||||
})
|
||||
it('should sort feature from custom key', function () {
|
||||
feat1.properties.mykey = "13. foo"
|
||||
feat2.properties.mykey = "7. foo"
|
||||
feat3.properties.mykey = "111. foo"
|
||||
let features = L.Util.sortFeatures([feat1, feat2, feat3], "mykey")
|
||||
assert.equal(features[0], feat2)
|
||||
assert.equal(features[1], feat1)
|
||||
assert.equal(features[2], feat3)
|
||||
})
|
||||
it('should sort feature from multiple keys', function () {
|
||||
feat1.properties.mykey = "13. foo"
|
||||
feat2.properties.mykey = "111. foo"
|
||||
feat3.properties.mykey = "111. foo"
|
||||
feat1.properties.otherkey = "C"
|
||||
feat2.properties.otherkey = "B"
|
||||
feat3.properties.otherkey = "A"
|
||||
let features = L.Util.sortFeatures([feat1, feat2, feat3], "mykey,otherkey")
|
||||
assert.equal(features[0], feat1)
|
||||
assert.equal(features[1], feat3)
|
||||
assert.equal(features[2], feat2)
|
||||
})
|
||||
it('should sort feature from custom key reverse', function () {
|
||||
feat1.properties.mykey = "13. foo"
|
||||
feat2.properties.mykey = "7. foo"
|
||||
feat3.properties.mykey = "111. foo"
|
||||
let features = L.Util.sortFeatures([feat1, feat2, feat3], "-mykey")
|
||||
assert.equal(features[0], feat3)
|
||||
assert.equal(features[1], feat1)
|
||||
assert.equal(features[2], feat2)
|
||||
})
|
||||
it('should sort feature from multiple keys with reverse', function () {
|
||||
feat1.properties.mykey = "13. foo"
|
||||
feat2.properties.mykey = "111. foo"
|
||||
feat3.properties.mykey = "111. foo"
|
||||
feat1.properties.otherkey = "C"
|
||||
feat2.properties.otherkey = "B"
|
||||
feat3.properties.otherkey = "A"
|
||||
let features = L.Util.sortFeatures([feat1, feat2, feat3], "mykey,-otherkey")
|
||||
assert.equal(features[0], feat1)
|
||||
assert.equal(features[1], feat2)
|
||||
assert.equal(features[2], feat3)
|
||||
})
|
||||
})
|
||||
})
|
||||
|
|
Loading…
Reference in a new issue