React Badge - Flowbite
Get started with the badge component to add labels or counters inside paragraphs, buttons, and inputs based on multiple colors and sizes from React and Tailwind CSS
The badge component can be used to show text, labels, and counters inside a small box or circle element which can be placed inside paragraphs, buttons, dropdowns, menu items, and more.
You can choose from multiple examples of badges based on the color, size, and icon and even use it as a link component by leveraging the properties from React and classes from Tailwind CSS.
To start using the badge component you need to import it from flowbite-react
:
import { Badge } from "flowbite-react";
#
Default badgesHere's a list of default <Badge>
component examples where you can use the color
property to change the color of the badge based on contextual colors such as info, gray, success, and more.
import { Badge } from "flowbite-react";
export function Component() {
return (
<div className="flex flex-wrap gap-2">
<Badge color="info">Default</Badge>
<Badge color="gray">Dark</Badge>
<Badge color="failure">Failure</Badge>
<Badge color="success">Success</Badge>
<Badge color="warning">Warning</Badge>
<Badge color="indigo">Indigo</Badge>
<Badge color="purple">Purple</Badge>
<Badge color="pink">Pink</Badge>
</div>
);
}
#
Badge as linkUse the badge as a link component by wrapping it with an anchor element.
import { Badge } from "flowbite-react";
export function Component() {
return (
<div className="flex flex-wrap gap-2">
<a href="#">
<Badge>Default</Badge>
</a>
<a href="#">
<Badge size="sm">Default</Badge>
</a>
</div>
);
}
#
Badge with iconAdd an icon to the badge by using the icon
property and pass the icon component as a value. This can be used to show the status of a task or a notification often used for admin dashboards and user feeds.
"use client";
import { Badge } from "flowbite-react";
import { HiCheck, HiClock } from "react-icons/hi";
export function Component() {
return (
<div className="flex flex-wrap gap-2">
<Badge icon={HiCheck}>2 minutes ago</Badge>
<Badge color="gray" icon={HiClock}>
3 days ago
</Badge>
</div>
);
}
#
Badge with icon onlyAn alternative style for the badge component is by only showing an icon without any text. You can do this by removing the children from the component and only using the icon
property.
"use client";
import { Badge } from "flowbite-react";
import { HiCheck, HiClock } from "react-icons/hi";
export function Component() {
return (
<div className="flex flex-wrap gap-2">
<Badge icon={HiCheck} />
<Badge color="gray" icon={HiCheck} />
<Badge size="sm" icon={HiCheck} />
<Badge color="gray" size="sm" icon={HiCheck} />
</div>
);
}
#
SizesUpdate the size of the badge component by using the size
property and passing the size as a value.
You can choose from xs
and sm
sizes.
import { Badge } from "flowbite-react";
export function Component() {
return (
<div className="flex flex-wrap gap-2">
<Badge color="info" size="sm">
Default
</Badge>
<Badge color="gray" size="sm">
Dark
</Badge>
<Badge color="failure" size="sm">
Failure
</Badge>
<Badge color="success" size="sm">
Success
</Badge>
<Badge color="warning" size="sm">
Warning
</Badge>
<Badge color="indigo" size="sm">
Indigo
</Badge>
<Badge color="purple" size="sm">
Purple
</Badge>
<Badge color="pink" size="sm">
Pink
</Badge>
</div>
);
}
#
ThemeTo learn more about how to customize the appearance of components, please see the Theme docs.
{
"root": {
"base": "flex h-fit items-center gap-1 font-semibold",
"color": {
"info": "bg-cyan-100 text-cyan-800 hover:bg-cyan-200 dark:bg-cyan-200 dark:text-cyan-800 dark:hover:bg-cyan-300",
"gray": "bg-gray-100 text-gray-800 hover:bg-gray-200 dark:bg-gray-700 dark:text-gray-300 dark:hover:bg-gray-600",
"failure": "bg-red-100 text-red-800 hover:bg-red-200 dark:bg-red-200 dark:text-red-900 dark:hover:bg-red-300",
"success": "bg-green-100 text-green-800 hover:bg-green-200 dark:bg-green-200 dark:text-green-900 dark:hover:bg-green-300",
"warning": "bg-yellow-100 text-yellow-800 hover:bg-yellow-200 dark:bg-yellow-200 dark:text-yellow-900 dark:hover:bg-yellow-300",
"indigo": "bg-indigo-100 text-indigo-800 hover:bg-indigo-200 dark:bg-indigo-200 dark:text-indigo-900 dark:hover:bg-indigo-300",
"purple": "bg-purple-100 text-purple-800 hover:bg-purple-200 dark:bg-purple-200 dark:text-purple-900 dark:hover:bg-purple-300",
"pink": "bg-pink-100 text-pink-800 hover:bg-pink-200 dark:bg-pink-200 dark:text-pink-900 dark:hover:bg-pink-300",
"blue": "bg-blue-100 text-blue-800 hover:bg-blue-200 dark:bg-blue-200 dark:text-blue-900 dark:hover:bg-blue-300",
"cyan": "bg-cyan-100 text-cyan-800 hover:bg-cyan-200 dark:bg-cyan-200 dark:text-cyan-900 dark:hover:bg-cyan-300",
"dark": "bg-gray-600 text-gray-100 hover:bg-gray-500 dark:bg-gray-900 dark:text-gray-200 dark:hover:bg-gray-700",
"light": "bg-gray-200 text-gray-800 hover:bg-gray-300 dark:bg-gray-400 dark:text-gray-900 dark:hover:bg-gray-500",
"green": "bg-green-100 text-green-800 hover:bg-green-200 dark:bg-green-200 dark:text-green-900 dark:hover:bg-green-300",
"lime": "bg-lime-100 text-lime-800 hover:bg-lime-200 dark:bg-lime-200 dark:text-lime-900 dark:hover:bg-lime-300",
"red": "bg-red-100 text-red-800 hover:bg-red-200 dark:bg-red-200 dark:text-red-900 dark:hover:bg-red-300",
"teal": "bg-teal-100 text-teal-800 hover:bg-teal-200 dark:bg-teal-200 dark:text-teal-900 dark:hover:bg-teal-300",
"yellow": "bg-yellow-100 text-yellow-800 hover:bg-yellow-200 dark:bg-yellow-200 dark:text-yellow-900 dark:hover:bg-yellow-300"
},
"size": {
"xs": "p-1 text-xs",
"sm": "p-1.5 text-sm"
}
},
"icon": {
"off": "rounded px-2 py-0.5",
"on": "rounded-full p-1.5",
"size": {
"xs": "h-3 w-3",
"sm": "h-3.5 w-3.5"
}
}
}