From 0dad3d2b555c41cbb3c2079a34e4d9b3f8ea5195 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Thu, 16 May 2024 14:04:38 +0200 Subject: [PATCH 1/5] Add lodash replacement --- src/handlers/createHandler.tsx | 4 +--- src/utils.ts | 26 ++++++++++++++++++++++++++ 2 files changed, 27 insertions(+), 3 deletions(-) diff --git a/src/handlers/createHandler.tsx b/src/handlers/createHandler.tsx index 83bdefb048..9803d32943 100644 --- a/src/handlers/createHandler.tsx +++ b/src/handlers/createHandler.tsx @@ -6,8 +6,6 @@ import { EmitterSubscription, } from 'react-native'; import { customDirectEventTypes } from './customDirectEventTypes'; -// @ts-ignore - it isn't typed by TS & don't have definitelyTyped types -import deepEqual from 'lodash/isEqual'; import RNGestureHandlerModule from '../RNGestureHandlerModule'; import { State } from '../State'; import { @@ -25,7 +23,7 @@ import { scheduleFlushOperations, } from './gestureHandlerCommon'; import { ValueOf } from '../typeUtils'; -import { isFabric, isJestEnv, tagMessage } from '../utils'; +import { deepEqual, isFabric, isJestEnv, tagMessage } from '../utils'; import { ActionType } from '../ActionType'; import { PressabilityDebugView } from './PressabilityDebugView'; import GestureHandlerRootViewContext from '../GestureHandlerRootViewContext'; diff --git a/src/utils.ts b/src/utils.ts index 6ca523c2da..6fc81e55d9 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -59,3 +59,29 @@ export function isRemoteDebuggingEnabled(): boolean { !localGlobal.RN$Bridgeless ); } + +export function deepEqual(obj1: any, obj2: any) { + if (obj1 === obj2) return true; + + if ( + typeof obj1 !== 'object' || + typeof obj2 !== 'object' || + obj1 === null || + obj2 === null + ) { + return obj1 === obj2; + } + + const keys1 = Object.keys(obj1); + const keys2 = Object.keys(obj2); + + if (keys1.length !== keys2.length) return false; + + for (let key of keys1) { + if (!keys2.includes(key) || !deepEqual(obj1[key], obj2[key])) { + return false; + } + } + + return true; +} From 2b53507f8de4540b7bdc3e2ca7b3477f1d01ba7e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Thu, 16 May 2024 14:05:31 +0200 Subject: [PATCH 2/5] Remove lodash --- package.json | 1 - yarn.lock | 2 +- 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/package.json b/package.json index 96f9b80bac..a692ccb3a5 100644 --- a/package.json +++ b/package.json @@ -62,7 +62,6 @@ "@egjs/hammerjs": "^2.0.17", "hoist-non-react-statics": "^3.3.0", "invariant": "^2.2.4", - "lodash": "^4.17.21", "prop-types": "^15.7.2" }, "jest": { diff --git a/yarn.lock b/yarn.lock index 9f4fb48677..09da07dab2 100644 --- a/yarn.lock +++ b/yarn.lock @@ -9046,7 +9046,7 @@ lodash@4.17.19: version "4.17.19" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.19.tgz#e48ddedbe30b3321783c5b4301fbd353bc1e4a4b" -lodash@^4.17.11, lodash@^4.17.15, lodash@^4.17.19, lodash@^4.17.21, lodash@^4.17.4, lodash@^4.5.0, lodash@^4.6.0, lodash@^4.6.1, lodash@^4.7.0: +lodash@^4.17.11, lodash@^4.17.15, lodash@^4.17.19, lodash@^4.17.4, lodash@^4.5.0, lodash@^4.6.0, lodash@^4.6.1, lodash@^4.7.0: version "4.17.21" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== From 5d8aff988eba79e572824662ce01944a3d3e402c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Fri, 17 May 2024 09:00:32 +0200 Subject: [PATCH 3/5] Fix lint --- src/utils.ts | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/utils.ts b/src/utils.ts index 6fc81e55d9..22cac75bd5 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -61,7 +61,9 @@ export function isRemoteDebuggingEnabled(): boolean { } export function deepEqual(obj1: any, obj2: any) { - if (obj1 === obj2) return true; + if (obj1 === obj2) { + return true; + } if ( typeof obj1 !== 'object' || @@ -75,9 +77,11 @@ export function deepEqual(obj1: any, obj2: any) { const keys1 = Object.keys(obj1); const keys2 = Object.keys(obj2); - if (keys1.length !== keys2.length) return false; + if (keys1.length !== keys2.length) { + return false; + } - for (let key of keys1) { + for (const key of keys1) { if (!keys2.includes(key) || !deepEqual(obj1[key], obj2[key])) { return false; } From 22a5accf20f72d084a2a349f208a51e7b490e269 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= <63123542+m-bert@users.noreply.github.com> Date: Fri, 17 May 2024 10:30:06 +0200 Subject: [PATCH 4/5] Change return value Co-authored-by: Jakub Piasecki --- src/utils.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/utils.ts b/src/utils.ts index 22cac75bd5..fb81fbb229 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -71,7 +71,7 @@ export function deepEqual(obj1: any, obj2: any) { obj1 === null || obj2 === null ) { - return obj1 === obj2; + return false; } const keys1 = Object.keys(obj1); From 4b5c10f62ab78c127d697af815ef182920316861 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Bert?= Date: Fri, 17 May 2024 11:22:27 +0200 Subject: [PATCH 5/5] Add tsdoc --- src/utils.ts | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/utils.ts b/src/utils.ts index fb81fbb229..6352d2135d 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -60,6 +60,15 @@ export function isRemoteDebuggingEnabled(): boolean { ); } +/** + * Recursively compares two objects for deep equality. + * + * **Note:** This function does not support cyclic references. + * + * @param obj1 - The first object to compare. + * @param obj2 - The second object to compare. + * @returns `true` if the objects are deeply equal, `false` otherwise. + */ export function deepEqual(obj1: any, obj2: any) { if (obj1 === obj2) { return true;