A set of frequently used functions for working with arrays, for sorting, filtering or checking the state of an array
npm install @plq/array-functionsFilters an array of objects so that the value of a given key occurs only once in the array.
``javascript
import { filterBySameKeyValue } from '@plq/array-functions'
const array = [
{ id: 1, name: 'Alice' },
{ id: 2, name: 'Bob' },
{ id: 3, name: 'Alice' },
]
console.log(filterBySameKeyValue(array, 'name')) // Output: [{ id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }]
`
Returns the array of values of a given key from an array of objects.
`javascript
import { getKeyValue } from '@plq/array-functions'
const array = [
{ id: 1, name: 'Alice' },
{ id: 2, name: 'Bob' },
{ id: 3, name: 'Alice' },
]
console.log(getKeyValue(array, 'name')) // Output: ['Alice', 'Bob', 'Alice']
`
Sorts an array of objects by a given key.
`javascript
import { sortBy } from '@plq/array-functions'
const array = [
{ id: 1, name: 'Alice' },
{ id: 3, name: 'Alice' },
{ id: 2, name: 'Bob' },
]
console.log(sortBy(array, 'id')) // Output: [{ id: 3, name: 'Bob' }, { id: 2, name: 'Alice' }, { id: 1, name: 'Alice' }]
console.log(sortBy(array, 'id', 'asc')) // Output: [{ id: 1, name: 'Alice' }, { id: 2, name: 'Alice' }, { id: 3, name: 'Bob' }]
`
Checks if an array of objects is sorted by a given key.
`javascript
import { isSorted } from '@plq/array-functions'
const array = [
{ id: 1, name: 'Alice' },
{ id: 2, name: 'Bob' },
{ id: 3, name: 'Alice' },
]
console.log(isSorted(array, 'id')) // Output: false because default sort order is 'desc'
console.log(isSorted(array, 'id', 'asc')) // Output: true
console.log(isSorted(array, 'name', 'asc')) // Output: false
`
Returns an array of unique values from an array of objects.
`javascript
import { getUniqueValues } from '@plq/array-functions'
const array = [
{ id: 1, name: 'Alice' },
{ id: 2, name: 'Bob' },
{ id: 3, name: 'Alice' },
]
console.log(getUniqueValues(array, 'name')) // Output: ['Alice', 'Bob']
`
Splits an array of objects into subarrays with the same value of the given key.
`javascript
import { splitByKeyValue } from '@plq/array-functions'
const array = [
{ id: 1, name: 'Alice' },
{ id: 2, name: 'Bob' },
{ id: 3, name: 'Alice' },
]
console.log(splitByKeyValue(array, 'name')) // Output: [[{ id: 1, name: 'Alice' }, { id: 3, name: 'Alice' }], [{ id: 2, name: 'Bob' }]]
`
Creates an array of a specified length where the sum of all elements equals a given sum. The function distributes the sum evenly across the array elements. If the sum is negative, the function creates an array of negative numbers. If the sum cannot be evenly distributed, the function distributes the remainder as evenly as possible. If the length is zero or negative, the function returns an empty array.
`typescript
import { createBalancedArray } from '@plq/array-functions'
console.log(createBalancedArray(5, 10)); // Output: [2, 2, 2, 2, 2]
console.log(createBalancedArray(3, -5)); // Output: [-2, -2, -1]
console.log(createBalancedArray(0, 10)); // Output: []
console.log(createBalancedArray(-3, 10)); // Output: []
`
`bash`
npm install
We use ESLint and @typescript-eslint/eslint-plugin to lint our code.
Check out .eslintrc.json
`bash`
npm run lint
We use Jest to test our code.
`bash`
npm test
We use TypeScript to build our code.
`bash`
npm run build
- [ ] Add new file to src folder like function-name.tsfunctionName
- [ ] Write a function in function-name.tssrc/index.ts
- [ ] Add new function to like export { default as functionName } from './function-name'__tests__
- [ ] Add new test to folder with name function-name.test.tsfunctionName
- [ ] Write tests for in function-name.test.tsnpm run lint
- [ ] Run npm run test`
- [ ] Run
- [ ] Commit and push your changes
- [ ] Create a pull request