Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2018 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License |
| 15 | */ |
| 16 | |
| 17 | package com.android.systemui.statusbar.car; |
| 18 | |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 19 | import static android.content.DialogInterface.BUTTON_NEGATIVE; |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 20 | import static android.content.DialogInterface.BUTTON_POSITIVE; |
| 21 | |
| 22 | import android.app.AlertDialog; |
| 23 | import android.app.AlertDialog.Builder; |
| 24 | import android.app.Dialog; |
Ying Zheng | ad2773f | 2018-09-14 10:31:07 -0700 | [diff] [blame] | 25 | import android.car.userlib.CarUserManagerHelper; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 26 | import android.content.Context; |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 27 | import android.content.DialogInterface; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 28 | import android.content.pm.UserInfo; |
| 29 | import android.content.res.Resources; |
jovanak | e4ce3cc | 2018-04-19 12:17:12 -0700 | [diff] [blame] | 30 | import android.graphics.Bitmap; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 31 | import android.os.AsyncTask; |
jovanak | e4ce3cc | 2018-04-19 12:17:12 -0700 | [diff] [blame] | 32 | import android.os.UserHandle; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 33 | import android.util.AttributeSet; |
| 34 | import android.view.LayoutInflater; |
| 35 | import android.view.View; |
| 36 | import android.view.ViewGroup; |
| 37 | import android.widget.ImageView; |
| 38 | import android.widget.TextView; |
| 39 | |
Aarthi Balachander | 608b6e3 | 2018-04-11 18:41:52 -0700 | [diff] [blame] | 40 | import androidx.car.widget.PagedListView; |
Aarthi Balachander | e3110e4 | 2018-04-30 18:16:26 -0700 | [diff] [blame] | 41 | import androidx.core.graphics.drawable.RoundedBitmapDrawable; |
| 42 | import androidx.core.graphics.drawable.RoundedBitmapDrawableFactory; |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 43 | import androidx.recyclerview.widget.RecyclerView; |
| 44 | |
jovanak | e4ce3cc | 2018-04-19 12:17:12 -0700 | [diff] [blame] | 45 | import com.android.internal.util.UserIcons; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 46 | import com.android.systemui.R; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 47 | |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 48 | import com.android.systemui.statusbar.phone.SystemUIDialog; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 49 | import java.util.ArrayList; |
| 50 | import java.util.List; |
| 51 | |
| 52 | /** |
| 53 | * Displays a GridLayout with icons for the users in the system to allow switching between users. |
| 54 | * One of the uses of this is for the lock screen in auto. |
| 55 | */ |
Aarthi Balachander | 608b6e3 | 2018-04-11 18:41:52 -0700 | [diff] [blame] | 56 | public class UserGridRecyclerView extends PagedListView implements |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 57 | CarUserManagerHelper.OnUsersUpdateListener { |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 58 | private UserSelectionListener mUserSelectionListener; |
| 59 | private UserAdapter mAdapter; |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 60 | private CarUserManagerHelper mCarUserManagerHelper; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 61 | private Context mContext; |
| 62 | |
| 63 | public UserGridRecyclerView(Context context, AttributeSet attrs) { |
| 64 | super(context, attrs); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 65 | mContext = context; |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 66 | mCarUserManagerHelper = new CarUserManagerHelper(mContext); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 67 | } |
| 68 | |
| 69 | /** |
| 70 | * Register listener for any update to the users |
| 71 | */ |
| 72 | @Override |
| 73 | public void onFinishInflate() { |
Aarthi Balachander | 608b6e3 | 2018-04-11 18:41:52 -0700 | [diff] [blame] | 74 | super.onFinishInflate(); |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 75 | mCarUserManagerHelper.registerOnUsersUpdateListener(this); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 76 | } |
| 77 | |
| 78 | /** |
| 79 | * Unregisters listener checking for any change to the users |
| 80 | */ |
| 81 | @Override |
| 82 | public void onDetachedFromWindow() { |
Aarthi Balachander | 608b6e3 | 2018-04-11 18:41:52 -0700 | [diff] [blame] | 83 | super.onDetachedFromWindow(); |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 84 | mCarUserManagerHelper.unregisterOnUsersUpdateListener(this); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 85 | } |
| 86 | |
| 87 | /** |
| 88 | * Initializes the adapter that populates the grid layout |
| 89 | * |
| 90 | * @return the adapter |
| 91 | */ |
| 92 | public void buildAdapter() { |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 93 | List<UserRecord> userRecords = createUserRecords(mCarUserManagerHelper |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 94 | .getAllUsers()); |
| 95 | mAdapter = new UserAdapter(mContext, userRecords); |
| 96 | super.setAdapter(mAdapter); |
| 97 | } |
| 98 | |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 99 | private List<UserRecord> createUserRecords(List<UserInfo> userInfoList) { |
| 100 | List<UserRecord> userRecords = new ArrayList<>(); |
jovanak | 2baf8d6 | 2018-08-09 12:59:50 -0700 | [diff] [blame] | 101 | |
| 102 | // If the foreground user CANNOT switch to other users, only display the foreground user. |
| 103 | if (!mCarUserManagerHelper.canForegroundUserSwitchUsers()) { |
| 104 | userRecords.add(createForegroundUserRecord()); |
| 105 | return userRecords; |
| 106 | } |
| 107 | |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 108 | for (UserInfo userInfo : userInfoList) { |
jovanak | 80b4859 | 2018-04-11 17:09:53 -0700 | [diff] [blame] | 109 | if (userInfo.isGuest()) { |
| 110 | // Don't display guests in the switcher. |
| 111 | continue; |
| 112 | } |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 113 | |
| 114 | boolean isForeground = |
| 115 | mCarUserManagerHelper.getCurrentForegroundUserId() == userInfo.id; |
jovanak | 80b4859 | 2018-04-11 17:09:53 -0700 | [diff] [blame] | 116 | UserRecord record = new UserRecord(userInfo, false /* isStartGuestSession */, |
jovanak | 0535abc | 2018-04-10 15:14:50 -0700 | [diff] [blame] | 117 | false /* isAddUser */, isForeground); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 118 | userRecords.add(record); |
| 119 | } |
| 120 | |
jovanak | 2d26ae3 | 2018-07-31 10:44:41 -0700 | [diff] [blame] | 121 | // Add button for starting guest session. |
| 122 | userRecords.add(createStartGuestUserRecord()); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 123 | |
jovanak | 0535abc | 2018-04-10 15:14:50 -0700 | [diff] [blame] | 124 | // Add add user record if the foreground user can add users |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 125 | if (mCarUserManagerHelper.canForegroundUserAddUsers()) { |
jovanak | 2d26ae3 | 2018-07-31 10:44:41 -0700 | [diff] [blame] | 126 | userRecords.add(createAddUserRecord()); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 127 | } |
| 128 | |
| 129 | return userRecords; |
| 130 | } |
| 131 | |
jovanak | 2baf8d6 | 2018-08-09 12:59:50 -0700 | [diff] [blame] | 132 | private UserRecord createForegroundUserRecord() { |
| 133 | return new UserRecord(mCarUserManagerHelper.getCurrentForegroundUserInfo(), |
| 134 | false /* isStartGuestSession */, false /* isAddUser */, true /* isForeground */); |
| 135 | } |
| 136 | |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 137 | /** |
| 138 | * Create guest user record |
| 139 | */ |
jovanak | 2d26ae3 | 2018-07-31 10:44:41 -0700 | [diff] [blame] | 140 | private UserRecord createStartGuestUserRecord() { |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 141 | UserInfo userInfo = new UserInfo(); |
jovanak | 2d26ae3 | 2018-07-31 10:44:41 -0700 | [diff] [blame] | 142 | userInfo.name = mContext.getString(R.string.start_guest_session); |
| 143 | return new UserRecord(userInfo, true /* isStartGuestSession */, false /* isAddUser */, |
| 144 | false /* isForeground */); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 145 | } |
| 146 | |
| 147 | /** |
| 148 | * Create add user record |
| 149 | */ |
jovanak | 2d26ae3 | 2018-07-31 10:44:41 -0700 | [diff] [blame] | 150 | private UserRecord createAddUserRecord() { |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 151 | UserInfo userInfo = new UserInfo(); |
| 152 | userInfo.name = mContext.getString(R.string.car_add_user); |
jovanak | 80b4859 | 2018-04-11 17:09:53 -0700 | [diff] [blame] | 153 | return new UserRecord(userInfo, false /* isStartGuestSession */, |
jovanak | 0535abc | 2018-04-10 15:14:50 -0700 | [diff] [blame] | 154 | true /* isAddUser */, false /* isForeground */); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 155 | } |
| 156 | |
| 157 | public void setUserSelectionListener(UserSelectionListener userSelectionListener) { |
| 158 | mUserSelectionListener = userSelectionListener; |
| 159 | } |
| 160 | |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 161 | @Override |
| 162 | public void onUsersUpdate() { |
| 163 | mAdapter.clearUsers(); |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 164 | mAdapter.updateUsers(createUserRecords(mCarUserManagerHelper.getAllUsers())); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 165 | mAdapter.notifyDataSetChanged(); |
| 166 | } |
| 167 | |
| 168 | /** |
| 169 | * Adapter to populate the grid layout with the available user profiles |
| 170 | */ |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 171 | public final class UserAdapter extends RecyclerView.Adapter<UserAdapter.UserAdapterViewHolder> |
Aarthi Balachander | c6d1366 | 2018-08-13 14:49:41 -0700 | [diff] [blame] | 172 | implements Dialog.OnClickListener, Dialog.OnCancelListener { |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 173 | |
| 174 | private final Context mContext; |
| 175 | private List<UserRecord> mUsers; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 176 | private final Resources mRes; |
| 177 | private final String mGuestName; |
| 178 | private final String mNewUserName; |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 179 | // View that holds the add user button. Used to enable/disable the view |
| 180 | private View mAddUserView; |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 181 | // User record for the add user. Need to call notifyUserSelected only if the user |
| 182 | // confirms adding a user |
| 183 | private UserRecord mAddUserRecord; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 184 | |
| 185 | public UserAdapter(Context context, List<UserRecord> users) { |
| 186 | mRes = context.getResources(); |
| 187 | mContext = context; |
| 188 | updateUsers(users); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 189 | mGuestName = mRes.getString(R.string.car_guest); |
| 190 | mNewUserName = mRes.getString(R.string.car_new_user); |
| 191 | } |
| 192 | |
| 193 | public void clearUsers() { |
| 194 | mUsers.clear(); |
| 195 | } |
| 196 | |
| 197 | public void updateUsers(List<UserRecord> users) { |
| 198 | mUsers = users; |
| 199 | } |
| 200 | |
| 201 | @Override |
| 202 | public UserAdapterViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { |
| 203 | View view = LayoutInflater.from(mContext) |
| 204 | .inflate(R.layout.car_fullscreen_user_pod, parent, false); |
| 205 | view.setAlpha(1f); |
| 206 | view.bringToFront(); |
| 207 | return new UserAdapterViewHolder(view); |
| 208 | } |
| 209 | |
| 210 | @Override |
| 211 | public void onBindViewHolder(UserAdapterViewHolder holder, int position) { |
| 212 | UserRecord userRecord = mUsers.get(position); |
Aarthi Balachander | e3110e4 | 2018-04-30 18:16:26 -0700 | [diff] [blame] | 213 | RoundedBitmapDrawable circleIcon = RoundedBitmapDrawableFactory.create(mRes, |
| 214 | getUserRecordIcon(userRecord)); |
| 215 | circleIcon.setCircular(true); |
| 216 | holder.mUserAvatarImageView.setImageDrawable(circleIcon); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 217 | holder.mUserNameTextView.setText(userRecord.mInfo.name); |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 218 | |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 219 | holder.mView.setOnClickListener(v -> { |
| 220 | if (userRecord == null) { |
| 221 | return; |
| 222 | } |
| 223 | |
jovanak | 80b4859 | 2018-04-11 17:09:53 -0700 | [diff] [blame] | 224 | if (userRecord.mIsStartGuestSession) { |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 225 | notifyUserSelected(userRecord); |
jovanak | 2469ca7 | 2018-09-19 16:30:04 -0700 | [diff] [blame^] | 226 | mCarUserManagerHelper.startGuestSession(mGuestName); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 227 | return; |
| 228 | } |
| 229 | |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 230 | // If the user wants to add a user, show dialog to confirm adding a user |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 231 | if (userRecord.mIsAddUser) { |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 232 | // Disable button so it cannot be clicked multiple times |
| 233 | mAddUserView = holder.mView; |
| 234 | mAddUserView.setEnabled(false); |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 235 | mAddUserRecord = userRecord; |
jovanak | a17e168 | 2018-08-09 15:02:13 -0700 | [diff] [blame] | 236 | |
| 237 | handleAddUserClicked(); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 238 | return; |
| 239 | } |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 240 | // If the user doesn't want to be a guest or add a user, switch to the user selected |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 241 | notifyUserSelected(userRecord); |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 242 | mCarUserManagerHelper.switchToUser(userRecord.mInfo); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 243 | }); |
| 244 | |
| 245 | } |
| 246 | |
jovanak | a17e168 | 2018-08-09 15:02:13 -0700 | [diff] [blame] | 247 | private void handleAddUserClicked() { |
| 248 | if (mCarUserManagerHelper.isUserLimitReached()) { |
| 249 | mAddUserView.setEnabled(true); |
| 250 | showMaxUserLimitReachedDialog(); |
| 251 | } else { |
| 252 | showConfirmAddUserDialog(); |
| 253 | } |
| 254 | } |
| 255 | |
| 256 | private void showMaxUserLimitReachedDialog() { |
| 257 | AlertDialog maxUsersDialog = new Builder(mContext, R.style.Theme_Car_Dark_Dialog_Alert) |
| 258 | .setTitle(R.string.user_limit_reached_title) |
| 259 | .setMessage(getResources().getQuantityString( |
| 260 | R.plurals.user_limit_reached_message, |
| 261 | mCarUserManagerHelper.getMaxSupportedRealUsers(), |
| 262 | mCarUserManagerHelper.getMaxSupportedRealUsers())) |
| 263 | .setPositiveButton(android.R.string.ok, null) |
| 264 | .create(); |
| 265 | // Sets window flags for the SysUI dialog |
| 266 | SystemUIDialog.applyFlags(maxUsersDialog); |
| 267 | maxUsersDialog.show(); |
| 268 | } |
| 269 | |
| 270 | private void showConfirmAddUserDialog() { |
| 271 | String message = mRes.getString(R.string.user_add_user_message_setup) |
| 272 | .concat(System.getProperty("line.separator")) |
| 273 | .concat(System.getProperty("line.separator")) |
| 274 | .concat(mRes.getString(R.string.user_add_user_message_update)); |
| 275 | |
| 276 | AlertDialog addUserDialog = new Builder(mContext, R.style.Theme_Car_Dark_Dialog_Alert) |
| 277 | .setTitle(R.string.user_add_user_title) |
| 278 | .setMessage(message) |
| 279 | .setNegativeButton(android.R.string.cancel, this) |
| 280 | .setPositiveButton(android.R.string.ok, this) |
| 281 | .setOnCancelListener(this) |
| 282 | .create(); |
| 283 | // Sets window flags for the SysUI dialog |
| 284 | SystemUIDialog.applyFlags(addUserDialog); |
| 285 | addUserDialog.show(); |
| 286 | } |
| 287 | |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 288 | private void notifyUserSelected(UserRecord userRecord) { |
| 289 | // Notify the listener which user was selected |
| 290 | if (mUserSelectionListener != null) { |
| 291 | mUserSelectionListener.onUserSelected(userRecord); |
| 292 | } |
| 293 | } |
| 294 | |
jovanak | e4ce3cc | 2018-04-19 12:17:12 -0700 | [diff] [blame] | 295 | private Bitmap getUserRecordIcon(UserRecord userRecord) { |
| 296 | if (userRecord.mIsStartGuestSession) { |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 297 | return mCarUserManagerHelper.getGuestDefaultIcon(); |
jovanak | e4ce3cc | 2018-04-19 12:17:12 -0700 | [diff] [blame] | 298 | } |
| 299 | |
| 300 | if (userRecord.mIsAddUser) { |
| 301 | return UserIcons.convertToBitmap(mContext |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 302 | .getDrawable(R.drawable.car_add_circle_round)); |
jovanak | e4ce3cc | 2018-04-19 12:17:12 -0700 | [diff] [blame] | 303 | } |
| 304 | |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 305 | return mCarUserManagerHelper.getUserIcon(userRecord.mInfo); |
jovanak | e4ce3cc | 2018-04-19 12:17:12 -0700 | [diff] [blame] | 306 | } |
| 307 | |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 308 | @Override |
| 309 | public void onClick(DialogInterface dialog, int which) { |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 310 | if (which == BUTTON_POSITIVE) { |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 311 | notifyUserSelected(mAddUserRecord); |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 312 | new AddNewUserTask().execute(mNewUserName); |
Aarthi Balachander | a709600 | 2018-05-21 18:12:25 -0700 | [diff] [blame] | 313 | } else if (which == BUTTON_NEGATIVE) { |
| 314 | // Enable the add button only if cancel |
| 315 | if (mAddUserView != null) { |
| 316 | mAddUserView.setEnabled(true); |
| 317 | } |
Aarthi Balachander | 0e0e921 | 2018-04-19 19:25:33 -0700 | [diff] [blame] | 318 | } |
| 319 | } |
| 320 | |
Aarthi Balachander | c6d1366 | 2018-08-13 14:49:41 -0700 | [diff] [blame] | 321 | @Override |
| 322 | public void onCancel(DialogInterface dialog) { |
| 323 | // Enable the add button again if user cancels dialog by clicking outside the dialog |
| 324 | if (mAddUserView != null) { |
| 325 | mAddUserView.setEnabled(true); |
| 326 | } |
| 327 | } |
| 328 | |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 329 | private class AddNewUserTask extends AsyncTask<String, Void, UserInfo> { |
| 330 | |
| 331 | @Override |
| 332 | protected UserInfo doInBackground(String... userNames) { |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 333 | return mCarUserManagerHelper.createNewNonAdminUser(userNames[0]); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 334 | } |
| 335 | |
| 336 | @Override |
| 337 | protected void onPreExecute() { |
| 338 | } |
| 339 | |
| 340 | @Override |
| 341 | protected void onPostExecute(UserInfo user) { |
| 342 | if (user != null) { |
jovanak | 78cacc4 | 2018-08-06 18:38:03 -0700 | [diff] [blame] | 343 | mCarUserManagerHelper.switchToUser(user); |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 344 | } |
| 345 | } |
| 346 | } |
| 347 | |
| 348 | @Override |
| 349 | public int getItemCount() { |
| 350 | return mUsers.size(); |
| 351 | } |
| 352 | |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 353 | public class UserAdapterViewHolder extends RecyclerView.ViewHolder { |
| 354 | |
| 355 | public ImageView mUserAvatarImageView; |
| 356 | public TextView mUserNameTextView; |
| 357 | public View mView; |
| 358 | |
| 359 | public UserAdapterViewHolder(View view) { |
| 360 | super(view); |
| 361 | mView = view; |
| 362 | mUserAvatarImageView = (ImageView) view.findViewById(R.id.user_avatar); |
| 363 | mUserNameTextView = (TextView) view.findViewById(R.id.user_name); |
| 364 | } |
| 365 | } |
| 366 | } |
| 367 | |
| 368 | /** |
| 369 | * Object wrapper class for the userInfo. Use it to distinguish if a profile is a |
jovanak | 0535abc | 2018-04-10 15:14:50 -0700 | [diff] [blame] | 370 | * guest profile, add user profile, or the foreground user. |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 371 | */ |
| 372 | public static final class UserRecord { |
| 373 | |
| 374 | public final UserInfo mInfo; |
jovanak | 80b4859 | 2018-04-11 17:09:53 -0700 | [diff] [blame] | 375 | public final boolean mIsStartGuestSession; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 376 | public final boolean mIsAddUser; |
jovanak | 0535abc | 2018-04-10 15:14:50 -0700 | [diff] [blame] | 377 | public final boolean mIsForeground; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 378 | |
jovanak | 80b4859 | 2018-04-11 17:09:53 -0700 | [diff] [blame] | 379 | public UserRecord(UserInfo userInfo, boolean isStartGuestSession, boolean isAddUser, |
jovanak | 0535abc | 2018-04-10 15:14:50 -0700 | [diff] [blame] | 380 | boolean isForeground) { |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 381 | mInfo = userInfo; |
jovanak | 80b4859 | 2018-04-11 17:09:53 -0700 | [diff] [blame] | 382 | mIsStartGuestSession = isStartGuestSession; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 383 | mIsAddUser = isAddUser; |
jovanak | 0535abc | 2018-04-10 15:14:50 -0700 | [diff] [blame] | 384 | mIsForeground = isForeground; |
Aarthi Balachander | d8bf249 | 2018-03-30 11:15:59 -0700 | [diff] [blame] | 385 | } |
| 386 | } |
| 387 | |
| 388 | /** |
| 389 | * Listener used to notify when a user has been selected |
| 390 | */ |
| 391 | interface UserSelectionListener { |
| 392 | |
| 393 | void onUserSelected(UserRecord record); |
| 394 | } |
| 395 | } |