Skip to content
This repository has been archived by the owner on Nov 13, 2024. It is now read-only.

Dex 1435 new notifications to fe #463

Merged
merged 8 commits into from
Oct 5, 2022

Conversation

Atticus29
Copy link
Contributor

@Atticus29 Atticus29 commented Oct 4, 2022

Pull request checklist:

  • Features and bugfixes should be PRed into the develop branch, not main
  • All text is internationalized
  • There are no linter errors
  • New features support all states (loading, error, etc)
    • Note that there are some new useGetMe() calls that don't monitor loading and error states. I think that this is ok given the context, but please let me know if not. Also, in that case, I'm not even sure what a good approach to waiting for loading to be false and error to be false would look like.

Which JIRA ticket(s) and/or GitHub issues does this PR address?

DEX-1435

Thanks for keeping it clean! Feel free to merge your own pull request after it has been approved - just use the "squash & merge" option.

QA Notes

collaboration_manager_edit_approved:

Let's say there's a collaboration between use1 and user2 such that they are already view collaborators, and user1 has already asked user2 to raise their collaboration to edit level. If at this point, a user manager updates that collab to edit, both users should see:
Screen Shot 2022-10-04 at 1 08 46 PM
Screen Shot 2022-10-04 at 1 09 28 PM

collaboration_manager_edit_revoke

Let's say there's a collaboration between use1 and user2 such that they are already edit collaborators. If at this point, a user manager updates that collab to view only, both users should see:

Screen Shot 2022-10-04 at 1 21 21 PM

collaboration_edit_denied

Let's say there's a collaboration between use1 and user2 such that they are already view collaborators. If at this point, a user1 requests edit access of user2, and user2 denies the request, user1 will see:

Screen Shot 2022-10-04 at 1 53 56 PM

collaboration_manager_edit_denied

I can't currently think of a way to create this notification. User managers can only edit the current state of a collaboration. If user1 and user2 are in an approved view state, and user1 has requested edit access of user2, the user manager can change the state to edit, in which case, there will be an approved notification. The user manager cannot change the state to view, because that's already the existing state:

Screen Shot 2022-10-04 at 1 52 03 PM

Screen Shot 2022-10-04 at 1 52 06 PM

It might also be a good idea to spot check for regressions in older notification types.

@@ -142,6 +142,7 @@ export default function AppHeader() {
refreshNotifications={refreshNotifications}
shouldOpen={shouldOpenNotificationPane}
setShouldOpen={setShouldOpenNotificationPane}
currentUserGuid={meData?.guid}
Copy link
Contributor Author

Choose a reason for hiding this comment

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

I fluctuated a little bit about whether I wanted this to be a prop here or just derive it with an api call in the child component.

Copy link
Contributor

Choose a reason for hiding this comment

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

I ran into the same question on #464. I passed it as a prop too. It looks like React Query recommends just deriving it though.
TanStack/query#463

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I kept it as a prop for this ticket...

Copy link
Contributor

Choose a reason for hiding this comment

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

That seems like a good idea to me. It is something we can look into and try to implement going forward.

@@ -0,0 +1,30 @@
import React from 'react';
Copy link
Contributor Author

Choose a reason for hiding this comment

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

All of these new dialogs are essentially duplicates with different names. I still don't love this pattern, because it's much DRYer to just have a baseNotificationDialog component do this job, but Ben long ago recommended to do it this way in case the notifications needed to diverge farther from one another in the future.

Copy link
Contributor

Choose a reason for hiding this comment

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

It looks to me like notifications have already diverged pretty far from each other, but instead of putting those differences in these files, we put them in the NotificationDetailsDialog.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yeah... NotificationDetailsDialog might be a great example of the abstraction monster situation described in https://www.deconstructconf.com/2019/dan-abramov-the-wet-codebase. Hoping to get the chance to make this better/more human-friendly in the future (but not for current ticket).

@Atticus29 Atticus29 marked this pull request as ready for review October 4, 2022 21:27
locale/en.json Outdated Show resolved Hide resolved
locale/en.json Outdated Show resolved Hide resolved
src/constants/notificationSchema.js Outdated Show resolved Hide resolved
src/utils/notificationUtils.js Outdated Show resolved Hide resolved
Copy link
Contributor

@Emily-Ke Emily-Ke left a comment

Choose a reason for hiding this comment

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

Looks good.

@Atticus29 Atticus29 merged commit ad726ae into develop Oct 5, 2022
@Atticus29 Atticus29 deleted the DEX-1435-new-notifications-to-FE branch October 5, 2022 23:40
@Atticus29 Atticus29 mentioned this pull request Oct 6, 2022
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants