array.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. 'use strict';
  2. 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"); } }; }();
  3. function _toArray(arr) { return Array.isArray(arr) ? arr : Array.from(arr); }
  4. function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
  5. var checkArray = function checkArray(val) {
  6. if (!Array.isArray(val)) {
  7. throw Error('value must be an array');
  8. }
  9. };
  10. module.exports = {
  11. toArray: function toArray(arraylike) {
  12. return [].concat(_toConsumableArray(arraylike));
  13. },
  14. ensureArray: function ensureArray() {
  15. var val = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
  16. return Array.isArray(val) ? val : [val];
  17. },
  18. head: function head(ar) {
  19. checkArray(ar);
  20. var _ar = _toArray(ar),
  21. head = _ar[0],
  22. rest = _ar.slice(1);
  23. return head;
  24. },
  25. tail: function tail(ar) {
  26. checkArray(ar);
  27. var _ar$slice = ar.slice(-1),
  28. _ar$slice2 = _slicedToArray(_ar$slice, 1),
  29. tail = _ar$slice2[0];
  30. return tail;
  31. },
  32. unique: function unique(ar) {
  33. checkArray(ar);
  34. return ar.filter(function (val, i, input) {
  35. return i === input.indexOf(val);
  36. });
  37. },
  38. flatten: function flatten(ar) {
  39. checkArray(ar);
  40. return ar.reduce(function (acc, item) {
  41. if (Array.isArray(item)) {
  42. acc.push.apply(acc, _toConsumableArray(flatten(item)));
  43. } else {
  44. acc.push(item);
  45. }
  46. return acc;
  47. }, []);
  48. }
  49. };