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

Improve map performance #1069

Open
wants to merge 9 commits into
base: master
Choose a base branch
from
Open

Improve map performance #1069

wants to merge 9 commits into from

Conversation

K-Markopoulos
Copy link
Collaborator

@K-Markopoulos K-Markopoulos commented Dec 11, 2024

The goal is to improve initial load of the map and provide smooth scrolling and zooming. The main cause is that we are rendering (and re-rendering many times) 5.000+ markers at once.

Changes

  • Incrementally mount site markers. Mount only visible markers, to avoid mounting all at once and freezing the UI. Keep the mounted to avoid re-mounting.
  • Replace siteOnMap selector with isSelected selector which caused all markers to re-render when selected site was changed.
  • Add back marker clustering.
  • Move "fly to selected site" logic to map component and remove double rendering.
  • Add back offset markers functionality.
  • Investigate cluster icon color not matching alert levels.

image

@K-Markopoulos K-Markopoulos self-assigned this Dec 11, 2024
Copy link

@pullrequest pullrequest bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ This pull request was not sent to the PullRequest network because the pull request is a draft.

Copy link

github-actions bot commented Dec 11, 2024

Build succeeded and deployed at https://aqualink-app-1069.surge.sh
(hash d814ec4 deployed at 2024-12-18T16:44:41)

@ericboucher
Copy link
Member

@K-Markopoulos could you rebase on the last version of the reef-check frontend so that we can deploy it to programize for testing?

@K-Markopoulos
Copy link
Collaborator Author

@K-Markopoulos could you rebase on the last version of the reef-check frontend so that we can deploy it to programize for testing?

@ericboucher Sure but what's the plan for testing? This PR doesn't have any overlapping changes with the reef-check frontend PRs. The generated link: https://aqualink-app-1069.surge.sh/ shows the reef-check sites on the map as well.

@K-Markopoulos K-Markopoulos marked this pull request as ready for review December 16, 2024 11:38
Copy link

@pullrequest pullrequest bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

✅ This pull request was sent to the PullRequest network for review. Expert reviewers are now being matched to your request based on the code's requirements. Stay tuned!

What to expect from this code review:
  • Comments posted to any areas of potential concern or improvement.
  • Detailed feedback or actions needed to resolve issues that are found.
  • Turnaround times vary, but we aim to be swift.

@K-Markopoulos you can click here to see the review status or cancel the code review job.

Copy link

@pullrequest pullrequest bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

PullRequest Breakdown

Reviewable lines of change

+ 178
- 98

66% TSX
34% TypeScript

Type of change

Feature - These changes are adding a new feature or improvement to existing code.

Copy link

@pullrequest pullrequest bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice work here. I don’t have any security concerns with these changes.

Image of Graham C Graham C


Reviewed with ❤️ by PullRequest

@K-Markopoulos
Copy link
Collaborator Author

Comparing different clustering options

Options Screenshot Full map
maxClusterRadius={80}, sizes (1k, 100, 10, 1): [100,64,48,36] image image
maxClusterRadius={60}, sizes: [50,44,36,32] image image
background: max alert color image image

Copy link

@pullrequest pullrequest bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

PullRequest reviewed the updates made to #1069 up until the latest commit (75d5c5c). No further issues were found.

Reviewed by:

Image of Graham C Graham C

@Caesarh97
Copy link
Collaborator

@K-Markopoulos I like the clustering icons. I like when we clearly show how many sites that experience what heat stress. I think the white center clarify this the most.

If we would color the center, then we should display the most abundant heat stress level for the specific area. I think we should maybe separate the center and the outside circle a little bit more if we’d choose this choice. See example below.

Which do you think would be best?

Untitled design

Copy link

@pullrequest pullrequest bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

PullRequest reviewed the updates made to #1069 up until the latest commit (d814ec4). No further issues were found.

Reviewed by:

Image of Graham C Graham C

Copy link

@pullrequest pullrequest bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Due to inactivity, PullRequest has cancelled this review job. You can reactivate the code review job from the PullRequest dashboard.

@ericboucher
Copy link
Member

Let's try a final time to improve map performance using geojson grouping.
If that doesn't work then we can stick with the clustering and upgrade it to match this figma: https://www.figma.com/design/5FeX5lEkdcRNZRaY8WtcqC/Aqualink?node-id=690-306&t=fZTLw6H98ekXnnSW-0

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants