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

feat(organizations): handle user removes itself flow TASK-1354 #5393

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

pauloamorimbr
Copy link
Contributor

@pauloamorimbr pauloamorimbr commented Dec 19, 2024

🗒️ Checklist

  1. run linter locally
  2. update all related docs (API, README, inline, etc.), if any
  3. draft PR with a title <type>(<scope>)<!>: <title> TASK-1234
  4. tag PR: at least frontend or backend unless it's global
  5. fill in the template below and delete template comments
  6. review thyself: read the diff and repro the preview as written
  7. open PR & confirm that CI passes
  8. request reviewers, if needed
  9. delete this section before merging

📣 Summary

The navigation and data flow is improved when an MMO organization admin removes itself from the organization.

📖 Description

The objective of this PR is to:

  • Minimize wrong API calls due to permissions and session data that needs to be updated
  • Present a better flow for the user, redirecting them to the correct view after the removal
    There's still a big margin for improving, mainly due to some work needed in useUsage, but it unfolds into several other files and flows, so it's better to be handled in a separated PR

👀 Preview steps

  1. ℹ️ have an account and a project
  2. Be the admin in an MMO
  3. Navigate to Account Settings > Members
  4. Remove yourself from the organization
  5. 🔴 [on main] notice that the user is not redirected and there are some failed attempts to API calls due to permissions
  6. 🟢 [on PR] notice that the user is redirected and there's only 1 failed attempt to usage API

@pauloamorimbr pauloamorimbr self-assigned this Dec 19, 2024
@pauloamorimbr pauloamorimbr marked this pull request as ready for review December 20, 2024 17:59
@@ -119,11 +119,11 @@ export const useOrganizationQuery = (params?: OrganizationQueryParams) => {
// the session data loaded. Account data is needed to fetch the organization
// data.

const query = useQuery<Organization, FailResponse, Organization, QueryKeys[]>({
const query = useQuery<Organization, FailResponse, Organization, string[]>({
Copy link
Contributor

Choose a reason for hiding this comment

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

Unrelated to this PR, but note to self: do we need to specify angle brackets here, or can we get better type safety and readability by leaving this blank and fixing types upstream of it?

@p2edwards
Copy link
Contributor

Skimmed, will test soon.

@p2edwards p2edwards self-requested a review December 23, 2024 17:05
@pauloamorimbr pauloamorimbr force-pushed the pamorim/task-1354-handle-ux-flow-admin-leaving-mmo branch from 15bae53 to f0541cb Compare December 23, 2024 21:21
Copy link
Contributor

@Akuukis Akuukis left a comment

Choose a reason for hiding this comment

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

Review inline, not tested. Also:

  • the title is confusing to have both "feat" and "fix" keywords in it, how about "feat(organizations): handle user removes itself flow" or similar?

Comment on lines +113 to +117
if (params?.isRemovingSelf) {
session.refreshAccount();
} else {
queryClient.invalidateQueries({queryKey: [QueryKeys.organizationMembers]});
}
Copy link
Contributor

Choose a reason for hiding this comment

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

Why removing self should skip invalidation? 🤔

Even if removing self invalidates it indirectly, AFAIK multiple invalidations are batched, so let's keep it simple and with a clearer intent.

Suggested change
if (params?.isRemovingSelf) {
session.refreshAccount();
} else {
queryClient.invalidateQueries({queryKey: [QueryKeys.organizationMembers]});
}
queryClient.invalidateQueries({queryKey: [QueryKeys.organizationMembers]});
if (params?.isRemovingSelf) {
session.refreshAccount();
}

Comment on lines 112 to +113
onSettled: () => {
queryClient.invalidateQueries({queryKey: [QueryKeys.organizationMembers]});
if (params?.isRemovingSelf) {
Copy link
Contributor

Choose a reason for hiding this comment

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

IMHO this hook can be simplified by removing the isRemovingSelf parameter and accessing variables within onSettled instead.

    onSettled: (_data, _error, username) => {
      if (session.currentLoggedAccount?.username === username) {

fetchDelete(getMemberEndpoint(orgId!, username))
),
return fetchDelete(getMemberEndpoint(orgId!, username));
},
onSettled: () => {
Copy link
Contributor

Choose a reason for hiding this comment

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

perhaps use onSuccess instead? It would be confusing to get logged out on a failure to remove oneself.

@@ -12,6 +12,8 @@ import envStore from 'jsapp/js/envStore';
import subscriptionStore from 'jsapp/js/account/subscriptionStore';
import {useRemoveOrganizationMember} from './membersQuery';
import {notify} from 'alertifyjs';
import {ROUTES} from 'jsapp/js/router/routerConstants';
import router from 'jsapp/js/router/router';
Copy link
Contributor

Choose a reason for hiding this comment

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

unused imports

@@ -18,6 +18,11 @@ import {OrganizationUserRole} from './organizationQuery';

// Styles
import styles from './memberActionsDropdown.module.scss';
import {queryClient} from 'jsapp/js/query/queryClient';
import {QueryKeys} from 'jsapp/js/query/queryKeys';
Copy link
Contributor

Choose a reason for hiding this comment

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

unused imports

Copy link
Contributor

@jamesrkiger jamesrkiger left a comment

Choose a reason for hiding this comment

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

Left a couple minor notes. On testing, I see the remaining issues from usage, but this is certainly an improvement. I will test again once you go through Kalvis' requested changes.

@pauloamorimbr pauloamorimbr changed the title feat(organizations): fix data and navigation flow when member updates themselves TASK-1354 feat(organizations): handle user removes itself flow" or similar TASK-1354 Jan 6, 2025
@pauloamorimbr pauloamorimbr changed the title feat(organizations): handle user removes itself flow" or similar TASK-1354 feat(organizations): handle user removes itself flow TASK-1354 Jan 6, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants