Presets

Blocks

Get PRO

Need premium blocks and templates? Upgrade to PRO and get access.

Upgrade
JoinLogin
Presets
Monochrome
Overview
  • Introduction
  • Components
  • Installation
Components
  • Accordion
  • Alert
  • Alert Dialog
  • Aspect Ratio
  • Avatar
  • Badge
  • Breadcrumb
  • Button
  • Button Group
  • CalendarNEW
  • Card
  • CarouselNEW
  • Checkbox
  • Collapsible
  • Dialog
  • Dropdown Menu
  • Empty
  • Field
  • Input
  • Input Group
  • Item
  • Kbd
  • Label
  • Native Select
  • Scroll Area
  • SelectNEW
  • Separator
  • SwitchNEW
  • Table
  • Tabs
  • Textarea
  • TooltipNEW

Button Group

PreviousNext

A container that groups related buttons together with consistent styling.

1import * as React from "react";2import { Button } from "@/components/ui/button";3import { ButtonGroup } from "@/components/ui/button-group";4import {

Installation

pnpm dlx sprawlify@latest add button-group
npx sprawlify@latest add button-group
yarn sprawlify@latest add button-group
bunx --bun sprawlify@latest add button-group

Install the following dependencies:

pnpm add @sprawlify/primitives @sprawlify/react
npm install @sprawlify/primitives @sprawlify/react
yarn add @sprawlify/primitives @sprawlify/react
bun add @sprawlify/primitives @sprawlify/react

Add the following files to your project:

button-group.tsx
1"use client";23import { cva, type VariantProps } from "class-variance-authority";4import { cn } from "@/lib/utils";5import { Separator } from "@/components/ui/separator";6import { sprawlify } from "@sprawlify/react";78const buttonGroupVariants = cva(9  "has-[>[data-slot=button-group]]:gap-2 has-[select[aria-hidden=true]:last-child]:[&>[data-slot=select-trigger]:last-of-type]:rounded-r-lg flex w-fit items-stretch *:focus-visible:z-10 *:focus-visible:relative [&>[data-slot=select-trigger]:not([class*='w-'])]:w-fit [&>input]:flex-1",10  {11    variants: {12      orientation: {13        horizontal:14          "[&>[data-slot]:not(:has(~[data-slot]))]:rounded-r-lg! [&>*:not(:first-child)]:rounded-l-none [&>*:not(:first-child)]:border-l-0 [&>*:not(:last-child)]:rounded-r-none",15        vertical:16          "[&>[data-slot]:not(:has(~[data-slot]))]:rounded-b-lg! flex-col [&>*:not(:first-child)]:rounded-t-none [&>*:not(:first-child)]:border-t-0 [&>*:not(:last-child)]:rounded-b-none",17      },18    },19    defaultVariants: {20      orientation: "horizontal",21    },22  },23);2425function ButtonGroup({26  className,27  orientation,28  ...props29}: React.ComponentProps<typeof sprawlify.div> & VariantProps<typeof buttonGroupVariants>) {30  return (31    <sprawlify.div32      data-scope="button-group"33      data-part="root"34      role="group"35      data-slot="button-group"36      data-orientation={orientation}37      className={cn(buttonGroupVariants({ orientation, className }))}38      {...props}39    />40  );41}4243function ButtonGroupText({ className, ...props }: React.ComponentProps<typeof sprawlify.div>) {44  return (45    <sprawlify.div46      className={cn(47        "bg-muted gap-2 rounded-lg border px-2.5 text-sm font-medium [&_svg:not([class*='size-'])]:size-4 flex items-center [&_svg]:pointer-events-none",48        className,49      )}50      {...props}51    />52  );53}5455function ButtonGroupSeparator({56  className,57  orientation = "vertical",58  ...props59}: React.ComponentProps<typeof Separator>) {60  return (61    <Separator62      data-scope="button-group"63      data-part="separator"64      data-slot="button-group-separator"65      orientation={orientation}66      className={cn(67        "bg-input relative self-stretch data-horizontal:mx-px data-horizontal:w-auto data-vertical:my-px data-vertical:h-auto",68        className,69      )}70      {...props}71    />72  );73}7475export { ButtonGroup, ButtonGroupSeparator, ButtonGroupText, buttonGroupVariants };76

Update the import paths to match your project setup.

Usage

1import {
2  ButtonGroup,
3  ButtonGroupSeparator,
4  ButtonGroupText
5} from "@/components/ui/button-group"
1<ButtonGroup>
2  <Button>Button 1</Button>
3  <Button>Button 2</Button>
4</ButtonGroup>

Examples

Orientation

Set the orientation prop to change the button group layout.

1import { Button } from "@/components/ui/button";2import { ButtonGroup } from "@/components/ui/button-group";3import { MinusIcon, PlusIcon } from "lucide-react";4

Separator

The ButtonGroupSeparator component visually divides buttons within a group.

1import { Button } from "@/components/ui/button";2import { ButtonGroup, ButtonGroupSeparator } from "@/components/ui/button-group";34export default function Preview() {

Size

Control the size of buttons using the size prop on individual buttons.

1import { Button } from "@/components/ui/button";2import { ButtonGroup } from "@/components/ui/button-group";3import { PlusIcon } from "lucide-react";4

Split

Create a split button group by adding two buttons separated by a ButtonGroupSeparator.

1import { Button } from "@/components/ui/button";2import { ButtonGroup, ButtonGroupSeparator } from "@/components/ui/button-group";3import { PlusIcon } from "lucide-react";4

On This Page

InstallationUsageExamplesOrientationSeparatorSizeSplit

Get PRO

Need premium blocks and templates? Upgrade to PRO and get access.