aTextElement;
canvas.fromXMLDocument(doc);
- aTextElement = utils.getElementForTextNode(aTextNode);
+ aTextElement = utils.getElementForNode(aTextNode);
aTextElement.setText('');
expect(sectionChildren[1].wlxmlNode.getTagName()).to.equal('a');
});
+ it('handles moving text node to another parent', function() {
+ var c = getCanvasFromXML('<section>Alice<div><span>has</span></div>a cat.</section>'),
+ doc = c.wlxmlDocument,
+ text = doc.root.contents()[0],
+ div = doc.root.contents()[1];
+
+ div.append(text);
+
+ var sectionChildren = c.doc().children();
+ expect(sectionChildren.length).to.equal(2);
+ expect(sectionChildren[0].wlxmlNode.sameNode(div)).to.equal(true);
+ expect(sectionChildren[1].getText()).to.equal('a cat.');
+
+ expect(div.contents().length).to.equal(2);
+ expect(div.contents()[0].getTagName()).to.equal('span');
+ expect(div.contents()[1].getText()).to.equal('Alice');
+ });
+
it('handles change in a text node', function() {
var c = getCanvasFromXML('<section>Alice</section>');
c.wlxmlDocument.root.contents()[0].setText('cat');
}
if(event.type === 'nodeMoved') {
- /* globals Node */
- if(event.meta.node.nodeType === Node.TEXT_NODE) {
- actionArg = utils.getElementForTextNode(event.meta.node);
- } else {
- actionArg = utils.getElementForNode(event.meta.node);
- }
+ actionArg = utils.getElementForNode(event.meta.node, event.meta.parent);
} else {
actionArg = event.meta.node;
}
};
-var getElementForNode = function(node) {
-
- var ptr = node.nodeType === Node.TEXT_NODE ? node.parent() : node;
- while(!ptr.getData('canvasElement')) {
- ptr = ptr.parent();
+var getElementForNode = function(node, withParent) {
+ if(node.nodeType === Node.TEXT_NODE) {
+ return _getElementForTextNode(node, withParent);
}
- return ptr.getData('canvasElement');
+ while(!node.getData('canvasElement')) {
+ node = node.parent();
+ }
+ return node.getData('canvasElement');
+};
+
+var _getElementForTextNode = function(textNode, withParent) {
+ var parentElement = getElementForNode(withParent || textNode.parent()),
+ toret;
+ parentElement.children().some(function(child) {
+ if(child.wlxmlNode.sameNode(textNode)) {
+ toret = child;
+ return true;
+ }
+ });
+ return toret;
};
var getElementForDetachedNode = function(node, originalParent) {
return ptr.getData('canvasElement');
};
-var getElementForTextNode = function(textNode) {
- var parentElement = getElementForNode(textNode.parent()),
- toret;
- parentElement.children().some(function(child) {
- if(child.wlxmlNode.sameNode(textNode)) {
- toret = child;
- return true;
- }
- });
- return toret;
-};
+
return {
nearestInDocumentOrder: nearestInDocumentOrder,
ZWS: '\u200B'
},
getElementForNode: getElementForNode,
- getElementForDetachedNode: getElementForDetachedNode,
- getElementForTextNode: getElementForTextNode
+ getElementForDetachedNode: getElementForDetachedNode
};
});