mirror of
https://git.mirrors.martin98.com/https://github.com/langgenius/dify.git
synced 2025-05-25 23:58:15 +08:00

Signed-off-by: -LAN- <laipz8200@outlook.com> Co-authored-by: -LAN- <laipz8200@outlook.com>
60 lines
1.7 KiB
TypeScript
60 lines
1.7 KiB
TypeScript
'use client'
|
|
|
|
import classNames from '@/utils/classnames'
|
|
|
|
export type IndicatorProps = {
|
|
color?: 'green' | 'orange' | 'red' | 'blue' | 'yellow' | 'gray'
|
|
className?: string
|
|
}
|
|
|
|
export type ColorMap = {
|
|
green: string
|
|
orange: string
|
|
red: string
|
|
blue: string
|
|
yellow: string
|
|
gray: string
|
|
}
|
|
|
|
const BACKGROUND_MAP: ColorMap = {
|
|
green: 'bg-components-badge-status-light-success-bg',
|
|
orange: 'bg-components-badge-status-light-warning-bg',
|
|
red: 'bg-components-badge-status-light-error-bg',
|
|
blue: 'bg-components-badge-status-light-normal-bg',
|
|
yellow: 'bg-components-badge-status-light-warning-bg',
|
|
gray: 'bg-components-badge-status-light-disabled-bg',
|
|
}
|
|
const BORDER_MAP: ColorMap = {
|
|
green: 'border-components-badge-status-light-success-border-inner',
|
|
orange: 'border-components-badge-status-light-warning-border-inner',
|
|
red: 'border-components-badge-status-light-error-border-inner',
|
|
blue: 'border-components-badge-status-light-normal-border-inner',
|
|
yellow: 'border-components-badge-status-light-warning-border-inner',
|
|
gray: 'border-components-badge-status-light-disabled-border-inner',
|
|
}
|
|
const SHADOW_MAP: ColorMap = {
|
|
green: 'shadow-status-indicator-green-shadow',
|
|
orange: 'shadow-status-indicator-warning-shadow',
|
|
red: 'shadow-status-indicator-red-shadow',
|
|
blue: 'shadow-status-indicator-blue-shadow',
|
|
yellow: 'shadow-status-indicator-warning-shadow',
|
|
gray: 'shadow-status-indicator-gray-shadow',
|
|
}
|
|
|
|
export default function Indicator({
|
|
color = 'green',
|
|
className = '',
|
|
}: IndicatorProps) {
|
|
return (
|
|
<div className={classNames(
|
|
'w-2 h-2 border border-solid rounded-[3px]',
|
|
BACKGROUND_MAP[color],
|
|
BORDER_MAP[color],
|
|
SHADOW_MAP[color],
|
|
className,
|
|
)}>
|
|
|
|
</div>
|
|
)
|
|
}
|