UNPKG

native-base

Version:

Essential cross-platform UI components for React Native

60 lines (54 loc) 1.53 kB
import React from 'react'; import { useEffect } from 'react'; import { BackHandler } from 'react-native'; type IParams = { enabled?: boolean; callback: () => any; }; let keyboardDismissHandlers: Array<() => any> = []; export const keyboardDismissHandlerManager = { push: (handler: () => any) => { keyboardDismissHandlers.push(handler); return () => { keyboardDismissHandlers = keyboardDismissHandlers.filter( (h) => h !== handler ); }; }, length: () => keyboardDismissHandlers.length, pop: () => { return keyboardDismissHandlers.pop(); }, }; /** * Handles attaching callback for Escape key listener on web and Back button listener on Android */ export const useKeyboardDismissable = ({ enabled, callback }: IParams) => { React.useEffect(() => { let cleanupFn = () => {}; if (enabled) { cleanupFn = keyboardDismissHandlerManager.push(callback); } else { cleanupFn(); } return () => { cleanupFn(); }; }, [enabled, callback]); useBackHandler({ enabled, callback }); }; export function useBackHandler({ enabled, callback }: IParams) { useEffect(() => { let backHandler = () => { callback(); return true; }; if (enabled) { BackHandler.addEventListener('hardwareBackPress', backHandler); } else { BackHandler.removeEventListener('hardwareBackPress', backHandler); } return () => BackHandler.removeEventListener('hardwareBackPress', backHandler); }, [enabled, callback]); }