sortable-debug.js revision 3a4068bc99eb66f327215c68a907098046c455f3
/**
* The class allows you to create a Drag & Drop reordered list.
* @module sortable
*/
/**
* The class allows you to create a Drag & Drop reordered list.
* @class Sortable
* @extends Base
* @constructor
*/
var Sortable = function(o) {
},
CURRENT_NODE = 'currentNode',
OPACITY_NODE = 'opacityNode',
CONT = 'container',
ID = 'id',
ZINDEX = 'zIndex',
OPACITY = 'opacity',
PARENT_NODE = 'parentNode',
NODES = 'nodes',
NODE = 'node';
/**
* @property delegate
* @type DD.Delegate
* @description A reference to the DD.Delegate instance.
*/
delegate: null,
initializer: function() {
delConfig = {
target: true,
dragConfig: {
}
}, del;
if (this.get('handles')) {
}
moveOnEnd: false,
cloneNode: true
});
});
},
_up: null,
_y: null,
_onDrag: function(e) {
this._up = true;
this._up = false;
}
},
/**
* @private
* @method _onDropOver
* @param Event e The Event Object
* @description Handles the DropOver event to append a drop node to an empty target
*/
_onDropOver: function(e) {
}
}
},
/**
* @private
* @method _onDragOver
* @param Event e The Event Object
* @description Handles the DragOver event that moves the object in the list or to another list.
*/
_onDragOver: function(e) {
return;
}
return;
}
// is drop a child of drag?
return;
}
same = true;
}
moveType = 'insert';
}
switch (moveType) {
case 'insert':
} else {
}
break;
case 'swap':
break;
case 'move':
case 'copy':
if (!dropsort) {
return;
}
//Same List
if (same) {
} else {
alert(1);
//New List
top: '',
left: ''
});
}
}
break;
}
},
/**
* @private
* @method _onDragStart
* @param Event e The Event Object
* @description Handles the DragStart event and initializes some settings.
*/
_onDragStart: function(e) {
},
/**
* @private
* @method _onDragEnd
* @param Event e The Event Object
* @description Handles the DragEnd event that cleans up the settings in the drag:start event.
*/
_onDragEnd: function(e) {
top: '',
left: ''
});
this.sync();
},
/**
* @method plug
* @param Class cls The class to plug
* @param Object config The class config
* @description Passthrough to the DD.Delegate.ddplug method
* @chainable
*/
//I don't like this.. Not at all, need to discuss with the team
} else {
}
return this;
},
/**
* @method plug
* @description Passthrough to the DD.Delegate syncTargets method.
* @chainable
*/
sync: function() {
this.delegate.syncTargets();
return this;
},
destructor: function() {
},
/**
* @method join
* @param Sortable sel The Sortable list to join with
* @param String type The type of join to do: full, inner, outer, none. Default: full
* @description Join this Sortable with another Sortable instance.
* <ul>
* <li>full: Exchange nodes with both lists.</li>
* <li>inner: Items can go into this list from the joined list.</li>
* <li>outer: Items can go out of the joined list into this list.</li>
* <li>none: Removes the join.</li>
* </ul>
* @chainable
*/
Y.error('Sortable: join needs a Sortable Instance');
return this;
}
if (!type) {
type = 'full';
}
if (this[method]) {
}
return this;
},
/**
* @private
* @method _join_none
* @param Sortable sel The Sortable to remove the join from
* @description Removes the join with the passed Sortable.
*/
_join_none: function(sel) {
},
/**
* @private
* @method _join_full
* @param Sortable sel The Sortable list to join with
* @description Joins both of the Sortables together.
*/
_join_full: function(sel) {
},
/**
* @private
* @method _join_outer
* @param Sortable sel The Sortable list to join with
* @description Allows this Sortable to accept items from the passed Sortable.
*/
_join_outer: function(sel) {
},
/**
* @private
* @method _join_inner
* @param Sortable sel The Sortable list to join with
* @description Allows this Sortable to give items to the passed Sortable.
*/
_join_inner: function(sel) {
},
/**
* A custom callback to allow a user to extract some sort of id or any other data from the node to use in the "ordering list" and then that data should be returned from the callback.
* @method getOrdering
* @param Function callback
* @returns Array
*/
getOrdering: function(callback) {
var ordering = [];
return node;
};
}
});
return ordering;
}
}, {
NAME: 'sortable',
ATTRS: {
/**
* @attribute handles
* @description Drag handles to pass on to the internal DD.Delegate instance.
* @type Array
*/
handles: {
value: false
},
/**
* @attribute container
* @description A selector query to get the container to listen for mousedown events on. All "nodes" should be a child of this container.
* @type String
*/
container: {
value: 'body'
},
/**
* @attribute nodes
* @description A selector query to get the children of the "container" to make draggable elements from.
* @type String
*/
nodes: {
value: '.dd-draggable'
},
/**
* @attribute opacity
* @description The opacity to change the proxy item to when dragging.
* @type String
*/
opacity: {
value: '.75'
},
/**
* @attribute opacityNode
* @description The node to set opacity on when dragging (dragNode or currentNode). Default: currentNode.
* @type String
*/
opacityNode: {
value: 'currentNode'
},
/**
* @attribute id
* @description The id of this Sortable, used to get a reference to this Sortable list from another list.
* @type String
*/
id: {
value: null
},
/**
* @attribute moveType
* @description How should an item move to another list: insert, swap, move, copy. Default: insert
* @type String
*/
moveType: {
value: 'insert'
},
/**
* @attribute invalid
* @description A selector string to test if a list item is invalid and not sortable
* @type String
*/
invalid: {
value: ''
}
},
/**
* @static
* @property _sortables
* @private
* @type Array
* @description Hash map of all Sortables on the page.
*/
_sortables: [],
/**
* @static
* @method _test
* @param {Node} node The node instance to test.
* @param {String|Node} test The node instance or selector string to test against.
* @description Test a Node or a selector for the container
*/
} else {
}
},
/**
* @static
* @method getSortable
* @param {String|Node} node The node instance or selector string to use to find a Sortable instance.
* @description Get a Sortable instance back from a node reference or a selector string.
*/
getSortable: function(node) {
var s = null;
s = v;
}
});
return s;
},
/**
* @static
* @method reg
* @param Sortable s A Sortable instance.
* @description Register a Sortable instance with the singleton to allow lookups later.
*/
reg: function(s) {
},
/**
* @static
* @method unreg
* @param Sortable s A Sortable instance.
* @description Unregister a Sortable instance with the singleton.
*/
unreg: function(s) {
if (v === s) {
Y.Sortable._sortables[k] = null;
delete Sortable._sortables[k];
}
});
}
});
/**
* @event copy
* @description A Sortable node was moved.
* @param {Event.Facade} event An Event Facade object with the following specific property added:
* <dl>
* <dt>same</dt><dd>Moved to the same list.</dd>
* <dt>drag</dt><dd>The Drag Object</dd>
* <dt>drop</dt><dd>The Drop Object</dd>
* </dl>
* @type {Event.Custom}
*
*
* @event move
* @description A Sortable node was moved.
* @param {Event.Facade} event An Event Facade object with the following specific property added:
* <dl>
* <dt>same</dt><dd>Moved to the same list.</dd>
* <dt>drag</dt><dd>The Drag Object</dd>
* <dt>drop</dt><dd>The Drop Object</dd>
* </dl>
* @type {Event.Custom}
*
*
* @event insert
* @description A Sortable node was moved.
* @param {Event.Facade} event An Event Facade object with the following specific property added:
* <dl>
* <dt>same</dt><dd>Moved to the same list.</dd>
* <dt>drag</dt><dd>The Drag Object</dd>
* <dt>drop</dt><dd>The Drop Object</dd>
* </dl>
* @type {Event.Custom}
*
*
* @event swap
* @description A Sortable node was moved.
* @param {Event.Facade} event An Event Facade object with the following specific property added:
* <dl>
* <dt>same</dt><dd>Moved to the same list.</dd>
* <dt>drag</dt><dd>The Drag Object</dd>
* <dt>drop</dt><dd>The Drop Object</dd>
* </dl>
* @type {Event.Custom}
*
*
* @event moved
* @description A Sortable node was moved.
* @param {Event.Facade} event An Event Facade object with the following specific property added:
* <dl>
* <dt>same</dt><dd>Moved to the same list.</dd>
* <dt>drag</dt><dd>The Drag Object</dd>
* <dt>drop</dt><dd>The Drop Object</dd>
* </dl>
* @type {Event.Custom}
*/