OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/toolbar/browser_action_view.h" | 5 #include "chrome/browser/ui/views/toolbar/browser_action_view.h" |
6 | 6 |
7 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
| 8 #include "chrome/app/chrome_command_ids.h" |
8 #include "chrome/browser/chrome_notification_types.h" | 9 #include "chrome/browser/chrome_notification_types.h" |
9 #include "chrome/browser/extensions/api/commands/command_service.h" | 10 #include "chrome/browser/extensions/api/commands/command_service.h" |
10 #include "chrome/browser/extensions/extension_action.h" | 11 #include "chrome/browser/extensions/extension_action.h" |
11 #include "chrome/browser/extensions/extension_action_manager.h" | 12 #include "chrome/browser/extensions/extension_action_manager.h" |
12 #include "chrome/browser/extensions/extension_context_menu_model.h" | 13 #include "chrome/browser/extensions/extension_context_menu_model.h" |
13 #include "chrome/browser/extensions/extension_service.h" | 14 #include "chrome/browser/extensions/extension_service.h" |
14 #include "chrome/browser/profiles/profile.h" | 15 #include "chrome/browser/profiles/profile.h" |
15 #include "chrome/browser/themes/theme_service.h" | 16 #include "chrome/browser/themes/theme_service.h" |
16 #include "chrome/browser/themes/theme_service_factory.h" | 17 #include "chrome/browser/themes/theme_service_factory.h" |
| 18 #include "chrome/browser/ui/accelerator_utils.h" |
17 #include "chrome/browser/ui/browser.h" | 19 #include "chrome/browser/ui/browser.h" |
18 #include "chrome/browser/ui/view_ids.h" | 20 #include "chrome/browser/ui/view_ids.h" |
19 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h" | 21 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h" |
20 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" | 22 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" |
| 23 #include "chrome/common/extensions/manifest_handlers/ui_overrides_handler.h" |
21 #include "extensions/common/extension.h" | 24 #include "extensions/common/extension.h" |
22 #include "extensions/common/manifest_constants.h" | 25 #include "extensions/common/manifest_constants.h" |
23 #include "grit/generated_resources.h" | 26 #include "grit/generated_resources.h" |
24 #include "grit/theme_resources.h" | 27 #include "grit/theme_resources.h" |
25 #include "ui/accessibility/ax_view_state.h" | 28 #include "ui/accessibility/ax_view_state.h" |
26 #include "ui/base/l10n/l10n_util.h" | 29 #include "ui/base/l10n/l10n_util.h" |
27 #include "ui/base/resource/resource_bundle.h" | 30 #include "ui/base/resource/resource_bundle.h" |
28 #include "ui/events/event.h" | 31 #include "ui/events/event.h" |
29 #include "ui/gfx/image/image_skia.h" | 32 #include "ui/gfx/image/image_skia.h" |
30 #include "ui/gfx/image/image_skia_operations.h" | 33 #include "ui/gfx/image/image_skia_operations.h" |
(...skipping 308 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
339 | 342 |
340 void BrowserActionButton::OnGestureEvent(ui::GestureEvent* event) { | 343 void BrowserActionButton::OnGestureEvent(ui::GestureEvent* event) { |
341 if (IsPopup()) | 344 if (IsPopup()) |
342 MenuButton::OnGestureEvent(event); | 345 MenuButton::OnGestureEvent(event); |
343 else | 346 else |
344 LabelButton::OnGestureEvent(event); | 347 LabelButton::OnGestureEvent(event); |
345 } | 348 } |
346 | 349 |
347 bool BrowserActionButton::AcceleratorPressed( | 350 bool BrowserActionButton::AcceleratorPressed( |
348 const ui::Accelerator& accelerator) { | 351 const ui::Accelerator& accelerator) { |
| 352 // As a special case, if the extension removes and reassigns the bookmark |
| 353 // shortcut we don't respond here but instead allow it to be handled by the |
| 354 // standard browser command processing. This preserves the same shortcut key |
| 355 // handling of Chrome's built-in bookmarking function, which can be overridden |
| 356 // by key handling on web pages. |
| 357 if (accelerator == |
| 358 chrome::GetPrimaryChromeAcceleratorForCommandId(IDC_BOOKMARK_PAGE) && |
| 359 extensions::UIOverrides::RemovesBookmarkShortcut(extension_)) { |
| 360 return false; |
| 361 } |
| 362 |
349 delegate_->OnBrowserActionExecuted(this); | 363 delegate_->OnBrowserActionExecuted(this); |
350 return true; | 364 return true; |
351 } | 365 } |
352 | 366 |
353 void BrowserActionButton::SetButtonPushed() { | 367 void BrowserActionButton::SetButtonPushed() { |
354 SetState(views::CustomButton::STATE_PRESSED); | 368 SetState(views::CustomButton::STATE_PRESSED); |
355 menu_visible_ = true; | 369 menu_visible_ = true; |
356 } | 370 } |
357 | 371 |
358 void BrowserActionButton::SetButtonNotPushed() { | 372 void BrowserActionButton::SetButtonNotPushed() { |
(...skipping 23 matching lines...) Expand all Loading... |
382 | 396 |
383 void BrowserActionButton::MaybeRegisterExtensionCommand() { | 397 void BrowserActionButton::MaybeRegisterExtensionCommand() { |
384 extensions::CommandService* command_service = | 398 extensions::CommandService* command_service = |
385 extensions::CommandService::Get(browser_->profile()); | 399 extensions::CommandService::Get(browser_->profile()); |
386 extensions::Command browser_action_command; | 400 extensions::Command browser_action_command; |
387 if (command_service->GetBrowserActionCommand( | 401 if (command_service->GetBrowserActionCommand( |
388 extension_->id(), | 402 extension_->id(), |
389 extensions::CommandService::ACTIVE_ONLY, | 403 extensions::CommandService::ACTIVE_ONLY, |
390 &browser_action_command, | 404 &browser_action_command, |
391 NULL)) { | 405 NULL)) { |
| 406 ui::AcceleratorManager::HandlerPriority priority = |
| 407 ui::AcceleratorManager::kHighPriority; |
| 408 // Extensions overriding the bookmark shortcut need normal priority to |
| 409 // preserve the built-in processing order of the key and not override |
| 410 // WebContents key handling. |
| 411 if (browser_action_command.accelerator() == |
| 412 chrome::GetPrimaryChromeAcceleratorForCommandId(IDC_BOOKMARK_PAGE) && |
| 413 extensions::UIOverrides::RemovesBookmarkShortcut(extension_)) { |
| 414 priority = ui::AcceleratorManager::kNormalPriority; |
| 415 } |
392 keybinding_.reset(new ui::Accelerator( | 416 keybinding_.reset(new ui::Accelerator( |
393 browser_action_command.accelerator())); | 417 browser_action_command.accelerator())); |
394 GetFocusManager()->RegisterAccelerator( | 418 GetFocusManager()->RegisterAccelerator(*keybinding_.get(), priority, this); |
395 *keybinding_.get(), ui::AcceleratorManager::kHighPriority, this); | |
396 } | 419 } |
397 } | 420 } |
398 | 421 |
399 void BrowserActionButton::MaybeUnregisterExtensionCommand(bool only_if_active) { | 422 void BrowserActionButton::MaybeUnregisterExtensionCommand(bool only_if_active) { |
400 if (!keybinding_.get() || !GetFocusManager()) | 423 if (!keybinding_.get() || !GetFocusManager()) |
401 return; | 424 return; |
402 | 425 |
403 extensions::CommandService* command_service = | 426 extensions::CommandService* command_service = |
404 extensions::CommandService::Get(browser_->profile()); | 427 extensions::CommandService::Get(browser_->profile()); |
405 | 428 |
406 extensions::Command browser_action_command; | 429 extensions::Command browser_action_command; |
407 if (!only_if_active || !command_service->GetBrowserActionCommand( | 430 if (!only_if_active || !command_service->GetBrowserActionCommand( |
408 extension_->id(), | 431 extension_->id(), |
409 extensions::CommandService::ACTIVE_ONLY, | 432 extensions::CommandService::ACTIVE_ONLY, |
410 &browser_action_command, | 433 &browser_action_command, |
411 NULL)) { | 434 NULL)) { |
412 GetFocusManager()->UnregisterAccelerator(*keybinding_.get(), this); | 435 GetFocusManager()->UnregisterAccelerator(*keybinding_.get(), this); |
413 keybinding_.reset(NULL); | 436 keybinding_.reset(NULL); |
414 } | 437 } |
415 } | 438 } |
OLD | NEW |