-
Notifications
You must be signed in to change notification settings - Fork 48
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
Optimize StoryClient to prevent unnecessary re-creation of client #221
base: main
Are you sure you want to change the base?
Conversation
- Use useMemo to ensure the client is only created when the config changes.
WalkthroughThe recent changes optimize the Changes
Poem
TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (invoked as PR comments)
Additionally, you can add CodeRabbit Configuration File (
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Files selected for processing (1)
- packages/react-sdk/src/StoryProtocolContext.tsx (2 hunks)
Additional comments not posted (3)
packages/react-sdk/src/StoryProtocolContext.tsx (3)
1-1
: LGTM! The addition ofuseMemo
is appropriate for optimization.The use of
useMemo
ensures that theclient
is only recreated whenconfig
changes, which can improve performance by preventing unnecessary re-instantiations.
Line range hint
15-17
:
LGTM! TheuseStoryContext
hook is correctly implemented.The function correctly uses
useContext
to return the context value fromStoryContext
.
12-12
: Ensureconfig
is correctly passed and used throughout the codebase.The
useMemo
hook is used correctly here. Verify thatconfig
is correctly passed and used in the rest of the codebase to ensure consistency and correctness.Verification successful
Verified:
config
is correctly passed and used throughout the codebase.The
config
object is correctly passed to theStoryProvider
in theWrapper
component, ensuring consistency and correctness.
Wrapper
component correctly passesconfig
toStoryProvider
.Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Verify that `config` is correctly passed and used throughout the codebase. # Test: Search for the usage of `StoryProvider` and ensure `config` is correctly passed. rg --type typescript -A 5 $'StoryProvider'Length of output: 76
Script:
#!/bin/bash # Description: Verify that `config` is correctly passed and used throughout the codebase. # Find all TypeScript files and search for the usage of `StoryProvider` to ensure `config` is correctly passed. fd -e ts -e tsx -x rg 'StoryProvider' -A 10Length of output: 1125
Description
Summary by CodeRabbit
StoryProvider
component to reduce unnecessary re-renders by using theuseMemo
hook for client instance creation.