Files
dify/web/app/components/base/icons/IconBase.tsx
Stephen Zhou 36e840cd87 chore: knip fix (#34481)
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
2026-04-02 15:03:42 +00:00

40 lines
740 B
TypeScript

import type { AbstractNode } from './utils'
import { generate } from './utils'
export type IconData = {
name: string
icon: AbstractNode
}
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