<script setup lang="ts"> import { InjectionKeyDropdownContext } from '~/constants/symbols' defineProps<{ placement?: string autoBoundaryMaxSize?: boolean }>() const dropdown = ref<any>() const colorMode = useColorMode() function hide() { return dropdown.value.hide() } provide(InjectionKeyDropdownContext, { hide, }) defineExpose({ hide, }) </script> <template> <VDropdown v-bind="$attrs" ref="dropdown" :class="colorMode.value" :placement="placement || 'auto'" :auto-boundary-max-size="autoBoundaryMaxSize"> <slot /> <template #popper="scope"> <slot name="popper" v-bind="scope" /> </template> </VDropdown> </template>