Merge branch 'master' of ssh://wisemapping.com/var/git-repos/wise-source

This commit is contained in:
Paulo Veiga 2011-12-01 18:08:17 -03:00
commit a482c410a2
7 changed files with 237 additions and 88 deletions

View File

@ -217,6 +217,10 @@
files="widget/TopicShapePanel.js"/> files="widget/TopicShapePanel.js"/>
<filelist dir="${basedir}/src/main/javascript/" <filelist dir="${basedir}/src/main/javascript/"
files="widget/IconPanel.js"/> files="widget/IconPanel.js"/>
<filelist dir="${basedir}/src/main/javascript/"
files="widget/IMenu.js"/>
<filelist dir="${basedir}/src/main/javascript/"
files="widget/ThinkmappingMenu.js"/>
<filelist dir="${basedir}/src/main/javascript/" <filelist dir="${basedir}/src/main/javascript/"
files="widget/Menu.js"/> files="widget/Menu.js"/>

View File

@ -167,7 +167,8 @@ mindplot.XMLMindmapSerializer_Beta = new Class({
$assert(rootElem.tagName == mindplot.XMLMindmapSerializer_Beta.MAP_ROOT_NODE, "This seem not to be a map document."); $assert(rootElem.tagName == mindplot.XMLMindmapSerializer_Beta.MAP_ROOT_NODE, "This seem not to be a map document.");
// Start the loading process ... // Start the loading process ...
var mindmap = new mindplot.model.Mindmap(); var version = rootElem.getAttribute("version");
var mindmap = new mindplot.model.Mindmap(mapId, version);
var children = rootElem.childNodes; var children = rootElem.childNodes;
for (var i = 0; i < children.length; i++) { for (var i = 0; i < children.length; i++) {

View File

@ -0,0 +1,67 @@
/*
* 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.widget.IMenu = new Class({
initialize : function(designer, containerId, mapId) {
$assert(designer, "designer can not be null");
$assert(containerId, "containerId can not be null");
this._designer = designer;
this._toolbarElems = [];
this._containerId = containerId;
this._mapId = mapId;
},
clear : function() {
this._toolbarElems.forEach(function(item) {
item.hide();
});
},
save:function (saveElem, designer, saveHistory) {
// Load map content ...
var mindmap = designer.getMindmap();
var mindmapProp = designer.getMindmapProperties();
// Display save message ..
if (saveHistory) {
$notify("Saving ...");
saveElem.setStyle('cursor', 'wait');
} else {
console.log("Saving without history ...");
}
// Call persistence manager for saving ...
var persistenceManager = mindplot.PersitenceManager.getInstance();
persistenceManager.save(mindmap, mindmapProp, saveHistory, {
onSuccess: function() {
if (saveHistory) {
saveElem.setStyle('cursor', 'pointer');
$notify("Save complete");
}
},
onError: function() {
if (saveHistory) {
saveElem.setStyle('cursor', 'pointer');
$notify("Save could not be completed. Try latter");
}
}
});
}
})

View File

@ -17,15 +17,12 @@
*/ */
mindplot.widget.Menu = new Class({ mindplot.widget.Menu = new Class({
initialize : function(designer, containerId, mapId, readOnly) { Extends: mindplot.widget.IMenu,
$assert(designer, "designer can not be null");
$assert(containerId, "containerId can not be null");
var baseUrl = "../css/widget";
// Init variables ... initialize : function(designer, containerId, mapId, readOnly) {
this._designer = designer; this.parent(designer, containerId, mapId);
this._toolbarElems = [];
this._containerId = containerId; var baseUrl = "../css/widget";
// Stop event propagation ... // Stop event propagation ...
$(this._containerId).addEvent('click', function(event) { $(this._containerId).addEvent('click', function(event) {
@ -179,7 +176,7 @@ mindplot.widget.Menu = new Class({
}; };
this._toolbarElems.push(new mindplot.widget.ColorPalettePanel('fontColor', fontColorModel, baseUrl)); this._toolbarElems.push(new mindplot.widget.ColorPalettePanel('fontColor', fontColorModel, baseUrl));
this.addButton('export', false, false, function() { this._addButton('export', false, false, function() {
var reqDialog = new MooDialog.Request('../c/export.htm?mapId=' + mapId, null, var reqDialog = new MooDialog.Request('../c/export.htm?mapId=' + mapId, null,
{'class': 'exportModalDialog', {'class': 'exportModalDialog',
closeButton:true, closeButton:true,
@ -194,72 +191,72 @@ mindplot.widget.Menu = new Class({
MooDialog.Request.active = reqDialog; MooDialog.Request.active = reqDialog;
}); });
this.addButton('print', false, false, function() { this._addButton('print', false, false, function() {
printMap(); printMap();
}); });
this.addButton('zoomIn', false, false, function() { this._addButton('zoomIn', false, false, function() {
designer.zoomIn(); designer.zoomIn();
}); });
this.addButton('zoomOut', false, false, function() { this._addButton('zoomOut', false, false, function() {
designer.zoomOut(); designer.zoomOut();
}); });
this.addButton('undoEdition', false, false, function() { this._addButton('undoEdition', false, false, function() {
designer.undo(); designer.undo();
}); });
this.addButton('redoEdition', false, false, function() { this._addButton('redoEdition', false, false, function() {
designer.redo(); designer.redo();
}); });
this.addButton('addTopic', true, false, function() { this._addButton('addTopic', true, false, function() {
designer.createChildForSelectedNode(); designer.createChildForSelectedNode();
}); });
this.addButton('deleteTopic', true, true, function() { this._addButton('deleteTopic', true, true, function() {
designer.deleteCurrentNode(); designer.deleteCurrentNode();
}); });
this.addButton('topicLink', true, false, function() { this._addButton('topicLink', true, false, function() {
designer.addLink(); designer.addLink();
}); });
this.addButton('topicRelation', true, false, function(event) { this._addButton('topicRelation', true, false, function(event) {
designer.showRelPivot(event); designer.showRelPivot(event);
}); });
this.addButton('topicNote', true, false, function() { this._addButton('topicNote', true, false, function() {
designer.addNote(); designer.addNote();
}); });
this.addButton('fontBold', true, false, function() { this._addButton('fontBold', true, false, function() {
designer.changeFontWeight(); designer.changeFontWeight();
}); });
this.addButton('fontItalic', true, false, function() { this._addButton('fontItalic', true, false, function() {
designer.changeFontStyle(); designer.changeFontStyle();
}); });
var saveElem = $('save'); var saveElem = $('save');
if (saveElem) { if (saveElem) {
this.addButton('save', false, false, function() { this._addButton('save', false, false, function() {
this._save(saveElem, designer, true); this.save(saveElem, designer, true);
}.bind(this)); }.bind(this));
if (!readOnly) { if (!readOnly) {
// To prevent the user from leaving the page with changes ... // To prevent the user from leaving the page with changes ...
$(window).addEvent('beforeunload', function () { $(window).addEvent('beforeunload', function () {
if (designer.needsSave()) { if (designer.needsSave()) {
this._save(saveElem, designer, false); this.save(saveElem, designer, false);
} }
}.bind(this)); }.bind(this));
// Autosave on a fixed period of time ... // Autosave on a fixed period of time ...
(function() { (function() {
if (designer.needsSave()) { if (designer.needsSave()) {
this._save(saveElem, designer, false); this.save(saveElem, designer, false);
} }
}.bind(this)).periodical(30000); }.bind(this)).periodical(30000);
} }
@ -267,7 +264,7 @@ mindplot.widget.Menu = new Class({
var discardElem = $('discard'); var discardElem = $('discard');
if (discardElem) { if (discardElem) {
this.addButton('discard', false, false, function() { this._addButton('discard', false, false, function() {
if (!readOnly) { if (!readOnly) {
displayLoading(); displayLoading();
@ -281,7 +278,7 @@ mindplot.widget.Menu = new Class({
var tagElem = $('tagIt'); var tagElem = $('tagIt');
if (tagElem) { if (tagElem) {
this.addButton('tagIt', false, false, function() { this._addButton('tagIt', false, false, function() {
var reqDialog = new MooDialog.Request('../c/tags.htm?mapId=' + mapId, null, var reqDialog = new MooDialog.Request('../c/tags.htm?mapId=' + mapId, null,
{'class': 'tagItModalDialog', {'class': 'tagItModalDialog',
closeButton:true, closeButton:true,
@ -298,7 +295,7 @@ mindplot.widget.Menu = new Class({
var shareElem = $('shareIt'); var shareElem = $('shareIt');
if (shareElem) { if (shareElem) {
this.addButton('shareIt', false, false, function() { this._addButton('shareIt', false, false, function() {
var reqDialog = new MooDialog.Request('../c/mymaps.htm?action=collaborator&userEmail=paulo%40pveiga.com.ar&mapId=' + mapId, null, var reqDialog = new MooDialog.Request('../c/mymaps.htm?action=collaborator&userEmail=paulo%40pveiga.com.ar&mapId=' + mapId, null,
{'class': 'shareItModalDialog', {'class': 'shareItModalDialog',
closeButton:true, closeButton:true,
@ -316,7 +313,7 @@ mindplot.widget.Menu = new Class({
var publishElem = $('publishIt'); var publishElem = $('publishIt');
if (publishElem) { if (publishElem) {
this.addButton('publishIt', false, false, function() { this._addButton('publishIt', false, false, function() {
var reqDialog = new MooDialog.Request('../c/publish.htm?mapId=' + mapId, null, var reqDialog = new MooDialog.Request('../c/publish.htm?mapId=' + mapId, null,
{'class': 'publishModalDialog', {'class': 'publishModalDialog',
closeButton:true, closeButton:true,
@ -335,7 +332,7 @@ mindplot.widget.Menu = new Class({
var historyElem = $('history'); var historyElem = $('history');
if (historyElem) { if (historyElem) {
this.addButton('history', false, false, function() { this._addButton('history', false, false, function() {
var reqDialog = new MooDialog.Request('../c/history.htm?action=list&goToMindmapList&mapId=' + mapId, null, var reqDialog = new MooDialog.Request('../c/history.htm?action=list&goToMindmapList&mapId=' + mapId, null,
{'class': 'historyModalDialog', {'class': 'historyModalDialog',
closeButton:true, closeButton:true,
@ -370,7 +367,7 @@ mindplot.widget.Menu = new Class({
var disable = false; var disable = false;
if (button.isTopicAction() && button.isRelAction()) { if (button.isTopicAction() && button.isRelAction()) {
disable = rels.length == 0 && topics.length == 0; disable = rels.length == 0 && topics.length == 0;
console.log(disable);
} else if (!button.isTopicAction() && !button.isRelAction()) { } else if (!button.isTopicAction() && !button.isRelAction()) {
disable = false; disable = false;
} }
@ -403,68 +400,14 @@ mindplot.widget.Menu = new Class({
} }
}) })
}.bind(this)); }.bind(this));
// designer.addEvent("modelUpdate", function(event) {
// if (event.undoSteps > 0) {
// $("undoEdition").setStyle("background-image", "url(../images/undo.png)");
// } else {
// $("undoEdition").setStyle("background-image", "url(../images/undo.png)");
// }
//
// if (event.redoSteps > 0) {
// $("redoEdition").setStyle("background-image", "url(../images/redo.png)");
// } else {
// $("redoEdition").setStyle("background-image", "url(../images/redo.png)");
// }
//
// });
}, },
addButton:function (buttonId, topic, rel, fn) { _addButton:function (buttonId, topic, rel, fn) {
// Register Events ... // Register Events ...
var button = new mindplot.widget.ToolbarItem(buttonId, function(event) { var button = new mindplot.widget.ToolbarItem(buttonId, function(event) {
fn(event); fn(event);
this.clear(); this.clear();
}.bind(this), {topicAction:topic,relAction:rel}); }.bind(this), {topicAction:topic,relAction:rel});
this._toolbarElems.push(button); this._toolbarElems.push(button);
},
clear : function() {
this._toolbarElems.forEach(function(item) {
item.hide();
});
},
_save:function (saveElem, designer, saveHistory) {
// Load map content ...
var mindmap = designer.getMindmap();
var mindmapProp = designer.getMindmapProperties();
// Display save message ..
if (saveHistory) {
$notify("Saving ...");
saveElem.setStyle('cursor', 'wait');
} else {
console.log("Saving without history ...");
} }
// Call persistence manager for saving ...
var persistenceManager = mindplot.PersitenceManager.getInstance();
persistenceManager.save(mindmap, mindmapProp, saveHistory, {
onSuccess: function() {
if (saveHistory) {
saveElem.setStyle('cursor', 'pointer');
$notify("Save complete");
}
},
onError: function() {
if (saveHistory) {
saveElem.setStyle('cursor', 'pointer');
$notify("Save could not be completed. Try latter");
}
}
});
}
}); });

View File

@ -0,0 +1,134 @@
/*
* 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.widget.ThinkmappingMenu = new Class({
Extends: mindplot.widget.IMenu,
initialize: function(designer, containerId, mapId) {
this.parent(designer, containerId, mapId);
var baseUrl = "../css/widget";
// Stop event propagation ...
$(this._containerId).addEvent('click', function(event) {
event.stopPropagation();
return false;
});
$(this._containerId).addEvent('dblclick', function(event) {
event.stopPropagation();
return false;
});
// Create panels ...
var designerModel = designer.getModel();
// DummyModel
var dummyModel =
{
getValue : function() {
return null;
},
setValue : function (hex) {
// Do Nothing
}
};
this._toolbarElems.push(new mindplot.widget.PersonalisePanel('personaliseButton', dummyModel, baseUrl));
this._toolbarElems.push(new mindplot.widget.AttachPanel('attachButton', dummyModel, baseUrl));
this._toolbarElems.push(new mindplot.widget.SharePanel('shareButton', dummyModel, baseUrl));
this._toolbarElems.push(new mindplot.widget.UserPanel('userButton', dummyModel, baseUrl));
this._addButton('newButton', function() {
var reqDialog = new MooDialog.Request('newMapDialog.htm', null,
{'class': 'newModalDialog',
closeButton:true,
destroyOnClose:true,
title:'Nouveau map'
});
reqDialog.setRequestOptions({
onRequest: function() {
reqDialog.setContent('loading...');
}
});
MooDialog.Request.active = reqDialog;
});
this._addButton('importButton', function() {
var reqDialog = new MooDialog.Request('importMap.htm', null,
{'class': 'importModalDialog',
closeButton:true,
destroyOnClose:true,
title:'Importez votre map'
});
reqDialog.setRequestOptions({
onRequest: function() {
reqDialog.setContent('loading...');
}
});
MooDialog.Request.active = reqDialog;
});
this._addButton('headerMapTitle', function() {
var reqDialog = new MooDialog.Request('renameMap.htm?mapId='+mapId, null,
{'class': 'renameModalDialog',
closeButton:true,
destroyOnClose:true,
title:'Renommez votre map'
});
reqDialog.setRequestOptions({
onRequest: function() {
reqDialog.setContent('loading...');
}
});
MooDialog.Request.active = reqDialog;
});
this._addButton('communicateButton', function() {
var reqDialog = new MooDialog.Request('sharing.htm?mapId='+mapId, null,
{'class': 'communicateModalDialog',
closeButton:true,
destroyOnClose:true,
title:'Collaboration'
});
reqDialog.setRequestOptions({
onRequest: function() {
reqDialog.setContent('loading...');
}
});
MooDialog.Request.active = reqDialog;
});
this._registerEvents(designer);
},
_registerEvents : function(designer) {
// Register on close events ...
this._toolbarElems.forEach(function(elem) {
elem.addEvent('show', function() {
this.clear()
}.bind(this));
}.bind(this));
},
_addButton:function (buttonId, fn) {
// Register Events ...
var button = new mindplot.widget.ToolbarItem(buttonId, function(event) {
fn(event);
this.clear();
}.bind(this), {topicAction:true, relAction:true});
this._toolbarElems.push(button);
}
})

View File

@ -133,7 +133,7 @@
<div id="headerMapTitle">Title: <span>${mindmap.title}</span></div> <div id="headerMapTitle">Title: <span>${mindmap.title}</span></div>
</div> </div>
<%@ include file="/jsp/toolbar.jsp" %> <%@ include file="/jsp/toolbar.jsf" %>
</div> </div>
<div id="mindplot"></div> <div id="mindplot"></div>