mirror of
https://github.com/streamyfin/streamyfin.git
synced 2026-01-15 15:48:05 +00:00
Co-authored-by: Alex Kim <alexkim@Alexs-MacBook-Pro.local> Co-authored-by: Fredrik Burmester <fredrik.burmester@gmail.com> Co-authored-by: Simon-Eklundh <simon.eklundh@proton.me>
71 lines
2.0 KiB
TypeScript
71 lines
2.0 KiB
TypeScript
import type { BaseItemDto } from "@jellyfin/sdk/lib/generated-client/models";
|
|
import { Image } from "expo-image";
|
|
import { useAtom } from "jotai";
|
|
import React, { useCallback, useMemo } from "react";
|
|
import { TouchableOpacity, View } from "react-native";
|
|
import { Text } from "@/components/common/Text";
|
|
import useRouter from "@/hooks/useAppRouter";
|
|
import { apiAtom } from "@/providers/JellyfinProvider";
|
|
import { getPrimaryImageUrl } from "@/utils/jellyfin/image/getPrimaryImageUrl";
|
|
|
|
interface Props {
|
|
album: BaseItemDto;
|
|
}
|
|
|
|
const IMAGE_SIZE = 56;
|
|
|
|
export const MusicAlbumRowCard: React.FC<Props> = ({ album }) => {
|
|
const [api] = useAtom(apiAtom);
|
|
const router = useRouter();
|
|
|
|
const imageUrl = useMemo(
|
|
() => getPrimaryImageUrl({ api, item: album }),
|
|
[api, album],
|
|
);
|
|
|
|
const handlePress = useCallback(() => {
|
|
router.push({
|
|
pathname: "/music/album/[albumId]",
|
|
params: { albumId: album.Id! },
|
|
});
|
|
}, [router, album.Id]);
|
|
|
|
return (
|
|
<TouchableOpacity
|
|
onPress={handlePress}
|
|
className='flex-row items-center py-2'
|
|
>
|
|
<View
|
|
style={{
|
|
width: IMAGE_SIZE,
|
|
height: IMAGE_SIZE,
|
|
borderRadius: 8,
|
|
overflow: "hidden",
|
|
backgroundColor: "#1a1a1a",
|
|
}}
|
|
>
|
|
{imageUrl ? (
|
|
<Image
|
|
source={{ uri: imageUrl }}
|
|
style={{ width: "100%", height: "100%" }}
|
|
contentFit='cover'
|
|
cachePolicy='memory-disk'
|
|
/>
|
|
) : (
|
|
<View className='flex-1 items-center justify-center bg-neutral-800'>
|
|
<Text className='text-2xl'>🎵</Text>
|
|
</View>
|
|
)}
|
|
</View>
|
|
<View className='flex-1 ml-3'>
|
|
<Text numberOfLines={1} className='text-white text-base font-medium'>
|
|
{album.Name}
|
|
</Text>
|
|
<Text numberOfLines={1} className='text-neutral-400 text-sm mt-0.5'>
|
|
{album.AlbumArtist || album.Artists?.join(", ")}
|
|
</Text>
|
|
</View>
|
|
</TouchableOpacity>
|
|
);
|
|
};
|