pleroma/app/soapbox/components/ui/icon/svg-icon.tsx

45 lines
1 KiB
TypeScript
Raw Normal View History

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, ...filteredProps }): JSX.Element => {
2022-04-10 10:56:15 -07:00
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'
{...filteredProps}
2022-04-10 11:25:10 -07:00
>
{/* If the fetch fails, fall back to displaying the loader */}
2022-04-10 11:25:10 -07:00
{loader}
</InlineSVG>
2022-04-10 10:56:15 -07:00
);
};
export default SvgIcon;