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

Unified Diff: chrome/browser/payments/ui/payment_sheet_state.cc

Issue 2528503002: [WebPayments] Implement state transitions in desktop WebPayments dialog. (Closed)
Patch Set: Change ToggleInteractable to SetInteractable Created 4 years, 1 month 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/payments/ui/payment_sheet_state.cc
diff --git a/chrome/browser/payments/ui/payment_sheet_state.cc b/chrome/browser/payments/ui/payment_sheet_state.cc
new file mode 100644
index 0000000000000000000000000000000000000000..617cab28163871f69d8e6c626d6507863df3949b
--- /dev/null
+++ b/chrome/browser/payments/ui/payment_sheet_state.cc
@@ -0,0 +1,65 @@
+// 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 "base/observer_list.h"
+#include "base/strings/utf_string_conversions.h"
+#include "chrome/browser/payments/ui/payment_sheet_state.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 kOrderSummaryTag = 0;
+
+PaymentSheetState::PaymentSheetState()
+ : view_(nullptr) {}
+
+PaymentSheetState::~PaymentSheetState() {}
+
+views::View* PaymentSheetState::GetView() {
+ if (!view_) {
+ view_ = new views::View();
+ view_->SetSize(gfx::Size(300, 300));
please use gerrit instead 2016/11/22 21:39:33 PaymentRequestDialog is hard-coding 200x200. http
anthonyvd 2016/11/22 22:11:19 Yep, this CL also changes the values in PaymentReq
+
+ views::GridLayout* layout = new views::GridLayout(view_);
please use gerrit instead 2016/11/22 21:39:33 Who owns this object.
anthonyvd 2016/11/22 22:11:19 See comment above about ownership.
+ view_->SetLayoutManager(layout);
+ views::ColumnSet* columns = layout->AddColumnSet(0);
please use gerrit instead 2016/11/22 21:39:33 Who owns this object?
anthonyvd 2016/11/22 22:11:19 See above.
+ 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("Payments Sheet")));
+
+ layout->StartRow(0, 0);
+ views::LabelButton* order_summary_button =
please use gerrit instead 2016/11/22 21:39:33 Who owns this object?
anthonyvd 2016/11/22 22:11:19 See above.
+ views::MdTextButton::CreateSecondaryUiBlueButton(
+ this, base::ASCIIToUTF16("Order Summary"));
+ order_summary_button->set_tag(kOrderSummaryTag);
+ layout->AddView(order_summary_button);
+ }
+ return view_;
+}
+
+void PaymentSheetState::AddObserver(Observer* observer) {
+ observers_.AddObserver(observer);
+}
+
+void PaymentSheetState::RemoveObserver(Observer* observer) {
+ observers_.RemoveObserver(observer);
+}
+
+void PaymentSheetState::ButtonPressed(
+ views::Button* sender, const ui::Event& event) {
+ if (!interactable())
+ return;
+
+ if (sender->tag() == kOrderSummaryTag) {
+ for (auto& observer : observers_) {
+ observer.OnOrderSummaryClicked();
+ }
+ }
+}
+
+} // namespace payments

Powered by Google App Engine
This is Rietveld 408576698