mirror of
https://github.com/streamyfin/streamyfin.git
synced 2026-01-15 15:48:05 +00:00
62 lines
1.7 KiB
TypeScript
62 lines
1.7 KiB
TypeScript
import { Text } from "@/components/common/Text";
|
|
import { DiscoverSliderType } from "@/utils/jellyseerr/server/constants/discover";
|
|
import type DiscoverSlider from "@/utils/jellyseerr/server/entity/DiscoverSlider";
|
|
import { FlashList } from "@shopify/flash-list";
|
|
import type { ContentStyle } from "@shopify/flash-list/src/FlashListProps";
|
|
import { t } from "i18next";
|
|
import type React from "react";
|
|
import type { PropsWithChildren } from "react";
|
|
import { View, type ViewProps } from "react-native";
|
|
|
|
export interface SlideProps {
|
|
slide: DiscoverSlider;
|
|
contentContainerStyle?: ContentStyle;
|
|
}
|
|
|
|
interface Props<T> extends SlideProps {
|
|
data: T[];
|
|
renderItem: (
|
|
item: T,
|
|
index: number,
|
|
) => React.ComponentType<any> | React.ReactElement | null | undefined;
|
|
keyExtractor: (item: T) => string;
|
|
onEndReached?: (() => void) | null | undefined;
|
|
}
|
|
|
|
const Slide = <T,>({
|
|
data,
|
|
slide,
|
|
renderItem,
|
|
keyExtractor,
|
|
onEndReached,
|
|
contentContainerStyle,
|
|
...props
|
|
}: PropsWithChildren<Props<T> & ViewProps>) => {
|
|
return (
|
|
<View {...props}>
|
|
<Text className='font-bold text-lg mb-2 px-4'>
|
|
{t(`search.${DiscoverSliderType[slide.type].toString().toLowerCase()}`)}
|
|
</Text>
|
|
<FlashList
|
|
horizontal
|
|
contentContainerStyle={{
|
|
paddingHorizontal: 16,
|
|
...(contentContainerStyle ? contentContainerStyle : {}),
|
|
}}
|
|
showsHorizontalScrollIndicator={false}
|
|
keyExtractor={keyExtractor}
|
|
estimatedItemSize={250}
|
|
data={data}
|
|
onEndReachedThreshold={1}
|
|
onEndReached={onEndReached}
|
|
//@ts-ignore
|
|
renderItem={({ item, index }) =>
|
|
item ? renderItem(item, index) : <></>
|
|
}
|
|
/>
|
|
</View>
|
|
);
|
|
};
|
|
|
|
export default Slide;
|