How to pass in a React icon as a prop and style it with Tailwind
Hello I'm trying to create a reusable react component that takes in an icon and I want to style said icon with a base style. I included some screenshots of what I have so far. I've been at this for a while, any help would be very much appreciated.
data:image/s3,"s3://crabby-images/6db41/6db41523e4f1b0daf1b06fe89df9f445754b6b70" alt=""
data:image/s3,"s3://crabby-images/90a23/90a234f7a5f93adf7242bac5c06e82049e8ceb35" alt=""
10 Replies
Set the type as React.ReactNode
You could also use JSX.Element or React Element
I believe
React.ReactNode
is the most permissiveI get the same type error in both
data:image/s3,"s3://crabby-images/72b69/72b690ecc3d1e84f56ba3dd6ee11a1c3b0fa6218" alt=""
data:image/s3,"s3://crabby-images/3447b/3447b2298d7229a3870d1372ae9d15d8e422a18f" alt=""
Unknown User•3y ago
Message Not Public
Sign In & Join Server To View
HTMLProps<HTMLButtonElement>
work? Ovs with htmlsvg element or whatever it isimport { HomeIcon } from "@heroicons/react/20/solid";
interface IButtonProps {
Icon: React.ReactNode;
}
const Button = ({ Icon }: IButtonProps) => {
return <>{Icon} Click me!</>;
};
export default function Test() {
return (
<>
<Button Icon={<HomeIcon className="text-lime-500" />} />
</>
);
}
Unknown User•3y ago
Message Not Public
Sign In & Join Server To View
I got it working by this thank you guys so much, I did a mix of everything you guys said. Thx everyone 😁😁
data:image/s3,"s3://crabby-images/d12dd/d12dd481b27482dafbe99e240bf0bbe0ea79badb" alt=""
data:image/s3,"s3://crabby-images/7ced9/7ced996533be84f70eee1da5b41bcfe0992d5de1" alt=""
Unknown User•3y ago
Message Not Public
Sign In & Join Server To View
There's something additionally needed for a type-safe usage. You can give the icon props as a generic, but then you need to make TypeScript happy by also checking whether this is a valid React element: