").addClass("node").append($nodeContent);
- }
+ .end()
+ .html();
+
+ //Increaments the node count which is used to link the source list and the org chart
+ nodeCount++;
+ $node.data("tree-node", nodeCount);
+ $nodeDiv = $("
").addClass("node")
+ .data("tree-node", nodeCount)
+ .append($nodeContent);
// Expand and contract nodes
if ($childNodes.length > 0) {
diff --git a/jquery.jOrgChart.js b/jquery.jOrgChart.js
index 89411b2..627309c 100644
--- a/jquery.jOrgChart.js
+++ b/jquery.jOrgChart.js
@@ -35,7 +35,7 @@
distance : 40,
helper : 'clone',
opacity : 0.8,
- revert : true,
+ revert : 'invalid',
revertDuration : 100,
snap : 'div.node.expanded',
snapMode : 'inner',
@@ -68,68 +68,27 @@
// Drop event handler for nodes
$('div.node').bind("drop", function handleDropEvent( event, ui ) {
- var sourceNode = ui.draggable;
- var targetNode = $(this);
-
- // finding nodes based on plaintext and html
- // content is hard!
- var targetLi = $('li').filter(function(){
-
- li = $(this).clone()
- .children("ul,li")
- .remove()
- .end();
- var attr = li.attr('id');
- if (typeof attr !== 'undefined' && attr !== false) {
- return li.attr("id") == targetNode.attr("id");
- }
- else {
- return li.html() == targetNode.html();
- }
-
- });
-
- var sourceLi = $('li').filter(function(){
-
- li = $(this).clone()
- .children("ul,li")
- .remove()
- .end();
- var attr = li.attr('id');
- if (typeof attr !== 'undefined' && attr !== false) {
- return li.attr("id") == sourceNode.attr("id");
- }
- else {
- return li.html() == sourceNode.html();
- }
-
- });
-
- var sourceliClone = sourceLi.clone();
+
+ var targetID = $(this).data("tree-node");
+ var targetLi = $this.find("li").filter(function() { return $(this).data("tree-node") === targetID; } );
+ var targetUl = targetLi.children('ul');
+
+ var sourceID = ui.draggable.data("tree-node");
+ var sourceLi = $this.find("li").filter(function() { return $(this).data("tree-node") === sourceID; } );
var sourceUl = sourceLi.parent('ul');
+
+ if (targetUl.length > 0){
+ targetUl.append(sourceLi);
+ } else {
+ targetLi.append("
");
+ targetLi.children('ul').append(sourceLi);
+ }
- if(sourceUl.children('li').size() > 1){
- sourceLi.remove();
- }else{
+ //Removes any empty lists
+ if (sourceUl.children().length === 0){
sourceUl.remove();
}
-
- var id = sourceLi.attr("id");
-
- if(targetLi.children('ul').size() >0){
- if (typeof id !== 'undefined' && id !== false) {
- targetLi.children('ul').append('
'+sourceliClone.html()+'');
- }else{
- targetLi.children('ul').append('
'+sourceliClone.html()+'');
- }
- }else{
- if (typeof id !== 'undefined' && id !== false) {
- targetLi.append('
');
- }else{
- targetLi.append('
');
- }
- }
-
+
}); // handleDropEvent
} // Drag and drop
@@ -142,7 +101,8 @@
chartClass : "jOrgChart",
dragAndDrop: false
};
-
+
+ var nodeCount = 0;
// Method that recursively builds the tree
function buildNode($node, $appendTo, level, opts) {
var $table = $("
");
@@ -162,15 +122,15 @@
var $nodeContent = $node.clone()
.children("ul,li")
.remove()
- .end()
- .html();
-
- var new_node_id = $node.attr("id");
- if (typeof new_node_id !== 'undefined' && new_node_id !== false) {
- $nodeDiv = $("
").addClass("node").attr("id", $node.attr("id")).append($nodeContent);
- }else{
- $nodeDiv = $("
").addClass("node").append($nodeContent);
- }
+ .end()
+ .html();
+
+ //Increaments the node count which is used to link the source list and the org chart
+ nodeCount++;
+ $node.data("tree-node", nodeCount);
+ $nodeDiv = $("
").addClass("node")
+ .data("tree-node", nodeCount)
+ .append($nodeContent);
// Expand and contract nodes
if ($childNodes.length > 0) {