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 |