diff options
author | ben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-12-01 16:34:49 +0000 |
---|---|---|
committer | ben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-12-01 16:34:49 +0000 |
commit | 7d791652c7ede4209a2014d885148e2713f49bce (patch) | |
tree | c26baf12593bed381c631b81c736106809d46b44 /chrome/browser/ui/cocoa/web_drop_target.h | |
parent | 3b94427c99bdf12836fd455eeb1499fdde511e26 (diff) | |
download | chromium_src-7d791652c7ede4209a2014d885148e2713f49bce.zip chromium_src-7d791652c7ede4209a2014d885148e2713f49bce.tar.gz chromium_src-7d791652c7ede4209a2014d885148e2713f49bce.tar.bz2 |
Move browser/cocoa to browser/ui/cocoa
BUG=none
TEST=none
TBR=brettw
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@67854 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/ui/cocoa/web_drop_target.h')
-rw-r--r-- | chrome/browser/ui/cocoa/web_drop_target.h | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/chrome/browser/ui/cocoa/web_drop_target.h b/chrome/browser/ui/cocoa/web_drop_target.h new file mode 100644 index 0000000..7f18ccf --- /dev/null +++ b/chrome/browser/ui/cocoa/web_drop_target.h @@ -0,0 +1,80 @@ +// Copyright (c) 2009 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 <Cocoa/Cocoa.h> + +#include "base/string16.h" + +class GURL; +class RenderViewHost; +class TabContents; +struct WebDropData; + +// A typedef for a RenderViewHost used for comparison purposes only. +typedef RenderViewHost* RenderViewHostIdentifier; + +// A class that handles tracking and event processing for a drag and drop +// over the content area. Assumes something else initiates the drag, this is +// only for processing during a drag. + +@interface WebDropTarget : NSObject { + @private + // Our associated TabContents. Weak reference. + TabContents* tabContents_; + + // Updated asynchronously during a drag to tell us whether or not we should + // allow the drop. + NSDragOperation current_operation_; + + // Keep track of the render view host we're dragging over. If it changes + // during a drag, we need to re-send the DragEnter message. + RenderViewHostIdentifier currentRVH_; +} + +// |contents| is the TabContents representing this tab, used to communicate +// drag&drop messages to WebCore and handle navigation on a successful drop +// (if necessary). +- (id)initWithTabContents:(TabContents*)contents; + +// Sets the current operation negotiated by the source and destination, +// which determines whether or not we should allow the drop. Takes effect the +// next time |-draggingUpdated:| is called. +- (void)setCurrentOperation: (NSDragOperation)operation; + +// Messages to send during the tracking of a drag, ususally upon receiving +// calls from the view system. Communicates the drag messages to WebCore. +- (NSDragOperation)draggingEntered:(id<NSDraggingInfo>)info + view:(NSView*)view; +- (void)draggingExited:(id<NSDraggingInfo>)info; +- (NSDragOperation)draggingUpdated:(id<NSDraggingInfo>)info + view:(NSView*)view; +- (BOOL)performDragOperation:(id<NSDraggingInfo>)info + view:(NSView*)view; + +@end + +// Public use only for unit tests. +@interface WebDropTarget(Testing) +// Populate the |url| and |title| with URL data in |pboard|. There may be more +// than one, but we only handle dropping the first. |url| must not be |NULL|; +// |title| is an optional parameter. Returns |YES| if URL data was obtained from +// the pasteboard, |NO| otherwise. If |convertFilenames| is |YES|, the function +// will also attempt to convert filenames in |pboard| to file URLs. +- (BOOL)populateURL:(GURL*)url + andTitle:(string16*)title + fromPasteboard:(NSPasteboard*)pboard + convertingFilenames:(BOOL)convertFilenames; +// Given |data|, which should not be nil, fill it in using the contents of the +// given pasteboard. +- (void)populateWebDropData:(WebDropData*)data + fromPasteboard:(NSPasteboard*)pboard; +// Given a point in window coordinates and a view in that window, return a +// flipped point in the coordinate system of |view|. +- (NSPoint)flipWindowPointToView:(const NSPoint&)windowPoint + view:(NSView*)view; +// Given a point in window coordinates and a view in that window, return a +// flipped point in screen coordinates. +- (NSPoint)flipWindowPointToScreen:(const NSPoint&)windowPoint + view:(NSView*)view; +@end |