diff --git a/mindplot/src/main/javascript/DesignerActionRunner.js b/mindplot/src/main/javascript/DesignerActionRunner.js index fb836e28..bcb91383 100644 --- a/mindplot/src/main/javascript/DesignerActionRunner.js +++ b/mindplot/src/main/javascript/DesignerActionRunner.js @@ -30,16 +30,21 @@ mindplot.DesignerActionRunner = new Class({ command.execute(this._context); this._undoManager.enqueue(command); this.fireChangeEvent(); + mindplot.EventBus.instance.fireEvent(mindplot.EventBus.events.DoLayout); + }, undo: function() { this._undoManager.execUndo(this._context); this.fireChangeEvent(); + mindplot.EventBus.instance.fireEvent(mindplot.EventBus.events.DoLayout); }, redo: function() { this._undoManager.execRedo(this._context); this.fireChangeEvent(); + mindplot.EventBus.instance.fireEvent(mindplot.EventBus.events.DoLayout); + }, fireChangeEvent : function () { diff --git a/mindplot/src/main/javascript/DragTopic.js b/mindplot/src/main/javascript/DragTopic.js index a39a8ef3..d9e67958 100644 --- a/mindplot/src/main/javascript/DragTopic.js +++ b/mindplot/src/main/javascript/DragTopic.js @@ -1,232 +1,234 @@ -/* - * Copyright [2011] [wisemapping] - * - * Licensed under WiseMapping Public License, Version 1.0 (the "License"). - * It is basically the Apache License, Version 2.0 (the "License") plus the - * "powered by wisemapping" text requirement on every single page; - * you may not use this file except in compliance with the License. - * You may obtain a copy of the license at - * - * http://www.wisemapping.org/license - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -mindplot.DragTopic = new Class({ - initialize:function(dragShape, draggedNode, layoutManger) { - $assert(dragShape, 'Rect can not be null.'); - $assert(draggedNode, 'draggedNode can not be null.'); - $assert(layoutManger, 'layoutManger can not be null.'); - - this._elem2d = dragShape; - this._order = null; - this._draggedNode = draggedNode; - this._layoutManager = layoutManger; - this._position = new core.Point(); - this._isInWorkspace = false; - this._isFreeLayoutEnabled = false; - }, - - setOrder : function(order) { - this._order = order; - }, - - setPosition : function(x, y) { - // Update drag shadow position .... - var position = {x:x,y:y}; - if (this.isFreeLayoutOn() && this.isConnected()) { - var _layoutManager = this._layoutManager; - var par = this.getConnectedToTopic(); - position = _layoutManager.predict(par.getId(), this._draggedNode.getId(), position, true).position; - } - this._position.setValue(position.x, position.y); - - // Elements are positioned in the center. - // All topic element must be positioned based on the innerShape. - var draggedNode = this._draggedNode; - var size = draggedNode.getSize(); - var cx = Math.ceil(position.x - (size.width / 2)); - var cy = Math.ceil(position.y - (size.height / 2)); - this._elem2d.setPosition(cx, cy); - - // In case is not free, pivot must be draw ... - if (this.isConnected() && !this.isFreeLayoutOn()) { - var parent = this.getConnectedToTopic(); - var predict = this._layoutManager.predict(parent.getId(), this._draggedNode.getId(), this.getPosition()); - if (this._order != predict.order) { - var dragPivot = this._getDragPivot(); - var pivotPosition = predict.position; - dragPivot.connectTo(parent, pivotPosition); - this.setOrder(predict.order); - } - } - }, - - updateFreeLayout: function(event) { - var isFreeEnabled = (event.meta && Browser.Platform.mac) || (event.control && !Browser.Platform.mac); - if (this.isFreeLayoutOn() != isFreeEnabled) { - var dragPivot = this._getDragPivot(); - dragPivot.setVisibility(!isFreeEnabled); - this._isFreeLayoutEnabled = isFreeEnabled; - } - }, - - setVisibility:function(value) { - var dragPivot = this._getDragPivot(); - dragPivot.setVisibility(value); - }, - - isVisible:function() { - var dragPivot = this._getDragPivot(); - return dragPivot.isVisible(); - }, - - getInnerShape : function() { - return this._elem2d; - }, - - disconnect : function(workspace) { - // Clear connection line ... - var dragPivot = this._getDragPivot(); - dragPivot.disconnect(workspace); - }, - - canBeConnectedTo : function(targetTopic) { - $assert(targetTopic, 'parent can not be null'); - - var result = true; - if (!targetTopic.areChildrenShrunken() && !targetTopic.isCollapsed()) { - // Dragged node can not be connected to himself. - if (targetTopic == this._draggedNode) { - result = false; - } else { - var draggedNode = this.getDraggedTopic(); - var topicPosition = this.getPosition(); - - var targetTopicModel = targetTopic.getModel(); - var childTopicModel = draggedNode.getModel(); - - result = targetTopicModel.canBeConnected(childTopicModel, topicPosition, 18, targetTopic.getSize()); - } - } else { - result = false; - } - return result; - }, - - connectTo : function(parent) { - $assert(parent, 'Parent connection node can not be null.'); - - // Where it should be connected ? - var predict = designer._eventBussDispatcher._layoutManager.predict(parent.getId(), this._draggedNode.getId(), this.getPosition()); - - // Connect pivot ... - var dragPivot = this._getDragPivot(); - var position = predict.position; - dragPivot.connectTo(parent, position); - dragPivot.setVisibility(true); - - this.setOrder(predict.order); - }, - - getDraggedTopic : function() { - return this._draggedNode; - }, - - removeFromWorkspace : function(workspace) { - // Remove drag shadow. - workspace.removeChild(this._elem2d); - this._isInWorkspace = false; - - // Remove pivot shape. To improve performace it will not be removed. Only the visibility will be changed. - var dragPivot = this._getDragPivot(); - dragPivot.setVisibility(false); - - }, - - isInWorkspace: function() { - return this._isInWorkspace; - }, - - addToWorkspace : function(workspace) { - workspace.appendChild(this._elem2d); - var dragPivot = this._getDragPivot(); - dragPivot.addToWorkspace(workspace); - this._isInWorkspace = true; - }, - - _getDragPivot : function() { - return mindplot.DragTopic.__getDragPivot(); - }, - - getPosition:function() { - return this._position; - }, - - isDragTopic : function() { - return true; - }, - - applyChanges : function(workspace) { - $assert(workspace, 'workspace can not be null'); - - - var actionDispatcher = mindplot.ActionDispatcher.getInstance(); - var draggedTopic = this.getDraggedTopic(); - var topicId = draggedTopic.getId(); - var position = this.getPosition(); - - if (!this.isFreeLayoutOn()) { - var order = null; - var parent = null; - var isDragConnected = this.isConnected(); - if (isDragConnected) { - var targetTopic = this.getConnectedToTopic(); - order = this._order; - parent = targetTopic; - } - - // If the node is not connected, position based on the original drag topic position. - actionDispatcher.dragTopic(topicId, position, order, parent); - } else { - actionDispatcher.moveTopic(topicId, position); - } - }, - - getConnectedToTopic : function() { - var dragPivot = this._getDragPivot(); - return dragPivot.getTargetTopic(); - }, - - isConnected : function() { - return this.getConnectedToTopic() != null; - }, - - isFreeLayoutOn: function() { - return this._isFreeLayoutEnabled; - } - -}); - -mindplot.DragTopic.PIVOT_SIZE = {width:50,height:6}; - -mindplot.DragTopic.init = function(workspace) { - - $assert(workspace, "workspace can not be null"); - var pivot = mindplot.DragTopic.__getDragPivot(); - workspace.appendChild(pivot); -}; - -mindplot.DragTopic.__getDragPivot = function() { - var result = mindplot.DragTopic._dragPivot; - if (!$defined(result)) { - result = new mindplot.DragPivot(); - mindplot.DragTopic._dragPivot = result; - } - return result; -} - +/* + * Copyright [2011] [wisemapping] + * + * Licensed under WiseMapping Public License, Version 1.0 (the "License"). + * It is basically the Apache License, Version 2.0 (the "License") plus the + * "powered by wisemapping" text requirement on every single page; + * you may not use this file except in compliance with the License. + * You may obtain a copy of the license at + * + * http://www.wisemapping.org/license + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +mindplot.DragTopic = new Class({ + initialize:function(dragShape, draggedNode, layoutManger) { + $assert(dragShape, 'Rect can not be null.'); + $assert(draggedNode, 'draggedNode can not be null.'); + $assert(layoutManger, 'layoutManger can not be null.'); + + this._elem2d = dragShape; + this._order = null; + this._draggedNode = draggedNode; + this._layoutManager = layoutManger; + this._position = new core.Point(); + this._isInWorkspace = false; + this._isFreeLayoutEnabled = false; + }, + + setOrder : function(order) { + this._order = order; + }, + + setPosition : function(x, y) { + // Update drag shadow position .... + var position = {x:x,y:y}; + if (this.isFreeLayoutOn() && this.isConnected()) { + var _layoutManager = this._layoutManager; + var par = this.getConnectedToTopic(); + position = _layoutManager.predict(par.getId(), this._draggedNode.getId(), position, true).position; + } + this._position.setValue(position.x, position.y); + + // Elements are positioned in the center. + // All topic element must be positioned based on the innerShape. + var draggedNode = this._draggedNode; + var size = draggedNode.getSize(); + var cx = Math.ceil(position.x - (size.width / 2)); + var cy = Math.ceil(position.y - (size.height / 2)); + this._elem2d.setPosition(cx, cy); + + // In case is not free, pivot must be draw ... + if (this.isConnected() && !this.isFreeLayoutOn()) { + var parent = this.getConnectedToTopic(); + var predict = this._layoutManager.predict(parent.getId(), this._draggedNode.getId(), this.getPosition()); + if (this._order != predict.order) { + var dragPivot = this._getDragPivot(); + var pivotPosition = predict.position; + dragPivot.connectTo(parent, pivotPosition); + this.setOrder(predict.order); + } + } + }, + + updateFreeLayout: function(event) { + var isFreeEnabled = (event.meta && Browser.Platform.mac) || (event.control && !Browser.Platform.mac); + if (this.isFreeLayoutOn() != isFreeEnabled) { + var dragPivot = this._getDragPivot(); + dragPivot.setVisibility(!isFreeEnabled); + this._isFreeLayoutEnabled = isFreeEnabled; + } + }, + + setVisibility:function(value) { + var dragPivot = this._getDragPivot(); + dragPivot.setVisibility(value); + }, + + isVisible:function() { + var dragPivot = this._getDragPivot(); + return dragPivot.isVisible(); + }, + + getInnerShape : function() { + return this._elem2d; + }, + + disconnect : function(workspace) { + // Clear connection line ... + var dragPivot = this._getDragPivot(); + dragPivot.disconnect(workspace); + }, + + canBeConnectedTo : function(targetTopic) { + $assert(targetTopic, 'parent can not be null'); + + var result = true; + if (!targetTopic.areChildrenShrunken() && !targetTopic.isCollapsed()) { + // Dragged node can not be connected to himself. + if (targetTopic == this._draggedNode) { + result = false; + } else { + var draggedNode = this.getDraggedTopic(); + var topicPosition = this.getPosition(); + + var targetTopicModel = targetTopic.getModel(); + var childTopicModel = draggedNode.getModel(); + + result = targetTopicModel.canBeConnected(childTopicModel, topicPosition, 18, targetTopic.getSize()); + } + } else { + result = false; + } + return result; + }, + + connectTo : function(parent) { + $assert(parent, 'Parent connection node can not be null.'); + + // Where it should be connected ? + var predict = designer._eventBussDispatcher._layoutManager.predict(parent.getId(), this._draggedNode.getId(), this.getPosition()); + + // Connect pivot ... + var dragPivot = this._getDragPivot(); + var position = predict.position; + dragPivot.connectTo(parent, position); + dragPivot.setVisibility(true); + + this.setOrder(predict.order); + }, + + getDraggedTopic : function() { + return this._draggedNode; + }, + + removeFromWorkspace : function(workspace) { + // Remove drag shadow. + workspace.removeChild(this._elem2d); + this._isInWorkspace = false; + + // Remove pivot shape. To improve performace it will not be removed. Only the visibility will be changed. + var dragPivot = this._getDragPivot(); + dragPivot.setVisibility(false); + + }, + + isInWorkspace: function() { + return this._isInWorkspace; + }, + + addToWorkspace : function(workspace) { + workspace.appendChild(this._elem2d); + var dragPivot = this._getDragPivot(); + dragPivot.addToWorkspace(workspace); + this._isInWorkspace = true; + }, + + _getDragPivot : function() { + return mindplot.DragTopic.__getDragPivot(); + }, + + getPosition:function() { + return this._position; + }, + + isDragTopic : function() { + return true; + }, + + applyChanges : function(workspace) { + $assert(workspace, 'workspace can not be null'); + + + var actionDispatcher = mindplot.ActionDispatcher.getInstance(); + var draggedTopic = this.getDraggedTopic(); + var topicId = draggedTopic.getId(); + var position = this.getPosition(); + + if (!this.isFreeLayoutOn()) { + var order = null; + var parent = null; + var isDragConnected = this.isConnected(); + if (isDragConnected) { + var targetTopic = this.getConnectedToTopic(); + order = this._order; + parent = targetTopic; + } + + // If the node is not connected, position based on the original drag topic position. + actionDispatcher.dragTopic(topicId, position, order, parent); + } else { + actionDispatcher.moveTopic(topicId, position); + } + }, + + getConnectedToTopic : function() { + var dragPivot = this._getDragPivot(); + return dragPivot.getTargetTopic(); + }, + + isConnected : function() { + return this.getConnectedToTopic() != null; + }, + + isFreeLayoutOn: function() { +// return this._isFreeLayoutEnabled; + // Disable free layout ... + return false; + } + +}); + +mindplot.DragTopic.PIVOT_SIZE = {width:50,height:6}; + +mindplot.DragTopic.init = function(workspace) { + + $assert(workspace, "workspace can not be null"); + var pivot = mindplot.DragTopic.__getDragPivot(); + workspace.appendChild(pivot); +}; + +mindplot.DragTopic.__getDragPivot = function() { + var result = mindplot.DragTopic._dragPivot; + if (!$defined(result)) { + result = new mindplot.DragPivot(); + mindplot.DragTopic._dragPivot = result; + } + return result; +} + diff --git a/mindplot/src/main/javascript/StandaloneActionDispatcher.js b/mindplot/src/main/javascript/StandaloneActionDispatcher.js index 33df7fd5..712c89e7 100644 --- a/mindplot/src/main/javascript/StandaloneActionDispatcher.js +++ b/mindplot/src/main/javascript/StandaloneActionDispatcher.js @@ -231,7 +231,6 @@ mindplot.StandaloneActionDispatcher = new Class({ execute:function (command) { this._actionRunner.execute(command); - mindplot.EventBus.instance.fireEvent(mindplot.EventBus.events.DoLayout); } }); diff --git a/mindplot/src/main/javascript/commands/DeleteCommand.js b/mindplot/src/main/javascript/commands/DeleteCommand.js index 785e4a52..a4aca0a3 100644 --- a/mindplot/src/main/javascript/commands/DeleteCommand.js +++ b/mindplot/src/main/javascript/commands/DeleteCommand.js @@ -84,11 +84,13 @@ mindplot.commands.DeleteCommand = new Class({ var parentTopic = parent[index]; if (parentTopic != null) { commandContext.connect(topic, parentTopic); + topic.setOnFocus(); } }.bind(this) ); + this._deletedRelModel.forEach(function (model) { commandContext.addRelationship(model); }.bind(this));