Page MenuHomePhabricator

[web] [fix] update menu button size, correct addition bottom padding
ClosedPublic

Authored by benschac on Mar 3 2022, 7:53 AM.
Tags
None
Referenced Files
F3726846: D3331.id10242.diff
Wed, Jan 8, 8:36 PM
F3726845: D3331.id10223.diff
Wed, Jan 8, 8:36 PM
F3726844: D3331.id10222.diff
Wed, Jan 8, 8:36 PM
F3726843: D3331.id10162.diff
Wed, Jan 8, 8:36 PM
F3726842: D3331.id10091.diff
Wed, Jan 8, 8:36 PM
F3726841: D3331.id10044.diff
Wed, Jan 8, 8:36 PM
F3726828: D3331.id.diff
Wed, Jan 8, 8:35 PM
F3726785: D3331.diff
Wed, Jan 8, 8:28 PM

Details

Summary

fix menu button size, including fixing the additional 2-3px bottom padding from the button element

Image 2022-03-03 at 10.49.30 AM.jpg (378×710 px, 23 KB)

Image 2022-03-03 at 9.13.55 AM.jpg (266×1 px, 47 KB)

Confirming vertical-align is the functionality that we want:

Image 2022-03-09 at 11.28.18 AM.jpg (1×1 px, 191 KB)

Test Plan

check the figma file, additionally, if you want to render the component locally, set the false conditions in thread-menu menu items to true

Diff Detail

Repository
rCOMM Comm
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

web/chat/thread-menu.css
5 ↗(On Diff #10044)

https://stackoverflow.com/questions/24626908/how-to-get-rid-of-extra-space-below-svg-in-div-element

All of the SWM have display: inline-block embedded into the in-line styling of the icon. I tried verticle-align: top without any luck. This seems like the best solution.

atul requested changes to this revision.Mar 3 2022, 11:08 AM
atul added subscribers: marcin, jacek.

All of the SWM have display: inline-block embedded into the in-line styling of the icon.

Can we just change that to avoid having to hack around it?

There's been a lot of churn getting these icons integrated correctly... hopefully we could batch this SVG change with the existing task for integrating all icons (https://linear.app/comm/issue/ENG-822/import-all-icons-from-swm-icon-pack)?


Alternatively, noticed in the SWMansionIcon v2 Dribbble post (https://dribbble.com/shots/17310944-Icons-Figma-Plugin-SWM-Icon-Pack) that there's an accompanying package: https://github.com/kamilagraf/react-swm-icon-pack. Is this something we should consider using instead? The SWM team might have more context on the state of this package, if it's maintained by SWMansion, etc? cc: @palys-swm @def-au1t @karol-bisztyga @adrian @marcinwasowicz

This revision now requires changes to proceed.Mar 3 2022, 11:08 AM
In D3331#89740, @atul wrote:

All of the SWM have display: inline-block embedded into the in-line styling of the icon.

Can we just change that to avoid having to hack around it?

I don't think it's a hack. But, I haven't been able to.

web/chat/thread-menu.css
5 ↗(On Diff #10044)

I added a style prop to https://phabricator.ashoat.com/D3346 to fix this issue.

web/chat/thread-menu.react.js
188 ↗(On Diff #10091)

We need to use an inline style here: https://github.com/aykutkardas/react-icomoon/blob/master/src/index.tsx#L71

because the Icomoon component uses an inline style. I know this isn't a norm and we typically stay away from inline styles.

We're using a block level element so we don't have to hard code a height, https://stackoverflow.com/questions/24626908/how-to-get-rid-of-extra-space-below-svg-in-div-element

confirming the button is now the correct 24x24 height:

Image 2022-03-04 at 5.00.26 PM.jpg (290×666 px, 24 KB)

ADDRESS INLINE COMMENT BEFORE LANDING

web/chat/thread-menu.react.js
188 ↗(On Diff #10091)

We can at least define { display: 'block' } in a higher context so it doesn't get redeclared on every render

In D3331#89740, @atul wrote:

All of the SWM have display: inline-block embedded into the in-line styling of the icon.

Can we just change that to avoid having to hack around it?

There's been a lot of churn getting these icons integrated correctly... hopefully we could batch this SVG change with the existing task for integrating all icons (https://linear.app/comm/issue/ENG-822/import-all-icons-from-swm-icon-pack)?


Alternatively, noticed in the SWMansionIcon v2 Dribbble post (https://dribbble.com/shots/17310944-Icons-Figma-Plugin-SWM-Icon-Pack) that there's an accompanying package: https://github.com/kamilagraf/react-swm-icon-pack. Is this something we should consider using instead? The SWM team might have more context on the state of this package, if it's maintained by SWMansion, etc? cc: @palys-swm @def-au1t @karol-bisztyga @adrian @marcinwasowicz

I don't knot why having display: inline-block on icons is an issue... it sounds reasonable, and if we want a different behavior, we should wrap it in a tag with different display. Regarding the icon pack, I would need to ask some people. This project on github isn't hosted on official Software Mansion account - not sure what's the reason for that.

Adding @palys-swm as a blocking reviewer based on the previous comment

web/chat/thread-menu.react.js
175 ↗(On Diff #10162)

Why didn't you just move this to the top level (outside of the ThreadMenu function)? This works too but the React.useMemo seems a bit unnecessary

update svg in buttons site wide to align correctly

I don't knot why having display: inline-block on icons is an issue... it sounds reasonable, and if we want a different behavior, we should wrap it in a tag with different display. Regarding the icon pack, I would need to ask some people. This project on github isn't hosted on official Software Mansion account - not sure what's the reason for that.

instead of changing the display of inline block I just changed the behavior of SVG in button elements to align correctly per https://stackoverflow.com/questions/24626908/how-to-get-rid-of-extra-space-below-svg-in-div-element.

I think this solution makes the most sense.

benschac edited the summary of this revision. (Show Details)
This revision is now accepted and ready to land.Mar 9 2022, 10:17 AM