mirror of
https://github.com/garraflavatra/rolens.git
synced 2025-04-16 15:51:03 +00:00
Squashed commit of the following: commit 93b2d67cef77d89df728ffbf831e5ce79904673e Author: Romein van Buren <romein@vburen.nl> Date: Sat Jul 1 20:07:33 2023 +0200 Add filter functionality commit 30b65a198fc8d494fe660babd409e42a85c85d14 Author: Romein van Buren <romein@vburen.nl> Date: Sat Jul 1 19:27:20 2023 +0200 Renamed `form-row` class to `formrow` commit 21afb01ea191c6d5b597884fae637ae1b8f49a7a Author: Romein van Buren <romein@vburen.nl> Date: Sat Jul 1 19:26:04 2023 +0200 Hide object types in object grid commit 037d5432a454720ad58f3c201bc60980759cc44f Author: Romein van Buren <romein@vburen.nl> Date: Sat Jul 1 19:21:54 2023 +0200 Make auto reload interval input smaller commit 49d50220272d87c34cd84678baf01557d4c24051 Author: Romein van Buren <romein@vburen.nl> Date: Sat Jul 1 15:08:00 2023 +0200 Implement logs autoreload commit 1f8984766bbd8a1f6ce232daa40b8c49bf079d9f Author: Romein van Buren <romein@vburen.nl> Date: Sat Jul 1 15:04:00 2023 +0200 Return on error commit 9c8525996494f023634ac3ea64370fc2778e717c Author: Romein van Buren <romein@vburen.nl> Date: Sat Jul 1 15:03:37 2023 +0200 Add log error handling commit 7a98a63866b6fbfe3be5897feddbacf3fafd7dbf Author: Romein van Buren <romein@vburen.nl> Date: Sat Jul 1 14:46:39 2023 +0200 Update log tab icon commit f30827ae2ec1c6254e0aab451de6763556c90ac5 Author: Romein van Buren <romein@vburen.nl> Date: Sat Jul 1 14:41:59 2023 +0200 Add host log panel
137 lines
2.6 KiB
Svelte
137 lines
2.6 KiB
Svelte
<script context="module">
|
|
let numberOfModalsOpen = 0;
|
|
</script>
|
|
|
|
<script>
|
|
import { Beep } from '$wails/go/ui/UI';
|
|
import { createEventDispatcher } from 'svelte';
|
|
import Icon from './icon.svelte';
|
|
|
|
export let show = true;
|
|
export let title = undefined;
|
|
export let contentPadding = true;
|
|
export let width = '80vw';
|
|
export let overflow = true;
|
|
|
|
const dispatch = createEventDispatcher();
|
|
const level = numberOfModalsOpen + 1;
|
|
let isNew = true;
|
|
|
|
$: if (show) {
|
|
numberOfModalsOpen++;
|
|
}
|
|
else if (!isNew) {
|
|
numberOfModalsOpen--;
|
|
}
|
|
else {
|
|
isNew = false;
|
|
}
|
|
|
|
function keydown(event) {
|
|
if ((event.key === 'Escape') && (level === numberOfModalsOpen)) {
|
|
event.preventDefault();
|
|
close();
|
|
}
|
|
}
|
|
|
|
function close() {
|
|
dispatch('close');
|
|
}
|
|
</script>
|
|
|
|
<svelte:window on:keydown={keydown} />
|
|
|
|
{#if show}
|
|
<div class="modal outer" on:pointerdown|self={Beep}>
|
|
<div class="inner" style:max-width={width || '80vw'}>
|
|
{#if title}
|
|
<header>
|
|
<div class="title">{title}</div>
|
|
<button class="button close" on:click={close} title="close" type="button">
|
|
<Icon name="x" />
|
|
</button>
|
|
</header>
|
|
{/if}
|
|
|
|
<div class="slot content" class:padded={contentPadding} class:overflow> <slot /> </div>
|
|
|
|
{#if $$slots.footer}
|
|
<footer> <slot name="footer" /> </footer>
|
|
{/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;
|
|
padding-top: 50px;
|
|
--wails-draggable: drag;
|
|
}
|
|
:global(#root.platform-darwin) .outer {
|
|
margin-top: var(--darwin-titlebar-height);
|
|
}
|
|
|
|
.inner {
|
|
max-height: 80vh;
|
|
background-color: #fff;
|
|
margin-left: auto;
|
|
margin-right: auto;
|
|
margin-bottom: auto;
|
|
width: 100%;
|
|
border-radius: var(--radius);
|
|
display: flex;
|
|
flex-flow: column;
|
|
cursor: auto;
|
|
overflow: hidden;
|
|
--wails-draggable: nodrag;
|
|
}
|
|
.inner > :global(*:first-child) {
|
|
margin-top: 0;
|
|
}
|
|
|
|
.inner > :global(*:last-child) {
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
header {
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 0.75rem;
|
|
background-color: #eee;
|
|
}
|
|
header .title {
|
|
font-size: 1.5rem;
|
|
}
|
|
|
|
.close {
|
|
margin-left: auto;
|
|
}
|
|
|
|
.content {
|
|
max-height: 100%;
|
|
}
|
|
.content.overflow {
|
|
overflow-y: auto;
|
|
}
|
|
.content.padded {
|
|
padding: 0.75rem;
|
|
}
|
|
header + .content.padded {
|
|
border-top: 1px solid #ccc;
|
|
}
|
|
|
|
footer {
|
|
padding: 0.75rem;
|
|
border-top: 1px solid #ccc;
|
|
}
|
|
</style>
|