2024-12-16 17:25:52 +01:00
|
|
|
<script setup lang="ts">
|
|
|
|
|
import { cn } from "@/lib/utils";
|
2025-03-28 01:16:24 +01:00
|
|
|
import { TabsTrigger, type TabsTriggerProps, useForwardProps } from "reka-ui";
|
2024-12-16 17:25:52 +01:00
|
|
|
import { type HTMLAttributes, computed } from "vue";
|
|
|
|
|
|
|
|
|
|
const props = defineProps<
|
|
|
|
|
TabsTriggerProps & { class?: HTMLAttributes["class"] }
|
|
|
|
|
>();
|
|
|
|
|
|
|
|
|
|
const delegatedProps = computed(() => {
|
|
|
|
|
const { class: _, ...delegated } = props;
|
|
|
|
|
|
|
|
|
|
return delegated;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const forwardedProps = useForwardProps(delegatedProps);
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<template>
|
|
|
|
|
<TabsTrigger
|
|
|
|
|
v-bind="forwardedProps"
|
|
|
|
|
:class="cn(
|
|
|
|
|
'inline-flex items-center justify-center whitespace-nowrap rounded-sm px-3 py-1.5 text-sm font-medium ring-offset-background transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow-sm',
|
|
|
|
|
props.class,
|
|
|
|
|
)"
|
|
|
|
|
>
|
|
|
|
|
<span class="truncate">
|
|
|
|
|
<slot />
|
|
|
|
|
</span>
|
|
|
|
|
</TabsTrigger>
|
|
|
|
|
</template>
|