1
0
mirror of https://github.com/garraflavatra/rolens.git synced 2025-04-20 01:01:03 +00:00
rolens/frontend/src/components/modal.svelte

137 lines
2.6 KiB
Svelte
Raw Normal View History

2023-01-19 08:41:09 +01:00
<script context="module">
let numberOfModalsOpen = 0;
</script>
2023-01-10 17:28:27 +01:00
<script>
2023-02-21 17:47:21 +01:00
import { Beep } from '$wails/go/ui/UI';
import { createEventDispatcher } from 'svelte';
2023-01-10 17:28:27 +01:00
import Icon from './icon.svelte';
export let show = true;
2023-01-10 17:28:27 +01:00
export let title = undefined;
export let contentPadding = true;
2023-01-18 20:59:00 +01:00
export let width = '80vw';
2023-01-21 10:27:52 +01:00
export let overflow = true;
2023-01-15 12:04:36 +01:00
const dispatch = createEventDispatcher();
2023-01-19 08:41:09 +01:00
const level = numberOfModalsOpen + 1;
let isNew = true;
$: if (show) {
numberOfModalsOpen++;
}
else if (!isNew) {
numberOfModalsOpen--;
}
else {
isNew = false;
}
2023-01-15 12:04:36 +01:00
function keydown(event) {
2023-01-19 08:41:09 +01:00
if ((event.key === 'Escape') && (level === numberOfModalsOpen)) {
event.preventDefault();
close();
2023-01-15 12:04:36 +01:00
}
}
function close() {
dispatch('close');
}
2023-01-10 17:28:27 +01:00
</script>
<svelte:window on:keydown={keydown} />
2023-01-15 12:04:36 +01:00
2023-01-10 17:28:27 +01:00
{#if show}
<div class="modal outer" on:pointerdown|self={Beep}>
<div class="inner" style:max-width={width || '80vw'}>
2023-01-15 16:49:08 +01:00
{#if title}
<header>
2023-01-10 17:28:27 +01:00
<div class="title">{title}</div>
2023-06-27 17:21:54 +02:00
<button class="button close" on:click={close} title="close" type="button">
2023-01-15 16:49:08 +01:00
<Icon name="x" />
</button>
</header>
{/if}
2023-01-21 10:27:52 +01:00
<div class="slot content" class:padded={contentPadding} class:overflow> <slot /> </div>
2023-01-15 16:49:08 +01:00
{#if $$slots.footer}
<footer> <slot name="footer" /> </footer>
2023-01-10 17:28:27 +01:00
{/if}
</div>
</div>
{/if}
<style>
.outer {
position: fixed;
display: flex;
z-index: 100;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
background-color: rgba(0, 0, 0, 0.5);
margin: 0;
2023-01-16 16:56:16 +01:00
padding-top: 50px;
--wails-draggable: drag;
2023-01-10 17:28:27 +01:00
}
2023-01-18 11:26:28 +01:00
:global(#root.platform-darwin) .outer {
2023-01-17 09:07:53 +01:00
margin-top: var(--darwin-titlebar-height);
2023-01-16 16:56:16 +01:00
}
2023-01-10 17:28:27 +01:00
.inner {
max-height: 80vh;
background-color: #fff;
margin-left: auto;
margin-right: auto;
margin-bottom: auto;
width: 100%;
2023-05-29 20:22:06 +02:00
border-radius: var(--radius);
2023-01-10 17:28:27 +01:00
display: flex;
2023-01-10 20:10:39 +01:00
flex-flow: column;
2023-01-10 17:28:27 +01:00
cursor: auto;
overflow: hidden;
--wails-draggable: nodrag;
2023-01-10 17:28:27 +01:00
}
.inner > :global(*:first-child) {
margin-top: 0;
}
.inner > :global(*:last-child) {
margin-bottom: 0;
}
header {
display: flex;
align-items: center;
2023-05-29 20:22:06 +02:00
padding: 0.75rem;
background-color: #eee;
2023-01-10 17:28:27 +01:00
}
header .title {
font-size: 1.5rem;
}
.close {
margin-left: auto;
}
.content {
max-height: 100%;
}
2023-01-21 10:27:52 +01:00
.content.overflow {
overflow-y: auto;
}
2023-01-15 12:02:17 +01:00
.content.padded {
2023-05-29 20:22:06 +02:00
padding: 0.75rem;
2023-01-15 12:02:17 +01:00
}
header + .content.padded {
border-top: 1px solid #ccc;
}
2023-01-10 17:28:27 +01:00
footer {
2023-05-29 20:22:06 +02:00
padding: 0.75rem;
2023-01-10 17:28:27 +01:00
border-top: 1px solid #ccc;
}
</style>