Vercel/src/camera/PhotoCamera.tsx
2025-03-16 15:44:55 -05:00

49 lines
1.1 KiB
TypeScript

import { AiFillApple } from 'react-icons/ai';
import { pathForCamera } from '@/app/paths';
import { Camera, formatCameraText, isCameraApple } from '.';
import EntityLink, {
EntityLinkExternalProps,
} from '@/components/primitives/EntityLink';
import IconCamera from '@/components/icons/IconCamera';
export default function PhotoCamera({
camera,
hideAppleIcon,
type,
badged,
contrast,
prefetch,
countOnHover,
className,
}: {
camera: Camera
hideAppleIcon?: boolean
countOnHover?: number
} & EntityLinkExternalProps) {
const isApple = isCameraApple(camera);
const showAppleIcon = !hideAppleIcon && isApple;
return (
<EntityLink
label={formatCameraText(camera)}
href={pathForCamera(camera)}
icon={showAppleIcon
? <AiFillApple
title="Apple"
className="translate-x-[-1px] translate-y-[-0.5px]"
size={15}
/>
: <IconCamera
size={15}
className="translate-x-[-0.5px]"
/>}
type={type}
className={className}
badged={badged}
contrast={contrast}
prefetch={prefetch}
hoverEntity={countOnHover}
/>
);
}