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

Side by Side Diff: chrome/browser/ui/views/website_settings/permission_selector_row.h

Issue 2272793007: Material Page Info (Views, 1/3): Rename {ChosenObject, PermissionSelector}View classes to {...}Row. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address comments. Created 4 years, 3 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 (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 #ifndef CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_VIEW_H_ 5 #ifndef CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_ROW_H_
6 #define CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_VIEW_H_ 6 #define CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_ROW_H_
7 7
8 #include <memory> 8 #include <memory>
9 9
10 #include "base/compiler_specific.h" 10 #include "base/compiler_specific.h"
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "base/observer_list.h" 12 #include "base/observer_list.h"
13 #include "base/strings/string16.h" 13 #include "base/strings/string16.h"
14 #include "chrome/browser/ui/views/website_settings/permission_selector_view_obse rver.h" 14 #include "chrome/browser/ui/views/website_settings/permission_selector_row_obser ver.h"
15 #include "chrome/browser/ui/website_settings/permission_menu_model.h" 15 #include "chrome/browser/ui/website_settings/permission_menu_model.h"
16 #include "chrome/browser/ui/website_settings/website_settings_ui.h" 16 #include "chrome/browser/ui/website_settings/website_settings_ui.h"
17 #include "components/content_settings/core/common/content_settings.h" 17 #include "components/content_settings/core/common/content_settings.h"
18 #include "components/content_settings/core/common/content_settings_types.h" 18 #include "components/content_settings/core/common/content_settings_types.h"
19 #include "ui/views/controls/button/menu_button_listener.h" 19 #include "ui/views/controls/button/menu_button_listener.h"
20 #include "ui/views/view.h" 20 #include "ui/views/view.h"
21 21
22 namespace internal { 22 namespace internal {
23 class ComboboxModelAdapter; 23 class ComboboxModelAdapter;
24 class PermissionCombobox; 24 class PermissionCombobox;
25 class PermissionMenuButton; 25 class PermissionMenuButton;
26 } 26 }
27 27
28 namespace views { 28 namespace views {
29 class GridLayout; 29 class GridLayout;
30 class ImageView; 30 class ImageView;
31 class MenuRunner; 31 class MenuRunner;
32 } 32 }
33 33
34 // A custom view for selecting a permission setting for the given permission 34 // A PermissionSelectorRow is a row in the Page Info bubble that shows a
35 // |type|. 35 // permission that a site can have ambient access to, and allows the user to
36 class PermissionSelectorView : public views::View { 36 // control whether that access is granted.
37 class PermissionSelectorRow : public views::View {
37 public: 38 public:
38 PermissionSelectorView(const GURL& url, 39 PermissionSelectorRow(const GURL& url,
39 const WebsiteSettingsUI::PermissionInfo& permission); 40 const WebsiteSettingsUI::PermissionInfo& permission);
40 41
41 void AddObserver(PermissionSelectorViewObserver* observer); 42 void AddObserver(PermissionSelectorRowObserver* observer);
42 43
43 void PermissionChanged(const WebsiteSettingsUI::PermissionInfo& permission); 44 void PermissionChanged(const WebsiteSettingsUI::PermissionInfo& permission);
44 45
45 protected: 46 protected:
46 // Overridden from views::View. 47 // Overridden from views::View.
47 void ChildPreferredSizeChanged(View* child) override; 48 void ChildPreferredSizeChanged(View* child) override;
48 49
49 private: 50 private:
50 ~PermissionSelectorView() override; 51 ~PermissionSelectorRow() override;
51 52
52 void InitializeMenuButtonView( 53 void InitializeMenuButtonView(
53 views::GridLayout* layout, 54 views::GridLayout* layout,
54 const WebsiteSettingsUI::PermissionInfo& permission); 55 const WebsiteSettingsUI::PermissionInfo& permission);
55 void InitializeComboboxView( 56 void InitializeComboboxView(
56 views::GridLayout* layout, 57 views::GridLayout* layout,
57 const WebsiteSettingsUI::PermissionInfo& permission); 58 const WebsiteSettingsUI::PermissionInfo& permission);
58 59
59 // Model for the permission's menu. 60 // Model for the permission's menu.
60 std::unique_ptr<PermissionMenuModel> menu_model_; 61 std::unique_ptr<PermissionMenuModel> menu_model_;
61 std::unique_ptr<internal::ComboboxModelAdapter> combobox_model_adapter_; 62 std::unique_ptr<internal::ComboboxModelAdapter> combobox_model_adapter_;
62 63
63 views::ImageView* icon_; // Owned by the views hierachy. 64 views::ImageView* icon_; // Owned by the views hierachy.
felt 2016/09/06 20:03:53 tiny nit: can you pls be consistent here with alig
lgarron 2016/09/07 06:55:26 It seems there were a bunch of rebased-induced for
64 internal::PermissionMenuButton* menu_button_; // Owned by the views hierachy. 65 internal::PermissionMenuButton* menu_button_; // Owned by the views hierachy.
65 internal::PermissionCombobox* combobox_; // Owned by the views hierarchy. 66 internal::PermissionCombobox* combobox_; // Owned by the views hierarchy.
66 67
67 base::ObserverList<PermissionSelectorViewObserver, false> observer_list_; 68 base::ObserverList<PermissionSelectorRowObserver, false> observer_list_;
68 69
69 DISALLOW_COPY_AND_ASSIGN(PermissionSelectorView); 70 DISALLOW_COPY_AND_ASSIGN(PermissionSelectorRow);
70 }; 71 };
71 72
72 #endif // CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_VIEW_H_ 73 #endif // CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_ROW_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698