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

Side by Side Diff: chrome/browser/ui/views/payments/payment_request_item_list.cc

Issue 2711973002: [Web Payments] Implement the credit card selection UI functionality. (Closed)
Patch Set: Created 3 years, 10 months 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
1 // Copyright 2017 The Chromium Authors. All rights reserved. 1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/views/payments/payment_request_item_list.h" 5 #include "chrome/browser/ui/views/payments/payment_request_item_list.h"
6 6
7 #include "chrome/browser/ui/views/payments/payment_request_views_util.h" 7 #include "chrome/browser/ui/views/payments/payment_request_views_util.h"
8 #include "ui/views/layout/box_layout.h" 8 #include "ui/views/layout/box_layout.h"
9 #include "ui/views/view.h" 9 #include "ui/views/view.h"
10 10
11 namespace payments { 11 namespace payments {
12 12
13 PaymentRequestItemList::Item::Item() {} 13 PaymentRequestItemList::Item::Item(PaymentRequestItemList* list, bool selected)
14 : list_(list), selected_(selected) {}
14 15
15 PaymentRequestItemList::Item::~Item() {} 16 PaymentRequestItemList::Item::~Item() {}
16 17
17 views::View* PaymentRequestItemList::Item::GetItemView() { 18 views::View* PaymentRequestItemList::Item::GetItemView() {
18 if (!item_view_) { 19 if (!item_view_) {
19 item_view_ = CreateItemView(); 20 item_view_ = CreateItemView();
20 item_view_->set_owned_by_client(); 21 item_view_->set_owned_by_client();
21 } 22 }
22 23
23 return item_view_.get(); 24 return item_view_.get();
24 } 25 }
25 26
27 void PaymentRequestItemList::Item::set_selected(bool selected) {
28 selected_ = selected;
29 SelectedStateChanged();
30 }
31
26 PaymentRequestItemList::PaymentRequestItemList() {} 32 PaymentRequestItemList::PaymentRequestItemList() {}
27 33
28 PaymentRequestItemList::~PaymentRequestItemList() {} 34 PaymentRequestItemList::~PaymentRequestItemList() {}
29 35
30 void PaymentRequestItemList::AddItem( 36 void PaymentRequestItemList::AddItem(
31 std::unique_ptr<PaymentRequestItemList::Item> item) { 37 std::unique_ptr<PaymentRequestItemList::Item> item) {
38 DCHECK_EQ(this, item->list());
32 items_.push_back(std::move(item)); 39 items_.push_back(std::move(item));
33 } 40 }
34 41
35 std::unique_ptr<views::View> PaymentRequestItemList::CreateListView() { 42 std::unique_ptr<views::View> PaymentRequestItemList::CreateListView() {
36 std::unique_ptr<views::View> content_view = base::MakeUnique<views::View>(); 43 std::unique_ptr<views::View> content_view = base::MakeUnique<views::View>();
37 44
38 views::BoxLayout* layout = new views::BoxLayout( 45 views::BoxLayout* layout = new views::BoxLayout(
39 views::BoxLayout::kVertical, 0, kPaymentRequestRowVerticalInsets, 0); 46 views::BoxLayout::kVertical, 0, kPaymentRequestRowVerticalInsets, 0);
40 content_view->SetLayoutManager(layout); 47 content_view->SetLayoutManager(layout);
41 48
42 for (auto& item : items_) { 49 for (auto& item : items_) {
43 content_view->AddChildView(item->GetItemView()); 50 content_view->AddChildView(item->GetItemView());
44 } 51 }
45 52
46 return content_view; 53 return content_view;
47 } 54 }
48 55
56 void PaymentRequestItemList::SelectItem(PaymentRequestItemList::Item* item) {
Mathieu 2017/02/23 21:22:53 As a newcomer to this code, I keep having double t
anthonyvd 2017/02/23 21:49:20 Fair point. There's a bigger, overarching discussi
57 DCHECK_EQ(this, item->list());
58 // First, deselect the previously selected item
Mathieu 2017/02/23 21:22:53 should we early abort if item->selected()
anthonyvd 2017/02/23 21:49:20 Done. Also realized naming both the parameter and
59 for (auto& item : items_) {
60 if (item->selected()) {
61 item->set_selected(false);
62 break; // Only one item is ever selected
63 }
64 }
65
66 item->set_selected(true);
67 }
68
49 } // namespace payments 69 } // namespace payments
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698