Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
✨ Fix Divergent Branch Issue and Update Default Mode Logic #2106
✨ Fix Divergent Branch Issue and Update Default Mode Logic #2106
Changes from 7 commits
47fdc9a
9a1e1fe
fcd823f
ed501e1
ab92d33
84fd2cb
cb65e37
4b7eecf
3b430cc
78957e2
f549ed7
6bc2259
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
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.
This looks good. Just put it in a function, iterate through the applications array and get the mode for each application. At the end either all of the modes are the same, or they are different. Same = return that mode, different = return undefined.
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.
That way, if a mode can't be figured out from the selected apps, the fallback/default mode is the original default.
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.
@sjd78 unfortunately @yael-spinner hit a real bug - the
AnalysisWizard
gets re-rendered with every change on the applications screen which means that the defaults are being set at start time when no apps are selected.So
useEffect
is necessary here as a workaround. The good news is that using (our old friend)key
property we can force re-creating the wizard when selected apps change. The following fix worked for me: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.
Ah right! I forgot about the order state gets loaded up in modals like this. Using the
key
prop does make sense.For some reference: https://react.dev/learn/preserving-and-resetting-state#resetting-a-form-with-a-key
So use the
key
attribute and dropuseEffect()
?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.
@sjd78 @rszwajko I changed the code according to your comments