import { Center, Group } from '@mantine/core'; import { closeAllModals, openModal } from '@mantine/modals'; import { AutoTextSize } from 'auto-text-size'; import clsx from 'clsx'; import { forwardRef, ReactNode, Ref, useCallback, useState } from 'react'; import { useTranslation } from 'react-i18next'; import { Link } from 'react-router-dom'; import styles from './library-header.module.css'; import { Text } from '/@/renderer/components'; import { ItemImagePlaceholder } from '/@/renderer/features/shared/components/item-image-placeholder'; import { useGeneralSettings } from '/@/renderer/store'; import { LibraryItem } from '/@/shared/types/domain-types'; interface LibraryHeaderProps { background?: string; blur?: number; children?: ReactNode; imagePlaceholderUrl?: null | string; imageUrl?: null | string; item: { route: string; type: LibraryItem }; loading?: boolean; title: string; } export const LibraryHeader = forwardRef( ( { background, blur, children, imageUrl, item, loading, title }: LibraryHeaderProps, ref: Ref, ) => { const { t } = useTranslation(); const [isImageError, setIsImageError] = useState(false); const { albumBackground } = useGeneralSettings(); const onImageError = () => { setIsImageError(true); }; const itemTypeString = () => { switch (item.type) { case LibraryItem.ALBUM: return t('entity.album', { count: 1 }); case LibraryItem.ALBUM_ARTIST: return t('entity.albumArtist', { count: 1 }); case LibraryItem.ARTIST: return t('entity.artist', { count: 1 }); case LibraryItem.PLAYLIST: return t('entity.playlist', { count: 1 }); case LibraryItem.SONG: return t('entity.track', { count: 1 }); default: return t('common.unknown'); } }; const openImage = useCallback(() => { if (imageUrl && !isImageError) { const fullSized = imageUrl.replace(/&?(size|width|height)=\d+/, ''); openModal({ children: (
closeAllModals()} style={{ cursor: 'pointer', height: 'calc(100vh - 80px)', width: '100%', }} > cover
), fullScreen: true, }); } }, [imageUrl, isImageError]); return (
openImage()} onKeyDown={(event) => [' ', 'Enter', 'Spacebar'].includes(event.key) && openImage() } role="button" style={{ cursor: 'pointer' }} tabIndex={0} > {!loading && (imageUrl && !isImageError ? ( cover ) : ( ))}
{title && (

{itemTypeString()}

{title}

{children}
)}
); }, );