Mindmap list new using rest services ...

This commit is contained in:
Paulo Gustavo Veiga 2012-04-06 20:18:25 -03:00
parent bca68f407d
commit 70b8fe8727
7 changed files with 75 additions and 121 deletions

View File

@ -1,7 +1,6 @@
package com.wisemapping.rest;
import com.sun.jdi.IntegerType;
import com.wisemapping.exceptions.WiseMappingException;
import com.wisemapping.model.MindMap;
import com.wisemapping.model.MindmapUser;

View File

@ -1,7 +1,7 @@
log4j.rootLogger=WARN, stdout, R
log4j.logger.com.wisemapping=WARN,stdout,R
log4j.logger.org.springframework=WARN,stdout,R
log4j.logger.org.codehaus.jackson=WARN,stdout,R
log4j.logger.org.springframework=DEBUG,stdout,R
log4j.logger.org.codehaus.jackson=DEBUG,stdout,R
# Stdout logger <20>
log4j.appender.stdout=org.apache.log4j.ConsoleAppender

View File

@ -115,11 +115,6 @@
<put name="body" value="/jsp/newMap.jsp"/>
</definition>
<definition name="newMap" extends="pageTemplate">
<put name="title" value="NEW_MINDMAP"/>
<put name="details" value="FIELD_REQUIRED_MSG"/>
<put name="body" value="/jsp/newMap.jsp"/>
</definition>
<definition name="newMapError" extends="pageTemplate">
<put name="title" value="NEW_MINDMAP"/>

View File

@ -1,102 +0,0 @@
/*
* 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.
*/
var Panel = new Class({
options:{
width:'140px',
height:250,
opacity:0.9,
panelButton:null,
content:null,
frame:null,
onStart:Class.empty,
onComplete:Class.empty
},
initialize:function(options){
this.setOptions(options);
this.buildBody();
//atach listener to button
this.options.panelButton.addEvent('click',this.openPanel.bindWithEvent(this));
},
buildBody:function(){
var opts = this.options;
opts.frame = new Element('div');
if($defined(opts.content))
{
this.setContent(opts.content);
}
},
setContent:function(content){
this.options.content=content;
this.options.content.inject(this.options.frame);
this.setInitialStyles();
this.options.frame.injectBefore(this.options.panelButton);
},
setInitialStyles:function(){
var opts = this.options;
var buttonTop = opts.panelButton.getTop();
var buttonLeft = opts.panelButton.getLeft();
var bodyHeight = parseInt(opts.panelButton.getParent().getStyle('height'));
var coordinates = opts.panelButton.getCoordinates();
var width = opts.width || coordinates.width;
var elemCoords = {
top:'0px',
left:coordinates.left,
width:width,
height:'0px',
zIndex:'10',
overflow:'hidden'
};
var elemStyles = {
backgroundColor: opts.backgroundColor||'blue',
opacity: opts.opacity,
position:'absolute'
}
opts.frame.setStyles(elemCoords).setStyles(elemStyles);
},
openPanel:function(){
this.fireEvent('onStart');
var button = this.options.panelButton;
button.removeEvents('click');
button.addEvent('click',this.hidePanel.bindWithEvent(this));
var top = parseInt(this.options.frame.getStyle('top'));
var fx = this.options.frame.effects({duration:500, onComplete:function(){this.options.content.fireEvent('show');}.bind(this)});
fx.start({'height':[0,this.options.height],'top':[top, top-this.options.height]});
this.fireEvent('onComplete');
},
hidePanel:function(){
this.fireEvent('onStart');
var button = this.options.panelButton;
button.removeEvents('click');
button.addEvent('click',this.openPanel.bindWithEvent(this));
var top = parseInt(this.options.frame.getStyle('top'));
this.options.content.fireEvent('hide');
var fx = this.options.frame.effects({duration:500});
fx.start({'height':[this.options.height,0],'top':[top, top+this.options.height]});
this.fireEvent('onComplete');
}
});
Panel.implement(new Events, new Options);

View File

