diff options
Diffstat (limited to 'content/browser/web_contents/web_drag_dest_mac.h')
-rw-r--r-- | content/browser/web_contents/web_drag_dest_mac.h | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/content/browser/web_contents/web_drag_dest_mac.h b/content/browser/web_contents/web_drag_dest_mac.h new file mode 100644 index 0000000..0e22fa0 --- /dev/null +++ b/content/browser/web_contents/web_drag_dest_mac.h @@ -0,0 +1,79 @@ +// 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 <Cocoa/Cocoa.h> + +#include "base/string16.h" + +class WebContentsImpl; +struct WebDropData; + +namespace content { +class RenderViewHost; +class WebDragDestDelegate; +} + +// A typedef for a RenderViewHost used for comparison purposes only. +typedef content::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 WebDragDest : NSObject { + @private + // Our associated WebContentsImpl. Weak reference. + WebContentsImpl* webContents_; + + // Delegate; weak. + content::WebDragDestDelegate* delegate_; + + // 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 WebContentsImpl representing this tab, used to communicate +// drag&drop messages to WebCore and handle navigation on a successful drop +// (if necessary). +- (id)initWithWebContentsImpl:(WebContentsImpl*)contents; + +- (void)setDragDelegate:(content::WebDragDestDelegate*)delegate; + +// 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 WebDragDest(Testing) +// 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 |