From 7ec7c18524fde6548089752e5499e213c71baaff Mon Sep 17 00:00:00 2001 From: Paulo Veiga Date: Sat, 21 Jan 2012 16:37:13 -0300 Subject: [PATCH] Serialize node text with CDATA. --- .../javascript/XMLMindmapSerializer_Pela.js | 33 +++++++++++++++++-- 1 file changed, 30 insertions(+), 3 deletions(-) diff --git a/mindplot/src/main/javascript/XMLMindmapSerializer_Pela.js b/mindplot/src/main/javascript/XMLMindmapSerializer_Pela.js index 2097b022..b4a4508a 100644 --- a/mindplot/src/main/javascript/XMLMindmapSerializer_Pela.js +++ b/mindplot/src/main/javascript/XMLMindmapSerializer_Pela.js @@ -65,7 +65,6 @@ mindplot.XMLMindmapSerializer_Pela = new Class({ if (topic.getType() == mindplot.model.INodeModel.CENTRAL_TOPIC_TYPE) { parentTopic.setAttribute("central", true); } else { - var parent = topic.getParent(); var pos = topic.getPosition(); parentTopic.setAttribute("position", pos.x + ',' + pos.y); @@ -77,7 +76,7 @@ mindplot.XMLMindmapSerializer_Pela = new Class({ var text = topic.getText(); if ($defined(text)) { - parentTopic.setAttribute('text', text); + this._noteTextToXML(document, parentTopic, text); } var shape = topic.getShapeType(); @@ -179,6 +178,17 @@ mindplot.XMLMindmapSerializer_Pela = new Class({ return noteDom; }, + _noteTextToXML : function(document, elem, text) { + if (text.indexOf('\n') == -1) { + elem.setAttribute('text', text); + } else { + var textDom = document.createElement("text"); + var cdata = document.createCDATASection(text); + textDom.appendChild(cdata); + elem.appendChild(textDom); + } + }, + _relationshipToXML : function(document, relationship) { var relationDom = document.createElement("relationship"); relationDom.setAttribute("srcTopicId", relationship.getFromNode()); @@ -319,7 +329,7 @@ mindplot.XMLMindmapSerializer_Pela = new Class({ for (var i = 0; i < children.length; i++) { var child = children[i]; if (child.nodeType == Node.ELEMENT_NODE) { - $assert(child.tagName == "topic" || child.tagName == "icon" || child.tagName == "link" || child.tagName == "note", 'Illegal node type:' + child.tagName); + $assert(child.tagName == "topic" || child.tagName == "icon" || child.tagName == "link" || child.tagName == "note" || child.tagName == "text", 'Illegal node type:' + child.tagName); if (child.tagName == "topic") { var childTopic = this._deserializeNode(child, mindmap); childTopic.connectTo(topic); @@ -332,7 +342,11 @@ mindplot.XMLMindmapSerializer_Pela = new Class({ } else if (child.tagName == "note") { var note = this._deserializeNote(child, topic); topic.addNote(note); + } else if (child.tagName == "text") { + var nodeText = this._deserializeNodeText(child); + topic.setText(nodeText); } + } } return topic; @@ -362,6 +376,19 @@ mindplot.XMLMindmapSerializer_Pela = new Class({ return topic.createNote(value); }, + _deserializeNodeText: function(domElem) { + + var children = domElem.childNodes; + var value = null; + for (var i = 0; i < children.length; i++) { + var child = children[i]; + if (child.nodeType == Node.CDATA_SECTION_NODE) { + value = child.nodeValue; + } + } + return value; + }, + _deserializeRelationship : function(domElement, mindmap) { var srcId = domElement.getAttribute("srcTopicId"); var destId = domElement.getAttribute("destTopicId");