Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/website_settings/chosen_object_row.h" | 5 #include "chrome/browser/ui/views/website_settings/chosen_object_row.h" |
| 6 | 6 |
| 7 #include "chrome/browser/ui/views/website_settings/chosen_object_row_observer.h" | 7 #include "chrome/browser/ui/views/website_settings/chosen_object_row_observer.h" |
| 8 #include "chrome/browser/ui/views/website_settings/website_settings_popup_view.h " | 8 #include "chrome/browser/ui/views/website_settings/website_settings_popup_view.h " |
| 9 #include "ui/base/l10n/l10n_util.h" | 9 #include "ui/base/l10n/l10n_util.h" |
| 10 #include "ui/base/resource/resource_bundle.h" | 10 #include "ui/base/resource/resource_bundle.h" |
| 11 #include "ui/gfx/font_list.h" | |
| 11 #include "ui/resources/grit/ui_resources.h" | 12 #include "ui/resources/grit/ui_resources.h" |
| 12 #include "ui/views/controls/button/image_button.h" | 13 #include "ui/views/controls/button/image_button.h" |
| 13 #include "ui/views/controls/image_view.h" | 14 #include "ui/views/controls/image_view.h" |
| 14 #include "ui/views/controls/label.h" | 15 #include "ui/views/controls/label.h" |
| 16 #include "ui/views/layout/box_layout.h" | |
| 15 #include "ui/views/layout/grid_layout.h" | 17 #include "ui/views/layout/grid_layout.h" |
| 16 | 18 |
| 17 ChosenObjectRow::ChosenObjectRow( | 19 ChosenObjectRow::ChosenObjectRow( |
| 18 std::unique_ptr<WebsiteSettingsUI::ChosenObjectInfo> info) | 20 std::unique_ptr<WebsiteSettingsUI::ChosenObjectInfo> info, |
| 21 views::GridLayout* layout) | |
| 19 : info_(std::move(info)) { | 22 : info_(std::move(info)) { |
| 20 views::GridLayout* layout = new views::GridLayout(this); | |
| 21 SetLayoutManager(layout); | |
| 22 const int column_set_id = 0; | |
| 23 views::ColumnSet* column_set = layout->AddColumnSet(column_set_id); | |
| 24 column_set->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL, 1, | |
| 25 views::GridLayout::FIXED, kPermissionIconColumnWidth, | |
| 26 0); | |
| 27 column_set->AddPaddingColumn(0, kPermissionIconMarginLeft); | |
| 28 column_set->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL, 1, | |
| 29 views::GridLayout::USE_PREF, 0, 0); | |
| 30 column_set->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL, 1, | |
| 31 views::GridLayout::USE_PREF, 0, 0); | |
| 32 | |
| 33 layout->StartRow(1, column_set_id); | |
| 34 // Create the permission icon. | 23 // Create the permission icon. |
| 35 icon_ = new views::ImageView(); | 24 icon_ = new views::ImageView(); |
| 36 const gfx::Image& image = | 25 const gfx::Image& image = |
| 37 WebsiteSettingsUI::GetChosenObjectIcon(*info_, false); | 26 WebsiteSettingsUI::GetChosenObjectIcon(*info_, false); |
| 38 icon_->SetImage(image.ToImageSkia()); | 27 icon_->SetImage(image.ToImageSkia()); |
| 39 layout->AddView(icon_, 1, 1, views::GridLayout::CENTER, | 28 layout->AddView(icon_); |
| 40 views::GridLayout::CENTER); | 29 |
| 30 label_with_delete_ = new views::View(); | |
|
msw
2016/09/26 20:47:55
Why create a view to contain the label and the del
lgarron
2016/09/28 21:11:45
They could be added directly, but then I'd need to
msw
2016/09/30 00:37:04
It'd be nice to avoid unnecessary containers, but
lgarron
2016/09/30 05:05:55
Acknowledged.
| |
| 31 views::BoxLayout* box_layout = | |
| 32 new views::BoxLayout(views::BoxLayout::kHorizontal, 0, 0, 5); | |
|
msw
2016/09/26 20:47:55
optional nit: use a views layout constant (kRelate
lgarron
2016/09/28 21:11:45
Thanks for the tip; I've changed to views::kRelate
| |
| 33 box_layout->set_cross_axis_alignment( | |
| 34 views::BoxLayout::CROSS_AXIS_ALIGNMENT_END); | |
| 35 label_with_delete_->SetLayoutManager(box_layout); | |
| 36 | |
| 41 // Create the label that displays the permission type. | 37 // Create the label that displays the permission type. |
| 42 views::Label* label = new views::Label(l10n_util::GetStringFUTF16( | 38 const gfx::FontList& font_list = |
| 43 info_->ui_info.label_string_id, | 39 ui::ResourceBundle::GetSharedInstance().GetFontListWithDelta(1); |
|
msw
2016/09/26 20:47:55
I find it odd to just toss around 1px taller fonts
lgarron
2016/09/28 21:11:45
Brought it up with Max (designer) and Emily (PM) a
| |
| 44 WebsiteSettingsUI::ChosenObjectToUIString(*info_))); | 40 views::Label* label = |
| 45 layout->AddView(label, 1, 1, views::GridLayout::LEADING, | 41 new views::Label(l10n_util::GetStringFUTF16( |
| 46 views::GridLayout::CENTER); | 42 info_->ui_info.label_string_id, |
| 43 WebsiteSettingsUI::ChosenObjectToUIString(*info_)), | |
| 44 font_list); | |
| 45 label_with_delete_->AddChildView(label); | |
| 46 | |
| 47 // Create the delete button. | 47 // Create the delete button. |
| 48 delete_button_ = new views::ImageButton(this); | 48 delete_button_ = new views::ImageButton(this); |
| 49 delete_button_->SetFocusForPlatform(); | 49 delete_button_->SetFocusForPlatform(); |
| 50 delete_button_->set_request_focus_on_press(true); | 50 delete_button_->set_request_focus_on_press(true); |
| 51 delete_button_->SetTooltipText( | 51 delete_button_->SetTooltipText( |
| 52 l10n_util::GetStringUTF16(info_->ui_info.delete_tooltip_string_id)); | 52 l10n_util::GetStringUTF16(info_->ui_info.delete_tooltip_string_id)); |
| 53 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); | 53 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
| 54 delete_button_->SetImage(views::ImageButton::STATE_NORMAL, | 54 delete_button_->SetImage(views::ImageButton::STATE_NORMAL, |
| 55 rb.GetImageSkiaNamed(IDR_CLOSE_2)); | 55 rb.GetImageSkiaNamed(IDR_CLOSE_2)); |
| 56 delete_button_->SetImage(views::ImageButton::STATE_HOVERED, | 56 delete_button_->SetImage(views::ImageButton::STATE_HOVERED, |
| 57 rb.GetImageSkiaNamed(IDR_CLOSE_2_H)); | 57 rb.GetImageSkiaNamed(IDR_CLOSE_2_H)); |
| 58 delete_button_->SetImage(views::ImageButton::STATE_PRESSED, | 58 delete_button_->SetImage(views::ImageButton::STATE_PRESSED, |
| 59 rb.GetImageSkiaNamed(IDR_CLOSE_2_P)); | 59 rb.GetImageSkiaNamed(IDR_CLOSE_2_P)); |
| 60 layout->AddView(delete_button_, 1, 1, views::GridLayout::LEADING, | 60 label_with_delete_->AddChildView(delete_button_); |
| 61 views::GridLayout::CENTER); | 61 layout->AddView(label_with_delete_); |
| 62 } | 62 } |
| 63 | 63 |
| 64 void ChosenObjectRow::AddObserver(ChosenObjectRowObserver* observer) { | 64 void ChosenObjectRow::AddObserver(ChosenObjectRowObserver* observer) { |
| 65 observer_list_.AddObserver(observer); | 65 observer_list_.AddObserver(observer); |
| 66 } | 66 } |
| 67 | 67 |
| 68 ChosenObjectRow::~ChosenObjectRow() {} | 68 ChosenObjectRow::~ChosenObjectRow() {} |
| 69 | 69 |
| 70 void ChosenObjectRow::ButtonPressed(views::Button* sender, | 70 void ChosenObjectRow::ButtonPressed(views::Button* sender, |
| 71 const ui::Event& event) { | 71 const ui::Event& event) { |
| 72 // Change the icon to reflect the selected setting. | 72 // Change the icon to reflect the selected setting. |
| 73 const gfx::Image& image = | 73 const gfx::Image& image = |
| 74 WebsiteSettingsUI::GetChosenObjectIcon(*info_, true); | 74 WebsiteSettingsUI::GetChosenObjectIcon(*info_, true); |
| 75 icon_->SetImage(image.ToImageSkia()); | 75 icon_->SetImage(image.ToImageSkia()); |
| 76 | 76 |
| 77 RemoveChildView(delete_button_); | 77 label_with_delete_->RemoveChildView(delete_button_); |
| 78 delete delete_button_; | 78 delete delete_button_; |
| 79 delete_button_ = nullptr; | 79 delete_button_ = nullptr; |
| 80 | 80 |
| 81 FOR_EACH_OBSERVER(ChosenObjectRowObserver, observer_list_, | 81 FOR_EACH_OBSERVER(ChosenObjectRowObserver, observer_list_, |
| 82 OnChosenObjectDeleted(*info_)); | 82 OnChosenObjectDeleted(*info_)); |
| 83 } | 83 } |
| OLD | NEW |