diff --git a/docs/docs/guides/building-own-hook.md b/docs/docs/guides/building-own-hook.md index 78dc089d14..590435bd1b 100644 --- a/docs/docs/guides/building-own-hook.md +++ b/docs/docs/guides/building-own-hook.md @@ -5,7 +5,15 @@ keywords: [react-native-keyboard-controller, react-native keyboard, react hook] # Building own hook -Default hooks may not perfectly fit in your app, because it changes/restores `softInputMode` on mount/unmount of the component where it's used. Though in deep stacks sometimes it may be important to have different `softInputMode` per screen, but by default `react-navigation` keeps previous screens mounted, so if you are using default `useKeyboardAnimation` hook, then all following screens will have `softInputMode=adjustResize`. +Default hooks may not perfectly fit in your app, because it changes/restores `softInputMode` on mount/unmount of the component where it's used. + +:::info +This is `useResizeMode` hook behavior - it changes `softInputMode` on mount to `adjustResize` and to default `softInput` on unmount. You may want to [read](../recipes/platform-differences.md#android) why it's crucial to change `softInputMode` to `adjustResize` before using this library. + +If you have `android:windowSoftInputMode="adjustResize"` declared in `AndroidManifest.xml` - then you can skip this step at all and forget about changing `softInputMode` in runtime (however you still may want to create your own version of hook without calls to `KeyboardController.*`) 😎. +::: + +Sometimes in deep stacks it may be important to have different `softInputMode` per screen, but by default `react-navigation` keeps previous screens mounted, so if you are using default `useKeyboardAnimation` hook, then all following screens will have `softInputMode=adjustResize`. To prevent such behavior you can write own hook based on primitives from this library. The implementation may look like: diff --git a/docs/versioned_docs/version-1.9.0/guides/building-own-hook.md b/docs/versioned_docs/version-1.9.0/guides/building-own-hook.md index 78dc089d14..590435bd1b 100644 --- a/docs/versioned_docs/version-1.9.0/guides/building-own-hook.md +++ b/docs/versioned_docs/version-1.9.0/guides/building-own-hook.md @@ -5,7 +5,15 @@ keywords: [react-native-keyboard-controller, react-native keyboard, react hook] # Building own hook -Default hooks may not perfectly fit in your app, because it changes/restores `softInputMode` on mount/unmount of the component where it's used. Though in deep stacks sometimes it may be important to have different `softInputMode` per screen, but by default `react-navigation` keeps previous screens mounted, so if you are using default `useKeyboardAnimation` hook, then all following screens will have `softInputMode=adjustResize`. +Default hooks may not perfectly fit in your app, because it changes/restores `softInputMode` on mount/unmount of the component where it's used. + +:::info +This is `useResizeMode` hook behavior - it changes `softInputMode` on mount to `adjustResize` and to default `softInput` on unmount. You may want to [read](../recipes/platform-differences.md#android) why it's crucial to change `softInputMode` to `adjustResize` before using this library. + +If you have `android:windowSoftInputMode="adjustResize"` declared in `AndroidManifest.xml` - then you can skip this step at all and forget about changing `softInputMode` in runtime (however you still may want to create your own version of hook without calls to `KeyboardController.*`) 😎. +::: + +Sometimes in deep stacks it may be important to have different `softInputMode` per screen, but by default `react-navigation` keeps previous screens mounted, so if you are using default `useKeyboardAnimation` hook, then all following screens will have `softInputMode=adjustResize`. To prevent such behavior you can write own hook based on primitives from this library. The implementation may look like: