diff --git a/packages/components/src/mobile/keyboard-aware-flat-list/index.ios.js b/packages/components/src/mobile/keyboard-aware-flat-list/index.ios.js index 87b319c711041..37adfcca2bd5f 100644 --- a/packages/components/src/mobile/keyboard-aware-flat-list/index.ios.js +++ b/packages/components/src/mobile/keyboard-aware-flat-list/index.ios.js @@ -1,16 +1,12 @@ /** * External dependencies */ -import { KeyboardAwareScrollView } from 'react-native-keyboard-aware-scroll-view'; -import { FlatList } from 'react-native'; -import { isEqual } from 'lodash'; +import { KeyboardAwareFlatList as RNKeyboardAwareFlatList } from 'react-native-keyboard-aware-scroll-view'; /** * WordPress dependencies */ -import { memo } from '@wordpress/element'; - -const List = memo( FlatList, isEqual ); +import { useRef } from '@wordpress/element'; export const KeyboardAwareFlatList = ( { extraScrollHeight, @@ -19,53 +15,62 @@ export const KeyboardAwareFlatList = ( { autoScroll, scrollViewStyle, inputAccessoryViewHeight, + scrollEnabled, ...listProps -} ) => ( - { - this.scrollViewRef = ref; - innerRef( ref ); - } } - onKeyboardWillHide={ () => { - this.keyboardWillShowIndicator = false; - } } - onKeyboardDidHide={ () => { - setTimeout( () => { - if ( - ! this.keyboardWillShowIndicator && - this.latestContentOffsetY !== undefined && - ! shouldPreventAutomaticScroll() - ) { - // Reset the content position if keyboard is still closed - if ( this.scrollViewRef ) { - this.scrollViewRef.scrollToPosition( - 0, - this.latestContentOffsetY, - true - ); +} ) => { + const scrollViewRef = useRef(); + const keyboardWillShowIndicator = useRef(); + const latestContentOffsetY = useRef(); + return ( + { + scrollViewRef.current = ref; + innerRef( ref ); + } } + onKeyboardWillHide={ () => { + keyboardWillShowIndicator.current = false; + } } + onKeyboardDidHide={ () => { + setTimeout( () => { + if ( + ! keyboardWillShowIndicator.current && + latestContentOffsetY.current !== undefined && + ! shouldPreventAutomaticScroll() + ) { + // Reset the content position if keyboard is still closed + if ( scrollViewRef.current ) { + scrollViewRef.current.scrollToPosition( + 0, + latestContentOffsetY.current, + true + ); + } } - } - }, 50 ); - } } - onKeyboardWillShow={ () => { - this.keyboardWillShowIndicator = true; - } } - scrollEnabled={ listProps.scrollEnabled } - onScroll={ ( event ) => { - this.latestContentOffsetY = event.nativeEvent.contentOffset.y; - } } - > - - -); + }, 50 ); + } } + onKeyboardWillShow={ () => { + keyboardWillShowIndicator.current = true; + } } + scrollEnabled={ scrollEnabled } + onScroll={ ( event ) => { + latestContentOffsetY.current = + event.nativeEvent.contentOffset.y; + } } + { ...listProps } + /> + ); +}; KeyboardAwareFlatList.handleCaretVerticalPositionChange = ( scrollView,