Popover
The Popover component is similar to tooltips; it is a pop-up box that appears when the user clicks on an element.
Examples
Code
vue
<script setup lang="ts">
import { BaseButton, BasePopover } from '@point-hub/papp'
import { ref } from 'vue'
const activeTab = ref('all')
const popoverRef = ref()
</script>
<template>
<Demo>
<component ref="popoverRef" :is="BasePopover" placement="bottom-start">
<component :is="BaseButton" size="md" color="primary" @click="popoverRef.toggle()">
Trigger element
</component>
<template #content>
<div class="popper-root">
<div
class="rounded-t-lg bg-slate-100 text-slate-600 dark:bg-slate-800 dark:text-slate-200 shadow"
>
<div class="flex items-center justify-between px-4 pt-2 mb-2">
<div class="flex items-center space-x-2">
<h3 class="font-medium text-slate-700 dark:text-slate-100">Notifications</h3>
<div
class="badge bg-primary/10 text-primary dark:bg-slate/15 dark:text-slate h-5 rounded-full px-1.5 text-sm"
>
26
</div>
</div>
<component
:is="BaseButton"
variant="text"
class="h-7 w-7 rounded-full p-0 -mr-1.5 active:bg-slate-300/25 focus:bg-slate-300/20 hover:bg-slate-300/20 dark:active:bg-slate-300/25 dark:focus:bg-slate-300/20 dark:hover:bg-slate-300/20"
>
<base-icon icon="i-far-maximize" />
</component>
</div>
<div class="scrollbar-hidden flex shrink-0 overflow-x-auto px-3 text-sm">
<component
:is="BaseButton"
variant="text"
:class="
activeTab === 'all'
? 'border-primary dark:border-accent dark:text-white font-bold'
: 'border-transparent hover:text-slate-800 focus:text-slate-800 dark:hover:text-slate-100 dark:focus:text-slate-100'
"
class="shrink-0 border-b-2 rounded-none px-3.5 py-1"
@click="activeTab = 'all'"
>
<span>All</span>
</component>
<component
:is="BaseButton"
variant="text"
:class="
activeTab === 'logs'
? 'border-primary dark:border-accent dark:text-white font-bold'
: 'border-transparent hover:text-slate-800 focus:text-slate-800 dark:hover:text-slate-100 dark:focus:text-slate-100'
"
class="shrink-0 border-b-2 rounded-none px-3.5 py-1"
@click="activeTab = 'logs'"
>
<span>Logs</span>
</component>
</div>
</div>
<div class="flex flex-col overflow-hidden shadow-lg">
<div v-if="activeTab === 'all'" class="overflow-y-auto p-4 space-y-4">
<div class="flex items-center space-x-3">
<div
class="bg-secondary/10 dark:bg-secondary-light/15 h-10 w-10 flex shrink-0 items-center justify-center rounded-lg"
>
<base-icon icon="i-far-user" />
</div>
<div>
<p class="font-medium text-slate-600 dark:text-slate-100">User Photo Changed</p>
<div class="line-clamp-1 mt-1 text-xs text-slate-400 dark:text-slate-300">
John Doe changed his avatar photo
</div>
</div>
</div>
<div class="flex items-center space-x-3">
<div
class="bg-info/10 dark:bg-info/15 h-10 w-10 flex shrink-0 items-center justify-center rounded-lg"
>
<base-icon icon="i-far-pencil" />
</div>
<div>
<p class="font-medium text-slate-600 dark:text-slate-100">
01 January 2022 <span class="text-xs font-light">08:00</span>
</p>
<div class="mt-1 flex text-xs text-slate-400 dark:text-slate-300">
<span class="line-clamp-1">Create new invoice</span>
</div>
</div>
</div>
</div>
<div v-if="activeTab === 'logs'" class="overflow-y-auto px-4">
<div class="mt-8 pb-8 text-center">
<div class="mt-5">
<p class="text-base font-semibold text-slate-700 dark:text-slate-100">
Empty logs
</p>
<p class="text-slate-400 dark:text-slate-300">There are no unread logs</p>
</div>
</div>
</div>
</div>
</div>
</template>
</component>
</Demo>
</template>
<style scoped>
.popper-root {
@apply border-slate-100 shadow dark:shadow-dark mx-4 mt-1 max-h-[calc(100vh-6rem)] w-[calc(100vw-2rem)] flex flex-col border rounded-lg bg-white sm:m-0 sm:w-80 dark:border-slate-800 dark:bg-slate-700;
}
</style>
Popover API
Types
ts
export type BasePopoverPlacementType =
| 'auto'
| 'auto-start'
| 'auto-end'
| 'top'
| 'top-start'
| 'top-end'
| 'bottom'
| 'bottom-start'
| 'bottom-end'
| 'right'
| 'right-start'
| 'right-end'
| 'left'
| 'left-start'
| 'left-end'
Props
Name | Type | Default | Description |
---|---|---|---|
placement | BasePopoverPlacementType | bottom | Popover placement |
Slot
#default
slot for rendering popover trigger element
#content
slot for rendering popover content