Page MenuHomePhabricator

[native] Redesign `InlineSidebar` for reactions feature
ClosedPublic

Authored by jacek on Aug 12 2022, 2:33 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 4, 3:29 PM
Unknown Object (File)
Fri, Jan 3, 8:34 AM
Unknown Object (File)
Mon, Dec 30, 10:50 AM
Unknown Object (File)
Mon, Dec 23, 12:03 AM
Unknown Object (File)
Sun, Dec 22, 11:56 PM
Unknown Object (File)
Sun, Dec 22, 11:38 PM
Unknown Object (File)
Sun, Dec 22, 11:10 PM
Unknown Object (File)
Sun, Dec 22, 10:19 PM
Subscribers

Details

Summary

Introduce redesigned InlineSidebar component for native. It is now able to keep both sidebar and reactions.
Now it receives reactions as an array of strings - so it would be easy to test visually by providing an array of emojis. Probably, in the future we will keep reactions in some more complex data structure, so the types should be adjusted then.


Screenshot_Simulator_2022-08-12_115809.png (588×565 px, 33 KB)

Screenshot_Simulator_2022-08-12_115833.png (262×571 px, 26 KB)

Screenshot_Simulator_2022-08-12_120031.png (777×553 px, 481 KB)

Screenshot_Simulator_2022-08-12_120112.png (163×393 px, 12 KB)

GIF:
Screenshot_Simulator_2022-08-12_120400.gif (160×560 px, 620 KB)

Test Plan

Tested the component look on both platforms in both color themes. Also provided smoji and tested displaying reactions and/or sidebar.
The visual issues when opening message tooltip will be fixed in next diff.

Diff Detail

Repository
rCOMM Comm
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

jacek held this revision as a draft.
jacek edited the summary of this revision. (Show Details)
abosh added 2 blocking reviewer(s): atul, tomek.

Adding @atul and @tomek as blocking to get at least one of them to review this.

native/chat/composed-message.react.js
150–154 ↗(On Diff #15600)

Should this be memoized because its dependent on the value of inlineSidebarPositionStyle?

Would landing this diff cause fake placeholder reaction emojis to appear on prod?

ashoat requested changes to this revision.Aug 12 2022, 10:20 AM

Seeing @abosh's screenshots in D4825 make me fear the answer is "yes". Please do not land something like this on master...

This revision now requires changes to proceed.Aug 12 2022, 10:20 AM

Seeing @abosh's screenshots in D4825 make me fear the answer is "yes". Please do not land something like this on master...

There are no placeholder emojis, I supplied the array of emojis as props to InlineSidebar myself. I also left a similar comment on D4825.

This revision now requires review to proceed.Aug 12 2022, 11:02 AM
atul requested changes to this revision.Aug 15 2022, 9:24 AM

Tried out the changes in the iOS Simulator and it looks really good!

Couple of questions inline, feel free to re-request review if I'm misunderstanding anything.


My understanding is that the values in native/chat/chat-constants.js (eg inlineSidebarMarginTop) were in there because they were used in other places (eg textMessageItemHeight).

Are values like inlineSidebarLeftTopOffset also expected to be used outside of the ComposedMessage component? If not, can we just set the values in the ComposedMessage styles object to avoid indirection?


As an aside, do any of the changes you've made affect functions like native/chat/multimedia-message-utils:multimediaMessageItemHeight(...) or native/chat/utils:textMessageItemHeight(...)?

native/chat/composed-message.react.js
16–25 ↗(On Diff #15600)

Can we encapsulate these constants in some sort of object to clean up exports/imports?

150–154 ↗(On Diff #15600)

ComposedMessage is currently a class component (though at a glance it probably wouldn't be too difficult to convert to a functional component)

native/chat/inline-sidebar.react.js
37 ↗(On Diff #15600)

Personally prefer idx (or index) over i, but really doesn't matter.. whatever you prefer.

56 ↗(On Diff #15600)

Could probably memoize this style outside of sidebarInfo?

This revision now requires changes to proceed.Aug 15 2022, 9:24 AM
In D4824#139635, @atul wrote:

Are values like inlineSidebarLeftTopOffset also expected to be used outside of the ComposedMessage component? If not, can we just set the values in the ComposedMessage styles object to avoid indirection?

Yes, these values will be used in TooltipInlineSidebar in next diff to correctly set its position.

As an aside, do any of the changes you've made affect functions like native/chat/multimedia-message-utils:multimediaMessageItemHeight(...) or native/chat/utils:textMessageItemHeight(...)?

These functions should still work correctly, and I didn't notice any problems with incorrect height measurements during tests, as I also updated inlineSidebarHeight.

tomek requested changes to this revision.Aug 19 2022, 7:50 AM
tomek added inline comments.
native/chat/inline-sidebar.react.js
39 ↗(On Diff #15708)

Not sure about using idx as a key here. If this component become stateful and we insert a new reaction in the middle / remove a reaction from a list, we might have a bug. What about using reaction as a key?

63 ↗(On Diff #15708)

We don't need to compute this memo when threadInfo is changed, so it would be more performant if we had a variable equal to !thread and used it as a dependency.

This revision now requires changes to proceed.Aug 19 2022, 7:50 AM
This revision is now accepted and ready to land.Aug 24 2022, 2:46 AM