mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2024-11-27 20:36:51 +01:00
Prevent crash on unknown activity charts tab
This commit is contained in:
parent
f76180c4bd
commit
bfde77fb3a
@ -17,7 +17,13 @@
|
||||
package nodomain.freeyourgadget.gadgetbridge.activities.charts;
|
||||
|
||||
import android.content.Context;
|
||||
import android.os.Bundle;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.fragment.app.Fragment;
|
||||
import androidx.fragment.app.FragmentManager;
|
||||
import androidx.fragment.app.FragmentStatePagerAdapter;
|
||||
@ -25,10 +31,12 @@ import androidx.fragment.app.FragmentStatePagerAdapter;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.Locale;
|
||||
|
||||
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||
import nodomain.freeyourgadget.gadgetbridge.R;
|
||||
import nodomain.freeyourgadget.gadgetbridge.activities.AbstractFragmentPagerAdapter;
|
||||
import nodomain.freeyourgadget.gadgetbridge.activities.AbstractGBFragment;
|
||||
import nodomain.freeyourgadget.gadgetbridge.activities.devicesettings.DeviceSettingsPreferenceConst;
|
||||
import nodomain.freeyourgadget.gadgetbridge.devices.DeviceCoordinator;
|
||||
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
||||
@ -107,7 +115,7 @@ public class ActivityChartsActivity extends AbstractChartsActivity {
|
||||
if (!coordinator.supportsTemperatureMeasurement()) {
|
||||
tabList.remove("temperature");
|
||||
}
|
||||
if(!coordinator.supportsCyclingData()) {
|
||||
if (!coordinator.supportsCyclingData()) {
|
||||
tabList.remove("cycling");
|
||||
}
|
||||
if (!coordinator.supportsWeightMeasurement()) {
|
||||
@ -136,6 +144,7 @@ public class ActivityChartsActivity extends AbstractChartsActivity {
|
||||
super(fm);
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@Override
|
||||
public Fragment getItem(int position) {
|
||||
// getItem is called to instantiate the fragment for the given page.
|
||||
@ -169,7 +178,8 @@ public class ActivityChartsActivity extends AbstractChartsActivity {
|
||||
case "weight":
|
||||
return new WeightChartFragment();
|
||||
}
|
||||
return null;
|
||||
|
||||
return new UnknownFragment();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -209,7 +219,27 @@ public class ActivityChartsActivity extends AbstractChartsActivity {
|
||||
case "weight":
|
||||
return getString(R.string.menuitem_weight);
|
||||
}
|
||||
return super.getPageTitle(position);
|
||||
|
||||
return String.format(Locale.getDefault(), "Unknown %d", position);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* A dummy fragment to avoid a crash when we get a unknown tab position (eg. broken
|
||||
* preference migration).
|
||||
*/
|
||||
public static class UnknownFragment extends AbstractGBFragment {
|
||||
@Override
|
||||
public View onCreateView(@NonNull final LayoutInflater inflater,
|
||||
final ViewGroup container,
|
||||
final Bundle savedInstanceState) {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Nullable
|
||||
@Override
|
||||
protected CharSequence getTitle() {
|
||||
return "Unknown";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user