32 lines
803 B
TypeScript
32 lines
803 B
TypeScript
import React, { CSSProperties } from 'react';
|
|
import { IconDefinition } from '@fortawesome/fontawesome-svg-core';
|
|
import tw from 'twin.macro';
|
|
|
|
interface Props {
|
|
icon: IconDefinition;
|
|
className?: string;
|
|
style?: CSSProperties;
|
|
}
|
|
|
|
const Icon = ({ icon, className, style }: Props) => {
|
|
let [width, height, , , paths] = icon.icon;
|
|
|
|
paths = Array.isArray(paths) ? paths : [paths];
|
|
|
|
return (
|
|
<svg
|
|
xmlns={'http://www.w3.org/2000/svg'}
|
|
viewBox={`0 0 ${width} ${height}`}
|
|
css={tw`fill-current inline-block`}
|
|
className={className}
|
|
style={style}
|
|
>
|
|
{paths.map((path, index) => (
|
|
<path key={`svg_path_${index}`} d={path} />
|
|
))}
|
|
</svg>
|
|
);
|
|
};
|
|
|
|
export default Icon;
|