react-native-keyboard-controller
Version:
Keyboard manager which works in identical way on both iOS and Android
110 lines (106 loc) • 4.28 kB
text/typescript
import { View } from "react-native";
import type {
ClippingScrollViewProps,
FocusedInputEventsModule,
KeyboardBackgroundViewProps,
KeyboardControllerNativeModule,
KeyboardControllerProps,
KeyboardEventsModule,
KeyboardExtenderProps,
KeyboardGestureAreaProps,
KeyboardToolbarGroupViewProps,
OverKeyboardViewProps,
WindowDimensionsEventsModule,
} from "./types";
import type { EmitterSubscription } from "react-native";
const NOOP = () => {};
export const KeyboardControllerNative: KeyboardControllerNativeModule = {
setDefaultMode: NOOP,
setInputMode: NOOP,
preload: NOOP,
dismiss: NOOP,
setFocusTo: NOOP,
viewPositionInWindow: () =>
Promise.resolve({ x: 0, y: 0, width: 0, height: 0 }),
addListener: NOOP,
removeListeners: NOOP,
getConstants: () => ({
keyboardBorderRadius: 0,
}),
};
/**
* An event emitter that provides a way to subscribe to next keyboard events:
* - `keyboardWillShow`;
* - `keyboardDidShow`;
* - `keyboardWillHide`;
* - `keyboardDidHide`.
*
* Use `addListener` function to add your event listener for a specific keyboard event.
*/
export const KeyboardEvents: KeyboardEventsModule = {
addListener: () => ({ remove: NOOP } as EmitterSubscription),
};
/**
* This API is not documented, it's for internal usage only (for now), and is a subject to potential breaking changes in future.
* Use it with cautious.
*/
export const FocusedInputEvents: FocusedInputEventsModule = {
addListener: () => ({ remove: NOOP } as EmitterSubscription),
};
export const WindowDimensionsEvents: WindowDimensionsEventsModule = {
addListener: () => ({ remove: NOOP } as EmitterSubscription),
};
/**
* A view that sends events whenever keyboard or focused events are happening.
*
* @see {@link https://kirillzyusko.github.io/react-native-keyboard-controller/docs/api/keyboard-controller-view|Documentation} page for more details.
*/
export const KeyboardControllerView =
View as unknown as React.FC<KeyboardControllerProps>;
export const KeyboardControllerViewCommands = {
synchronizeFocusedInputLayout: (
_ref: React.Component<KeyboardControllerProps> | null,
) => {},
};
/**
* A view that defines a region on the screen, where gestures will control the keyboard position.
*
* @see {@link https://kirillzyusko.github.io/react-native-keyboard-controller/docs/api/keyboard-gesture-area|Documentation} page for more details.
*/
export const KeyboardGestureArea =
View as unknown as React.FC<KeyboardGestureAreaProps>;
export const RCTOverKeyboardView =
View as unknown as React.FC<OverKeyboardViewProps>;
/**
* A view that matches keyboard background.
*
* @see {@link https://kirillzyusko.github.io/react-native-keyboard-controller/docs/api/keyboard-background-view|Documentation} page for more details.
*/
export const KeyboardBackgroundView =
View as unknown as React.FC<KeyboardBackgroundViewProps>;
/**
* A container that will embed its children into the keyboard
* and will always show them above the keyboard.
*
* @see {@link https://kirillzyusko.github.io/react-native-keyboard-controller/docs/api/keyboard-extender|Documentation} page for more details.
*/
export const RCTKeyboardExtender =
View as unknown as React.FC<KeyboardExtenderProps>;
/**
* A decorator that will clip the content of the `ScrollView`. It helps to simulate `contentInset` behavior on Android
* Supports only `bottom` property (`paddingBottom` is not supported property of `ScrollView.style`).
* Using this component we can modify bottom inset without having a fake view.
*
* On iOS we use swizzling to apply runtime patches to fix some broken internal methods.
* Ideally this component shouldn't exist and all its fixes/polyfills must be added directly to react-native and
* we will port features/fixes back to upstream, but at the moment we use this view to
* deliver desired functionality regardless of react-native version used.
*/
export const ClippingScrollView =
View as unknown as React.FC<ClippingScrollViewProps>;
/**
* A View that defines a group of `TextInput`s.
* Used in toolbar navigation to assure that you can navigate only between inputs withing the same group.
*/
export const RCTKeyboardToolbarGroupView =
View as unknown as React.FC<KeyboardToolbarGroupViewProps>;