Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(346)

Unified Diff: chrome/browser/ui/views/autofill/new_credit_card_bubble_views.cc

Issue 21668003: Implement newly saved card bubble for realz and update generated card bubble to (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: compile Created 7 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/views/autofill/new_credit_card_bubble_views.cc
diff --git a/chrome/browser/ui/views/autofill/new_credit_card_bubble_views.cc b/chrome/browser/ui/views/autofill/new_credit_card_bubble_views.cc
new file mode 100644
index 0000000000000000000000000000000000000000..7ddf5530bce27439c8089f80fb36e54634ebc1ca
--- /dev/null
+++ b/chrome/browser/ui/views/autofill/new_credit_card_bubble_views.cc
@@ -0,0 +1,122 @@
+// Copyright 2013 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.
+
+#include "chrome/browser/ui/views/autofill/new_credit_card_bubble_views.h"
+
+#include "chrome/browser/ui/autofill/new_credit_card_bubble_controller.h"
+#include "chrome/browser/ui/browser_finder.h"
+#include "chrome/browser/ui/host_desktop.h"
+#include "chrome/browser/ui/views/frame/browser_view.h"
+#include "chrome/browser/ui/views/toolbar_view.h"
+#include "ui/gfx/insets.h"
+#include "ui/gfx/size.h"
+#include "ui/views/bubble/bubble_frame_view.h"
+#include "ui/views/controls/image_view.h"
+#include "ui/views/controls/link.h"
+#include "ui/views/layout/box_layout.h"
+#include "ui/views/layout/layout_constants.h"
+#include "ui/views/view.h"
+#include "ui/views/widget/widget.h"
+
+namespace autofill {
+
+namespace {
+
+views::View* GetAnchor(
+ const base::WeakPtr<NewCreditCardBubbleController>& controller) {
+ Browser* browser = chrome::FindTabbedBrowser(controller->profile(), false,
+ chrome::GetActiveDesktop());
Evan Stade 2013/08/06 22:06:25 I feel that |browser| should be sorted out based o
Dan Beam 2013/08/07 02:30:22 popups don't have a wrench menu, which is why I us
Evan Stade 2013/08/07 23:31:21 that doesn't seem right to me, we should still sho
Dan Beam 2013/08/08 05:23:48 asked jstark@ on the bug
+ BrowserView* browser_view = BrowserView::GetBrowserViewForBrowser(browser);
+ return browser_view->GetToolbarView()->app_menu();
+}
+
+} // namespace
+
+NewCreditCardBubbleViews::~NewCreditCardBubbleViews() {
+ if (controller_)
+ controller_->OnBubbleDestroyed();
+}
+
+void NewCreditCardBubbleViews::Show() {
+ // TODO(dbeam): investigate why this steals focus from the web contents.
+ views::BubbleDelegateView::CreateBubble(this);
+ GetWidget()->Show();
+ SizeToContents();
+}
+
+void NewCreditCardBubbleViews::Hide() {
+ GetWidget()->Close();
+}
+
+void NewCreditCardBubbleViews::Init() {
+ SetLayoutManager(
+ new views::BoxLayout(views::BoxLayout::kVertical, 0, 0,
+ views::kUnrelatedControlVerticalSpacing));
+
+ views::Label* contents = new views::Label(controller_->ContentsText());
+ contents->SetHorizontalAlignment(gfx::ALIGN_LEFT);
+ contents->SetMultiLine(true);
+ AddChildView(contents);
+
+ views::View* card_container = new views::View();
+ card_container->SetLayoutManager(
+ new views::BoxLayout(views::BoxLayout::kVertical, 0, 0, 10));
+
+ views::View* card_desc_view = new views::View();
+ card_desc_view->SetLayoutManager(
+ new views::BoxLayout(views::BoxLayout::kHorizontal, 0, 0, 10));
+
+ views::ImageView* card_icon = new views::ImageView();
+ const CreditCardDescription& card_desc = controller_->CardDescription();
+ card_icon->SetImage(card_desc.icon.AsImageSkia());
+ card_desc_view->AddChildView(card_icon);
+
+ views::Label* card_name = new views::Label(card_desc.name);
+ card_name->SetHorizontalAlignment(gfx::ALIGN_LEFT);
+ card_desc_view->AddChildView(card_name);
+ card_container->AddChildView(card_desc_view);
+
+ views::Label* desc = new views::Label(card_desc.description);
+ desc->SetHorizontalAlignment(gfx::ALIGN_LEFT);
+ desc->SetMultiLine(true);
+ card_container->AddChildView(desc);
+
+ AddChildView(card_container);
+
+ views::Link* link = new views::Link(controller_->LinkText());
+ link->SetHorizontalAlignment(gfx::ALIGN_LEFT);
+ link->set_listener(this);
+ AddChildView(link);
+}
+
+gfx::Size NewCreditCardBubbleViews::GetPreferredSize() {
+ return gfx::Size(
+ NewCreditCardBubbleViews::kContentWidth,
+ GetHeightForWidth(NewCreditCardBubble::kContentWidth));
+}
+
+void NewCreditCardBubbleViews::LinkClicked(views::Link* source,
+ int event_flags) {
+ if (controller_)
+ controller_->OnLinkClicked();
+}
+
+// static
+base::WeakPtr<NewCreditCardBubble> NewCreditCardBubble::Create(
+ const base::WeakPtr<NewCreditCardBubbleController>& controller) {
+ NewCreditCardBubbleViews* bubble =
+ new NewCreditCardBubbleViews(controller);
+ return bubble->weak_ptr_factory_.GetWeakPtr();
+}
+
+NewCreditCardBubbleViews::NewCreditCardBubbleViews(
+ const base::WeakPtr<NewCreditCardBubbleController>& controller)
+ : BubbleDelegateView(GetAnchor(controller), views::BubbleBorder::TOP_RIGHT),
+ controller_(controller),
+ weak_ptr_factory_(this) {
+ // Match bookmarks bubble view's margins.
+ set_margins(gfx::Insets(18, 19, 18, 18));
Evan Stade 2013/08/06 22:06:25 heinous. Perhaps you can create these insets via a
Dan Beam 2013/08/07 02:30:22 check what I did, see if you like
+}
+
+} // namespace autofill

Powered by Google App Engine
This is Rietveld 408576698