Popover case studies

Swetha Gopalakrishnan
Swetha Gopalakrishnan
Saurabh Rajpal
Saurabh Rajpal

Popovers are everywhere on the web. You can see them in menus, toggletips, and dialogs, used for features such as account settings, disclosure widgets, and product card previews. Despite how prevalent these components are, building them in browsers is still surprisingly cumbersome. To resolve this, a new set of declarative HTML APIs for building popovers are coming to browsers, the first of these being the Popover API.

Popover is part of Baseline Newly Available.

Browser Support

  • Chrome: 114.
  • Edge: 114.
  • Firefox: 125.
  • Safari: 17.

Source

A popover is commonly confused with a dialog. However there are some key differences in their behavior. A dialog element opened with dialog.showModal (a modal dialog), is an experience which requires explicit user interaction to close the modal. A popover supports light-dismiss. A modal dialog does not. A modal dialog makes the rest of the page inert. A popover does not. Read more about the differences.

This article is is part of a series which discusses how ecommerce companies enhanced their website using new CSS and UI features. In this article, discover how Tokopedia implemented and benefited from the Popover API.

Tokopedia

Using popover attributes reduced up to 70% lines of code in React. The modal can be natively controlled by HTML instead of requiring event handling in JavaScript and using React.createPortal for moving the modal DOM to the end of document.body. We are also able to use @starting-style to animate the opening and closing of the popover.—Andy Wihalim, Senior Software Engineer, Tokopedia.

Tokopedia's Product Detail Pages (PDP) contain multiple product images for each product. When the product thumbnail is clicked, a modal is opened to show the enlarged image. This is a common pattern used in ecommerce websites.

Code

Tokopedia uses React for their frontend development. Before implementing the popover API for this modal, they used a DOM modal and a button. The button changed the React state to open the modal. With the popover API, they specify a popovertarget attribute in the element which opens the popover with a value that is the same as the ID of the popover element.

With this basic implementation, the popover works but appears and disappears without any animation. To create a smooth entry and exit animation for the popover, use :popover-open and @starting-style and allow animation of discrete properties. In the following code example, the popover scales in and out using the transform: 'scale()'property.

This code example shows how to implement entry and exit animations for the popover API.

<Thumbnail popovertarget="medialightbox" />
<MediaLightbox popover id="medialightbox" />
export const cssModalWrapper = css({
  background: NN0,
  border: 'none',
  borderRadius: '.625rem',
  width: 1024,
  padding: 24,

  '&::backdrop': {
    opacity: 0,
    transitionProperty: 'opacity, display',
    transition: '.25s ease-out',
    transitionBehavior: 'allow-discrete',
  },

  transitionProperty: 'transform, opacity, display',
  transition: '.25s ease-out',
  transitionBehavior: 'allow-discrete',

  '@starting-style': {
    transform: 'scale(1)',
    opacity: 1,
  },
  transform: 'scale(0.8)',
  opacity: 0,

  '&:popover-open': {
    '@starting-style': {
      transform: 'scale(0.8)',
      opacity: 0,
    },
    transform: 'scale(1)',
    opacity: 1,
  },
});

To cater to browsers that don't support the popover API, Tokopedia implemented the popover-polyfill by oddbird, which is only 3.2 KB with gzip compression. They were satisfied with the polyfill as it worked well and did not cause performance regressions. Overall, they were able to reduce up to 70% lines of code in React with the popover API.

Things to consider when using the Popover API

Tokopedia uses React, and the team achieved code splitting by unmounting the popover component for pages which don't use it, then doing a code split for the popover content. This way, they reduced the size of their initial request.

Consider combining popovers with CSS anchor positioning (coming soon to Chrome) to position them relative to other elements. This is helpful for menus and tooltips for example.

Resources

Explore the other articles in this series that talk about how ecommerce companies benefited from using new CSS and UI features such as Scroll-driven animations, popover, container queries and the has() selector.