summaryrefslogtreecommitdiffstats
path: root/chrome/browser/cocoa/bookmarks/bookmark_folder_target.mm
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/cocoa/bookmarks/bookmark_folder_target.mm')
-rw-r--r--chrome/browser/cocoa/bookmarks/bookmark_folder_target.mm118
1 files changed, 0 insertions, 118 deletions
diff --git a/chrome/browser/cocoa/bookmarks/bookmark_folder_target.mm b/chrome/browser/cocoa/bookmarks/bookmark_folder_target.mm
deleted file mode 100644
index 3fb1507..0000000
--- a/chrome/browser/cocoa/bookmarks/bookmark_folder_target.mm
+++ /dev/null
@@ -1,118 +0,0 @@
-// Copyright (c) 2010 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/cocoa/bookmarks/bookmark_folder_target.h"
-
-#include "base/logging.h"
-#include "base/sys_string_conversions.h"
-#include "chrome/browser/bookmarks/bookmark_model.h"
-#import "chrome/browser/cocoa/bookmarks/bookmark_bar_folder_controller.h"
-#import "chrome/browser/cocoa/bookmarks/bookmark_button.h"
-#import "chrome/browser/cocoa/event_utils.h"
-#import "third_party/mozilla/NSPasteboard+Utils.h"
-
-NSString* kBookmarkButtonDragType = @"ChromiumBookmarkButtonDragType";
-
-@implementation BookmarkFolderTarget
-
-- (id)initWithController:(id<BookmarkButtonControllerProtocol>)controller {
- if ((self = [super init])) {
- controller_ = controller;
- }
- return self;
-}
-
-// This IBAction is called when the user clicks (mouseUp, really) on a
-// "folder" bookmark button. (In this context, "Click" does not
-// include right-click to open a context menu which follows a
-// different path). Scenarios when folder X is clicked:
-// *Predicate* *Action*
-// (nothing) Open Folder X
-// Folder X open Close folder X
-// Folder Y open Close Y, open X
-// Cmd-click Open All with proper disposition
-//
-// Note complication in which a click-drag engages drag and drop, not
-// a click-to-open. Thus the path to get here is a little twisted.
-- (IBAction)openBookmarkFolderFromButton:(id)sender {
- DCHECK(sender);
- // Watch out for a modifier click. For example, command-click
- // should open all.
- //
- // NOTE: we cannot use [[sender cell] mouseDownFlags] because we
- // thwart the normal mouse click mechanism to make buttons
- // draggable. Thus we must use [NSApp currentEvent].
- //
- // Holding command while using the scroll wheel (or moving around
- // over a bookmark folder) can confuse us. Unless we check the
- // event type, we are not sure if this is an "open folder" due to a
- // hover-open or "open folder" due to a click. It doesn't matter
- // (both do the same thing) unless a modifier is held, since
- // command-click should "open all" but command-move should not.
- // WindowOpenDispositionFromNSEvent does not consider the event
- // type; only the modifiers. Thus the need for an extra
- // event-type-check here.
- DCHECK([sender bookmarkNode]->is_folder());
- NSEvent* event = [NSApp currentEvent];
- WindowOpenDisposition disposition =
- event_utils::WindowOpenDispositionFromNSEvent(event);
- if (([event type] != NSMouseEntered) &&
- ([event type] != NSMouseMoved) &&
- ([event type] != NSScrollWheel) &&
- (disposition == NEW_BACKGROUND_TAB)) {
- [controller_ closeAllBookmarkFolders];
- [controller_ openAll:[sender bookmarkNode] disposition:disposition];
- return;
- }
-
- // If click on same folder, close it and be done.
- // Else we clicked on a different folder so more work to do.
- if ([[controller_ folderController] parentButton] == sender) {
- [controller_ closeBookmarkFolder:controller_];
- return;
- }
-
- [controller_ addNewFolderControllerWithParentButton:sender];
-}
-
-- (void)copyBookmarkNode:(const BookmarkNode*)node
- toPasteboard:(NSPasteboard*)pboard {
- if (!node) {
- NOTREACHED();
- return;
- }
-
- if (node->is_folder()) {
- // TODO(viettrungluu): I'm not sure what we should do, so just declare the
- // "additional" types we're given for now. Maybe we want to add a list of
- // URLs? Would we then have to recurse if there were subfolders?
- // In the meanwhile, we *must* set it to a known state. (If this survives to
- // a 10.6-only release, it can be replaced with |-clearContents|.)
- [pboard declareTypes:[NSArray array] owner:nil];
- } else {
- const std::string spec = node->GetURL().spec();
- NSString* url = base::SysUTF8ToNSString(spec);
- NSString* title = base::SysUTF16ToNSString(node->GetTitle());
- [pboard declareURLPasteboardWithAdditionalTypes:[NSArray array]
- owner:nil];
- [pboard setDataForURL:url title:title];
- }
-}
-
-- (void)fillPasteboard:(NSPasteboard*)pboard
- forDragOfButton:(BookmarkButton*)button {
- if (const BookmarkNode* node = [button bookmarkNode]) {
- // Put the bookmark information into the pasteboard, and then write our own
- // data for |kBookmarkButtonDragType|.
- [self copyBookmarkNode:node toPasteboard:pboard];
- [pboard addTypes:[NSArray arrayWithObject:kBookmarkButtonDragType]
- owner:nil];
- [pboard setData:[NSData dataWithBytes:&button length:sizeof(button)]
- forType:kBookmarkButtonDragType];
- } else {
- NOTREACHED();
- }
-}
-
-@end