124 lines
3.7 KiB
Svelte
124 lines
3.7 KiB
Svelte
<script>
|
|
import { _ } from "svelte-i18n";
|
|
import { clickOutside } from "../base/outsideclick";
|
|
import { createEventDispatcher, onMount } from "svelte";
|
|
export let modal_open;
|
|
export let delete_card = {
|
|
id: 0,
|
|
code: "",
|
|
runner: {
|
|
firstname: "",
|
|
lastname: "",
|
|
},
|
|
};
|
|
const dispatch = createEventDispatcher();
|
|
onMount(() => {
|
|
document.onkeydown = (e) => {
|
|
e = e || window.event;
|
|
if (e.key === "Escape") {
|
|
modal_open = false;
|
|
}
|
|
if (e.keyCode === 13) {
|
|
if (createbtnenabled === true) {
|
|
createbtnenabled = false;
|
|
submit();
|
|
}
|
|
}
|
|
};
|
|
});
|
|
async function submit() {
|
|
dispatch("delete", { id: delete_card.id });
|
|
modal_open = false;
|
|
}
|
|
</script>
|
|
|
|
{#if modal_open}
|
|
<div
|
|
class="fixed z-10 inset-0 overflow-y-hidden"
|
|
use:clickOutside
|
|
on:click_outside={() => {
|
|
modal_open = false;
|
|
}}
|
|
>
|
|
<div
|
|
class="flex items-end justify-center h-screen text-center sm:block p-0 lg:p-4"
|
|
>
|
|
<div class="fixed inset-0 transition-opacity" aria-hidden="true">
|
|
<div
|
|
class="absolute inset-0 bg-gray-500 opacity-75"
|
|
data-id="modal_backdrop"
|
|
/>
|
|
</div>
|
|
<span
|
|
class="hidden sm:inline-block sm:align-middle sm:h-screen"
|
|
aria-hidden="true">​</span
|
|
>
|
|
<div
|
|
class="inline-block align-bottom text-left shadow-xl transform transition-all sm:align-middle w-full lg:w-auto min-w-auto lg:min-w-[35vw] relative z-10"
|
|
role="dialog"
|
|
aria-modal="true"
|
|
aria-labelledby="modal-headline"
|
|
>
|
|
<div class="bg-white px-4 pt-5 pb-4 sm:p-6 sm:pb-4 rounded-t-xl">
|
|
<div class="">
|
|
<div
|
|
class="flex-shrink-0 flex items-center justify-center size-12 rounded-full bg-blue-100 sm:mx-0 sm:h-10 sm:w-10"
|
|
>
|
|
<svg
|
|
class="size-6 text-blue-600"
|
|
fill="currentColor"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
viewBox="0 0 24 24"
|
|
width="24"
|
|
height="24"
|
|
><path fill="none" d="M0 0h24v24H0z" />
|
|
<path
|
|
fill="currentColor"
|
|
d="M22 10v10a1 1 0 01-1 1H3a1 1 0 01-1-1V10h20zm0-2H2V4a1 1 0 011-1h18a1 1 0 011 1v4zm-7 8v2h4v-2h-4z"
|
|
/></svg
|
|
>
|
|
</div>
|
|
<div class="mt-3 sm:text-left max-h-[75vh] overflow-y-auto">
|
|
<h3 class="text-lg leading-6 font-medium text-gray-900">
|
|
{$_("please-confirm-the-deletion-of-card")}
|
|
</h3>
|
|
<div class="w-full">
|
|
{$_("card")} #{delete_card.code}<br />
|
|
<span class="inline-block">
|
|
{$_("runner")}:
|
|
{#if delete_card.runner}
|
|
<span class="inline-block"
|
|
>{delete_card.runner.firstname}
|
|
{delete_card.runner.lastname}</span
|
|
>
|
|
{:else}
|
|
{$_("non-blanko")}
|
|
{/if}</span
|
|
>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="bg-gray-50 px-4 lg:py-3 sm:px-6 grid gap-2 lg:rounded-b-xl pt-3 pb-10">
|
|
<button
|
|
on:click={submit}
|
|
type="button"
|
|
class="confirm_deletion_button"
|
|
>
|
|
{$_("delete")}
|
|
</button>
|
|
<button
|
|
on:click={() => {
|
|
modal_open = false;
|
|
}}
|
|
type="button"
|
|
class="cancel_modal_button"
|
|
>
|
|
{$_("cancel")}
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{/if}
|