UNPKG

react-native-draggable-flatlist

Version:
55 lines (54 loc) 1.96 kB
import React from "react"; import { FlatListProps, StyleProp, ViewStyle } from "react-native"; import { FlatList } from "react-native-gesture-handler"; import Animated from "react-native-reanimated"; import { DEFAULT_PROPS } from "./constants"; export declare type DragEndParams<T> = { data: T[]; from: number; to: number; }; declare type Modify<T, R> = Omit<T, keyof R> & R; declare type DefaultProps = Readonly<typeof DEFAULT_PROPS>; export declare type DraggableFlatListProps<T> = Modify<FlatListProps<T>, { data: T[]; activationDistance?: number; animationConfig?: Partial<Animated.SpringConfig>; autoscrollSpeed?: number; autoscrollThreshold?: number; containerStyle?: StyleProp<ViewStyle>; debug?: boolean; dragItemOverflow?: boolean; keyExtractor: (item: T, index: number) => string; onDragBegin?: (index: number) => void; onDragEnd?: (params: DragEndParams<T>) => void; onPlaceholderIndexChange?: (placeholderIndex: number) => void; onRef?: (ref: FlatList<T>) => void; onRelease?: (index: number) => void; onScrollOffsetChange?: (scrollOffset: number) => void; renderItem: RenderItem<T>; renderPlaceholder?: RenderPlaceholder<T>; simultaneousHandlers?: React.Ref<any> | React.Ref<any>[]; } & Partial<DefaultProps>>; export declare type RenderPlaceholder<T> = (params: { item: T; index: number; }) => JSX.Element; export declare type RenderItemParams<T> = { item: T; index?: number; drag: () => void; isActive: boolean; }; export declare type RenderItem<T> = (params: RenderItemParams<T>) => React.ReactNode; export declare type AnimatedFlatListType = <T>(props: Animated.AnimateProps<FlatListProps<T> & { ref: React.Ref<FlatList<T>>; simultaneousHandlers?: React.Ref<any> | React.Ref<any>[]; }>) => React.ReactElement; export declare type CellData = { measurements: { size: number; offset: number; }; }; export {};