diff options
| author | Michael W <baddaemon87@gmail.com> | 2020-05-23 16:51:33 +0200 |
|---|---|---|
| committer | Michael W <baddaemon87@gmail.com> | 2020-05-25 22:10:56 +0200 |
| commit | 07c937e7011fd20e456fc1b397dee33ff8c5b367 (patch) | |
| tree | ef3da1b5da67b5312a523ea89aff92894b2a49f7 /java/src/com/android/inputmethodcommon/InputMethodSettingsImpl.java | |
| parent | 50ae60707defd1e7ba1be9d033946e8c46bf39c2 (diff) | |
LatinIME: Fix back-arrow finishing activity
* When going to a sub setting menu and pressing the
action bar up arrow instead of the device's back
key, the settings are closed instead of going
one level up as expected
* Call "onBackPressed" instead of "finish" to fix
that
* For InputMethodSettings create a new flag to
alter the behaviour for our use case but to keep
existing behaviour for other callers
Test:
- Open the keyboard settings from Settings app
and navigate between menus ->
action bar back icon only goes one levelup
- Open keyboard settings directly from keyboard:
behaviour is the same, last "up" action takes you
back to where you came from
Change-Id: I4f01e80e7f35ddbd2af1baae899d689f1144a5a1
Diffstat (limited to 'java/src/com/android/inputmethodcommon/InputMethodSettingsImpl.java')
| -rw-r--r-- | java/src/com/android/inputmethodcommon/InputMethodSettingsImpl.java | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/java/src/com/android/inputmethodcommon/InputMethodSettingsImpl.java b/java/src/com/android/inputmethodcommon/InputMethodSettingsImpl.java index cfa1a6596..e56c97578 100644 --- a/java/src/com/android/inputmethodcommon/InputMethodSettingsImpl.java +++ b/java/src/com/android/inputmethodcommon/InputMethodSettingsImpl.java @@ -40,6 +40,7 @@ import java.util.List; private Drawable mSubtypeEnablerIcon; private InputMethodManager mImm; private InputMethodInfo mImi; + private boolean mSpawnAsNewActivity = true; /** * Initialize internal states of this object. @@ -55,9 +56,11 @@ import java.util.List; } final Intent intent = new Intent(Settings.ACTION_INPUT_METHOD_SUBTYPE_SETTINGS); intent.putExtra(Settings.EXTRA_INPUT_METHOD_ID, mImi.getId()); - intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK - | Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED - | Intent.FLAG_ACTIVITY_CLEAR_TOP); + if (mSpawnAsNewActivity) { + intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK + | Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED + | Intent.FLAG_ACTIVITY_CLEAR_TOP); + } mSubtypeEnablerPreference = new Preference(context); mSubtypeEnablerPreference.setIntent(intent); prefScreen.addPreference(mSubtypeEnablerPreference); @@ -176,4 +179,8 @@ import java.util.List; pref.setIcon(mSubtypeEnablerIcon); } } + + public void setSpawnAsNewActivity(boolean spawnAsNew) { + mSpawnAsNewActivity = spawnAsNew; + } } |
