From d15d6e70d7fa1cca77f51c3f22d5eb04fafadde1 Mon Sep 17 00:00:00 2001 From: Ryan Meredith Date: Tue, 24 Mar 2020 17:08:35 -0400 Subject: [PATCH] Android: Don't let onSettingChanged clobber ConfirmRunnable changes --- .../features/settings/ui/MenuTag.java | 3 +- .../settings/ui/SettingsActivity.java | 4 +- .../ui/SettingsActivityPresenter.java | 8 ++-- .../settings/ui/SettingsActivityView.java | 8 ++-- .../features/settings/ui/SettingsAdapter.java | 42 ++++++++++++------- .../settings/ui/SettingsFragment.java | 14 +------ .../ui/SettingsFragmentPresenter.java | 7 +--- .../settings/ui/SettingsFragmentView.java | 6 --- .../viewholder/ConfirmRunnableViewHolder.java | 6 ++- .../app/src/main/res/values/strings.xml | 1 - 10 files changed, 45 insertions(+), 54 deletions(-) diff --git a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/MenuTag.java b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/MenuTag.java index 88fcd6a011..ef7aca9f04 100644 --- a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/MenuTag.java +++ b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/MenuTag.java @@ -27,8 +27,7 @@ public enum MenuTag WIIMOTE_EXTENSION_1("wiimote_extension", 4), WIIMOTE_EXTENSION_2("wiimote_extension", 5), WIIMOTE_EXTENSION_3("wiimote_extension", 6), - WIIMOTE_EXTENSION_4("wiimote_extension", 7), - BLANK("Blank"); + WIIMOTE_EXTENSION_4("wiimote_extension", 7); private String tag; private int subType = -1; diff --git a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivity.java b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivity.java index d5f6754225..bfaf6daf80 100644 --- a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivity.java +++ b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivity.java @@ -105,13 +105,13 @@ public final class SettingsActivity extends AppCompatActivity implements Setting @Override public void showSettingsFragment(MenuTag menuTag, Bundle extras, boolean addToStack, - boolean customAnimations, String gameID) + String gameID) { FragmentTransaction transaction = getSupportFragmentManager().beginTransaction(); if (addToStack) { - if (areSystemAnimationsEnabled() && customAnimations) + if (areSystemAnimationsEnabled()) { transaction.setCustomAnimations( R.animator.settings_enter, diff --git a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivityPresenter.java b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivityPresenter.java index ebdcd9bdcd..77ce9cee9c 100644 --- a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivityPresenter.java +++ b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivityPresenter.java @@ -70,7 +70,7 @@ public final class SettingsActivityPresenter } } - mView.showSettingsFragment(menuTag, null, false, true, gameId); + mView.showSettingsFragment(menuTag, null, false, gameId); mView.onSettingsFileLoaded(mSettings); } @@ -195,7 +195,7 @@ public final class SettingsActivityPresenter { Bundle bundle = new Bundle(); bundle.putInt(SettingsFragmentPresenter.ARG_CONTROLLER_TYPE, value / 6); - mView.showSettingsFragment(key, bundle, true, true, gameId); + mView.showSettingsFragment(key, bundle, true, gameId); } } @@ -204,7 +204,7 @@ public final class SettingsActivityPresenter switch (value) { case 1: - mView.showSettingsFragment(menuTag, null, true, true, gameId); + mView.showSettingsFragment(menuTag, null, true, gameId); break; case 2: @@ -219,7 +219,7 @@ public final class SettingsActivityPresenter { Bundle bundle = new Bundle(); bundle.putInt(SettingsFragmentPresenter.ARG_CONTROLLER_TYPE, value); - mView.showSettingsFragment(menuTag, bundle, true, true, gameId); + mView.showSettingsFragment(menuTag, bundle, true, gameId); } } diff --git a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivityView.java b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivityView.java index 21ea870839..71583aa989 100644 --- a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivityView.java +++ b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsActivityView.java @@ -14,12 +14,10 @@ public interface SettingsActivityView /** * Show a new SettingsFragment. * - * @param menuTag Identifier for the settings group that should be displayed. - * @param addToStack Whether or not this fragment should replace a previous one. - * @param customAnimations Custom animations are used if true while system animations are enabled. + * @param menuTag Identifier for the settings group that should be displayed. + * @param addToStack Whether or not this fragment should replace a previous one. */ - void showSettingsFragment(MenuTag menuTag, Bundle extras, boolean addToStack, - boolean customAnimations, String gameId); + void showSettingsFragment(MenuTag menuTag, Bundle extras, boolean addToStack, String gameId); /** * Called by a contained Fragment to get access to the Setting HashMap diff --git a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsAdapter.java b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsAdapter.java index 04d68d17fc..f11a183626 100644 --- a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsAdapter.java +++ b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsAdapter.java @@ -55,6 +55,7 @@ public final class SettingsAdapter extends RecyclerView.Adapter mSettings; @@ -72,6 +73,7 @@ public final class SettingsAdapter extends RecyclerView.Adapter SettingsAdapter.resetPaths())); + sl.add(new ConfirmRunnable(R.string.reset_paths, 0, R.string.reset_paths_confirmation, 0, + SettingsAdapter::resetPaths)); } private void addGameCubeSettings(ArrayList sl) diff --git a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsFragmentView.java b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsFragmentView.java index 3fd8fca07f..eeff02d7db 100644 --- a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsFragmentView.java +++ b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/SettingsFragmentView.java @@ -57,12 +57,6 @@ public interface SettingsFragmentView */ void loadSubMenu(MenuTag menuKey); - /** - * Show a new blank submenu and then immediately back out of it. - * Useful for updating dynamic setting descriptions. - */ - void reloadSubMenu(); - /** * Tell the Fragment to tell the containing activity to display a toast message. * diff --git a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/viewholder/ConfirmRunnableViewHolder.java b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/viewholder/ConfirmRunnableViewHolder.java index f29173e8c9..32be613bc2 100644 --- a/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/viewholder/ConfirmRunnableViewHolder.java +++ b/Source/Android/app/src/main/java/org/dolphinemu/dolphinemu/features/settings/ui/viewholder/ConfirmRunnableViewHolder.java @@ -57,7 +57,6 @@ public final class ConfirmRunnableViewHolder extends SettingViewHolder { String alertTitle = mContext.getString(mItem.getNameId()); String alertText = mContext.getString(mItem.getAlertText()); - String confirmationText = mContext.getString(mItem.getConfirmationText()); AlertDialog.Builder builder = new AlertDialog.Builder(mContext) .setTitle(alertTitle) @@ -70,10 +69,13 @@ public final class ConfirmRunnableViewHolder extends SettingViewHolder if (mItem.getConfirmationText() > 0) { + String confirmationText = mContext.getString(mItem.getConfirmationText()); Toast.makeText(mContext, confirmationText, Toast.LENGTH_SHORT).show(); } dialog.dismiss(); - mView.reloadSubMenu(); + + // TODO: Remove finish and properly update dynamic settings descriptions. + mView.getActivity().finish(); }) .setNegativeButton("No", (dialog, whichButton) -> { diff --git a/Source/Android/app/src/main/res/values/strings.xml b/Source/Android/app/src/main/res/values/strings.xml index f1b6e062ba..df006410f1 100644 --- a/Source/Android/app/src/main/res/values/strings.xml +++ b/Source/Android/app/src/main/res/values/strings.xml @@ -172,7 +172,6 @@ SD Card Path Reset Paths to Default Settings Are you sure you want to reset Paths to default settings? - Paths reset General