123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- /*
- * Ext JS Library 2.0 Copyright(c) 2006-2007, Ext JS, LLC. licensing@extjs.com
- *
- * http://extjs.com/license
- */
- /**
- * @class Ext.dd.DragZone
- * @extends Ext.dd.DragSource This class provides a container DD instance that
- * proxies for multiple child node sources.<br />
- * By default, this class requires that draggable child nodes are
- * registered with {@link Ext.dd.Registry}.
- * @constructor
- * @param {Mixed}
- * el The container element
- * @param {Object}
- * config
- */
- Ext.dd.DragZone = function(el, config) {
- Ext.dd.DragZone.superclass.constructor.call(this, el, config);
- if (this.containerScroll) {
- Ext.dd.ScrollManager.register(this.el);
- }
- };
- Ext.extend(Ext.dd.DragZone, Ext.dd.DragSource, {
- /**
- * @cfg {Boolean} containerScroll True to register this container
- * with the Scrollmanager for auto scrolling during drag
- * operations.
- */
- /**
- * @cfg {String} hlColor The color to use when visually highlighting
- * the drag source in the afterRepair method after a failed
- * drop (defaults to "c3daf9" - light blue)
- */
- /**
- * Called when a mousedown occurs in this container. Looks in
- * {@link Ext.dd.Registry} for a valid target to drag based on the
- * mouse down. Override this method to provide your own lookup logic
- * (e.g. finding a child by class name). Make sure your returned
- * object has a "ddel" attribute (with an HTML Element) for other
- * functions to work.
- *
- * @param {EventObject}
- * e The mouse down event
- * @return {Object} The dragData
- */
- getDragData : function(e) {
- return Ext.dd.Registry.getHandleFromEvent(e);
- },
- /**
- * Called once drag threshold has been reached to initialize the
- * proxy element. By default, it clones the this.dragData.ddel
- *
- * @param {Number}
- * x The x position of the click on the dragged object
- * @param {Number}
- * y The y position of the click on the dragged object
- * @return {Boolean} true to continue the drag, false to cancel
- */
- onInitDrag : function(x, y) {
- this.proxy.update(this.dragData.ddel.cloneNode(true));
- this.onStartDrag(x, y);
- return true;
- },
- /**
- * Called after a repair of an invalid drop. By default, highlights
- * this.dragData.ddel
- */
- afterRepair : function() {
- if (Ext.enableFx) {
- Ext.Element.fly(this.dragData.ddel).highlight(this.hlColor
- || "c3daf9");
- }
- this.dragging = false;
- },
- /**
- * Called before a repair of an invalid drop to get the XY to
- * animate to. By default returns the XY of this.dragData.ddel
- *
- * @param {EventObject}
- * e The mouse up event
- * @return {Array} The xy location (e.g. [100, 200])
- */
- getRepairXY : function(e) {
- return Ext.Element.fly(this.dragData.ddel).getXY();
- }
- });
|