Files
24936d36-ee22-485a-9066-8d0…/research/base44/toggle-group.md
kudinDmitriyUp 0f06856ca5 Initial commit
2026-04-28 10:06:59 +00:00

1.3 KiB

"use client"; import * as React from "react" import * as ToggleGroupPrimitive from "@radix-ui/react-toggle-group"

import { cn } from "@/lib/utils" import { toggleVariants } from "@/components/ui/toggle"

const ToggleGroupContext = React.createContext({ size: "default", variant: "default", })

const ToggleGroup = React.forwardRef(({ className, variant, size, children, ...props }, ref) => ( <ToggleGroupPrimitive.Root ref={ref} className={cn("flex items-center justify-center gap-1", className)} {...props}> <ToggleGroupContext.Provider value={{ variant, size }}> {children} </ToggleGroupContext.Provider> </ToggleGroupPrimitive.Root> ))

ToggleGroup.displayName = ToggleGroupPrimitive.Root.displayName

const ToggleGroupItem = React.forwardRef(({ className, children, variant, size, ...props }, ref) => { const context = React.useContext(ToggleGroupContext)

return ( (<ToggleGroupPrimitive.Item ref={ref} className={cn(toggleVariants({ variant: context.variant || variant, size: context.size || size, }), className)} {...props}> {children} </ToggleGroupPrimitive.Item>) ); })

ToggleGroupItem.displayName = ToggleGroupPrimitive.Item.displayName

export { ToggleGroup, ToggleGroupItem }