wisemapping-open-source/wise-editor/src/main/webapp/js/editor.js

298 lines
9.4 KiB
JavaScript
Raw Normal View History

2012-02-21 19:37:15 +01:00
/*
2012-10-05 01:48:01 +02:00
* Copyright [2012] [wisemapping]
2012-02-21 19:37:15 +01:00
*
* 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.
*/
var designer = null;
function buildDesigner(options) {
var container = $(options.container);
$assert(container, 'container could not be null');
// Register load events ...
designer = new mindplot.Designer(options, container);
2012-07-01 22:21:02 +02:00
designer.addEvent('loadSuccess', function () {
window.waitDialog.close.delay(1000, window.waitDialog);
window.waitDialog = null;
window.mindmapLoadReady = true;
2012-02-21 19:37:15 +01:00
});
2012-07-01 22:21:02 +02:00
window.onerror = function (message, url, lineNo) {
2012-09-23 15:39:56 +02:00
// Ignore errors ...
if (message === "Script error." && lineNo == 0) {
2012-09-23 15:30:42 +02:00
// http://stackoverflow.com/questions/5913978/cryptic-script-error-reported-in-javascript-in-chrome-and-firefox
return;
}
2012-11-05 03:20:21 +01:00
// Transform error ...
2012-09-23 15:39:56 +02:00
var errorMsg = message;
if (typeof(message) === 'object' && message.srcElement && message.target) {
if (message.srcElement == '[object HTMLScriptElement]' && message.target == '[object HTMLScriptElement]') {
errorMsg = 'Error loading script';
} else {
errorMsg = 'Event Error - target:' + message.target + ' srcElement:' + message.srcElement;
}
}
2012-09-23 15:39:56 +02:00
errorMsg = errorMsg.toString();
2012-09-23 15:30:42 +02:00
new Request({
2012-07-01 22:21:02 +02:00
method:'post',
url:"/service/logger/editor",
headers:{"Content-Type":"application/json", "Accept":"application/json"},
emulation:false,
urlEncoded:false
}).post(JSON.encode({
2012-11-05 03:20:21 +01:00
jsErrorMsg:"Message: '" + errorMsg + "', line:'" + lineNo + "', url: :" + url,
2012-07-01 22:21:02 +02:00
jsStack:window.errorStack,
userAgent:navigator.userAgent,
mapId:options.mapId}));
2012-09-23 15:39:56 +02:00
// Close loading dialog ...
if (window.waitDialog) {
window.waitDialog.close.delay(1000, window.waitDialog);
window.waitDialog = null;
}
// Open error dialog only in case of mindmap loading errors. The rest of the error are reported but not display the dialog.
// Remove this in the near future.
if (!window.mindmapLoadReady) {
errorDialog.show();
}
2012-03-08 04:11:54 +01:00
};
2012-02-21 19:37:15 +01:00
// Configure default persistence manager ...
var persistence;
if (options.persistenceManager) {
if (options.persistenceManager instanceof String) {
persistence = eval("new " + options.persistenceManager + "()");
2012-02-21 19:37:15 +01:00
}
else {
persistence = options.persistenceManager;
2012-02-21 19:37:15 +01:00
}
} else {
persistence = new mindplot.LocalStorageManager();
}
mindplot.PersistenceManager.init(persistence);
// Register toolbar event ...
if ($('toolbar')) {
var menu = new mindplot.widget.Menu(designer, 'toolbar', options.mapId, "");
2012-02-21 19:37:15 +01:00
// If a node has focus, focus can be move to another node using the keys.
2012-07-01 22:21:02 +02:00
designer._cleanScreen = function () {
2012-02-21 19:37:15 +01:00
menu.clear()
};
}
return designer;
}
function loadDesignerOptions(jsonConf) {
// Load map options ...
var result;
2012-02-21 19:37:15 +01:00
if (jsonConf) {
var request = new Request.JSON({
2012-07-01 22:21:02 +02:00
url:jsonConf,
2012-02-21 19:37:15 +01:00
async:false,
2012-07-01 22:21:02 +02:00
onSuccess:function (options) {
this.options = options;
2012-02-21 19:37:15 +01:00
2012-07-01 22:21:02 +02:00
}.bind(this)
2012-02-21 19:37:15 +01:00
}
);
request.get();
result = this.options;
}
else {
// Set workspace screen size as default. In this way, resize issues are solved.
var containerSize = {
2012-07-01 22:21:02 +02:00
height:parseInt(screen.height),
width:parseInt(screen.width)
2012-02-21 19:37:15 +01:00
};
var viewPort = {
2012-07-01 22:21:02 +02:00
height:parseInt(window.innerHeight - 70), // Footer and Header
width:parseInt(window.innerWidth)
2012-02-21 19:37:15 +01:00
};
result = {readOnly:false, zoom:0.85, saveOnLoad:true, size:containerSize, viewPort:viewPort, container:'mindplot', locale:'en'};
2012-02-21 19:37:15 +01:00
}
return result;
}
editor = {};
editor.WaitDialog = new Class({
Extends:MooDialog,
2012-07-01 22:21:02 +02:00
initialize:function () {
2012-02-21 19:37:15 +01:00
var panel = this._buildPanel();
this.parent({
closeButton:false,
destroyOnClose:true,
autoOpen:false,
2012-02-21 19:37:15 +01:00
useEscKey:false,
title:'',
2012-07-01 22:21:02 +02:00
onInitialize:function (wrapper) {
wrapper.setStyle('opacity', 0);
2012-04-02 03:06:49 +02:00
this.wrapper.setStyle('display', 'none');
this.fx = new Fx.Morph(wrapper, {
2012-07-01 22:21:02 +02:00
duration:100,
transition:Fx.Transitions.Bounce.easeOut
});
},
2012-07-01 22:21:02 +02:00
onBeforeOpen:function () {
this.overlay = new Overlay(this.options.inject, {
2012-07-01 22:21:02 +02:00
duration:this.options.duration
});
this.overlay.open();
this.fx.start({
2012-07-01 22:21:02 +02:00
'margin-top':[-200, -100],
opacity:[0, 1]
}).chain(function () {
this.fireEvent('show');
this.wrapper.setStyle('display', 'block');
}.bind(this));
},
2012-07-01 22:21:02 +02:00
onBeforeClose:function () {
this.fx.start({
2012-07-01 22:21:02 +02:00
'margin-top':[-100, 0],
opacity:0,
duration:200
}).chain(function () {
this.fireEvent('hide');
this.wrapper.setStyle('display', 'none');
}.bind(this));
}}
);
this.setContent(panel);
},
2012-07-01 22:21:02 +02:00
_buildPanel:function () {
var result = new Element('div');
result.setStyles({
'text-align':'center',
2012-07-01 22:21:02 +02:00
width:'400px'
});
2012-07-01 22:21:02 +02:00
var img = new Element('img', {'src':'images/ajax-loader.gif'});
2012-06-20 23:01:02 +02:00
img.setStyle('margin-top', '15px');
img.inject(result);
return result;
},
2012-07-01 22:21:02 +02:00
show:function () {
this.open();
},
2012-07-01 22:21:02 +02:00
destroy:function () {
this.parent();
this.overlay.destroy();
}
});
editor.FatalErrorDialog = new Class({
Extends:MooDialog,
2012-07-01 22:21:02 +02:00
initialize:function () {
this.parent({
closeButton:false,
destroyOnClose:true,
autoOpen:true,
useEscKey:false,
title:'Outch!!. An unexpected error has occurred',
2012-07-01 22:21:02 +02:00
onInitialize:function (wrapper) {
2012-02-21 19:37:15 +01:00
wrapper.setStyle('opacity', 0);
2012-04-02 03:06:49 +02:00
this.wrapper.setStyle('display', 'none');
2012-02-21 19:37:15 +01:00
this.fx = new Fx.Morph(wrapper, {
2012-07-01 22:21:02 +02:00
duration:100,
transition:Fx.Transitions.Bounce.easeOut
2012-02-21 19:37:15 +01:00
});
},
2012-07-01 22:21:02 +02:00
onBeforeOpen:function () {
var panel = this._buildPanel();
this.setContent(panel);
2012-02-21 19:37:15 +01:00
this.overlay = new Overlay(this.options.inject, {
2012-07-01 22:21:02 +02:00
duration:this.options.duration
2012-02-21 19:37:15 +01:00
});
if (this.options.closeOnOverlayClick)
this.overlay.addEvent('click', this.close.bind(this));
2012-02-21 19:37:15 +01:00
this.overlay.open();
this.fx.start({
2012-07-01 22:21:02 +02:00
'margin-top':[-200, -100],
opacity:[0, 1]
}).chain(function () {
2012-02-21 19:37:15 +01:00
this.fireEvent('show');
2012-04-02 03:06:49 +02:00
this.wrapper.setStyle('display', 'block');
2012-02-21 19:37:15 +01:00
}.bind(this));
2012-04-02 03:06:49 +02:00
},
2012-02-21 19:37:15 +01:00
2012-07-01 22:21:02 +02:00
onBeforeClose:function () {
2012-02-21 19:37:15 +01:00
this.fx.start({
2012-07-01 22:21:02 +02:00
'margin-top':[-100, 0],
opacity:0,
duration:200
}).chain(function () {
2012-04-02 03:06:49 +02:00
this.wrapper.setStyle('display', 'none');
2012-02-21 19:37:15 +01:00
this.fireEvent('hide');
2012-04-02 03:06:49 +02:00
2012-02-21 19:37:15 +01:00
}.bind(this));
}}
);
2012-02-21 19:37:15 +01:00
},
2012-07-01 22:21:02 +02:00
destroy:function () {
this.parent();
this.overlay.destroy();
},
2012-07-01 22:21:02 +02:00
_buildPanel:function () {
2012-02-21 19:37:15 +01:00
var result = new Element('div');
result.setStyles({
'text-align':'center',
2012-07-01 22:21:02 +02:00
width:'400px'
2012-02-21 19:37:15 +01:00
});
2012-07-01 22:21:02 +02:00
var p = new Element('p', {'text':$msg('UNEXPECTED_ERROR_LOADING')});
p.inject(result);
2012-07-01 22:21:02 +02:00
var img = new Element('img', {'src':'images/alert-sign.png'});
2012-02-21 19:37:15 +01:00
img.inject(result);
2012-02-21 19:37:15 +01:00
return result;
},
2012-07-01 22:21:02 +02:00
show:function () {
2012-02-21 19:37:15 +01:00
this.open();
}
});
// Show loading dialog ...
waitDialog = new editor.WaitDialog();
waitDialog.show();
errorDialog = new editor.FatalErrorDialog();
2012-02-21 19:37:15 +01:00
// Loading libraries ...
Asset.javascript("js/mindplot-min.js");