Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Geometry in map component not updating when changed #2727

Closed
MartinRoberg opened this issue Nov 19, 2024 · 0 comments · Fixed by #2729
Closed

Geometry in map component not updating when changed #2727

MartinRoberg opened this issue Nov 19, 2024 · 0 comments · Fixed by #2729
Labels
kind/bug Something isn't working status/triage

Comments

@MartinRoberg
Copy link
Contributor

MartinRoberg commented Nov 19, 2024

Description of the bug

The map-component renderes geometries given to it by the datamodel. The component expects an array of objects { data: string; label?: string; }.
When objects are added to the array, the map component renderes them properly. On the other hand, if you change the data/polygon part of a geometry that has previously been rendered on the map, the map moves to the new geometry location, but the geometry itself remains unchanged. Since the map moves to the new placement, that means the geometry bounds are recalculated, showing that the datamodel has been updated correctly. It seems like this happens as long as the data/gemoetry object has the same index and label in the datamodel array as it had on previous renders/updates. Reversing the list in the app before storing it in the datamodel so the index of the object has been changed since last update makes the geometry behave correctly/as expected.

The problem is propably with the key of the geojson components in the map component.

{geometries?.map(({ data, label }, i) => (
        <GeoJSON
          key={`${i}-${label}`}

What happened

Geometry is placed in datamodel and rendered in map. When the geometry is changed in the datamodel, the geometry remains in place on the map, instead of moving where it should.

What should have happened

Map should have moved to the new placement of the geometry, and the geometry object should have moved and adapted to the changed geometry data.

Steps To Reproduce

  1. Make an app with a map and geometries that can be changed by the user.
  2. Place geometries in the datamodel/map
  3. Watch them render on the map
  4. Change/update the data prop/field of one of the geometries
  5. The map should move the view to the updated placement of the geometry, while the geometry stays in place.

Additional Information

Placed geometry on map, and rendered correctly
Image

Changed the data of a geometry, but kept same label and placement in the array. The map moves but geometry does not.
Image

Expected behavior is that the geometry updates to new place:
Image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
kind/bug Something isn't working status/triage
Projects
Status: No status
Development

Successfully merging a pull request may close this issue.

1 participant