Page MenuHomePhabricator

[web] Warn the user when deleting a chat that has contained chats
ClosedPublic

Authored by patryk on Jul 18 2023, 6:57 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 8, 12:07 PM
Unknown Object (File)
Tue, Jan 7, 1:57 PM
Unknown Object (File)
Tue, Jan 7, 2:38 AM
Unknown Object (File)
Tue, Jan 7, 2:38 AM
Unknown Object (File)
Tue, Jan 7, 2:38 AM
Unknown Object (File)
Tue, Jan 7, 2:38 AM
Unknown Object (File)
Tue, Jan 7, 2:38 AM
Unknown Object (File)
Tue, Jan 7, 2:38 AM
Subscribers

Details

Summary

Part of ENG-4319.

Before deletion, the user is warned about possible contained chats. For subchannel deletion, the modal looks like this:

screen1.png (627×1 px, 55 KB)

When deleting a whole community, message changes:

screen2.png (716×1 px, 55 KB)

When there are no contained chats, the confirmation modal does not pop up.

Depends on D8526.

Test Plan

This modal should pop up when deleting:

  • Non-empty community
  • Subchannel with threads

Modal should not pop up when deleting:

  • Empty community
  • Empty subchannel
  • Thread

Note: right now we don't support deleting subchannels when the parent channel is deleted. What I mean is this situation:
-> Community
--> Subchannel 1
---> Subchannel 2
If we delete Subchannel 1, right now Subchannel 2 is not deleted, thus modal should not pop up.

Diff Detail

Repository
rCOMM Comm
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

patryk held this revision as a draft.
patryk edited the test plan for this revision. (Show Details)
patryk added reviewers: bartek, tomek, inka, michal.
patryk attached a referenced file: F642488: screen2.png. (Show Details)
patryk attached a referenced file: F642476: screen1.png. (Show Details)
patryk edited the test plan for this revision. (Show Details)

Refactor component.

patryk added inline comments.
web/modals/threads/settings/thread-settings-delete-tab.react.js
79 ↗(On Diff #28812)

I wanted to use the finally block to avoid repeating this function call in line 75. However, in doing so, we may experience a delay in closing the modal when the callDeleteThread function is successful

bartek added a reviewer: ashoat.

Adding @ashoat because this diff adds new user-facing text content.

Note: I talked with Ted about this warning text.

web/modals/threads/settings/thread-settings-delete-confirmation-modal.react.js
12 ↗(On Diff #28812)

I don't think we call community chats "channel roots". Maybe just isCommunity?

web/modals/threads/settings/thread-settings-delete-tab.react.js
55–60 ↗(On Diff #28812)

You missed GENESIS. GENESIS is a special channel type in our codebase, that allows us to do hacks. It is a community root.
Also - we have a function for this: threadTypeIsCommunityRoot. This also suggests we should call this variable isCommunity / isCommunityRoot

79 ↗(On Diff #28812)

Isn't the delay still possible since you call popThreadDeleteConfirmationModal after await callDeleteThread?

ashoat added inline comments.
web/modals/threads/settings/thread-settings-delete-confirmation-modal.react.js
36 ↗(On Diff #28890)

If it's a community root, we should say "within this community" instead of "within this chat"

web/modals/threads/settings/thread-settings-delete-confirmation-modal.react.js
36 ↗(On Diff #28890)

We could consider using threadNoun instead of "chat" here, but it doesn't seem to handle communities very well

We could introduce a new function that uses "community" if threadTypeIsCommunityRoot, and otherwise calls threadNoun

web/modals/threads/settings/thread-settings-delete-tab.react.js
60 ↗(On Diff #28890)

One thing to consider here... in the future, we may change it, and make it so we don't always have threads available in the Redux store, even if they exist

Right now, the Redux store is very large and very expensive in terms of performance

If we remove old threads from the Redux store, then this check will no longer be viable

Before landing, can you add a subtask to ENG-4423 to address this in the future?

Change 'chat' to 'community' in modal text.

web/modals/threads/settings/thread-settings-delete-confirmation-modal.react.js
36 ↗(On Diff #28936)

Doesn't it now say "community" for normal chats (not communities) as well??

ashoat requested changes to this revision.Jul 27 2023, 1:42 PM
ashoat added inline comments.
web/modals/threads/settings/thread-settings-delete-confirmation-modal.react.js
36 ↗(On Diff #28936)

Yes, I think my feedback was misinterpreted. Here's a very precise list of instructions:

  1. Introduce a new function that calls return "community" if threadTypeIsCommunityRoot, and threadNoun otherwise
  2. Call that function here and use its return value instead of the string "community" here
This revision now requires changes to proceed.Jul 27 2023, 1:42 PM

Fix confirmation modal text.

ashoat requested changes to this revision.EditedJul 28 2023, 7:06 AM

Introduce a new function

Please introduce a new function in lib/shared/thread-utils.js, so you can reuse it on native. My feedback was extremely specific... please try rereading it closely and slowly.

This revision now requires changes to proceed.Jul 28 2023, 7:06 AM

Introduce a new function that calls return "community" if threadTypeIsCommunityRoot, and
threadNoun otherwise and use it in threadsToDeleteText variable.

Thank you!!

web/modals/threads/settings/thread-settings-delete-confirmation-modal.react.js
16 ↗(On Diff #29179)

If you are taking a function as input, and you don't care what that function returns, it is better to use () => mixed. That is a more flexible contract, and allows your caller to eg. hand you an async function (which returns a Promise) without having to wrap it in a lambda

This revision is now accepted and ready to land.Jul 28 2023, 11:09 AM

Use mixed type rather than void.

Move threadsToDeleteText to lib.