Add setting to allow RemoteInput on keyguard
Bug: 26440855 Change-Id: I57e02876c615f558eee279f2dc7edca8b28fc495
This commit is contained in:
35
res/layout/lockscreen_remote_input.xml
Normal file
35
res/layout/lockscreen_remote_input.xml
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright (C) 2016 The Android Open Source Project
|
||||||
|
~
|
||||||
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
~ you may not use this file except in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing, software
|
||||||
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
~ See the License for the specific language governing permissions and
|
||||||
|
~ limitations under the License
|
||||||
|
-->
|
||||||
|
|
||||||
|
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
<CheckBox
|
||||||
|
android:id="@+id/lockscreen_remote_input"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginStart="20dp"
|
||||||
|
android:paddingStart="20dp"
|
||||||
|
android:paddingEnd="?android:attr/dialogPreferredPadding"
|
||||||
|
android:minHeight="?android:attr/listPreferredItemHeightSmall"
|
||||||
|
android:textAppearance="?android:attr/textAppearanceMedium"
|
||||||
|
android:textColor="?android:attr/textColorAlertDialogListItem"
|
||||||
|
android:gravity="center_vertical"
|
||||||
|
android:text="@string/lockscreen_remote_input"
|
||||||
|
/>
|
||||||
|
</FrameLayout>
|
@@ -15,7 +15,8 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<com.android.settings.CheckableLinearLayout
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:orientation="horizontal"
|
android:orientation="horizontal"
|
||||||
@@ -41,4 +42,4 @@
|
|||||||
android:baselineAlignBottom="true"
|
android:baselineAlignBottom="true"
|
||||||
android:scaleType="centerInside"
|
android:scaleType="centerInside"
|
||||||
android:visibility="gone" />
|
android:visibility="gone" />
|
||||||
</LinearLayout>
|
</com.android.settings.CheckableLinearLayout>
|
@@ -5912,7 +5912,7 @@
|
|||||||
<string name="notification_pulse_title">Pulse notification light</string>
|
<string name="notification_pulse_title">Pulse notification light</string>
|
||||||
|
|
||||||
<!-- Configure Notifications: Title for the option controlling notifications on the lockscreen. [CHAR LIMIT=30] -->
|
<!-- Configure Notifications: Title for the option controlling notifications on the lockscreen. [CHAR LIMIT=30] -->
|
||||||
<string name="lock_screen_notifications_title">When device is locked</string>
|
<string name="lock_screen_notifications_title">On the lock screen</string>
|
||||||
|
|
||||||
<!-- Configure Notifications: Value for lockscreen notifications: all information will be
|
<!-- Configure Notifications: Value for lockscreen notifications: all information will be
|
||||||
shown in notifications shown on a secure lock screen
|
shown in notifications shown on a secure lock screen
|
||||||
@@ -7221,6 +7221,9 @@
|
|||||||
<!-- [CHAR_LIMIT=NONE] Label for when app is ignoring battery optimizations -->
|
<!-- [CHAR_LIMIT=NONE] Label for when app is ignoring battery optimizations -->
|
||||||
<string name="not_battery_optimizing">Not using battery optimization</string>
|
<string name="not_battery_optimizing">Not using battery optimization</string>
|
||||||
|
|
||||||
|
<!-- Text for the setting on whether you can type text into notifications without unlocking the device. -->
|
||||||
|
<string name="lockscreen_remote_input">If device is locked, prevent typing replies or other text in notifications</string>
|
||||||
|
|
||||||
<string-array name="bytes_picker_sizes" translatable="false">
|
<string-array name="bytes_picker_sizes" translatable="false">
|
||||||
<item>@*android:string/megabyteShort</item>
|
<item>@*android:string/megabyteShort</item>
|
||||||
<item>@*android:string/gigabyteShort</item>
|
<item>@*android:string/gigabyteShort</item>
|
||||||
|
@@ -25,7 +25,7 @@
|
|||||||
android:title="@string/notification_pulse_title" />
|
android:title="@string/notification_pulse_title" />
|
||||||
|
|
||||||
<!-- When device is locked -->
|
<!-- When device is locked -->
|
||||||
<com.android.settingslib.RestrictedDropDownPreference
|
<com.android.settings.notification.NotificationLockscreenPreference
|
||||||
android:key="lock_screen_notifications"
|
android:key="lock_screen_notifications"
|
||||||
android:title="@string/lock_screen_notifications_title"
|
android:title="@string/lock_screen_notifications_title"
|
||||||
android:summary="%s" />
|
android:summary="%s" />
|
||||||
|
@@ -17,12 +17,14 @@
|
|||||||
package com.android.settings;
|
package com.android.settings;
|
||||||
|
|
||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
|
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.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 {
|
||||||
|
|
||||||
@@ -42,6 +44,13 @@ public class CustomListPreference extends ListPreference {
|
|||||||
protected void onDialogClosed(boolean positiveResult) {
|
protected void onDialogClosed(boolean positiveResult) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void onDialogCreated(Dialog dialog) {
|
||||||
|
}
|
||||||
|
|
||||||
|
protected boolean isAutoClosePreference() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
public static class CustomListPreferenceDialogFragment extends ListPreferenceDialogFragment {
|
public static class CustomListPreferenceDialogFragment extends ListPreferenceDialogFragment {
|
||||||
|
|
||||||
private int mClickedDialogEntryIndex;
|
private int mClickedDialogEntryIndex;
|
||||||
@@ -64,6 +73,23 @@ public class CustomListPreference extends ListPreference {
|
|||||||
mClickedDialogEntryIndex = getCustomizablePreference()
|
mClickedDialogEntryIndex = getCustomizablePreference()
|
||||||
.findIndexOfValue(getCustomizablePreference().getValue());
|
.findIndexOfValue(getCustomizablePreference().getValue());
|
||||||
getCustomizablePreference().onPrepareDialogBuilder(builder, getOnItemClickListener());
|
getCustomizablePreference().onPrepareDialogBuilder(builder, getOnItemClickListener());
|
||||||
|
if (!getCustomizablePreference().isAutoClosePreference()) {
|
||||||
|
builder.setPositiveButton(R.string.okay, new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
CustomListPreferenceDialogFragment.this.onClick(dialog,
|
||||||
|
DialogInterface.BUTTON_POSITIVE);
|
||||||
|
dialog.dismiss();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
||||||
|
Dialog dialog = super.onCreateDialog(savedInstanceState);
|
||||||
|
getCustomizablePreference().onDialogCreated(dialog);
|
||||||
|
return dialog;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected DialogInterface.OnClickListener getOnItemClickListener() {
|
protected DialogInterface.OnClickListener getOnItemClickListener() {
|
||||||
@@ -71,6 +97,8 @@ public class CustomListPreference extends ListPreference {
|
|||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
setClickedDialogEntryIndex(which);
|
setClickedDialogEntryIndex(which);
|
||||||
|
|
||||||
|
|
||||||
|
if (getCustomizablePreference().isAutoClosePreference()) {
|
||||||
/*
|
/*
|
||||||
* Clicking on an item simulates the positive button
|
* Clicking on an item simulates the positive button
|
||||||
* click, and dismisses the dialog.
|
* click, and dismisses the dialog.
|
||||||
@@ -79,6 +107,7 @@ public class CustomListPreference extends ListPreference {
|
|||||||
DialogInterface.BUTTON_POSITIVE);
|
DialogInterface.BUTTON_POSITIVE);
|
||||||
dialog.dismiss();
|
dialog.dismiss();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -149,8 +149,12 @@ public class RestrictedListPreference extends CustomListPreference {
|
|||||||
text.setChecked(false);
|
text.setChecked(false);
|
||||||
padlock.setVisibility(View.VISIBLE);
|
padlock.setVisibility(View.VISIBLE);
|
||||||
} else {
|
} else {
|
||||||
|
if (mSelectedIndex != -1) {
|
||||||
text.setChecked(position == mSelectedIndex);
|
text.setChecked(position == mSelectedIndex);
|
||||||
|
}
|
||||||
|
if (!text.isEnabled()) {
|
||||||
text.setEnabled(true);
|
text.setEnabled(true);
|
||||||
|
}
|
||||||
padlock.setVisibility(View.GONE);
|
padlock.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
return root;
|
return root;
|
||||||
@@ -199,6 +203,7 @@ public class RestrictedListPreference extends CustomListPreference {
|
|||||||
setClickedDialogEntryIndex(which);
|
setClickedDialogEntryIndex(which);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (getCustomizablePreference().isAutoClosePreference()) {
|
||||||
/*
|
/*
|
||||||
* Clicking on an item simulates the positive button
|
* Clicking on an item simulates the positive button
|
||||||
* click, and dismisses the dialog.
|
* click, and dismisses the dialog.
|
||||||
@@ -207,6 +212,7 @@ public class RestrictedListPreference extends CustomListPreference {
|
|||||||
DialogInterface.BUTTON_POSITIVE);
|
DialogInterface.BUTTON_POSITIVE);
|
||||||
dialog.dismiss();
|
dialog.dismiss();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -32,13 +32,11 @@ import android.util.Log;
|
|||||||
import com.android.internal.widget.LockPatternUtils;
|
import com.android.internal.widget.LockPatternUtils;
|
||||||
import com.android.settings.InstrumentedFragment;
|
import com.android.settings.InstrumentedFragment;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.RestrictedListPreference.RestrictedItem;
|
||||||
import com.android.settings.SettingsPreferenceFragment;
|
import com.android.settings.SettingsPreferenceFragment;
|
||||||
import com.android.settingslib.RestrictedDropDownPreference;
|
|
||||||
import com.android.settingslib.RestrictedDropDownPreference.RestrictedItem;
|
|
||||||
import com.android.settingslib.RestrictedLockUtils;
|
import com.android.settingslib.RestrictedLockUtils;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import static android.app.admin.DevicePolicyManager.KEYGUARD_DISABLE_SECURE_NOTIFICATIONS;
|
import static android.app.admin.DevicePolicyManager.KEYGUARD_DISABLE_SECURE_NOTIFICATIONS;
|
||||||
import static android.app.admin.DevicePolicyManager.KEYGUARD_DISABLE_UNREDACTED_NOTIFICATIONS;
|
import static android.app.admin.DevicePolicyManager.KEYGUARD_DISABLE_UNREDACTED_NOTIFICATIONS;
|
||||||
@@ -56,7 +54,7 @@ public class ConfigureNotificationSettings extends SettingsPreferenceFragment {
|
|||||||
private Context mContext;
|
private Context mContext;
|
||||||
|
|
||||||
private TwoStatePreference mNotificationPulse;
|
private TwoStatePreference mNotificationPulse;
|
||||||
private RestrictedDropDownPreference mLockscreen;
|
private NotificationLockscreenPreference mLockscreen;
|
||||||
private boolean mSecure;
|
private boolean mSecure;
|
||||||
private int mLockscreenSelectedValue;
|
private int mLockscreenSelectedValue;
|
||||||
|
|
||||||
@@ -131,7 +129,7 @@ public class ConfigureNotificationSettings extends SettingsPreferenceFragment {
|
|||||||
// === Lockscreen (public / private) notifications ===
|
// === Lockscreen (public / private) notifications ===
|
||||||
|
|
||||||
private void initLockscreenNotifications() {
|
private void initLockscreenNotifications() {
|
||||||
mLockscreen = (RestrictedDropDownPreference) getPreferenceScreen().findPreference(
|
mLockscreen = (NotificationLockscreenPreference) getPreferenceScreen().findPreference(
|
||||||
KEY_LOCK_SCREEN_NOTIFICATIONS);
|
KEY_LOCK_SCREEN_NOTIFICATIONS);
|
||||||
if (mLockscreen == null) {
|
if (mLockscreen == null) {
|
||||||
Log.i(TAG, "Preference not found: " + KEY_LOCK_SCREEN_NOTIFICATIONS);
|
Log.i(TAG, "Preference not found: " + KEY_LOCK_SCREEN_NOTIFICATIONS);
|
||||||
|
@@ -0,0 +1,118 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2016 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.notification;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.RestrictedListPreference;
|
||||||
|
|
||||||
|
import android.app.AlertDialog;
|
||||||
|
import android.app.Dialog;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
|
import android.provider.Settings;
|
||||||
|
import android.util.AttributeSet;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.CheckBox;
|
||||||
|
import android.widget.CompoundButton;
|
||||||
|
import android.widget.ListAdapter;
|
||||||
|
|
||||||
|
public class NotificationLockscreenPreference extends RestrictedListPreference {
|
||||||
|
|
||||||
|
private boolean mAllowRemoteInput;
|
||||||
|
private int mInitialIndex;
|
||||||
|
private Listener mListener;
|
||||||
|
private boolean mShowRemoteInput;
|
||||||
|
|
||||||
|
public NotificationLockscreenPreference(Context context, AttributeSet attrs) {
|
||||||
|
super(context, attrs);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onPrepareDialogBuilder(AlertDialog.Builder builder,
|
||||||
|
DialogInterface.OnClickListener innerListener) {
|
||||||
|
|
||||||
|
final String selectedValue = getValue();
|
||||||
|
mInitialIndex = (selectedValue == null) ? -1 : findIndexOfValue(selectedValue);
|
||||||
|
mListener = new Listener(innerListener);
|
||||||
|
builder.setSingleChoiceItems(createListAdapter(), mInitialIndex, mListener);
|
||||||
|
mShowRemoteInput = getEntryValues().length == 3;
|
||||||
|
mAllowRemoteInput = Settings.Secure.getInt(getContext().getContentResolver(),
|
||||||
|
Settings.Secure.LOCK_SCREEN_ALLOW_REMOTE_INPUT, 0) != 0;
|
||||||
|
builder.setView(R.layout.lockscreen_remote_input);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onDialogCreated(Dialog dialog) {
|
||||||
|
super.onDialogCreated(dialog);
|
||||||
|
dialog.create();
|
||||||
|
CheckBox view = (CheckBox) dialog.findViewById(R.id.lockscreen_remote_input);
|
||||||
|
view.setChecked(mAllowRemoteInput);
|
||||||
|
view.setOnCheckedChangeListener(mListener);
|
||||||
|
View panel = dialog.findViewById(com.android.internal.R.id.customPanel);
|
||||||
|
panel.setVisibility(checkboxVisibilityForSelectedIndex(mInitialIndex, mShowRemoteInput));
|
||||||
|
mListener.setView(panel);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected ListAdapter createListAdapter() {
|
||||||
|
return new RestrictedArrayAdapter(getContext(), getEntries(), -1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onDialogClosed(boolean positiveResult) {
|
||||||
|
super.onDialogClosed(positiveResult);
|
||||||
|
Settings.Secure.putInt(getContext().getContentResolver(),
|
||||||
|
Settings.Secure.LOCK_SCREEN_ALLOW_REMOTE_INPUT, mAllowRemoteInput ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean isAutoClosePreference() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static int checkboxVisibilityForSelectedIndex(int selected, boolean showRemoteAtAll) {
|
||||||
|
return selected == 0 && showRemoteAtAll ? View.VISIBLE : View.GONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
private class Listener implements DialogInterface.OnClickListener,
|
||||||
|
CompoundButton.OnCheckedChangeListener {
|
||||||
|
|
||||||
|
private final DialogInterface.OnClickListener mInner;
|
||||||
|
private View mView;
|
||||||
|
|
||||||
|
public Listener(DialogInterface.OnClickListener inner) {
|
||||||
|
mInner = inner;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
mInner.onClick(dialog, which);
|
||||||
|
if (mView != null) {
|
||||||
|
mView.setVisibility(checkboxVisibilityForSelectedIndex(which, mShowRemoteInput));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
|
||||||
|
mAllowRemoteInput = isChecked;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setView(View view) {
|
||||||
|
mView = view;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user