mirror of
				https://github.com/langgenius/dify.git
				synced 2025-11-04 12:53:38 +00: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>
 | 
						|
  )
 | 
						|
}
 |