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), state_(state), list_(list), selected_(selected) { | |
| 35 if (show_edit_button) { | |
| 36 edit_button_.reset(views::CreateVectorImageButton(this)); | |
| 37 edit_button_->set_owned_by_client(); | |
| 38 views::SetImageFromVectorIcon(edit_button_.get(), ui::kEditPenIcon); | |
| 39 constexpr int kBackArrowSize = 16; | |
|
Mathieu
2017/05/08 14:08:02
fix
anthonyvd
2017/05/08 14:45:54
Done.
| |
| 40 edit_button_->SetSize(gfx::Size(kBackArrowSize, kBackArrowSize)); | |
| 41 edit_button_->SetFocusBehavior(views::View::FocusBehavior::ALWAYS); | |
| 42 edit_button_->set_id(static_cast<int>(DialogViewID::EDIT_ITEM_BUTTON)); | |
| 43 } | |
| 44 } | |
| 31 | 45 |
| 32 PaymentRequestItemList::Item::~Item() {} | 46 PaymentRequestItemList::Item::~Item() {} |
| 33 | 47 |
| 34 views::View* PaymentRequestItemList::Item::GetItemView() { | 48 views::View* PaymentRequestItemList::Item::GetItemView() { |
| 35 if (!item_view_) { | 49 if (!item_view_) { |
| 36 item_view_ = CreateItemView(); | 50 item_view_ = CreateItemView(); |
| 37 item_view_->set_owned_by_client(); | 51 item_view_->set_owned_by_client(); |
| 38 } | 52 } |
| 39 | 53 |
| 40 return item_view_.get(); | 54 return item_view_.get(); |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 87 views::ColumnSet* columns = layout->AddColumnSet(0); | 101 views::ColumnSet* columns = layout->AddColumnSet(0); |
| 88 columns->AddColumn(views::GridLayout::FILL, views::GridLayout::LEADING, 1, | 102 columns->AddColumn(views::GridLayout::FILL, views::GridLayout::LEADING, 1, |
| 89 views::GridLayout::USE_PREF, 0, 0); | 103 views::GridLayout::USE_PREF, 0, 0); |
| 90 | 104 |
| 91 columns->AddPaddingColumn(1, 0); | 105 columns->AddPaddingColumn(1, 0); |
| 92 | 106 |
| 93 // Add a column for the checkmark shown next to the selected profile. | 107 // Add a column for the checkmark shown next to the selected profile. |
| 94 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, 0, | 108 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, 0, |
| 95 views::GridLayout::USE_PREF, 0, 0); | 109 views::GridLayout::USE_PREF, 0, 0); |
| 96 | 110 |
| 97 // Add a column for the extra_view, which comes after the checkmark. | 111 constexpr int kExtraViewSpacing = 10; |
| 98 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, 0, | 112 std::unique_ptr<views::View> extra_view = CreateExtraView(); |
| 99 views::GridLayout::USE_PREF, 0, 0); | 113 if (extra_view) { |
| 114 columns->AddPaddingColumn(0, kExtraViewSpacing); | |
| 115 // Add a column for the extra_view, which comes after the checkmark. | |
| 116 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, | |
| 117 0, views::GridLayout::USE_PREF, 0, 0); | |
| 118 } | |
| 119 | |
|
Mathieu
2017/05/08 14:08:02
I would find it easier to reason if we had CreateE
anthonyvd
2017/05/08 14:45:54
This way avoided having to store the show_edit_but
| |
| 120 if (edit_button_) { | |
| 121 columns->AddPaddingColumn(0, kExtraViewSpacing); | |
| 122 // Add a column for the edit_button if it exists. | |
| 123 columns->AddColumn(views::GridLayout::TRAILING, views::GridLayout::CENTER, | |
| 124 0, views::GridLayout::USE_PREF, 0, 0); | |
| 125 } | |
| 100 | 126 |
| 101 layout->StartRow(0, 0); | 127 layout->StartRow(0, 0); |
| 102 content->set_can_process_events_within_subtree(false); | 128 content->set_can_process_events_within_subtree(false); |
| 103 layout->AddView(content.release()); | 129 layout->AddView(content.release()); |
| 104 | 130 |
| 105 checkmark_ = CreateCheckmark(selected()); | 131 checkmark_ = CreateCheckmark(selected()); |
| 106 layout->AddView(checkmark_.get()); | 132 layout->AddView(checkmark_.get()); |
| 107 | 133 |
| 108 std::unique_ptr<views::View> extra_view = CreateExtraView(); | |
| 109 if (extra_view) | 134 if (extra_view) |
| 110 layout->AddView(extra_view.release()); | 135 layout->AddView(extra_view.release()); |
| 111 | 136 |
| 137 if (edit_button_) | |
| 138 layout->AddView(edit_button_.get()); | |
| 139 | |
| 112 return std::move(row); | 140 return std::move(row); |
| 113 } | 141 } |
| 114 | 142 |
| 115 void PaymentRequestItemList::Item::ButtonPressed(views::Button* sender, | 143 void PaymentRequestItemList::Item::ButtonPressed(views::Button* sender, |
| 116 const ui::Event& event) { | 144 const ui::Event& event) { |
| 117 if (CanBeSelected()) { | 145 if (sender == edit_button_.get()) { |
| 146 EditButtonPressed(); | |
| 147 } else if (CanBeSelected()) { | |
| 118 list()->SelectItem(this); | 148 list()->SelectItem(this); |
| 119 } else { | 149 } else { |
| 120 PerformSelectionFallback(); | 150 PerformSelectionFallback(); |
| 121 } | 151 } |
| 122 } | 152 } |
| 123 | 153 |
| 124 PaymentRequestItemList::PaymentRequestItemList() : selected_item_(nullptr) {} | 154 PaymentRequestItemList::PaymentRequestItemList() : selected_item_(nullptr) {} |
| 125 | 155 |
| 126 PaymentRequestItemList::~PaymentRequestItemList() {} | 156 PaymentRequestItemList::~PaymentRequestItemList() {} |
| 127 | 157 |
| (...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 | 195 // 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 | 196 // 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. | 197 // selected item has been deselected but the new one isn't selected yet. |
| 168 if (selected_item_) | 198 if (selected_item_) |
| 169 selected_item_->SetSelected(/*selected=*/false, /*notify=*/true); | 199 selected_item_->SetSelected(/*selected=*/false, /*notify=*/true); |
| 170 | 200 |
| 171 selected_item_ = nullptr; | 201 selected_item_ = nullptr; |
| 172 } | 202 } |
| 173 | 203 |
| 174 } // namespace payments | 204 } // namespace payments |
| OLD | NEW |