Popover React 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 Components

There are following components included:

  • Popover

Popover Props

NameTypeDefaultDescription
anglebooleantrue

Renders popover "angle"/"corner"

angleClassNamestringundefined

Additional css class to add on "angle"/"corner" element

backdropbooleantrue

Enables Popover backdrop (dark semi transparent layer behind)

colorsobject

Object with Tailwind CSS colors classes

colors.bgIosstring'bg-ios-light-surface-3 dark:bg-ios-dark-surface-3'
colors.bgMaterialstring'bg-md-light-surface-3 dark:bg-md-dark-surface-3'
componentstring'div'

Component's HTML Element

openedbooleanfalse

Allows to open/close Popover and set its initial state

sizestring'w-64'

Tailwind CSS size classes

targetstring | HTMLElement | Ref

Popover target element. Popover will be positioned around this element

targetHeightnumber

Virtual target element height (in px). Required without using real target element (target prop)

targetWidthnumber

Virtual target element width (in px). Required without using real target element (target prop)

targetXnumber

Virtual target element horizontal offset from left side of the screen. Required without using real target element (target prop)

targetYnumber

Virtual target element vertical offset from top of the screen. Required without using real target element (target prop)

translucentbooleantrue

Makes Popover background translucent (with backdrop-filter: blur) in iOS theme

onBackdropClickfunction(e)

Click handler on backdrop element

Examples

Popover.jsx
import React, { useRef, useState } from 'react';
import {
Page,
Navbar,
NavbarBackLink,
Popover,
Block,
Link,
Button,
List,
ListItem,
} from 'konsta/react';
export default function PopoverPage() {
const [popoverOpened, setPopoverOpened] = useState(false);
const popoverTargetRef = useRef(null);
const openPopover = (targetRef) => {
popoverTargetRef.current = targetRef;
setPopoverOpened(true);
};
return (
<Page>
<Navbar
title="Popover"
right={
<Link
className="popover-navbar-link"
navbar
onClick={() => openPopover('.popover-navbar-link')}
>
Popover
</Link>
}
/>
<Block className="space-y-4">
<p>
<Button
className="popover-button"
onClick={() => openPopover('.popover-button')}
>
Open popover on me
</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,{' '}
<Link
className="popover-link-1"
onClick={() => openPopover('.popover-link-1')}
>
popover
</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{' '}
<Link
className="popover-link-2"
onClick={() => openPopover('.popover-link-2')}
>
popover!
</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{' '}
<Link
className="popover-link-3"
onClick={() => openPopover('.popover-link-3')}
>
one more popover
</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>
</Block>
<Popover
opened={popoverOpened}
target={popoverTargetRef.current}
onBackdropClick={() => setPopoverOpened(false)}
>
<List nested>
<ListItem
title="Item 1"
link
onClick={() => setPopoverOpened(false)}
/>
<ListItem
title="List Item 2"
link
onClick={() => setPopoverOpened(false)}
/>
<ListItem
title="Item 3"
link
onClick={() => setPopoverOpened(false)}
/>
<ListItem
title="List Item 4"
link
onClick={() => setPopoverOpened(false)}
/>
<ListItem
title="Item 5"
link
onClick={() => setPopoverOpened(false)}
/>
</List>
</Popover>
</Page>
);
}
Code licensed under MIT.
2022 © Konsta UI by nolimits4web.