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 #include "chrome/browser/ui/views/website_settings/permission_selector_view.h" | 5 #include "chrome/browser/ui/views/website_settings/permission_selector_view.h" |
| 6 | 6 |
| 7 #include "base/i18n/rtl.h" | 7 #include "base/i18n/rtl.h" |
| 8 #include "base/macros.h" | 8 #include "base/macros.h" |
| 9 #include "base/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
| 10 #include "chrome/browser/ui/website_settings/permission_menu_model.h" | 10 #include "chrome/browser/ui/website_settings/permission_menu_model.h" |
| 11 #include "chrome/browser/ui/website_settings/website_settings_ui.h" | 11 #include "chrome/browser/ui/website_settings/website_settings_ui.h" |
| 12 #include "chrome/grit/generated_resources.h" | 12 #include "chrome/grit/generated_resources.h" |
| 13 #include "components/content_settings/core/browser/content_settings_info.h" | |
| 14 #include "components/content_settings/core/browser/content_settings_registry.h" | |
| 13 #include "ui/accessibility/ax_view_state.h" | 15 #include "ui/accessibility/ax_view_state.h" |
| 14 #include "ui/base/l10n/l10n_util.h" | 16 #include "ui/base/l10n/l10n_util.h" |
| 15 #include "ui/gfx/image/image.h" | 17 #include "ui/gfx/image/image.h" |
| 16 #include "ui/views/controls/button/menu_button.h" | 18 #include "ui/views/controls/button/menu_button.h" |
| 17 #include "ui/views/controls/image_view.h" | 19 #include "ui/views/controls/image_view.h" |
| 18 #include "ui/views/controls/label.h" | 20 #include "ui/views/controls/label.h" |
| 19 #include "ui/views/controls/menu/menu_runner.h" | 21 #include "ui/views/controls/menu/menu_runner.h" |
| 20 #include "ui/views/layout/grid_layout.h" | 22 #include "ui/views/layout/grid_layout.h" |
| 21 #include "ui/views/view.h" | 23 #include "ui/views/view.h" |
| 22 #include "ui/views/widget/widget.h" | 24 #include "ui/views/widget/widget.h" |
| (...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 117 } | 119 } |
| 118 | 120 |
| 119 } // namespace internal | 121 } // namespace internal |
| 120 | 122 |
| 121 /////////////////////////////////////////////////////////////////////////////// | 123 /////////////////////////////////////////////////////////////////////////////// |
| 122 // PermissionSelectorView | 124 // PermissionSelectorView |
| 123 /////////////////////////////////////////////////////////////////////////////// | 125 /////////////////////////////////////////////////////////////////////////////// |
| 124 | 126 |
| 125 PermissionSelectorView::PermissionSelectorView( | 127 PermissionSelectorView::PermissionSelectorView( |
| 126 const GURL& url, | 128 const GURL& url, |
| 127 const WebsiteSettingsUI::PermissionInfo& permission) | 129 const WebsiteSettingsUI::PermissionInfo& permission, |
| 130 bool is_incognito) | |
| 128 : icon_(NULL), menu_button_(NULL) { | 131 : icon_(NULL), menu_button_(NULL) { |
| 129 views::GridLayout* layout = new views::GridLayout(this); | 132 views::GridLayout* layout = new views::GridLayout(this); |
| 130 SetLayoutManager(layout); | 133 SetLayoutManager(layout); |
| 131 const int column_set_id = 0; | 134 const int column_set_id = 0; |
| 132 views::ColumnSet* column_set = layout->AddColumnSet(column_set_id); | 135 views::ColumnSet* column_set = layout->AddColumnSet(column_set_id); |
| 133 column_set->AddColumn(views::GridLayout::FILL, | 136 column_set->AddColumn(views::GridLayout::FILL, |
| 134 views::GridLayout::FILL, | 137 views::GridLayout::FILL, |
| 135 1, | 138 1, |
| 136 views::GridLayout::FIXED, | 139 views::GridLayout::FIXED, |
| 137 kPermissionIconColumnWidth, | 140 kPermissionIconColumnWidth, |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 171 views::GridLayout::CENTER); | 174 views::GridLayout::CENTER); |
| 172 // Create the menu model. | 175 // Create the menu model. |
| 173 menu_model_.reset(new PermissionMenuModel( | 176 menu_model_.reset(new PermissionMenuModel( |
| 174 url, | 177 url, |
| 175 permission, | 178 permission, |
| 176 base::Bind(&PermissionSelectorView::PermissionChanged, | 179 base::Bind(&PermissionSelectorView::PermissionChanged, |
| 177 base::Unretained(this)))); | 180 base::Unretained(this)))); |
| 178 // Create the permission menu button. | 181 // Create the permission menu button. |
| 179 bool button_enabled = | 182 bool button_enabled = |
| 180 permission.source == content_settings::SETTING_SOURCE_USER; | 183 permission.source == content_settings::SETTING_SOURCE_USER; |
| 184 if (is_incognito) { | |
| 185 const content_settings::ContentSettingsInfo* info = | |
| 186 content_settings::ContentSettingsRegistry::GetInstance()->Get( | |
| 187 permission.type); | |
| 188 if (info && | |
| 189 info->incognito_behavior() == content_settings::ContentSettingsInfo:: | |
| 190 DENY_IN_INCOGNITO_AFTER_DELAY) { | |
|
palmer
2016/01/11 20:28:08
Is this the formatting that "git cl format" chose?
johnme
2016/01/12 18:04:52
Yes, I think so. I've refactored this anyway thoug
| |
| 191 // This permission is disabled in incognito. Don't let user enable it. | |
| 192 button_enabled = false; | |
| 193 } | |
| 194 } | |
| 181 menu_button_ = new internal::PermissionMenuButton( | 195 menu_button_ = new internal::PermissionMenuButton( |
| 182 WebsiteSettingsUI::PermissionActionToUIString( | 196 WebsiteSettingsUI::PermissionActionToUIString( |
| 183 permission.type, permission.setting, permission.default_setting, | 197 permission.type, permission.setting, permission.default_setting, |
| 184 permission.source), | 198 permission.source), |
| 185 menu_model_.get(), button_enabled); | 199 menu_model_.get(), button_enabled); |
| 186 menu_button_->SetEnabled(button_enabled); | 200 menu_button_->SetEnabled(button_enabled); |
| 187 menu_button_->SetFocusable(button_enabled); | 201 menu_button_->SetFocusable(button_enabled); |
| 188 menu_button_->SetAccessibleName( | 202 menu_button_->SetAccessibleName( |
| 189 WebsiteSettingsUI::PermissionTypeToUIString(permission.type)); | 203 WebsiteSettingsUI::PermissionTypeToUIString(permission.type)); |
| 190 layout->AddView(menu_button_); | 204 layout->AddView(menu_button_); |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 216 // Update the menu button text to reflect the new setting. | 230 // Update the menu button text to reflect the new setting. |
| 217 menu_button_->SetText(WebsiteSettingsUI::PermissionActionToUIString( | 231 menu_button_->SetText(WebsiteSettingsUI::PermissionActionToUIString( |
| 218 permission.type, permission.setting, permission.default_setting, | 232 permission.type, permission.setting, permission.default_setting, |
| 219 content_settings::SETTING_SOURCE_USER)); | 233 content_settings::SETTING_SOURCE_USER)); |
| 220 menu_button_->SizeToPreferredSize(); | 234 menu_button_->SizeToPreferredSize(); |
| 221 | 235 |
| 222 FOR_EACH_OBSERVER(PermissionSelectorViewObserver, | 236 FOR_EACH_OBSERVER(PermissionSelectorViewObserver, |
| 223 observer_list_, | 237 observer_list_, |
| 224 OnPermissionChanged(permission)); | 238 OnPermissionChanged(permission)); |
| 225 } | 239 } |
| OLD | NEW |