Badge

A short text to represent a status or a category.

Usage

Label

Use the default slot to set the label of the Badge.

Badge
<template>
  <UBadge>Badge</UBadge>
</template>

You can achieve the same result by using the label prop.

Badge
<template>
  <UBadge label="Badge" />
</template>

Color

Use the color prop to change the color of the Badge.

Badge
<template>
  <UBadge color="neutral">Badge</UBadge>
</template>

Variant

Use the variant props to change the variant of the Badge.

Badge
<template>
  <UBadge color="neutral" variant="outline">Badge</UBadge>
</template>

Size

Use the size prop to change the size of the Badge.

Badge
<template>
  <UBadge size="lg">Badge</UBadge>
</template>

Icon

Use the icon prop to show an Icon inside the Badge.

Badge
<template>
  <UBadge icon="i-lucide-rocket">Badge</UBadge>
</template>

Use the leading and trailing props to set the icon position or the leading-icon and trailing-icon props to set a different icon for each position.

Badge
<template>
  <UBadge trailing-icon="i-lucide-arrow-right">Badge</UBadge>
</template>

Avatar

Use the avatar prop to show an Avatar inside the Badge.

Badge
<template>
  <UBadge
    :avatar="{
      src: 'https://github.com/nuxt.png'
    }"
    color="neutral"
    variant="outline"
  >
    Badge
  </UBadge>
</template>

Examples

class prop

Use the class prop to override the base styles of the Badge.

Badge
<template>
  <UBadge class="font-bold rounded-full">Badge</UBadge>
</template>

API

Props

Prop Default Type
as

"span"

any

The element or component this component should render as.

label

string | number

color

primary

"error" | "primary" | "secondary" | "success" | "info" | "warning" | "neutral"

variant

solid

"solid" | "outline" | "soft" | "subtle"

size

md

"md" | "sm" | "lg"

icon

string

Display an icon based on the leading and trailing props.

avatar

AvatarProps

Display an avatar on the left side.

leading

boolean

When true, the icon will be displayed on the left side.

leadingIcon

string

Display an icon on the left side.

trailing

boolean

When true, the icon will be displayed on the right side.

trailingIcon

string

Display an icon on the right side.

ui

Partial<{ base: string; label: string; leadingIcon: string; leadingAvatar: string; leadingAvatarSize: string; trailingIcon: string; }>

Slots

Slot Type
leading

{}

default

{}

trailing

{}

Theme

app.config.ts
export default defineAppConfig({
  ui: {
    badge: {
      slots: {
        base: 'rounded-[calc(var(--ui-radius)*1.5)] font-medium inline-flex items-center',
        label: 'truncate',
        leadingIcon: 'shrink-0',
        leadingAvatar: 'shrink-0',
        leadingAvatarSize: '',
        trailingIcon: 'shrink-0'
      },
      variants: {
        color: {
          primary: '',
          secondary: '',
          success: '',
          info: '',
          warning: '',
          error: '',
          neutral: ''
        },
        variant: {
          solid: '',
          outline: '',
          soft: '',
          subtle: ''
        },
        size: {
          sm: {
            base: 'text-xs px-1.5 py-0.5 gap-1',
            leadingIcon: 'size-4',
            leadingAvatarSize: '3xs',
            trailingIcon: 'size-4'
          },
          md: {
            base: 'text-xs px-2 py-1 gap-1',
            leadingIcon: 'size-4',
            leadingAvatarSize: '3xs',
            trailingIcon: 'size-4'
          },
          lg: {
            base: 'text-sm px-2 py-1 gap-1.5',
            leadingIcon: 'size-5',
            leadingAvatarSize: '2xs',
            trailingIcon: 'size-5'
          }
        }
      },
      compoundVariants: [
        {
          color: 'primary',
          variant: 'solid',
          class: 'bg-[var(--ui-primary)] text-[var(--ui-bg)]'
        },
        {
          color: 'primary',
          variant: 'outline',
          class: 'text-[var(--ui-primary)] ring ring-inset ring-[var(--ui-primary)]/50'
        },
        {
          color: 'primary',
          variant: 'soft',
          class: 'bg-[var(--ui-primary)]/10 text-[var(--ui-primary)]'
        },
        {
          color: 'primary',
          variant: 'subtle',
          class: 'bg-[var(--ui-primary)]/10 text-[var(--ui-primary)] ring ring-inset ring-[var(--ui-primary)]/25'
        },
        {
          color: 'neutral',
          variant: 'solid',
          class: 'text-[var(--ui-bg)] bg-[var(--ui-bg-inverted)]'
        },
        {
          color: 'neutral',
          variant: 'outline',
          class: 'ring ring-inset ring-[var(--ui-border-accented)] text-[var(--ui-text)] bg-[var(--ui-bg)]'
        },
        {
          color: 'neutral',
          variant: 'soft',
          class: 'text-[var(--ui-text)] bg-[var(--ui-bg-elevated)]'
        },
        {
          color: 'neutral',
          variant: 'subtle',
          class: 'ring ring-inset ring-[var(--ui-border-accented)] text-[var(--ui-text)] bg-[var(--ui-bg-elevated)]'
        }
      ],
      defaultVariants: {
        color: 'primary',
        variant: 'solid',
        size: 'md'
      }
    }
  }
})
Some colors in compoundVariants are omitted for readability. Check out the source code on GitHub.