Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

frontend - feat: add new list view of users on map #4848 #5294

Open
wants to merge 18 commits into
base: develop
Choose a base branch
from

Conversation

marco-digennaro
Copy link
Contributor

@marco-digennaro marco-digennaro commented Dec 4, 2024

Closes #4848

Web frontend checklist

  • [ x] Formatted my code with yarn format
  • [x ] There are no warnings from yarn lint --fix
  • There are no console warnings when running the app
  • Added any new components to storybook
  • Added tests where relevant
  • All tests pass
  • [ xx] Clicked around my changes running locally and it works
  • Checked Desktop, Mobile and Tablet screen sizes

Copy link

vercel bot commented Dec 4, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Updated (UTC)
couchers ✅ Ready (Inspect) Visit Preview Jan 2, 2025 0:12am

@jesseallhands
Copy link
Contributor

@marco-digennaro this is looking really good! I'm super excited to this feature to be rolled out as is should improve mobile QoL by a lot.

Here are a few things I noticed in the preview (from a UI/UX perspective, I'm not a FE dev):

The spacing between the cards is too much and takes up a lot of screen real estate:
Screenshot_20241204_193034_Firefox

When the user selects a single pin, it should not show the expand drawer arrow ^ because there is no point of expanding the drawer upward for a single user card. Also, the spacing above and below the card is too much:
Screenshot_20241204_192531_Firefox

When no pin is selected, the drawer still appears, which should not happen:
Screenshot_20241204_192819_Firefox

After clicking on a pin, if the user zooms in and clicks on "search in this area" the card for the previously clicked pin persists, even if that pin is no longer in the search area:
https://github.com/user-attachments/assets/e32ba8e2-1ccf-444a-81c8-49f5864811c6

It's possible some of the map behavior issues may be caused by the next instance, but I'm not sure. Perhaps @nabramow and/or @darrenvong can assist here in helping assess the causes.

@bakeiro
Copy link
Contributor

bakeiro commented Dec 4, 2024

this is so cool feature 🤩 , thanks for this!

@bakeiro
Copy link
Contributor

bakeiro commented Dec 4, 2024

code looks great, once the UI feedback is done, and the build isn't red I can re-check and most likely approve :)

Comment on lines 10 to 71
const useStyles = makeStyles((theme) => ({
drawer: {
/* */
width: "100%",
height: "350px",
overflowY: "auto",
"&[data-open-state='true']": {
height: "100%",
top: "56px",
position: "fixed",
bottom: 0,
left: 0,
zIndex: theme.zIndex.drawer,
backgroundColor: theme.palette.background.default,
},
},
singleResult: {
width: "100%",
display: "flex",
flexDirection: "column",
justifyContent: "center",
alignItems: "center",
maxHeight: "400px",
paddingBottom: theme.spacing(2),
overflowY: "auto",
},
verticalList: {
display: "flex",
flexDirection: "column",
gap: theme.spacing(2),
padding: theme.spacing(2),
"& .MuiCard-root": {
height: "auto",
width: "100%",
[theme.breakpoints.down("md")]: {
height: "auto",
"& .MuiCardContent-root": {
height: "auto",
},
"& .MuiCardActionArea-root": {
height: "100%",
},
},
},
},
openButton: {
width: "100%",
marginLeft: 0,
},
closeButton: {
width: "100%",
marginLeft: 0,
position: "sticky",
top: 0,
backgroundColor: theme.palette.background.default,
borderRadius: 0,
zIndex: theme.zIndex.drawer,
},
icon: {
fontSize: "3rem",
},
}));
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since this is a new component, could you please use the new MUI styled way of doing the CSS? We're slowly trying to remove all of this way as it's not compatible with the next MUI version.

Just search "Styled" for some examples or you can look at: app/web/components/Footer/Footer.tsx.

@marco-digennaro
Copy link
Contributor Author

It's possible some of the map behavior issues may be caused by the next instance, but I'm not sure. Perhaps @nabramow and/or @darrenvong can assist here in helping assess the causes.

yes, i tried to investigate, it's cause of this piece of code
` const wasResultFound =
resultsList?.find(
(value) => value.user?.userId === selectedResult?.userId
) !== undefined;

if (!wasResultFound && selectedUserData.data) {
resultsList = [{ user: selectedUserData.data, rank: 0, snippet: "" }];
}`
which persist che selected user in the search result
@nabramow is it necessary?

@marco-digennaro
Copy link
Contributor Author

@bakeiro @nabramow @jesseallhands made some adjustments, please check :)

