Index: chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarControlLayout.java |
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarControlLayout.java b/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarControlLayout.java |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f90defeee4848c3029136addeaa935ba3b375e91 |
--- /dev/null |
+++ b/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarControlLayout.java |
@@ -0,0 +1,66 @@ |
+// 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.widget.FrameLayout; |
+import android.widget.ImageView; |
+import android.widget.LinearLayout; |
+import android.widget.Switch; |
+import android.widget.TextView; |
+ |
+import org.chromium.chrome.R; |
+ |
+/** |
+ * Lays out controls for InfoBars that require more than the standard pair of OK/CANCEL buttons. |
+ * |
+ * This class works with the {@link InfoBarLayout} to define a standard set of controls with |
+ * standardized spacings and text styling that gets laid out in grid form: https://crbug.com/543205 |
+ * |
+ * TODO(dfalcantara): Implement the measurement and layout algorithms. |
+ */ |
+public class InfoBarControlLayout extends FrameLayout { |
+ |
+ public InfoBarControlLayout(Context context) { |
+ super(context); |
+ } |
+ |
+ /** |
+ * Adds a toggle switch to the layout. |
+ * |
+ * ------------------------------------------------- |
+ * | ICON | MESSAGE | TOGGLE | |
+ * ------------------------------------------------- |
+ * If an icon is not provided, the ImageView that would normally show it is hidden. |
+ * |
+ * @param iconResourceId ID of the drawable to use for the icon, or 0 to hide the ImageView. |
+ * @param toggleMessage Message to display for the toggle. |
+ * @param toggleId ID to use for the toggle. |
+ * @param isChecked Whether the toggle should start off checked. |
+ */ |
+ public LinearLayout addSwitch( |
+ int iconResourceId, CharSequence toggleMessage, int toggleId, boolean isChecked) { |
+ LinearLayout switchLayout = (LinearLayout) LayoutInflater.from(getContext()).inflate( |
+ R.layout.infobar_control_toggle, this, false); |
+ addView(switchLayout); |
+ |
+ ImageView iconView = (ImageView) switchLayout.findViewById(R.id.control_toggle_icon); |
+ if (iconResourceId == 0) { |
+ removeView(iconView); |
newt (away)
2015/11/05 22:23:14
or switchLayout.removeView()
|
+ } else { |
+ iconView.setImageResource(iconResourceId); |
+ } |
+ |
+ TextView messageView = (TextView) switchLayout.findViewById(R.id.control_toggle_message); |
+ messageView.setText(toggleMessage); |
+ |
+ Switch switchView = (Switch) switchLayout.findViewById(R.id.control_toggle_switch); |
+ switchView.setId(toggleId); |
+ switchView.setChecked(isChecked); |
+ |
+ return switchLayout; |
+ } |
+} |