UNPKG

set-state-compare

Version:

setState for React that compares with the current state and only sets the state if changed.

129 lines 13.3 kB
/** * @param {any} value1 * @param {any} value2 * @param {boolean} [debug] * @returns {boolean} */ function anythingDifferent(value1, value2, debug) { if (Array.isArray(value1) && Array.isArray(value2)) { return arrayDifferent(value1, value2); } else if (isSimpleObject(value1) && isSimpleObject(value2)) { return simpleObjectDifferent(value1, value2, true); } else if (typeof value1 == "object" && typeof value2 == "object" && value1 && value2) { return !Object.is(value1, value2); } else if (value1 !== value2) { if (debug) console.log(`Value 1 ${value1} wasn't the same as value 2 ${value2}`); return true; } return false; } /** * @param {any} value1 * @param {any} value2 * @param {boolean} [debug] * @returns {boolean} */ function referenceDifferent(value1, value2, debug) { const isSame = Object.is(value1, value2); if (!isSame && debug) { console.log(`Value 1 ${value1} wasn't the same as value 2 ${value2}`); } return !isSame; } /** * @param {any[]} array1 * @param {any[]} array2 * @param {boolean} [debug] * @returns {boolean} */ function arrayReferenceDifferent(array1, array2, debug) { if (array1.length !== array2.length) { if (debug) { console.log(`Array length ${array1.length} wasn't the same as ${array2.length}`); } return true; } for (let index = 0; index < array1.length; index += 1) { if (referenceDifferent(array1[index], array2[index], debug)) { return true; } } return false; } /** * @param {any[]} array1 * @param {any[]} array2 * @returns {boolean} */ function arrayDifferent(array1, array2) { if (array1.length != array2.length) { return true; } for (const key in array1) { if (anythingDifferent(array1[key], array2[key])) { return true; } } return false; } /** * @param {any} value * @returns {boolean} */ function isSimpleObject(value) { // Objects that contain $$typeof are special React objects that have recursive issues if (typeof value == "object" && value !== null && value.constructor.name == "Object" && !value["$$typeof"]) { return true; } return false; } /** * @param {object} object1 * @param {object} object2 * @param {boolean} checkLength * @returns {boolean} */ function simpleObjectDifferent(object1, object2, checkLength) { if (checkLength && Object.keys(object1).length !== Object.keys(object2).length) { return true; } return simpleObjectValuesDifferent(object1, object2); } /** * @param {any} object1 * @param {any} object2 * @param {object} [args] * @param {boolean} [args.debug] * @param {(string) => boolean} [args.ignore] * @returns {boolean} */ function simpleObjectValuesDifferent(object1, object2, args) { for (const key in object1) { if (args?.ignore && args.ignore({ key })) { if (args?.debug) console.log(`Ignoring key ${key}`); continue; } if (args?.debug) console.log({ key, object1: object1[key], object2: object2[key] }); if (!(key in object2)) { if (args?.debug) { console.log(`Key ${key} wasn't found in object`); } return true; } else if (anythingDifferent(object1[key], object2[key], args?.debug)) { if (args?.debug) { console.log(`Something was different for ${key}`); } return true; } } return false; } export { anythingDifferent, arrayDifferent, arrayReferenceDifferent, isSimpleObject, referenceDifferent, simpleObjectDifferent, simpleObjectValuesDifferent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"diff-utils.js","sourceRoot":"","sources":["../src/diff-utils.js"],"names":[],"mappings":"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","sourcesContent":["/**\n * @param {any} value1\n * @param {any} value2\n * @param {boolean} [debug]\n * @returns {boolean}\n */\nfunction anythingDifferent(value1, value2, debug) {\n  if (Array.isArray(value1) && Array.isArray(value2)) {\n    return arrayDifferent(value1, value2)\n  } else if (isSimpleObject(value1) && isSimpleObject(value2)) {\n    return simpleObjectDifferent(value1, value2, true)\n  } else if (typeof value1 == \"object\" && typeof value2 == \"object\" && value1 && value2) {\n    return !Object.is(value1, value2)\n  } else if (value1 !== value2) {\n    if (debug) console.log(`Value 1 ${value1} wasn't the same as value 2 ${value2}`)\n\n    return true\n  }\n\n  return false\n}\n\n/**\n * @param {any} value1\n * @param {any} value2\n * @param {boolean} [debug]\n * @returns {boolean}\n */\nfunction referenceDifferent(value1, value2, debug) {\n  const isSame = Object.is(value1, value2)\n\n  if (!isSame && debug) {\n    console.log(`Value 1 ${value1} wasn't the same as value 2 ${value2}`)\n  }\n\n  return !isSame\n}\n\n/**\n * @param {any[]} array1\n * @param {any[]} array2\n * @param {boolean} [debug]\n * @returns {boolean}\n */\nfunction arrayReferenceDifferent(array1, array2, debug) {\n  if (array1.length !== array2.length) {\n    if (debug) {\n      console.log(`Array length ${array1.length} wasn't the same as ${array2.length}`)\n    }\n\n    return true\n  }\n\n  for (let index = 0; index < array1.length; index += 1) {\n    if (referenceDifferent(array1[index], array2[index], debug)) {\n      return true\n    }\n  }\n\n  return false\n}\n\n/**\n * @param {any[]} array1\n * @param {any[]} array2\n * @returns {boolean}\n */\nfunction arrayDifferent(array1, array2) {\n  if (array1.length != array2.length) {\n    return true\n  }\n\n  for (const key in array1) {\n    if (anythingDifferent(array1[key], array2[key])) {\n      return true\n    }\n  }\n\n  return false\n}\n\n/**\n * @param {any} value\n * @returns {boolean}\n */\nfunction isSimpleObject(value) {\n  // Objects that contain $$typeof are special React objects that have recursive issues\n  if (typeof value == \"object\" && value !== null && value.constructor.name == \"Object\" && !value[\"$$typeof\"]) {\n    return true\n  }\n\n  return false\n}\n\n/**\n * @param {object} object1\n * @param {object} object2\n * @param {boolean} checkLength\n * @returns {boolean}\n */\nfunction simpleObjectDifferent(object1, object2, checkLength) {\n  if (checkLength && Object.keys(object1).length !== Object.keys(object2).length) {\n    return true\n  }\n\n  return simpleObjectValuesDifferent(object1, object2)\n}\n\n/**\n * @param {any} object1\n * @param {any} object2\n * @param {object} [args]\n * @param {boolean} [args.debug]\n * @param {(string) => boolean} [args.ignore]\n * @returns {boolean}\n */\nfunction simpleObjectValuesDifferent(object1, object2, args) {\n  for (const key in object1) {\n    if (args?.ignore && args.ignore({key})) {\n      if (args?.debug) console.log(`Ignoring key ${key}`)\n      continue\n    }\n\n    if (args?.debug) console.log({key, object1: object1[key], object2: object2[key]})\n\n    if (!(key in object2)) {\n      if (args?.debug) {\n        console.log(`Key ${key} wasn't found in object`)\n      }\n\n      return true\n    } else if (anythingDifferent(object1[key], object2[key], args?.debug)) {\n      if (args?.debug) {\n        console.log(`Something was different for ${key}`)\n      }\n\n      return true\n    }\n  }\n\n  return false\n}\n\nexport {\n  anythingDifferent,\n  arrayDifferent,\n  arrayReferenceDifferent,\n  isSimpleObject,\n  referenceDifferent,\n  simpleObjectDifferent,\n  simpleObjectValuesDifferent\n}\n"]}