rewrite how preference screens are invokved
This commit is contained in:
parent
de0272fd1a
commit
a25c5ed401
|
@ -186,6 +186,10 @@
|
||||||
<meta-data
|
<meta-data
|
||||||
android:name="android.support.PARENT_ACTIVITY"
|
android:name="android.support.PARENT_ACTIVITY"
|
||||||
android:value="eu.siacs.conversations.ui.SettingsActivity" />
|
android:value="eu.siacs.conversations.ui.SettingsActivity" />
|
||||||
|
<intent-filter>
|
||||||
|
<action android:name="android.intent.action.VIEW" />
|
||||||
|
<category android:name="android.intent.category.PREFERENCE" />
|
||||||
|
</intent-filter>
|
||||||
</activity>
|
</activity>
|
||||||
<activity android:name="com.soundcloud.android.crop.CropImageActivity" />
|
<activity android:name="com.soundcloud.android.crop.CropImageActivity" />
|
||||||
<activity android:name=".ui.MemorizingActivity"/>
|
<activity android:name=".ui.MemorizingActivity"/>
|
||||||
|
|
|
@ -7,7 +7,7 @@ import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.content.SharedPreferences.OnSharedPreferenceChangeListener;
|
import android.content.SharedPreferences.OnSharedPreferenceChangeListener;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.ResolveInfo;
|
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
@ -63,6 +63,7 @@ public class SettingsActivity extends XmppActivity implements
|
||||||
mSettingsFragment = new SettingsFragment();
|
mSettingsFragment = new SettingsFragment();
|
||||||
fm.beginTransaction().replace(android.R.id.content, mSettingsFragment).commit();
|
fm.beginTransaction().replace(android.R.id.content, mSettingsFragment).commit();
|
||||||
}
|
}
|
||||||
|
mSettingsFragment.setActivityIntent(getIntent());
|
||||||
|
|
||||||
this.mTheme = findTheme();
|
this.mTheme = findTheme();
|
||||||
setTheme(this.mTheme);
|
setTheme(this.mTheme);
|
||||||
|
@ -132,9 +133,8 @@ public class SettingsActivity extends XmppActivity implements
|
||||||
}
|
}
|
||||||
|
|
||||||
final Preference removeCertsPreference = mSettingsFragment.findPreference("remove_trusted_certificates");
|
final Preference removeCertsPreference = mSettingsFragment.findPreference("remove_trusted_certificates");
|
||||||
removeCertsPreference.setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() {
|
if (removeCertsPreference != null) {
|
||||||
@Override
|
removeCertsPreference.setOnPreferenceClickListener(preference -> {
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
|
||||||
final MemorizingTrustManager mtm = xmppConnectionService.getMemorizingTrustManager();
|
final MemorizingTrustManager mtm = xmppConnectionService.getMemorizingTrustManager();
|
||||||
final ArrayList<String> aliases = Collections.list(mtm.getCertificates());
|
final ArrayList<String> aliases = Collections.list(mtm.getCertificates());
|
||||||
if (aliases.size() == 0) {
|
if (aliases.size() == 0) {
|
||||||
|
@ -145,44 +145,37 @@ public class SettingsActivity extends XmppActivity implements
|
||||||
final AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(SettingsActivity.this);
|
final AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(SettingsActivity.this);
|
||||||
dialogBuilder.setTitle(getResources().getString(R.string.dialog_manage_certs_title));
|
dialogBuilder.setTitle(getResources().getString(R.string.dialog_manage_certs_title));
|
||||||
dialogBuilder.setMultiChoiceItems(aliases.toArray(new CharSequence[aliases.size()]), null,
|
dialogBuilder.setMultiChoiceItems(aliases.toArray(new CharSequence[aliases.size()]), null,
|
||||||
new DialogInterface.OnMultiChoiceClickListener() {
|
(dialog, indexSelected, isChecked) -> {
|
||||||
@Override
|
if (isChecked) {
|
||||||
public void onClick(DialogInterface dialog, int indexSelected,
|
selectedItems.add(indexSelected);
|
||||||
boolean isChecked) {
|
} else if (selectedItems.contains(indexSelected)) {
|
||||||
if (isChecked) {
|
selectedItems.remove(Integer.valueOf(indexSelected));
|
||||||
selectedItems.add(indexSelected);
|
}
|
||||||
} else if (selectedItems.contains(indexSelected)) {
|
if (selectedItems.size() > 0)
|
||||||
selectedItems.remove(Integer.valueOf(indexSelected));
|
((AlertDialog) dialog).getButton(DialogInterface.BUTTON_POSITIVE).setEnabled(true);
|
||||||
}
|
else {
|
||||||
if (selectedItems.size() > 0)
|
((AlertDialog) dialog).getButton(DialogInterface.BUTTON_POSITIVE).setEnabled(false);
|
||||||
((AlertDialog) dialog).getButton(DialogInterface.BUTTON_POSITIVE).setEnabled(true);
|
|
||||||
else {
|
|
||||||
((AlertDialog) dialog).getButton(DialogInterface.BUTTON_POSITIVE).setEnabled(false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
dialogBuilder.setPositiveButton(
|
dialogBuilder.setPositiveButton(
|
||||||
getResources().getString(R.string.dialog_manage_certs_positivebutton), new DialogInterface.OnClickListener() {
|
getResources().getString(R.string.dialog_manage_certs_positivebutton), (dialog, which) -> {
|
||||||
@Override
|
int count = selectedItems.size();
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
if (count > 0) {
|
||||||
int count = selectedItems.size();
|
for (int i = 0; i < count; i++) {
|
||||||
if (count > 0) {
|
try {
|
||||||
for (int i = 0; i < count; i++) {
|
Integer item = Integer.valueOf(selectedItems.get(i).toString());
|
||||||
try {
|
String alias = aliases.get(item);
|
||||||
Integer item = Integer.valueOf(selectedItems.get(i).toString());
|
mtm.deleteCertificate(alias);
|
||||||
String alias = aliases.get(item);
|
} catch (KeyStoreException e) {
|
||||||
mtm.deleteCertificate(alias);
|
e.printStackTrace();
|
||||||
} catch (KeyStoreException e) {
|
displayToast("Error: " + e.getLocalizedMessage());
|
||||||
e.printStackTrace();
|
|
||||||
displayToast("Error: " + e.getLocalizedMessage());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (xmppConnectionServiceBound) {
|
|
||||||
reconnectAccounts();
|
|
||||||
}
|
|
||||||
displayToast(getResources().getQuantityString(R.plurals.toast_delete_certificates, count, count));
|
|
||||||
}
|
}
|
||||||
|
if (xmppConnectionServiceBound) {
|
||||||
|
reconnectAccounts();
|
||||||
|
}
|
||||||
|
displayToast(getResources().getQuantityString(R.plurals.toast_delete_certificates, count, count));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
dialogBuilder.setNegativeButton(getResources().getString(R.string.dialog_manage_certs_negativebutton), null);
|
dialogBuilder.setNegativeButton(getResources().getString(R.string.dialog_manage_certs_negativebutton), null);
|
||||||
|
@ -190,48 +183,35 @@ public class SettingsActivity extends XmppActivity implements
|
||||||
removeCertsDialog.show();
|
removeCertsDialog.show();
|
||||||
removeCertsDialog.getButton(AlertDialog.BUTTON_POSITIVE).setEnabled(false);
|
removeCertsDialog.getButton(AlertDialog.BUTTON_POSITIVE).setEnabled(false);
|
||||||
return true;
|
return true;
|
||||||
}
|
});
|
||||||
});
|
}
|
||||||
|
|
||||||
final Preference exportLogsPreference = mSettingsFragment.findPreference("export_logs");
|
final Preference exportLogsPreference = mSettingsFragment.findPreference("export_logs");
|
||||||
exportLogsPreference.setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() {
|
if (exportLogsPreference != null) {
|
||||||
@Override
|
exportLogsPreference.setOnPreferenceClickListener(preference -> {
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
|
||||||
if (hasStoragePermission(REQUEST_WRITE_LOGS)) {
|
if (hasStoragePermission(REQUEST_WRITE_LOGS)) {
|
||||||
startExport();
|
startExport();
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (Config.ONLY_INTERNAL_STORAGE) {
|
|
||||||
final Preference cleanCachePreference = mSettingsFragment.findPreference("clean_cache");
|
|
||||||
cleanCachePreference.setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() {
|
|
||||||
@Override
|
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
|
||||||
cleanCache();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
final Preference cleanPrivateStoragePreference = mSettingsFragment.findPreference("clean_private_storage");
|
|
||||||
cleanPrivateStoragePreference.setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() {
|
|
||||||
@Override
|
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
|
||||||
cleanPrivateStorage();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
final Preference deleteOmemoPreference = mSettingsFragment.findPreference("delete_omemo_identities");
|
if (Config.ONLY_INTERNAL_STORAGE) {
|
||||||
deleteOmemoPreference.setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() {
|
final Preference cleanCachePreference = mSettingsFragment.findPreference("clean_cache");
|
||||||
@Override
|
if (cleanCachePreference != null) {
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
cleanCachePreference.setOnPreferenceClickListener(preference -> cleanCache());
|
||||||
deleteOmemoIdentities();
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
final Preference cleanPrivateStoragePreference = mSettingsFragment.findPreference("clean_private_storage");
|
||||||
|
if (cleanPrivateStoragePreference != null) {
|
||||||
|
cleanPrivateStoragePreference.setOnPreferenceClickListener(preference -> cleanPrivateStorage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
final Preference deleteOmemoPreference = mSettingsFragment.findPreference("delete_omemo_identities");
|
||||||
|
if (deleteOmemoPreference != null) {
|
||||||
|
deleteOmemoPreference.setOnPreferenceClickListener(preference -> deleteOmemoIdentities());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isCallable(final Intent i) {
|
private boolean isCallable(final Intent i) {
|
||||||
|
@ -239,15 +219,17 @@ public class SettingsActivity extends XmppActivity implements
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void cleanCache() {
|
private boolean cleanCache() {
|
||||||
Intent intent = new Intent(android.provider.Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
|
Intent intent = new Intent(android.provider.Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
|
||||||
intent.setData(Uri.parse("package:" + getPackageName()));
|
intent.setData(Uri.parse("package:" + getPackageName()));
|
||||||
startActivity(intent);
|
startActivity(intent);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void cleanPrivateStorage() {
|
private boolean cleanPrivateStorage() {
|
||||||
cleanPrivatePictures();
|
cleanPrivatePictures();
|
||||||
cleanPrivateFiles();
|
cleanPrivateFiles();
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void cleanPrivatePictures() {
|
private void cleanPrivatePictures() {
|
||||||
|
@ -290,11 +272,11 @@ public class SettingsActivity extends XmppActivity implements
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void deleteOmemoIdentities() {
|
private boolean deleteOmemoIdentities() {
|
||||||
AlertDialog.Builder builder = new AlertDialog.Builder(this);
|
AlertDialog.Builder builder = new AlertDialog.Builder(this);
|
||||||
builder.setTitle(R.string.pref_delete_omemo_identities);
|
builder.setTitle(R.string.pref_delete_omemo_identities);
|
||||||
final List<CharSequence> accounts = new ArrayList<>();
|
final List<CharSequence> accounts = new ArrayList<>();
|
||||||
for(Account account : xmppConnectionService.getAccounts()) {
|
for (Account account : xmppConnectionService.getAccounts()) {
|
||||||
if (account.isEnabled()) {
|
if (account.isEnabled()) {
|
||||||
accounts.add(account.getJid().toBareJid().toString());
|
accounts.add(account.getJid().toBareJid().toString());
|
||||||
}
|
}
|
||||||
|
@ -305,7 +287,7 @@ public class SettingsActivity extends XmppActivity implements
|
||||||
public void onClick(DialogInterface dialog, int which, boolean isChecked) {
|
public void onClick(DialogInterface dialog, int which, boolean isChecked) {
|
||||||
checkedItems[which] = isChecked;
|
checkedItems[which] = isChecked;
|
||||||
final AlertDialog alertDialog = (AlertDialog) dialog;
|
final AlertDialog alertDialog = (AlertDialog) dialog;
|
||||||
for(boolean item : checkedItems) {
|
for (boolean item : checkedItems) {
|
||||||
if (item) {
|
if (item) {
|
||||||
alertDialog.getButton(DialogInterface.BUTTON_POSITIVE).setEnabled(true);
|
alertDialog.getButton(DialogInterface.BUTTON_POSITIVE).setEnabled(true);
|
||||||
return;
|
return;
|
||||||
|
@ -314,11 +296,11 @@ public class SettingsActivity extends XmppActivity implements
|
||||||
alertDialog.getButton(DialogInterface.BUTTON_POSITIVE).setEnabled(false);
|
alertDialog.getButton(DialogInterface.BUTTON_POSITIVE).setEnabled(false);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
builder.setNegativeButton(R.string.cancel,null);
|
builder.setNegativeButton(R.string.cancel, null);
|
||||||
builder.setPositiveButton(R.string.delete_selected_keys, new DialogInterface.OnClickListener() {
|
builder.setPositiveButton(R.string.delete_selected_keys, new DialogInterface.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
for(int i = 0; i < checkedItems.length; ++i) {
|
for (int i = 0; i < checkedItems.length; ++i) {
|
||||||
if (checkedItems[i]) {
|
if (checkedItems[i]) {
|
||||||
try {
|
try {
|
||||||
Jid jid = Jid.fromString(accounts.get(i).toString());
|
Jid jid = Jid.fromString(accounts.get(i).toString());
|
||||||
|
@ -337,6 +319,7 @@ public class SettingsActivity extends XmppActivity implements
|
||||||
AlertDialog dialog = builder.create();
|
AlertDialog dialog = builder.create();
|
||||||
dialog.show();
|
dialog.show();
|
||||||
dialog.getButton(AlertDialog.BUTTON_POSITIVE).setEnabled(false);
|
dialog.getButton(AlertDialog.BUTTON_POSITIVE).setEnabled(false);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -1,77 +1,60 @@
|
||||||
package eu.siacs.conversations.ui;
|
package eu.siacs.conversations.ui;
|
||||||
|
|
||||||
import android.app.Dialog;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.preference.Preference;
|
import android.preference.Preference;
|
||||||
import android.preference.PreferenceCategory;
|
import android.preference.PreferenceCategory;
|
||||||
import android.preference.PreferenceFragment;
|
import android.preference.PreferenceFragment;
|
||||||
import android.preference.PreferenceScreen;
|
import android.preference.PreferenceScreen;
|
||||||
import android.view.View;
|
import android.text.TextUtils;
|
||||||
import android.view.ViewGroup;
|
|
||||||
import android.view.ViewParent;
|
|
||||||
import android.widget.FrameLayout;
|
|
||||||
import android.widget.LinearLayout;
|
|
||||||
|
|
||||||
import eu.siacs.conversations.Config;
|
import eu.siacs.conversations.Config;
|
||||||
import eu.siacs.conversations.R;
|
import eu.siacs.conversations.R;
|
||||||
|
|
||||||
public class SettingsFragment extends PreferenceFragment {
|
public class SettingsFragment extends PreferenceFragment {
|
||||||
|
|
||||||
//http://stackoverflow.com/questions/16374820/action-bar-home-button-not-functional-with-nested-preferencescreen/16800527#16800527
|
private String page = null;
|
||||||
private void initializeActionBar(PreferenceScreen preferenceScreen) {
|
|
||||||
final Dialog dialog = preferenceScreen.getDialog();
|
|
||||||
|
|
||||||
if (dialog != null) {
|
|
||||||
View homeBtn = dialog.findViewById(android.R.id.home);
|
|
||||||
|
|
||||||
if (homeBtn != null) {
|
|
||||||
View.OnClickListener dismissDialogClickListener = new View.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
dialog.dismiss();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
ViewParent homeBtnContainer = homeBtn.getParent();
|
|
||||||
|
|
||||||
if (homeBtnContainer instanceof FrameLayout) {
|
|
||||||
ViewGroup containerParent = (ViewGroup) homeBtnContainer.getParent();
|
|
||||||
if (containerParent instanceof LinearLayout) {
|
|
||||||
((LinearLayout) containerParent).setOnClickListener(dismissDialogClickListener);
|
|
||||||
} else {
|
|
||||||
((FrameLayout) homeBtnContainer).setOnClickListener(dismissDialogClickListener);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
homeBtn.setOnClickListener(dismissDialogClickListener);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
// Load the preferences from an XML resource
|
|
||||||
addPreferencesFromResource(R.xml.preferences);
|
addPreferencesFromResource(R.xml.preferences);
|
||||||
|
|
||||||
// Remove from standard preferences if the flag ONLY_INTERNAL_STORAGE is not true
|
// Remove from standard preferences if the flag ONLY_INTERNAL_STORAGE is not true
|
||||||
if (!Config.ONLY_INTERNAL_STORAGE) {
|
if (!Config.ONLY_INTERNAL_STORAGE) {
|
||||||
PreferenceCategory mCategory = (PreferenceCategory) findPreference("security_options");
|
PreferenceCategory mCategory = (PreferenceCategory) findPreference("security_options");
|
||||||
Preference mPref1 = findPreference("clean_cache");
|
if (mCategory != null) {
|
||||||
Preference mPref2 = findPreference("clean_private_storage");
|
Preference cleanCache = findPreference("clean_cache");
|
||||||
mCategory.removePreference(mPref1);
|
Preference cleanPrivateStorage = findPreference("clean_private_storage");
|
||||||
mCategory.removePreference(mPref2);
|
mCategory.removePreference(cleanCache);
|
||||||
|
mCategory.removePreference(cleanPrivateStorage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!TextUtils.isEmpty(page)) {
|
||||||
|
openPreferenceScreen(page);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
public void setActivityIntent(final Intent intent) {
|
||||||
public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen, Preference preference) {
|
if (intent != null) {
|
||||||
super.onPreferenceTreeClick(preferenceScreen, preference);
|
if (Intent.ACTION_VIEW.equals(intent.getAction())) {
|
||||||
if (preference instanceof PreferenceScreen) {
|
if (intent.getExtras() != null) {
|
||||||
initializeActionBar((PreferenceScreen) preference);
|
this.page = intent.getExtras().getString("page");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void openPreferenceScreen(final String screenName) {
|
||||||
|
final Preference pref = findPreference(screenName);
|
||||||
|
if (pref instanceof PreferenceScreen) {
|
||||||
|
final PreferenceScreen preferenceScreen = (PreferenceScreen) pref;
|
||||||
|
getActivity().setTitle(preferenceScreen.getTitle());
|
||||||
|
preferenceScreen.setDependency("");
|
||||||
|
setPreferenceScreen((PreferenceScreen) pref);
|
||||||
}
|
}
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -87,6 +87,12 @@
|
||||||
android:key="quiet_hours"
|
android:key="quiet_hours"
|
||||||
android:summary="@string/pref_quiet_hours_summary"
|
android:summary="@string/pref_quiet_hours_summary"
|
||||||
android:title="@string/title_pref_quiet_hours">
|
android:title="@string/title_pref_quiet_hours">
|
||||||
|
<intent
|
||||||
|
android:action="android.intent.action.VIEW"
|
||||||
|
android:targetPackage="eu.siacs.conversations"
|
||||||
|
android:targetClass="eu.siacs.conversations.ui.SettingsActivity" >
|
||||||
|
<extra android:name="page" android:value="quiet_hours" />
|
||||||
|
</intent>
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
android:defaultValue="@bool/enable_quiet_hours"
|
android:defaultValue="@bool/enable_quiet_hours"
|
||||||
android:key="enable_quiet_hours"
|
android:key="enable_quiet_hours"
|
||||||
|
@ -185,6 +191,12 @@
|
||||||
android:key="expert"
|
android:key="expert"
|
||||||
android:summary="@string/pref_expert_options_summary"
|
android:summary="@string/pref_expert_options_summary"
|
||||||
android:title="@string/pref_expert_options">
|
android:title="@string/pref_expert_options">
|
||||||
|
<intent
|
||||||
|
android:action="android.intent.action.VIEW"
|
||||||
|
android:targetPackage="eu.siacs.conversations"
|
||||||
|
android:targetClass="eu.siacs.conversations.ui.SettingsActivity" >
|
||||||
|
<extra android:name="page" android:value="expert" />
|
||||||
|
</intent>
|
||||||
<PreferenceCategory android:title="@string/pref_security_settings"
|
<PreferenceCategory android:title="@string/pref_security_settings"
|
||||||
android:key="security_options">
|
android:key="security_options">
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
|
Loading…
Reference in New Issue