import React from 'react';
import { createIcon } from '../createIcon';
const accessClassName = (style: any) => {
const styleObject = Array.isArray(style) ? style[0] : style;
const keys = Object.keys(styleObject);
return styleObject[keys[1]];
};
const Svg = React.forwardRef<
React.ComponentRef<'svg'>,
React.ComponentPropsWithoutRef<'svg'>
>(({ style, className, ...props }, ref) => {
const calculateClassName = React.useMemo(() => {
return className === undefined ? accessClassName(style) : className;
}, [className, style]);
return ;
});
export type IPrimitiveIcon = {
height?: number | string;
width?: number | string;
fill?: string;
color?: string;
size?: number | string;
stroke?: string;
as?: React.ElementType;
className?: string;
classNameColor?: string;
style?: any;
};
const PrimitiveIcon = React.forwardRef<
React.ComponentRef,
IPrimitiveIcon
>(
(
{
height,
width,
fill,
color,
classNameColor,
size,
stroke,
as: AsComp,
...props
},
ref
) => {
color = color ?? classNameColor;
const sizeProps = React.useMemo(() => {
if (size) return { size };
if (height && width) return { height, width };
if (height) return { height };
if (width) return { width };
return {};
}, [size, height, width]);
let colorProps = {};
if (fill) {
colorProps = { ...colorProps, fill: fill };
}
if (stroke !== 'currentColor') {
colorProps = { ...colorProps, stroke: stroke };
} else if (stroke === 'currentColor' && color !== undefined) {
colorProps = { ...colorProps, stroke: color };
}
if (AsComp) {
return ;
}
return (
);
}
);
const UIIcon = createIcon({
Root: PrimitiveIcon,
});
export { PrimitiveIcon, Svg, UIIcon };