diff options
author | jennb@chromium.org <jennb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-08-24 21:07:35 +0000 |
---|---|---|
committer | jennb@chromium.org <jennb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-08-24 21:07:35 +0000 |
commit | e3edaa66ebca07e25b9c9777f2e44a19b448de8c (patch) | |
tree | e6c24ee5a55531e02f7cc5f13afbd3f9b44e4f7e /chrome/browser/ui/cocoa/browser_window_cocoa.mm | |
parent | 40ecae221cf0c26f8a3d622a041fd430a0f80563 (diff) | |
download | chromium_src-e3edaa66ebca07e25b9c9777f2e44a19b448de8c.zip chromium_src-e3edaa66ebca07e25b9c9777f2e44a19b448de8c.tar.gz chromium_src-e3edaa66ebca07e25b9c9777f2e44a19b448de8c.tar.bz2 |
Handle keyboard shortcuts in Mac Panels.
Common code from browser_window_cocoa separated into cocoa/browser_window_utils.
Panel.xib changed to make the NSWindow for the PanelWindowControllerCocoa a ChromeEventProcessingWindow.
BUG=None
TEST=Manual testing with Panels and keyboard shortcuts to find/next/previous/close window/quit chrome.
Review URL: http://codereview.chromium.org/7719016
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@98112 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/ui/cocoa/browser_window_cocoa.mm')
-rw-r--r-- | chrome/browser/ui/cocoa/browser_window_cocoa.mm | 123 |
1 files changed, 10 insertions, 113 deletions
diff --git a/chrome/browser/ui/cocoa/browser_window_cocoa.mm b/chrome/browser/ui/cocoa/browser_window_cocoa.mm index c87c61a..9ad67b9 100644 --- a/chrome/browser/ui/cocoa/browser_window_cocoa.mm +++ b/chrome/browser/ui/cocoa/browser_window_cocoa.mm @@ -11,7 +11,6 @@ #include "chrome/app/chrome_command_ids.h" #include "chrome/browser/bookmarks/bookmark_utils.h" #include "chrome/browser/download/download_shelf.h" -#include "chrome/browser/global_keyboard_shortcuts_mac.h" #include "chrome/browser/page_info_window.h" #include "chrome/browser/prefs/pref_service.h" #include "chrome/browser/profiles/profile.h" @@ -21,6 +20,7 @@ #include "chrome/browser/ui/browser_list.h" #import "chrome/browser/ui/cocoa/browser/edit_search_engine_cocoa_controller.h" #import "chrome/browser/ui/cocoa/browser_window_controller.h" +#import "chrome/browser/ui/cocoa/browser_window_utils.h" #import "chrome/browser/ui/cocoa/bug_report_window_controller.h" #import "chrome/browser/ui/cocoa/chrome_event_processing_window.h" #import "chrome/browser/ui/cocoa/content_settings/collected_cookies_mac.h" @@ -449,130 +449,27 @@ void BrowserWindowCocoa::ShowAppMenu() { bool BrowserWindowCocoa::PreHandleKeyboardEvent( const NativeWebKeyboardEvent& event, bool* is_keyboard_shortcut) { - if (event.skip_in_browser || event.type == NativeWebKeyboardEvent::Char) + if (![BrowserWindowUtils shouldHandleKeyboardEvent:event]) return false; - DCHECK(event.os_event != NULL); - int id = GetCommandId(event); + int id = [BrowserWindowUtils getCommandId:event]; if (id == -1) return false; - if (browser_->IsReservedCommandOrKey(id, event)) - return HandleKeyboardEventInternal(event.os_event); + if (browser_->IsReservedCommandOrKey(id, event)) { + return [BrowserWindowUtils handleKeyboardEvent:event.os_event + inWindow:window()]; + } - DCHECK(is_keyboard_shortcut != NULL); + DCHECK(is_keyboard_shortcut); *is_keyboard_shortcut = true; - return false; } void BrowserWindowCocoa::HandleKeyboardEvent( const NativeWebKeyboardEvent& event) { - if (event.skip_in_browser || event.type == NativeWebKeyboardEvent::Char) - return; - - DCHECK(event.os_event != NULL); - HandleKeyboardEventInternal(event.os_event); -} - -@interface MenuWalker : NSObject -+ (NSMenuItem*)itemForKeyEquivalent:(NSEvent*)key - menu:(NSMenu*)menu; -@end - -@implementation MenuWalker -+ (NSMenuItem*)itemForKeyEquivalent:(NSEvent*)key - menu:(NSMenu*)menu { - NSMenuItem* result = nil; - - for (NSMenuItem *item in [menu itemArray]) { - NSMenu* submenu = [item submenu]; - if (submenu) { - if (submenu != [NSApp servicesMenu]) - result = [self itemForKeyEquivalent:key - menu:submenu]; - } else if ([item cr_firesForKeyEventIfEnabled:key]) { - result = item; - } - - if (result) - break; - } - - return result; -} -@end - -int BrowserWindowCocoa::GetCommandId(const NativeWebKeyboardEvent& event) { - if ([event.os_event type] != NSKeyDown) - return -1; - - // Look in menu. - NSMenuItem* item = [MenuWalker itemForKeyEquivalent:event.os_event - menu:[NSApp mainMenu]]; - - if (item && [item action] == @selector(commandDispatch:) && [item tag] > 0) - return [item tag]; - - // "Close window" doesn't use the |commandDispatch:| mechanism. Menu items - // that do not correspond to IDC_ constants need no special treatment however, - // as they can't be blacklisted in |Browser::IsReservedCommandOrKey()| anyhow. - if (item && [item action] == @selector(performClose:)) - return IDC_CLOSE_WINDOW; - - // "Exit" doesn't use the |commandDispatch:| mechanism either. - if (item && [item action] == @selector(terminate:)) - return IDC_EXIT; - - // Look in secondary keyboard shortcuts. - NSUInteger modifiers = [event.os_event modifierFlags]; - const bool cmdKey = (modifiers & NSCommandKeyMask) != 0; - const bool shiftKey = (modifiers & NSShiftKeyMask) != 0; - const bool cntrlKey = (modifiers & NSControlKeyMask) != 0; - const bool optKey = (modifiers & NSAlternateKeyMask) != 0; - const int keyCode = [event.os_event keyCode]; - const unichar keyChar = KeyCharacterForEvent(event.os_event); - - int cmdNum = CommandForWindowKeyboardShortcut( - cmdKey, shiftKey, cntrlKey, optKey, keyCode, keyChar); - if (cmdNum != -1) - return cmdNum; - - cmdNum = CommandForBrowserKeyboardShortcut( - cmdKey, shiftKey, cntrlKey, optKey, keyCode, keyChar); - if (cmdNum != -1) - return cmdNum; - - return -1; -} - -bool BrowserWindowCocoa::HandleKeyboardEventInternal(NSEvent* event) { - ChromeEventProcessingWindow* event_window = - static_cast<ChromeEventProcessingWindow*>(window()); - DCHECK([event_window isKindOfClass:[ChromeEventProcessingWindow class]]); - - // Do not fire shortcuts on key up. - if ([event type] == NSKeyDown) { - // Send the event to the menu before sending it to the browser/window - // shortcut handling, so that if a user configures cmd-left to mean - // "previous tab", it takes precedence over the built-in "history back" - // binding. Other than that, the |-redispatchKeyEvent:| call would take care - // of invoking the original menu item shortcut as well. - - if ([[NSApp mainMenu] performKeyEquivalent:event]) - return true; - - if ([event_window handleExtraBrowserKeyboardShortcut:event]) - return true; - - if ([event_window handleExtraWindowKeyboardShortcut:event]) - return true; - - if ([event_window handleDelayedWindowKeyboardShortcut:event]) - return true; - } - - return [event_window redispatchKeyEvent:event]; + if ([BrowserWindowUtils shouldHandleKeyboardEvent:event]) + [BrowserWindowUtils handleKeyboardEvent:event.os_event inWindow:window()]; } void BrowserWindowCocoa::ShowCreateWebAppShortcutsDialog( |