mirror of
https://github.com/KokaKiwi/BarInsta
synced 2024-11-22 14:47:29 +00:00
Add back screen transitions with option to disable them
This commit is contained in:
parent
8a88f90281
commit
97490d5c0b
@ -0,0 +1,90 @@
|
|||||||
|
package awais.instagrabber.customviews
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import androidx.fragment.app.FragmentManager
|
||||||
|
import androidx.navigation.NavBackStackEntry
|
||||||
|
import androidx.navigation.NavOptions
|
||||||
|
import androidx.navigation.Navigator
|
||||||
|
import androidx.navigation.fragment.FragmentNavigator
|
||||||
|
import androidx.navigation.navOptions
|
||||||
|
import awais.instagrabber.R
|
||||||
|
import awais.instagrabber.fragments.settings.PreferenceKeys
|
||||||
|
import awais.instagrabber.utils.Utils
|
||||||
|
|
||||||
|
private val defaultNavOptions = navOptions {
|
||||||
|
anim {
|
||||||
|
enter = R.anim.slide_in_right
|
||||||
|
exit = R.anim.slide_out_left
|
||||||
|
popEnter = android.R.anim.slide_in_left
|
||||||
|
popExit = android.R.anim.slide_out_right
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private val emptyNavOptions = navOptions {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Needs to replace FragmentNavigator and replacing is done with name in annotation.
|
||||||
|
* Navigation method will use defaults for fragments transitions animations.
|
||||||
|
*/
|
||||||
|
@Navigator.Name("fragment")
|
||||||
|
class BarinstaFragmentNavigator(
|
||||||
|
context: Context,
|
||||||
|
fragmentManager: FragmentManager,
|
||||||
|
containerId: Int
|
||||||
|
) : FragmentNavigator(context, fragmentManager, containerId) {
|
||||||
|
|
||||||
|
override fun navigate(
|
||||||
|
entries: List<NavBackStackEntry>,
|
||||||
|
navOptions: NavOptions?,
|
||||||
|
navigatorExtras: Navigator.Extras?
|
||||||
|
) {
|
||||||
|
val disableTransitions = Utils.settingsHelper.getBoolean(PreferenceKeys.PREF_DISABLE_SCREEN_TRANSITIONS)
|
||||||
|
if (disableTransitions) {
|
||||||
|
super.navigate(entries, navOptions, navigatorExtras)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// this will try to fill in empty animations with defaults when no shared element transitions
|
||||||
|
// https://developer.android.com/guide/navigation/navigation-animate-transitions#shared-element
|
||||||
|
val hasSharedElements = navigatorExtras != null && navigatorExtras is Extras
|
||||||
|
val navOptions1 = if (hasSharedElements) navOptions else navOptions.fillEmptyAnimationsWithDefaults()
|
||||||
|
super.navigate(entries, navOptions1, navigatorExtras)
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun NavOptions?.fillEmptyAnimationsWithDefaults(): NavOptions =
|
||||||
|
this?.copyNavOptionsWithDefaultAnimations() ?: defaultNavOptions
|
||||||
|
|
||||||
|
private fun NavOptions.copyNavOptionsWithDefaultAnimations(): NavOptions = let { originalNavOptions ->
|
||||||
|
navOptions {
|
||||||
|
launchSingleTop = originalNavOptions.shouldLaunchSingleTop()
|
||||||
|
popUpTo(originalNavOptions.popUpToId) {
|
||||||
|
inclusive = originalNavOptions.isPopUpToInclusive()
|
||||||
|
saveState = originalNavOptions.shouldPopUpToSaveState()
|
||||||
|
}
|
||||||
|
originalNavOptions.popUpToRoute?.let {
|
||||||
|
popUpTo(it) {
|
||||||
|
inclusive = originalNavOptions.isPopUpToInclusive()
|
||||||
|
saveState = originalNavOptions.shouldPopUpToSaveState()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
restoreState = originalNavOptions.shouldRestoreState()
|
||||||
|
anim {
|
||||||
|
enter =
|
||||||
|
if (originalNavOptions.enterAnim == emptyNavOptions.enterAnim) defaultNavOptions.enterAnim
|
||||||
|
else originalNavOptions.enterAnim
|
||||||
|
exit =
|
||||||
|
if (originalNavOptions.exitAnim == emptyNavOptions.exitAnim) defaultNavOptions.exitAnim
|
||||||
|
else originalNavOptions.exitAnim
|
||||||
|
popEnter =
|
||||||
|
if (originalNavOptions.popEnterAnim == emptyNavOptions.popEnterAnim) defaultNavOptions.popEnterAnim
|
||||||
|
else originalNavOptions.popEnterAnim
|
||||||
|
popExit =
|
||||||
|
if (originalNavOptions.popExitAnim == emptyNavOptions.popExitAnim) defaultNavOptions.popExitAnim
|
||||||
|
else originalNavOptions.popExitAnim
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private companion object {
|
||||||
|
private const val TAG = "FragmentNavigator"
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,14 @@
|
|||||||
|
package awais.instagrabber.customviews
|
||||||
|
|
||||||
|
import androidx.navigation.NavHostController
|
||||||
|
import androidx.navigation.fragment.NavHostFragment
|
||||||
|
|
||||||
|
class BarinstaNavHostFragment : NavHostFragment() {
|
||||||
|
override fun onCreateNavHostController(navHostController: NavHostController) {
|
||||||
|
super.onCreateNavHostController(navHostController)
|
||||||
|
navHostController.navigatorProvider.addNavigator(
|
||||||
|
// this replaces FragmentNavigator
|
||||||
|
BarinstaFragmentNavigator(requireContext(), childFragmentManager, id)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
@ -1,75 +0,0 @@
|
|||||||
package awais.instagrabber.customviews;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.os.Bundle;
|
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
import androidx.annotation.Nullable;
|
|
||||||
import androidx.fragment.app.FragmentManager;
|
|
||||||
import androidx.navigation.NavDestination;
|
|
||||||
import androidx.navigation.NavOptions;
|
|
||||||
import androidx.navigation.Navigator;
|
|
||||||
import androidx.navigation.fragment.FragmentNavigator;
|
|
||||||
|
|
||||||
import awais.instagrabber.R;
|
|
||||||
|
|
||||||
@Navigator.Name("fragment")
|
|
||||||
public class FragmentNavigatorWithDefaultAnimations extends FragmentNavigator {
|
|
||||||
|
|
||||||
private final NavOptions emptyNavOptions = new NavOptions.Builder().build();
|
|
||||||
// private final NavOptions defaultNavOptions = new NavOptions.Builder()
|
|
||||||
// .setEnterAnim(R.animator.nav_default_enter_anim)
|
|
||||||
// .setExitAnim(R.animator.nav_default_exit_anim)
|
|
||||||
// .setPopEnterAnim(R.animator.nav_default_pop_enter_anim)
|
|
||||||
// .setPopExitAnim(R.animator.nav_default_pop_exit_anim)
|
|
||||||
// .build();
|
|
||||||
|
|
||||||
private final NavOptions defaultNavOptions = new NavOptions.Builder()
|
|
||||||
.setEnterAnim(R.anim.slide_in_right)
|
|
||||||
.setExitAnim(R.anim.slide_out_left)
|
|
||||||
.setPopEnterAnim(android.R.anim.slide_in_left)
|
|
||||||
.setPopExitAnim(android.R.anim.slide_out_right)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
public FragmentNavigatorWithDefaultAnimations(@NonNull final Context context,
|
|
||||||
@NonNull final FragmentManager manager,
|
|
||||||
final int containerId) {
|
|
||||||
super(context, manager, containerId);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Nullable
|
|
||||||
@Override
|
|
||||||
public NavDestination navigate(@NonNull final Destination destination,
|
|
||||||
@Nullable final Bundle args,
|
|
||||||
@Nullable final NavOptions navOptions,
|
|
||||||
@Nullable final Navigator.Extras navigatorExtras) {
|
|
||||||
// this will try to fill in empty animations with defaults when no shared element transitions are set
|
|
||||||
// https://developer.android.com/guide/navigation/navigation-animate-transitions#shared-element
|
|
||||||
final boolean shouldUseTransitionsInstead = navigatorExtras != null;
|
|
||||||
final NavOptions navOptions1 = shouldUseTransitionsInstead ? navOptions : fillEmptyAnimationsWithDefaults(navOptions);
|
|
||||||
return super.navigate(destination, args, navOptions1, navigatorExtras);
|
|
||||||
}
|
|
||||||
|
|
||||||
private NavOptions fillEmptyAnimationsWithDefaults(@Nullable final NavOptions navOptions) {
|
|
||||||
if (navOptions == null) {
|
|
||||||
return defaultNavOptions;
|
|
||||||
}
|
|
||||||
return copyNavOptionsWithDefaultAnimations(navOptions);
|
|
||||||
}
|
|
||||||
|
|
||||||
@NonNull
|
|
||||||
private NavOptions copyNavOptionsWithDefaultAnimations(@NonNull final NavOptions navOptions) {
|
|
||||||
return new NavOptions.Builder()
|
|
||||||
.setLaunchSingleTop(navOptions.shouldLaunchSingleTop())
|
|
||||||
.setPopUpTo(navOptions.getPopUpTo(), navOptions.isPopUpToInclusive())
|
|
||||||
.setEnterAnim(navOptions.getEnterAnim() == emptyNavOptions.getEnterAnim()
|
|
||||||
? defaultNavOptions.getEnterAnim() : navOptions.getEnterAnim())
|
|
||||||
.setExitAnim(navOptions.getExitAnim() == emptyNavOptions.getExitAnim()
|
|
||||||
? defaultNavOptions.getExitAnim() : navOptions.getExitAnim())
|
|
||||||
.setPopEnterAnim(navOptions.getPopEnterAnim() == emptyNavOptions.getPopEnterAnim()
|
|
||||||
? defaultNavOptions.getPopEnterAnim() : navOptions.getPopEnterAnim())
|
|
||||||
.setPopExitAnim(navOptions.getPopExitAnim() == emptyNavOptions.getPopExitAnim()
|
|
||||||
? defaultNavOptions.getPopExitAnim() : navOptions.getPopExitAnim())
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,60 +0,0 @@
|
|||||||
// package awais.instagrabber.customviews;
|
|
||||||
//
|
|
||||||
// import android.os.Bundle;
|
|
||||||
//
|
|
||||||
// import androidx.annotation.NavigationRes;
|
|
||||||
// import androidx.annotation.NonNull;
|
|
||||||
// import androidx.annotation.Nullable;
|
|
||||||
// import androidx.navigation.NavController;
|
|
||||||
// import androidx.navigation.Navigator;
|
|
||||||
// import androidx.navigation.fragment.FragmentNavigator;
|
|
||||||
// import androidx.navigation.fragment.NavHostFragment;
|
|
||||||
//
|
|
||||||
// public class NavHostFragmentWithDefaultAnimations extends NavHostFragment {
|
|
||||||
// private static final String KEY_GRAPH_ID = "android-support-nav:fragment:graphId";
|
|
||||||
// private static final String KEY_START_DESTINATION_ARGS =
|
|
||||||
// "android-support-nav:fragment:startDestinationArgs";
|
|
||||||
// private static final String KEY_NAV_CONTROLLER_STATE =
|
|
||||||
// "android-support-nav:fragment:navControllerState";
|
|
||||||
// private static final String KEY_DEFAULT_NAV_HOST = "android-support-nav:fragment:defaultHost";
|
|
||||||
//
|
|
||||||
// @NonNull
|
|
||||||
// public static NavHostFragment create(@NavigationRes int graphResId) {
|
|
||||||
// return create(graphResId, null);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// @NonNull
|
|
||||||
// public static NavHostFragment create(@NavigationRes int graphResId,
|
|
||||||
// @Nullable Bundle startDestinationArgs) {
|
|
||||||
// Bundle b = null;
|
|
||||||
// if (graphResId != 0) {
|
|
||||||
// b = new Bundle();
|
|
||||||
// b.putInt(KEY_GRAPH_ID, graphResId);
|
|
||||||
// }
|
|
||||||
// if (startDestinationArgs != null) {
|
|
||||||
// if (b == null) {
|
|
||||||
// b = new Bundle();
|
|
||||||
// }
|
|
||||||
// b.putBundle(KEY_START_DESTINATION_ARGS, startDestinationArgs);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// final NavHostFragmentWithDefaultAnimations result = new NavHostFragmentWithDefaultAnimations();
|
|
||||||
// if (b != null) {
|
|
||||||
// result.setArguments(b);
|
|
||||||
// }
|
|
||||||
// return result;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// @NonNull
|
|
||||||
// @Override
|
|
||||||
// protected Navigator<? extends FragmentNavigator.Destination> createFragmentNavigator() {
|
|
||||||
// return new FragmentNavigatorWithDefaultAnimations(requireContext(), getChildFragmentManager(), getId());
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// @Override
|
|
||||||
// protected void onCreateNavController(@NonNull final NavController navController) {
|
|
||||||
// super.onCreateNavController(navController);
|
|
||||||
// navController.getNavigatorProvider()
|
|
||||||
// .addNavigator(new FragmentNavigatorWithDefaultAnimations(requireContext(), getChildFragmentManager(), getId()));
|
|
||||||
// }
|
|
||||||
// }
|
|
@ -34,6 +34,7 @@ public class GeneralPreferencesFragment extends BasePreferencesFragment implemen
|
|||||||
screen.addPreference(getDefaultTabPreference(context));
|
screen.addPreference(getDefaultTabPreference(context));
|
||||||
screen.addPreference(getTabOrderPreference(context));
|
screen.addPreference(getTabOrderPreference(context));
|
||||||
}
|
}
|
||||||
|
screen.addPreference(getDisableScreenTransitionsPreference(context));
|
||||||
screen.addPreference(getUpdateCheckPreference(context));
|
screen.addPreference(getUpdateCheckPreference(context));
|
||||||
screen.addPreference(getFlagSecurePreference(context));
|
screen.addPreference(getFlagSecurePreference(context));
|
||||||
screen.addPreference(getSearchFocusPreference(context));
|
screen.addPreference(getSearchFocusPreference(context));
|
||||||
@ -82,6 +83,14 @@ public class GeneralPreferencesFragment extends BasePreferencesFragment implemen
|
|||||||
return preference;
|
return preference;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Preference getDisableScreenTransitionsPreference(@NonNull final Context context) {
|
||||||
|
final SwitchPreferenceCompat preference = new SwitchPreferenceCompat(context);
|
||||||
|
preference.setKey(PreferenceKeys.PREF_DISABLE_SCREEN_TRANSITIONS);
|
||||||
|
preference.setTitle(R.string.disable_screen_transitions);
|
||||||
|
preference.setIconSpaceReserved(false);
|
||||||
|
return preference;
|
||||||
|
}
|
||||||
|
|
||||||
private Preference getUpdateCheckPreference(@NonNull final Context context) {
|
private Preference getUpdateCheckPreference(@NonNull final Context context) {
|
||||||
final SwitchPreferenceCompat preference = new SwitchPreferenceCompat(context);
|
final SwitchPreferenceCompat preference = new SwitchPreferenceCompat(context);
|
||||||
preference.setKey(PreferenceKeys.CHECK_UPDATES);
|
preference.setKey(PreferenceKeys.CHECK_UPDATES);
|
||||||
|
@ -11,6 +11,7 @@ object PreferenceKeys {
|
|||||||
const val PREF_SHOWN_COUNT_TOOLTIP = "shown_count_tooltip"
|
const val PREF_SHOWN_COUNT_TOOLTIP = "shown_count_tooltip"
|
||||||
const val PREF_SEARCH_FOCUS_KEYBOARD = "search_focus_keyboard"
|
const val PREF_SEARCH_FOCUS_KEYBOARD = "search_focus_keyboard"
|
||||||
const val PREF_AUTO_BACKUP_ENABLED = "auto_backup_enabled"
|
const val PREF_AUTO_BACKUP_ENABLED = "auto_backup_enabled"
|
||||||
|
const val PREF_DISABLE_SCREEN_TRANSITIONS = "disable_screen_transitions"
|
||||||
|
|
||||||
// string prefs
|
// string prefs
|
||||||
const val FOLDER_PATH = "custom_path"
|
const val FOLDER_PATH = "custom_path"
|
||||||
|
@ -60,7 +60,7 @@
|
|||||||
|
|
||||||
<androidx.fragment.app.FragmentContainerView
|
<androidx.fragment.app.FragmentContainerView
|
||||||
android:id="@+id/main_nav_host"
|
android:id="@+id/main_nav_host"
|
||||||
android:name="androidx.navigation.fragment.NavHostFragment"
|
android:name="awais.instagrabber.customviews.BarinstaNavHostFragment"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:clipToPadding="false"
|
android:clipToPadding="false"
|
||||||
|
@ -515,4 +515,5 @@
|
|||||||
<string name="share_via_dm">Share via DM</string>
|
<string name="share_via_dm">Share via DM</string>
|
||||||
<string name="share_link">Share link…</string>
|
<string name="share_link">Share link…</string>
|
||||||
<string name="slide_to_cancel">Slide to Cancel</string>
|
<string name="slide_to_cancel">Slide to Cancel</string>
|
||||||
|
<string name="disable_screen_transitions">Disable screen transitions</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
Loading…
Reference in New Issue
Block a user