2019-07-30 02:56:17 +03:00
---
title: Popover
path: components/popover
status: Experimental
source: 'https://github.com/primer/css/tree/master/src/popover'
bundle: popover
---
Popovers are used to bring attention to specific user interface elements, typically to suggest an action or to guide users through a new experience.
2019-08-09 01:24:04 +03:00
2019-07-30 02:56:17 +03:00
A popover consist of:
- The block element, `.Popover` , which simply positions its content absolutely atop other body content.
- The child element, `.Popover-message` , which contains the markup for the intended messaging and the visual "caret."
In the examples below, `Popover-message` , in particular, uses a handful of utility classes to style it appropriately. And these are intended to demonstrate the default, go-to presentation for the popover's message. By default, the message's caret is centered on the top edge of the message.
The `Popover-message` element also supports several modifiers, most of which position the caret differently:
- [`.Popover-message--top` ](#default-top-center ) (default): Places the caret on the top edge of the message, horizontally centered.
- [`.Popover-message--bottom` ](#bottom ) Places the caret on the bottom edge of the message, horizontally centered.
- [`.Popover-message--right` ](#right ): Places the caret on the right edge of the message, vertically centered.
- [`.Popover-message--left` ](#left ): Places the caret on the left edge of the message, vertically centered.
Each of these modifiers also support a syntax for adjusting the positioning the caret to the right, left, top, or bottom of its respective edge. That syntax looks like:
- [`.Popover-message--bottom-left` ](#bottom-left )
- [`.Popover-message--bottom-right` ](#bottom-right )
- [`.Popover-message--left-bottom` ](#left-bottom )
- [`.Popover-message--left-top` ](#left-top )
- [`.Popover-message--right-bottom` ](#right-bottom )
- [`.Popover-message--right-top` ](#right-top )
- [`.Popover-message--top-left` ](#top-left )
- [`.Popover-message--top-right` ](#top-right )
Lastly, there is an added [`.Popover-message--large` ](#large ) modifier, which assumes a slightly wider popover message on screens wider than 544px.
### Notes
The samples below include optional markup, like:
- An outermost container that establishes stacking context (e.g. `position-relative` ).
- A choice piece of user interface (a button, in this case) to relate the popover to.
- Use of the `Details` and `js-details` family of class names, which interact with JavaScript to demonstrate dismissal of the popover by clicking the nested "Got it!" button.
### Basic example
Defaults to caret oriented top-center.
2019-08-09 01:24:04 +03:00
```html live title="Default (top-center)"
2019-07-30 02:56:17 +03:00
< div class = "position-relative text-center" >
< button class = "btn btn-primary" > UI< / button >
< div class = "Popover right-0 left-0 position-relative" >
< div class = "Popover-message text-left p-4 mt-2 mx-auto Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< / div >
```
### Large example
2019-08-09 01:24:04 +03:00
```html live title="Large"
2019-07-30 02:56:17 +03:00
< div class = "position-relative text-center" >
< button class = "btn btn-primary" > UI< / button >
< div class = "Popover right-0 left-0 position-relative" >
< div class = "Popover-message Popover-message--large text-left p-4 mt-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< / div >
```
### Bottom
2019-08-09 01:24:04 +03:00
```html live title="Bottom"
2019-07-30 02:56:17 +03:00
< div class = "position-relative text-center" >
< div class = "Popover position-relative" >
< div class = "Popover-message Popover-message--bottom p-4 mx-auto mb-2 text-left Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< button class = "btn btn-primary" > UI< / button >
< / div >
```
### Bottom-right
2019-08-09 01:24:04 +03:00
```html live title="Bottom-right"
2019-07-30 02:56:17 +03:00
< div class = "position-relative text-right pr-2" >
< div class = "Popover position-relative" >
< div class = "Popover-message Popover-message--bottom-right p-4 mb-2 text-left Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< button class = "btn btn-primary" > UI< / button >
< / div >
```
### Bottom-left
2019-08-09 01:24:04 +03:00
```html live title="Bottom-left"
2019-07-30 02:56:17 +03:00
< div class = "Popover position-relative pl-2" >
< div class = "Popover-message Popover-message--bottom-left p-4 mb-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< button class = "btn btn-primary" > UI< / button >
< / div >
```
### Left
2019-08-09 01:24:04 +03:00
```html live title="Left"
2019-07-30 02:56:17 +03:00
< div class = "d-flex flex-justify-center flex-items-center" >
< button class = "btn btn-primary" > UI< / button >
< div class = "Popover position-relative" >
< div class = "Popover-message Popover-message--left p-4 ml-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< / div >
```
### Left-bottom
2019-08-09 01:24:04 +03:00
```html live title="Left-bottom"
2019-07-30 02:56:17 +03:00
< div class = "d-flex flex-justify-center flex-items-end" >
< button class = "btn btn-primary" > UI< / button >
< div class = "Popover position-relative" >
< div class = "Popover-message Popover-message--left-bottom p-4 ml-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< / div >
```
### Left-top
2019-08-09 01:24:04 +03:00
```html live title="Left-top"
2019-07-30 02:56:17 +03:00
< div class = "d-flex flex-justify-center flex-items-start" >
< button class = "btn btn-primary" > UI< / button >
< div class = "Popover position-relative" >
< div class = "Popover-message Popover-message--left-top p-4 ml-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< / div >
```
### Right
2019-08-09 01:24:04 +03:00
```html live title="Right"
2019-07-30 02:56:17 +03:00
< div class = "d-flex flex-justify-center flex-items-center" >
< div class = "Popover position-relative" >
< div class = "Popover-message Popover-message--right p-4 mr-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< button class = "btn btn-primary" > UI< / button >
< / div >
```
### Right-bottom
2019-08-09 01:24:04 +03:00
```html live title="Right-bottom"
2019-07-30 02:56:17 +03:00
< div class = "d-flex flex-justify-center flex-items-end" >
< div class = "Popover position-relative" >
< div class = "Popover-message Popover-message--right-bottom p-4 mr-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< button class = "btn btn-primary" > UI< / button >
< / div >
```
### Right-top
2019-08-09 01:24:04 +03:00
```html live title="Right-top"
2019-07-30 02:56:17 +03:00
< div class = "d-flex flex-justify-center flex-items-start" >
< div class = "Popover position-relative" >
< div class = "Popover-message Popover-message--right-top p-4 mr-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< button class = "btn btn-primary" > UI< / button >
< / div >
```
### Top-left
2019-08-09 01:24:04 +03:00
```html live title="Top-left"
2019-07-30 02:56:17 +03:00
< div class = "position-relative pl-2" >
< button class = "btn btn-primary" > UI< / button >
< div class = "Popover position-relative" >
< div class = "Popover-message Popover-message--top-left p-4 mt-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< / div >
```
### Top-right
2019-08-09 01:24:04 +03:00
```html live title="Top-right"
2019-07-30 02:56:17 +03:00
< div class = "position-relative text-right pr-2" >
< button class = "btn btn-primary" > UI< / button >
< div class = "Popover right-0 position-relative" >
< div class = "Popover-message Popover-message--top-right text-left p-4 mt-2 Box box-shadow-large" >
< h4 class = "mb-2" > Popover heading< / h4 >
< p > Message about this particular piece of UI.< / p >
< button type = "submit" class = "btn btn-outline mt-2 text-bold" > Got it!< / button >
< / div >
< / div >
< / div >
```