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

Activity: improve performance #2772

Merged
merged 2 commits into from
Jan 27, 2025

Conversation

myxmaster
Copy link
Contributor

@myxmaster myxmaster commented Jan 26, 2025

Description

  • Loading indicator removed from multiple places in ActivityStore (that alone results in less renderings), and used in Activity directly so it is now correctly displayed while loading (now it also includes setFilters() which also takes some time)
    • Removed usage of loading in ActivityFilter since it had no effect
  • removed await for Storage.setItem(ACTIVITY_FILTERS_KEY, filters) in setFilters() to avoid delay of rendering
  • Preparations of setFilters() now done before updating observable filteredActivity (outdated note... I was playing around with it, but because of "@action" decorator it doesn't trigger multiple renders anyway)
  • Now using React.memo to avoid re-renderings of ListItems

Tested with LNC connection to a real node (~650 items in Activity) on emulator.
Rendering time before this PR: 18.54s (avg of 3 runs)
Rendering time after this PR: 11.06s (avg of 3 runs)
=> This is pretty significant because only fetching data from backend is around 4.x seconds.

This pull request is categorized as a:

  • New feature
  • Bug fix
  • Code refactor
  • Configuration change
  • Locales update
  • Quality assurance
  • Other

Checklist

  • I’ve run yarn run tsc and made sure my code compiles correctly
  • I’ve run yarn run lint and made sure my code didn’t contain any problematic patterns
  • I’ve run yarn run prettier and made sure my code is formatted correctly
  • I’ve run yarn run test and made sure all of the tests pass

Testing

If you modified or added a utility file, did you add new unit tests?

  • No, I’m a fool
  • Yes
  • N/A

I have tested this PR on the following platforms (please specify OS version and phone model/VM):

  • Android
  • iOS

I have tested this PR with the following types of nodes (please specify node version and API version where appropriate):

  • Embedded LND
  • LND (REST)
  • LND (Lightning Node Connect)
  • Core Lightning (CLNRest)
  • LndHub
  • [DEPRECATED] Core Lightning (c-lightning-REST)
  • [DEPRECATED] Core Lightning (Spark)
  • [DEPRECATED] Eclair

Locales

  • I’ve added new locale text that requires translations
  • I’m aware that new translations should be made on the ZEUS Transfix page and not directly to this repo

Third Party Dependencies and Packages

  • Contributors will need to run yarn after this PR is merged in
  • 3rd party dependencies have been modified:
    • verify that package.json and yarn.lock have been properly updated
    • verify that dependencies are installed for both iOS and Android platforms

Other:

  • Changes were made that require an update to the README
  • Changes were made that require an update to onboarding

@myxmaster myxmaster marked this pull request as draft January 26, 2025 19:10
@AndySchroder
Copy link

Rendering time before this PR: 11.06s (avg of 3 runs)
Rendering time afterthis PR: 18.54s (avg of 3 runs)
=> This is pretty significant because only fetching data from backend is around 4.x seconds.

Do you have this backwards?

@myxmaster
Copy link
Contributor Author

Yep, edited.

@kaloudis kaloudis changed the title Improve activity performance Activity: improve performance Jan 27, 2025
@kaloudis kaloudis added this to the v0.9.5 milestone Jan 27, 2025
Copy link
Contributor

@kaloudis kaloudis left a comment

Choose a reason for hiding this comment

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

tACK

great PR! Putting this into v0.9.5

@kaloudis kaloudis merged commit bb537cb into ZeusLN:master Jan 27, 2025
4 checks passed
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