From 972787d2b2671c78826df017b457549f03f1ea96 Mon Sep 17 00:00:00 2001 From: Kirill Zyusko Date: Mon, 18 Nov 2024 17:27:59 +0100 Subject: [PATCH] feat: new `KeyboardController.isVisible()` method (#694) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ## 📜 Description Added `KeyboardController.isVisible()` method. ## 💡 Motivation and Context I decided to match `Keyboard` API from `react-native` more closely, and I thought that `isVisible()` method can be useful in many places. So in this PR I'm adding `isVisible` method. ## 📢 Changelog ### Docs - added API spec for new method. ### JS - added `isVisible` method to `KeyboardController` API. ## 🤔 How Has This Been Tested? Tested manually. ## 📝 Checklist - [x] CI successfully passed - [x] I added new mocks and corresponding unit-tests if library API was changed --- docs/docs/api/keyboard-controller.md | 14 ++++++++++++++ jest/index.js | 1 + src/module.ts | 10 ++++++---- src/types.ts | 1 + 4 files changed, 22 insertions(+), 4 deletions(-) diff --git a/docs/docs/api/keyboard-controller.md b/docs/docs/api/keyboard-controller.md index 6d3b2158b..4eb9342f5 100644 --- a/docs/docs/api/keyboard-controller.md +++ b/docs/docs/api/keyboard-controller.md @@ -70,6 +70,20 @@ The equivalent method from `react-native` relies on specific internal components In contrast, the described method enables keyboard dismissal for any focused input, extending functionality beyond the limitations of the default implementation. ::: +### `isVisible` + +```ts +static isVisible(): boolean; +``` + +This method returns `true` if keyboard is currently visible and `false` otherwise. + +```ts +if (KeyboardController.isVisible()) { + // do something +} +``` + ### `setFocusTo` ```ts diff --git a/jest/index.js b/jest/index.js index dbbe4cd63..55da80c89 100644 --- a/jest/index.js +++ b/jest/index.js @@ -51,6 +51,7 @@ const mock = { setDefaultMode: jest.fn(), dismiss: jest.fn().mockReturnValue(Promise.resolve()), setFocusTo: jest.fn(), + isVisible: jest.fn().mockReturnValue(false), }, AndroidSoftInputModes: { SOFT_INPUT_ADJUST_NOTHING: 48, diff --git a/src/module.ts b/src/module.ts index d66c210b3..dbc3d3b1d 100644 --- a/src/module.ts +++ b/src/module.ts @@ -2,19 +2,19 @@ import { KeyboardControllerNative, KeyboardEvents } from "./bindings"; import type { KeyboardControllerModule } from "./types"; -let isVisible = false; +let isClosed = false; KeyboardEvents.addListener("keyboardDidHide", () => { - isVisible = false; + isClosed = true; }); KeyboardEvents.addListener("keyboardDidShow", () => { - isVisible = true; + isClosed = false; }); const dismiss = async (): Promise => { return new Promise((resolve) => { - if (!isVisible) { + if (isClosed) { resolve(); return; @@ -28,10 +28,12 @@ const dismiss = async (): Promise => { KeyboardControllerNative.dismiss(); }); }; +const isVisible = () => !isClosed; export const KeyboardController: KeyboardControllerModule = { setDefaultMode: KeyboardControllerNative.setDefaultMode, setInputMode: KeyboardControllerNative.setInputMode, setFocusTo: KeyboardControllerNative.setFocusTo, dismiss: dismiss, + isVisible, }; diff --git a/src/types.ts b/src/types.ts index 8e712f412..b2801519c 100644 --- a/src/types.ts +++ b/src/types.ts @@ -121,6 +121,7 @@ export type KeyboardControllerModule = { // all platforms dismiss: () => Promise; setFocusTo: (direction: Direction) => void; + isVisible: () => boolean; }; export type KeyboardControllerNativeModule = { // android only