mirror of
https://github.com/amir20/dozzle.git
synced 2025-12-21 21:33:18 +01:00
54 lines
1.3 KiB
Vue
54 lines
1.3 KiB
Vue
<template>
|
|
<dialog ref="panel" class="modal-right modal items-start outline-hidden backdrop:bg-none">
|
|
<div class="modal-box" :width="width">
|
|
<form method="dialog">
|
|
<button class="swap swap-rotate hover:swap-active absolute top-4 right-4 outline-hidden">
|
|
<mdi:keyboard-esc class="swap-off" />
|
|
<mdi:close class="swap-on" />
|
|
</button>
|
|
</form>
|
|
<slot v-if="open"></slot>
|
|
</div>
|
|
<form method="dialog" class="modal-backdrop">
|
|
<button>close</button>
|
|
</form>
|
|
</dialog>
|
|
</template>
|
|
<script setup lang="ts">
|
|
import { type DrawerWidth } from "@/composable/drawer";
|
|
const panel = useTemplateRef<HTMLDialogElement>("panel");
|
|
|
|
const open = ref(false);
|
|
const { width } = defineProps<{
|
|
width: DrawerWidth;
|
|
}>();
|
|
|
|
defineExpose({
|
|
open: () => {
|
|
open.value = true;
|
|
panel.value?.showModal();
|
|
},
|
|
});
|
|
|
|
useEventListener(panel, "close", () => (open.value = false));
|
|
</script>
|
|
<style scoped>
|
|
@import "@/main.css" reference;
|
|
|
|
.modal-right :where(.modal-box) {
|
|
@apply bg-base-100 fixed right-0 h-lvh max-h-screen translate-x-24 scale-100 rounded-none shadow-none;
|
|
|
|
&[width="md"] {
|
|
@apply max-w-3xl;
|
|
}
|
|
|
|
&[width="lg"] {
|
|
@apply max-w-5xl;
|
|
}
|
|
}
|
|
|
|
.modal-right[open] .modal-box {
|
|
@apply translate-x-0;
|
|
}
|
|
</style>
|