Defines the interface and base operation of items that that can be
dragged or can be drop targets. It was designed to be extended, overriding
the event handlers for startDrag, onDrag, onDragOver and onDragOut.
Up to three html elements can be associated with a DragDrop instance:
- linked element: the element that is passed into the constructor.
This is the element which defines the boundaries for interaction with
other DragDrop objects.
- handle element(s): The drag operation only occurs if the element that
was clicked matches a handle element. By default this is the linked
element, but there are times that you will want only a portion of the
linked element to initiate the drag operation, and the setHandleElId()
method provides a way to define this.
- drag element: this represents the element that would be moved along
with the cursor during a drag operation. By default, this is the linked
element itself as in Ext.dd.DD. setDragElId() lets you define
a separate element that would be moved, as in Ext.dd.DDProxy.
This class should not be instantiated until the onload event to ensure that
the associated elements are available.
The following would define a DragDrop obj that would interact with any
other DragDrop obj in the "group1" group:
dd = new Ext.dd.DragDrop("div1", "group1");
Since none of the event handlers have been implemented, nothing would
actually happen if you were to run the code above. Normally you would
override this class or one of the default implementations, but you can
also override the methods you want on an instance of the class...
dd.onDragDrop = function(e, id) {
alert("dd was dropped on " + id);
}
|
available : boolean
The availabe property is false until the linked dom element is accessible.
|
DragDrop |
|
config : object
Configuration attributes passed into the constructor
|
DragDrop |
|
groups : object
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.
|
DragDrop |
|
hasOuterHandles : boolean
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.
|
DragDrop |
|
id : String
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.
|
DragDrop |
|
invalidHandleClasses : string[]
An indexted array of css class names for elements that will be ignored
if clicked.
|
DragDrop |
|
invalidHandleIds : string:
An associative array of ids for elements that will be ignored if clicked
|
DragDrop |
|
invalidHandleTypes : string:
An associative array of HTML tags that will be ignored if clicked.
|
DragDrop |
|
isTarget : boolean
By default, all insances can be a drop target. This can be disabled by
setting isTarget to false.
|
DragDrop |
|
maintainOffset : boolean
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
|
DragDrop |
|
padding : int[]
The padding configured for this drag and drop object for calculating
the drop zone intersection with this object.
|
DragDrop |
|
primaryButtonOnly : boolean
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
|
DragDrop |
|
xTicks : int[]
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.
|
DragDrop |
|
yTicks : int[]
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.
|
DragDrop |
|
DragDrop( String id , String sGroup , object config )
Parameters:
id : Stringof the element that is linked to this instance sGroup : Stringthe group of related DragDrop objects config : objectan object containing configurable attributes
Valid properties for DragDrop:
padding, isTarget, maintainOffset, primaryButtonOnly
Returns:
|
DragDrop |
|
addInvalidHandleClass( string cssClass ) : 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
|
DragDrop |
|
addInvalidHandleId( string id ) : 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
|
DragDrop |
|
addInvalidHandleType( string tagName ) : 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.
|
DragDrop |
|
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} : sGroupthe name of the group
Returns:
|
DragDrop |
|
applyConfig() : 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.
|
DragDrop |
|
clearConstraints() : 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.
|
DragDrop |
|
clearTicks() : void
Clears any tick interval defined for this instance
Clears any tick interval defined for this instance
|
DragDrop |
|
endDrag( Event e ) : void
Fired when we are done dragging the object
Fired when we are done dragging the object
Parameters:
e : Eventthe mouseup event
Returns:
|
DragDrop |
|
getDragEl() : HTMLElement
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
Parameters:
Returns:
HTMLElement the html element
|
DragDrop |
|
getEl() : HTMLElement
Returns a reference to the linked element
Returns a reference to the linked element
Parameters:
Returns:
HTMLElement the html element
|
DragDrop |
|
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
|
DragDrop |
|
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.
|
DragDrop |
|
isLocked() : boolean
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.)
|
DragDrop |
|
isValidHandleChild( HTMLElement node ) : boolean
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
|
DragDrop |
|
lock() : void
|
DragDrop |
|
onAvailable() : void
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.
|
DragDrop |
|
onDrag( Event e ) : void
Abstract method called during the onMouseMove event while dragging an
object.
Abstract method called during the onMouseMove event while dragging an
object.
Parameters:
e : Eventthe mousemove event
Returns:
|
DragDrop |
|
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
|
DragDrop |
|
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
|
DragDrop |
|
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
|
DragDrop |
|
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
|
DragDrop |
|
onInvalidDrop( Event e ) : 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 : Eventthe mouseup event
Returns:
|
DragDrop |
|
onMouseDown( Event e ) : 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 : Eventthe mousedown event
Returns:
|
DragDrop |
|
onMouseUp( Event e ) : 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 : Eventthe mouseup event
Returns:
|
DragDrop |
|
removeFromGroup( string sGroup ) : void
Remove's this instance from the supplied interaction group
Remove's this instance from the supplied interaction group
Parameters:
sGroup : stringThe group to drop
Returns:
|
DragDrop |
|
removeInvalidHandleClass( string cssClass ) : void
Unsets an invalid css class
Unsets an invalid css class
|
DragDrop |
|
removeInvalidHandleId( string id ) : void
Unsets an invalid handle id
Unsets an invalid handle id
|
DragDrop |
|
removeInvalidHandleType( string tagName ) : void
Unsets an excluded tag name set by addInvalidHandleType
Unsets an excluded tag name set by addInvalidHandleType
|
DragDrop |
|
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.
|
DragDrop |
|
setDragElId( id {string} ) : 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
|
DragDrop |
|
setHandleElId( id {string} ) : 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.
|
DragDrop |
|
setInitialPosition( int diffX , int diffY ) : void
Stores the initial placement of the linked element.
Stores the initial placement of the linked element.
Parameters:
diffX : intthe X offset, default 0 diffY : intthe Y offset, default 0
Returns:
|
DragDrop |
|
setOuterHandleElId( id the ) : 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
|
DragDrop |
|
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 : intTop pad iRight : intRight pad iBot : intBot pad iLeft : intLeft pad
Returns:
|
DragDrop |
|
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 : intthe number of pixels the element can move to the left iRight : intthe number of pixels the element can move to the
right iTickSize : intoptional parameter for specifying that the
element
should move iTickSize pixels at a time.
Returns:
|
DragDrop |
|
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 : intthe number of pixels the element can move up iDown : intthe number of pixels the element can move down iTickSize : intoptional parameter for specifying that the
element should move iTickSize pixels at a time.
Returns:
|
DragDrop |
|
startDrag( int X , int Y ) : 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 : intclick location Y : intclick location
Returns:
|
DragDrop |
|
toString() : string
|
DragDrop |
|
unlock() : void
|
DragDrop |
|
unreg() : void
Remove all drag and drop hooks for this element
Remove all drag and drop hooks for this element
|
DragDrop |
This class has no public events.