diff options
author | sgk@google.com <sgk@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-06 03:58:38 +0000 |
---|---|---|
committer | sgk@google.com <sgk@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-06 03:58:38 +0000 |
commit | 3d4bd23ffafc9e4cdb423e0f3e524976969097e3 (patch) | |
tree | 03c134ca1c5e555ec2b7c3cd4f55b570d9b12a88 /chrome/browser | |
parent | a1c2bd30f9a04a3b1d635c4581cec51c1ed4d7cb (diff) | |
download | chromium_src-3d4bd23ffafc9e4cdb423e0f3e524976969097e3.zip chromium_src-3d4bd23ffafc9e4cdb423e0f3e524976969097e3.tar.gz chromium_src-3d4bd23ffafc9e4cdb423e0f3e524976969097e3.tar.bz2 |
Explicitly activeIgnoringOtherApps from IDC_NEW{,_INCOGNITO}_WINDOW
in app_controller_mac.mm, under the assumption we're either already
the foreground app or should become the foreground mac
(when created from the dock menu).
BUG=22595
TEST="New Window" or "New Incognito Window" from dock menu with other app in foreground
Review URL: http://codereview.chromium.org/256054
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@28091 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser')
-rw-r--r-- | chrome/browser/app_controller_mac.mm | 12 | ||||
-rw-r--r-- | chrome/browser/app_controller_mac_unittest.mm | 2 |
2 files changed, 11 insertions, 3 deletions
diff --git a/chrome/browser/app_controller_mac.mm b/chrome/browser/app_controller_mac.mm index c56aa46..a45907e 100644 --- a/chrome/browser/app_controller_mac.mm +++ b/chrome/browser/app_controller_mac.mm @@ -448,6 +448,8 @@ enable = YES; } else if (action == @selector(orderFrontStandardAboutPanel:)) { enable = YES; + } else if (action == @selector(newWindowFromDock:)) { + enable = YES; } return enable; } @@ -667,12 +669,18 @@ [aboutController_ showWindow:self]; } +// Explicitly bring to the foreground when creating new windows from the dock. +- (void)newWindowFromDock:(id)sender { + [NSApp activateIgnoringOtherApps:YES]; + [self commandDispatch:sender]; +} + - (NSMenu*)applicationDockMenu:(id)sender { NSMenu* dockMenu = [[[NSMenu alloc] initWithTitle: @""] autorelease]; NSString* titleStr = l10n_util::GetNSStringWithFixup(IDS_NEW_WINDOW_MAC); scoped_nsobject<NSMenuItem> item([[NSMenuItem alloc] initWithTitle:titleStr - action:@selector(commandDispatch:) + action:@selector(newWindowFromDock:) keyEquivalent:@""]); [item setTarget:self]; [item setTag:IDC_NEW_WINDOW]; @@ -680,7 +688,7 @@ titleStr = l10n_util::GetNSStringWithFixup(IDS_NEW_INCOGNITO_WINDOW_MAC); item.reset([[NSMenuItem alloc] initWithTitle:titleStr - action:@selector(commandDispatch:) + action:@selector(newWindowFromDock:) keyEquivalent:@""]); [item setTarget:self]; [item setTag:IDC_NEW_INCOGNITO_WINDOW]; diff --git a/chrome/browser/app_controller_mac_unittest.mm b/chrome/browser/app_controller_mac_unittest.mm index fdc444a..39cc77e 100644 --- a/chrome/browser/app_controller_mac_unittest.mm +++ b/chrome/browser/app_controller_mac_unittest.mm @@ -22,6 +22,6 @@ TEST_F(AppControllerTest, DockMenu) { EXPECT_NE(-1, [menu indexOfItemWithTag:IDC_NEW_INCOGNITO_WINDOW]); for (item in [menu itemArray]) { EXPECT_EQ(ac.get(), [item target]); - EXPECT_EQ(@selector(commandDispatch:), [item action]); + EXPECT_EQ(@selector(newWindowFromDock:), [item action]); } } |