@jesseallhands
Copy link
Contributor

jesseallhands commented Dec 5, 2024

The spacing issues are completely resolved! Thanks!

While testing, I ran into an issue where when I clicked on certain pins, it would not center the card within the drawer (it would land somewhere in between cards) see video below:

Screen_Recording_20241205_200746_Firefox_1.mp4

There is also some strange behavior when drawer initially opens. It's almost as if it is showing my own card (and the Chevron for the drawer) just before opening or just before closing. See video:

Screen_Recording_20241205_201332_Firefox.mp4

In addition to resolving that problem, I would also recommend using mountOnEnter and unmountOnExit so the drawer slides in from the bottom upward, which also hints to the user that it is a slidable drawer. I think the same can be used to slide down the drawer when minimizing from the "full screen" list view to the Single-Card view and also when closing the drawer altogether.

Thanks once again for working on this feature! I'm very excited about it and I think mobile users will really love it!

@bakeiro
Copy link
Contributor

bakeiro commented Dec 5, 2024

Screen_Recording_20241205_201332_Firefox.mp4
In addition to resolving that problem, I would also recommend using mountOnEnter and unmountOnExit so the drawer slides in from the bottom upward, which also hints to the user that it is a slidable drawer. I think the same can be used to slide down the drawer when minimizing from the "full screen" list view to the Single-Card view and also when closing the drawer altogether.

Although I agree on this I am not sure how we can solve this as first it is nothing new, it is something old [and in production already....]

The behavior we see on the video is the difference between openning a result which is on the loaded list vs opening a result which isn't in this list, (you may wonder which list is the one on the left in the desktop version).

the background for this is, at the beginning I implemented to show only a subset of results, plus the pagination, what happened is that we wanted to implement to show all users at the first render, because it was something that sold very well.

Since loading all users in the list isn't possible (cause it's to big) therefore, when you click on a user, if this is within the list, it moves and puts the user in the center, otherwise it clears the list temporarily and shows specifically that particular user.

Edit:
I thinking about 2 possible solutions:

  • Not to show a list at the beginning, in the first render, then whenever you click on a pin, it shows that particular user.
    And once you do a search then it shows that result in the list.

  • Use pagination, and display on the map only what's on the list, plus to prevent the map seeing empty, display the user's surroundings (without much zoom).

apart of this we can create a investigation ticket to find a better solution

@marco-digennaro
Copy link
Contributor Author

There is also some strange behavior when drawer initially opens. It's almost as if it is showing my own card (and the Chevron for the drawer) just before opening or just before closing. See video:

i think there's a different behaviour of the map between mobile and desktop, and apparently i can't reproduce that bug on desktop browser with mobile view.
if i understood the problem on mobile the results change on map move (?), if so i added a (maybe) fix, but again, i couldn't reproduce it so i hope it would work.

PS: where can i find the vercel previews?

@bakeiro
Copy link
Contributor

bakeiro commented Dec 6, 2024

There is also some strange behavior when drawer initially opens. It's almost as if it is showing my own card (and the Chevron for the drawer) just before opening or just before closing. See video:

i think there's a different behaviour of the map between mobile and desktop, and apparently i can't reproduce that bug on desktop browser with mobile view. if i understood the problem on mobile the results change on map move (?), if so i added a (maybe) fix, but again, i couldn't reproduce it so i hope it would work.

PS: where can i find the vercel previews?

Vercel preview :)
image

@marco-digennaro
Copy link
Contributor Author

There is also some strange behavior when drawer initially opens. It's almost as if it is showing my own card (and the Chevron for the drawer) just before opening or just before closing. See video:

