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

Side by Side 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 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "base/observer_list.h"
6 #include "base/strings/utf_string_conversions.h"
7 #include "chrome/browser/payments/ui/payment_sheet_state.h"
8 #include "ui/views/controls/button/md_text_button.h"
9 #include "ui/views/controls/label.h"
10 #include "ui/views/layout/grid_layout.h"
11
12 namespace payments {
13
14 const int kOrderSummaryTag = 0;
15
16 PaymentSheetState::PaymentSheetState()
17 : view_(nullptr) {}
18
19 PaymentSheetState::~PaymentSheetState() {}
20
21 views::View* PaymentSheetState::GetView() {
22 if (!view_) {
23 view_ = new views::View();
24 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
25
26 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.
27 view_->SetLayoutManager(layout);
28 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.
29 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER,
30 0, views::GridLayout::USE_PREF, 0, 0);
31
32 layout->StartRow(0, 0);
33 layout->AddView(new views::Label(base::ASCIIToUTF16("Payments Sheet")));
34
35 layout->StartRow(0, 0);
36 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.
37 views::MdTextButton::CreateSecondaryUiBlueButton(
38 this, base::ASCIIToUTF16("Order Summary"));
39 order_summary_button->set_tag(kOrderSummaryTag);
40 layout->AddView(order_summary_button);
41 }
42 return view_;
43 }
44
45 void PaymentSheetState::AddObserver(Observer* observer) {
46 observers_.AddObserver(observer);
47 }
48
49 void PaymentSheetState::RemoveObserver(Observer* observer) {
50 observers_.RemoveObserver(observer);
51 }
52
53 void PaymentSheetState::ButtonPressed(
54 views::Button* sender, const ui::Event& event) {
55 if (!interactable())
56 return;
57
58 if (sender->tag() == kOrderSummaryTag) {
59 for (auto& observer : observers_) {
60 observer.OnOrderSummaryClicked();
61 }
62 }
63 }
64
65 } // namespace payments
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698