Files
Caramel-CRM/resources/js/components/ui/sidebar/SidebarMenuAction.vue
T

35 lines
1.3 KiB
Vue
Raw Normal View History

2025-10-20 08:57:51 +02:00
<script setup lang="ts">
2026-02-17 10:35:03 +01:00
import type { PrimitiveProps } from "reka-ui"
import type { HTMLAttributes } from "vue"
import { Primitive } from "reka-ui"
import { cn } from "@/lib/utils"
2025-10-20 08:57:51 +02:00
const props = withDefaults(defineProps<PrimitiveProps & {
showOnHover?: boolean
2026-02-17 10:35:03 +01:00
class?: HTMLAttributes["class"]
2025-10-20 08:57:51 +02:00
}>(), {
2026-02-17 10:35:03 +01:00
as: "button",
2025-10-20 08:57:51 +02:00
})
</script>
<template>
<Primitive
data-sidebar="menu-action"
:class="cn(
2026-02-17 10:35:03 +01:00
'absolute right-1 top-1.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 peer-hover/menu-button:text-sidebar-accent-foreground [&>svg]:size-4 [&>svg]:shrink-0',
'after:absolute after:-inset-2 after:md:hidden',
2025-10-20 08:57:51 +02:00
'peer-data-[size=sm]/menu-button:top-1',
'peer-data-[size=default]/menu-button:top-1.5',
'peer-data-[size=lg]/menu-button:top-2.5',
'group-data-[collapsible=icon]:hidden',
showOnHover
2026-02-17 10:35:03 +01:00
&& 'group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 peer-data-[active=true]/menu-button:text-sidebar-accent-foreground md:opacity-0',
2025-10-20 08:57:51 +02:00
props.class,
)"
:as="as"
:as-child="asChild"
>
<slot />
</Primitive>
</template>