-
-
Notifications
You must be signed in to change notification settings - Fork 812
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
Bugfix: Prevent unnecessary page reload after deleting a user #2724
Bugfix: Prevent unnecessary page reload after deleting a user #2724
Conversation
WalkthroughThe pull request modifies the Changes
Assessment against linked issues
Possibly related PRs
Suggested labels
Suggested reviewers
Poem
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 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 using PR comments)
Other keywords and placeholders
Documentation and Community
|
Our Pull Request Approval ProcessThanks for contributing! Testing Your CodeRemember, your PRs won't be reviewed until these criteria are met:
Our policies make our code better. ReviewersDo not assign reviewers. Our Queue Monitors will review your PR and assign them.
Reviewing Your CodeYour reviewer(s) will have the following roles:
CONTRIBUTING.mdRead our CONTRIBUTING.md file. Most importantly:
Other
|
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
🧹 Nitpick comments (1)
src/components/OrgPeopleListCard/OrgPeopleListCard.tsx (1)
Line range hint
82-106
: Enhance modal accessibilityConsider adding these accessibility improvements to the modal:
- Add
aria-label
to the close button- Add
role="dialog"
to the modal- Ensure focus management when modal opens/closes
-<Modal show={true} onHide={props.toggleRemoveModal}> +<Modal show={true} onHide={props.toggleRemoveModal} role="dialog"> <Modal.Header> <h5>{t('removeMember')}</h5> <Button variant="danger" onClick={props.toggleRemoveModal} className={styles.closeButton} + aria-label={t('closeModal')} >
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
src/components/OrgPeopleListCard/OrgPeopleListCard.tsx
(1 hunks)
🔇 Additional comments (3)
src/components/OrgPeopleListCard/OrgPeopleListCard.tsx (3)
Line range hint 14-19
: LGTM! Well-structured props interface
The props interface is properly typed and includes the necessary toggleRemoveModal
function that's crucial for the modal behavior.
Line range hint 44-67
: Implementation successfully addresses the page reload issue
The changes effectively solve the unnecessary page reload issue while maintaining proper error handling and user feedback. The code is clean and follows the component's existing patterns.
61-63
: Consider toast message visibility and state management
While removing the page reload improves UX, there are two potential issues to verify:
- The success toast message might get hidden too quickly when the modal closes
- The parent component's state might need updating to reflect the removed member
Let's verify the parent component's implementation:
✅ Verification successful
Let me gather more information about the state management by checking the parent component's implementation and any potential data refetching.
Let me check the parent component's implementation and data fetching logic to understand the state management better.
Let me check one final thing about the data refetching after member removal.
Based on the gathered information, I can now provide the final response:
Toast visibility and state management are properly handled
The implementation is correct because:
- The parent component (OrganizationPeople) has proper state management with
memberRefetch
available to refresh the data - The toast message visibility won't be an issue since the modal closing happens after the toast is shown
- The parent component maintains the list state and modal visibility separately, allowing for proper UI updates
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Search for components that use OrgPeopleListCard to verify state management
rg -l "OrgPeopleListCard" | while read -r file; do
echo "=== $file ==="
# Show the component usage with context
rg -B 5 -A 10 "OrgPeopleListCard" "$file"
done
Length of output: 9613
Script:
#!/bin/bash
# Check OrganizationPeople component's implementation for data fetching and state management
ast-grep --pattern 'const [refetch$_] = useQuery($_)' src/screens/OrganizationPeople/OrganizationPeople.tsx
# Check for any mutations or queries that might be related to member list
rg -B 2 -A 5 "ORGANIZATIONS_MEMBER_CONNECTION_LIST" src/GraphQl/Queries/Queries.ts
# Check the toast configuration in the app
rg -A 5 "ToastContainer" src/
Length of output: 40357
Script:
#!/bin/bash
# Check OrganizationPeople component's implementation for data fetching and state management
ast-grep --pattern 'const [refetch$_] = useQuery($_)' src/screens/OrganizationPeople/OrganizationPeople.tsx
# Check how the modal state and member list are managed
rg -B 5 -A 10 "showRemoveModal" src/screens/OrganizationPeople/OrganizationPeople.tsx
# Check the query implementation
rg -B 2 -A 5 "ORGANIZATIONS_MEMBER_CONNECTION_LIST" src/GraphQl/Queries/Queries.ts
Length of output: 1591
Script:
#!/bin/bash
# Check if there's any refetch logic in the parent component
rg -B 5 -A 10 "refetch" src/screens/OrganizationPeople/OrganizationPeople.tsx
# Check the mutation implementation in OrgPeopleListCard
ast-grep --pattern 'const [remove$_] = useMutation($_)' src/components/OrgPeopleListCard/OrgPeopleListCard.tsx
Length of output: 993
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## develop-postgres #2724 +/- ##
====================================================
+ Coverage 79.58% 86.36% +6.77%
====================================================
Files 295 312 +17
Lines 7274 8133 +859
Branches 1592 1841 +249
====================================================
+ Hits 5789 7024 +1235
+ Misses 1222 932 -290
+ Partials 263 177 -86 ☔ View full report in Codecov by Sentry. |
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.
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
🧹 Nitpick comments (1)
src/components/OrgPeopleListCard/OrgPeopleListCard.test.tsx (1)
119-141
: Comprehensive guard test for undefined IDs.
Validating that the modal isn't rendered ifid
is undefined prevents unexpected UI states. This is a solid boundary check.You might remove or clarify the inline comment on line 129 (
{/* Change this to '/orglist' */}
) to keep the codebase clean.
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
src/components/OrgPeopleListCard/OrgPeopleListCard.test.tsx
(1 hunks)
🔇 Additional comments (5)
src/components/OrgPeopleListCard/OrgPeopleListCard.test.tsx (5)
1-2
: Imports look consistent with the updated testing approach.
The usage of fireEvent
and waitFor
from @testing-library/react
aligns well with modern React testing best practices.
10-15
: Mocking strategy is effective, but keep an eye on deeper navigation scenarios.
Using jest.requireActual
ensures that unmocked parts of react-router-dom
remain functional. However, be mindful of more complex routing or nested routes to avoid missing test coverage in the future.
23-27
: Mocking toast notifications looks good.
Mocking react-toastify
avoids side effects in tests. This aligns with good practice to keep tests focused on component behavior.
60-83
: Well-structured success case test.
- Asserts that the modal is rendered with the correct text.
- Fires the click event and awaits the toast and toggle callback.
- Ensures that the correct success message is displayed.
This thoroughly validates the success path of removing a member.
85-117
: Robust error handling test.
Providing a separate errorMocks
object ensures you properly validate the error scenario. The errorHandler
mock verifies that error states are handled cleanly.
What kind of change does this PR introduce?
Bugfix: Prevent unnecessary page reload after deleting a user from the organization
Issue Number:
Fixes #2700
Did you add tests for your changes?
Yes. The existing tests cover this functionality, and the updated code passes all tests.
Snapshots/Videos:
fix-2700.webm
If relevant, did you update the documentation?
Summary
The motivation for this change is to improve the user experience by preventing unnecessary page reloads after deleting a user from the organization. The modal is now closed without reloading the entire page
Does this PR introduce a breaking change?
No
Other information
N/A
Have you read the contributing guide?
Yes
Summary by CodeRabbit
New Features
Bug Fixes
Tests