Chromium Code Reviews| OLD | NEW |
|---|---|
| 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_VIEW_H_ |
| 6 #define CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_VIEW_H_ | 6 #define CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_VIEW_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_view_obse rver.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; | |
| 24 class PermissionCombobox; | |
| 23 class PermissionMenuButton; | 25 class PermissionMenuButton; |
| 24 } | 26 } |
| 25 | 27 |
| 26 namespace views { | 28 namespace views { |
| 29 class GridLayout; | |
| 27 class ImageView; | 30 class ImageView; |
| 28 class MenuRunner; | 31 class MenuRunner; |
| 29 } | 32 } |
| 30 | 33 |
| 31 // A custom view for selecting a permission setting for the given permission | 34 // A custom view for selecting a permission setting for the given permission |
| 32 // |type|. | 35 // |type|. |
| 33 class PermissionSelectorView : public views::View { | 36 class PermissionSelectorView : public views::View { |
| 34 public: | 37 public: |
| 35 PermissionSelectorView(const GURL& url, | 38 PermissionSelectorView(const GURL& url, |
| 36 const WebsiteSettingsUI::PermissionInfo& permission); | 39 const WebsiteSettingsUI::PermissionInfo& permission); |
| 37 | 40 |
| 38 void AddObserver(PermissionSelectorViewObserver* observer); | 41 void AddObserver(PermissionSelectorViewObserver* observer); |
| 39 | 42 |
| 40 void PermissionChanged(const WebsiteSettingsUI::PermissionInfo& permission); | 43 void PermissionChanged(const WebsiteSettingsUI::PermissionInfo& permission); |
| 41 | 44 |
| 42 protected: | 45 protected: |
| 43 // Overridden from views::View. | 46 // Overridden from views::View. |
| 44 void ChildPreferredSizeChanged(View* child) override; | 47 void ChildPreferredSizeChanged(View* child) override; |
| 45 | 48 |
| 46 private: | 49 private: |
| 47 ~PermissionSelectorView() override; | 50 ~PermissionSelectorView() override; |
| 48 | 51 |
| 52 void InitializeMenuButtonView(views::GridLayout* layout, | |
| 53 const WebsiteSettingsUI::PermissionInfo& perm); | |
|
palmer
2016/05/25 18:34:39
Nit: Identifiers in interfaces should be full word
Elly Fong-Jones
2016/05/26 13:40:38
Done.
| |
| 54 void InitializeComboboxView(views::GridLayout* layout, | |
| 55 const WebsiteSettingsUI::PermissionInfo& perm); | |
| 56 | |
| 49 // Model for the permission's menu. | 57 // Model for the permission's menu. |
| 50 std::unique_ptr<PermissionMenuModel> menu_model_; | 58 std::unique_ptr<PermissionMenuModel> menu_model_; |
| 59 std::unique_ptr<internal::ComboboxModelAdapter> combobox_model_adaptor_; | |
|
palmer
2016/05/25 18:34:39
Nit: Standardize on "adaptor" vs. "adapter". Since
Elly Fong-Jones
2016/05/26 13:40:38
Done.
| |
| 51 | 60 |
| 52 views::ImageView* icon_; // Owned by the views hierachy. | 61 views::ImageView* icon_; // Owned by the views hierachy. |
| 53 internal::PermissionMenuButton* menu_button_; // Owned by the views hierachy. | 62 internal::PermissionMenuButton* menu_button_; // Owned by the views hierachy. |
| 63 internal::PermissionCombobox* combobox_; // Owned by the views heirarchy. | |
|
palmer
2016/05/25 18:34:39
Nit: Typo: "hierarchy"
Elly Fong-Jones
2016/05/26 13:40:38
Done.
| |
| 54 | 64 |
| 55 base::ObserverList<PermissionSelectorViewObserver, false> observer_list_; | 65 base::ObserverList<PermissionSelectorViewObserver, false> observer_list_; |
| 56 | 66 |
| 57 DISALLOW_COPY_AND_ASSIGN(PermissionSelectorView); | 67 DISALLOW_COPY_AND_ASSIGN(PermissionSelectorView); |
| 58 }; | 68 }; |
| 59 | 69 |
| 60 #endif // CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_VIEW_H_ | 70 #endif // CHROME_BROWSER_UI_VIEWS_WEBSITE_SETTINGS_PERMISSION_SELECTOR_VIEW_H_ |
| OLD | NEW |