New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

redux-collector

Package Overview
Dependencies
Maintainers
1
Versions
6
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

redux-collector - npm Package Compare versions

Comparing version 0.1.2 to 1.0.0

lib/default-matcher.js

54

lib/collectify.js

@@ -10,4 +10,2 @@ 'use strict';

var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
var _collectorReducers = require('./collector-reducers');

@@ -41,33 +39,23 @@

return function collectify() {
for (var _len = arguments.length, config = Array(_len), _key = 0; _key < _len; _key++) {
config[_key] = arguments[_key];
}
var _ref = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];
var _config$reverse = config.reverse();
var itemDefaultArg = _ref.itemDefault;
var _ref$add = _ref.add;
var add = _ref$add === undefined ? '@@/COLLECTOR_ADD' : _ref$add;
var _ref$move = _ref.move;
var move = _ref$move === undefined ? '@@/COLLECTOR_MOVE' : _ref$move;
var _ref$swap = _ref.swap;
var swap = _ref$swap === undefined ? '@@/COLLECTOR_SWAP' : _ref$swap;
var _ref$addRange = _ref.addRange;
var addRange = _ref$addRange === undefined ? '@@/COLLECTOR_ADD_RANGE' : _ref$addRange;
var _ref$remove = _ref.remove;
var remove = _ref$remove === undefined ? '@@/COLLECTOR_REMOVE' : _ref$remove;
var _ref$hydrate = _ref.hydrate;
var hydrate = _ref$hydrate === undefined ? '@@/COLLECTOR_HYDRATE' : _ref$hydrate;
var _ref$sort = _ref.sort;
var sort = _ref$sort === undefined ? '@@/COLLECTOR_SORT' : _ref$sort;
var reducerArg = arguments.length <= 1 || arguments[1] === undefined ? [] : arguments[1];
var collectionDefault = arguments.length <= 2 || arguments[2] === undefined ? [] : arguments[2];
var _config$reverse2 = _slicedToArray(_config$reverse, 2);
var _config$reverse2$ = _config$reverse2[0];
_config$reverse2$ = _config$reverse2$ === undefined ? {} : _config$reverse2$;
var itemDefaultArg = _config$reverse2$.itemDefault;
var _config$reverse2$$col = _config$reverse2$.collectionDefault;
var collectionDefault = _config$reverse2$$col === undefined ? [] : _config$reverse2$$col;
var _config$reverse2$$add = _config$reverse2$.add;
var add = _config$reverse2$$add === undefined ? '@@/COLLECTOR_ADD' : _config$reverse2$$add;
var _config$reverse2$$mov = _config$reverse2$.move;
var move = _config$reverse2$$mov === undefined ? '@@/COLLECTOR_MOVE' : _config$reverse2$$mov;
var _config$reverse2$$swa = _config$reverse2$.swap;
var swap = _config$reverse2$$swa === undefined ? '@@/COLLECTOR_SWAP' : _config$reverse2$$swa;
var _config$reverse2$$add2 = _config$reverse2$.addRange;
var addRange = _config$reverse2$$add2 === undefined ? '@@/COLLECTOR_ADD_RANGE' : _config$reverse2$$add2;
var _config$reverse2$$rem = _config$reverse2$.remove;
var remove = _config$reverse2$$rem === undefined ? '@@/COLLECTOR_REMOVE' : _config$reverse2$$rem;
var _config$reverse2$$hyd = _config$reverse2$.hydrate;
var hydrate = _config$reverse2$$hyd === undefined ? '@@/COLLECTOR_HYDRATE' : _config$reverse2$$hyd;
var _config$reverse2$$sor = _config$reverse2$.sort;
var sort = _config$reverse2$$sor === undefined ? '@@/COLLECTOR_SORT' : _config$reverse2$$sor;
var _config$reverse2$2 = _config$reverse2[1];
var reducerArg = _config$reverse2$2 === undefined ? [] : _config$reverse2$2;
var itemDefault = itemDefaultArg === undefined ? reducerArg.defaultsTo : itemDefaultArg;

@@ -83,4 +71,4 @@

