mirror of
https://github.com/sysadminsmedia/homebox.git
synced 2025-12-21 21:33:02 +01:00
32 lines
646 B
Vue
32 lines
646 B
Vue
<template>
|
|
<div
|
|
ref="el"
|
|
class="grid h-24 w-full place-content-center border-2 border-dashed border-primary"
|
|
:class="isOverDropZone ? 'bg-primary bg-opacity-10' : ''"
|
|
>
|
|
<slot />
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
defineProps({
|
|
modelValue: {
|
|
type: Boolean,
|
|
required: false,
|
|
},
|
|
});
|
|
|
|
const emit = defineEmits(["update:modelValue", "drop"]);
|
|
|
|
const el = ref<HTMLDivElement>();
|
|
const { isOverDropZone } = useDropZone(el, files => {
|
|
emit("drop", files);
|
|
});
|
|
|
|
watch(isOverDropZone, () => {
|
|
emit("update:modelValue", isOverDropZone.value);
|
|
});
|
|
</script>
|
|
|
|
<style scoped></style>
|