Skip to content
+

Popup

The Popup component is a utility that lets you display content in tooltips and popovers.

Introduction

The Popup is a utility component for creating various kinds of popups. It relies on the third-party Floating UI library for positioning.

Component

Usage

After installation, you can start building with this component using the following basic elements:

import { Unstable_Popup as Popup } from '@mui/base/Unstable_Popup';

export default function MyApp() {
  return <Popup>{/* the popup's content */}</Popup>;
}

Basics

By default, the Popup is mounted to the DOM when its open prop is set to true, and removed from the DOM when open is false.

anchor is passed as the reference element to Floating UI's useFloating hook. The children are placed in a Portal prepended to the body of the document to avoid rendering problems. You can disable this behavior with disablePortal prop. See how it's done in the Disable portal section below.

The following demo shows how to create and style a basic popup. Click Toggle Popup to see how it behaves:

Press Enter to start editing

Customization

Placement

The Popup's default placement is bottom. You can change it using the placement prop. Try changing this value to top in the interactive demo below to see how it works:

Placement value:
Anchor

Transitions

You can animate the opening and closing of the Popup using CSS transitions, CSS animations, or third-party animation libraries.

To enable transitions, first set the withTransition prop. This will make the Popup wait for the exit animation to finish before unmounting.

Then, instead of placing the Popup contents directly as its children, wrap them in a function that receives an object with requestOpen: boolean, onEnter: () => void, and onExited: () => void fields.

Run the open transition when requestOpen becomes true and the close transition when it changes to false. Call the onEnter once the entering transition is about to start. When the exit transition finishes, call the provided onExited function to let the Popup know it can be unmounted.

If using CSS transitions or animations, you can use the onTransitionEnd or onAnimationEnd events, respectively, to detect when the transition is over.

Press Enter to start editing

Disable portal

To render the Popup where it's defined in the source, without using React portals, pass in the disablePortal prop. Note that it may cause visual clipping if a Popup is placed in a container without visible overflow.

You can use fixed positioning to prevent clipping when not using portals. The Popup has the strategy prop which is responsible for determining how the position is calculated. When set to "fixed", the fixed CSS position will be used and the Popup won't be subject to overflow hiding.

Press Enter to start editing

Floating UI middleware

If you need to modify the underlying Floating UI middleware, you can do so via the middleware prop. By default, the Popup uses the offset (with the value provided in the offset prop) and flip functions. If you provide your own middleware array, these defaults won't be applied.