From 9ef82bf140712ed301153da65daf985d1a8c2b72 Mon Sep 17 00:00:00 2001 From: ryuyutyo Date: Fri, 3 Jan 2025 00:19:46 +0800 Subject: [PATCH] feat: update masonry --- ui/list/src/react-native/List.tsx | 2 +- ui/masonry/src/react-native/MasonryList.tsx | 61 ++++++++++++------- .../src/react-native/types/masonryList.ts | 10 +-- ui/masonry/src/react/MasonryList.tsx | 19 ++++-- 4 files changed, 58 insertions(+), 34 deletions(-) diff --git a/ui/list/src/react-native/List.tsx b/ui/list/src/react-native/List.tsx index 6ff53cd7..e756ee9b 100644 --- a/ui/list/src/react-native/List.tsx +++ b/ui/list/src/react-native/List.tsx @@ -64,7 +64,7 @@ const List = (props: ListProps) => { display: 'flex', height: '100%', flexDirection: 'row', - backgroundColor: 'blue', + // backgroundColor: 'blue', position: 'relative', }; return style; diff --git a/ui/masonry/src/react-native/MasonryList.tsx b/ui/masonry/src/react-native/MasonryList.tsx index c8b848d8..65cdec98 100644 --- a/ui/masonry/src/react-native/MasonryList.tsx +++ b/ui/masonry/src/react-native/MasonryList.tsx @@ -8,6 +8,7 @@ import { ForwardedRef, useContext, } from 'react'; +import { ItemLayout } from '@infinite-list/types'; import { View, ViewStyle, @@ -31,7 +32,16 @@ const MasonryList = ( props: MasonryListProps ) => { const [state, setState] = useState>(); - const { id, data, column = 2, getColumnWidth, forwardRef, ...rest } = props; + const { + id, + data, + column = 2, + getColumnWidth, + horizontal = false, + getContainerLayout, + forwardRef, + ...rest + } = props; const contextValues = useContext(ScrollViewContext); const listId = useMemo(() => id || `__masonry_list${count++}__`, []); @@ -50,29 +60,34 @@ const MasonryList = ( nextResolveColumnInfo() ); + const containerLayoutRef = useRef({ + x: 0, + y: 0, + width: 0, + height: 0, + }); const listRef = useRef(null); + const containerStyle = useMemo(() => { + const style: ViewStyle = { + position: 'relative', + display: 'flex', + /** + * to make the backdrop div to render in column style + */ + flexDirection: 'row', + }; + + return style; + }, []); - const style: { - [key: string]: ViewStyle; - } = useMemo( - () => ({ - container: { - width: '100%', - height: '100%', - overflowY: 'auto', - position: 'relative', - display: 'flex', - /** - * to make the backdrop div to render in column style - */ - flexDirection: 'row', - }, - }), - [] - ); + const onLayoutHandler = useCallback((e: LayoutChangeEvent) => { + const scrollMetrics = contextValues.getScrollHelper().getScrollMetrics(); + dimensionsModel.updateScrollMetrics(scrollMetrics); + + const rect = e.nativeEvent.layout; + containerLayoutRef.current = rect; - const onLayoutHandler = useCallback((event: LayoutChangeEvent) => { - const { width } = event.nativeEvent.layout; + const { width } = e.nativeEvent.layout; if (!getColumnWidth) { setColumnDimensions(nextResolveColumnInfo(width)); } @@ -92,6 +107,8 @@ const MasonryList = ( data, column, ...rest, + getContainerLayout: + getContainerLayout || (() => containerLayoutRef.current), stateListener, }), [] @@ -146,7 +163,7 @@ const MasonryList = ( {state?.map((columnState, index) => ( diff --git a/ui/masonry/src/react-native/types/masonryList.ts b/ui/masonry/src/react-native/types/masonryList.ts index 9010a988..e4515700 100644 --- a/ui/masonry/src/react-native/types/masonryList.ts +++ b/ui/masonry/src/react-native/types/masonryList.ts @@ -11,24 +11,24 @@ import { export { ColumnDimensionInfo }; -export type ContainerRef = RefObject; +export type ScrollerRef = RefObject; export type MasonryListProps = CommonMasonryListProps & { - containerRef: ContainerRef; + scrollerRef: ScrollerRef; forwardRef?: ForwardedRef; }; export type RecycleItemProps = CommonRecycleItemProps & { - containerRef: ContainerRef; + scrollerRef: ScrollerRef; }; export type SpaceItemProps = CommonSpaceItemProps & { - containerRef: ContainerRef; + scrollerRef: ScrollerRef; }; export type ColumnStateRendererProps< ItemT extends GenericItemT = GenericItemT > = CommonColumnStateRendererProps & { - containerRef: ContainerRef; + scrollerRef: ScrollerRef; }; diff --git a/ui/masonry/src/react/MasonryList.tsx b/ui/masonry/src/react/MasonryList.tsx index 520633aa..975dfe3e 100644 --- a/ui/masonry/src/react/MasonryList.tsx +++ b/ui/masonry/src/react/MasonryList.tsx @@ -76,12 +76,19 @@ export const MasonryList = ( }); const containerStyle = useMemo(() => { - const style: CSSProperties = { position: 'relative' }; - if (horizontal) { - style.display = 'flex'; - style.flexDirection = 'column'; - style.height = '100%'; - } + const style: CSSProperties = { + position: 'relative', + display: 'flex', + /** + * to make the backdrop div to render in column style + */ + flexDirection: 'row', + }; + // if (horizontal) { + // style.display = 'flex'; + // style.flexDirection = 'column'; + // style.height = '100%'; + // } if (!usingControlledScroller) { style.width = '100%';