Chromium Code Reviews| 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 |