SidebarMenuAction.vue 1.3 KB

1234567891011121314151617181920212223242526272829303132333435
  1. <script setup lang="ts">
  2. import type { PrimitiveProps } from "reka-ui"
  3. import type { HTMLAttributes } from "vue"
  4. import { Primitive } from "reka-ui"
  5. import { cn } from '@/Packages/Shadcn/Lib/utils'
  6. const props = withDefaults(defineProps<PrimitiveProps & {
  7. showOnHover?: boolean
  8. class?: HTMLAttributes["class"]
  9. }>(), {
  10. as: "button",
  11. })
  12. </script>
  13. <template>
  14. <Primitive
  15. data-slot="sidebar-menu-action"
  16. data-sidebar="menu-action"
  17. :class="cn(
  18. 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0',
  19. 'after:absolute after:-inset-2 md:after:hidden',
  20. 'peer-data-[size=sm]/menu-button:top-1',
  21. 'peer-data-[size=default]/menu-button:top-1.5',
  22. 'peer-data-[size=lg]/menu-button:top-2.5',
  23. 'group-data-[collapsible=icon]:hidden',
  24. showOnHover
  25. && 'peer-data-[active=true]/menu-button:text-sidebar-accent-foreground group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 md:opacity-0',
  26. props.class,
  27. )"
  28. :as="as"
  29. :as-child="asChild"
  30. >
  31. <slot />
  32. </Primitive>
  33. </template>