Sencha Documentation

Defined By

Config Options

 
True if drops on the tree container (outside of a specific tree node) are allowed (defaults to false)
True if drops on the tree container (outside of a specific tree node) are allowed (defaults to false)
 
Allow inserting a dragged node between an expanded parent node and its first child that will become a sibling of the ...
Allow inserting a dragged node between an expanded parent node and its first child that will become a sibling of the parent when dropped (defaults to false)
 
True if the tree should only allow append drops (use for trees which are sorted, defaults to false)
True if the tree should only allow append drops (use for trees which are sorted, defaults to false)
 
A named drag drop group to which this object belongs. If a group is specified, then this object will only interact w...
A named drag drop group to which this object belongs. If a group is specified, then this object will only interact with other drag drop objects in the same group (defaults to 'TreeDD').
 
The CSS class returned to the drag source when drop is allowed (defaults to "x-dd-drop-ok").
The CSS class returned to the drag source when drop is allowed (defaults to "x-dd-drop-ok").
 
The CSS class returned to the drag source when drop is not allowed (defaults to "x-dd-drop-nodrop").
The CSS class returned to the drag source when drop is not allowed (defaults to "x-dd-drop-nodrop").
 
The delay in milliseconds to wait before expanding a target tree node while dragging a droppable node over the target...
The delay in milliseconds to wait before expanding a target tree node while dragging a droppable node over the target (defaults to 1000)
 
The CSS class applied to the drop target element while the drag source is over it (defaults to "").
The CSS class applied to the drop target element while the drag source is over it (defaults to "").
Defined By

Properties

 
The available property is false until the linked dom element is accessible.
The available property is false until the linked dom element is accessible.
 
Configuration attributes passed into the constructor
Configuration attributes passed into the constructor
 
Provides default constraint padding to "constrainTo" elements (defaults to {left: 0, right:0, top:0, bottom:0}).
Provides default constraint padding to "constrainTo" elements (defaults to {left: 0, right:0, top:0, bottom:0}).
 
Arbitrary data that can be associated with this tree and will be included in the event object that gets passed to any...
Arbitrary data that can be associated with this tree and will be included in the event object that gets passed to any nodedragover event handler (defaults to {})
 
