2024-10-26 23:51:56 +02:00
|
|
|
<script setup lang="ts">
|
2024-10-27 15:02:54 +01:00
|
|
|
import { cn } from '@/src/modules/shared/style/cn';
|
|
|
|
import { ChevronDownIcon } from '@radix-icons/vue';
|
|
|
|
import { SelectScrollDownButton, type SelectScrollDownButtonProps, useForwardProps } from 'radix-vue';
|
|
|
|
import { computed, type HTMLAttributes } from 'vue';
|
2024-10-26 23:51:56 +02:00
|
|
|
|
2024-10-27 15:02:54 +01:00
|
|
|
const props = defineProps<SelectScrollDownButtonProps & { class?: HTMLAttributes['class'] }>();
|
2024-10-26 23:51:56 +02:00
|
|
|
|
|
|
|
const delegatedProps = computed(() => {
|
2024-10-27 15:02:54 +01:00
|
|
|
const { class: _, ...delegated } = props;
|
2024-10-26 23:51:56 +02:00
|
|
|
|
2024-10-27 15:02:54 +01:00
|
|
|
return delegated;
|
|
|
|
});
|
2024-10-26 23:51:56 +02:00
|
|
|
|
2024-10-27 15:02:54 +01:00
|
|
|
const forwardedProps = useForwardProps(delegatedProps);
|
2024-10-26 23:51:56 +02:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<SelectScrollDownButton v-bind="forwardedProps" :class="cn('flex cursor-default items-center justify-center py-1', props.class)">
|
|
|
|
<slot>
|
|
|
|
<ChevronDownIcon />
|
|
|
|
</slot>
|
|
|
|
</SelectScrollDownButton>
|
|
|
|
</template>
|