pleroma/app/soapbox/components/ui/icon/svg-icon.tsx
2022-04-30 23:39:58 -05:00

43 lines
994 B
TypeScript

import React from 'react';
import InlineSVG from 'react-inlinesvg'; // eslint-disable-line no-restricted-imports
interface ISvgIcon {
/** Class name for the <svg> */
className?: string,
/** Tooltip text for the icon. */
alt?: string,
/** URL to the svg file. */
src: string,
/** Width and height of the icon in pixels. */
size?: number,
}
/** Renders an inline SVG with an empty frame loading state */
const SvgIcon: React.FC<ISvgIcon> = ({ src, alt, size = 24, className }): JSX.Element => {
const loader = (
<svg
className={className}
width={size}
height={size}
data-src={src}
data-testid='svg-icon-loader'
/>
);
return (
<InlineSVG
className={className}
src={src}
title={alt}
width={size}
height={size}
loader={loader}
data-testid='svg-icon'
>
{/* If the fetch fails, fall back to displaying the loader */}
{loader}
</InlineSVG>
);
};
export default SvgIcon;