mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-11-05 13:26:48 +08:00
Merge pull request #3757 from NativeScript/fix-android-keyboard
FIX: Android keyboard
This commit is contained in:
@@ -4,7 +4,7 @@
|
||||
|
||||
export * from "./utils-common";
|
||||
|
||||
import { getNativeApplication } from "application";
|
||||
import { getNativeApplication, android as androidApp } from "application";
|
||||
|
||||
export module layout {
|
||||
let density: number;
|
||||
@@ -98,10 +98,19 @@ export module ad {
|
||||
}
|
||||
}
|
||||
|
||||
export function dismissSoftInput(nativeView: android.view.View): void {
|
||||
export function dismissSoftInput(nativeView?: android.view.View): void {
|
||||
const inputManager = getInputMethodManager();
|
||||
if (inputManager && nativeView instanceof android.view.View && inputManager.isActive(nativeView)) {
|
||||
inputManager.hideSoftInputFromWindow(nativeView.getWindowToken(), 0);
|
||||
let windowToken: android.os.IIBinder;
|
||||
|
||||
if (nativeView instanceof android.view.View) {
|
||||
windowToken = nativeView.getWindowToken()
|
||||
} else if (androidApp.foregroundActivity instanceof android.app.Activity) {
|
||||
const decorView = androidApp.foregroundActivity.getWindow().getDecorView();
|
||||
windowToken = decorView ? decorView.getWindowToken() : null;
|
||||
}
|
||||
|
||||
if (inputManager && windowToken) {
|
||||
inputManager.hideSoftInputFromWindow(windowToken, 0);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
2
tns-core-modules/utils/utils.d.ts
vendored
2
tns-core-modules/utils/utils.d.ts
vendored
@@ -94,7 +94,7 @@ export module ad {
|
||||
/**
|
||||
* Hides the soft input method, ususally a soft keyboard.
|
||||
*/
|
||||
export function dismissSoftInput(nativeView: any /* android.view.View */): void;
|
||||
export function dismissSoftInput(nativeView?: any /* android.view.View */): void;
|
||||
|
||||
/**
|
||||
* Shows the soft input method, ususally a soft keyboard.
|
||||
|
||||
Reference in New Issue
Block a user