40 lines
1.2 KiB
TypeScript
40 lines
1.2 KiB
TypeScript
type StatusType = 'success' | 'error' | 'warning' | 'default' | 'processing';
|
|
|
|
interface StatusDotProps {
|
|
status: StatusType | boolean;
|
|
text?: string;
|
|
className?: string;
|
|
size?: 'default' | 'sm' | 'lg';
|
|
pulse?: boolean;
|
|
}
|
|
|
|
export function StatusDot({
|
|
status,
|
|
text,
|
|
className = '',
|
|
size = 'default',
|
|
pulse = false
|
|
}: StatusDotProps) {
|
|
// 如果status是布尔值,则转换为对应的状态类型
|
|
const statusType = typeof status === 'boolean'
|
|
? (status ? 'success' : 'default')
|
|
: status;
|
|
|
|
// 如果没有提供文本,则根据状态类型提供默认文本
|
|
const statusText = text ?? (
|
|
statusType === 'success' ? '启用' :
|
|
statusType === 'error' ? '禁用' :
|
|
statusType === 'warning' ? '警告' :
|
|
statusType === 'processing' ? '处理中' : '未知'
|
|
);
|
|
|
|
const sizeClass = size !== 'default' ? `status-dot-${size}` : '';
|
|
const pulseClass = pulse ? 'status-dot-pulse' : '';
|
|
|
|
return (
|
|
<span className={`status-dot-with-text ${className}`}>
|
|
<span className={`status-dot status-dot-${statusType} ${sizeClass} ${pulseClass}`}></span>
|
|
<span className="status-dot-text">{statusText}</span>
|
|
</span>
|
|
);
|
|
}
|