Merge "Properly handle rotation in NotificationLockscreenPreference" into nyc-dev
am: 820d7c85c7
* commit '820d7c85c724b28267b1a5d0dee8b190f49d8517':
Properly handle rotation in NotificationLockscreenPreference
Change-Id: I67be3fb9333356f0e1e7fa3de7c4a3838554b32a
This commit is contained in:
@@ -24,7 +24,6 @@ import android.os.Bundle;
|
|||||||
import android.support.v14.preference.ListPreferenceDialogFragment;
|
import android.support.v14.preference.ListPreferenceDialogFragment;
|
||||||
import android.support.v7.preference.ListPreference;
|
import android.support.v7.preference.ListPreference;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.view.View;
|
|
||||||
|
|
||||||
public class CustomListPreference extends ListPreference {
|
public class CustomListPreference extends ListPreference {
|
||||||
|
|
||||||
@@ -51,8 +50,14 @@ public class CustomListPreference extends ListPreference {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void onDialogStateRestored(Dialog dialog, Bundle savedInstanceState) {
|
||||||
|
}
|
||||||
|
|
||||||
public static class CustomListPreferenceDialogFragment extends ListPreferenceDialogFragment {
|
public static class CustomListPreferenceDialogFragment extends ListPreferenceDialogFragment {
|
||||||
|
|
||||||
|
private static final java.lang.String KEY_CLICKED_ENTRY_INDEX
|
||||||
|
= "settings.CustomListPrefDialog.KEY_CLICKED_ENTRY_INDEX";
|
||||||
|
|
||||||
private int mClickedDialogEntryIndex;
|
private int mClickedDialogEntryIndex;
|
||||||
|
|
||||||
public static ListPreferenceDialogFragment newInstance(String key) {
|
public static ListPreferenceDialogFragment newInstance(String key) {
|
||||||
@@ -88,10 +93,26 @@ public class CustomListPreference extends ListPreference {
|
|||||||
@Override
|
@Override
|
||||||
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
||||||
Dialog dialog = super.onCreateDialog(savedInstanceState);
|
Dialog dialog = super.onCreateDialog(savedInstanceState);
|
||||||
|
if (savedInstanceState != null) {
|
||||||
|
mClickedDialogEntryIndex = savedInstanceState.getInt(KEY_CLICKED_ENTRY_INDEX,
|
||||||
|
mClickedDialogEntryIndex);
|
||||||
|
}
|
||||||
getCustomizablePreference().onDialogCreated(dialog);
|
getCustomizablePreference().onDialogCreated(dialog);
|
||||||
return dialog;
|
return dialog;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSaveInstanceState(Bundle outState) {
|
||||||
|
super.onSaveInstanceState(outState);
|
||||||
|
outState.putInt(KEY_CLICKED_ENTRY_INDEX, mClickedDialogEntryIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onActivityCreated(Bundle savedInstanceState) {
|
||||||
|
super.onActivityCreated(savedInstanceState);
|
||||||
|
getCustomizablePreference().onDialogStateRestored(getDialog(), savedInstanceState);
|
||||||
|
}
|
||||||
|
|
||||||
protected DialogInterface.OnClickListener getOnItemClickListener() {
|
protected DialogInterface.OnClickListener getOnItemClickListener() {
|
||||||
return new DialogInterface.OnClickListener() {
|
return new DialogInterface.OnClickListener() {
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
@@ -24,6 +24,7 @@ import android.app.AlertDialog;
|
|||||||
import android.app.Dialog;
|
import android.app.Dialog;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
|
import android.os.Bundle;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
@@ -37,7 +38,6 @@ import android.widget.ListView;
|
|||||||
public class NotificationLockscreenPreference extends RestrictedListPreference {
|
public class NotificationLockscreenPreference extends RestrictedListPreference {
|
||||||
|
|
||||||
private boolean mAllowRemoteInput;
|
private boolean mAllowRemoteInput;
|
||||||
private int mInitialIndex;
|
|
||||||
private Listener mListener;
|
private Listener mListener;
|
||||||
private boolean mShowRemoteInput;
|
private boolean mShowRemoteInput;
|
||||||
private boolean mRemoteInputCheckBoxEnabled = true;
|
private boolean mRemoteInputCheckBoxEnabled = true;
|
||||||
@@ -69,10 +69,8 @@ public class NotificationLockscreenPreference extends RestrictedListPreference {
|
|||||||
protected void onPrepareDialogBuilder(AlertDialog.Builder builder,
|
protected void onPrepareDialogBuilder(AlertDialog.Builder builder,
|
||||||
DialogInterface.OnClickListener innerListener) {
|
DialogInterface.OnClickListener innerListener) {
|
||||||
|
|
||||||
final String selectedValue = getValue();
|
|
||||||
mInitialIndex = (selectedValue == null) ? -1 : findIndexOfValue(selectedValue);
|
|
||||||
mListener = new Listener(innerListener);
|
mListener = new Listener(innerListener);
|
||||||
builder.setSingleChoiceItems(createListAdapter(), mInitialIndex, mListener);
|
builder.setSingleChoiceItems(createListAdapter(), getSelectedValuePos(), mListener);
|
||||||
mShowRemoteInput = getEntryValues().length == 3;
|
mShowRemoteInput = getEntryValues().length == 3;
|
||||||
mAllowRemoteInput = Settings.Secure.getInt(getContext().getContentResolver(),
|
mAllowRemoteInput = Settings.Secure.getInt(getContext().getContentResolver(),
|
||||||
Settings.Secure.LOCK_SCREEN_ALLOW_REMOTE_INPUT, 0) != 0;
|
Settings.Secure.LOCK_SCREEN_ALLOW_REMOTE_INPUT, 0) != 0;
|
||||||
@@ -86,8 +84,17 @@ public class NotificationLockscreenPreference extends RestrictedListPreference {
|
|||||||
CheckBox view = (CheckBox) dialog.findViewById(R.id.lockscreen_remote_input);
|
CheckBox view = (CheckBox) dialog.findViewById(R.id.lockscreen_remote_input);
|
||||||
view.setChecked(!mAllowRemoteInput);
|
view.setChecked(!mAllowRemoteInput);
|
||||||
view.setOnCheckedChangeListener(mListener);
|
view.setOnCheckedChangeListener(mListener);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onDialogStateRestored(Dialog dialog, Bundle savedInstanceState) {
|
||||||
|
super.onDialogStateRestored(dialog, savedInstanceState);
|
||||||
|
ListView listView = ((AlertDialog) dialog).getListView();
|
||||||
|
int selectedPosition = listView.getCheckedItemPosition();
|
||||||
|
|
||||||
View panel = dialog.findViewById(com.android.internal.R.id.customPanel);
|
View panel = dialog.findViewById(com.android.internal.R.id.customPanel);
|
||||||
panel.setVisibility(checkboxVisibilityForSelectedIndex(mInitialIndex, mShowRemoteInput));
|
panel.setVisibility(checkboxVisibilityForSelectedIndex(selectedPosition,
|
||||||
|
mShowRemoteInput));
|
||||||
mListener.setView(panel);
|
mListener.setView(panel);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user