feat(admin): add dynamic role color support for user badges

This commit is contained in:
2026-04-22 15:08:46 -04:00
parent 13410a6dd9
commit 1613bd5275
3 changed files with 34 additions and 7 deletions
+12 -3
View File
@@ -6,11 +6,12 @@ const Badge = ({
children,
variant = 'default',
size = 'sm',
color = null,
className = '',
...props
}) => {
const baseClassName = 'inline-flex items-center font-medium border font-ibm-plex-mono';
const variants = {
default: 'bg-neutral-100 text-neutral-700 border-neutral-200 dark:bg-neutral-500/10 dark:text-neutral-400 dark:border-neutral-500/20',
primary: 'bg-blue-100 text-blue-700 border-blue-200 dark:bg-blue-500/10 dark:text-blue-400 dark:border-blue-500/20',
@@ -22,16 +23,24 @@ const Badge = ({
pink: 'bg-pink-100 text-pink-700 border-pink-200 dark:bg-pink-500/10 dark:text-pink-400 dark:border-pink-500/20',
orange: 'bg-orange-100 text-orange-700 border-orange-200 dark:bg-orange-500/10 dark:text-orange-400 dark:border-orange-500/20'
};
const sizes = {
sm: 'px-[8px] py-[2px] rounded-lg text-[11px]',
md: 'px-[8px] py-[2px] rounded-lg text-[11px]',
lg: 'px-3 py-1 rounded-lg text-xs'
};
const variantClass = color ? '' : (variants[variant] || variants.default);
const colorStyle = color ? {
backgroundColor: `${color}1a`,
color: color,
borderColor: `${color}33`,
} : {};
return (
<span
className={`${baseClassName} ${variants[variant]} ${sizes[size]} ${className}`}
className={`${baseClassName} ${variantClass} ${sizes[size]} ${className}`.trim()}
style={colorStyle}
{...props}
>
{children}