@ -50,7 +50,6 @@ jQuery.fn.dataTableExt.removeSelectedRows = function() {
url: "../service/maps/batch?ids=" + mapIds.join(","),
type:"DELETE",
success : function(data, textStatus, jqXHR) {
console.log("delete success");
var trs = $('.select input:checked[id!="selectAll"]').parent().parent();
trs.each(function() {
$('#mindmapListTable').dataTable().fnDeleteRow(this);
@ -60,6 +59,4 @@ jQuery.fn.dataTableExt.removeSelectedRows = function() {
alert("Unexpected error removing maps. Refresh before continue.");
}
});
};

View File

@ -9,8 +9,6 @@
<link rel="icon" href="${pageContext.request.contextPath}/images/favicon.ico" type="image/x-icon"/>
<link rel="shortcut icon" href="${pageContext.request.contextPath}/images/favicon.ico" type="image/x-icon"/>
<script type='text/javascript' src='../js/mootools-core.js'></script>
<link rel="stylesheet/less" type="text/css" href="css/mymaps.less"/>
<script src="js/less.js" type="text/javascript"></script>
@ -163,8 +161,37 @@
$("#buttons .newMap").button({
icons: { primary: "ui-icon-circle-plus" }
}).click(function() {
window.location = "c/newMap.htm"
});
$("#new-dialog-modal").dialog({
modal: true,
buttons: {
"Create": function() {
var formData = {};
$('#new-dialog-modal input').each(function(index, elem) {
formData[elem.name] = elem.value;
});
jQuery.ajax("../service/maps", {
async:false,
dataType: 'json',
data: JSON.stringify(formData),
type: 'POST',
contentType:"application/json; charset=utf-8",
success : function(data, textStatus, jqXHR) {
var location = jqXHR.getResponseHeader("Location");
var mapId = location.substring(location.lastIndexOf('/') + 1, location.length);
window.location = "c/editor.htm?action=open&mapId=" + mapId;
},
error: function() {
alert("Unexpected error removing maps. Refresh before continue.");
}
});
},
Cancel: function() {
$(this).dialog("close");
}
}
});
});
$("#buttons .importMap").button({
icons: { primary: "ui-icon-trash" }
@ -196,8 +223,6 @@
}
});
});
</script>
</head>
<body>
@ -217,6 +242,27 @@
<div id="delete-dialog-modal" title="Delete maps" style="display: none">
<p>Are you sure you want to delete maps <span></span> ?</p>
</div>
<div id="new-dialog-modal" title="New" style="display: none">
<table>
<tr>
<td class="formLabel">
<span class="fieldRequired">*</span>
<label for="title"><spring:message code="NAME"/>:</label>
</td>
<td>
<input name="title" id="title" tabindex="1" type="text" required="true"/>
</td>
</tr>
<tr>
<td class="formLabel">
<label for="description"><spring:message code="DESCRIPTION"/>:</label>
</td>
<td>
<input name="description" id="description" tabindex="2"/>
</td>
</tr>
</table>
</div>
<div id="share-dialog-modal" title="Share maps" style="display: none">
<p>Are you sure you want to share maps <span></span> ?</p>
</div>

View File

@ -14,11 +14,30 @@ public class JsonTest {
@Test
void deserialize() throws IOException {
String mapJson = "{\"id\":\"1\",\"xml\":\"<map name=\\\"1\\\" version=\\\"tango\\\"><topic central=\\\"true\\\" text=\\\"ss\\\" id=\\\"1\\\"/></map>\",\"properties\":\"{\\\"zoom\\\":0.85}\"}";
ObjectMapper mapper = new ObjectMapper();
final RestMindmap restMindmap = mapper.readValue(mapJson, RestMindmap.class);
String json1 = "{\"id\":\"1\",\"xml\":\"<map name=\\\"1\\\" version=\\\"tango\\\"><topic central=\\\"true\\\" text=\\\"ss\\\" id=\\\"1\\\"/></map>\",\"properties\":\"{\\\"zoom\\\":0.85}\"}";
mapper.readValue(json1, RestMindmap.class);
String json2 = "{\"title\":\"some title\",\"description\":\"description here\"}";
mapper.readValue(json2, RestMindmap.class);
String userJson = "{\"username\":\"admin\",\"email\":\"admin@wisemapping.org\",\"tags\":[],\"creationDate\":1329706800000,\"firstname\":\"Wise\",\"lastname\":\"test\",\"password\":\"test\"}";
final RestUser restUser = mapper.readValue(userJson, RestUser.class);
}
@Test
void serialize() throws IOException {
String mapJson = "{\"id\":\"1\",\"xml\":\"<map name=\\\"1\\\" version=\\\"tango\\\"><topic central=\\\"true\\\" text=\\\"ss\\\" id=\\\"1\\\"/></map>\",\"properties\":\"{\\\"zoom\\\":0.85}\"}";
ObjectMapper mapper = new ObjectMapper();
final RestMindmap value = new RestMindmap();
value.setTitle("titl");
value.setTitle("desck");
final String restMindmap = mapper.writeValueAsString(value);
System.out.println(restMindmap);
}
}