Package Exports
- sort-array
- sort-array/index.mjs
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (sort-array) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
sort-array
Isomorphic, load-anywhere function to sort an array by scalar, deep or computed values in any standard or custom order.
const sortArray = require('sort-array')Synopsis
Sort an array of primitives, for example strings.
> const partsOfTheDay = ['twilight', 'afternoon', 'morning', 'evening']
> sortArray(partsOfTheDay)
[ 'afternoon', 'evening', 'morning', 'twilight' ]The default sort order is asc. You can also specify desc or a custom order. For example, sort parts of the day by the time in which they occur.
> sortArray(partsOfTheDay, {
order: 'time',
customOrders: {
time: ['morning', 'afternoon', 'evening', 'twilight']
}
})
[ 'morning', 'afternoon', 'evening', 'twilight' ]Sort by a computed field. For example, an algorithm to rank boxers by influence.
> const boxers = [
{ name: 'Anthony', ticketsSold: 90000, titlesHeld: 0 },
{ name: 'Amir', ticketsSold: 30000, titlesHeld: 2 },
{ name: 'Vasiliy', ticketsSold: 20000, titlesHeld: 4 },
{ name: 'Josh', ticketsSold: 10000, titlesHeld: 3 },
]
> sortArray(boxers, {
by: 'rank',
order: 'desc',
computed: {
rank: boxer => boxer.ticketsSold + (boxer.titlesHeld * 10000)
}
})
[
{ name: 'Anthony', ticketsSold: 90000, titlesHeld: 0 },
{ name: 'Vasiliy', ticketsSold: 20000, titlesHeld: 4 },
{ name: 'Amir', ticketsSold: 30000, titlesHeld: 2 },
{ name: 'Josh', ticketsSold: 10000, titlesHeld: 3 }
]You can use computed fields to sort by values deep in an object structure.
> const data = [
{ inner: { number: 2 } },
{ inner: { number: 3 } },
{ inner: { number: 5 } },
{ inner: { number: 1 } },
{ inner: { number: 4 } }
]
> sortArray(data, {
by: 'number',
computed: {
number: row => row.inner.number
}
})
[
{ inner: { number: 1 } },
{ inner: { number: 2 } },
{ inner: { number: 3 } },
{ inner: { number: 4 } },
{ inner: { number: 5 } }
]Sort by multiple columns using multiple custom orders.
> const attributes = [
{ skill: 'accuracy', confidence: 'medium' },
{ skill: 'power', confidence: 'high' },
{ skill: 'speed', confidence: 'low' },
{ skill: 'power', confidence: 'low' },
{ skill: 'speed', confidence: 'high' },
{ skill: 'accuracy', confidence: 'low' },
{ skill: 'speed', confidence: 'medium' },
{ skill: 'accuracy', confidence: 'high' },
{ skill: 'power', confidence: 'medium' }
]
> sortArray(attributes, {
by: ['skill', 'confidence'],
order: ['skill', 'confidence'],
customOrders: {
skill: ['accuracy', 'speed', 'power'],
confidence: ['low', 'medium', 'high'],
}
})
[
{ skill: 'accuracy', confidence: 'low' },
{ skill: 'accuracy', confidence: 'medium' },
{ skill: 'accuracy', confidence: 'high' },
{ skill: 'speed', confidence: 'low' },
{ skill: 'speed', confidence: 'medium' },
{ skill: 'speed', confidence: 'high' },
{ skill: 'power', confidence: 'low' },
{ skill: 'power', confidence: 'medium' },
{ skill: 'power', confidence: 'high' }
]sort-array
Isomorphic, load-anywhere function to sort an array by scalar, deep or computed values in any standard or custom order.
Example
const sortArray = require('sort-array')sortArray(array, [options]) ⏏
Kind: Exported function
| Param | Type | Description |
|---|---|---|
| array | Array |
Input array. |
| [options] | object |
Sort config. |
| [options.by] | Array.<string> |
One or more property names or computed fields to sort by. Specifying property names is only relevant when sorting an array of objects. |
| [options.order] | Array.<string> |
One or more sort orders. Specify asc, desc or the property name from options.customOrders. |
| [options.customOrders] | object |
An object containing one or more custom orders. Each custom order must be an array defining the order expected values must be sorted in. |
| [options.computed] | object |
An object containing one or more computed field functions. |
Load anywhere
This library is compatible with Node.js, the Web and any style of module loader. It can be loaded anywhere, natively without transpilation.
Node.js:
const arrayify = require('sort-array')Within Node.js with ECMAScript Module support enabled:
import arrayify from 'sort-array'Within an modern browser ECMAScript Module:
import arrayify from './node_modules/sort-array/index.mjs'Old browser (adds window.sortArray):
<script nomodule src="./node_modules/sort-array/dist/index.js"></script>© 2015-19 Lloyd Brookes <75pound@gmail.com>. Documented by jsdoc-to-markdown.