From 75564c17ec0042c87d2a6855f5fa736bb4c7c3ea Mon Sep 17 00:00:00 2001 From: Pablo Luna Date: Fri, 15 Apr 2011 11:42:05 +0100 Subject: [PATCH] adding support for independent topics in freemind layout --- mindplot/src/main/javascript/Topic.js | 2 + .../freeMind/ReconnectTopicCommand.js | 27 ++-- .../layoutManagers/BaseLayoutManager.js | 2 +- .../layoutManagers/FreeMindLayoutManager.js | 132 ++++++++++++------ .../layoutManagers/OriginalLayoutManager.js | 6 +- .../boards/freeMindBoards/Board.js | 7 +- .../freeMindBoards/CentralTopicBoard.js | 2 +- 7 files changed, 120 insertions(+), 58 deletions(-) diff --git a/mindplot/src/main/javascript/Topic.js b/mindplot/src/main/javascript/Topic.js index 5de53ad0..d79b8a98 100644 --- a/mindplot/src/main/javascript/Topic.js +++ b/mindplot/src/main/javascript/Topic.js @@ -1193,6 +1193,8 @@ mindplot.Topic.prototype.disconnect = function(workspace) var childModel = this.getModel(); childModel.disconnect(); + this._parent = null; + // Remove graphical element from the workspace... outgoingLine.removeFromWorkspace(workspace); diff --git a/mindplot/src/main/javascript/commands/freeMind/ReconnectTopicCommand.js b/mindplot/src/main/javascript/commands/freeMind/ReconnectTopicCommand.js index 0100d50d..e690b4a1 100644 --- a/mindplot/src/main/javascript/commands/freeMind/ReconnectTopicCommand.js +++ b/mindplot/src/main/javascript/commands/freeMind/ReconnectTopicCommand.js @@ -45,7 +45,7 @@ mindplot.commands.freeMind.ReconnectTopicCommand = mindplot.Command.extend( node._originalPosition = modTopic.originalPos; } } - var oldParent = commandContext.findTopics(parseInt(this._oldParent))[0]; + var oldParent = this._oldParent!=null?commandContext.findTopics(parseInt(this._oldParent))[0]:null; node.relationship = this._relationship; node._relationship_oldParent = oldParent; node._relationship_index = this._index; @@ -60,11 +60,12 @@ mindplot.commands.freeMind.ReconnectTopicCommand = mindplot.Command.extend( delete node._relationship_oldParent; delete node._relationship_sibling_node; delete node._relationship_index; + delete node._originalPosition; }, undoExecute: function(commandContext) { var node = commandContext.findTopics(parseInt(this._node))[0]; - var targetNode = commandContext.findTopics(parseInt(this._oldParent))[0]; + var targetNode = this._oldParent!=null?commandContext.findTopics(parseInt(this._oldParent))[0]:null; var keys = this._modifiedTopics.keys(); for(var i=0; in2.getPosition().y; + if(n1.getPosition() && n2.getPosition()) + return n1.getPosition().y>n2.getPosition().y; + else + return true; }); return result; }, @@ -106,31 +109,50 @@ mindplot.layoutManagers.FreeMindLayoutManager = mindplot.layoutManagers.BaseLayo var pos = screen.getWorkspaceMousePosition(event); pos.x = Math.round(pos.x); pos.y = Math.round(pos.y); - //If still in same side - if(Math.sign(nodePos.x)==Math.sign(pos.x) || (Math.sign(nodePos.x)!=Math.sign(pos.x) && !this._isCentralTopic(node.getParent()))){ - var x = nodePos.x - pos.x; - var y = nodePos.y - pos.y; - var delta = new core.Point(Math.round(x), Math.round(y)); - var board = this.getTopicBoardForTopic(node.getParent()); - board.updateEntry(node, delta, this._modifiedTopics); - } else { - var parentBoard = this.getTopicBoardForTopic(node.getParent()); - var entryObj = parentBoard.findNodeEntryIndex(node); - var entry = entryObj.table[entryObj.index]; - parentBoard._removeEntry(node, entryObj.table, entryObj.index, this._modifiedTopics); - this._changeChildrenSide(node, pos, this._modifiedTopics); - node.setPosition(pos.clone(), false); - if(this._modifiedTopics.set){ - var key = node.getId(); - if(this._modifiedTopics.hasKey(key)){ - nodePos = this._modifiedTopics.get(key).originalPos; - } - this._modifiedTopics.set(key,{originalPos:nodePos, newPos:pos}); + //if isolated topic + if(node.getParent()==null){ + //If still in same side + if(Math.sign(nodePos.x)==Math.sign(pos.x)){ + var x = nodePos.x - pos.x; + var y = nodePos.y - pos.y; + var delta = new core.Point(Math.round(x), Math.round(y)); + var actualPos = node.getPosition().clone(); + var newPos = new core.Point(actualPos.x-(delta.x==null?0:delta.x), actualPos.y-delta.y); + node.setPosition(newPos, false); + this._addToModifiedList(this._modifiedTopics, node.getId(), actualPos, newPos); + this._updateChildrenBoards(node, delta, this._modifiedTopics); + }else{ + this._changeChildrenSide(node, pos, this._modifiedTopics); + node.setPosition(pos.clone(), false); + this._addToModifiedList(this._modifiedTopics, node.getId(), nodePos, pos); } - entryObj = parentBoard.findNewNodeEntryIndex(entry); - parentBoard._addEntry(entry, entryObj.table, entryObj.index); - parentBoard._updateTable(entryObj.index, entryObj.table, this._modifiedTopics, true); + }else{ + //If still in same side + if(Math.sign(nodePos.x)==Math.sign(pos.x) || (Math.sign(nodePos.x)!=Math.sign(pos.x) && !this._isCentralTopic(node.getParent()))){ + var x = nodePos.x - pos.x; + var y = nodePos.y - pos.y; + var delta = new core.Point(Math.round(x), Math.round(y)); + var board = this.getTopicBoardForTopic(node.getParent()); + board.updateEntry(node, delta, this._modifiedTopics); + } else { + var parentBoard = this.getTopicBoardForTopic(node.getParent()); + var entryObj = parentBoard.findNodeEntryIndex(node); + var entry = entryObj.table[entryObj.index]; + parentBoard._removeEntry(node, entryObj.table, entryObj.index, this._modifiedTopics); + this._changeChildrenSide(node, pos, this._modifiedTopics); + node.setPosition(pos.clone(), false); + if(this._modifiedTopics.set){ + var key = node.getId(); + if(this._modifiedTopics.hasKey(key)){ + nodePos = this._modifiedTopics.get(key).originalPos; + } + this._modifiedTopics.set(key,{originalPos:nodePos, newPos:pos}); + } + entryObj = parentBoard.findNewNodeEntryIndex(entry); + parentBoard._addEntry(entry, entryObj.table, entryObj.index); + parentBoard._updateTable(entryObj.index, entryObj.table, this._modifiedTopics, true); + } } this._isMovingNode=false; } @@ -202,7 +224,7 @@ mindplot.layoutManagers.FreeMindLayoutManager = mindplot.layoutManagers.BaseLayo }, _updateBoard:function(node, modifiedTopics){ var parent = node; - if(!this._isCentralTopic(parent)){ + if(!this._isCentralTopic(parent) && parent.getParent()!=null){ var parentBoard = this.getTopicBoardForTopic(parent.getParent()); var result = parentBoard.findNodeEntryIndex(parent); var parentEntry = result.table[result.index]; @@ -278,8 +300,10 @@ mindplot.layoutManagers.FreeMindLayoutManager = mindplot.layoutManagers.BaseLayo this._mouseOverListeners = new Hash(); this._mouseOutListeners = new Hash(); - var board = this.getTopicBoardForTopic(topic.getParent()); - this._currentIndex = board.findNodeEntryIndex(topic).index; + if(topic.getParent()!=null){ + var board = this.getTopicBoardForTopic(topic.getParent()); + this._currentIndex = board.findNodeEntryIndex(topic).index; + } var topics = this.getDesigner()._getTopics(); // Disable all mouse events. @@ -383,12 +407,12 @@ mindplot.layoutManagers.FreeMindLayoutManager = mindplot.layoutManagers.BaseLayo //Check that it has to be relocated if(this._createShape !=null){ if(this._createShape == "Child"){ - if(node.getParent().getId() == this._targetNode.getId()){ + if(node.getParent()!=null && node.getParent().getId() == this._targetNode.getId()){ var mod = this._modifiedTopics.get(node.getId()); if(Math.sign(mod.originalPos.x) == Math.sign(node.getPosition().x)) this._createShape = null; } - }else if(node.getParent().getId() == this._targetNode.getParent().getId()){ + }else if(node.getParent()!=null && this._targetNode.getParent()!= null && node.getParent().getId() == this._targetNode.getParent().getId()){ var chkboard = this.getTopicBoardForTopic(this._targetNode.getParent()); var mod = this._modifiedTopics.get(node.getId()); var chk = chkboard.findNodeEntryIndex(node, mod.originalPos); @@ -447,7 +471,7 @@ mindplot.layoutManagers.FreeMindLayoutManager = mindplot.layoutManagers.BaseLayo pos.y = Math.round(pos.y); var nodePos = this.getPosition(); //if it is on the child half side, or it is central topic add it as child - if(layoutManager._isCentralTopic(this) || ((Math.sign(nodePos.x)>0 && pos.x>nodePos.x) || (Math.sign(nodePos.x)<0 && pos.x0 && pos.x>nodePos.x) || (Math.sign(nodePos.x)<0 && pos.x0){ + var firstChild = table[0]; + var marginTop = entry.getPosition()-(firstChild.getPosition()-firstChild.getTotalMarginTop()); + board.setNodeChildrenMarginTop(entry,marginTop); + var lastChild = table[table.length-1]; + var marginBottom = (lastChild.getPosition()+lastChild.getTotalMarginBottom())-entry.getPosition(); + board.setNodeChildrenMarginBottom(entry,marginBottom); + } else { + board.setNodeChildrenMarginTop(entry, 0); + board.setNodeChildrenMarginBottom(entry, 0); + } } - var entry = entryObj.table[entryObj.index]; - parentBoard._removeEntry(node, entryObj.table, entryObj.index, []); var targetBoard = this.getTopicBoardForTopic(targetNode); var table = targetBoard._getTableForNode(node); var index; @@ -613,8 +657,18 @@ mindplot.layoutManagers.FreeMindLayoutManager = mindplot.layoutManagers.BaseLayo targetBoard._addEntry(entry, table, index); targetBoard._updateTable(index, table, [], true); this._updateBoard(targetNode,[]); - this._updateBoard(node._relationship_oldParent,[]); + if(node._relationship_oldParent!=null) + this._updateBoard(node._relationship_oldParent,[]); + mindplot.EventBus.instance.fireEvent(mindplot.EventBus.events.NodeMouseOutEvent,[node ]); + }, + _addToModifiedList:function(modifiedTopics, key, originalpos, newPos){ + if(modifiedTopics.set){ + if(modifiedTopics.hasKey(key)){ + originalpos = modifiedTopics.get(key).originalPos; + } + modifiedTopics.set(key,{originalPos:originalpos, newPos:newPos}); + } } }); diff --git a/mindplot/src/main/javascript/layoutManagers/OriginalLayoutManager.js b/mindplot/src/main/javascript/layoutManagers/OriginalLayoutManager.js index bb26305c..2eb72b88 100644 --- a/mindplot/src/main/javascript/layoutManagers/OriginalLayoutManager.js +++ b/mindplot/src/main/javascript/layoutManagers/OriginalLayoutManager.js @@ -33,11 +33,7 @@ mindplot.layoutManagers.OriginalLayoutManager = mindplot.layoutManagers.BaseLayo return result; }, _nodeResizeEvent:function(node){ - if(this._isCentralTopic(node)){ - var size = node.getSize(); - if(!this._isCentralTopic(node)) - this.getTopicBoardForTopic(node).updateChildrenPosition(node,size.height/2, []); - } + }, _nodeRepositionateEvent:function(node){ this.getTopicBoardForTopic(node).repositionate(); diff --git a/mindplot/src/main/javascript/layoutManagers/boards/freeMindBoards/Board.js b/mindplot/src/main/javascript/layoutManagers/boards/freeMindBoards/Board.js index 1a77584a..85745360 100644 --- a/mindplot/src/main/javascript/layoutManagers/boards/freeMindBoards/Board.js +++ b/mindplot/src/main/javascript/layoutManagers/boards/freeMindBoards/Board.js @@ -15,7 +15,10 @@ mindplot.layoutManagers.boards.freeMindBoards.Board = mindplot.layoutManagers.bo core.assert(false, "no Board implementation found!") }, removeTopicFromBoard:function(node, modifiedTopics){ - var result = this.findNodeEntryIndex(node); + var pos; + if(node._originalPosition) + pos = node._originalPosition; + var result = this.findNodeEntryIndex(node, pos); core.assert(result.index