Usage
Popover is an overlay that opens on demand after clicking on the trigger. Popover allows to expose extra information or functionality to the user. It should always open next to the trigger.
Best practices
data:image/s3,"s3://crabby-images/d6a54/d6a5447ce3165eac374d9fee47dd9fe0f02a5c5e" alt=""
Do
Use the popover to expose a small amount of additional functionality or information to the user.
data:image/s3,"s3://crabby-images/7bd57/7bd572a9a43a3dc37158c9248307a373becf9ee6" alt=""
Don't
Do not use the popover if content can be shown directly or if the information is vital for using the screen.
data:image/s3,"s3://crabby-images/0a3cb/0a3cb0960b5baaf7d2d76de2fa4a8da1af537d2d" alt=""
Don't
Don’t use popovers for simple labeling i.e. providing a label for the icon button. Use a tooltip instead.
data:image/s3,"s3://crabby-images/a2a1d/a2a1dc32ee1fdc9893bd256a63730833de508532" alt=""
Don't
Don’t use popovers to show a list of actions. Use the dropdown menu instead.
Anatomy
data:image/s3,"s3://crabby-images/738ce/738ce7670e390bade60b0c63728dd152f6520cd9" alt=""
Trigger slot
This area is designated for the trigger. When clicked, a popover will open. Hovering is not a supported trigger event.
data:image/s3,"s3://crabby-images/665e2/665e236e48fcb2f1468dac4a9e64548039394dbe" alt=""
Do
Use buttons or elements that users expect to be clickable as triggers.
Don't
Do not use links or non-interactive elements (icons, text, images) as triggers.
Content slot
This area is designated for the content of the popover.
data:image/s3,"s3://crabby-images/9f5f2/9f5f256d0d17cff8f00dc94ccb1c18cdbc88b173" alt=""
Do
- Focus on one context or functionality only.
- Use edge-to-edge dividers to separate sections inside.
Don't
- Don’t nest popovers inside each other.
- Do not resize the popover arbitrarily. Adjust its dimensions to the content inside.
Positioning
The popover should always be placed next to the trigger and aligned to one of its edges.
data:image/s3,"s3://crabby-images/42a2b/42a2b57653f0499f46320d50a69213b75f401d33" alt=""
Examples
Live Preview
Props
Name | Description | Type | Default | Values |
---|---|---|---|---|
v-model model-value v2, wc open v1 | Controls whether the popover is open or not. | boolean | false | false, true |
position | Controls the position of the popover menu in relation to the trigger. `bottom-left` will align it to the bottom left of the trigger. `bottom-right` will align it to the bottom right of the trigger. `top-left`and 'top-right' will align it to the top left and right respectively. | string | bottom-left | bottom-left, bottom, bottom-right, top-left, top, top-right, left-top, left, left-bottom, right-top, right, right-bottom |
target | Type string or an actual DOM node where you want render component | string|object | body | |
use-teleport | When it is set to true, dropdown menu will teleport the content part into the body. | boolean | false | false, true |
anchor | Set an optional anchor element to align against, replacing the triggering element. | string|object | null |
Slots
Name | Description |
---|---|
default | The slot where the trigger for the popover is placed |
content | Default content for popover |
Events
Name | Description | Type |
---|---|---|
open | This event is emitted when the popover is open. | { "names": [ "Boolean" ] } |
close | This event is emitted when the popover is closed. | { "names": [ "Boolean" ] } |
v-model update:modelValue v2, wc toggle v1 | Emitted on popover open or close | { "names": [ "Boolean" ] } |