woodpecker/web/src/components/layout/Popup.vue
Patrick Schratz 5b0d788737
Add vscode tailwind extensions & prettier tailwind linter, sort tailwind classes (#4622)
Co-authored-by: Anbraten <6918444+anbraten@users.noreply.github.com>
2024-12-31 14:03:21 +01:00

39 lines
826 B
Vue

<template>
<!-- overlay -->
<div
v-if="open"
class="z-500 fixed bottom-0 left-0 right-0 top-0 bg-gray-900 opacity-80 print:hidden"
@click="$emit('close')"
/>
<!-- overlay end -->
<div
v-if="open"
class="max-w-1/3 <md:max-w-4/5 max-h-3/5 z-1000 fixed left-1/2 top-1/2 flex -translate-x-1/2 -translate-y-1/2 transform print:hidden"
>
<div class="shadow-all m-auto flex h-auto flex-col">
<slot />
</div>
</div>
</template>
<script lang="ts" setup>
import { onKeyStroke } from '@vueuse/core';
import { toRef } from 'vue';
const props = defineProps<{
open: boolean;
}>();
const emit = defineEmits<{
(event: 'close'): void;
}>();
const open = toRef(props, 'open');
onKeyStroke('Escape', (e) => {
e.preventDefault();
if (open.value) {
emit('close');
}
});
</script>