2021-03-31 11:59:07 +02:00
|
|
|
<script>
|
2021-04-21 16:03:12 +02:00
|
|
|
import "@spectrum-css/popover/dist/index-vars.css"
|
2021-03-31 11:59:07 +02:00
|
|
|
import Portal from "svelte-portal"
|
|
|
|
import { createEventDispatcher } from "svelte"
|
|
|
|
import positionDropdown from "../Actions/position_dropdown"
|
|
|
|
import clickOutside from "../Actions/click_outside"
|
2021-04-21 16:03:12 +02:00
|
|
|
|
2021-03-31 11:59:07 +02:00
|
|
|
const dispatch = createEventDispatcher()
|
|
|
|
|
|
|
|
export let anchor
|
|
|
|
export let align = "right"
|
|
|
|
|
|
|
|
export const show = () => {
|
2021-04-21 16:03:12 +02:00
|
|
|
dispatch("open")
|
2021-03-31 11:59:07 +02:00
|
|
|
open = true
|
|
|
|
}
|
|
|
|
|
|
|
|
export const hide = () => {
|
2021-04-21 16:03:12 +02:00
|
|
|
dispatch("close")
|
2021-03-31 11:59:07 +02:00
|
|
|
open = false
|
|
|
|
}
|
|
|
|
|
2021-04-21 16:03:12 +02:00
|
|
|
let open = null
|
|
|
|
|
2021-03-31 11:59:07 +02:00
|
|
|
function handleEscape(e) {
|
|
|
|
if (open && e.key === "Escape") {
|
|
|
|
hide()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
{#if open}
|
|
|
|
<Portal>
|
|
|
|
<div
|
|
|
|
tabindex="0"
|
|
|
|
use:positionDropdown={{ anchor, align }}
|
|
|
|
use:clickOutside={hide}
|
|
|
|
on:keydown={handleEscape}
|
2021-04-21 16:03:12 +02:00
|
|
|
class="spectrum-Popover is-open"
|
|
|
|
role="presentation">
|
2021-03-31 11:59:07 +02:00
|
|
|
<slot />
|
|
|
|
</div>
|
|
|
|
</Portal>
|
|
|
|
{/if}
|