You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gcgj-dify-1.7.0/web/app/components/base/badge.tsx

38 lines
950 B
TypeScript

import type { ReactNode } from 'react'
import { memo } from 'react'
import cn from '@/utils/classnames'
type BadgeProps = {
className?: string
text?: ReactNode
children?: ReactNode
uppercase?: boolean
hasRedCornerMark?: boolean
}
const Badge = ({
className,
text,
children,
uppercase = true,
hasRedCornerMark,
}: BadgeProps) => {
return (
<div
className={cn(
'border-divider-deep text-text-tertiary relative inline-flex h-5 items-center rounded-[5px] border px-[5px] leading-3',
uppercase ? 'system-2xs-medium-uppercase' : 'system-xs-medium',
className,
)}
>
{hasRedCornerMark && (
<div className='border-components-badge-status-light-error-border-inner bg-components-badge-status-light-error-bg absolute right-[-2px] top-[-2px] h-1.5 w-1.5 rounded-[2px] border shadow-sm'>
</div>
)}
{children || text}
</div>
)
}
export default memo(Badge)