Files
dify/web/app/components/base/icons/IconBase.tsx
2025-09-05 10:14:13 +08:00

40 lines
748 B
TypeScript

import { generate } from './utils'
import type { AbstractNode } from './utils'
export type IconData = {
name: string
icon: AbstractNode
}
export type IconBaseProps = {
data: IconData
className?: string
onClick?: React.MouseEventHandler<SVGElement>
style?: React.CSSProperties
}
const IconBase = (
{
ref,
...props
}: IconBaseProps & {
ref?: React.RefObject<React.RefObject<HTMLOrSVGElement>>;
},
) => {
const { data, className, onClick, style, ...restProps } = props
return generate(data.icon, `svg-${data.name}`, {
className,
onClick,
style,
'data-icon': data.name,
'aria-hidden': 'true',
...restProps,
'ref': ref,
})
}
IconBase.displayName = 'IconBase'
export default IconBase