mirror of
https://gitlab.com/mbugroup/lti-web-client.git
synced 2026-05-25 15:55:48 +00:00
feat(FE-Storyless): add Badge component with customizable variants, colors, and sizes
This commit is contained in:
@@ -0,0 +1,80 @@
|
|||||||
|
'use client';
|
||||||
|
|
||||||
|
import { HTMLAttributes, ReactNode } from 'react';
|
||||||
|
|
||||||
|
import { cn } from '@/lib/helper';
|
||||||
|
|
||||||
|
export interface BadgeProps
|
||||||
|
extends Omit<HTMLAttributes<HTMLSpanElement>, 'className'> {
|
||||||
|
children?: ReactNode;
|
||||||
|
className?: {
|
||||||
|
badge?: string;
|
||||||
|
};
|
||||||
|
variant?: 'default' | 'outline' | 'ghost' | 'soft' | 'dash';
|
||||||
|
color?:
|
||||||
|
| 'neutral'
|
||||||
|
| 'primary'
|
||||||
|
| 'secondary'
|
||||||
|
| 'accent'
|
||||||
|
| 'info'
|
||||||
|
| 'success'
|
||||||
|
| 'warning'
|
||||||
|
| 'error';
|
||||||
|
size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl';
|
||||||
|
}
|
||||||
|
|
||||||
|
const Badge = ({
|
||||||
|
children,
|
||||||
|
className,
|
||||||
|
variant = 'default',
|
||||||
|
color,
|
||||||
|
size = 'md',
|
||||||
|
...props
|
||||||
|
}: BadgeProps) => {
|
||||||
|
const getBadgeClasses = () => {
|
||||||
|
const baseClasses = 'badge';
|
||||||
|
|
||||||
|
const variantClasses = {
|
||||||
|
default: '',
|
||||||
|
outline: 'badge-outline',
|
||||||
|
ghost: 'badge-ghost',
|
||||||
|
soft: 'badge-soft',
|
||||||
|
dash: 'badge-dash',
|
||||||
|
};
|
||||||
|
|
||||||
|
const colorClasses = {
|
||||||
|
neutral: 'badge-neutral',
|
||||||
|
primary: 'badge-primary',
|
||||||
|
secondary: 'badge-secondary',
|
||||||
|
accent: 'badge-accent',
|
||||||
|
info: 'badge-info',
|
||||||
|
success: 'badge-success',
|
||||||
|
warning: 'badge-warning',
|
||||||
|
error: 'badge-error',
|
||||||
|
};
|
||||||
|
|
||||||
|
const sizeClasses = {
|
||||||
|
xs: 'badge-xs',
|
||||||
|
sm: 'badge-sm',
|
||||||
|
md: 'badge-md',
|
||||||
|
lg: 'badge-lg',
|
||||||
|
xl: 'badge-xl',
|
||||||
|
};
|
||||||
|
|
||||||
|
return cn(
|
||||||
|
baseClasses,
|
||||||
|
variantClasses[variant],
|
||||||
|
color && colorClasses[color],
|
||||||
|
sizeClasses[size],
|
||||||
|
className?.badge
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<span className={getBadgeClasses()} {...props}>
|
||||||
|
{children}
|
||||||
|
</span>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default Badge;
|
||||||
Reference in New Issue
Block a user