Page MenuHomePhabricator

[native] fix missing threadInfo in thread settings
ClosedPublic

Authored by michal on Sep 15 2022, 2:29 AM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 6, 12:12 AM
Unknown Object (File)
Sun, Jan 5, 7:55 PM
Unknown Object (File)
Sun, Jan 5, 7:55 PM
Unknown Object (File)
Sun, Jan 5, 2:49 PM
Unknown Object (File)
Sat, Jan 4, 3:27 PM
Unknown Object (File)
Tue, Dec 31, 10:11 AM
Unknown Object (File)
Tue, Dec 31, 10:10 AM
Unknown Object (File)
Tue, Dec 31, 10:10 AM
Subscribers

Details

Summary

Logging out while sidebar settings are opened causes a crash.
https://linear.app/comm/issue/ENG-1721/

After logging out, we lose redux state and crash because threadInfo is undefined. In this case we should fall back onto threadInfo in the navigation params.

Test Plan
  1. Check if the app doesn't crash after logging out with sidebar settings open.
  2. Check if the app doesn't crash with non-sidebar thread settings open.
  3. Check that if you change some value in settings (e.g. color) and log out, the settings screen that "blinks" for a moment has an updated value.

Diff Detail

Repository
rCOMM Comm
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

ashoat requested changes to this revision.Sep 16 2022, 7:06 AM

I can review this one since I have the most context. Overall, great work, but some changes requested inline

native/chat/settings/thread-settings.react.js
242–243

Don't think this needs to be removed. It's correct – when ThreadSettings is opened, threadInfo should exist

294–296

If you want to move getThreadInfo to ConnectedThreadSettings, then I think this logic for updating props.route.params.threadInfo should've been moved to ConnectedThreadSettings too. That way you can keep looking at reduxThreadInfo specifically (which I think is more clear), and I also think this sort of logic is more readable as a React.useEffect anyways

(Separately, there is no need to check if newThreadInfo is truthy here... your changes should guarantee that it is always truthy)

298–305

These changes make sense, but I would also consider moving them to a React.useEffect in ConnectedThreadSettings... feels a little cleaner that way

1132

(This is the actual line that was causing problems)

This revision now requires changes to proceed.Sep 16 2022, 7:06 AM
native/chat/settings/thread-settings.react.js
242–243

Should be moved to ConnectedThreadSettings though, and should be checking reduxThreadInfo specifically

native/chat/settings/thread-settings.react.js
242–243

Only thing to do in this diff now is just to move this invariant to ConnectedThreadSettings and have it check reduxThreadInfo

294–296

Ah, I see you did this in D5143!! Disregard here

298–305

Since D5143 handles the above, we can address this there

Please address the inline comment before landing!

native/chat/settings/thread-settings.react.js
5 ↗(On Diff #16811)

Nit: we usually just specify React.useEffect on the team, rather than separately importing it. Would you mind removing this import?

This revision is now accepted and ready to land.Sep 19 2022, 6:53 AM