Fix npe
This commit is contained in:
parent
b51b8fdd1f
commit
1691f90ee7
1 changed files with 30 additions and 20 deletions
|
@ -165,7 +165,7 @@ public abstract class BaseSettingsFragment extends PreferenceFragmentCompat impl
|
||||||
updateTheme();
|
updateTheme();
|
||||||
View view = super.onCreateView(inflater, container, savedInstanceState);
|
View view = super.onCreateView(inflater, container, savedInstanceState);
|
||||||
if (view != null) {
|
if (view != null) {
|
||||||
if (getPreferenceScreen() != null) {
|
if (getPreferenceScreen() != null && currentScreenType != null) {
|
||||||
PreferenceManager prefManager = getPreferenceManager();
|
PreferenceManager prefManager = getPreferenceManager();
|
||||||
PreferenceScreen preferenceScreen = prefManager.inflateFromResource(prefManager.getContext(), currentScreenType.preferencesResId, null);
|
PreferenceScreen preferenceScreen = prefManager.inflateFromResource(prefManager.getContext(), currentScreenType.preferencesResId, null);
|
||||||
if (prefManager.setPreferences(preferenceScreen)) {
|
if (prefManager.setPreferences(preferenceScreen)) {
|
||||||
|
@ -293,7 +293,7 @@ public abstract class BaseSettingsFragment extends PreferenceFragmentCompat impl
|
||||||
@ColorRes
|
@ColorRes
|
||||||
public int getStatusBarColorId() {
|
public int getStatusBarColorId() {
|
||||||
boolean nightMode = isNightMode();
|
boolean nightMode = isNightMode();
|
||||||
if (currentScreenType.profileDependent) {
|
if (isProfileDependent()) {
|
||||||
View view = getView();
|
View view = getView();
|
||||||
if (view != null && Build.VERSION.SDK_INT >= 23 && !nightMode) {
|
if (view != null && Build.VERSION.SDK_INT >= 23 && !nightMode) {
|
||||||
view.setSystemUiVisibility(view.getSystemUiVisibility() | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
|
view.setSystemUiVisibility(view.getSystemUiVisibility() | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
|
||||||
|
@ -314,6 +314,10 @@ public abstract class BaseSettingsFragment extends PreferenceFragmentCompat impl
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isProfileDependent() {
|
||||||
|
return currentScreenType != null && currentScreenType.profileDependent;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onDisplayPreferenceDialog(Preference preference) {
|
public void onDisplayPreferenceDialog(Preference preference) {
|
||||||
FragmentManager fragmentManager = getFragmentManager();
|
FragmentManager fragmentManager = getFragmentManager();
|
||||||
|
@ -323,13 +327,13 @@ public abstract class BaseSettingsFragment extends PreferenceFragmentCompat impl
|
||||||
|
|
||||||
ApplicationMode appMode = getSelectedAppMode();
|
ApplicationMode appMode = getSelectedAppMode();
|
||||||
if (preference instanceof ListPreferenceEx) {
|
if (preference instanceof ListPreferenceEx) {
|
||||||
SingleSelectPreferenceBottomSheet.showInstance(fragmentManager, preference.getKey(), this, false, appMode, currentScreenType.profileDependent, false);
|
SingleSelectPreferenceBottomSheet.showInstance(fragmentManager, preference.getKey(), this, false, appMode, isProfileDependent(), false);
|
||||||
} else if (preference instanceof SwitchPreferenceEx) {
|
} else if (preference instanceof SwitchPreferenceEx) {
|
||||||
BooleanPreferenceBottomSheet.showInstance(fragmentManager, preference.getKey(), this, false, appMode, currentScreenType.profileDependent);
|
BooleanPreferenceBottomSheet.showInstance(fragmentManager, preference.getKey(), this, false, appMode, isProfileDependent());
|
||||||
} else if (preference instanceof EditTextPreference) {
|
} else if (preference instanceof EditTextPreference) {
|
||||||
EditTextPreferenceBottomSheet.showInstance(fragmentManager, preference.getKey(), this, false, appMode);
|
EditTextPreferenceBottomSheet.showInstance(fragmentManager, preference.getKey(), this, false, appMode);
|
||||||
} else if (preference instanceof MultiSelectBooleanPreference) {
|
} else if (preference instanceof MultiSelectBooleanPreference) {
|
||||||
MultiSelectPreferencesBottomSheet.showInstance(fragmentManager, preference.getKey(), this, false, appMode, currentScreenType.profileDependent);
|
MultiSelectPreferencesBottomSheet.showInstance(fragmentManager, preference.getKey(), this, false, appMode, isProfileDependent());
|
||||||
} else {
|
} else {
|
||||||
super.onDisplayPreferenceDialog(preference);
|
super.onDisplayPreferenceDialog(preference);
|
||||||
}
|
}
|
||||||
|
@ -359,7 +363,7 @@ public abstract class BaseSettingsFragment extends PreferenceFragmentCompat impl
|
||||||
|
|
||||||
public void recreate() {
|
public void recreate() {
|
||||||
FragmentActivity activity = getActivity();
|
FragmentActivity activity = getActivity();
|
||||||
if (activity != null) {
|
if (activity != null && currentScreenType != null) {
|
||||||
Fragment fragment = Fragment.instantiate(activity, currentScreenType.fragmentName);
|
Fragment fragment = Fragment.instantiate(activity, currentScreenType.fragmentName);
|
||||||
fragment.setArguments(buildArguments());
|
fragment.setArguments(buildArguments());
|
||||||
FragmentManager fm = activity.getSupportFragmentManager();
|
FragmentManager fm = activity.getSupportFragmentManager();
|
||||||
|
@ -386,7 +390,7 @@ public abstract class BaseSettingsFragment extends PreferenceFragmentCompat impl
|
||||||
titleView.setSingleLine(false);
|
titleView.setSingleLine(false);
|
||||||
}
|
}
|
||||||
boolean enabled = preference.isEnabled();
|
boolean enabled = preference.isEnabled();
|
||||||
if (currentScreenType.profileDependent) {
|
if (isProfileDependent()) {
|
||||||
View cb = holder.itemView.findViewById(R.id.switchWidget);
|
View cb = holder.itemView.findViewById(R.id.switchWidget);
|
||||||
if (cb == null) {
|
if (cb == null) {
|
||||||
cb = holder.findViewById(android.R.id.checkbox);
|
cb = holder.findViewById(android.R.id.checkbox);
|
||||||
|
@ -423,22 +427,28 @@ public abstract class BaseSettingsFragment extends PreferenceFragmentCompat impl
|
||||||
AppBarLayout appBarLayout = (AppBarLayout) view.findViewById(R.id.appbar);
|
AppBarLayout appBarLayout = (AppBarLayout) view.findViewById(R.id.appbar);
|
||||||
ViewCompat.setElevation(appBarLayout, 5.0f);
|
ViewCompat.setElevation(appBarLayout, 5.0f);
|
||||||
|
|
||||||
View toolbarContainer = UiUtilities.getInflater(getActivity(), isNightMode()).inflate(currentScreenType.toolbarResId, appBarLayout);
|
View toolbarContainer = currentScreenType == null ? null :
|
||||||
|
UiUtilities.getInflater(getActivity(), isNightMode()).inflate(currentScreenType.toolbarResId, appBarLayout);
|
||||||
|
|
||||||
TextView toolbarTitle = (TextView) view.findViewById(R.id.toolbar_title);
|
TextView toolbarTitle = (TextView) view.findViewById(R.id.toolbar_title);
|
||||||
toolbarTitle.setText(getPreferenceScreen().getTitle());
|
if (toolbarTitle != null) {
|
||||||
|
toolbarTitle.setText(getPreferenceScreen().getTitle());
|
||||||
|
}
|
||||||
|
|
||||||
View closeButton = view.findViewById(R.id.close_button);
|
View closeButton = view.findViewById(R.id.close_button);
|
||||||
closeButton.setOnClickListener(new View.OnClickListener() {
|
if (closeButton != null) {
|
||||||
@Override
|
closeButton.setOnClickListener(new View.OnClickListener() {
|
||||||
public void onClick(View v) {
|
@Override
|
||||||
MapActivity mapActivity = getMapActivity();
|
public void onClick(View v) {
|
||||||
if (mapActivity != null) {
|
MapActivity mapActivity = getMapActivity();
|
||||||
mapActivity.onBackPressed();
|
if (mapActivity != null) {
|
||||||
|
mapActivity.onBackPressed();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
});
|
||||||
});
|
}
|
||||||
View switchProfile = toolbarContainer.findViewById(R.id.profile_button);
|
|
||||||
|
View switchProfile = toolbarContainer == null ? null : toolbarContainer.findViewById(R.id.profile_button);
|
||||||
if (switchProfile != null) {
|
if (switchProfile != null) {
|
||||||
switchProfile.setContentDescription(getString(R.string.switch_profile));
|
switchProfile.setContentDescription(getString(R.string.switch_profile));
|
||||||
switchProfile.setOnClickListener(new View.OnClickListener() {
|
switchProfile.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@ -487,7 +497,7 @@ public abstract class BaseSettingsFragment extends PreferenceFragmentCompat impl
|
||||||
}
|
}
|
||||||
|
|
||||||
View profileButton = view.findViewById(R.id.profile_button);
|
View profileButton = view.findViewById(R.id.profile_button);
|
||||||
if (profileButton != null) {
|
if (profileButton != null && currentScreenType != null) {
|
||||||
int toolbarRes = currentScreenType.toolbarResId;
|
int toolbarRes = currentScreenType.toolbarResId;
|
||||||
int iconColor = getActiveProfileColor();
|
int iconColor = getActiveProfileColor();
|
||||||
int bgColor = UiUtilities.getColorWithAlpha(iconColor, 0.1f);
|
int bgColor = UiUtilities.getColorWithAlpha(iconColor, 0.1f);
|
||||||
|
@ -521,7 +531,7 @@ public abstract class BaseSettingsFragment extends PreferenceFragmentCompat impl
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updatePreferencesScreen() {
|
private void updatePreferencesScreen() {
|
||||||
if (getSelectedAppMode() != null) {
|
if (getSelectedAppMode() != null && currentScreenType != null) {
|
||||||
int resId = currentScreenType.preferencesResId;
|
int resId = currentScreenType.preferencesResId;
|
||||||
if (resId != -1) {
|
if (resId != -1) {
|
||||||
addPreferencesFromResource(resId);
|
addPreferencesFromResource(resId);
|
||||||
|
|
Loading…
Reference in a new issue