From: Aleksander Ɓukasz Date: Mon, 18 Nov 2013 14:59:50 +0000 (+0100) Subject: smartxml: Doument.findSiblingParents X-Git-Url: https://git.mdrn.pl/fnpeditor.git/commitdiff_plain/65c64d3696e38bda0e2259d48c8d02978da7a3d8?ds=sidebyside;hp=ed98b7046fe7f1e484bf9d58d3981054f4b06563 smartxml: Doument.findSiblingParents --- diff --git a/src/smartxml/smartxml.js b/src/smartxml/smartxml.js index 9a402cf..ffbe4c2 100644 --- a/src/smartxml/smartxml.js +++ b/src/smartxml/smartxml.js @@ -399,6 +399,25 @@ $.extend(Document.prototype, Backbone.Events, { return wrapper; }, + getSiblingParents: function(params) { + var parents1 = [params.node1].concat(params.node1.parents()).reverse(), + parents2 = [params.node2].concat(params.node2.parents()).reverse(), + noSiblingParents = null; + + if(parents1.length === 0 || parents2.length === 0 || !(parents1[0].sameNode(parents2[0]))) { + return noSiblingParents; + } + + var i; + for(i = 0; i < Math.min(parents1.length, parents2.length); i++) { + if(parents1[i].sameNode(parents2[i])) { + continue; + } + break; + } + return {node1: parents1[i], node2: parents2[i]}; + }, + _wrapText: function(params) { params = _.extend({textNodeIdx: 0}, params); if(typeof params.textNodeIdx === 'number') { @@ -447,6 +466,11 @@ $.extend(Document.prototype, Backbone.Events, { wrapperElement.after({text: suffixOutside}); } return wrapperElement; + }, + + trigger: function() { + //console.log('trigger: ' + arguments[0] + (arguments[1] ? ', ' + arguments[1].type : '')); + Backbone.Events.trigger.apply(this, arguments); } }); diff --git a/src/smartxml/smartxml.test.js b/src/smartxml/smartxml.test.js index 00c3ee9..db9777f 100644 --- a/src/smartxml/smartxml.test.js +++ b/src/smartxml/smartxml.test.js @@ -506,6 +506,32 @@ describe('smartxml', function() { expect(parents).to.eql([b,a]); }); }); + + describe('finding sibling parents of two elements', function() { + it('returns elements themself if they have direct common parent', function() { + var doc = getDocumentFromXML('
A
B
'), + wrappingDiv = doc.root.contents()[0], + divA = wrappingDiv.contents()[0], + divB = wrappingDiv.contents()[1]; + + var siblingParents = doc.getSiblingParents({node1: divA, node2: divB}); + + expect(siblingParents.node1.sameNode(divA)).to.equal(true, 'divA'); + expect(siblingParents.node2.sameNode(divB)).to.equal(true, 'divB'); + }); + + it('returns sibling parents - example 1', function() { + var doc = getDocumentFromXML('
Alice has a cat
'), + aliceText = doc.root.contents()[0], + span = doc.root.contents()[1], + spanText = span.contents()[0]; + + var siblingParents = doc.getSiblingParents({node1: aliceText, node2: spanText}); + + expect(siblingParents.node1.sameNode(aliceText)).to.equal(true, 'aliceText'); + expect(siblingParents.node2.sameNode(span)).to.equal(true, 'span'); + }); + }); }); describe('Serializing document to WLXML', function() {