index.js 1.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. 'use strict';
  2. const isPlainObj = require('is-plain-obj');
  3. module.exports = (obj, opts) => {
  4. if (!isPlainObj(obj)) {
  5. throw new TypeError('Expected a plain object');
  6. }
  7. opts = opts || {};
  8. // DEPRECATED
  9. if (typeof opts === 'function') {
  10. throw new TypeError('Specify the compare function as an option instead');
  11. }
  12. const deep = opts.deep;
  13. const seenInput = [];
  14. const seenOutput = [];
  15. const sortKeys = x => {
  16. const seenIndex = seenInput.indexOf(x);
  17. if (seenIndex !== -1) {
  18. return seenOutput[seenIndex];
  19. }
  20. const ret = {};
  21. const keys = Object.keys(x).sort(opts.compare);
  22. seenInput.push(x);
  23. seenOutput.push(ret);
  24. for (let i = 0; i < keys.length; i++) {
  25. const key = keys[i];
  26. const val = x[key];
  27. if (deep && Array.isArray(val)) {
  28. const retArr = [];
  29. for (let j = 0; j < val.length; j++) {
  30. retArr[j] = isPlainObj(val[j]) ? sortKeys(val[j]) : val[j];
  31. }
  32. ret[key] = retArr;
  33. continue;
  34. }
  35. ret[key] = deep && isPlainObj(val) ? sortKeys(val) : val;
  36. }
  37. return ret;
  38. };
  39. return sortKeys(obj);
  40. };