mirror of
https://github.com/syncthing/syncthing-android.git
synced 2024-11-26 14:21:16 +00:00
Fix crash in MainActivity.onSaveInstanceState()
This commit is contained in:
parent
bdec750b34
commit
8e1dfe875e
1 changed files with 21 additions and 16 deletions
|
@ -42,6 +42,7 @@ import android.widget.ImageView;
|
|||
import android.widget.TextView;
|
||||
import android.widget.Toast;
|
||||
|
||||
import com.annimon.stream.function.Consumer;
|
||||
import com.nutomic.syncthingandroid.R;
|
||||
import com.nutomic.syncthingandroid.fragments.DeviceListFragment;
|
||||
import com.nutomic.syncthingandroid.fragments.DrawerFragment;
|
||||
|
@ -272,12 +273,17 @@ public class MainActivity extends StateDialogActivity
|
|||
@Override
|
||||
protected void onSaveInstanceState(Bundle outState) {
|
||||
super.onSaveInstanceState(outState);
|
||||
// Avoid crash if called during startup.
|
||||
if (mFolderListFragment != null && mDeviceListFragment != null && mDrawerFragment != null) {
|
||||
|
||||
FragmentManager fm = getSupportFragmentManager();
|
||||
fm.putFragment(outState, FolderListFragment.class.getName(), mFolderListFragment);
|
||||
fm.putFragment(outState, DeviceListFragment.class.getName(), mDeviceListFragment);
|
||||
fm.putFragment(outState, DrawerFragment.class.getName(), mDrawerFragment);
|
||||
Consumer<Fragment> putFragment = fragment -> {
|
||||
if (fragment != null && fragment.isAdded()) {
|
||||
fm.putFragment(outState, fragment.getClass().getName(), fragment);
|
||||
}
|
||||
};
|
||||
putFragment.accept(mFolderListFragment);
|
||||
putFragment.accept(mDeviceListFragment);
|
||||
putFragment.accept(mDrawerFragment);
|
||||
|
||||
outState.putInt("currentTab", mViewPager.getCurrentItem());
|
||||
outState.putBoolean(BATTERY_DIALOG_DISMISSED, mBatteryOptimizationsDialog == null || !mBatteryOptimizationsDialog.isShowing());
|
||||
outState.putBoolean(IS_SHOWING_RESTART_DIALOG, mRestartDialog != null && mRestartDialog.isShowing());
|
||||
|
@ -290,7 +296,6 @@ public class MainActivity extends StateDialogActivity
|
|||
}
|
||||
Util.dismissDialogSafe(mRestartDialog, this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onPostCreate(Bundle savedInstanceState) {
|
||||
|
|
Loading…
Reference in a new issue