summaryrefslogtreecommitdiffstats
path: root/src/com/android/settings/users/UserPreference.java
diff options
context:
space:
mode:
authorAmith Yamasani <yamasani@google.com>2013-03-01 17:05:23 -0800
committerAmith Yamasani <yamasani@google.com>2013-03-20 22:23:45 -0700
commit233592bb43c02e88d39d990fadc59fd330a4d3dd (patch)
tree9543b26bbc9af6bc70a7b18131cbfc0bd0137127 /src/com/android/settings/users/UserPreference.java
parent9f5b49192d281eb24cbe4e12d989857e9e195b03 (diff)
downloadpackages_apps_Settings-233592bb43c02e88d39d990fadc59fd330a4d3dd.zip
packages_apps_Settings-233592bb43c02e88d39d990fadc59fd330a4d3dd.tar.gz
packages_apps_Settings-233592bb43c02e88d39d990fadc59fd330a4d3dd.tar.bz2
Application restrictions UI
Refactored User Settings UI to have two types of users. Display a list of apps to select. Edit user restrictions. Handle saving and updating RestrictionEntry items via User Manager. Change-Id: I3ad5aa71d5ef66dffd39e17ba0556f075ac10a0f
Diffstat (limited to 'src/com/android/settings/users/UserPreference.java')
-rw-r--r--src/com/android/settings/users/UserPreference.java29
1 files changed, 25 insertions, 4 deletions
diff --git a/src/com/android/settings/users/UserPreference.java b/src/com/android/settings/users/UserPreference.java
index 23cca73..6889747 100644
--- a/src/com/android/settings/users/UserPreference.java
+++ b/src/com/android/settings/users/UserPreference.java
@@ -20,6 +20,7 @@ import com.android.internal.util.CharSequences;
import com.android.settings.R;
import android.content.Context;
+import android.os.UserHandle;
import android.os.UserManager;
import android.preference.Preference;
import android.util.AttributeSet;
@@ -31,21 +32,32 @@ public class UserPreference extends Preference {
public static final int USERID_UNKNOWN = -10;
private OnClickListener mDeleteClickListener;
+ private OnClickListener mSettingsClickListener;
private int mSerialNumber = -1;
private int mUserId = USERID_UNKNOWN;
+ private boolean mRestricted;
+ static final int SETTINGS_ID = R.id.manage_user;
+ static final int DELETE_ID = R.id.trash_user;
public UserPreference(Context context, AttributeSet attrs) {
- this(context, attrs, USERID_UNKNOWN, false, null);
+ this(context, attrs, USERID_UNKNOWN, false, null, null);
}
- UserPreference(Context context, AttributeSet attrs, int userId, boolean showDelete,
- OnClickListener deleteListener) {
+ UserPreference(Context context, AttributeSet attrs, int userId,
+ boolean showOptions, OnClickListener deleteListener,
+ OnClickListener settingsListener) {
super(context, attrs);
- if (showDelete) {
+ if (showOptions) {
setWidgetLayoutResource(R.layout.preference_user_delete_widget);
mDeleteClickListener = deleteListener;
+ mSettingsClickListener = settingsListener;
}
mUserId = userId;
+ if (mUserId > UserHandle.USER_OWNER) {
+ mRestricted = ((UserManager) getContext().getSystemService(Context.USER_SERVICE))
+ .getUserInfo(mUserId).isRestricted();
+ }
+ setSummary(mRestricted ? R.string.user_limited : R.string.user_trusted);
}
@Override
@@ -55,6 +67,15 @@ public class UserPreference extends Preference {
deleteView.setOnClickListener(mDeleteClickListener);
deleteView.setTag(this);
}
+ View settingsView = view.findViewById(R.id.manage_user);
+ if (settingsView != null) {
+ if (mRestricted) {
+ settingsView.setOnClickListener(mSettingsClickListener);
+ settingsView.setTag(this);
+ } else {
+ settingsView.setVisibility(View.INVISIBLE);
+ }
+ }
super.onBindView(view);
}