From 5f8de423f190bbb79a62f804151bc24824fa32d8 Mon Sep 17 00:00:00 2001 From: "Matt A. Tobin" Date: Fri, 2 Feb 2018 04:16:08 -0500 Subject: Add m-esr52 at 52.6.0 --- dom/base/nsContentAreaDragDrop.h | 81 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 81 insertions(+) create mode 100644 dom/base/nsContentAreaDragDrop.h (limited to 'dom/base/nsContentAreaDragDrop.h') diff --git a/dom/base/nsContentAreaDragDrop.h b/dom/base/nsContentAreaDragDrop.h new file mode 100644 index 000000000..b62132efa --- /dev/null +++ b/dom/base/nsContentAreaDragDrop.h @@ -0,0 +1,81 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + + +#ifndef nsContentAreaDragDrop_h__ +#define nsContentAreaDragDrop_h__ + + +#include "nsCOMPtr.h" + +#include "nsIDOMEventListener.h" +#include "nsITransferable.h" + +class nsPIDOMWindowOuter; +class nsISelection; +class nsITransferable; +class nsIContent; +class nsIFile; + +namespace mozilla { +namespace dom { +class DataTransfer; +} // namespace dom +} // namespace mozilla + +// +// class nsContentAreaDragDrop, used to generate the dragdata +// +class nsContentAreaDragDrop +{ +public: + + /** + * Determine what data in the content area, if any, is being dragged. + * + * aWindow - the window containing the target node + * aTarget - the mousedown event target that started the drag + * aSelectionTargetNode - the node where the drag event should be fired + * aIsAltKeyPressed - true if the Alt key is pressed. In some cases, this + * will prevent the drag from occuring. For example, + * holding down Alt over a link should select the text, + * not drag the link. + * aDataTransfer - the dataTransfer for the drag event. + * aCanDrag - [out] set to true if the drag may proceed, false to stop the + * drag entirely + * aSelection - [out] set to the selection being dragged, or null if no + * selection is being dragged. + * aDragNode - [out] the link, image or area being dragged, or null if the + * drag occurred on another element. + */ + static nsresult GetDragData(nsPIDOMWindowOuter* aWindow, + nsIContent* aTarget, + nsIContent* aSelectionTargetNode, + bool aIsAltKeyPressed, + mozilla::dom::DataTransfer* aDataTransfer, + bool* aCanDrag, + nsISelection** aSelection, + nsIContent** aDragNode); +}; + +// this is used to save images to disk lazily when the image data is asked for +// during the drop instead of when it is added to the drag data transfer. This +// ensures that the image data is only created when an image drop is allowed. +class nsContentAreaDragDropDataProvider : public nsIFlavorDataProvider +{ + virtual ~nsContentAreaDragDropDataProvider() {} + +public: + NS_DECL_ISUPPORTS + NS_DECL_NSIFLAVORDATAPROVIDER + + nsresult SaveURIToFile(nsAString& inSourceURIString, + nsIFile* inDestFile, bool isPrivate); +}; + + +#endif /* nsContentAreaDragDrop_h__ */ + -- cgit v1.2.3