Page MenuHomePhabricator

[web] Fix thread description and color modification in private thread
ClosedPublic

Authored by abosh on May 18 2022, 10:07 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 20, 11:00 PM
Unknown Object (File)
Wed, Jan 15, 3:14 PM
Unknown Object (File)
Sat, Jan 11, 8:02 PM
Unknown Object (File)
Tue, Dec 31, 10:44 PM
Unknown Object (File)
Tue, Dec 31, 10:44 PM
Unknown Object (File)
Tue, Dec 31, 10:44 PM
Unknown Object (File)
Tue, Dec 31, 10:44 PM
Unknown Object (File)
Tue, Dec 31, 10:44 PM

Details

Summary

Fix issue where user is unable to modify the thread description and color in their private thread. The thread name is still unmodifiable (following the inclusion of the EDIT_DESCRIPTION and EDIT_COLOR permissions but not the EDIT_THREAD_NAME permission in D1980), but the thread description and color can be modified.

Related Linear issue with full context here.

Test Plan

Tested on Chrome/Safari and works as expected:

Before:

After:

Diff Detail

Repository
rCOMM Comm
Branch
master
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

abosh edited the test plan for this revision. (Show Details)
abosh added 1 blocking reviewer(s): atul.
web/modals/threads/settings/thread-settings-general-tab.react.js
149–152

This extra condition makes sure that the thread has the EDIT_THREAD_NAME permission. Private threads do not have this permission, so this condition will ensure that the Input will be disabled if the thread is a private thread.

atul requested changes to this revision.May 19 2022, 6:18 AM
atul added inline comments.
web/modals/threads/settings/thread-settings-general-tab.react.js
149–152

Looks good, can we pull this conditional outside of the disabled prop?

Maybe introduce an threadNameInputDisabled variable that gets passed to the disabled prop?

This revision now requires changes to proceed.May 19 2022, 6:18 AM

Moved conditional outside disabled prop and memoized the call to threadHasPermission so it's only called once the dependencies changed and not each time the Input is rendered.

atul requested changes to this revision.May 20 2022, 7:50 AM

Let's "un-memoize" threadNameInputDisabled and then this should be good to land.

web/modals/threads/settings/thread-settings-general-tab.react.js
136–139 ↗(On Diff #12973)

We don't need to memoize this since threadHasPermission returns a boolean.

We typically use React.useMemo when we're getting an object (eg array, function, etc) and want to preserve referential equality.

Might also make sense to memoize something that's computationally expensive, but I don't think threadHasPermission is?

This revision now requires changes to proceed.May 20 2022, 7:50 AM
abosh marked an inline comment as done.

Got it. I assumed we needed to memoize it since I was only looking at the dependency (threadInfo) but didn't realize threadNameInputDisabled only returns a boolean which is much less expensive to compute in this case.

atul added inline comments.
web/modals/threads/settings/thread-settings-general-tab.react.js
152 ↗(On Diff #12987)

We should probably rename this in another diff to something like threadSettingsOperationInProgress or something to make it more descriptive.

This revision is now accepted and ready to land.May 20 2022, 12:04 PM