From f2e143f527ca589c0bcf6dfeeb822b6ad4ef344a Mon Sep 17 00:00:00 2001 From: hublot Date: Fri, 16 Aug 2024 17:41:26 +0800 Subject: [PATCH] fix: revert the overrideItemLayout (#5558) * Revert "fix: the invisible cell of SectionList on native OK-31409 (#5546)" This reverts commit f1288528b388a76d27a8f0aac8df6d39071cba29. * fix: remove the duplicate keyExtractor of Currency #5546 * fix: remove the duplicate keyExtractor of Currency #5546 --- .../components/src/layouts/ListView/list.tsx | 7 -- .../src/layouts/SectionList/index.tsx | 66 +------------------ 2 files changed, 3 insertions(+), 70 deletions(-) diff --git a/packages/components/src/layouts/ListView/list.tsx b/packages/components/src/layouts/ListView/list.tsx index 17ee394527d..8f5f18e1d71 100644 --- a/packages/components/src/layouts/ListView/list.tsx +++ b/packages/components/src/layouts/ListView/list.tsx @@ -41,13 +41,6 @@ export type IListViewProps = Omit< See https://shopify.github.io/flash-list/docs/estimated-item-size/#how-to-calculate */ estimatedItemSize?: number | `$${keyof Tokens['size']}`; - overrideItemLayout?: ( - layout: { span?: number; size?: number }, - item: T, - index: number, - maxColumns: number, - extraData?: any, - ) => void; getItemType?: (item: T) => string | undefined; onBlankArea?: (blankAreaEvent: { offsetStart: number; diff --git a/packages/components/src/layouts/SectionList/index.tsx b/packages/components/src/layouts/SectionList/index.tsx index 3791f8b438a..fd103e28792 100644 --- a/packages/components/src/layouts/SectionList/index.tsx +++ b/packages/components/src/layouts/SectionList/index.tsx @@ -7,7 +7,7 @@ import { useRef, } from 'react'; -import { getTokenValue, withStaticProperties } from 'tamagui'; +import { withStaticProperties } from 'tamagui'; import platformEnv from '@onekeyhq/shared/src/platformEnv'; @@ -16,7 +16,6 @@ import { ListView } from '../ListView/list'; import type { ISizableTextProps, IStackProps } from '../../primitives'; import type { IListViewProps, IListViewRef } from '../ListView/list'; -import type { Tokens } from '@tamagui/web/types/types'; import type { ListRenderItem } from 'react-native'; type ISectionRenderInfo = (info: { @@ -26,7 +25,7 @@ type ISectionRenderInfo = (info: { export type ISectionListProps = Omit< IListViewProps, - 'data' | 'renderItem' | 'overrideItemLayout' + 'data' | 'renderItem' > & { sections: Array<{ data?: any[]; @@ -40,9 +39,6 @@ export type ISectionListProps = Omit< renderSectionFooter?: ISectionRenderInfo; SectionSeparatorComponent?: ReactNode; stickySectionHeadersEnabled?: boolean; - estimatedSectionHeaderSize?: number | `$${keyof Tokens['size']}`; - estimatedSectionFooterSize?: number | `$${keyof Tokens['size']}`; - estimatedSectionSeparatorSize?: number | `$${keyof Tokens['size']}`; }; type IScrollToLocationParams = { @@ -82,10 +78,7 @@ function BaseSectionList( SectionSeparatorComponent = , stickySectionHeadersEnabled = false, keyExtractor, - estimatedItemSize = 0, - estimatedSectionHeaderSize = '$9', - estimatedSectionFooterSize = 0, - estimatedSectionSeparatorSize = 20, + estimatedItemSize, ...restProps }: ISectionListProps, parentRef: ForwardedRef>, @@ -220,56 +213,6 @@ function BaseSectionList( }, [keyExtractor], ); - const getTokenSizeNumber = useCallback( - (token?: number | `$${keyof Tokens['size']}`) => { - if (typeof token === 'undefined') { - return undefined; - } - return typeof token === 'number' - ? token - : (getTokenValue(token) as number); - }, - [], - ); - const tokenSizeNumberList = useMemo( - () => ({ - [ESectionLayoutType.Header]: getTokenSizeNumber( - estimatedSectionHeaderSize, - ), - [ESectionLayoutType.Item]: getTokenSizeNumber(estimatedItemSize), - [ESectionLayoutType.Footer]: getTokenSizeNumber( - estimatedSectionFooterSize, - ), - [ESectionLayoutType.SectionSeparator]: getTokenSizeNumber( - estimatedSectionSeparatorSize, - ), - }), - [ - getTokenSizeNumber, - estimatedSectionHeaderSize, - estimatedItemSize, - estimatedSectionFooterSize, - estimatedSectionSeparatorSize, - ], - ); - const overrideItemLayout = useCallback( - (layout: { span?: number; size?: number }, item: T) => { - layout.size = tokenSizeNumberList[(item as ISectionLayoutItem).type] ?? 0; - }, - [tokenSizeNumberList], - ); - const layoutList = useMemo(() => { - let offset = 0; - return reloadSections.map((item, index) => { - const size = tokenSizeNumberList[item.type] ?? 0; - offset += size; - return { offset, length: size, index }; - }); - }, [reloadSections, tokenSizeNumberList]); - const getItemLayout = useCallback( - (_: ArrayLike | null | undefined, index: number) => layoutList[index], - [layoutList], - ); return ( ( getItemType={getItemType} keyExtractor={platformEnv.isNative ? reloadKeyExtractor : undefined} estimatedItemSize={platformEnv.isNative ? estimatedItemSize : undefined} - overrideItemLayout={platformEnv.isNative ? overrideItemLayout : undefined} - // will enable `getItemLayout` in next version - // getItemLayout={getItemLayout} {...restProps} /> );