// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #import "chrome/browser/ui/cocoa/bookmarks/bookmark_menu_cocoa_controller.h" #include "base/sys_string_conversions.h" #include "base/utf_string_conversions.h" #include "chrome/app/chrome_command_ids.h" // IDC_BOOKMARK_MENU #import "chrome/browser/app_controller_mac.h" #include "chrome/browser/bookmarks/bookmark_model.h" #include "chrome/browser/bookmarks/bookmark_utils.h" #include "chrome/browser/ui/browser.h" #include "chrome/browser/ui/browser_finder.h" #import "chrome/browser/ui/cocoa/bookmarks/bookmark_menu_bridge.h" #include "chrome/browser/ui/cocoa/event_utils.h" #include "content/public/browser/user_metrics.h" #include "ui/base/text/text_elider.h" using content::OpenURLParams; using content::Referrer; using content::UserMetricsAction; namespace { // Menus more than this many pixels wide will get trimmed // TODO(jrg): ask UI dudes what a good value is. const NSUInteger kMaximumMenuPixelsWide = 300; } @implementation BookmarkMenuCocoaController + (NSString*)menuTitleForNode:(const BookmarkNode*)node { NSFont* nsfont = [NSFont menuBarFontOfSize:0]; // 0 means "default" gfx::Font font(base::SysNSStringToUTF8([nsfont fontName]), static_cast([nsfont pointSize])); string16 title = ui::ElideText(node->GetTitle(), font, kMaximumMenuPixelsWide, ui::ELIDE_AT_END); return base::SysUTF16ToNSString(title); } + (NSString*)tooltipForNode:(const BookmarkNode*)node { NSString* title = base::SysUTF16ToNSString(node->GetTitle()); std::string url_string = node->url().possibly_invalid_spec(); NSString* url = [NSString stringWithUTF8String:url_string.c_str()]; if ([title length] == 0) return url; else if ([url length] == 0 || [url isEqualToString:title]) return title; else return [NSString stringWithFormat:@"%@\n%@", title, url]; } - (id)initWithBridge:(BookmarkMenuBridge *)bridge andMenu:(NSMenu*)menu { if ((self = [super init])) { bridge_ = bridge; DCHECK(bridge_); menu_ = menu; [[self menu] setDelegate:self]; } return self; } - (void)dealloc { if ([[self menu] delegate] == self) [[self menu] setDelegate:nil]; [super dealloc]; } - (NSMenu*)menu { return menu_; } - (BOOL)validateMenuItem:(NSMenuItem*)menuItem { AppController* controller = [NSApp delegate]; return [controller keyWindowIsNotModal]; } // NSMenu delegate method: called just before menu is displayed. - (void)menuNeedsUpdate:(NSMenu*)menu { bridge_->UpdateMenu(menu); } // Return the a BookmarkNode that has the given id (called // "identifier" here to avoid conflict with objc's concept of "id"). - (const BookmarkNode*)nodeForIdentifier:(int)identifier { return bridge_->GetBookmarkModel()->GetNodeByID(identifier); } // Open the URL of the given BookmarkNode in the current tab. - (void)openURLForNode:(const BookmarkNode*)node { Browser* browser = browser::FindTabbedBrowser(bridge_->GetProfile(), true); if (!browser) browser = Browser::Create(bridge_->GetProfile()); WindowOpenDisposition disposition = event_utils::WindowOpenDispositionFromNSEvent([NSApp currentEvent]); OpenURLParams params( node->url(), Referrer(), disposition, content::PAGE_TRANSITION_AUTO_BOOKMARK, false); browser->OpenURL(params); } // Open sites under BookmarkNode with the specified disposition. - (void)openAll:(NSInteger)tag withDisposition:(WindowOpenDisposition)disposition { int identifier = tag; const BookmarkNode* node = [self nodeForIdentifier:identifier]; DCHECK(node); Browser* browser = browser::FindTabbedBrowser(bridge_->GetProfile(), true); if (!browser) browser = Browser::Create(bridge_->GetProfile()); DCHECK(browser); if (!node || !browser) return; // shouldn't be reached bookmark_utils::OpenAll(NULL, browser->profile(), browser, node, disposition); if (disposition == NEW_FOREGROUND_TAB) { content::RecordAction(UserMetricsAction("OpenAllBookmarks")); } else if (disposition == NEW_WINDOW) { content::RecordAction(UserMetricsAction("OpenAllBookmarksNewWindow")); } else { content::RecordAction( UserMetricsAction("OpenAllBookmarksIncognitoWindow")); } } - (IBAction)openBookmarkMenuItem:(id)sender { NSInteger tag = [sender tag]; int identifier = tag; const BookmarkNode* node = [self nodeForIdentifier:identifier]; DCHECK(node); if (!node) return; // shouldn't be reached [self openURLForNode:node]; } - (IBAction)openAllBookmarks:(id)sender { [self openAll:[sender tag] withDisposition:NEW_FOREGROUND_TAB]; } - (IBAction)openAllBookmarksNewWindow:(id)sender { [self openAll:[sender tag] withDisposition:NEW_WINDOW]; } - (IBAction)openAllBookmarksIncognitoWindow:(id)sender { [self openAll:[sender tag] withDisposition:OFF_THE_RECORD]; } @end // BookmarkMenuCocoaController