groups : object An object in the format {'group1':true, 'group2':true
The group defines a logical collection of DragDrop objects that are related. Instances only get events when interact...
The group defines a logical collection of DragDrop objects that are related. Instances only get events when interacting with other DragDrop object in the same group. This lets us define multiple groups using a single DragDrop subclass if we want.
 
By default, drags can only be initiated if the mousedown occurs in the region the linked element is. This is done in...
By default, drags can only be initiated if the mousedown occurs in the region the linked element is. This is done in part to work around a bug in some browsers that mis-report the mousedown if the previous mouseup happened outside of the window. This property is set to true if outer handles are defined.
 
The id of the element associated with this object. This is what we refer to as the "linked element" because the size...
The id of the element associated with this object. This is what we refer to as the "linked element" because the size and position of this element is used to determine when the drag and drop objects have interacted.
 
Set to false to enable a DragDrop object to fire drag events while dragging over its own Element. Defaults to true - ...
Set to false to enable a DragDrop object to fire drag events while dragging over its own Element. Defaults to true - DragDrop objects do not by default fire drag events to themselves.
 
An Array of CSS class names for elements to be considered in valid as drag handles.
An Array of CSS class names for elements to be considered in valid as drag handles.
 
An object who's property names identify the IDs of elements to be considered invalid as drag handles. A non-null prop...
An object who's property names identify the IDs of elements to be considered invalid as drag handles. A non-null property value identifies the ID as invalid. For example, to prevent dragging from being initiated on element ID "foo", use:
{
    foo: true
}
 
An object who's property names identify HTML tags to be considered invalid as drag handles. A non-null property value...
An object who's property names identify HTML tags to be considered invalid as drag handles. A non-null property value identifies the tag as invalid. Defaults to the following value which prevents drag operations from being initiated by <a> elements:
{
    A: "A"
}
 
By default, all instances can be a drop target. This can be disabled by setting isTarget to false.
By default, all instances can be a drop target. This can be disabled by setting isTarget to false.
 
Maintain offsets when we resetconstraints. Set to true when you want the position of the element relative to its par...
Maintain offsets when we resetconstraints. Set to true when you want the position of the element relative to its parent to stay the same when the page changes
 
When set to true, other DD objects in cooperating DDGroups do not receive notification events when this DD object is ...
When set to true, other DD objects in cooperating DDGroups do not receive notification events when this DD object is dragged over them. Defaults to false.
 
padding : int[] An array containing the 4 padding values: [top, right, bottom, left]
The padding configured for this drag and drop object for calculating the drop zone intersection with this object.
The padding configured for this drag and drop object for calculating the drop zone intersection with this object.
 
By default the drag and drop instance will only respond to the primary button click (left button for a right-handed m...
By default the drag and drop instance will only respond to the primary button click (left button for a right-handed mouse). Set to true to allow drag and drop to start with any mouse click that is propogated by the browser
 
The TreePanel for this drop zone
The TreePanel for this drop zone
 
Array of pixel locations the element will snap to if we specified a horizontal graduation/interval. This array is ge...
Array of pixel locations the element will snap to if we specified a horizontal graduation/interval. This array is generated automatically when you define a tick interval.
 
Array of pixel locations the element will snap to if we specified a vertical graduation/interval. This array is gene...
Array of pixel locations the element will snap to if we specified a vertical graduation/interval. This array is generated automatically when you define a tick interval.
Defined By

Methods

 
new Ext.tree.TreeDropZone( String/HTMLElement/Element tree, Object config) : Void

Parameters

  • tree : String/HTMLElement/Element
    The Ext.tree.TreePanel for which to enable dropping
  • config : Object

Returns

  • Void
 
Lets you specify a css class of elements that will not initiate a drag
Lets you specify a css class of elements that will not initiate a drag

Parameters

  • cssClass : string
    the class of the elements you wish to ignore

Returns

  • Void
 
Lets you to specify an element id for a child of a drag handle that should not initiate a drag
Lets you to specify an element id for a child of a drag handle that should not initiate a drag

Parameters

  • id : string
    the element id of the element you wish to ignore

Returns

  • Void
 
Allows you to specify a tag name that should not start a drag operation when clicked. This is designed to facilitate...
Allows you to specify a tag name that should not start a drag operation when clicked. This is designed to facilitate embedding links within a drag handle that do something other than start the drag.

Parameters

  • tagName : string
    the type of element to exclude

Returns

  • Void
 
addToGroup( sGroup {string}) : Void
Add this instance to a group of related drag/drop objects. All instances belong to at least one group, and can belon...
Add this instance to a group of related drag/drop objects. All instances belong to at least one group, and can belong to as many groups as needed.

Parameters

  • {string} : sGroup
    the name of the group

Returns

  • Void
 
Applies the configuration parameters that were passed into the constructor. This is supposed to happen at each level ...
Applies the configuration parameters that were passed into the constructor. This is supposed to happen at each level through the inheritance chain. So a DDProxy implentation will execute apply config on DDProxy, DD, and DragDrop in order to get all of the parameters that are available in each object.

Returns

  • Void
 
Clears any constraints applied to this instance. Also clears ticks since they can't exist independent of a constrain...
Clears any constraints applied to this instance. Also clears ticks since they can't exist independent of a constraint at this time.

Returns

  • Void
 
Clears any tick interval defined for this instance
Clears any tick interval defined for this instance

Returns

  • Void
 
constrainTo( Mixed constrainTo, [Object/Number pad], [Boolean inContent]) : Void
Initializes the drag drop object's constraints to restrict movement to a certain element. Usage: var dd = new Ext.dd...
Initializes the drag drop object's constraints to restrict movement to a certain element. Usage:
var dd = new Ext.dd.DDProxy("dragDiv1", "proxytest",
                { dragElId: "existingProxyDiv" });
 dd.startDrag = function(){
     this.constrainTo("parent-id");
 };
Or you can initalize it using the Ext.core.Element object:
Ext.get("dragDiv1").initDDProxy("proxytest", {dragElId: "existingProxyDiv"}, {
     startDrag : function(){
         this.constrainTo("parent-id");
     }
 });

Parameters

  • constrainTo : Mixed
    The element to constrain to.
  • pad : Object/Number
    (optional) Pad provides a way to specify "padding" of the constraints, and can be either a number for symmetrical padding (4 would be equal to {left:4, right:4, top:4, bottom:4}) or an object containing the sides to pad. For example: {right:10, bottom:10}
  • inContent : Boolean
    (optional) Constrain the draggable in the content box of the element (inside padding and borders)

Returns

  • Void
 
Fired when we are done dragging the object
Fired when we are done dragging the object

Parameters

  • e : Event
    the mouseup event

Returns

  • Void
 
Returns a reference to the actual element to drag. By default this is the same as the html element, but it can be as...
Returns a reference to the actual element to drag. By default this is the same as the html element, but it can be assigned to another element. An example of this can be found in Ext.dd.DDProxy

Returns

  • HTMLElement   the html element
 
Returns a reference to the linked element
Returns a reference to the linked element

Returns

  • HTMLElement   the html element
 
Returns a custom data object associated with the DOM node that is the target of the event. By default this looks up ...
Returns a custom data object associated with the DOM node that is the target of the event. By default this looks up the event target in the Ext.dd.Registry, although you can override this method to provide your own custom lookup.

Parameters

  • e : Event
    The event

Returns

  • Object   data The custom data
 
init( id the, String sGroup, object config) : Void
Sets up the DragDrop object. Must be called in the constructor of any Ext.dd.DragDrop subclass
Sets up the DragDrop object. Must be called in the constructor of any Ext.dd.DragDrop subclass

Parameters

  • the : id
    id of the linked element
  • sGroup : String
    the group of related items
  • config : object
    configuration attributes

Returns

  • Void
 
initTarget( id the, String sGroup, object config) : Void
Initializes Targeting functionality only... the object does not get a mousedown handler.
Initializes Targeting functionality only... the object does not get a mousedown handler.

Parameters

  • the : id
    id of the linked element
  • sGroup : String
    the group of related items
  • config : object
    configuration attributes

Returns

  • Void
 
Returns true if this instance is locked, or the drag drop mgr is locked (meaning that all drag/drop is disabled on th...
Returns true if this instance is locked, or the drag drop mgr is locked (meaning that all drag/drop is disabled on the page.)

Returns

  • boolean   true if this obj or all drag/drop is locked, else false
 
Checks the tag exclusion list to see if this click should be ignored
Checks the tag exclusion list to see if this click should be ignored

Parameters

  • node : HTMLElement
    the HTMLElement to evaluate

Returns

  • boolean   true if this is a valid tag type, false if not
 
Lock this instance
Lock this instance

Returns

  • Void
 
notifyDrop( Ext.dd.DragSource source, Event e, Object data) : Boolean
The function a Ext.dd.DragSource calls once to notify this drop zone that the dragged item has been dropped on it. T...
The function a Ext.dd.DragSource calls once to notify this drop zone that the dragged item has been dropped on it. The drag zone will look up the target node based on the event passed in, and if there is a node registered for that event, it will delegate to onNodeDrop for node-specific handling, otherwise it will call onContainerDrop.

Parameters

  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop zone
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag source

Returns

  • Boolean   True if the drop was valid, else false
 
notifyEnter( Ext.dd.DragSource source, Event e, Object data) : String
The function a Ext.dd.DragSource calls once to notify this drop zone that the source is now over the zone. The defau...
The function a Ext.dd.DragSource calls once to notify this drop zone that the source is now over the zone. The default implementation returns this.dropNotAllowed and expects that only registered drop nodes can process drag drop operations, so if you need the drop zone itself to be able to process drops you should override this method and provide a custom implementation.

Parameters

  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop zone
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag source

Returns

  • String   status The CSS class that communicates the drop status back to the source so that the underlying {@link Ext.dd.StatusProxy} can be updated
 
notifyOut( Ext.dd.DragSource source, Event e, Object data) : Void
The function a Ext.dd.DragSource calls once to notify this drop zone that the source has been dragged out of the zone...
The function a Ext.dd.DragSource calls once to notify this drop zone that the source has been dragged out of the zone without dropping. If the drag source is currently over a registered node, the notification will be delegated to onNodeOut for node-specific handling, otherwise it will be ignored.

Parameters

  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop target
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag zone

Returns

  • Void
 
notifyOver( Ext.dd.DragSource source, Event e, Object data) : String
The function a Ext.dd.DragSource calls continuously while it is being dragged over the drop zone. This method will be...
The function a Ext.dd.DragSource calls continuously while it is being dragged over the drop zone. This method will be called on every mouse movement while the drag source is over the drop zone. It will call onNodeOver while the drag source is over a registered node, and will also automatically delegate to the appropriate node-specific methods as necessary when the drag source enters and exits registered nodes (onNodeEnter, onNodeOut). If the drag source is not currently over a registered node, it will call onContainerOver.

Parameters

  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop zone
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag source

Returns

  • String   status The CSS class that communicates the drop status back to the source so that the underlying {@link Ext.dd.StatusProxy} can be updated
 
Override the onAvailable method to do what is needed after the initial position was determined.
Override the onAvailable method to do what is needed after the initial position was determined.

Returns

  • Void
 
onContainerDrop( Ext.dd.DragSource source, Event e, Object data) : Boolean
Called when the DropZone determines that a Ext.dd.DragSource has been dropped on it, but not on any of its registered...
Called when the DropZone determines that a Ext.dd.DragSource has been dropped on it, but not on any of its registered drop nodes. The default implementation returns false, so it should be overridden to provide the appropriate processing of the drop event if you need the drop zone itself to be able to accept drops. It should return true when valid so that the drag source's repair action does not run.

Parameters

  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop zone
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag source

Returns

  • Boolean   True if the drop was valid, else false
 
onContainerOver( Ext.dd.DragSource source, Event e, Object data) : String
Called while the DropZone determines that a Ext.dd.DragSource is being dragged over it, but not over any of its regis...
Called while the DropZone determines that a Ext.dd.DragSource is being dragged over it, but not over any of its registered drop nodes. The default implementation returns this.dropNotAllowed, so it should be overridden to provide the proper feedback if necessary.

Parameters

  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop zone
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag source

Returns

  • String   status The CSS class that communicates the drop status back to the source so that the underlying {@link Ext.dd.StatusProxy} can be updated
 
Abstract method called during the onMouseMove event while dragging an object.
Abstract method called during the onMouseMove event while dragging an object.

Parameters

  • e : Event
    the mousemove event

Returns

  • Void
 
onDragDrop( Event e, String|DragDrop[] id) : Void
Abstract method called when this item is dropped on another DragDrop obj
Abstract method called when this item is dropped on another DragDrop obj

Parameters

  • e : Event
    the mouseup event
  • id : String|DragDrop[]
    In POINT mode, the element id this was dropped on. In INTERSECT mode, an array of dd items this was dropped on.

Returns

  • Void
 
onDragEnter( Event e, String|DragDrop[] id) : Void
Abstract method called when this element fist begins hovering over another DragDrop obj
Abstract method called when this element fist begins hovering over another DragDrop obj

Parameters

  • e : Event
    the mousemove event
  • id : String|DragDrop[]
    In POINT mode, the element id this is hovering over. In INTERSECT mode, an array of one or more dragdrop items being hovered over.

Returns

  • Void
 
onDragOut( Event e, String|DragDrop[] id) : Void
Abstract method called when we are no longer hovering over an element
Abstract method called when we are no longer hovering over an element

Parameters

  • e : Event
    the mousemove event
  • id : String|DragDrop[]
    In POINT mode, the element id this was hovering over. In INTERSECT mode, an array of dd items that the mouse is no longer over.

Returns

  • Void
 
onDragOver( Event e, String|DragDrop[] id) : Void
Abstract method called when this element is hovering over another DragDrop obj
Abstract method called when this element is hovering over another DragDrop obj

Parameters

  • e : Event
    the mousemove event
  • id : String|DragDrop[]
    In POINT mode, the element id this is hovering over. In INTERSECT mode, an array of dd items being hovered over.

Returns

  • Void
 
Abstract method called when this item is dropped on an area with no drop target
Abstract method called when this item is dropped on an area with no drop target

Parameters

  • e : Event
    the mouseup event

Returns

  • Void
 
Event handler that fires when a drag/drop obj gets a mousedown
Event handler that fires when a drag/drop obj gets a mousedown

Parameters

  • e : Event
    the mousedown event

Returns

  • Void
 
Event handler that fires when a drag/drop obj gets a mouseup
Event handler that fires when a drag/drop obj gets a mouseup

Parameters

  • e : Event
    the mouseup event

Returns

  • Void
 
onNodeDrop( Object nodeData, Ext.dd.DragSource source, Event e, Object data) : Boolean
Called when the DropZone determines that a Ext.dd.DragSource has been dropped onto the drop node. The default implem...
Called when the DropZone determines that a Ext.dd.DragSource has been dropped onto the drop node. The default implementation returns false, so it should be overridden to provide the appropriate processing of the drop event and return true so that the drag source's repair action does not run.

Parameters

  • nodeData : Object
    The custom data associated with the drop node (this is the same value returned from getTargetFromEvent for this node)
  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop zone
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag source

Returns

  • Boolean   True if the drop was valid, else false
 
onNodeEnter( Object nodeData, Ext.dd.DragSource source, Event e, Object data) : Void
Called when the DropZone determines that a Ext.dd.DragSource has entered a drop node that has either been registered ...
Called when the DropZone determines that a Ext.dd.DragSource has entered a drop node that has either been registered or detected by a configured implementation of getTargetFromEvent. This method has no default implementation and should be overridden to provide node-specific processing if necessary.

Parameters

  • nodeData : Object
    The custom data associated with the drop node (this is the same value returned from getTargetFromEvent for this node)
  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop zone
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag source

Returns

  • Void
 
onNodeOut( Object nodeData, Ext.dd.DragSource source, Event e, Object data) : Void
Called when the DropZone determines that a Ext.dd.DragSource has been dragged out of the drop node without dropping. ...
Called when the DropZone determines that a Ext.dd.DragSource has been dragged out of the drop node without dropping. This method has no default implementation and should be overridden to provide node-specific processing if necessary.

Parameters

  • nodeData : Object
    The custom data associated with the drop node (this is the same value returned from getTargetFromEvent for this node)
  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop zone
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag source

Returns

  • Void
 
onNodeOver( Object nodeData, Ext.dd.DragSource source, Event e, Object data) : String
Called while the DropZone determines that a Ext.dd.DragSource is over a drop node that has either been registered or ...
Called while the DropZone determines that a Ext.dd.DragSource is over a drop node that has either been registered or detected by a configured implementation of getTargetFromEvent. The default implementation returns this.dropNotAllowed, so it should be overridden to provide the proper feedback.

Parameters

  • nodeData : Object
    The custom data associated with the drop node (this is the same value returned from getTargetFromEvent for this node)
  • source : Ext.dd.DragSource
    The drag source that was dragged over this drop zone
  • e : Event
    The event
  • data : Object
    An object containing arbitrary data supplied by the drag source

Returns

  • String   status The CSS class that communicates the drop status back to the source so that the underlying {@link Ext.dd.StatusProxy} can be updated
 
Remove's this instance from the supplied interaction group
Remove's this instance from the supplied interaction group

Parameters

  • sGroup : string
    The group to drop

Returns

  • Void
 
Unsets an invalid css class
Unsets an invalid css class

Parameters

  • cssClass : string
    the class of the element(s) you wish to re-enable

Returns

  • Void
 
Unsets an invalid handle id
Unsets an invalid handle id

Parameters

  • id : string
    the id of the element to re-enable

Returns

  • Void
 
Unsets an excluded tag name set by addInvalidHandleType
Unsets an excluded tag name set by addInvalidHandleType

Parameters

  • tagName : string
    the type of element to unexclude

Returns

  • Void
 
resetConstraints( boolean maintainOffset) : Void
resetConstraints must be called if you manually reposition a dd element.
resetConstraints must be called if you manually reposition a dd element.

Parameters

  • maintainOffset : boolean

Returns

  • Void
 
Allows you to specify that an element other than the linked element will be moved with the cursor during a drag
Allows you to specify that an element other than the linked element will be moved with the cursor during a drag

Parameters

  • {string} : id
    the id of the element that will be used to initiate the drag

Returns

  • Void
 
Allows you to specify a child of the linked element that should be used to initiate the drag operation. An example o...
Allows you to specify a child of the linked element that should be used to initiate the drag operation. An example of this would be if you have a content div with text and links. Clicking anywhere in the content area would normally start the drag operation. Use this method to specify that an element inside of the content div is the element that starts the drag operation.

Parameters

  • {string} : id
    the id of the element that will be used to initiate the drag.

Returns

  • Void
 
setInitPosition( int diffX, int diffY) : Void
Stores the initial placement of the linked element.
Stores the initial placement of the linked element.

Parameters

  • diffX : int
    the X offset, default 0
  • diffY : int
    the Y offset, default 0

Returns

  • Void
 
Allows you to set an element outside of the linked element as a drag handle
Allows you to set an element outside of the linked element as a drag handle

Parameters

  • the : id
    id of the element that will be used to initiate the drag

Returns

  • Void
 
setPadding( int iTop, int iRight, int iBot, int iLeft) : Void
Configures the padding for the target zone in px. Effectively expands (or reduces) the virtual object size for targe...
Configures the padding for the target zone in px. Effectively expands (or reduces) the virtual object size for targeting calculations. Supports css-style shorthand; if only one parameter is passed, all sides will have that padding, and if only two are passed, the top and bottom will have the first param, the left and right the second.

Parameters

  • iTop : int
    Top pad
  • iRight : int
    Right pad
  • iBot : int
    Bot pad
  • iLeft : int
    Left pad

Returns

  • Void
 
setXConstraint( int iLeft, int iRight, int iTickSize) : Void
By default, the element can be dragged any place on the screen. Use this method to limit the horizontal travel of th...
By default, the element can be dragged any place on the screen. Use this method to limit the horizontal travel of the element. Pass in 0,0 for the parameters if you want to lock the drag to the y axis.

Parameters

  • iLeft : int
    the number of pixels the element can move to the left
  • iRight : int
    the number of pixels the element can move to the right
  • iTickSize : int
    optional parameter for specifying that the element should move iTickSize pixels at a time.

Returns

  • Void
 
setYConstraint( int iUp, int iDown, int iTickSize) : Void
By default, the element can be dragged any place on the screen. Set this to limit the vertical travel of the element...
By default, the element can be dragged any place on the screen. Set this to limit the vertical travel of the element. Pass in 0,0 for the parameters if you want to lock the drag to the x axis.

Parameters

  • iUp : int
    the number of pixels the element can move up
  • iDown : int
    the number of pixels the element can move down
  • iTickSize : int
    optional parameter for specifying that the element should move iTickSize pixels at a time.

Returns

  • Void
 
Abstract method called after a drag/drop object is clicked and the drag or mousedown time thresholds have beeen met.
Abstract method called after a drag/drop object is clicked and the drag or mousedown time thresholds have beeen met.

Parameters

  • X : int
    click location
  • Y : int
    click location

Returns

  • Void
 
toString method
toString method

Returns

  • string   string representation of the dd obj
 
Unlock this instace
Unlock this instace

Returns

  • Void
 
Remove all drag and drop hooks for this element
Remove all drag and drop hooks for this element

Returns

  • Void