/arr-mutations

Calculate all mutation operations between two arrays. Supports a generic equals predicate function

Primary LanguageJavaScriptMIT LicenseMIT

Array mutations

Build Status

Calculate all mutation operations between two arrays. Supports a generic equals predicate function.

Install

npm install arr-mutations

Usage

var mutations = require('arr-mutations');

mutations([1, 2], [2, 3]);
//=> [{type: 'add', item: 3}, {type: 'remove', item: 1}]

mutations([2, 2, 2], [2, 2]);
//=> [{type: 'remove', item: 2}]

mutations([2, 2, 3, 2], [2, 3, 3, 2]);
//=> [{type: 'add', item: 3}, {type: 'remove', item: 2}]

// Items are matched in order from the new array, consider this example:
var first = [{id: 1, name: 'a'}, {id: 1, name: 'b'}, {id: 1, name: 'c'}];
var second = [{id: 1, name: 'aa'}, {id: 1, text: 'bb'}];
mutations(first, second, {
	equals: function(a, b) { return a.id === b.id; }
});
//=> [
//     {type: 'change', old: {id: 1, name: 'a'}, item: {id: 1, name: 'aa'}},
//     {type: 'change', old: {id: 1, name: 'b'}, item: {id: 1, text: 'bb'}},
//     {type: 'remove', item: {id: 1, name: 'c'}}
//   ]

var first = [{id: 1, text: 'one'}, {id: 2, text: 'two'}];
var second = [{id: 2, text: 'another'}, {id: 3, text: 'three'}];
mutations(first, second, {
	equals: function(a, b) { return a.id === b.id; }
});
//=> [
//     {type: 'add', item: {id: 3, text: 'three'}},
//     {type: 'change', old: {id: 2, text: 'two'}, item: {id: 2, text: 'another'}},
//     {type: 'remove', item: {id: 1, text: 'one'}}
//   ]

API

mutations(old, new, [options])

Returns an array of mutation operations which are needed to convert array old to new. When detecting if an item has changed, the items from new array are scanned from left to right and the first item passing options.equals check, will be considered as the new version of the original item. If that new item also matches options.deepEquals, it will be listed as a changed item.

Returned mutation operations are sorted by type.

old

Required
Type: array

Original array of items.

new

Required
Type: array

New array of items.

options

Type: object

options.equals

Type: function Default: function equals(a, b) { return a === b; }

Equality function. Should return true if a and b items are considered as the same entity. Entity means e.g. single user with id: 1.

If you have e.g. an array of users, this function answers to: is a the same user as b?

options.deepEquals

Type: function
Default: function deepEquals(a1, a2) { return _.isEqual(a1, a2); }

Deep equality function. Should return true if a1 is not equal to a2. Used to detect if an entity has changed.

If you have e.g. an array of users, this function answers to: is a2 a changed version a1?

License

MIT