2023-04-02 02:59:20 +02:00
|
|
|
<script lang="ts">
|
2023-12-19 23:02:02 +01:00
|
|
|
import { createEventDispatcher } from "svelte"
|
2023-12-26 22:30:27 +01:00
|
|
|
import { ariaLabel } from "../../Utils/ariaLabel"
|
|
|
|
import Translations from "../i18n/Translations"
|
2024-07-11 19:01:32 +02:00
|
|
|
import { XCircleIcon } from "@babeard/svelte-heroicons/solid"
|
2024-09-02 00:26:02 +02:00
|
|
|
import { CloseButton } from "flowbite-svelte"
|
2023-12-19 23:02:02 +01:00
|
|
|
|
2023-06-14 20:39:36 +02:00
|
|
|
/**
|
|
|
|
* The slotted element will be shown on top, with a lower-opacity border
|
|
|
|
*/
|
2023-12-19 22:08:00 +01:00
|
|
|
const dispatch = createEventDispatcher<{ close }>()
|
2023-04-02 02:59:20 +02:00
|
|
|
</script>
|
|
|
|
|
2023-12-19 22:08:00 +01:00
|
|
|
<!-- Draw the background over the total screen -->
|
|
|
|
<div
|
|
|
|
class="absolute top-0 left-0 h-screen w-screen"
|
|
|
|
on:click={() => {
|
2024-06-17 04:27:08 +02:00
|
|
|
console.log("OnClose")
|
2023-10-16 14:27:05 +02:00
|
|
|
dispatch("close")
|
2023-12-19 22:08:00 +01:00
|
|
|
}}
|
2023-12-19 23:02:02 +01:00
|
|
|
style="background-color: #00000088; z-index: 20"
|
2023-12-19 22:08:00 +01:00
|
|
|
/>
|
2023-12-07 21:57:20 +01:00
|
|
|
<!-- draw a _second_ absolute div, placed using 'bottom' which will be above the navigation bar on mobile browsers -->
|
2024-06-20 04:21:29 +02:00
|
|
|
<div
|
|
|
|
class="pointer-events-none absolute bottom-0 right-0 h-full w-screen p-4 md:p-6"
|
|
|
|
style="z-index: 21"
|
|
|
|
on:click={() => {
|
|
|
|
console.log("Closing...")
|
|
|
|
dispatch("close")
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<div
|
2024-09-02 00:26:02 +02:00
|
|
|
class="content relative normal-background pointer-events-auto h-full"
|
2024-06-20 04:21:29 +02:00
|
|
|
on:click|stopPropagation={() => {}}
|
|
|
|
>
|
2023-06-14 20:44:01 +02:00
|
|
|
<div class="h-full rounded-xl">
|
2023-06-14 20:39:36 +02:00
|
|
|
<slot />
|
2023-05-07 23:19:30 +02:00
|
|
|
</div>
|
2023-06-14 20:39:36 +02:00
|
|
|
<slot name="close-button">
|
|
|
|
<!-- The close button is placed _after_ the default slot in order to always paint it on top -->
|
2024-09-02 00:26:02 +02:00
|
|
|
<div class="absolute top-0 right-0">
|
|
|
|
|
|
|
|
<CloseButton class="normal-background mt-2 mr-2"
|
|
|
|
on:click={() => dispatch("close")}
|
|
|
|
/>
|
2024-07-11 19:01:32 +02:00
|
|
|
</div>
|
2024-09-02 00:26:02 +02:00
|
|
|
|
2023-06-14 20:39:36 +02:00
|
|
|
</slot>
|
|
|
|
</div>
|
2023-04-02 02:59:20 +02:00
|
|
|
</div>
|
2023-05-07 23:19:30 +02:00
|
|
|
|
|
|
|
<style>
|
2024-09-02 00:26:02 +02:00
|
|
|
.content {
|
|
|
|
border-radius: 0.5rem;
|
|
|
|
overflow-x: hidden;
|
|
|
|
box-shadow: 0 0 1rem #00000088;
|
|
|
|
}
|
2023-05-07 23:19:30 +02:00
|
|
|
</style>
|