UNPKG

@gorhom/bottom-sheet

Version:

A performant interactive bottom sheet with fully configurable options 🚀

58 lines (54 loc) • 1.75 kB
import React, { memo, useCallback, useMemo } from 'react'; import Animated, { useAnimatedStyle } from 'react-native-reanimated'; import { KEYBOARD_STATE } from '../../constants'; import { useBottomSheetInternal } from '../../hooks'; import { styles } from './styles'; function BottomSheetFooterComponent({ animatedFooterPosition, bottomInset = 0, style, children }) { //#region hooks const { animatedFooterHeight, animatedKeyboardState } = useBottomSheetInternal(); //#endregion //#region styles const containerAnimatedStyle = useAnimatedStyle(() => { let footerTranslateY = animatedFooterPosition.value; /** * Offset the bottom inset only when keyboard is not shown */ if (animatedKeyboardState.value !== KEYBOARD_STATE.SHOWN) { footerTranslateY = footerTranslateY - bottomInset; } return { transform: [{ translateY: Math.max(0, footerTranslateY) }] }; }, [bottomInset, animatedKeyboardState, animatedFooterPosition]); const containerStyle = useMemo(() => [styles.container, style, containerAnimatedStyle], [style, containerAnimatedStyle]); //#endregion //#region callbacks const handleContainerLayout = useCallback(({ nativeEvent: { layout: { height } } }) => { animatedFooterHeight.value = height; }, [animatedFooterHeight]); //#endregion return children !== null ? /*#__PURE__*/React.createElement(Animated.View, { onLayout: handleContainerLayout, style: containerStyle }, children) : null; } const BottomSheetFooter = /*#__PURE__*/memo(BottomSheetFooterComponent); BottomSheetFooter.displayName = 'BottomSheetFooter'; export default BottomSheetFooter; //# sourceMappingURL=BottomSheetFooter.js.map