🔥 Black Friday Sale: Up to 40% OFF on UI Initiative, Swiper Studio and t0ggles 🔥

Popover Vue Component

Popover component is used to manage the presentation of content in a popover. You use popovers to present information temporarily. The popover remains visible until the user taps outside of the popover window or you explicitly dismiss it.

Popover Vue component represents Popover component.

Popover Components

There are following components included:

Popover Properties

PropTypeDefaultDescription
<f7-popover> properties
openedbooleanfalseAllows to open/close Popover and set its initial state
arrowbooleantrueEnables Popover arrow/corner
target-elstring
object
HTML element or string CSS selector of Popover target element
vertical-positionstringautoForce popover vertical position, can be auto, top or bottom
backdropbooleantrueEnables Popover backdrop (dark semi transparent layer behind). By default inherits same app parameter value (true)
backdrop-elstring
object
HTML element or string CSS selector of custom backdrop element
backdrop-uniquebooleanfalseIf enabled it creates unique backdrop element exclusively for this modal
close-by-backdrop-clickbooleantrueWhen enabled, popover will be closed on backdrop click. By default inherits same app parameter value
close-by-outside-clickbooleantrueWhen enabled, popover will be closed on when click outside of it. By default inherits same app parameter value
close-on-escapebooleanfalseWhen enabled, popover will be closed on ESC keyboard key press
animatebooleantrueWhether the modal should be opened/closed with animation or not
container-elHTMLElement
string
Element to mount modal to (default to app root element)

Popover Events

EventDescription
<f7-popover> events
popover:openEvent will be triggered when Popover starts its opening animation
popover:openedEvent will be triggered after Popover completes its opening animation
popover:closeEvent will be triggered when Popover starts its closing animation
popover:closedEvent will be triggered after Popover completes its closing animation

Popover v-model

Popover component supports v-model on opened prop:

<template>
  <f7-page>
    <f7-popover v-model:opened="isOpened">
      ...
    </f7-popover>
    <p>Modal is opened: {{ isOpened }}</p>
  </f7-page>
</template>
<script>
  export default {
    data() {
      return {
        isOpened: false,
      };
    }
  };
</script>

Open And Close Popover

You can control Popover state, open and closing it:

Examples

popover.vue
<template>
  <f7-page>
    <f7-navbar title="Popover"></f7-navbar>
    <f7-toolbar bottom>
      <f7-link>Dummy Link</f7-link>
      <f7-link popover-open=".popover-menu">Open Popover</f7-link>
    </f7-toolbar>

    <f7-block>
      <p><f7-button fill popover-open=".popover-menu">Open popover on me</f7-button></p>
      <p>
        Mauris fermentum neque et luctus venenatis. Vivamus a sem rhoncus, ornare tellus eu, euismod
        mauris. In porta turpis at semper convallis. Duis adipiscing leo eu nulla lacinia, quis
        rhoncus metus condimentum. Etiam nec malesuada nibh. Maecenas quis lacinia nisl, vel posuere
        dolor. Vestibulum condimentum, nisl ac vulputate egestas, neque enim dignissim elit, rhoncus
        volutpat magna enim a est. Aenean sit amet ligula neque. Cras suscipit rutrum enim. Nam a
        odio facilisis, elementum tellus non,
        <f7-link popover-open=".popover-menu">popover</f7-link> tortor. Pellentesque felis eros,
        dictum vitae lacinia quis, lobortis vitae ipsum. Cras vehicula bibendum lorem quis
        imperdiet.
      </p>
      <p>
        In hac habitasse platea dictumst. Etiam varius, ante vel ornare facilisis, velit massa
        rutrum dolor, ac porta magna magna lacinia nunc. Curabitur
        <f7-link popover-open=".popover-menu">popover!</f7-link> cursus laoreet. Aenean vel tempus
        augue. Pellentesque in imperdiet nibh. Mauris rhoncus nulla id sem suscipit volutpat.
        Pellentesque ac arcu in nisi viverra pulvinar. Nullam nulla orci, bibendum sed ligula non,
        ullamcorper iaculis mi. In hac habitasse platea dictumst. Praesent varius at nisl eu luctus.
        Cras aliquet porta est. Quisque elementum quis dui et consectetur. Cum sociis natoque
        penatibus et magnis dis parturient montes, nascetur ridiculus mus. Sed sed laoreet purus.
        Pellentesque eget ante ante.
      </p>
      <p>
        Duis et ultricies nibh. Sed facilisis turpis urna, ac imperdiet erat venenatis eu. Proin sit
        amet faucibus tortor, et varius sem. Etiam vitae lacinia neque. Aliquam nisi purus, interdum
        in arcu sed, ultrices rutrum arcu. Nulla mi turpis, consectetur vel enim quis, facilisis
        viverra dui. Aliquam quis convallis tortor, quis semper ligula. Morbi ullamcorper
        <f7-link popover-open=".popover-menu">one more popover</f7-link> massa at accumsan. Etiam
        purus odio, posuere in ligula vitae, viverra ultricies justo. Vestibulum nec interdum nisi.
        Aenean ac consectetur velit, non malesuada magna. Sed pharetra vehicula augue, vel venenatis
        lectus gravida eget. Curabitur lacus tellus, venenatis eu arcu in, interdum auctor nunc.
        Nunc non metus neque. Suspendisse viverra lectus sed risus aliquet, vel accumsan dolor
        feugiat.
      </p>
    </f7-block>
    <f7-popover class="popover-menu">
      <f7-list>
        <f7-list-item link="/dialog/" popover-close title="Dialog" />
        <f7-list-item link="/tabs/" popover-close title="Tabs" />
        <f7-list-item link="/panel/" popover-close title="Side Panels" />
        <f7-list-item link="/list/" popover-close title="List View" />
        <f7-list-item link="/inputs/" popover-close title="Form Inputs" />
      </f7-list>
    </f7-popover>
  </f7-page>
</template>
<script>
import {
  f7Navbar,
  f7Page,
  f7Toolbar,
  f7Popover,
  f7List,
  f7ListItem,
  f7Block,
  f7Link,
  f7Button,
} from 'framework7-vue';

export default {
  components: {
    f7Navbar,
    f7Page,
    f7Toolbar,
    f7Popover,
    f7List,
    f7ListItem,
    f7Block,
    f7Link,
    f7Button,
  },
};
</script>