@gorhom/bottom-sheet
Version:
A performant interactive bottom sheet with fully configurable options 🚀
41 lines (38 loc) • 1.63 kB
JavaScript
import React, { memo } from 'react';
import { useDerivedValue } from 'react-native-reanimated';
import { KEYBOARD_STATE } from '../../constants';
import { useBottomSheetInternal } from '../../hooks';
import { jsx as _jsx } from "react/jsx-runtime";
const BottomSheetFooterContainerComponent = ({
footerComponent: FooterComponent
}) => {
//#region hooks
const {
animatedContainerHeight,
animatedHandleHeight,
animatedFooterHeight,
animatedPosition,
animatedKeyboardState,
animatedKeyboardHeightInContainer
} = useBottomSheetInternal();
//#endregion
//#region variables
const animatedFooterPosition = useDerivedValue(() => {
const keyboardHeight = animatedKeyboardHeightInContainer.value;
let footerTranslateY = Math.max(0, animatedContainerHeight.value - animatedPosition.value);
if (animatedKeyboardState.value === KEYBOARD_STATE.SHOWN) {
footerTranslateY = footerTranslateY - keyboardHeight;
}
footerTranslateY = footerTranslateY - animatedFooterHeight.value - animatedHandleHeight.value;
return footerTranslateY;
}, [animatedKeyboardHeightInContainer, animatedContainerHeight, animatedPosition, animatedKeyboardState, animatedFooterHeight, animatedHandleHeight]);
//#endregion
return /*#__PURE__*/_jsx(FooterComponent, {
animatedFooterPosition: animatedFooterPosition
});
};
const BottomSheetFooterContainer = /*#__PURE__*/memo(BottomSheetFooterContainerComponent);
BottomSheetFooterContainer.displayName = 'BottomSheetFooterContainer';
export default BottomSheetFooterContainer;
//# sourceMappingURL=BottomSheetFooterContainer.js.map
;