X-Git-Url: https://git.mdrn.pl/fnpeditor.git/blobdiff_plain/86ecf0f60182c63eecb45c7cc836fe5a050d8d8a..058eee1d91537d6b060be9f5eb5433287e7303fc:/modules/documentCanvas/canvas/canvas.test3.js?ds=sidebyside diff --git a/modules/documentCanvas/canvas/canvas.test3.js b/modules/documentCanvas/canvas/canvas.test3.js index a92ddb3..4a7c661 100644 --- a/modules/documentCanvas/canvas/canvas.test3.js +++ b/modules/documentCanvas/canvas/canvas.test3.js @@ -28,6 +28,15 @@ describe('Canvas', function() { child = root.children()[1]; expect(root.childIndex(child)).to.equal(1); }); + + describe('DocumentTextElement can have its content set', function() { + var c = canvas.fromXML('
Alice
'), + root = c.doc(), + text = root.children()[0]; + + text.setText('a cat'); + expect(root.children()[0].getText()).to.equal('a cat'); + }); }); }); @@ -138,6 +147,16 @@ describe('Canvas', function() { expect(children[0].sameNode(appended)); }); + it('can put new TextElement at the end', function() { + var c = canvas.fromXML('
'), + appended = c.doc().append({text: 'Alice'}), + children = c.doc().children(); + + expect(children.length).to.equal(1); + expect(children[0].sameNode(appended)); + expect(children[0].getText()).to.equal('Alice'); + }); + it('can put new NodeElement after another NodeElement', function() { var c = canvas.fromXML('
'), div = c.doc().children()[0], @@ -146,6 +165,28 @@ describe('Canvas', function() { expect(children.length).to.equal(2); expect(children[1].sameNode(added)); }); + + it('can put new Nodeelement before another element', function() { + var c = canvas.fromXML('
'), + div = c.doc().children()[0], + added = div.before({tag: 'header', klass: 'some.class'}), + children = c.doc().children(); + expect(children.length).to.equal(2); + expect(children[0].sameNode(added)); + }); + + it('can put new DocumentNodeElement after DocumentTextElement', function() { + var c = canvas.fromXML('
Alice
'), + text = c.doc().children()[0], + added = text.after({tag: 'p'}), + children = c.doc().children(); + + expect(children.length).to.equal(2); + expect(children[0]).to.be.instanceOf(documentElement.DocumentTextElement); + expect(children[0].getText()).to.equal('Alice'); + expect(children[1]).to.be.instanceOf(documentElement.DocumentNodeElement); + expect(children[1].sameNode(added)).to.be.true; + }); }); describe('wrapping', function() { @@ -171,6 +212,55 @@ describe('Canvas', function() { expect(returned.sameNode(parent)).to.be.true; expect(returned.sameNode(parent2)).to.be.true; }); + + it('wraps part of DocumentTextElement', function() { + var c = canvas.fromXML('
Alice has a cat
'), + text = c.doc().children()[0]; + + var returned = text.wrapWithNodeElement({tag: 'header', klass: 'some.class', start: 5, end: 12}), + children = c.doc().children(); + + expect(children.length).to.equal(3); + + expect(children[0]).to.be.instanceOf(documentElement.DocumentTextElement); + expect(children[0].getText()).to.equal('Alice'); + + expect(children[1].sameNode(returned)).to.be.true; + expect(children[1].children().length).to.equal(1); + expect(children[1].children()[0].getText()).to.equal(' has a '); + + expect(children[2]).to.be.instanceOf(documentElement.DocumentTextElement); + expect(children[2].getText()).to.equal('cat'); + }); + + it('wraps text spanning multiple sibling DocumentTextNodes', function() { + var c = canvas.fromXML('
Alice has a small cat
'), + section = c.doc(), + wrapper = c.wrapText({ + inside: section, + _with: {tag: 'span', klass: 'some.class'}, + offsetStart: 6, + offsetEnd: 4, + textNodeIdx: [0,2] + }); + + expect(section.children().length).to.equal(2); + expect(section.children()[0]).to.be.instanceOf(documentElement.DocumentTextElement); + expect(section.children()[0].getText()).to.equal('Alice '); + + var wrapper2 = section.children()[1]; + expect(wrapper2.sameNode(wrapper)).to.be.true; + + var wrapperChildren = wrapper.children(); + expect(wrapperChildren.length).to.equal(3); + expect(wrapperChildren[0].getText()).to.equal('has a '); + + expect(wrapperChildren[1]).to.be.instanceOf(documentElement.DocumentNodeElement); + expect(wrapperChildren[1].children().length).to.equal(1); + expect(wrapperChildren[1].children()[0].getText()).to.equal('small'); + + expect(wrapperChildren[2].getText()).to.equal(' cat'); + }); }); });