import { mergeProps } from '@base-ui/react/merge-props'; import { useRender } from '@base-ui/react/use-render'; import { Separator } from '@components/common/ui/Separator.js'; import { cn } from '@evershop/evershop/lib/util/cn'; import { cva, type VariantProps } from 'class-variance-authority'; import React from 'react'; const buttonGroupVariants = cva( "has-[>[data-slot=button-group]]:gap-2 has-[select[aria-hidden=true]:last-child]:[&>[data-slot=select-trigger]:last-of-type]:rounded-r-md flex w-fit items-stretch [&>*]:focus-visible:z-10 [&>*]:focus-visible:relative [&>[data-slot=select-trigger]:not([class*='w-'])]:w-fit [&>input]:flex-1", { variants: { orientation: { horizontal: '[&>[data-slot]:not(:has(~[data-slot]))]:rounded-r-md! [&>[data-slot]~[data-slot]]:rounded-l-none [&>[data-slot]~[data-slot]]:border-l-0 [&>[data-slot]]:rounded-r-none', vertical: '[&>[data-slot]:not(:has(~[data-slot]))]:rounded-b-md! flex-col [&>[data-slot]~[data-slot]]:rounded-t-none [&>[data-slot]~[data-slot]]:border-t-0 [&>[data-slot]]:rounded-b-none' } }, defaultVariants: { orientation: 'horizontal' } } ); function ButtonGroup({ className, orientation, ...props }: React.ComponentProps<'div'> & VariantProps) { return (
); } function ButtonGroupText({ className, render, ...props }: useRender.ComponentProps<'div'>) { return useRender({ defaultTagName: 'div', props: mergeProps<'div'>( { className: cn( "bg-muted gap-2 rounded-md border px-2.5 text-sm font-medium shadow-xs [&_svg:not([class*='size-'])]:size-4 flex items-center [&_svg]:pointer-events-none", className ) }, props ), render, state: { slot: 'button-group-text' } }); } function ButtonGroupSeparator({ className, orientation = 'vertical', ...props }: React.ComponentProps) { return ( ); } export { ButtonGroup, ButtonGroupSeparator, ButtonGroupText, buttonGroupVariants };