Page MenuHomePhabricator

[native] Compute typeahead suggestions and matched strings outside the class component
ClosedPublic

Authored by rohan on Dec 18 2023, 6:49 AM.
Tags
None
Referenced Files
F3639518: D10386.id34997.diff
Sat, Jan 4, 5:54 AM
F3639510: D10386.id34801.diff
Sat, Jan 4, 5:47 AM
F3639496: D10386.id34804.diff
Sat, Jan 4, 5:35 AM
Unknown Object (File)
Wed, Jan 1, 7:18 PM
Unknown Object (File)
Wed, Jan 1, 2:33 PM
Unknown Object (File)
Wed, Jan 1, 12:15 PM
Unknown Object (File)
Wed, Jan 1, 12:15 PM
Unknown Object (File)
Wed, Jan 1, 12:15 PM
Subscribers

Details

Summary

In order to use a hook that will get user mention candidates that are resolved, we need to first extract the logic to compute user chat mention candidates outside of the class component. There are two steps to this:

  1. Lift the selectionState out of the class component
  2. Move the computation logic out of the class component

This diff just covers step 2. We should now be able to refactor getMentionTypeaheadUserSuggestions into a hook that will allow for @ mentioning ENS users by their name.

Addresses https://linear.app/comm/issue/ENG-6112/update-native-chat-input-bar-to-make-it-easier-to-use-hooks

Depends on D10385

Test Plan

Once again confirmed that there were no regressions introduced by this changed. I also added some console.log statements for suggestions both off master and this diff, and made sure that I didn't notice any additional re-renderings caused by this change.

Diff Detail

Repository
rCOMM Comm
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

native/chat/chat-input-bar.react.js
1295–1299 ↗(On Diff #34801)

Essentially copy and pasted from the class component above

1307–1308 ↗(On Diff #34801)

This is so we keep the old behavior of not showing the typeahead tooltip if typeaheadRegexMatches is null

1312–1331 ↗(On Diff #34801)

Essentially copy and pasted from the class component above

Harbormaster returned this revision to the author for changes because remote builds failed.Dec 18 2023, 6:59 AM
Harbormaster failed remote builds in B25186: Diff 34801!
rohan requested review of this revision.Dec 18 2023, 8:52 AM

Seems like a straightforward refactor

This revision is now accepted and ready to land.Dec 20 2023, 10:14 PM