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

Skeleton loader on Cart PMME is absent #9107

Closed
pierorocca opened this issue Jul 16, 2024 · 42 comments
Closed

Skeleton loader on Cart PMME is absent #9107

pierorocca opened this issue Jul 16, 2024 · 42 comments
Assignees
Labels
focus: checkout payments needs demo PR should provide screenshot or gif of changes to be reviewed by product and design priority: high The issue/PR is high priority—it affects lots of customers substantially, but not critically. type: bug The issue is a confirmed bug.

Comments

@pierorocca
Copy link
Contributor

pierorocca commented Jul 16, 2024

In #8606 a skeleton was applied to the PMME in order to prevent screen shift and to provide a loading state to the BNPL offer which loads after the page in painted. I'm observing that the skeleton is missing from shortcode and Blocks sites.

@pierorocca pierorocca added type: bug The issue is a confirmed bug. priority: high The issue/PR is high priority—it affects lots of customers substantially, but not critically. focus: checkout payments labels Jul 16, 2024
@mdmoore
Copy link
Member

mdmoore commented Jul 16, 2024

@pierorocca Just tested out the cart on the develop branch and I'm seeing the skeleton still in place on cart update. Let me know the site on which it's not working and I'll take a look.

I'm observing that the skeleton is missing from shortcode and Blocks sites.

The skeleton is only present on the shortcode cart since the PMME isn't removed from the page in the cart block.

@pierorocca
Copy link
Contributor Author

pierorocca commented Jul 16, 2024

@pierorocca
Copy link
Contributor Author

Screen.Capture.on.2024-07-16.at.16-03-00.mp4
Screen.Capture.on.2024-07-16.at.16-04-40.mp4

@mdmoore
Copy link
Member

mdmoore commented Jul 17, 2024

Thanks @pierorocca! Was the skeleton loader implemented on PDPs? I think it was only present on shortcode carts. @brettshumaker might know better, but I don't remember ever seeing it on PDPs. I do see the layout shifts on page load though, so maybe this issue can serve as a task to implement skeleton loading on PDPs.

@pierorocca
Copy link
Contributor Author

Was the skeleton loader implemented on PDPs?

Am I looking for it but can't find it and any PDP related demos are static images. Maybe I missed it but it's a lot more noticeable on the PDP than the Cart no?

@pierorocca
Copy link
Contributor Author

Or maybe when computed styles got applied, it slowed down the paint enough that it's now a noticeable issue?

@pierorocca pierorocca changed the title Skeleton loader on PMME is absent Skeleton loader on Cart PMME is absent Jul 17, 2024
@pierorocca
Copy link
Contributor Author

PMME isn't removed from the page in the cart block

True for updates, but on page load? There's a lot of screen shifting happening.

@gpressutto5 gpressutto5 self-assigned this Jul 22, 2024
@FangedParakeet
Copy link
Contributor

Please add your planning poker estimate with Zenhub @gpressutto5

@FangedParakeet FangedParakeet added the needs demo PR should provide screenshot or gif of changes to be reviewed by product and design label Jul 25, 2024
@gpressutto5
Copy link
Contributor

@pierorocca I'm adding the skeleton loader to the blocks cart when it's updated. Does it resolve this issue?

Jul-25-2024 14-03-09

@pierorocca
Copy link
Contributor Author

Needs to be there on page load as well to prevent screen shifting. It's a better UX to not have things moving around.

@gpressutto5
Copy link
Contributor

@pierorocca Like in the shortcode cart implementation in #8606, we can't have the skeleton in the initial load because we don't know how large it will be, so we wait for it to be rendered once and save its size. It might not even be displayed. This is out of our control because it is an iframe rendered by Stripe. We could analyze the available data and settings and try to predict whether it is going to be displayed and try to calculate an approximate height, but inevitably, we will have things moving around when we don't get the estimated height correct. It would look like this (the proceed button is moving, but it doesn't look like that because of the flicker):

Jul-25-2024 15-26-32

@pierorocca
Copy link
Contributor Author

pierorocca commented Jul 25, 2024

Good point. Any other option to get the offer before the page is painted or to make the fetch faster?

@gpressutto5
Copy link
Contributor