i think there's a different behaviour of the map between mobile and desktop, and apparently i can't reproduce that bug on desktop browser with mobile view. if i understood the problem on mobile the results change on map move (?), if so i added a (maybe) fix, but again, i couldn't reproduce it so i hope it would work.

PS: where can i find the vercel previews?

it didnt work, i need to investigate further why it happens, or if @bakeiro knows already where to look, please write me so i'll try to fix :)

@bakeiro
Copy link
Contributor

bakeiro commented Dec 6, 2024

There is also some strange behavior when drawer initially opens. It's almost as if it is showing my own card (and the Chevron for the drawer) just before opening or just before closing. See video:

i think there's a different behaviour of the map between mobile and desktop, and apparently i can't reproduce that bug on desktop browser with mobile view. if i understood the problem on mobile the results change on map move (?), if so i added a (maybe) fix, but again, i couldn't reproduce it so i hope it would work.
PS: where can i find the vercel previews?

it didnt work, i need to investigate further why it happens, or if @bakeiro knows already where to look, please write me so i'll try to fix :)

I believe that both issues can be solved if we solve the list issue, as I say before depends how we want to solve it

  • One solution could be not to show a list at the beginning, then when you click on a pin, it shows that particular user
  • Use Pagination + subsets, and in the first render, show the user surrondings, plus don't allow the user to see the map zommed out

if other person has other suggestion/solution please say, I personally think the best one it's to do the first solution [not show the list at the beginning] and then create a re-search ticket for the future.

If this solution is outside the scope of this PR/ticket I can create another ticket for this :) [then we can merge both PRs together, or you can do a PR from this PR as you prefer...]

write me on Slack if you need more info about this!

@bakeiro
Copy link
Contributor

bakeiro commented Dec 6, 2024

Update: Marco and I talked about this, our plan it's to merge this PR (unless a new bug is found, code suggestions or whatever) and then we will do pair programming to see how to address these bugs [in another PR/ticket]

bakeiro
bakeiro previously approved these changes Dec 6, 2024
@bakeiro
Copy link
Contributor

bakeiro commented Dec 15, 2024

to give context:

Screenshot_20241204_192819_Firefox

this is not related with this PR, will be solved once this gets merged :)

@bakeiro bakeiro requested review from nabramow and bakeiro December 15, 2024 14:44
@@ -174,52 +172,35 @@ export default function SearchPage({
locationResult.location.lat,
]);

