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

Unified Diff: chrome/browser/ui/views/payments/order_summary_state.cc

Issue 2528503002: [WebPayments] Implement state transitions in desktop WebPayments dialog. (Closed)
Patch Set: Make PaymentDialogState own the view returned through GetView Created 4 years 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/payments/order_summary_state.cc
diff --git a/chrome/browser/ui/views/payments/order_summary_state.cc b/chrome/browser/ui/views/payments/order_summary_state.cc
new file mode 100644
index 0000000000000000000000000000000000000000..22b4637b9220a222efeac474dd7cb7d7beefa3ce
--- /dev/null
+++ b/chrome/browser/ui/views/payments/order_summary_state.cc
@@ -0,0 +1,64 @@
+// Copyright 2016 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/payments/order_summary_state.h"
+
+#include "base/observer_list.h"
+#include "base/strings/utf_string_conversions.h"
+#include "ui/views/controls/button/md_text_button.h"
+#include "ui/views/controls/label.h"
+#include "ui/views/layout/grid_layout.h"
+
+namespace payments {
+
+const int kBackButtonTag = 0;
sky 2016/12/08 03:58:16 constexpr, also move into anonymous namespace and
anthonyvd 2016/12/08 20:31:22 Done.
+
+OrderSummaryState::OrderSummaryState() {}
+
+OrderSummaryState::~OrderSummaryState() {}
+
+views::View* OrderSummaryState::CreateView() {
+ views::View* view = new views::View();
+ view->SetSize(gfx::Size(300, 300));
sky 2016/12/08 03:58:17 Why are you setting the size? The size should come
anthonyvd 2016/12/08 20:31:22 Done.
+
+ views::GridLayout* layout = new views::GridLayout(view);
+ view->SetLayoutManager(layout);
+ views::ColumnSet* columns = layout->AddColumnSet(0);
+ columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER,
+ 0, views::GridLayout::USE_PREF, 0, 0);
+
+ layout->StartRow(0, 0);
+ layout->AddView(new views::Label(base::ASCIIToUTF16("Order Summary")));
sky 2016/12/08 03:58:16 Shouldn't you be looking these names up from resou
anthonyvd 2016/12/08 20:31:22 Those controls are there temporarily to have somet
+
+ layout->StartRow(0, 0);
+ views::LabelButton* back_button =
+ views::MdTextButton::CreateSecondaryUiBlueButton(
+ this, base::ASCIIToUTF16("Back"));
+ back_button->set_tag(kBackButtonTag);
+ layout->AddView(back_button);
+
+ return view;
+}
+
+void OrderSummaryState::AddObserver(Observer* observer) {
+ observers_.AddObserver(observer);
+}
+
+void OrderSummaryState::RemoveObserver(Observer* observer) {
+ observers_.RemoveObserver(observer);
+}
+
+void OrderSummaryState::ButtonPressed(
+ views::Button* sender, const ui::Event& event) {
+ if (!interactable())
+ return;
+
+ if (sender->tag() == kBackButtonTag) {
sky 2016/12/08 03:58:17 DCHECK_EQ as there is only one button.
anthonyvd 2016/12/08 20:31:22 Done.
+ for (auto& observer : observers_) {
+ observer.OnBackClicked();
+ }
+ }
+}
+
+} // namespace payments

Powered by Google App Engine
This is Rietveld 408576698