/** * Style.spec.js * (c) 2015~ Summernote Team * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import $ from 'jquery'; import range from '../../../../src/js/base/core/range'; import Style from '../../../../src/js/base/editing/Style'; var expect = chai.expect; describe('base:editing.Style', () => { var style = new Style(); describe('styleNodes', () => { it('should wrap selected text with span', () => { var $cont = $('

text

'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 0, $p[0].firstChild, 4); style.styleNodes(rng); expect($cont.html()).to.deep.equal('

text

'); }); it('should split text and wrap selected text with span', () => { var $cont = $('

text

'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 1, $p[0].firstChild, 3); style.styleNodes(rng); expect($cont.html()).to.deep.equal('

text

'); }); it('should split text and insert span', () => { var $cont = $('

text

'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 2, $p[0].firstChild, 2); style.styleNodes(rng); expect($cont.html()).to.deep.equal('

text

'); }); it('should just return a parent span', () => { var $cont = $('

text

'); var $span = $cont.find('span'); var rng = range.create($span[0].firstChild, 0, $span[0].firstChild, 4); style.styleNodes(rng); expect($cont.html()).to.deep.equal('

text

'); }); it('should wrap each texts with span', () => { var $cont = $('

boldspan

'); var $b = $cont.find('b'); var $span = $cont.find('span'); var rng = range.create($b[0].firstChild, 2, $span[0].firstChild, 2); style.styleNodes(rng); expect($cont.html()).to.deep.equal('

boldspan

'); }); it('should wrap each texts with span except not a single blood line', () => { var $cont = $('

boldspan

'); var $b = $cont.find('b'); var $span = $cont.find('span'); var rng = range.create($b[0].firstChild, 2, $span[0].firstChild, 4); style.styleNodes(rng); expect($cont.html()).to.deep.equal('

boldspan

'); }); it('should expand b tag when providing the expandClosestSibling option', () => { var $cont = $('

textbold

'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 0, $p[0].firstChild, 4); style.styleNodes(rng, { nodeName: 'B', expandClosestSibling: true }); expect($cont.html()).to.deep.equal('

textbold

'); }); it('should not expand b tag when providing the onlyPartialContains option', () => { var $cont = $('

textbold

'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 0, $p[0].firstChild, 4); style.styleNodes(rng, { nodeName: 'B', expandClosestSibling: true, onlyPartialContains: true }); expect($cont.html()).to.deep.equal('

textbold

'); }); }); });