owncast/web/components/ui/SocialLinks/SocialLinks.tsx

51 lines
1.4 KiB
TypeScript

import Image from 'next/image';
import { FC } from 'react';
import { ErrorBoundary } from 'react-error-boundary';
import { SocialLink } from '../../../interfaces/social-link.model';
import { ComponentError } from '../ComponentError/ComponentError';
import styles from './SocialLinks.module.scss';
export type SocialLinksProps = {
links: SocialLink[];
};
export const SocialLinks: FC<SocialLinksProps> = ({ links }) => {
if (!links?.length) {
return null;
}
return (
<ErrorBoundary
// eslint-disable-next-line react/no-unstable-nested-components
fallbackRender={({ error, resetErrorBoundary }) => (
<ComponentError
componentName="SocialLinks"
message={error.message}
retryFunction={resetErrorBoundary}
/>
)}
>
<div className={styles.links}>
{links?.map(link => (
<a
key={link.platform}
href={link.url}
className={styles.link}
target="_blank"
// eslint-disable-next-line react/no-invalid-html-attribute
rel="noreferrer me"
>
<Image
src={link.icon || '/img/platformlogos/default.svg'}
alt={link.platform}
className={styles.link}
width="30"
height="30"
/>
</a>
))}
</div>
</ErrorBoundary>
);
};