/**
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixes the bug when a selected result remains even after searching

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry I just saw this. I think it makes more sense to set this in the same place the search happens rather than a separate useEffect? So where you set the new location, then set this there instead.

@@ -123,6 +128,10 @@ export default function SearchResultsList({
.flatMap((page) => page.resultsList)
.filter((result) => result.user);

if (isMobile && !wasSearchPerformed && !searchFromDashboard) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fix blinking

@bakeiro bakeiro self-requested a review December 15, 2024 14:57
Copy link
Collaborator

@nabramow nabramow left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Okay two things here:

  1. The up and down arrows are really big, thick and have a lot of padding around them. That seems non-standard to me. Especially since mobile space is limited, could you make the arrow smaller and less pixels of padding above and below?

  2. Can we just always show this version on mobile even if there is only one result? It seems confusing that it switches when there's more results. I think it's fine if it shows even with one result for consistency.

Otherwise works great functionality-wise so just those 2 design things!

@bakeiro
Copy link
Contributor

bakeiro commented Dec 29, 2024

  1. Can we just always show this version on mobile even if there is only one result? It seems confusing that it switches when there's more results. I think it's fine if it shows even with one result for consistency.

@nabramow

I totally agree here, the problem is that we show all the users the first time (bc is a big selling point apparently) and this creates issues, since we need to change the behavior after the user performs a search/applies a filter, I've been complaining about this during long time, I've created this ticket to explore different solutions #5348

we can talk about this (and we should) but is basically this switch between the first render and after the search which causes a lot of issues, but apparently is better this behavior inconsistency than not showing all the users at the first render...

@bakeiro
Copy link
Contributor

bakeiro commented Dec 29, 2024

I'm thinking about a solution for this... I came up with this idea:
Clicking a result on the map will always show a small bubble on the botton, regardless we display all the users on the map or only a subset, to avoid the weird behaviour, and we display the box with the arrow to toggle the users list only when there is a search/filter (aka subset)

I feel this way it's better than re-locating the list on the button to display the selected user... [basically something like airbnb is doing!]

more info #5405

@bakeiro
Copy link
Contributor

bakeiro commented Dec 29, 2024

small CSS change pushed :)

@nabramow
Copy link
Collaborator

@bakeiro This looks way better, thanks for making that change! Way more consistent this way.

Just that one comment about the arrow then, would it be possible to make the arrow a bit smaller? Especially the up arrow seems huge and on mobile it's usually thinner and smaller.

@bakeiro bakeiro requested a review from nabramow January 2, 2025 12:08
@bakeiro
Copy link
Contributor

bakeiro commented Jan 2, 2025

making arrow smaller again, please, let me know if its good enough now @nabramow :)

backgroundColor: theme.palette.background.default,
borderRadius: 0,
zIndex: theme.zIndex.drawer,
"& svg": { fontSize: "3rem" },
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would remove this here

boxShadow: "0px -4px 5px 0px rgba(17, 17, 26, 0.08)",
backgroundColor: theme.palette.background.default,
maxHeight: "50px",
"& svg": { fontSize: "4rem" },
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

and remove this here (they are different sizes by the way). see below

Comment on lines +60 to +79
const StyledVerticalList = styled(List)(({ theme }) => ({
display: "flex",
flexDirection: "column",
alignItems: "center",
gap: theme.spacing(2),
padding: theme.spacing(2),
"& .MuiCard-root": {
height: "auto",
width: "100%",
[theme.breakpoints.down("md")]: {
height: "auto",
"& .MuiCardContent-root": {
height: "auto",
},
"& .MuiCardActionArea-root": {
height: "100%",
},
},
},
}));
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
const StyledVerticalList = styled(List)(({ theme }) => ({
display: "flex",
flexDirection: "column",
alignItems: "center",
gap: theme.spacing(2),
padding: theme.spacing(2),
"& .MuiCard-root": {
height: "auto",
width: "100%",
[theme.breakpoints.down("md")]: {
height: "auto",
"& .MuiCardContent-root": {
height: "auto",
},
"& .MuiCardActionArea-root": {
height: "100%",
},
},
},
}));
const StyledVerticalList = styled(List)(({ theme }) => ({
display: "flex",
flexDirection: "column",
alignItems: "center",
gap: theme.spacing(2),
padding: theme.spacing(2),
"&:first-child": {
paddingTop: 0,
},
"& .MuiCard-root": {
height: "auto",
width: "100%",
[theme.breakpoints.down("md")]: {
height: "auto",
"& .MuiCardContent-root": {
height: "auto",
},
"& .MuiCardActionArea-root": {
height: "100%",
},
},
},
}));

Copy link
Collaborator

@nabramow nabramow Jan 3, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add this &:first-child to remove the padding from the top item so there's not so much space

<StyledDiv>
{shouldShowOpenButton && (
<StyledOpenButton onClick={toggleDrawer(true)}>
<ExpandLess />
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
<ExpandLess />
<ExpandLess sx={{ fontSize: "24px"}}/>

Do size here so you're not targeting all svgs. I think for icons a static size is okay, especially as this is only mobile.

<StyledDrawer open={open}>
{open && (
<StyledCloseButton onClick={toggleDrawer(false)}>
<ExpandMore />
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
<ExpandMore />
<ExpandLess sx={{ fontSize: "24px"}}/>

Same here.

Comment on lines +50 to +52
'.maplibregl-ctrl-bottom-right': {
bottom: '7px !important',
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm a little nervous about all these fixes mixed in here. Could we keep this PR to this feature and put the fixes in another PR?

Copy link

@nexagoai nexagoai Jan 8, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

hmmm it's related 😅 I can explain where and how (but lately I don't have much time for this 😞)

@nabramow
Copy link
Collaborator

nabramow commented Jan 3, 2025

Looks like prettier needs to run FYI.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[map] [mobile] add new list view of users on map
5 participants