Chromium Code Reviews| OLD | NEW |
|---|---|
| 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_dialog_view_ids.h" | 7 #include "chrome/browser/ui/views/payments/payment_request_dialog_view_ids.h" |
| 8 #include "chrome/browser/ui/views/payments/payment_request_row_view.h" | 8 #include "chrome/browser/ui/views/payments/payment_request_row_view.h" |
| 9 #include "chrome/browser/ui/views/payments/payment_request_views_util.h" | 9 #include "chrome/browser/ui/views/payments/payment_request_views_util.h" |
| 10 #include "components/payments/content/payment_request_state.h" | 10 #include "components/payments/content/payment_request_state.h" |
| 11 #include "ui/gfx/paint_vector_icon.h" | 11 #include "ui/gfx/paint_vector_icon.h" |
| 12 #include "ui/vector_icons/vector_icons.h" | |
| 13 #include "ui/views/controls/button/image_button.h" | |
| 14 #include "ui/views/controls/button/image_button_factory.h" | |
| 12 #include "ui/views/controls/image_view.h" | 15 #include "ui/views/controls/image_view.h" |
| 13 #include "ui/views/layout/box_layout.h" | 16 #include "ui/views/layout/box_layout.h" |
| 14 #include "ui/views/layout/grid_layout.h" | 17 #include "ui/views/layout/grid_layout.h" |
| 15 #include "ui/views/vector_icons.h" | 18 #include "ui/views/vector_icons.h" |
| 16 #include "ui/views/view.h" | 19 #include "ui/views/view.h" |
| 17 | 20 |
| 18 namespace payments { | 21 namespace payments { |
| 19 | 22 |
| 20 namespace { | 23 namespace { |
| 21 | 24 |
| 22 const SkColor kCheckmarkColor = 0xFF609265; | 25 const SkColor kCheckmarkColor = 0xFF609265; |
| 23 | 26 |
| 24 } // namespace | 27 } // namespace |
| 25 | 28 |
| 26 PaymentRequestItemList::Item::Item(PaymentRequestSpec* spec, | 29 PaymentRequestItemList::Item::Item(PaymentRequestSpec* spec, |
| 27 PaymentRequestState* state, | 30 PaymentRequestState* state, |
| 28 PaymentRequestItemList* list, | 31 PaymentRequestItemList* list, |
| 29 bool selected) | 32 bool selected, |
| 30 : spec_(spec), state_(state), list_(list), selected_(selected) {} | 33 bool show_edit_button) |
| 34 : spec_(spec), | |
| 35 state_(state), | |
| 36 list_(list), | |
| 37 selected_(selected), | |
| 38 show_edit_button_(show_edit_button) {} | |
| 31 | 39 |
| 32 PaymentRequestItemList::Item::~Item() {} | 40 PaymentRequestItemList::Item::~Item() {} |
| 33 | 41 |
| 34 views::View* PaymentRequestItemList::Item::GetItemView() { | 42 views::View* PaymentRequestItemList::Item::GetItemView() { |
| 35 if (!item_view_) { | 43 if (!item_view_) { |
| 36 item_view_ = CreateItemView(); | 44 item_view_ = CreateItemView(); |
| 37 item_view_->set_owned_by_client(); | 45 item_view_->set_owned_by_client(); |
| 38 } | 46 } |
| 39 | 47 |
| 40 return item_view_.get(); | 48 return item_view_.get(); |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 87 views::ColumnSet* columns = layout->AddColumnSet(0); | 95 views::ColumnSet* columns = layout->AddColumnSet(0); |
| 88 columns->AddColumn(views::GridLayout::FILL, views::GridLayout::LEADING, 1, | 96 columns->AddColumn(views::GridLayout::FILL, views::GridLayout::LEADING, 1, |
| 89 views::GridLayout::USE_PREF, 0, 0); | 97 views::GridLayout::USE_PREF, 0, 0); |
| 90 | 98 |
| 91 columns->AddPaddingColumn(1, 0); | 99 columns->AddPaddingColumn(1, 0); |
| 92 | 100 |
| 93 // Add a column for the checkmark shown next to the selected profile. | 101 // Add a column for the checkmark shown next to the selected profile. |
| 94 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, 0, | 102 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, 0, |
| 95 views::GridLayout::USE_PREF, 0, 0); | 103 views::GridLayout::USE_PREF, 0, 0); |
| 96 | 104 |
| 97 // Add a column for the extra_view, which comes after the checkmark. | 105 // The space between the checkmark, extra view, and edit button. |
| 98 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, 0, | 106 constexpr int kExtraViewSpacing = 16; |
| 99 views::GridLayout::USE_PREF, 0, 0); | 107 std::unique_ptr<views::View> extra_view = CreateExtraView(); |
| 108 if (extra_view) { | |
| 109 columns->AddPaddingColumn(0, kExtraViewSpacing); | |
| 110 // Add a column for the extra_view, which comes after the checkmark. | |
| 111 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, | |
| 112 0, views::GridLayout::USE_PREF, 0, 0); | |
| 113 } | |
| 114 | |
| 115 if (show_edit_button_) { | |
| 116 columns->AddPaddingColumn(0, kExtraViewSpacing); | |
| 117 // Add a column for the edit_button if it exists. | |
| 118 constexpr int kEditIconSize = 16; | |
| 119 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, | |
| 120 0, views::GridLayout::FIXED, kEditIconSize, | |
| 121 kEditIconSize); | |
| 122 } | |
| 100 | 123 |
| 101 layout->StartRow(0, 0); | 124 layout->StartRow(0, 0); |
| 102 content->set_can_process_events_within_subtree(false); | 125 content->set_can_process_events_within_subtree(false); |
| 103 layout->AddView(content.release()); | 126 layout->AddView(content.release()); |
| 104 | 127 |
| 105 checkmark_ = CreateCheckmark(selected()); | 128 checkmark_ = CreateCheckmark(selected()); |
| 106 layout->AddView(checkmark_.get()); | 129 layout->AddView(checkmark_.get()); |
| 107 | 130 |
| 108 std::unique_ptr<views::View> extra_view = CreateExtraView(); | |
| 109 if (extra_view) | 131 if (extra_view) |
| 110 layout->AddView(extra_view.release()); | 132 layout->AddView(extra_view.release()); |
| 111 | 133 |
| 134 if (show_edit_button_) { | |
| 135 views::ImageButton* edit_button = views::CreateVectorImageButton(this); | |
| 136 edit_button->set_owned_by_client(); | |
| 137 views::SetImageFromVectorIcon(edit_button, ui::kEditIcon); | |
| 138 edit_button->SetFocusBehavior(views::View::FocusBehavior::ALWAYS); | |
| 139 edit_button->set_id(static_cast<int>(DialogViewID::EDIT_ITEM_BUTTON)); | |
| 140 layout->AddView(edit_button); | |
| 141 } | |
| 142 | |
| 112 return std::move(row); | 143 return std::move(row); |
| 113 } | 144 } |
| 114 | 145 |
| 115 void PaymentRequestItemList::Item::ButtonPressed(views::Button* sender, | 146 void PaymentRequestItemList::Item::ButtonPressed(views::Button* sender, |
| 116 const ui::Event& event) { | 147 const ui::Event& event) { |
| 117 if (CanBeSelected()) { | 148 if (sender->id() == static_cast<int>(DialogViewID::EDIT_ITEM_BUTTON)) { |
|
Evan Stade
2017/05/12 18:48:07
nit: are both of these casts necessary? (here and
anthonyvd
2017/05/12 20:16:48
Yeah, since DialogViewID is an enum class not cast
Evan Stade
2017/05/15 17:14:55
what error do you get for the other one? Because c
anthonyvd
2017/05/15 17:27:40
error: cannot initialize a parameter of type 'int'
| |
| 149 EditButtonPressed(); | |
| 150 } else if (CanBeSelected()) { | |
| 118 list()->SelectItem(this); | 151 list()->SelectItem(this); |
| 119 } else { | 152 } else { |
| 120 PerformSelectionFallback(); | 153 PerformSelectionFallback(); |
| 121 } | 154 } |
| 122 } | 155 } |
| 123 | 156 |
| 124 PaymentRequestItemList::PaymentRequestItemList() : selected_item_(nullptr) {} | 157 PaymentRequestItemList::PaymentRequestItemList() : selected_item_(nullptr) {} |
| 125 | 158 |
| 126 PaymentRequestItemList::~PaymentRequestItemList() {} | 159 PaymentRequestItemList::~PaymentRequestItemList() {} |
| 127 | 160 |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 165 // It's possible that no item is currently selected, either during list | 198 // It's possible that no item is currently selected, either during list |
| 166 // creation or in the middle of the selection operation when the previously | 199 // creation or in the middle of the selection operation when the previously |
| 167 // selected item has been deselected but the new one isn't selected yet. | 200 // selected item has been deselected but the new one isn't selected yet. |
| 168 if (selected_item_) | 201 if (selected_item_) |
| 169 selected_item_->SetSelected(/*selected=*/false, /*notify=*/true); | 202 selected_item_->SetSelected(/*selected=*/false, /*notify=*/true); |
| 170 | 203 |
| 171 selected_item_ = nullptr; | 204 selected_item_ = nullptr; |
| 172 } | 205 } |
| 173 | 206 |
| 174 } // namespace payments | 207 } // namespace payments |
| OLD | NEW |