js-samples icon indicating copy to clipboard operation
js-samples copied to clipboard

Bug: React-Map createCustomEqual no overloads matches call.

Open alexlohe25 opened this issue 2 years ago • 2 comments

Operating system

Windows 10 21H2

Browser Version

Firefox 102.0

How severe is the bug?

high

Bug description

Checking the custom hook for deep comparisons, the method createCustomEqual in deepCompareEqualsForMaps (line 213, in react-maps/docs/index.tsx), does not recognize both a and b:

(deepEqual) => (a: any, b: any)

throws the following error:

No overload matches this call.
  Overload 1 of 2, '(getComparatorOptions: GetComparatorOptions<undefined>): <A, B>(a: A, b: B, meta?: undefined) => boolean', gave the following error.
    Value of type '(a: any, b: any) => any' has no properties in common with type 'Partial<CreateComparatorCreatorOptions<undefined>>'. Did you mean to call it?
  Overload 2 of 2, '(getComparatorOptions: GetComparatorOptions<undefined>): <A, B>(a: A, b: B, meta?: undefined) => boolean', gave the following error.
    Value of type '(a: any, b: any) => any' has no properties in common with type 'Partial<CreateComparatorCreatorOptions<undefined>>'. Did you mean to call it?ts(2769),

index.d.ts(16, 42): The expected type comes from the return type of this signature.
index.d.ts(16, 42): The expected type comes from the return type of this signature.

And also the deepEqual(a , b); call throws the error:

This expression is not callable.
  Type 'CreateComparatorCreatorOptions<undefined>' has no call signatures.ts(2349)

I guess both things are related to some Typescript error using fast-equals library. I also tried cloning the repository and the same problems are still showing up.

Steps to reproduce

No response

Console log output

No response

alexlohe25 avatar Jul 06 '22 07:07 alexlohe25

I have this same problem since upgrading fast-equals from version 3.0.2 to 4.0.1, looks like there have been some changes in the createCustomEqual function.

EDIT: for anyone who uses this code in their maps implementation: pinning fast-equals to ~3.0.3 should fix this.

bobvork avatar Jul 19 '22 14:07 bobvork

For 4.0.1 version I've replaced function deepCompareEqualsForMaps with following code:

import {createCustomEqual, deepEqual} from "fast-equals";

const deepCompareEqualsForMaps = createCustomEqual(() => ({
    areObjectsEqual: (a, b) => {
        if (isLatLngLiteral(a) || a instanceof google.maps.LatLng || isLatLngLiteral(b) || b instanceof google.maps.LatLng) {
            return new google.maps.LatLng(a).equals(new google.maps.LatLng(b));
        }

        return deepEqual(a, b);
    },
}));

Inner arrow function may be extracted to separate function. See fast-equals recipe.

Nevertheless, I haven't dig into this comparison library, so I'm not sure about returning deepEquals() for other objects. Maybe there can be used something more accurate.

mstarzak avatar Jul 28 '22 18:07 mstarzak