private EditUserInfoController mEditUserInfoController = new EditUserInfoController();
private AddUserWhenLockedPreferenceController mAddUserWhenLockedPreferenceController;
- private AutoSyncDataPreferenceController mAutoSyncDataPreferenceController;
- private AutoSyncPersonalDataPreferenceController mAutoSyncPersonalDataPreferenceController;
- private AutoSyncWorkDataPreferenceController mAutoSyncWorkDataPreferenceController;
// A place to cache the generated default avatar
private Drawable mDefaultIconDrawable;
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
- case MESSAGE_UPDATE_LIST:
- updateUserList();
- break;
- case MESSAGE_SETUP_USER:
- onUserCreated(msg.arg1);
- break;
- case MESSAGE_CONFIG_USER:
- onManageUserClicked(msg.arg1, true);
- break;
+ case MESSAGE_UPDATE_LIST:
+ updateUserList();
+ break;
+ case MESSAGE_SETUP_USER:
+ onUserCreated(msg.arg1);
+ break;
+ case MESSAGE_CONFIG_USER:
+ onManageUserClicked(msg.arg1, true);
+ break;
}
}
};
final Context context = getActivity();
mAddUserWhenLockedPreferenceController = new AddUserWhenLockedPreferenceController(
context, KEY_ADD_USER_WHEN_LOCKED, getLifecycle());
- mAutoSyncDataPreferenceController = new AutoSyncDataPreferenceController(context, this);
- mAutoSyncPersonalDataPreferenceController =
- new AutoSyncPersonalDataPreferenceController(context, this);
- mAutoSyncWorkDataPreferenceController =
- new AutoSyncWorkDataPreferenceController(context, this);
-
final PreferenceScreen screen = getPreferenceScreen();
mAddUserWhenLockedPreferenceController.displayPreference(screen);
- mAutoSyncDataPreferenceController.displayPreference(screen);
- mAutoSyncPersonalDataPreferenceController.displayPreference(screen);
- mAutoSyncWorkDataPreferenceController.displayPreference(screen);
+
screen.findPreference(mAddUserWhenLockedPreferenceController.getPreferenceKey())
.setOnPreferenceChangeListener(mAddUserWhenLockedPreferenceController);
}
final PreferenceScreen screen = getPreferenceScreen();
- if (mAutoSyncDataPreferenceController.isAvailable()) {
- mAutoSyncDataPreferenceController.updateState(screen.findPreference(
- mAutoSyncDataPreferenceController.getPreferenceKey()));
- }
if (mAddUserWhenLockedPreferenceController.isAvailable()) {
mAddUserWhenLockedPreferenceController.updateState(screen.findPreference(
mAddUserWhenLockedPreferenceController.getPreferenceKey()));
}
- if (mAutoSyncPersonalDataPreferenceController.isAvailable()) {
- mAutoSyncPersonalDataPreferenceController.updateState(screen.findPreference(
- mAutoSyncPersonalDataPreferenceController.getPreferenceKey()));
- }
- if (mAutoSyncWorkDataPreferenceController.isAvailable()) {
- mAutoSyncWorkDataPreferenceController.updateState(screen.findPreference(
- mAutoSyncWorkDataPreferenceController.getPreferenceKey()));
- }
if (mShouldUpdateUserList) {
mUserCaps.updateAddUserCapabilities(getActivity());
}
@Override
- public boolean onPreferenceTreeClick(Preference preference) {
- if (mAutoSyncDataPreferenceController.handlePreferenceTreeClick(preference)) {
- return true;
- }
- if (mAutoSyncPersonalDataPreferenceController.handlePreferenceTreeClick(preference)) {
- return true;
- }
- if (mAutoSyncWorkDataPreferenceController.handlePreferenceTreeClick(preference)) {
- return true;
- }
- return super.onPreferenceTreeClick(preference);
- }
-
- @Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
int pos = 0;
UserManager um = getContext().getSystemService(UserManager.class);
synchronized (mUserLock) {
if (mRemovingUserId == -1 && !mAddingUser) {
switch (userType) {
- case USER_TYPE_USER:
- showDialog(DIALOG_ADD_USER);
- break;
- case USER_TYPE_RESTRICTED_PROFILE:
- if (hasLockscreenSecurity()) {
- addUserNow(USER_TYPE_RESTRICTED_PROFILE);
- } else {
- showDialog(DIALOG_NEED_LOCKSCREEN);
- }
- break;
+ case USER_TYPE_USER:
+ showDialog(DIALOG_ADD_USER);
+ break;
+ case USER_TYPE_RESTRICTED_PROFILE:
+ if (hasLockscreenSecurity()) {
+ addUserNow(USER_TYPE_RESTRICTED_PROFILE);
+ } else {
+ showDialog(DIALOG_NEED_LOCKSCREEN);
+ }
+ break;
}
}
}
}
case DIALOG_USER_CANNOT_MANAGE:
return new AlertDialog.Builder(context)
- .setMessage(R.string.user_cannot_manage_message)
- .setPositiveButton(android.R.string.ok, null)
- .create();
+ .setMessage(R.string.user_cannot_manage_message)
+ .setPositiveButton(android.R.string.ok, null)
+ .create();
case DIALOG_ADD_USER: {
final SharedPreferences preferences = getActivity().getPreferences(
Context.MODE_PRIVATE);
final int userType = dialogId == DIALOG_ADD_USER
? USER_TYPE_USER : USER_TYPE_RESTRICTED_PROFILE;
Dialog dlg = new AlertDialog.Builder(context)
- .setTitle(R.string.user_add_user_title)
- .setMessage(messageResId)
- .setPositiveButton(android.R.string.ok,
- new DialogInterface.OnClickListener() {
- public void onClick(DialogInterface dialog, int which) {
- addUserNow(userType);
- if (!longMessageDisplayed) {
- preferences.edit().putBoolean(
- KEY_ADD_USER_LONG_MESSAGE_DISPLAYED, true).apply();
- }
- }
- })
- .setNegativeButton(android.R.string.cancel, null)
- .create();
+ .setTitle(R.string.user_add_user_title)
+ .setMessage(messageResId)
+ .setPositiveButton(android.R.string.ok,
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ addUserNow(userType);
+ if (!longMessageDisplayed) {
+ preferences.edit().putBoolean(
+ KEY_ADD_USER_LONG_MESSAGE_DISPLAYED,
+ true).apply();
+ }
+ }
+ })
+ .setNegativeButton(android.R.string.cancel, null)
+ .create();
return dlg;
}
case DIALOG_SETUP_USER: {
Dialog dlg = new AlertDialog.Builder(context)
- .setTitle(R.string.user_setup_dialog_title)
- .setMessage(R.string.user_setup_dialog_message)
- .setPositiveButton(R.string.user_setup_button_setup_now,
- new DialogInterface.OnClickListener() {
- public void onClick(DialogInterface dialog, int which) {
- switchUserNow(mAddedUserId);
- }
- })
- .setNegativeButton(R.string.user_setup_button_setup_later, null)
- .create();
+ .setTitle(R.string.user_setup_dialog_title)
+ .setMessage(R.string.user_setup_dialog_message)
+ .setPositiveButton(R.string.user_setup_button_setup_now,
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ switchUserNow(mAddedUserId);
+ }
+ })
+ .setNegativeButton(R.string.user_setup_button_setup_later, null)
+ .create();
return dlg;
}
case DIALOG_SETUP_PROFILE: {
Dialog dlg = new AlertDialog.Builder(context)
- .setMessage(R.string.user_setup_profile_dialog_message)
- .setPositiveButton(android.R.string.ok,
- new DialogInterface.OnClickListener() {
- public void onClick(DialogInterface dialog, int which) {
- switchUserNow(mAddedUserId);
- }
- })
- .setNegativeButton(android.R.string.cancel, null)
- .create();
+ .setMessage(R.string.user_setup_profile_dialog_message)
+ .setPositiveButton(android.R.string.ok,
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ switchUserNow(mAddedUserId);
+ }
+ })
+ .setNegativeButton(android.R.string.cancel, null)
+ .create();
return dlg;
}
case DIALOG_CHOOSE_USER_TYPE: {
- List<HashMap<String, String>> data = new ArrayList<HashMap<String,String>>();
- HashMap<String,String> addUserItem = new HashMap<String,String>();
+ List<HashMap<String, String>> data = new ArrayList<HashMap<String, String>>();
+ HashMap<String, String> addUserItem = new HashMap<String, String>();
addUserItem.put(KEY_TITLE, getString(R.string.user_add_user_item_title));
addUserItem.put(KEY_SUMMARY, getString(R.string.user_add_user_item_summary));
- HashMap<String,String> addProfileItem = new HashMap<String,String>();
+ HashMap<String, String> addProfileItem = new HashMap<String, String>();
addProfileItem.put(KEY_TITLE, getString(R.string.user_add_profile_item_title));
addProfileItem.put(KEY_SUMMARY, getString(R.string.user_add_profile_item_summary));
data.add(addUserItem);
// Add a virtual Guest user for guest defaults
UserPreference pref = new UserPreference(getPrefContext(), null,
UserPreference.USERID_GUEST_DEFAULTS,
- mUserCaps.mIsAdmin && voiceCapable? this : null /* settings icon handler */,
+ mUserCaps.mIsAdmin && voiceCapable ? this : null /* settings icon handler */,
null /* delete icon handler */);
pref.setTitle(R.string.user_guest);
pref.setIcon(getEncircledDefaultIcon());
if (v.getTag() instanceof UserPreference) {
int userId = ((UserPreference) v.getTag()).getUserId();
switch (v.getId()) {
- case UserPreference.DELETE_ID:
- final EnforcedAdmin removeDisallowedAdmin =
- RestrictedLockUtils.checkIfRestrictionEnforced(getContext(),
- UserManager.DISALLOW_REMOVE_USER, UserHandle.myUserId());
- if (removeDisallowedAdmin != null) {
- RestrictedLockUtils.sendShowAdminSupportDetailsIntent(getContext(),
- removeDisallowedAdmin);
- } else {
- onRemoveUserClicked(userId);
- }
- break;
- case UserPreference.SETTINGS_ID:
- onManageUserClicked(userId, false);
- break;
+ case UserPreference.DELETE_ID:
+ final EnforcedAdmin removeDisallowedAdmin =
+ RestrictedLockUtils.checkIfRestrictionEnforced(getContext(),
+ UserManager.DISALLOW_REMOVE_USER, UserHandle.myUserId());
+ if (removeDisallowedAdmin != null) {
+ RestrictedLockUtils.sendShowAdminSupportDetailsIntent(getContext(),
+ removeDisallowedAdmin);
+ } else {
+ onRemoveUserClicked(userId);
+ }
+ break;
+ case UserPreference.SETTINGS_ID:
+ onManageUserClicked(userId, false);
+ break;
}
}
}
* Returns a default user icon (as a {@link Bitmap}) for the given user.
*
* Note that for guest users, you should pass in {@code UserHandle.USER_NULL}.
+ *
* @param resources resources object to fetch the user icon.
- * @param userId the user id or {@code UserHandle.USER_NULL} for a non-user specific icon
+ * @param userId the user id or {@code UserHandle.USER_NULL} for a non-user specific icon
*/
private static Bitmap getDefaultUserIconAsBitmap(Resources resources, int userId) {
Bitmap bitmap = null;
/**
* Assign the default photo to user with {@paramref userId}
+ *
* @param context used to get the {@link UserManager}
* @param userId used to get the icon bitmap
* @return true if assign photo successfully, false if failed
um.setUserIcon(userId, icon);
try {
avatarDataStream.close();
- } catch (IOException ioe) { }
+ } catch (IOException ioe) {
+ }
}
private static class SummaryProvider implements SummaryLoader.SummaryProvider {
public void setListening(boolean listening) {
if (listening) {
UserInfo info = mContext.getSystemService(UserManager.class).getUserInfo(
- UserHandle.myUserId());
+ UserHandle.myUserId());
mSummaryLoader.setSummary(this, mContext.getString(R.string.users_summary,
- info.name));
+ info.name));
}
}
}