for (var _len2 = arguments.length, rest = Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) {
rest[_key2 - 2] = arguments[_key2];
for (var _len = arguments.length, rest = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {
rest[_key - 2] = arguments[_key];
}

@@ -113,2 +101,2 @@

exports.clamp = _lib.clamp;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb2xsZWN0aWZ5LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUE7Ozs7QUFDQTs7QUFDQTs7OztBQUNBOzs7Ozs7QUFFQSxTQUFTLGVBQVQsQ0FBeUIsR0FBekIsRUFBOEI7QUFDNUIsTUFBSSxJQUFJLENBQUosSUFBUyxJQUFJLE1BQWpCLEVBQXlCO0FBQ3ZCLFVBQU0scUxBQU47QUFDRDtBQUNELFNBQU8sSUFBUDtBQUNEOztBQUVELFNBQVMsbUJBQVQsR0FBMkM7QUFBQSxNQUFkLE9BQWMseURBQUosRUFBSTs7O0FBRXpDLFNBQU8sU0FBUyxVQUFULEdBQStCO0FBQUEsc0NBQVIsTUFBUTtBQUFSLFlBQVE7QUFBQTs7QUFBQSwwQkFZVCxPQUFPLE9BQVAsRUFaUzs7QUFBQTs7QUFBQTtBQUFBLDBEQVloQyxFQVpnQztBQUFBLFFBR3JCLGNBSHFCLHFCQUdsQyxXQUhrQztBQUFBLGtEQUlsQyxpQkFKa0M7QUFBQSxRQUlsQyxpQkFKa0MseUNBSWQsRUFKYztBQUFBLGtEQUtsQyxHQUxrQztBQUFBLFFBS2xDLEdBTGtDLHlDQUs1QixrQkFMNEI7QUFBQSxrREFNbEMsSUFOa0M7QUFBQSxRQU1sQyxJQU5rQyx5Q0FNM0IsbUJBTjJCO0FBQUEsa0RBT2xDLElBUGtDO0FBQUEsUUFPbEMsSUFQa0MseUNBTzNCLG1CQVAyQjtBQUFBLG1EQVFsQyxRQVJrQztBQUFBLFFBUWxDLFFBUmtDLDBDQVF2Qix3QkFSdUI7QUFBQSxrREFTbEMsTUFUa0M7QUFBQSxRQVNsQyxNQVRrQyx5Q0FTekIscUJBVHlCO0FBQUEsa0RBVWxDLE9BVmtDO0FBQUEsUUFVbEMsT0FWa0MseUNBVXhCLHNCQVZ3QjtBQUFBLGtEQVdsQyxJQVhrQztBQUFBLFFBV2xDLElBWGtDLHlDQVczQixtQkFYMkI7QUFBQTtBQUFBLFFBWTVCLFVBWjRCLHNDQVlmLEVBWmU7OztBQWNwQyxRQUFNLGNBQWMsbUJBQW1CLFNBQW5CLEdBQ2hCLFdBQVcsVUFESyxHQUVoQixjQUZKOztBQUlBLFFBQU0sVUFBVSx3QkFBUyxpQkFBRSxhQUFGLENBQWdCLFVBQWhCLElBQStCLGdCQUFnQixVQUFoQixrQkFBbUMsVUFBbkMsSUFBK0MsWUFBWSxFQUEzRCxHQUEvQixHQUFpRyxVQUExRyxDQUFoQjs7QUFFQSxRQUFNLGNBQWMsaUNBQWUsT0FBZixFQUF3QixFQUFDLHdCQUFELEVBQWMsZ0JBQWQsRUFBeEIsQ0FBcEI7O0FBRUEsV0FBTyxTQUFTLGNBQVQsR0FBeUU7QUFBQSxVQUFqRCxLQUFpRCx5REFBekMsaUJBQXlDO0FBQUEsVUFBdEIsTUFBc0IseURBQWIsRUFBYTs7QUFBQSx5Q0FBTixJQUFNO0FBQU4sWUFBTTtBQUFBOztBQUM5RSxjQUFRLE9BQU8sSUFBZjtBQUNFLGFBQUssR0FBTDtBQUNFLGlCQUFPLFlBQVksR0FBWixxQkFBZ0IsS0FBaEIsRUFBdUIsTUFBdkIsU0FBa0MsSUFBbEMsRUFBUDtBQUNGLGFBQUssSUFBTDtBQUNFLGlCQUFPLFlBQVksSUFBWixxQkFBaUIsS0FBakIsRUFBd0IsTUFBeEIsU0FBbUMsSUFBbkMsRUFBUDtBQUNGLGFBQUssUUFBTDtBQUNFLGlCQUFPLFlBQVksUUFBWixxQkFBcUIsS0FBckIsRUFBNEIsTUFBNUIsU0FBdUMsSUFBdkMsRUFBUDtBQUNGLGFBQUssTUFBTDtBQUNFLGlCQUFPLFlBQVksTUFBWixxQkFBbUIsS0FBbkIsRUFBMEIsTUFBMUIsU0FBcUMsSUFBckMsRUFBUDtBQUNGLGFBQUssSUFBTDtBQUNFLGlCQUFPLFlBQVksSUFBWixxQkFBaUIsS0FBakIsRUFBd0IsTUFBeEIsU0FBbUMsSUFBbkMsRUFBUDtBQUNGLGFBQUssT0FBTDtBQUNFLGlCQUFPLFlBQVksT0FBWixxQkFBb0IsS0FBcEIsRUFBMkIsTUFBM0IsU0FBc0MsSUFBdEMsRUFBUDtBQUNGLGFBQUssSUFBTDtBQUNFLGlCQUFPLFlBQVksSUFBWixxQkFBaUIsS0FBakIsRUFBd0IsTUFBeEIsU0FBbUMsSUFBbkMsRUFBUDtBQUNGO0FBQ0UsaUJBQU8sWUFBWSxNQUFaLHFCQUFtQixLQUFuQixFQUEwQixNQUExQixTQUFxQyxJQUFyQyxFQUFQO0FBaEJKO0FBa0JELEtBbkJEO0FBb0JELEdBMUNEO0FBMkNEOztrQkFFYyxxQjtRQUNQLG1CLEdBQUEsbUI7UUFBcUIsSyIsImZpbGUiOiJjb2xsZWN0aWZ5LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNyZWF0ZVJlZHVjZXJzIGZyb20gJy4vY29sbGVjdG9yLXJlZHVjZXJzJztcbmltcG9ydCB7Y2xhbXB9IGZyb20gJy4vbGliJztcbmltcG9ydCByZWR1Y2lmeSBmcm9tICdyZWR1Y2lmeSc7XG5pbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuXG5mdW5jdGlvbiBjaGVja1JlZHVjZXJBcmcoYXJnKSB7XG4gIGlmIChhcmcuJCB8fCBhcmcuc2VsZWN0KSB7XG4gICAgdGhyb3cgJ1tSZWR1eCBDb2xsZWN0b3JdIC0gVGhlIHRvcCBsZXZlbCBvZiB0aGlzIHJlZHVjZXIgbXVzdCBiZSBhbiBhcnJheS4gTWFrZSB0aGlzIHJlZHVjZXIgYSBjaGlsZCBvZiBhIHBpcGVsaW5lIHJlZHVjZXIgd2l0aCBhIHNlbGVjdG9yLiBodHRwOi8vcmVkdXgtY29sbGVjdG9yLm1lZGlhZHJha2UuY29tLyNnb3RjaGFzJztcbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZnVuY3Rpb24gY29uZmlndXJlQ29sbGVjdGlmeShvcHRpb25zID0ge30pIHtcblxuICByZXR1cm4gZnVuY3Rpb24gY29sbGVjdGlmeSguLi5jb25maWcpIHtcblxuICAgIGNvbnN0IFt7XG4gICAgICBpdGVtRGVmYXVsdDogaXRlbURlZmF1bHRBcmcsXG4gICAgICBjb2xsZWN0aW9uRGVmYXVsdCA9IFtdLFxuICAgICAgYWRkID0gJ0BAL0NPTExFQ1RPUl9BREQnLFxuICAgICAgbW92ZSA9ICdAQC9DT0xMRUNUT1JfTU9WRScsXG4gICAgICBzd2FwID0gJ0BAL0NPTExFQ1RPUl9TV0FQJyxcbiAgICAgIGFkZFJhbmdlID0gJ0BAL0NPTExFQ1RPUl9BRERfUkFOR0UnLFxuICAgICAgcmVtb3ZlID0gJ0BAL0NPTExFQ1RPUl9SRU1PVkUnLFxuICAgICAgaHlkcmF0ZSA9ICdAQC9DT0xMRUNUT1JfSFlEUkFURScsXG4gICAgICBzb3J0ID0gJ0BAL0NPTExFQ1RPUl9TT1JUJ1xuICAgIH0gPSB7fSwgcmVkdWNlckFyZyA9IFtdXSA9IGNvbmZpZy5yZXZlcnNlKCk7XG5cbiAgICBjb25zdCBpdGVtRGVmYXVsdCA9IGl0ZW1EZWZhdWx0QXJnID09PSB1bmRlZmluZWRcbiAgICAgID8gcmVkdWNlckFyZy5kZWZhdWx0c1RvXG4gICAgICA6IGl0ZW1EZWZhdWx0QXJnO1xuXG4gICAgY29uc3QgcmVkdWNlciA9IHJlZHVjaWZ5KF8uaXNQbGFpbk9iamVjdChyZWR1Y2VyQXJnKSA/IChjaGVja1JlZHVjZXJBcmcocmVkdWNlckFyZykgJiYgey4uLnJlZHVjZXJBcmcsIGRlZmF1bHRzVG86IFtdfSkgOiByZWR1Y2VyQXJnKTtcblxuICAgIGNvbnN0ICQkY29sbGVjdG9yID0gY3JlYXRlUmVkdWNlcnMob3B0aW9ucywge2l0ZW1EZWZhdWx0LCByZWR1Y2VyfSk7XG5cbiAgICByZXR1cm4gZnVuY3Rpb24gcmVkdXhDb2xsZWN0b3Ioc3RhdGUgPSBjb2xsZWN0aW9uRGVmYXVsdCwgYWN0aW9uID0ge30sIC4uLnJlc3QpIHtcbiAgICAgIHN3aXRjaCAoYWN0aW9uLnR5cGUpIHtcbiAgICAgICAgY2FzZSBhZGQ6XG4gICAgICAgICAgcmV0dXJuICQkY29sbGVjdG9yLmFkZChzdGF0ZSwgYWN0aW9uLCAuLi5yZXN0KTtcbiAgICAgICAgY2FzZSBzb3J0OlxuICAgICAgICAgIHJldHVybiAkJGNvbGxlY3Rvci5zb3J0KHN0YXRlLCBhY3Rpb24sIC4uLnJlc3QpO1xuICAgICAgICBjYXNlIGFkZFJhbmdlOlxuICAgICAgICAgIHJldHVybiAkJGNvbGxlY3Rvci5hZGRSYW5nZShzdGF0ZSwgYWN0aW9uLCAuLi5yZXN0KTtcbiAgICAgICAgY2FzZSByZW1vdmU6XG4gICAgICAgICAgcmV0dXJuICQkY29sbGVjdG9yLmZpbHRlcihzdGF0ZSwgYWN0aW9uLCAuLi5yZXN0KTtcbiAgICAgICAgY2FzZSBtb3ZlOlxuICAgICAgICAgIHJldHVybiAkJGNvbGxlY3Rvci5tb3ZlKHN0YXRlLCBhY3Rpb24sIC4uLnJlc3QpO1xuICAgICAgICBjYXNlIGh5ZHJhdGU6XG4gICAgICAgICAgcmV0dXJuICQkY29sbGVjdG9yLmh5ZHJhdGUoc3RhdGUsIGFjdGlvbiwgLi4ucmVzdCk7XG4gICAgICAgIGNhc2Ugc3dhcDpcbiAgICAgICAgICByZXR1cm4gJCRjb2xsZWN0b3Iuc3dhcChzdGF0ZSwgYWN0aW9uLCAuLi5yZXN0KTtcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICByZXR1cm4gJCRjb2xsZWN0b3IudXBkYXRlKHN0YXRlLCBhY3Rpb24sIC4uLnJlc3QpO1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBjb25maWd1cmVDb2xsZWN0aWZ5KCk7XG5leHBvcnQge2NvbmZpZ3VyZUNvbGxlY3RpZnksIGNsYW1wfTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,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O1FBQ1AsbUIsR0FBQSxtQjtRQUFxQixLIiwiZmlsZSI6ImNvbGxlY3RpZnkuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY3JlYXRlUmVkdWNlcnMgZnJvbSAnLi9jb2xsZWN0b3ItcmVkdWNlcnMnO1xuaW1wb3J0IHtjbGFtcH0gZnJvbSAnLi9saWInO1xuaW1wb3J0IHJlZHVjaWZ5IGZyb20gJ3JlZHVjaWZ5JztcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5cbmZ1bmN0aW9uIGNoZWNrUmVkdWNlckFyZyhhcmcpIHtcbiAgaWYgKGFyZy4kIHx8IGFyZy5zZWxlY3QpIHtcbiAgICB0aHJvdyAnW1JlZHV4IENvbGxlY3Rvcl0gLSBUaGUgdG9wIGxldmVsIG9mIHRoaXMgcmVkdWNlciBtdXN0IGJlIGFuIGFycmF5LiBNYWtlIHRoaXMgcmVkdWNlciBhIGNoaWxkIG9mIGEgcGlwZWxpbmUgcmVkdWNlciB3aXRoIGEgc2VsZWN0b3IuIGh0dHA6Ly9yZWR1eC1jb2xsZWN0b3IubWVkaWFkcmFrZS5jb20vI2dvdGNoYXMnO1xuICB9XG4gIHJldHVybiB0cnVlO1xufVxuXG5mdW5jdGlvbiBjb25maWd1cmVDb2xsZWN0aWZ5KG9wdGlvbnMgPSB7fSkge1xuXG4gIHJldHVybiBmdW5jdGlvbiBjb2xsZWN0aWZ5KHtcbiAgICBpdGVtRGVmYXVsdDogaXRlbURlZmF1bHRBcmcsXG4gICAgYWRkID0gJ0BAL0NPTExFQ1RPUl9BREQnLFxuICAgIG1vdmUgPSAnQEAvQ09MTEVDVE9SX01PVkUnLFxuICAgIHN3YXAgPSAnQEAvQ09MTEVDVE9SX1NXQVAnLFxuICAgIGFkZFJhbmdlID0gJ0BAL0NPTExFQ1RPUl9BRERfUkFOR0UnLFxuICAgIHJlbW92ZSA9ICdAQC9DT0xMRUNUT1JfUkVNT1ZFJyxcbiAgICBoeWRyYXRlID0gJ0BAL0NPTExFQ1RPUl9IWURSQVRFJyxcbiAgICBzb3J0ID0gJ0BAL0NPTExFQ1RPUl9TT1JUJ1xuICB9ID0ge30sIHJlZHVjZXJBcmcgPSBbXSwgY29sbGVjdGlvbkRlZmF1bHQgPSBbXSkge1xuXG5cblxuICAgIGNvbnN0IGl0ZW1EZWZhdWx0ID0gaXRlbURlZmF1bHRBcmcgPT09IHVuZGVmaW5lZFxuICAgICAgPyByZWR1Y2VyQXJnLmRlZmF1bHRzVG9cbiAgICAgIDogaXRlbURlZmF1bHRBcmc7XG5cbiAgICBjb25zdCByZWR1Y2VyID0gcmVkdWNpZnkoXy5pc1BsYWluT2JqZWN0KHJlZHVjZXJBcmcpID8gKGNoZWNrUmVkdWNlckFyZyhyZWR1Y2VyQXJnKSAmJiB7Li4ucmVkdWNlckFyZywgZGVmYXVsdHNUbzogW119KSA6IHJlZHVjZXJBcmcpO1xuXG4gICAgY29uc3QgJCRjb2xsZWN0b3IgPSBjcmVhdGVSZWR1Y2VycyhvcHRpb25zLCB7aXRlbURlZmF1bHQsIHJlZHVjZXJ9KTtcblxuICAgIHJldHVybiBmdW5jdGlvbiByZWR1eENvbGxlY3RvcihzdGF0ZSA9IGNvbGxlY3Rpb25EZWZhdWx0LCBhY3Rpb24gPSB7fSwgLi4ucmVzdCkge1xuICAgICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgICBjYXNlIGFkZDpcbiAgICAgICAgICByZXR1cm4gJCRjb2xsZWN0b3IuYWRkKHN0YXRlLCBhY3Rpb24sIC4uLnJlc3QpO1xuICAgICAgICBjYXNlIHNvcnQ6XG4gICAgICAgICAgcmV0dXJuICQkY29sbGVjdG9yLnNvcnQoc3RhdGUsIGFjdGlvbiwgLi4ucmVzdCk7XG4gICAgICAgIGNhc2UgYWRkUmFuZ2U6XG4gICAgICAgICAgcmV0dXJuICQkY29sbGVjdG9yLmFkZFJhbmdlKHN0YXRlLCBhY3Rpb24sIC4uLnJlc3QpO1xuICAgICAgICBjYXNlIHJlbW92ZTpcbiAgICAgICAgICByZXR1cm4gJCRjb2xsZWN0b3IuZmlsdGVyKHN0YXRlLCBhY3Rpb24sIC4uLnJlc3QpO1xuICAgICAgICBjYXNlIG1vdmU6XG4gICAgICAgICAgcmV0dXJuICQkY29sbGVjdG9yLm1vdmUoc3RhdGUsIGFjdGlvbiwgLi4ucmVzdCk7XG4gICAgICAgIGNhc2UgaHlkcmF0ZTpcbiAgICAgICAgICByZXR1cm4gJCRjb2xsZWN0b3IuaHlkcmF0ZShzdGF0ZSwgYWN0aW9uLCAuLi5yZXN0KTtcbiAgICAgICAgY2FzZSBzd2FwOlxuICAgICAgICAgIHJldHVybiAkJGNvbGxlY3Rvci5zd2FwKHN0YXRlLCBhY3Rpb24sIC4uLnJlc3QpO1xuICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgIHJldHVybiAkJGNvbGxlY3Rvci51cGRhdGUoc3RhdGUsIGFjdGlvbiwgLi4ucmVzdCk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IGNvbmZpZ3VyZUNvbGxlY3RpZnkoKTtcbmV4cG9ydCB7Y29uZmlndXJlQ29sbGVjdGlmeSwgY2xhbXB9O1xuIl19

@@ -15,3 +15,3 @@ 'use strict';

var _defaultResolver = require('./default-resolver');
var _defaultMatcher = require('./default-matcher');

@@ -55,3 +55,3 @@ var _methodGenerators = require('./method-generators');

var matcherConfig = matcherArg === undefined ? _defaultResolver.defaultMatcher : _lodash2.default.partialRight(matcherArg, _defaultResolver.defaultMatcher);
var matcherConfig = matcherArg === undefined ? _defaultMatcher.defaultMatcher : _lodash2.default.partialRight(matcherArg, _defaultMatcher.defaultMatcher);

@@ -147,2 +147,2 @@ // Matcher Methods

exports.default = generateCollector;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb2xsZWN0b3ItcmVkdWNlcnMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQTs7OztBQUNBOztBQUVBOztBQUNBOztBQUVBOztBQUNBOztBQUNBOzs7O0FBQ0E7Ozs7OztBQUVBLFNBQVMsVUFBVCxDQUFxQixLQUFyQixFQUE0QjtBQUMxQixNQUFJLENBQUMsaUJBQUUsT0FBRixDQUFVLEtBQVYsQ0FBTCxFQUF1QjtBQUNyQix5Q0FBbUMsS0FBSyxTQUFMLENBQWUsS0FBZixDQUFuQztBQUNEO0FBQ0Y7O0FBRUQsU0FBUyxpQkFBVCxHQUErSztBQUFBLG1FQUEzRCxFQUEyRDs7QUFBQSxNQUExSSxVQUEwSSxRQUFuSixPQUFtSjtBQUFBLE1BQXJILFVBQXFILFFBQTlILE9BQThIO0FBQUEsTUFBOUYsWUFBOEYsUUFBekcsU0FBeUc7QUFBQSxNQUF4RSxTQUF3RSxRQUFoRixNQUFnRjs7QUFBQSxvRUFBSixFQUFJOztBQUFBLDRCQUF0RCxPQUFzRDtBQUFBLE1BQTdDLFdBQTZDLGlDQUEvQixpQkFBRSxRQUE2QjtBQUFBLE1BQW5CLFdBQW1CLFNBQW5CLFdBQW1COzs7QUFFN0ssTUFBTSxnQkFBZ0IsZUFBZSxTQUFmLHFDQUE0QyxpQkFBRSxZQUFGLENBQWUsVUFBZixrQ0FBbEU7OztBQUdBLE1BQU0sVUFBVSxpQkFBRSxJQUFGLENBQU8sYUFBUCxtQkFBaEI7QUFDQSxNQUFNLFlBQVksZ0JBQWdCLHlDQUFrQixPQUFsQixDQUFsQztBQUNBLE1BQU0sVUFBVSxjQUFjLHVDQUFnQixTQUFoQixDQUE5QjtBQUNBLE1BQU0sU0FBUyxhQUFhLGlCQUFFLE9BQTlCO0FBQ0EsTUFBTSxrQkFBa0IsNkJBQW9CLElBQXBCLENBQXlCLElBQXpCLEVBQStCLE9BQS9CLENBQXhCOzs7QUFJQSxXQUFTLFNBQVQsQ0FBb0IsS0FBcEIsRUFBMkIsTUFBM0IsRUFBbUM7QUFBQSw2QkFDVixvQ0FBa0IsTUFBbEIsQ0FEVTs7QUFBQSxRQUMx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NkIscUJBQTdCLENBRlQ7QUFJRCxHQWJNLEVBYUosRUFiSSxDQUFQO0FBZUQ7O2tCQUVjLGlCIiwiZmlsZSI6ImNvbGxlY3Rvci1yZWR1Y2Vycy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQge2NvbnRhaW5zLCBtYXRjaGVyV3JhcCwgbWFwSW5kZXhlcywgcmVzdWx0VHJhbnNmb3JtLCBzb3J0UmVzdWx0VHJhbnNmb3JtLCBhZGRXcmFwcGVyLCBzb3J0VHJhbnNmb3JtfSBmcm9tICcuL2xpYic7XG5cbmltcG9ydCB7ZGVmYXVsdE1hdGNoZXJ9IGZyb20gJy4vZGVmYXVsdC1yZXNvbHZlcic7XG5pbXBvcnQge2dlbmVyYXRlSW5kZXhlc09mLCBnZW5lcmF0ZUluZGV4b2Z9IGZyb20gJy4vbWV0aG9kLWdlbmVyYXRvcnMnO1xuXG5pbXBvcnQge25vcm1hbGl6ZVNvcnRBcmdzLCBub3JtYWxpemVJbmRleEFyZ3MsIG5vcm1hbGl6ZUFjdGlvbiBhcyBub3JtYWxpemVBY3Rpb25CYXNlfSBmcm9tICcuL25vcm1hbGl6ZXJzJztcbmltcG9ydCB7Z2V0SW5kZXhlc0Jhc2UsIGdldE1vdmVJbmRleGVzQmFzZX0gZnJvbSAnLi9tYXRjaC1tZXRob2RzJztcbmltcG9ydCBjb2xsZWN0b3JSZWR1Y2VyQmFzZSBmcm9tICcuL2NvbGxlY3Rvci1yZWR1Y2VyLWJhc2UnO1xuaW1wb3J0IHtzb3J0UmVkdWNlcnN9IGZyb20gJy4vY29uZmlnJztcblxuZnVuY3Rpb24gY2hlY2tTdGF0ZSAoc3RhdGUpIHtcbiAgaWYgKCFfLmlzQXJyYXkoc3RhdGUpKSB7XG4gICAgdGhyb3cgYFtSZWR1eCBDb2xsZWN0b3JdIC0gU3RhdGUgJHtKU09OLnN0cmluZ2lmeShzdGF0ZSl9IGlzIG5vdCBhbiBhcnJheS4gQWxsIGNvbGxlY3RvciByZWR1Y2VycyBtdXN0IGJlIHBhc3NlZCBhbiBhcnJheS5gO1xuICB9XG59XG5cbmZ1bmN0aW9uIGdlbmVyYXRlQ29sbGVjdG9yKHttYXRjaGVyOiBtYXRjaGVyQXJnLCBpbmRleE9mOiBpbmRleE9mQXJnLCBpbmRleGVzT2Y6IGluZGV4ZXNPZkFyZywgc29ydEJ5OiBzb3J0QnlBcmd9ID0ge30sIHtyZWR1Y2VyOiBpdGVtUmVkdWNlciA9IF8uaWRlbnRpdHksIGl0ZW1EZWZhdWx0fSA9IHt9KSB7XG5cbiAgY29uc3QgbWF0Y2hlckNvbmZpZyA9IG1hdGNoZXJBcmcgPT09IHVuZGVmaW5lZCA/IGRlZmF1bHRNYXRjaGVyIDogXy5wYXJ0aWFsUmlnaHQobWF0Y2hlckFyZywgZGVmYXVsdE1hdGNoZXIpO1xuXG4gIC8vIE1hdGNoZXIgTWV0aG9kc1xuICBjb25zdCBtYXRjaGVyID0gXy53cmFwKG1hdGNoZXJDb25maWcsIG1hdGNoZXJXcmFwKTtcbiAgY29uc3QgaW5kZXhlc09mID0gaW5kZXhlc09mQXJnIHx8IGdlbmVyYXRlSW5kZXhlc09mKG1hdGNoZXIpO1xuICBjb25zdCBpbmRleE9mID0gaW5kZXhPZkFyZyB8fCBnZW5lcmF0ZUluZGV4b2YoaW5kZXhlc09mKTtcbiAgY29uc3Qgc29ydEJ5ID0gc29ydEJ5QXJnIHx8IF8ub3JkZXJCeTtcbiAgY29uc3Qgbm9ybWFsaXplQWN0aW9uID0gbm9ybWFsaXplQWN0aW9uQmFzZS5iaW5kKHRoaXMsIGluZGV4T2YpO1xuXG5cbiAgLy8gQXJndW1lbnQgVHJhbnNmb3Jtc1xuICBmdW5jdGlvbiBzb3J0SWZBcmcgKHN0YXRlLCBhY3Rpb24pIHtcbiAgICBjb25zdCB7c29ydCwgb3JkZXJzfSA9IG5vcm1hbGl6ZVNvcnRBcmdzKGFjdGlvbik7XG4gICAgaWYgKHNvcnQgIT09IHVuZGVmaW5lZCB8fCBvcmRlcnMgIT09IHVuZGVmaW5lZCkge1xuICAgICAgY29uc3QgcmVzdWx0ID0gc29ydEJ5KHN0YXRlLFxuICAgICAgICBzb3J0VHJhbnNmb3JtKHNvcnQsIG9yZGVycyksXG4gICAgICAgIG9yZGVycyk7XG4gICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH1cbiAgICByZXR1cm4gc3RhdGU7XG4gIH1cblxuICBmdW5jdGlvbiBhcmdUcmFuc2Zvcm0gKHJlc3VsdCwgYWN0aW9uKSB7XG4gICAgcmV0dXJuIF8ocmVzdWx0KVxuICAgICAgLnRocnUoXy5wYXJ0aWFsUmlnaHQobWFwSW5kZXhlcywgYWN0aW9uKSlcbiAgICAgIC50aHJ1KF8ucGFydGlhbFJpZ2h0KHNvcnRJZkFyZywgYWN0aW9uKSlcbiAgICAgIC52YWx1ZSgpO1xuICB9XG5cbiAgLy8gUmVkdWNlciBUcmFuc2Zvcm1zXG4gIGZ1bmN0aW9uIGNvbGxlY3Rpb25SZWR1Y2VyV3JhcCAocmVkdWNlciwgc3RhdGUsIGFjdGlvbkFyZ3MsIC4uLmFyZ3MpIHtcbiAgICBjaGVja1N0YXRlKHN0YXRlKTtcbiAgICBjb25zdCBzdGF0ZUFyZyA9IGFyZ1RyYW5zZm9ybShzdGF0ZSwgYWN0aW9uQXJncyk7XG4gICAgY29uc3QgYWN0aW9uID0gbm9ybWFsaXplQWN0aW9uKHN0YXRlQXJnLCBhY3Rpb25BcmdzKTtcbiAgICBjb25zdCBpbmRleGVzID0gbm9ybWFsaXplSW5kZXhBcmdzKGFjdGlvbkFyZ3MpO1xuICAgIGNvbnN0IHJlc3VsdCA9IHJlZHVjZXIuY2FsbCh0aGlzLCBzdGF0ZUFyZywgey4uLmFjdGlvbiwgLi4uaW5kZXhlc30sIC4uLmFyZ3MpO1xuICAgIHJldHVybiByZXN1bHRUcmFuc2Zvcm0ocmVzdWx0LCBhY3Rpb24pO1xuICB9XG5cbiAgZnVuY3Rpb24gc29ydFJlZHVjZXJXcmFwIChyZWR1Y2VyLCBzdGF0ZSwgYWN0aW9uLCAuLi5hcmdzKSB7XG4gICAgY2hlY2tTdGF0ZShzdGF0ZSk7XG4gICAgY29uc3Qgc3RhdGVBcmcgPSBhcmdUcmFuc2Zvcm0oc3RhdGUsIGFjdGlvbik7XG4gICAgY29uc3QgcmVzdWx0ID0gcmVkdWNlci5jYWxsKHRoaXMsIHN0YXRlQXJnLCBhY3Rpb24sIC4uLmFyZ3MpO1xuICAgIHJldHVybiBzb3J0UmVzdWx0VHJhbnNmb3JtKHJlc3VsdCwgYWN0aW9uKTtcbiAgfVxuXG4gIGZ1bmN0aW9uIGl0ZW1SZWR1Y2VyV3JhcChmbiwge2l0ZW0sIGluZGV4fSwgLi4uYXJncykge1xuICAgIGNvbnN0IHJlc3VsdCA9IGZuKGl0ZW0sIC4uLmFyZ3MpO1xuICAgIHJldHVybiB7aXRlbTogcmVzdWx0LCBpbmRleH07XG4gIH1cblxuXG5cbiAgLy8gTWF0Y2hlciBtZXRob2RzXG4gIGNvbnN0IGdldEluZGV4ZXMgPSBnZXRJbmRleGVzQmFzZS5iaW5kKHRoaXMsIGluZGV4ZXNPZik7XG4gIGNvbnN0IGdldE1vdmVJbmRleGVzID0gZ2V0TW92ZUluZGV4ZXNCYXNlLmJpbmQodGhpcywgaW5kZXhlc09mKTtcblxuXG4gIGNvbnN0IGNvbGxlY3Rvck9iamVjdCA9IGNvbGxlY3RvclJlZHVjZXJCYXNlKHtcbiAgICBpdGVtRGVmYXVsdCxcbiAgICBtYXRjaGVyLFxuICAgIGdldEluZGV4ZXMsXG4gICAgZ2V0TW92ZUluZGV4ZXMsXG4gICAgYWRkV3JhcHBlcixcbiAgICByZWR1Y2VyOiBfLndyYXAoaXRlbVJlZHVjZXIsIGl0ZW1SZWR1Y2VyV3JhcCksXG4gICAgc29ydEJ5XG4gIH0pO1xuXG4gIHJldHVybiBPYmplY3Qua2V5cyhjb2xsZWN0b3JPYmplY3QpLnJlZHVjZSgocG9pbnRlciwga2V5KSA9PiB7XG5cbiAgICBpZiAoY29udGFpbnMoc29ydFJlZHVjZXJzLCBrZXkpKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5wb2ludGVyLFxuICAgICAgICBba2V5XTogXy53cmFwKGNvbGxlY3Rvck9iamVjdFtrZXldLCBzb3J0UmVkdWNlcldyYXApXG4gICAgICB9O1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5wb2ludGVyLFxuICAgICAgW2tleV06IF8ud3JhcChjb2xsZWN0b3JPYmplY3Rba2V5XSwgY29sbGVjdGlvblJlZHVjZXJXcmFwKVxuICAgIH07XG4gIH0sIHt9KTtcblxufVxuXG5leHBvcnQgZGVmYXVsdCBnZW5lcmF0ZUNvbGxlY3RvcjtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb2xsZWN0b3ItcmVkdWNlcnMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQTs7OztBQUNBOztBQUVBOztBQUNBOztBQUVBOztBQUNBOztBQUNBOzs7O0FBQ0E7Ozs7OztBQUVBLFNBQVMsVUFBVCxDQUFxQixLQUFyQixFQUE0QjtBQUMxQixNQUFJLENBQUMsaUJBQUUsT0FBRixDQUFVLEtBQVYsQ0FBTCxFQUF1QjtBQUNyQix5Q0FBbUMsS0FBSyxTQUFMLENBQWUsS0FBZixDQUFuQztBQUNEO0FBQ0Y7O0FBRUQsU0FBUyxpQkFBVCxHQUErSztBQUFBLG1FQUEzRCxFQUEyRDs7QUFBQSxNQUExSSxVQUEwSSxRQUFuSixPQUFtSjtBQUFBLE1BQXJILFVBQXFILFFBQTlILE9BQThIO0FBQUEsTUFBOUYsWUFBOEYsUUFBekcsU0FBeUc7QUFBQSxNQUF4RSxTQUF3RSxRQUFoRixNQUFnRjs7QUFBQSxvRUFBSixFQUFJOztBQUFBLDRCQUF0RCxPQUFzRDtBQUFBLE1BQTdDLFdBQTZDLGlDQUEvQixpQkFBRSxRQUE2QjtBQUFBLE1BQW5CLFdBQW1CLFNBQW5CLFdBQW1COzs7QUFFN0ssTUFBTSxnQkFBZ0IsZUFBZSxTQUFmLG9DQUE0QyxpQkFBRSxZQUFGLENBQWUsVUFBZixpQ0FBbEU7OztBQUdBLE1BQU0sVUFBVSxpQkFBRSxJQUFGLENBQU8sYUFBUCxtQkFBaEI7QUFDQSxNQUFNLFlBQVksZ0JBQWdCLHlDQUFrQixPQUFsQixDQUFsQztBQUNBLE1BQU0sVUFBVSxjQUFjLHVDQUFnQixTQUFoQixDQUE5QjtBQUNBLE1BQU0sU0FBUyxhQUFhLGlCQUFFLE9BQTlCO0FBQ0EsTUFBTSxrQkFBa0IsNkJBQW9CLElBQXBCLENBQXlCLElBQXpCLEVBQStCLE9BQS9CLENBQXhCOzs7QUFJQSxXQUFTLFNBQVQsQ0FBb0IsS0FBcEIsRUFBMkIsTUFBM0IsRUFBbUM7QUFBQSw2QkFDVixvQ0FBa0IsTUFBbEIsQ0FEVTs7QUFBQSxRQUMx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NkIscUJBQTdCLENBRlQ7QUFJRCxHQWJNLEVBYUosRUFiSSxDQUFQO0FBZUQ7O2tCQUVjLGlCIiwiZmlsZSI6ImNvbGxlY3Rvci1yZWR1Y2Vycy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQge2NvbnRhaW5zLCBtYXRjaGVyV3JhcCwgbWFwSW5kZXhlcywgcmVzdWx0VHJhbnNmb3JtLCBzb3J0UmVzdWx0VHJhbnNmb3JtLCBhZGRXcmFwcGVyLCBzb3J0VHJhbnNmb3JtfSBmcm9tICcuL2xpYic7XG5cbmltcG9ydCB7ZGVmYXVsdE1hdGNoZXJ9IGZyb20gJy4vZGVmYXVsdC1tYXRjaGVyJztcbmltcG9ydCB7Z2VuZXJhdGVJbmRleGVzT2YsIGdlbmVyYXRlSW5kZXhvZn0gZnJvbSAnLi9tZXRob2QtZ2VuZXJhdG9ycyc7XG5cbmltcG9ydCB7bm9ybWFsaXplU29ydEFyZ3MsIG5vcm1hbGl6ZUluZGV4QXJncywgbm9ybWFsaXplQWN0aW9uIGFzIG5vcm1hbGl6ZUFjdGlvbkJhc2V9IGZyb20gJy4vbm9ybWFsaXplcnMnO1xuaW1wb3J0IHtnZXRJbmRleGVzQmFzZSwgZ2V0TW92ZUluZGV4ZXNCYXNlfSBmcm9tICcuL21hdGNoLW1ldGhvZHMnO1xuaW1wb3J0IGNvbGxlY3RvclJlZHVjZXJCYXNlIGZyb20gJy4vY29sbGVjdG9yLXJlZHVjZXItYmFzZSc7XG5pbXBvcnQge3NvcnRSZWR1Y2Vyc30gZnJvbSAnLi9jb25maWcnO1xuXG5mdW5jdGlvbiBjaGVja1N0YXRlIChzdGF0ZSkge1xuICBpZiAoIV8uaXNBcnJheShzdGF0ZSkpIHtcbiAgICB0aHJvdyBgW1JlZHV4IENvbGxlY3Rvcl0gLSBTdGF0ZSAke0pTT04uc3RyaW5naWZ5KHN0YXRlKX0gaXMgbm90IGFuIGFycmF5LiBBbGwgY29sbGVjdG9yIHJlZHVjZXJzIG11c3QgYmUgcGFzc2VkIGFuIGFycmF5LmA7XG4gIH1cbn1cblxuZnVuY3Rpb24gZ2VuZXJhdGVDb2xsZWN0b3Ioe21hdGNoZXI6IG1hdGNoZXJBcmcsIGluZGV4T2Y6IGluZGV4T2ZBcmcsIGluZGV4ZXNPZjogaW5kZXhlc09mQXJnLCBzb3J0Qnk6IHNvcnRCeUFyZ30gPSB7fSwge3JlZHVjZXI6IGl0ZW1SZWR1Y2VyID0gXy5pZGVudGl0eSwgaXRlbURlZmF1bHR9ID0ge30pIHtcblxuICBjb25zdCBtYXRjaGVyQ29uZmlnID0gbWF0Y2hlckFyZyA9PT0gdW5kZWZpbmVkID8gZGVmYXVsdE1hdGNoZXIgOiBfLnBhcnRpYWxSaWdodChtYXRjaGVyQXJnLCBkZWZhdWx0TWF0Y2hlcik7XG5cbiAgLy8gTWF0Y2hlciBNZXRob2RzXG4gIGNvbnN0IG1hdGNoZXIgPSBfLndyYXAobWF0Y2hlckNvbmZpZywgbWF0Y2hlcldyYXApO1xuICBjb25zdCBpbmRleGVzT2YgPSBpbmRleGVzT2ZBcmcgfHwgZ2VuZXJhdGVJbmRleGVzT2YobWF0Y2hlcik7XG4gIGNvbnN0IGluZGV4T2YgPSBpbmRleE9mQXJnIHx8IGdlbmVyYXRlSW5kZXhvZihpbmRleGVzT2YpO1xuICBjb25zdCBzb3J0QnkgPSBzb3J0QnlBcmcgfHwgXy5vcmRlckJ5O1xuICBjb25zdCBub3JtYWxpemVBY3Rpb24gPSBub3JtYWxpemVBY3Rpb25CYXNlLmJpbmQodGhpcywgaW5kZXhPZik7XG5cblxuICAvLyBBcmd1bWVudCBUcmFuc2Zvcm1zXG4gIGZ1bmN0aW9uIHNvcnRJZkFyZyAoc3RhdGUsIGFjdGlvbikge1xuICAgIGNvbnN0IHtzb3J0LCBvcmRlcnN9ID0gbm9ybWFsaXplU29ydEFyZ3MoYWN0aW9uKTtcbiAgICBpZiAoc29ydCAhPT0gdW5kZWZpbmVkIHx8IG9yZGVycyAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBjb25zdCByZXN1bHQgPSBzb3J0Qnkoc3RhdGUsXG4gICAgICAgIHNvcnRUcmFuc2Zvcm0oc29ydCwgb3JkZXJzKSxcbiAgICAgICAgb3JkZXJzKTtcbiAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgfVxuICAgIHJldHVybiBzdGF0ZTtcbiAgfVxuXG4gIGZ1bmN0aW9uIGFyZ1RyYW5zZm9ybSAocmVzdWx0LCBhY3Rpb24pIHtcbiAgICByZXR1cm4gXyhyZXN1bHQpXG4gICAgICAudGhydShfLnBhcnRpYWxSaWdodChtYXBJbmRleGVzLCBhY3Rpb24pKVxuICAgICAgLnRocnUoXy5wYXJ0aWFsUmlnaHQoc29ydElmQXJnLCBhY3Rpb24pKVxuICAgICAgLnZhbHVlKCk7XG4gIH1cblxuICAvLyBSZWR1Y2VyIFRyYW5zZm9ybXNcbiAgZnVuY3Rpb24gY29sbGVjdGlvblJlZHVjZXJXcmFwIChyZWR1Y2VyLCBzdGF0ZSwgYWN0aW9uQXJncywgLi4uYXJncykge1xuICAgIGNoZWNrU3RhdGUoc3RhdGUpO1xuICAgIGNvbnN0IHN0YXRlQXJnID0gYXJnVHJhbnNmb3JtKHN0YXRlLCBhY3Rpb25BcmdzKTtcbiAgICBjb25zdCBhY3Rpb24gPSBub3JtYWxpemVBY3Rpb24oc3RhdGVBcmcsIGFjdGlvbkFyZ3MpO1xuICAgIGNvbnN0IGluZGV4ZXMgPSBub3JtYWxpemVJbmRleEFyZ3MoYWN0aW9uQXJncyk7XG4gICAgY29uc3QgcmVzdWx0ID0gcmVkdWNlci5jYWxsKHRoaXMsIHN0YXRlQXJnLCB7Li4uYWN0aW9uLCAuLi5pbmRleGVzfSwgLi4uYXJncyk7XG4gICAgcmV0dXJuIHJlc3VsdFRyYW5zZm9ybShyZXN1bHQsIGFjdGlvbik7XG4gIH1cblxuICBmdW5jdGlvbiBzb3J0UmVkdWNlcldyYXAgKHJlZHVjZXIsIHN0YXRlLCBhY3Rpb24sIC4uLmFyZ3MpIHtcbiAgICBjaGVja1N0YXRlKHN0YXRlKTtcbiAgICBjb25zdCBzdGF0ZUFyZyA9IGFyZ1RyYW5zZm9ybShzdGF0ZSwgYWN0aW9uKTtcbiAgICBjb25zdCByZXN1bHQgPSByZWR1Y2VyLmNhbGwodGhpcywgc3RhdGVBcmcsIGFjdGlvbiwgLi4uYXJncyk7XG4gICAgcmV0dXJuIHNvcnRSZXN1bHRUcmFuc2Zvcm0ocmVzdWx0LCBhY3Rpb24pO1xuICB9XG5cbiAgZnVuY3Rpb24gaXRlbVJlZHVjZXJXcmFwKGZuLCB7aXRlbSwgaW5kZXh9LCAuLi5hcmdzKSB7XG4gICAgY29uc3QgcmVzdWx0ID0gZm4oaXRlbSwgLi4uYXJncyk7XG4gICAgcmV0dXJuIHtpdGVtOiByZXN1bHQsIGluZGV4fTtcbiAgfVxuXG5cblxuICAvLyBNYXRjaGVyIG1ldGhvZHNcbiAgY29uc3QgZ2V0SW5kZXhlcyA9IGdldEluZGV4ZXNCYXNlLmJpbmQodGhpcywgaW5kZXhlc09mKTtcbiAgY29uc3QgZ2V0TW92ZUluZGV4ZXMgPSBnZXRNb3ZlSW5kZXhlc0Jhc2UuYmluZCh0aGlzLCBpbmRleGVzT2YpO1xuXG5cbiAgY29uc3QgY29sbGVjdG9yT2JqZWN0ID0gY29sbGVjdG9yUmVkdWNlckJhc2Uoe1xuICAgIGl0ZW1EZWZhdWx0LFxuICAgIG1hdGNoZXIsXG4gICAgZ2V0SW5kZXhlcyxcbiAgICBnZXRNb3ZlSW5kZXhlcyxcbiAgICBhZGRXcmFwcGVyLFxuICAgIHJlZHVjZXI6IF8ud3JhcChpdGVtUmVkdWNlciwgaXRlbVJlZHVjZXJXcmFwKSxcbiAgICBzb3J0QnlcbiAgfSk7XG5cbiAgcmV0dXJuIE9iamVjdC5rZXlzKGNvbGxlY3Rvck9iamVjdCkucmVkdWNlKChwb2ludGVyLCBrZXkpID0+IHtcblxuICAgIGlmIChjb250YWlucyhzb3J0UmVkdWNlcnMsIGtleSkpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIC4uLnBvaW50ZXIsXG4gICAgICAgIFtrZXldOiBfLndyYXAoY29sbGVjdG9yT2JqZWN0W2tleV0sIHNvcnRSZWR1Y2VyV3JhcClcbiAgICAgIH07XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnBvaW50ZXIsXG4gICAgICBba2V5XTogXy53cmFwKGNvbGxlY3Rvck9iamVjdFtrZXldLCBjb2xsZWN0aW9uUmVkdWNlcldyYXApXG4gICAgfTtcbiAgfSwge30pO1xuXG59XG5cbmV4cG9ydCBkZWZhdWx0IGdlbmVyYXRlQ29sbGVjdG9yO1xuIl19

@@ -120,3 +120,3 @@ 'use strict';

toLimit = end - start;
toLimit = end + 1 - start;
toSkip = start;

@@ -136,7 +136,12 @@ } else if (after !== undefined) {

function normalizeFrom(from) {
return _lodash2.default.isNumber(from) ? { index: from } : _lodash2.default.isArray(from) ? from.length === 2 ? { range: from } : { indexes: from } : _lodash2.default.isFunction(from) ? { query: from } : from;
return _lodash2.default.isNumber(from) ? { index: from } : _lodash2.default.isArray(from) ? { indexes: from } : _lodash2.default.isFunction(from) ? { query: from } : from;
}
function normalizeTo(to) {
return _lodash2.default.isNumber(to) ? { index: to } : _lodash2.default.isArray(to) ? { range: to } : to;
if (_lodash2.default.isArray(to)) {
throw '[Redux Collector] `to` must be a single index. You passed: ' + to;
}
return _lodash2.default.isNumber(to) ? { index: to } : _lodash2.default.isFunction(to) ? { query: to } : to;
}

@@ -150,2 +155,2 @@

exports.normalizeTo = normalizeTo;
//# sourceMappingURL=data:application/json;base64,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QTZCO0FBQzNCLFNBQU8saUJBQUUsUUFBRixDQUFXLElBQVgsSUFDSCxFQUFDLE9BQU8sSUFBUixFQURHLEdBRUgsaUJBQUUsT0FBRixDQUFVLElBQVYsSUFDQSxLQUFLLE1BQUwsS0FBZ0IsQ0FBaEIsR0FBb0IsRUFBQyxPQUFPLElBQVIsRUFBcEIsR0FBb0MsRUFBQyxTQUFTLElBQVYsRUFEcEMsR0FFQSxpQkFBRSxVQUFGLENBQWEsSUFBYixJQUFxQixFQUFDLE9BQU8sSUFBUixFQUFyQixHQUFxQyxJQUp6QztBQUtEOztBQUVELFNBQVMsV0FBVCxDQUFxQixFQUFyQixFQUF5QjtBQUN2QixTQUFPLGlCQUFFLFFBQUYsQ0FBVyxFQUFYLElBQ0gsRUFBQyxPQUFPLEVBQVIsRUFERyxHQUVILGlCQUFFLE9BQUYsQ0FBVSxFQUFWLElBQ0EsRUFBQyxPQUFPLEVBQVIsRUFEQSxHQUVBLEVBSko7QUFLRDs7UUFHTyxjLEdBQUEsYztRQUFnQixpQixHQUFBLGlCO1FBQW1CLGtCLEdBQUEsa0I7UUFBb0IsZSxHQUFBLGU7UUFBaUIsYSxHQUFBLGE7UUFBZSxXLEdBQUEsVyIsImZpbGUiOiJub3JtYWxpemVycy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5cbmltcG9ydCB7c29ydEFsaWFzZXN9IGZyb20gJy4vY29uZmlnJztcbmltcG9ydCB7Y29udGFpbnMsIGNsYW1wfSBmcm9tICcuL2xpYic7XG5cbmZ1bmN0aW9uIG5vcm1hbGl6ZU9yZGVyKG9yZGVyQXJnKSB7XG4gIGNvbnN0IG9yZGVyID0gXy5pc1N0cmluZyhvcmRlckFyZylcbiAgICA/IG9yZGVyQXJnLnRvTG93ZXJDYXNlKClcbiAgICA6IG9yZGVyQXJnO1xuICBpZiAoY29udGFpbnMoc29ydEFsaWFzZXMuZGVzYywgb3JkZXJBcmcpKSB7XG4gICAgcmV0dXJuICdkZXNjJztcbiAgfVxuICBpZiAoY29udGFpbnMoc29ydEFsaWFzZXMuYXNjLCBvcmRlckFyZykpIHtcbiAgICByZXR1cm4gJ2FzYyc7XG4gIH1cbiAgcmV0dXJuIG9yZGVyO1xufVxuXG5mdW5jdGlvbiBub3JtYWxpemVTb3J0QXJncyh7c29ydCwgb3JkZXJzLCBvcmRlciwgLi4ucmVzdH0pIHtcblxuICBpZiAoc29ydCA9PT0gdW5kZWZpbmVkICYmIG9yZGVycyA9PT0gdW5kZWZpbmVkICYmIG9yZGVyID09PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gcmVzdDtcbiAgfVxuXG4gIGlmIChfLmlzUGxhaW5PYmplY3Qoc29ydCkpIHtcbiAgICBjb25zdCBbc29ydHMsIG9yZGVyc10gPSBPYmplY3Qua2V5cyhzb3J0KS5yZWR1Y2UoKFtzb3J0cywgb3JkZXJzXSwga2V5KSA9PiB7XG4gICAgICBjb25zdCBvcmRlckFyZyA9IHNvcnRba2V5XTtcbiAgICAgIHJldHVybiBbXG4gICAgICAgIFsuLi5zb3J0cywga2V5XSxcbiAgICAgICAgWy4uLm9yZGVycywgbm9ybWFsaXplT3JkZXIob3JkZXJBcmcpXVxuICAgICAgXTtcbiAgICB9LCBbW10sIFtdXSk7XG4gICAgcmV0dXJuIHtzb3J0OiBzb3J0cywgb3JkZXJzOiBvcmRlcnMsIC4uLnJlc3R9O1xuICB9XG5cbiAgY29uc3QgdG9PcmRlciA9IG9yZGVycyA9PT0gdW5kZWZpbmVkXG4gICAgPyBbb3JkZXJdXG4gICAgOiBvcmRlcnM7XG4gIHJldHVybiB7c29ydCwgb3JkZXJzOiB0b09yZGVyLm1hcChub3JtYWxpemVPcmRlciksIC4uLnJlc3R9O1xufVxuXG5mdW5jdGlvbiBpc05vdFVuZGVmaW5lZCh2YWwpIHtcbiAgcmV0dXJuIHZhbCAhPT0gdW5kZWZpbmVkO1xufVxuXG5mdW5jdGlvbiBub3JtYWxpemVJbmRleEFyZ3Moe2luZGV4ZXMgPSBbXSwgaW5kZXgsIHJhbmdlcyA9IFtdLCByYW5nZSwgcXVlcmllcyA9IFtdLCBxdWVyeSwgLi4ucmVzdH0pIHtcblxuICByZXR1cm4ge1xuICAgIGluZGV4ZXM6IFtpbmRleCwgLi4uaW5kZXhlc10uZmlsdGVyKGlzTm90VW5kZWZpbmVkKSxcbiAgICBxdWVyaWVzOiBbcXVlcnksIC4uLnF1ZXJpZXNdLmZpbHRlcihpc05vdFVuZGVmaW5lZCksXG4gICAgcmFuZ2VzOiBbcmFuZ2UsIC4uLnJhbmdlc10uZmlsdGVyKGlzTm90VW5kZWZpbmVkKSxcbiAgICAuLi5yZXN0XG4gIH07XG5cbn1cblxuZnVuY3Rpb24gbm9ybWFsaXplQWN0aW9uKGluZGV4T2YsIHN0YXRlLCBhY3Rpb24pIHtcbiAgY29uc3Qge3NraXAsIGxpbWl0ID0gc3RhdGUubGVuZ3RoLCBpbmRleGVzLCBpbmRleCwgYWZ0ZXIsIHJhbmdlLCAuLi5yZXN0fSA9IGFjdGlvbjtcbiAgbGV0IHRvU2tpcCA9IHNraXA7XG4gIGxldCB0b0xpbWl0ID0gbGltaXQ7XG5cbiAgaWYgKGluZGV4ICE9PSB1bmRlZmluZWQpIHtcbiAgICB0b0xpbWl0ID0gMTtcbiAgICB0b1NraXAgPSBjbGFtcChzdGF0ZS5sZW5ndGgsIGluZGV4KTtcbiAgfSBlbHNlIGlmIChyYW5nZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgY29uc3QgW3N0YXJ0LCBlbmRdID0gcmFuZ2UubWFwKGNsYW1wLmJpbmQodW5kZWZpbmVkLCBzdGF0ZS5sZW5ndGgpKTtcbiAgICB0b0xpbWl0ID0gZW5kIC0gc3RhcnQ7XG4gICAgdG9Ta2lwID0gc3RhcnQ7XG4gIH0gZWxzZSBpZiAoYWZ0ZXIgIT09IHVuZGVmaW5lZCkge1xuICAgIHRvU2tpcCA9IGluZGV4T2Yoc3RhdGUsIGFmdGVyLCBza2lwKSArIDE7XG4gIH1cbiAgaWYgKGluZGV4ZXMgIT09IHVuZGVmaW5lZCkge1xuICAgIGNvbnN0IHF1ZXJ5ID0gcmVzdC5xdWVyeSA9PT0gdW5kZWZpbmVkID8gW10gOiBbcmVzdC5xdWVyeV07XG4gICAgcmVzdC5xdWVyeSA9IFsuLi5xdWVyeSwgKGl0ZW0sIGluZGV4KSA9PiBjb250YWlucyhpbmRleGVzLCBpbmRleCldO1xuICB9XG4gIHJldHVybiB7c2tpcDogdG9Ta2lwLCBpbmRleGVzLCBsaW1pdDogdG9MaW1pdCwgLi4ucmVzdH07XG59XG5cbmZ1bmN0aW9uIG5vcm1hbGl6ZUZyb20oZnJvbSkge1xuICByZXR1cm4gXy5pc051bWJlcihmcm9tKVxuICAgID8ge2luZGV4OiBmcm9tfVxuICAgIDogXy5pc0FycmF5KGZyb20pXG4gICAgPyBmcm9tLmxlbmd0aCA9PT0gMiA/IHtyYW5nZTogZnJvbX0gOiB7aW5kZXhlczogZnJvbX1cbiAgICA6IF8uaXNGdW5jdGlvbihmcm9tKSA/IHtxdWVyeTogZnJvbX0gOiBmcm9tO1xufVxuXG5mdW5jdGlvbiBub3JtYWxpemVUbyh0bykge1xuICByZXR1cm4gXy5pc051bWJlcih0bylcbiAgICA/IHtpbmRleDogdG99XG4gICAgOiBfLmlzQXJyYXkodG8pXG4gICAgPyB7cmFuZ2U6IHRvfVxuICAgIDogdG87XG59XG5cblxuZXhwb3J0IHtub3JtYWxpemVPcmRlciwgbm9ybWFsaXplU29ydEFyZ3MsIG5vcm1hbGl6ZUluZGV4QXJncywgbm9ybWFsaXplQWN0aW9uLCBub3JtYWxpemVGcm9tLCBub3JtYWxpemVUb307XG4iXX0=
//# sourceMappingURL=data:application/json;base64,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QixJQUF2QixFQUE2QjtBQUMzQixTQUFPLGlCQUFFLFFBQUYsQ0FBVyxJQUFYLElBQ0gsRUFBQyxPQUFPLElBQVIsRUFERyxHQUVILGlCQUFFLE9BQUYsQ0FBVSxJQUFWLElBQ0UsRUFBQyxTQUFTLElBQVYsRUFERixHQUVFLGlCQUFFLFVBQUYsQ0FBYSxJQUFiLElBQ0UsRUFBQyxPQUFPLElBQVIsRUFERixHQUVFLElBTlI7QUFPRDs7QUFFRCxTQUFTLFdBQVQsQ0FBcUIsRUFBckIsRUFBeUI7O0FBRXZCLE1BQUksaUJBQUUsT0FBRixDQUFVLEVBQVYsQ0FBSixFQUFtQjtBQUNqQixVQUFNLGdFQUFnRSxFQUF0RTtBQUNEOztBQUVELFNBQU8saUJBQUUsUUFBRixDQUFXLEVBQVgsSUFDSCxFQUFDLE9BQU8sRUFBUixFQURHLEdBRUgsaUJBQUUsVUFBRixDQUFhLEVBQWIsSUFDRSxFQUFDLE9BQU8sRUFBUixFQURGLEdBRUUsRUFKTjtBQUtEOztRQUdPLGMsR0FBQSxjO1FBQWdCLGlCLEdBQUEsaUI7UUFBbUIsa0IsR0FBQSxrQjtRQUFvQixlLEdBQUEsZTtRQUFpQixhLEdBQUEsYTtRQUFlLFcsR0FBQSxXIiwiZmlsZSI6Im5vcm1hbGl6ZXJzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcblxuaW1wb3J0IHtzb3J0QWxpYXNlc30gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHtjb250YWlucywgY2xhbXB9IGZyb20gJy4vbGliJztcblxuZnVuY3Rpb24gbm9ybWFsaXplT3JkZXIob3JkZXJBcmcpIHtcbiAgY29uc3Qgb3JkZXIgPSBfLmlzU3RyaW5nKG9yZGVyQXJnKVxuICAgID8gb3JkZXJBcmcudG9Mb3dlckNhc2UoKVxuICAgIDogb3JkZXJBcmc7XG4gIGlmIChjb250YWlucyhzb3J0QWxpYXNlcy5kZXNjLCBvcmRlckFyZykpIHtcbiAgICByZXR1cm4gJ2Rlc2MnO1xuICB9XG4gIGlmIChjb250YWlucyhzb3J0QWxpYXNlcy5hc2MsIG9yZGVyQXJnKSkge1xuICAgIHJldHVybiAnYXNjJztcbiAgfVxuICByZXR1cm4gb3JkZXI7XG59XG5cbmZ1bmN0aW9uIG5vcm1hbGl6ZVNvcnRBcmdzKHtzb3J0LCBvcmRlcnMsIG9yZGVyLCAuLi5yZXN0fSkge1xuXG4gIGlmIChzb3J0ID09PSB1bmRlZmluZWQgJiYgb3JkZXJzID09PSB1bmRlZmluZWQgJiYgb3JkZXIgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiByZXN0O1xuICB9XG5cbiAgaWYgKF8uaXNQbGFpbk9iamVjdChzb3J0KSkge1xuICAgIGNvbnN0IFtzb3J0cywgb3JkZXJzXSA9IE9iamVjdC5rZXlzKHNvcnQpLnJlZHVjZSgoW3NvcnRzLCBvcmRlcnNdLCBrZXkpID0+IHtcbiAgICAgIGNvbnN0IG9yZGVyQXJnID0gc29ydFtrZXldO1xuICAgICAgcmV0dXJuIFtcbiAgICAgICAgWy4uLnNvcnRzLCBrZXldLFxuICAgICAgICBbLi4ub3JkZXJzLCBub3JtYWxpemVPcmRlcihvcmRlckFyZyldXG4gICAgICBdO1xuICAgIH0sIFtbXSwgW11dKTtcbiAgICByZXR1cm4ge3NvcnQ6IHNvcnRzLCBvcmRlcnM6IG9yZGVycywgLi4ucmVzdH07XG4gIH1cblxuICBjb25zdCB0b09yZGVyID0gb3JkZXJzID09PSB1bmRlZmluZWRcbiAgICA/IFtvcmRlcl1cbiAgICA6IG9yZGVycztcbiAgcmV0dXJuIHtzb3J0LCBvcmRlcnM6IHRvT3JkZXIubWFwKG5vcm1hbGl6ZU9yZGVyKSwgLi4ucmVzdH07XG59XG5cbmZ1bmN0aW9uIGlzTm90VW5kZWZpbmVkKHZhbCkge1xuICByZXR1cm4gdmFsICE9PSB1bmRlZmluZWQ7XG59XG5cbmZ1bmN0aW9uIG5vcm1hbGl6ZUluZGV4QXJncyh7aW5kZXhlcyA9IFtdLCBpbmRleCwgcmFuZ2VzID0gW10sIHJhbmdlLCBxdWVyaWVzID0gW10sIHF1ZXJ5LCAuLi5yZXN0fSkge1xuXG4gIHJldHVybiB7XG4gICAgaW5kZXhlczogW2luZGV4LCAuLi5pbmRleGVzXS5maWx0ZXIoaXNOb3RVbmRlZmluZWQpLFxuICAgIHF1ZXJpZXM6IFtxdWVyeSwgLi4ucXVlcmllc10uZmlsdGVyKGlzTm90VW5kZWZpbmVkKSxcbiAgICByYW5nZXM6IFtyYW5nZSwgLi4ucmFuZ2VzXS5maWx0ZXIoaXNOb3RVbmRlZmluZWQpLFxuICAgIC4uLnJlc3RcbiAgfTtcblxufVxuXG5mdW5jdGlvbiBub3JtYWxpemVBY3Rpb24oaW5kZXhPZiwgc3RhdGUsIGFjdGlvbikge1xuICBjb25zdCB7c2tpcCwgbGltaXQgPSBzdGF0ZS5sZW5ndGgsIGluZGV4ZXMsIGluZGV4LCBhZnRlciwgcmFuZ2UsIC4uLnJlc3R9ID0gYWN0aW9uO1xuICBsZXQgdG9Ta2lwID0gc2tpcDtcbiAgbGV0IHRvTGltaXQgPSBsaW1pdDtcblxuICBpZiAoaW5kZXggIT09IHVuZGVmaW5lZCkge1xuICAgIHRvTGltaXQgPSAxO1xuICAgIHRvU2tpcCA9IGNsYW1wKHN0YXRlLmxlbmd0aCwgaW5kZXgpO1xuICB9IGVsc2UgaWYgKHJhbmdlICE9PSB1bmRlZmluZWQpIHtcbiAgICBjb25zdCBbc3RhcnQsIGVuZF0gPSByYW5nZS5tYXAoY2xhbXAuYmluZCh1bmRlZmluZWQsIHN0YXRlLmxlbmd0aCkpO1xuICAgIHRvTGltaXQgPSAoZW5kICsgMSkgLSBzdGFydDtcbiAgICB0b1NraXAgPSBzdGFydDtcbiAgfSBlbHNlIGlmIChhZnRlciAhPT0gdW5kZWZpbmVkKSB7XG4gICAgdG9Ta2lwID0gaW5kZXhPZihzdGF0ZSwgYWZ0ZXIsIHNraXApICsgMTtcbiAgfVxuICBpZiAoaW5kZXhlcyAhPT0gdW5kZWZpbmVkKSB7XG4gICAgY29uc3QgcXVlcnkgPSByZXN0LnF1ZXJ5ID09PSB1bmRlZmluZWQgPyBbXSA6IFtyZXN0LnF1ZXJ5XTtcbiAgICByZXN0LnF1ZXJ5ID0gWy4uLnF1ZXJ5LCAoaXRlbSwgaW5kZXgpID0+IGNvbnRhaW5zKGluZGV4ZXMsIGluZGV4KV07XG4gIH1cbiAgcmV0dXJuIHtza2lwOiB0b1NraXAsIGluZGV4ZXMsIGxpbWl0OiB0b0xpbWl0LCAuLi5yZXN0fTtcbn1cblxuZnVuY3Rpb24gbm9ybWFsaXplRnJvbShmcm9tKSB7XG4gIHJldHVybiBfLmlzTnVtYmVyKGZyb20pXG4gICAgPyB7aW5kZXg6IGZyb219XG4gICAgOiBfLmlzQXJyYXkoZnJvbSlcbiAgICAgID8ge2luZGV4ZXM6IGZyb219XG4gICAgICA6IF8uaXNGdW5jdGlvbihmcm9tKVxuICAgICAgICA/IHtxdWVyeTogZnJvbX1cbiAgICAgICAgOiBmcm9tO1xufVxuXG5mdW5jdGlvbiBub3JtYWxpemVUbyh0bykge1xuXG4gIGlmIChfLmlzQXJyYXkodG8pKSB7XG4gICAgdGhyb3cgJ1tSZWR1eCBDb2xsZWN0b3JdIGB0b2AgbXVzdCBiZSBhIHNpbmdsZSBpbmRleC4gWW91IHBhc3NlZDogJyArIHRvO1xuICB9XG5cbiAgcmV0dXJuIF8uaXNOdW1iZXIodG8pXG4gICAgPyB7aW5kZXg6IHRvfVxuICAgIDogXy5pc0Z1bmN0aW9uKHRvKVxuICAgICAgPyB7cXVlcnk6IHRvfVxuICAgICAgOiB0bztcbn1cblxuXG5leHBvcnQge25vcm1hbGl6ZU9yZGVyLCBub3JtYWxpemVTb3J0QXJncywgbm9ybWFsaXplSW5kZXhBcmdzLCBub3JtYWxpemVBY3Rpb24sIG5vcm1hbGl6ZUZyb20sIG5vcm1hbGl6ZVRvfTtcbiJdfQ==
{
"name": "redux-collector",
"version": "0.1.2",
"version": "1.0.0",
"description": "Easy Collection Reducers for Redux",

@@ -5,0 +5,0 @@ "main": "lib/redux-collector.js",

@@ -0,1 +1,6 @@

[Redux]: https://github.com/reactjs/redux
[Matthew Drake]: http://www.mediadrake.com
[Reducify]: http://reducify.mediadrake.com
[Redux Pipeline]: http://redux-pipeline.mediadrake.com
# Redux Collector [![Build Status](https://travis-ci.org/gtg092x/redux-collector.svg?branch=master)](https://travis-ci.org/gtg092x/redux-collector)

@@ -35,4 +40,3 @@

export default createStore(
collectify(
counterReducer,
collectify(
{

@@ -42,3 +46,4 @@ add: 'ADD_ITEM',

remove: 'REMOVE_ITEM'
}
},
counterReducer
)

@@ -109,10 +114,10 @@ );

{
add: 'ADD_ITEM',
hydrate: 'HYDRATE_ITEMS',
remove: 'REMOVE_ITEM'
},
{
defaultsTo: 0,
"INCREMENT": state => state + 1,
"DECRAMENT": state => state - 1
},
{
add: 'ADD_ITEM',
hydrate: 'HYDRATE_ITEMS',
remove: 'REMOVE_ITEM'
}

@@ -132,3 +137,3 @@ )

```js
collectify([[itemReducer<Object|Function>], actionTypes<Object>]);
collectify([actionTypes<Object>, [itemReducer<Object|Function>, collectionDefault<Array>]]);
```

@@ -161,3 +166,3 @@

const myReducer = collectify(itemReducer, actionTypes);
const myReducer = collectify(actionTypes, itemReducer);
```

@@ -185,3 +190,3 @@

const myStore = createStore(collectify(itemReducer, {hydrate: 'SET_ITEMS'}));
const myStore = createStore(collectify({hydrate: 'SET_ITEMS'}, itemReducer));

@@ -208,3 +213,3 @@ myStore.dispatch({

#### collectionDefault
#### Collection Default

@@ -218,3 +223,3 @@ This is the default or initial value of the collection.

const myStore = createStore(collectify(itemReducer, {collectionDefault: [1, 2]}));
const myStore = createStore(collectify({}, itemReducer, [1, 2]));

@@ -237,3 +242,3 @@ myStore.dispatch({

const myStore = createStore(collectify(itemReducer, {itemDefault: 10, add: 'ADD_ITEM'}));
const myStore = createStore(collectify({itemDefault: 10, add: 'ADD_ITEM'}, itemReducer));

@@ -261,7 +266,7 @@ myStore.dispatch({

const myStore = createStore(
collectify(
itemReducer,
collectify(
{
hydrate: 'HYDRATE_ITEMS'
}
},
itemReducer
)

@@ -272,3 +277,3 @@ );

type: 'HYDRATE',
data: [1, 2, 3, 4] // data is required
data: [1, 2, 3, 4] // data is required for HYDRATE
});

@@ -287,8 +292,8 @@ ```

const myStore = createStore(
collectify(
itemReducer,
collectify(
{
itemDefault: 10,
add: 'ADD_ITEM'
}
},
itemReducer
)

@@ -319,5 +324,5 @@ );

const myStore = createStore(
collectify(
itemReducer,
{ add: 'ADD_ITEM' }
collectify(
{ add: 'ADD_ITEM' },
itemReducer
)

@@ -353,8 +358,8 @@ );

const myStore = createStore(
collectify(
itemReducer,
collectify(
{
itemDefault: 10,
addRange: 'ADD_MULTIPLE_ITEMS'
}
},
itemReducer
)

@@ -385,5 +390,5 @@ );

const myStore = createStore(
collectify(
itemReducer,
{ addRange: 'ADD_MULTIPLE_ITEMS' }
collectify(
{ addRange: 'ADD_MULTIPLE_ITEMS' },
itemReducer
)

@@ -415,8 +420,8 @@ );

const myStore = createStore(
collectify(
[1, 2, 3, 4], // this is a static reducify reducer - defaulting to this array
collectify(
{
hydrate: 'HYDRATE_ITEMS',
remove: 'REMOVE_ITEMS'
}
},
[1, 2, 3, 4] // passing in an object and not a function will make this the default value
)

@@ -493,8 +498,8 @@ );

const myStore = createStore(
collectify(
[4, 3, 2, 1],
collectify(
{
hydrate: 'HYDRATE_ITEMS',
sort: 'SORT_ITEMS'
}
},
[4, 3, 2, 1]
)

@@ -556,7 +561,7 @@ );

const myStore = createStore(
collectify(
[4, 3, 2, 1],
collectify(
{
move: 'MOVE_ITEMS'
}
},
[4, 3, 2, 1]
)

@@ -595,7 +600,7 @@ );

const myStore = createStore(
collectify(
[4, 3, 2, 1],
collectify(
{
swap: 'SWAP_ITEMS'
}
},
[4, 3, 2, 1]
)

@@ -621,35 +626,627 @@ );

Because we may not always want to change the entire collection, Redux Collector looks for the keyword `query` in your action that you dispatch. This query is processed by the collector matching method.
```js
function increment(state = 0, action) {
switch(action.type) {
case 'INCREMENT':
return state + 1;
default:
return state;
}
}
const myStore = createStore(
collectify(
{
hydrate: 'HYDRATE_LIST'
},
increment
)
);
myStore.dispatch({
type: 'HYDRATE_LIST',
data: [-1, 2, 4]
});
// state is [-1, 2, 4]
myStore.dispatch({
type: 'INCREMENT',
query: function(item) {
return item > 0;
}
});
// all items are incremented by 1
// state is [-1, 3, 5]
```
#### Matcher
By default, the matcher used by `query` and `after` inspects your query argument and compares it against every item in the collection.
By default, your query is processed as follows:
##### Undefined
If undefined, we assume you want your operation applied to all items in the list.
##### Function
If a function, we evaluate this function passing in `[state, index]`. Returning `true` will say that query matches the item. Returning `false` will say it doesn't.
##### Array
If you pass an array, we will process every item in the query with against `every` (as an **and**, not **or**). For or, use [$or](#or). This is recursive.
##### Or
If you pass an object with the key `$or`, it must have a child that is an array and we will process this against `some`. This is recursive.
```js
myStore.dispatch({
type: 'INCREMENT',
query: [
item => item > 0,
item => item % 2 === 0
] // all items that are greater than 0 and are even
});
myStore.dispatch({
type: 'INCREMENT',
query: {
$or: [
item => item > 0,
item => item % 2 === 0
]
} // all items that are greater than 0 or are even
});
myStore.dispatch({
type: 'INCREMENT',
query: [
item => item % 2 === 0
{
$or: [
item => item > 0,
item => item === -2
]
}
] // all items that are even and are either greater than 0 or equal to -2
});
```
#### Boolean
If `true`, we assume you want your operation applied to all truthy items in the list.
If `false`, we assume you want your operation applied to all falsy items in the list.
#### Object
If you pass an object, we'll pass this to the [lodash function](https://lodash.com/docs#isMatch) `_.isMatch` with the item's state as the first argument.
#### Primitive
If you pass any number or string, we will do a strict equals comparison.
#### Custom
It's possible to customize your matcher function. Use the import `{configureCollectify}` and pass in a matcher argument.
```js
import {configureCollectify}
// We pass you the default matcher so you can add functionality without losing default matching behavior
function matcher(item, test, index, defaultMatcher) {
if (test === 'isOdd') {
return (item % 2) === 1;
}
return defaultMatcher(item, test, index);
}
const myCollectify = configureCollectify({matcher});
const myColReducer = myCollectify(
{},
incrementReducer,
[2, 3, 4]
);
dispatch({
type: 'INCREMENT',
query: 'isOdd'
})
// result is [2, 4, 4]
```
### Operations
#### Order
Beyond queries, there are other ways to apply your partial changes to your collection. These should be familiar to anyone with experience in mongo or other collection libraries.
#### Limit
Limits the number of operations your query will execute. This applies to all reducer behavior and `remove`.
```js
const myColReducer = collectify(
{},
incrementReducer,
[1, 2, 3]
);
dispatch({
type: 'INCREMENT',
limit: 1
})
// result would be [2, 2, 3]
```
```js
const myColReducer = collectify(
{remove: 'REMOVE'},
[1, 2, 3]
);
dispatch({
type: 'REMOVE',
limit: 1
})
// result would be [2, 3]
```
#### Skip
Skips a number of items before executing your operation. This applies to all reducer behavior and `remove`.
```js
const myColReducer = collectify(
{},
incrementReducer,
[1, 2, 3]
);
dispatch({
type: 'INCREMENT',
skip: 1
})
// result would be [1, 3, 4]
```
Skip and limit can be combined together.
```js
const myColReducer = collectify(
{},
incrementReducer,
[1, 2, 3]
);
dispatch({
type: 'INCREMENT',
skip: 1,
limit: 1
})
// result would be [1, 3, 3]
```
#### Index
A shortcut for `skip = index` and `limit = 1`. Indexes are pythonic, meaning that -1 is equal to the last item in the array.
```js
const myColReducer = collectify(
{},
incrementReducer,
[1, 2, 3]
);
dispatch({
type: 'INCREMENT',
index: 1
})
// result would be [1, 3, 3]
```
```js
const myColReducer = collectify(
{},
incrementReducer,
[1, 2, 3]
);
dispatch({
type: 'INCREMENT',
index: -1
})
// result would be [1, 2, 4]
```
#### Indexes
The same as `index`, but should be an array of indexes. Like `index`, these values are pythonic.
```js
const myColReducer = collectify(
{remove: 'REMOVE'},
[1, 2, 3]
);
dispatch({
type: 'REMOVE',
indexes: [0, 2]
})
// result would be [2]
```
#### Range
Should be a two dimensional array of pythonic indexes of the form `[start, end]`.
```js
const myColReducer = collectify(
{remove: 'REMOVE'},
[1, 2, 3, 4]
);
dispatch({
type: 'REMOVE',
range: [0, 2]
})
// result would be [4]
```
#### After
Should be a `query` that, upon first match, will determine the `skip` and `limit`.
```js
const myColReducer = collectify(
{remove: 'REMOVE'},
[1, 2, 3, 4]
);
dispatch({
type: 'REMOVE',
after: (arg, index) => arg === 2
})
// result would be [1, 2]
```
Keep in mind, this is only evaluated once. If the after function returns true, the rest of the collection will have operations applied to it.
#### Sort
#### Limit
Sorts the collection before applying operations to it. This uses the same arguments available for `sort`, but does not actually sort your list. This is useful when used in conjunction with any index operators.
```js
function incrementReducer(state = {value: 0}, action) {
switch(action.type) {
case 'INCREMENT':
return {...state, value: state.value + 1};
default:
return state;
}
}
const myColReducer = collectify(
{},
incrementReducer,
[{ord: 1, value: 3}, {ord: 3, value: 5}, {ord: 2, value: 10}]
);
dispatch({
type: 'INCREMENT',
sort: 'ord',
limit : 2
})
// result would be [{ord: 1, value: 4}, {ord: 3, value: 5}, {ord: 2, value: 11}]
// notice the second element was not changed
```
```js
const myColReducer = collectify(
{remove: 'REMOVE'},
[{ord: 1, value: 3}, {ord: 3, value: 5}, {ord: 2, value: 10}]
);
dispatch({
type: 'REMOVE',
sort: 'ord',
limit : 1,
skip: 1
})
// result would be [{ord: 1, value: 3}, {ord: 3, value: 5}]
```
You can pass a function to `sort` if you need to do something more complicated than just checking against a single key. Keep in mind, that `order` can still flip your collection. If you sort by the negative result of a key, your `order` argument might undo that.
```js
// same as above
const myColReducer = collectify(
{remove: 'REMOVE'},
[{ord: 1, value: 3}, {ord: 3, value: 5}, {ord: 2, value: 10}]
);
dispatch({
type: 'REMOVE',
sort: item => item.ord,
limit : 1,
skip: 1
})
// result would be [{ord: 1, value: 3}, {ord: 3, value: 5}]
```
#### Order
This determines the direction your collections's sorting occurs in. If you do not sort your list, it can be used to just reverse the direction your operations are done in.
```js
const myColReducer = collectify(
{remove: 'REMOVE'},
[1, 5, 2]
);
// removes the last item in the list
dispatch({
type: 'REMOVE',
order: -1,
limit : 1
})
// result would be [1, 5]
```
```js
const myColReducer = collectify(
{remove: 'REMOVE'},
[{ord: 1, value: 3}, {ord: 3, value: 5}, {ord: 2, value: 10}]
);
dispatch({
type: 'REMOVE',
sort: 'ord',
order : -1
})
// result would be [{ord: 1, value: 3}, {ord: 3, value: 5}]
```
You can combine `order` and `sort` with a shortcut by passing an object to `sort`.
```js
// same as above
const myColReducer = collectify(
{remove: 'REMOVE'},
[{ord: 1, value: 3}, {ord: 3, value: 5}, {ord: 2, value: 10}]
);
dispatch({
type: 'REMOVE',
sort: {ord: -1}
})
// result would be [{ord: 1, value: 3}, {ord: 3, value: 5}]
```
### Moving and Sorting
### Indexes
#### Sort List
## Customization
Using the same arguments for [sort](#sort), you can modify the output of your list.
### Matcher
```js
// same as above
const myColReducer = collectify(
{sort: 'SORT'},
[{ord: 1, value: 3}, {ord: 3, value: 5}, {ord: 2, value: 10}]
);
## Gotchas
dispatch({
type: 'SORT',
sort: 'ord'
})
// result would be [{ord: 1, value: 3}, {ord: 2, value: 10}, {ord: 3, value: 5}]
```
#### Move
Move lets you take a set of `indexes` passed to a `from` argument and places them at a single indexes provided by a `to` argument.
```js
const myColReducer = collectify(
{move: 'MOVE', hydrate: 'HYDRATE'},
[1, 2, 3, 4, 5]
);
dispatch({
type: 'MOVE',
from: 1,
to: 0
})
// result would be [2, 1, 3, 4, 5]
dispatch({
type: 'HYDRATE',
data: [1, 2, 3, 4, 5]
})
dispatch({
type: 'MOVE',
from: [1, 3], // treated as a list of indexes
to: 0
})
// result would be [2, 4, 1, 3, 5]
dispatch({
type: 'HYDRATE',
data: [1, 2, 3, 4, 5]
})
dispatch({
type: 'MOVE',
from: item => item === 3, // treated as a query
to: item => item === 2 // treated as a query, we will only use the first index returned
})
// result would be [1, 3, 2, 4, 5]
dispatch({
type: 'HYDRATE',
data: [1, 2, 3, 4, 5]
})
dispatch({
type: 'MOVE',
from: {after: item => item > 1},
to: 0
})
// result would be [2, 3, 4, 5, 1]
```
#### Swap
Swap switches item by index.
```js
const myColReducer = collectify(
{move: 'SWAP'},
[1, 2, 3, 4, 5]
);
dispatch({
type: 'SWAP',
indexes: [1, 4]
})
// result would be [1, 5, 3, 4, 2]
```
While most `swap` use cases should just take advantage of `indexes`, you can swap more than one item and have everything move in a carousel.
```js
const myColReducer = collectify(
{move: 'SWAP'},
[1, 2, 3, 4, 5]
);
dispatch({
type: 'SWAP',
after: item => item === 3
})
// result would be [1, 2, 5, 3, 4]
```
Check out [operations](#operations) for more details.
## Integration
Not every reducer is just a single array. Sometimes your array might be a property on the reducer itself. There's two ways to solve this.
### With Pipeline
The easy way.
[Redux Pipeline]() can you let select object properties to apply certain reducers to.
It would look something like this:
```js
const myState = {items: []};
function itemReducer(state = 0, action) {
// reducer
}
const myReducer = pipeline(
myState,
{
$: 'items',
reducer: collectify({
add: 'ADD',
// etc.
}, itemReducer)
}
);
```
### Without Pipeline
The slightly more difficult, but not impossible, way.
Track all actions that would apply to your collection and run them through a collectified reducer for that item. It would look like this:
```js
const collectified = collectify({
add: "ADD"
}, {
"INCREMENT": state => state + 1
});
function reducer(state = {items: []}, action = {}) {
switch(action.type) {
case 'ADD':
case 'INCREMENT':
return {...state, items: collectified(state.items, action)};
default:
return state;
}
}
const store = createStore(reducer);
const {dispatch, getState} = store;
dispatch({type: 'ADD', data: 10});
// state is {items: [10]}
dispatch({type: 'INCREMENT'});
// state is {items: [11]}
```
## Gotchas
### Multiple Aliases
A lot of operations will override behavior of other operations. Mixing them together can lead to odd consequences. We try our best to merge them all, but, when in doubt, either use specific indexes or stick to `skip` and `limit`.
```js
const myColReducer = collectify(
{},
incrementReducer,
[1, 2, 3, 4]
);
dispatch({
type: 'INCREMENT',
skip: 1,
index: 0,
limit 2
})
// result would be [1, 3, 4]
// index just gets ignored
```
### Selectors without pipeline
Redux Collector uses [Reducify]() for your reducer config. This means you can pass any reducer function or a configuration. However, Redux Collector only works on collections, so trying to select something with your configuration will throw an error.
```js
const myState = {items: []};
const myReducer = collectify(
{},
{
$: 'items',
"INCREMENT": state => state + 1
},
myState
);
// throws an error, use pipeline instead
```
If you find yourself selecting something within `collectify`, refer to the [With Pipeline](#with-pipeline) section of this readme.
## Credits
Redux Collector is free software under the MIT license. It was created in sunny Santa Monica by [Matthew Drake][].
[Redux]: https://github.com/reactjs/redux
[Matthew Drake]: http://www.mediadrake.com
[Reducify]: http://reducify.mediadrake.com
[Redux Pipeline]: http://redux-pipeline.mediadrake.com

@@ -34,3 +34,3 @@ import collectify from '../src/redux-collector';

const addAction = 'ADD_TEST';
const myReducer = collectify([], {
const myReducer = collectify({
add: addAction

@@ -75,3 +75,3 @@ });

const setAction = 'SET_TEST';
const myReducer = collectify([], {
const myReducer = collectify({
hydrate: setAction

@@ -91,3 +91,3 @@ });

const addAction = 'ADD_RANGE_TEST';
const myReducer = collectify([], {
const myReducer = collectify({
addRange: addAction

@@ -149,3 +149,3 @@ });

const removeAction = 'REMOVE_TEST';
const myReducer = collectify([], {
const myReducer = collectify({
remove: removeAction

@@ -165,2 +165,19 @@ });

it ("Should support range", function () {
let newArr = myReducer([10, 11, 12, 13], {type: removeAction, range: [0, 2]});
assert.deepEqual([13], newArr);
});
it ("Should support after", function () {
let newArr = myReducer([10, 11, 12, 13], {type: removeAction, after: arg => arg === 11});
assert.deepEqual([10, 11], newArr);
newArr = myReducer([10, 11, 12, 13], {type: removeAction, after: (arg, index) => index === 1});
assert.deepEqual([10, 11], newArr);
});
it("Should support query", function() {

@@ -222,3 +239,3 @@

const sortAction = 'SORT_TEST';
const myReducer = collectify([], {sort: sortAction});
const myReducer = collectify({sort: sortAction});

@@ -269,3 +286,3 @@ checkIntegrity(myReducer, {type: sortAction});

const moveAction = 'MOVE_TEST';
const myReducer = collectify([], {
const myReducer = collectify({
move: moveAction

@@ -283,3 +300,6 @@ });

newArr = myReducer([3, 4, 5, 6], {type: moveAction, from: [1, 3], to: 0});
newArr = myReducer([3, 4, 5, 6, 7], {type: moveAction, from: [2, 4], to: 0});
assert.deepEqual([5, 7, 3, 4, 6], newArr);
newArr = myReducer([3, 4, 5, 6], {type: moveAction, from: {range: [1, 3]}, to: 0});
assert.deepEqual([4, 5, 6, 3], newArr);

@@ -292,2 +312,5 @@

assert.deepEqual([5, 6, 3, 4], newArr);
newArr = myReducer([3, 4, 5, 6], {type: moveAction, from: item => item > 5, to: item => item === 4});
assert.deepEqual([3, 6, 4, 5], newArr);
});

@@ -298,3 +321,3 @@ });

const swapAction = 'SWAP_TEST';
const myReducer = collectify([], {
const myReducer = collectify({
swap: swapAction

@@ -315,6 +338,6 @@ });

describe('item reduce', function () {
const myReducer = collectify({
const myReducer = collectify({}, {
defaultsTo: [],
"RANDOMIZE": () => randomInt()
}, {});
});

@@ -391,3 +414,3 @@ const action = {type: 'RANDOMIZE'};

const myColReducer = collectify([], {
const myColReducer = collectify({
add: "ADD_ITEM"

@@ -420,8 +443,7 @@ });

const myColReducer = configureCollectify({matcher})({
add: "ADD_ITEM"
}, {
"INCREMENT": state => state + 1,
defaultsTo: 0
}, {
collectionDefault: [2],
add: "ADD_ITEM"
});
}, [2]);

@@ -428,0 +450,0 @@

@@ -15,7 +15,7 @@ import { createStore, combineReducers } from 'redux';

const store = createStore(collectify({
add: "ADD",
remove: "REMOVE"
}, {
defaultsTo: 0,
"INCREMENT": state => state + 1
}, {
add: "ADD",
remove: "REMOVE"
}));

@@ -50,3 +50,54 @@

});
it('integrates into a parent reducer', function () {
const collectified = collectify({
add: "ADD",
remove: "REMOVE"
}, {
defaultsTo: 0,
"INCREMENT": state => state + 1
});
function reducer(state = {items: []}, action = {}) {
switch(action.type) {
case 'ADD':
case 'REMOVE':
case 'INCREMENT':
return {...state, items: collectified(state.items, action)};
default:
return state;
}
}
const store = createStore(reducer);
const {dispatch, getState} = store;
let toCompare = {items: []};
dispatch({type: 'ADD'});
toCompare.items.push(0);
assert.deepEqual(toCompare, getState());
const toAdd = 10;
dispatch({type: 'ADD', data: toAdd});
toCompare.items.push(toAdd);
assert.deepEqual(toCompare, getState());
dispatch({type: 'ADD', data: toAdd});
toCompare.items.push(toAdd);
dispatch({type: 'INCREMENT'});
toCompare.items = toCompare.items.map(item => item + 1);
assert.deepEqual(toCompare, getState());
dispatch({type: 'REMOVE', limit: 1, index: -1});
toCompare.items.pop();
assert.deepEqual(toCompare, getState());
});
});
}

@@ -20,4 +20,4 @@ import pipeline from 'redux-pipeline';

defaults,
['breads', collectify({'SPOIL_BREAD': spoil}, {add: 'ADD_BREAD'})],
['cheeses', collectify({'SPOIL_CHEESE': spoil}, {add: 'ADD_CHEESE'})],
['breads', collectify({add: 'ADD_BREAD'}, {'SPOIL_BREAD': spoil})],
['cheeses', collectify({add: 'ADD_CHEESE'}, {'SPOIL_CHEESE': spoil})],
{

@@ -58,6 +58,7 @@ $: 'lunch',

assert.throw(function() {
const spoil = (state) => state + ' - gross';
pipeline(
defaults,
['breads', collectify({$: 'fail', 'SPOIL_BREAD': spoil}, {add: 'ADD_BREAD'})],
['cheeses', collectify({$: 'fail', 'SPOIL_CHEESE': spoil}, {add: 'ADD_CHEESE'})],
['breads', collectify({add: 'ADD_BREAD'}, {$: 'fail', 'SPOIL_BREAD': spoil})],
['cheeses', collectify({add: 'ADD_CHEESE'}, {$: 'fail', 'SPOIL_CHEESE': spoil})],
{

@@ -64,0 +65,0 @@ $: 'lunch',

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc