mirror of
https://github.com/streamyfin/streamyfin.git
synced 2025-08-20 18:37:18 +02:00
57 lines
1.5 KiB
TypeScript
57 lines
1.5 KiB
TypeScript
import React, {PropsWithChildren} from "react";
|
|
import DiscoverSlider from "@/utils/jellyseerr/server/entity/DiscoverSlider";
|
|
import { DiscoverSliderType } from "@/utils/jellyseerr/server/constants/discover";
|
|
import { Text } from "@/components/common/Text";
|
|
import { FlashList } from "@shopify/flash-list";
|
|
import {View, ViewProps} from "react-native";
|
|
import { t } from "i18next";
|
|
|
|
export interface SlideProps {
|
|
slide: DiscoverSlider;
|
|
}
|
|
|
|
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 extends unknown>({
|
|
data,
|
|
slide,
|
|
renderItem,
|
|
keyExtractor,
|
|
onEndReached,
|
|
...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,
|
|
}}
|
|
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;
|