Menu refactor
parent
e520d9baba
commit
a300899673
|
@ -209,6 +209,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"/>
|
||||||
|
|
||||||
|
|
|
@ -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++) {
|
||||||
|
|
|
@ -0,0 +1,120 @@
|
||||||
|
/*
|
||||||
|
* 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;
|
||||||
|
},
|
||||||
|
|
||||||
|
_registerEvents : function(designer) {
|
||||||
|
|
||||||
|
// Register on close events ...
|
||||||
|
this._toolbarElems.forEach(function(elem) {
|
||||||
|
elem.addEvent('show', function() {
|
||||||
|
this.clear()
|
||||||
|
}.bind(this));
|
||||||
|
}.bind(this));
|
||||||
|
|
||||||
|
designer.addEvent('onblur', function() {
|
||||||
|
var topics = designer.getModel().filterSelectedTopics();
|
||||||
|
var rels = designer.getModel().filterSelectedRelations();
|
||||||
|
|
||||||
|
this._toolbarElems.forEach(function(button) {
|
||||||
|
var disable = false;
|
||||||
|
if (button.isTopicAction() && button.isRelAction()) {
|
||||||
|
disable = rels.length == 0 && topics.length == 0;
|
||||||
|
|
||||||
|
} else if (!button.isTopicAction() && !button.isRelAction()) {
|
||||||
|
disable = false;
|
||||||
|
}
|
||||||
|
else if (button.isTopicAction() && topics.length == 0) {
|
||||||
|
disable = true;
|
||||||
|
} else if (button.isRelAction() && rels.length == 0) {
|
||||||
|
disable = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (disable) {
|
||||||
|
button.disable();
|
||||||
|
} else {
|
||||||
|
button.enable();
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
}.bind(this));
|
||||||
|
|
||||||
|
designer.addEvent('onfocus', function() {
|
||||||
|
var topics = designer.getModel().filterSelectedTopics();
|
||||||
|
var rels = designer.getModel().filterSelectedRelations();
|
||||||
|
|
||||||
|
this._toolbarElems.forEach(function(button) {
|
||||||
|
if (button.isTopicAction() && topics.length > 0) {
|
||||||
|
button.enable();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (button.isRelAction() && rels.length > 0) {
|
||||||
|
button.enable();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}.bind(this));
|
||||||
|
},
|
||||||
|
|
||||||
|
clear : function() {
|
||||||
|
this._toolbarElems.forEach(function(item) {
|
||||||
|
item.hide();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
_save:function (saveElem, designer, saveHistory) {
|
||||||
|
|
||||||
|
console.log("save!!!!"); //TODO(gb): Remove trace!!!
|
||||||
|
// 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");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
})
|
|
@ -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,57 +191,57 @@ 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));
|
||||||
|
|
||||||
|
@ -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,
|
||||||
|
@ -353,118 +350,12 @@ mindplot.widget.Menu = new Class({
|
||||||
this._registerEvents(designer);
|
this._registerEvents(designer);
|
||||||
},
|
},
|
||||||
|
|
||||||
_registerEvents : function(designer) {
|
_addButton:function (buttonId, topic, rel, fn) {
|
||||||
|
|
||||||
// Register on close events ...
|
|
||||||
this._toolbarElems.forEach(function(elem) {
|
|
||||||
elem.addEvent('show', function() {
|
|
||||||
this.clear()
|
|
||||||
}.bind(this));
|
|
||||||
}.bind(this));
|
|
||||||
|
|
||||||
designer.addEvent('onblur', function() {
|
|
||||||
var topics = designer.getModel().filterSelectedTopics();
|
|
||||||
var rels = designer.getModel().filterSelectedRelations();
|
|
||||||
|
|
||||||
this._toolbarElems.forEach(function(button) {
|
|
||||||
var disable = false;
|
|
||||||
if (button.isTopicAction() && button.isRelAction()) {
|
|
||||||
disable = rels.length == 0 && topics.length == 0;
|
|
||||||
|
|
||||||
} else if (!button.isTopicAction() && !button.isRelAction()) {
|
|
||||||
disable = false;
|
|
||||||
}
|
|
||||||
else if (button.isTopicAction() && topics.length == 0) {
|
|
||||||
disable = true;
|
|
||||||
} else if (button.isRelAction() && rels.length == 0) {
|
|
||||||
disable = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (disable) {
|
|
||||||
button.disable();
|
|
||||||
} else {
|
|
||||||
button.enable();
|
|
||||||
}
|
|
||||||
|
|
||||||
})
|
|
||||||
}.bind(this));
|
|
||||||
|
|
||||||
designer.addEvent('onfocus', function() {
|
|
||||||
var topics = designer.getModel().filterSelectedTopics();
|
|
||||||
var rels = designer.getModel().filterSelectedRelations();
|
|
||||||
|
|
||||||
this._toolbarElems.forEach(function(button) {
|
|
||||||
if (button.isTopicAction() && topics.length > 0) {
|
|
||||||
button.enable();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (button.isRelAction() && rels.length > 0) {
|
|
||||||
button.enable();
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}.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) {
|
|
||||||
// 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");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
});
|
|
@ -0,0 +1,171 @@
|
||||||
|
/*
|
||||||
|
* 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', false, false, 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', false, false, 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', false, false, 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', false, false, 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._addButton('save', false, false, function() {
|
||||||
|
this._save(saveElem, designer, true);
|
||||||
|
}.bind(this));
|
||||||
|
|
||||||
|
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));
|
||||||
|
|
||||||
|
designer.addEvent('onblur', function() {
|
||||||
|
var topics = designer.getModel().filterSelectedTopics();
|
||||||
|
var rels = designer.getModel().filterSelectedRelations();
|
||||||
|
|
||||||
|
this._toolbarElems.forEach(function(button) {
|
||||||
|
var disable = false;
|
||||||
|
if (button.isTopicAction() && button.isRelAction()) {
|
||||||
|
disable = rels.length == 0 && topics.length == 0;
|
||||||
|
|
||||||
|
} else if (!button.isTopicAction() && !button.isRelAction()) {
|
||||||
|
disable = false;
|
||||||
|
}
|
||||||
|
else if (button.isTopicAction() && topics.length == 0) {
|
||||||
|
disable = true;
|
||||||
|
} else if (button.isRelAction() && rels.length == 0) {
|
||||||
|
disable = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (disable) {
|
||||||
|
button.disable();
|
||||||
|
} else {
|
||||||
|
button.enable();
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
}.bind(this));
|
||||||
|
|
||||||
|
designer.addEvent('onfocus', function() {
|
||||||
|
var topics = designer.getModel().filterSelectedTopics();
|
||||||
|
var rels = designer.getModel().filterSelectedRelations();
|
||||||
|
|
||||||
|
this._toolbarElems.forEach(function(button) {
|
||||||
|
if (button.isTopicAction() && topics.length > 0) {
|
||||||
|
button.enable();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (button.isRelAction() && rels.length > 0) {
|
||||||
|
button.enable();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}.bind(this));
|
||||||
|
}
|
||||||
|
})
|
Loading…
Reference in New Issue