Unfortunately, no. The PMME is out of our control and can only be loaded in the front end. Samir added an initial loader in #9166. It is similar to the one above, but it doesn't flicker. He also had the same problem of not knowing the correct height and had to estimate it until the component loaded for the first time. Do you think it is better to have this loader with an approximate height or not have the initial loader?

@pierorocca
Copy link
Contributor Author

pierorocca commented Jul 26, 2024

Correct me if I'm wrong, the PMME will either return nothing because the shopper doesn't qualify (country, currency, total amount) or it will return the logos on the first row and copy on the 2nd row. The copy is wrapped if the container is too narrow. There are also differences between mobile and desktop widths. So there's predictability here of what could be provided in the response.

One approach used by American Eagle is to reserve the max space needed, and if there's an offer it populates otherwise it's left blank.

The other approach I've seen is to shift down once the offer is available with the offer populating a bit more quickly than what I'm seeing from the PMME (are we preconnecting?) and there's only a single, acceptable screen shift down. @FangedParakeet indicated he's trying to minimize shift but that all of the elements we're introducing on the screen are added to the DOM independently so each is causing shift independently. Could you take a look at that work and see if it can be further improved upon?

@gpressutto5
Copy link
Contributor

@pierorocca I updated it to use the same logic as Samir used:

Jul-30-2024 13-54-18

@pierorocca
Copy link
Contributor Author

That's great! @nikkivias for QA. Nikki we're trying to limit screen shifting and buttons and bnpl messaging from jumping around independently of each other. Does the skeleton help or hinder here? It was originally implemented but suffered regression so we've brought it back with tweaks.

@pierorocca
Copy link
Contributor Author

@gpressutto5 could you enabled Google and WooPay please?

@gpressutto5
Copy link
Contributor

@pierorocca Sorry, WooPay is not set up in my environment. I recorded this video with Apple Pay! Let me know if you need me to set up WooPay to record a new video.

Jul-30-2024 18-42-30

@pierorocca
Copy link
Contributor Author

@FangedParakeet what do you think?

@pierorocca
Copy link
Contributor Author

Here's the current 8.0 experience for comparison:

v7f8Lg.mp4

@pierorocca
Copy link
Contributor Author

pierorocca commented Jul 30, 2024

@gpressutto5 I think your changes looks better in comparison? Is the slow Apple Pay rendering due to your location or local dev?

@FangedParakeet
Copy link
Contributor

@FangedParakeet what do you think?

Here's what @gpressutto5's changes look like on my local with WooPay & GPay enabled as well.

Screen.Recording.2024-07-30.at.8.30.10.PM.mov

There's a bit of extra spacing around the PMME, but the loading of that specific element looks smooth enough. The express checkout buttons are still making the page leap around quite erratically, but possibly there's potential to implement a similar preloader in a separate issue to improve that.

@pierorocca
Copy link
Contributor Author

pierorocca commented Jul 31, 2024

Thanks for the video! I slowed it down to .25 speed to get a better idea of what's going on. There's still too much happening even with these improvements.

  1. Feedback for the Blocks component/team is the cart component transition is harsh. It doesn't appear to pulse, and then there's too long of a period between when the loader is removed and when the cart is rendered. That makes it feel choppy. The total and proceed to checkout button are also rendered (3rd image) a bit before the cart summary and in the space that will be occupied by the cart summary, adding to the flurry of movement and choppiness. Are we influencing that or is that Blocks behavior?
  2. I like that the PMME loader loads at the same time as the cart. Let's make the skeleton occupy the full width of what it could take up. Looks cutoff and unbalanced.
  3. Agree on adding a separate issue for the buttons.

image

image

image

image

image

image

image

@gpressutto5
Copy link
Contributor

I updated the width and fixed an issue I found with the padding on small screens:

image

image

@pierorocca
Copy link
Contributor Author

@nikkivias question to you if we should have a skeleton loader for the PMME and prevent screen shift or ditch the loader and have the PMME smoothly shift the screen down?

@nikkivias
Copy link

@pierorocca @gpressutto5 Better to use a skeleton loader, engagement is enhanced when users see that content is about to load. However, the skeleton should closely resemble the layout of the fully loaded element to manage expectations correctly.

So something like this, and make sure the height doesn't shift

@pierorocca
Copy link
Contributor Author

