Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/slammayjammay/array-element-combiner
Combines or cancels adjacent elements of an array
https://github.com/slammayjammay/array-element-combiner
chai es6 mocha node
Last synced: 27 days ago
JSON representation
Combines or cancels adjacent elements of an array
- Host: GitHub
- URL: https://github.com/slammayjammay/array-element-combiner
- Owner: slammayjammay
- License: mit
- Created: 2017-07-20T01:46:38.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-07-20T01:46:56.000Z (over 7 years ago)
- Last Synced: 2024-10-16T19:14:28.706Z (3 months ago)
- Topics: chai, es6, mocha, node
- Language: JavaScript
- Size: 13.7 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# `array-element-combiner`
Traverses an array, comparing every two adjacent elements. Takes a `compare` callback, which determines whether to combine elements; and a `combine` callback, which determines the value of the combination of elements. In the returned array, the combined value will be stored and the two original elements will be deleted.A possible use case might include an array holding a set of ordered instructions that can be shortened in the case of duplicative or opposite instructions. See the [example](#example).
## Usage
```sh
$ npm install --save array-element-combiner
``````js
const combiner = require('array-element-combiner');let array = [1, 2, 3, 4, 5];
const options = {
cancel(value) { /* ... */ },
compare(a, b) { /* ... */ },
combine(a, b,) { /* ... */ },
ignore(a, b) { /* ... */ }
};array = combiner(array, options); // returns new array
console.log(array);
```## Example
Let's say you have a set of directions that include `goForward`, `turnRight`, `turnLeft`, and `turnAround`. You also have an array that has a randomized set of directions. The array can possibly be shortened, because some elements can cancel out (`turnRight` and `turnLeft`), while others can be combined (two `turnRight`'s).```js
const directions = [
'goForward',
'turnRight',
'goForward',
'turnLeft',
'turnLeft',
'turnAround',
'goForward'
];
```Now we need to provide logic for how the directions will be combined or cancelled. For example, two `turnRight`s combine to make a `turnAround`; a `turnAround` and `turnRight` make `turnLeft`; a `turnLeft` and `turnRight` cancel out, etc.
```js
const options = {
compare(a, b) {
// can be combined if they both include a 'turn'
return a.includes('turn') && b.includes('turn');
},
combine(a, b) {
// we know that a and b both include 'turn' because they passed the
// `compare` callbackconst aDir = a.includes('right') ? 1 : a.includes('left') ? -1 : 2;
const bDir = b.includes('right') ? 1 : b.includes('left') ? -1 : 2;let totalDir = aDir + bDir;
// Two `turnAround`s or a `turnLeft` and `turnRight` will cancel out. Without
// providing a cancel callback, an empty string will be inserted into the
// returned array.
if (totalDir === 0 || totalDir === 4) {
return '';
}// A `turnAround` and a `turnRight` make a left.
if (totalDir === 3) {
totalDir = -1;
}const dirString = totalDir === 1 ? 'Right' : totalDir === 2 ? 'Around' : 'Left'
return `turn${dirString}`;
},
cancel(value) {
return value === '';
}
};
```Output:
```js
/* ... */
const output = combiner(directions, options);
console.log(output);
// [
// 'goForward',
// 'turnRight',
// 'goForward',
// 'goForward'
// ]
```