/* This file is part of Ext JS 3.4 Copyright (c) 2011-2013 Sencha Inc Contact: http://www.sencha.com/contact GNU General Public License Usage This file may be used under the terms of the GNU General Public License version 3.0 as published by the Free Software Foundation and appearing in the file LICENSE included in the packaging of this file. Please review the following information to ensure the GNU General Public License version 3.0 requirements will be met: http://www.gnu.org/copyleft/gpl.html. If you are unsure which license is appropriate for your use, please contact the sales department at http://www.sencha.com/contact. Build date: 2013-04-03 15:07:25 */ Ext.data.JsonP.Ext_dd_DragDropMgr({"alternateClassNames":[],"aliases":{},"enum":null,"parentMixins":[],"tagname":"class","subclasses":[],"extends":null,"uses":[],"html":"
Files
DragDropMgr is a singleton that tracks the element interaction for\nall DragDrop items in the window. Generally, you will not call\nthis class directly, but it does have helper methods that could\nbe useful in your DragDrop implementations.
\nIn intersect mode, drag and drop interaction is defined by the\noverlap of two or more drag and drop objects.
\nDefaults to: 1
In point mode, drag and drop interaction is defined by the\nlocation of the cursor during the drag/drop
\nDefaults to: 0
The number of pixels that the mouse needs to move after the\nmousedown before the drag is initiated. Default=3;
\nDefaults to: 3
The number of milliseconds after the mousedown event to initiate the\ndrag if we don't get a mouseup event. Default=350
\nDefaults to: 350
Timeout used for the click time threshold
\nTimeout used for the click time threshold
\nthe X distance between the cursor and the object being dragged
\nDefaults to: 0
the Y distance between the cursor and the object being dragged
\nDefaults to: 0
the DragDrop object that is currently being dragged
\nthe DragDrop object that is currently being dragged
\nthe DragDrop object(s) that are being hovered over
\nDefaults to: {}
Flag that indicates that either the drag pixel threshold or the\nmousdown time threshold has been met
\nDefaults to: false
Array of element ids defined as drag handles. Used to determine\nif the element that generated the mousedown event is actually the\nhandle and not the html element itself.
\nDefaults to: {}
Two dimensional Array of registered DragDrop objects. The first\ndimension is the DragDrop item group, the second the DragDrop\nobject.
\nDefaults to: {}
Internal flag that is set to true when drag and drop has been\nintialized
\nDefaults to: false
Location cache that is set for all drag drop objects when a drag is\ninitiated, cleared when the drag is finished.
\nDefaults to: {}
All drag and drop can be disabled.
\nDefaults to: false
The current drag and drop mode. Default: POINT
\nDefaults to: 0
This config is only provided to provide old, usually unwanted drag/drop behaviour.
\n\nFrom ExtJS 4.1.0 onwards, when drop targets are contained in floating, absolutely positioned elements\nsuch as in Windows, which may overlap each other, over
and drop
events\nare only delivered to the topmost drop target at the mouse position.
If all targets below that in zIndex order should also receive notifications, set\nnotifyOccluded
to true
.
Defaults to: false
Flag to determine if we should prevent the default behavior of the\nevents we define. By default this is true, but this can be set to\nfalse if you need the default behavior (not recommended)
\nDefaults to: true
The X position of the mousedown event stored for later use when a\ndrag threshold is met.
\nDefaults to: 0
The Y position of the mousedown event stored for later use when a\ndrag threshold is met.
\nDefaults to: 0
Flag to determine if we should stop the propagation of the events\nwe generate. This is true by default but you may want to set it to\nfalse if the html element contains other features that require the\nmouse click.
\nDefaults to: true
Set useCache to false if you want to force object the lookup of each\ndrag and drop linked element constantly during a drag.
\nDefaults to: true
Runs method on all drag and drop objects
\nDrag and drop initialization. Sets up the global event handlers
\nReset constraints on all drag and drop objs
\nunload event handler
\nUnregisters a drag and drop item. This is executed in\nDragDrop.unreg, use that method instead of calling this directly.
\nUtility method to pass to Ext.Array.sort when sorting potential drop targets by z-index.
\nIterates over all of the DragDrop elements to find ones we are\nhovering over or dropping on
\nthe event
\nis this a drop op or a mouseover op?
\nHelper function for getting the best match from the list of drag\nand drop objects returned by the drag and drop events when we are\nin INTERSECT mode. It returns either the first object that the\ncursor is over, or the object that has the greatest overlap with\nthe dragged element.
\nThe array of drag and drop objects\ntargeted
\nThe best single match
\nReturns the style property for the DOM element (i.e.,\ndocument.getElById(id).style)
\nThis method has been deprecated
\nuse Ext.lib.Dom instead
\n\nthe id of the elment to get
\nThe style property of the element
\nReturns the DragDrop instance for a given id
\nthe id of the DragDrop object
\nthe drag drop object, null if it is not found
\nGet the wrapper for the DOM element specified
\nThis method has been deprecated
\nThis wrapper isn't that useful
\n\nthe id of the element to get
\nthe wrapped element
\nReturns the actual DOM element
\nThis method has been deprecated
\nuse Ext.lib.Ext.getDom instead
\n\nthe id of the elment to get
\nThe element
\nReturns a Region object containing the drag and drop element's position\nand size, including the padding configured for it
\nthe drag and drop object to get the
\n\n location for\n
\n\n@return {Ext.lib.Region} a Region object representing the total area
\n\n the element occupies, including any padding\n the instance is configured for.\n
\nReturns the drag and drop instances that are in all groups the\npassed in instance belongs to.
\nthe obj to get related data for
\nif true, only return targetable objs
\nthe related instances
\nCollects the z-index of the passed element, looking up the parentNode axis to find an absolutely positioned ancestor\nwhich is able to yield a z-index. If found to be not absolutely positionedm returns -1.
\n\nThis is used when sorting potential drop targets into z-index order so that only the topmost receives over
and drop
events.
The z-index of the element, or of its topmost absolutely positioned ancestor. Returns -1 if the element is not\nabsolutely positioned.
\nFired after a registered DragDrop object gets the mousedown event.\nSets up the events required to track the object being dragged
\nthe event
\nthe DragDrop object being dragged
\nInternal function to handle the mousemove event. Will be invoked\nfrom the context of the html element.
\n\n@TODO figure out what we can do about mouse events lost when the\nuser drags objects beyond the window boundary. Currently we can\ndetect this in internet explorer by verifying that the mouse is\ndown during the mousemove event. Firefox doesn't give us the\nbutton state on the mousemove event.
\nthe event
\nInternal function to handle the mouseup event. Will be invoked\nfrom the context of the document.
\nthe event
\nCalled the first time an element is registered.
\nUtility function to determine if a given element has been\nregistered as a drag drop item.
\nthe element id to check
\ntrue if this element is a DragDrop item,\nfalse otherwise
\nUtility function to determine if a given element has been\nregistered as a drag drop handle for the given Drag Drop object.
\nthe element id to check
\ntrue if this element is a DragDrop handle, false\notherwise
\nReturns true if the specified dd target is a legal target for\nthe specifice drag obj
\nthe drag obj
\nthe target
\ntrue if the target is a legal target for the\ndd obj
\nIs drag and drop locked?
\nTrue if drag and drop is locked, false otherwise.
\nChecks the cursor location to see if it over the target
\nThe point to evaluate
\nthe DragDrop object we are inspecting
\ntrue if the mouse is over the target
\nMy goal is to be able to transparently determine if an object is\ntypeof DragDrop, and the exact subclass of DragDrop. typeof\nreturns \"object\", oDD.constructor.toString() always returns\n\"DragDrop\" and not the name of the subclass. So for now it just\nevaluates a well-known variable in DragDrop.
\nobject to evaluate
\ntrue if typeof oDD = DragDrop
\nRefreshes the cache of the top-left and bottom-right points of the\ndrag and drop objects in the specified group(s). This is in the\nformat that is stored in the drag and drop instance, so typical\nusage is:\n\nExt.dd.DragDropMgr.refreshCache(ddinstance.groups);\n
\nAlternatively:\n\nExt.dd.DragDropMgr.refreshCache({group1:true, group2:true});\n
\n@TODO this really should be an indexed array. Alternatively this\nmethod could accept both.
an associative array of groups to refresh
\nEach DragDrop instance must be registered with the DragDropMgr.\nThis is executed in DragDrop.init()
\nthe DragDrop object to register
\nthe name of the group this element belongs to
\nRemoves the supplied dd instance from the supplied group. Executed\nby DragDrop.removeFromGroup, so don't call this function directly.
\nFired when either the drag pixel threshol or the mousedown hold\ntime threshold has been met.
\n{int} the X position of the original mousedown
\n{int} the Y position of the original mousedown
\nInternal function to clean up event handlers after the drag\noperation is complete
\nthe event
\nUtility to stop event propagation and event default, if these\nfeatures are turned on.
\nthe event as returned by this.getEvent()
\nCleans up the drag and drop events and objects.
\nThis checks to make sure an element exists and is in the DOM. The\nmain purpose is to handle cases where innerHTML is used to remove\ndrag and drop objects from the DOM. IE provides an 'unspecified\nerror' when trying to access the offsetParent of such an element
\nthe element to check
\ntrue if the element looks usable
\n