That looks sweet. Ty!

@gpressutto5
Copy link
Contributor

@pierorocca @nikkivias We don't know if the body text will have 1 or 2 lines after loading, so I made the bottom loader skeleton slightly bigger. What do you think?

Aug-07-2024 13-43-37

Aug-07-2024 13-44-58

@pierorocca
Copy link
Contributor Author

True, can you show what it would look like with one line only?

@gpressutto5
Copy link
Contributor

@pierorocca The second gif has only one line of text in its body. The first gif has two lines.

@pierorocca
Copy link
Contributor Author

pierorocca commented Aug 7, 2024

Ah gotcha one line of text plus the line of logos. I believe if there's only 1 logo, both logo and text are on one line?

image

image

@gpressutto5
Copy link
Contributor

Aug-08-2024 13-30-01

Aug-08-2024 13-32-08

@pierorocca
Copy link
Contributor Author

So net we could have 1 to 3 lines and we don't know in advance, is that an accurate summary? @nikkivias fyi.

@gpressutto5
Copy link
Contributor

gpressutto5 commented Aug 8, 2024

Yes, that's correct. To be fair, we can potentially have more than 3 lines if the site uses a wide font with a large font size, but that's extremely unlikely as many other components would look broken.

@nikkivias
Copy link

@gpressutto5 Can you tell me what is the minimum and maximum height of the widget once its loaded? I want to create a loader design that will account for both scenarios and anything in between.

@gpressutto5
Copy link
Contributor

gpressutto5 commented Aug 14, 2024

@nikkivias

TLDR: most likely 12px - 70px, but it can be anything.

We can't say, because it uses the style from the website. Here are some variations I could reproduce using Storefront just by updating the price or the number of methods available, except for the last one. However, there are infinite possibilities by changing the theme or updating the font style (as in the last example).
It can be any size, but most likely >12px as it would be too small to read if it were smaller. As for the maximum height, it might be around 70px, but there's no limit. If the website uses a wide font with a large font size it could be larger than that (as in the last example).

Text height iFrame height (with margin/padding)
image 16px 26px
image 28px 28px
image 36px 44px
image 36px 44px
image 39px 47px
image 60px 68px
image 42px 50px
image 60px 68px
image 68px 76px

@nikkivias
Copy link

@gpressutto5 you shared a gif of how it works on Slack:

Aug-14-2024 14-20-44

The shifting doesn't look problematic to me because it is alleviated by the smooth motion. Unlike if it were to suddenly just appear, which would be jarring. Since there will be some cases where nothing will be loaded at all (in cases where the cart totals doesn't qualify) I am inclined to propose that we don't use a loader at all. Just need to make sure the appearance of the widget is smooth.

Thoughts? @pierorocca

@pierorocca
Copy link
Contributor Author

pierorocca commented Aug 15, 2024

Just need to make sure the appearance of the widget is smooth.

@nikkivias I agree with this. After seeing the loader and not being able to predict the right sizing, it made me rethink if it's needed at all. The smoothness is key so that it feels intentional.

@gpressutto5
Copy link
Contributor

@pierorocca @nikkivias

  1. We use this same loader on the shortcode cart and product pages. Should we remove them as well? cc @FangedParakeet @mdmoore
  2. In the first implementation, the skeleton loader only appeared when updating the cart after the initial load. Can we leave it without a loader in this case as well?

Jul-25-2024 14-03-09

@pierorocca
Copy link
Contributor Author

If it's smooth we can follow the same approach.

On refresh, similarly if we can keep it super smooth and prevent screen shifting, then I'm ok removing the loader.

@nikkivias ?

@gpressutto5
Copy link
Contributor

Without a skeleton loader it just updates the text.

Aug-15-2024 12-30-48

@pierorocca
Copy link
Contributor Author

Looks pretty seamless to me and updates in the same way as tax, totals, etc. do. so it's all consistent.

@gpressutto5 gpressutto5 closed this as not planned Won't fix, can't repro, duplicate, stale Aug 15, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
focus: checkout payments needs demo PR should provide screenshot or gif of changes to be reviewed by product and design priority: high The issue/PR is high priority—it affects lots of customers substantially, but not critically. type: bug The issue is a confirmed bug.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants