| Index: chrome/android/java/src/org/chromium/chrome/browser/infobar/AccountChooserInfoBar.java
|
| diff --git a/chrome/android/java/src/org/chromium/chrome/browser/infobar/AccountChooserInfoBar.java b/chrome/android/java/src/org/chromium/chrome/browser/infobar/AccountChooserInfoBar.java
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..d7e2efab06fa601f64a8a7a70cbdd45e730d44af
|
| --- /dev/null
|
| +++ b/chrome/android/java/src/org/chromium/chrome/browser/infobar/AccountChooserInfoBar.java
|
| @@ -0,0 +1,188 @@
|
| +// Copyright 2015 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +package org.chromium.chrome.browser.infobar;
|
| +
|
| +import android.content.Context;
|
| +import android.view.LayoutInflater;
|
| +import android.view.MenuItem;
|
| +import android.view.View;
|
| +import android.view.View.OnClickListener;
|
| +import android.view.ViewGroup;
|
| +import android.widget.ArrayAdapter;
|
| +import android.widget.Button;
|
| +import android.widget.ImageView;
|
| +import android.widget.LinearLayout;
|
| +import android.widget.ListView;
|
| +import android.widget.PopupMenu;
|
| +import android.widget.PopupMenu.OnMenuItemClickListener;
|
| +import android.widget.TextView;
|
| +
|
| +import org.chromium.base.CalledByNative;
|
| +import org.chromium.chrome.R;
|
| +import org.chromium.chrome.browser.ResourceId;
|
| +import org.chromium.chrome.browser.preferences.PreferencesLauncher;
|
| +import org.chromium.chrome.browser.widget.ButtonCompat;
|
| +
|
| +/**
|
| + * An infobar which allows user to choose credentials.
|
| + * Provides JNI methods for the infobar which allows user to choose account in
|
| + * Google Smart Lock.
|
| + */
|
| +public class AccountChooserInfoBar extends InfoBar implements OnMenuItemClickListener {
|
| + private enum CredentialType {
|
| + EMPTY(0),
|
| + LOCAL(1),
|
| + FEDERATED(2);
|
| +
|
| + private final int mType;
|
| + private CredentialType(int type) {
|
| + mType = type;
|
| + };
|
| +
|
| + public int getValue() {
|
| + return mType;
|
| + }
|
| + }
|
| +
|
| + private final String[] mUsernames;
|
| +
|
| + /**
|
| + * Creates and shows the infobar wich allows user to choose credentials for login.
|
| + * @param nativeInfoBar Pointer to the native infobar.
|
| + * @param enumeratedIconId Enum ID corresponding to the icon that the infobar will show.
|
| + * @param usernames Usernames to display in the infobar.
|
| + */
|
| + @CalledByNative
|
| + private static InfoBar show(long nativeInfoBar, int enumeratedIconId, String[] usernames) {
|
| + return new AccountChooserInfoBar(
|
| + nativeInfoBar, ResourceId.mapToDrawableId(enumeratedIconId), usernames);
|
| + }
|
| +
|
| + /**
|
| + * Creates and shows the infobar which allows user to choose credentials.
|
| + * @param nativeInfoBar Pointer to the native infobar.
|
| + * @param iconDrawableId Drawable ID corresponding to the icon that the infobar will show.
|
| + * @param usernames list of usernames to display in infobar.
|
| + */
|
| + public AccountChooserInfoBar(long nativeInfoBar, int iconDrawableId, String[] usernames) {
|
| + super(null /* Infobar Listener */, iconDrawableId, null /* bitmap*/,
|
| + null /* message to show */);
|
| + setNativeInfoBar(nativeInfoBar);
|
| + mUsernames = usernames;
|
| + }
|
| +
|
| + @Override
|
| + public boolean onMenuItemClick(MenuItem item) {
|
| + if (item.getItemId() == R.id.settings) {
|
| + PreferencesLauncher.launchSettingsPage(getContext(), null);
|
| + return true;
|
| + }
|
| + // TODO(melandory): Learn more should open link to help center
|
| + // article which is not ready yet.
|
| + return false;
|
| + }
|
| +
|
| + @Override
|
| + public void onCloseButtonClicked() {
|
| + // Notifies the native infobar, which
|
| + // closes the infobar.
|
| + nativeOnCloseButtonClicked(mNativeInfoBarPtr);
|
| + }
|
| +
|
| + @Override
|
| + public void onButtonClicked(boolean isPrimaryButton) {
|
| + onCloseButtonClicked();
|
| + }
|
| +
|
| + @Override
|
| + public void createContent(InfoBarLayout layout) {
|
| + layout.setMessage(getContext().getString(R.string.account_chooser_infobar_title));
|
| + createAccountsView(layout);
|
| + createCustomButtonsView(layout);
|
| + }
|
| +
|
| + private void createAccountsView(InfoBarLayout layout) {
|
| + ViewGroup accountsView =
|
| + (ViewGroup) LayoutInflater.from(getContext())
|
| + .inflate(R.layout.account_chooser_infobar_list, null, false);
|
| + ArrayAdapter<String> adapter = generateAccountsArrayAdapter(getContext(), mUsernames);
|
| + ListView listView = (ListView) accountsView.findViewById(R.id.account_list);
|
| + listView.setAdapter(adapter);
|
| + if (adapter.getCount() >= 2) {
|
| + double coeff = (adapter.getCount() > 2) ? 2.5 : 2;
|
| + ViewGroup.LayoutParams params = listView.getLayoutParams();
|
| + params.height = (int) (coeff
|
| + * getContext().getResources().getDimension(
|
| + R.dimen.account_chooser_infobar_item_height));
|
| + }
|
| + layout.setCustomContent(accountsView);
|
| + }
|
| +
|
| + private ArrayAdapter<String> generateAccountsArrayAdapter(Context context, String[] usernames) {
|
| + return new ArrayAdapter<String>(context, 0, usernames) {
|
| + @Override
|
| + public View getView(int position, View convertView, ViewGroup parent) {
|
| + LinearLayout row =
|
| + (LinearLayout) LayoutInflater.from(getContext())
|
| + .inflate(R.layout.account_chooser_infobar_item, null, false);
|
| + ImageView avatarView = (ImageView) convertView.findViewById(R.id.profile_image);
|
| + TextView usernameView = (TextView) convertView.findViewById(R.id.username);
|
| + TextView displayNameView = (TextView) convertView.findViewById(R.id.display_name);
|
| + String username = getItem(position);
|
| + usernameView.setText(username);
|
| + // TODO(melandory): View should show the full name. Temporarily the view shows
|
| + // username.
|
| + displayNameView.setText(username);
|
| + // TODO(melandory): View should show proper avatar. Temporarily the view shows
|
| + // blue man icon.
|
| + avatarView.setImageResource(R.drawable.account_management_no_picture);
|
| + final int currentCredentialIndex = position;
|
| + row.setOnClickListener(new View.OnClickListener() {
|
| + @Override
|
| + public void onClick(View view) {
|
| + passCredentialsToNative(currentCredentialIndex);
|
| + }
|
| + });
|
| + return row;
|
| + }
|
| + };
|
| + }
|
| +
|
| + /**
|
| + * For the Account Chooser infobar different, than InfobarLayout has, appearance of button
|
| + * is required.
|
| + */
|
| + private void createCustomButtonsView(InfoBarLayout layout) {
|
| + layout.setButtons(getContext().getString(R.string.no_thanks), null);
|
| + Button moreButton = ButtonCompat.createBorderlessButton(getContext());
|
| + moreButton.setText(getContext().getString(R.string.account_chooser_infobar_more_button));
|
| + // TODO(melandory): Looks like spinner in mocks.
|
| + moreButton.setOnClickListener(new OnClickListener() {
|
| + @Override
|
| + public void onClick(View view) {
|
| + showMorePopup(view);
|
| + }
|
| + });
|
| + layout.setCustomViewInButtonRow(moreButton);
|
| + }
|
| +
|
| + private void passCredentialsToNative(Integer credentialIndex) {
|
| + // TODO(melandory): Adding federated login support should change this
|
| + // code.
|
| + nativeOnCredentialClicked(
|
| + mNativeInfoBarPtr, credentialIndex, CredentialType.LOCAL.getValue());
|
| + }
|
| +
|
| + /** Pops up menu with two items: Setting and Learn More when user clicks more button*/
|
| + private void showMorePopup(View v) {
|
| + PopupMenu popup = new PopupMenu(getContext(), v);
|
| + popup.setOnMenuItemClickListener(this);
|
| + popup.inflate(R.menu.account_chooser_infobar_more_menu_popup);
|
| + popup.show();
|
| + }
|
| +
|
| + private native void nativeOnCredentialClicked(
|
| + long nativeAccountChooserInfoBar, int credentialId, int credentialType);
|
| +}
|
|
|