2014-03-24 06:59:45 +01:00
module ( "tinymce.Formatter - Remove" , {
setupModule : function ( ) {
document . getElementById ( 'view' ) . innerHTML = '<textarea id="elm1"></textarea><div id="elm2"></div>' ;
QUnit . stop ( ) ;
tinymce . init ( {
selector : "textarea" ,
2014-10-23 04:07:15 +02:00
plugins : wpPlugins ,
2014-06-18 01:49:00 +02:00
external _plugins : { noneditable : '../../../../tests/qunit/editor/external-plugins/noneditable/plugin.min.js' } , // WP
2014-03-24 06:59:45 +01:00
indent : false ,
add _unload _trigger : false ,
skin : false ,
extended _valid _elements : 'b,i,span[style|contenteditable]' ,
entities : 'raw' ,
valid _styles : {
'*' : 'color,font-size,font-family,background-color,font-weight,font-style,text-decoration,float,margin,margin-top,margin-right,margin-bottom,margin-left,display'
} ,
disable _nodechange : true ,
init _instance _callback : function ( ed ) {
window . editor = ed ;
QUnit . start ( ) ;
}
} ) ;
}
2014-02-10 02:11:25 +01:00
} ) ;
function getContent ( ) {
return editor . getContent ( ) . toLowerCase ( ) . replace ( /[\r]+/g , '' ) ;
2014-03-24 06:59:45 +01:00
}
2014-02-10 02:11:25 +01:00
test ( 'Inline element on selected text' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . getBody ( ) . innerHTML = '<p><b>1234</b></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'b' ) [ 0 ] . firstChild , 0 ) ;
rng . setEnd ( editor . dom . select ( 'b' ) [ 0 ] . firstChild , 4 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p>1234</p>' , 'Inline element on selected text' ) ;
} ) ;
test ( 'Inline element on selected text with remove=all' , function ( ) {
editor . formatter . register ( 'format' , { selector : 'b' , remove : 'all' } ) ;
editor . getBody ( ) . innerHTML = '<p><b title="text">1234</b></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'b' ) [ 0 ] . firstChild , 0 ) ;
rng . setEnd ( editor . dom . select ( 'b' ) [ 0 ] . firstChild , 4 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p>1234</p>' , 'Inline element on selected text with remove=all' ) ;
} ) ;
test ( 'Inline element on selected text with remove=none' , function ( ) {
editor . formatter . register ( 'format' , { selector : 'span' , styles : { fontWeight : 'bold' } , remove : 'none' } ) ;
editor . getBody ( ) . innerHTML = '<p><span style="font-weight:bold">1234</span></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'p' ) [ 0 ] , 0 ) ;
rng . setEnd ( editor . dom . select ( 'p' ) [ 0 ] , 1 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><span>1234</span></p>' , 'Inline element on selected text with remove=none' ) ;
} ) ;
test ( 'Inline element style where element is format root' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'span' , styles : { fontWeight : 'bold' } } ) ;
editor . getBody ( ) . innerHTML = '<p><span style="font-weight:bold; color:#FF0000"><em>1234</em></span></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'em' ) [ 0 ] . firstChild , 1 ) ;
rng . setEnd ( editor . dom . select ( 'em' ) [ 0 ] . firstChild , 3 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) ,
'<p><span style="color: #ff0000; font-weight: bold;">' +
'<em>1</em></span><span style="color: #ff0000;"><em>23</em></span>' +
'<span style=\"color: #ff0000; font-weight: bold;\"><em>4' +
'</em></span></p>' ,
'Inline element style where element is format root' ) ;
} ) ;
test ( 'Partially selected inline element text' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . getBody ( ) . innerHTML = '<p><b>1234</b></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'b' ) [ 0 ] . firstChild , 2 ) ;
rng . setEnd ( editor . dom . select ( 'b' ) [ 0 ] . firstChild , 4 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><b>12</b>34</p>' , 'Partially selected inline element text' ) ;
} ) ;
test ( 'Partially selected inline element text with children' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . getBody ( ) . innerHTML = '<p><b><em><span>1234</span></em></b></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'span' ) [ 0 ] . firstChild , 2 ) ;
rng . setEnd ( editor . dom . select ( 'span' ) [ 0 ] . firstChild , 4 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><b><em><span>12</span></em></b><em><span>34</span></em></p>' , 'Partially selected inline element text with children' ) ;
} ) ;
test ( 'Partially selected inline element text with complex children' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'span' , styles : { fontWeight : 'bold' } } ) ;
editor . getBody ( ) . innerHTML = '<p><span style="font-weight:bold"><em><span style="color:#ff0000;font-weight:bold">1234</span></em></span></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'span' ) [ 1 ] . firstChild , 2 ) ;
rng . setEnd ( editor . dom . select ( 'span' ) [ 1 ] . firstChild , 4 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><span style="font-weight: bold;"><em><span style="color: #ff0000; font-weight: bold;">12</span></em></span><em><span style="color: #ff0000;">34</span></em></p>' , 'Partially selected inline element text with complex children' ) ;
} ) ;
test ( 'Inline elements with exact flag' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'span' , styles : { color : '#ff0000' } , exact : true } ) ;
editor . getBody ( ) . innerHTML = '<p><span style="font-size:10px;color:#ff0000">1234</span><span style="font-size:10px;color:#00ff00">1234</span></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'p' ) [ 0 ] , 0 ) ;
rng . setEnd ( editor . dom . select ( 'p' ) [ 0 ] , 2 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><span style="font-size: 10px;">1234</span><span style="color: #00ff00; font-size: 10px;">1234</span></p>' , 'Inline elements with exact flag' ) ;
} ) ;
test ( 'Inline elements with variables' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'span' , styles : { color : '%color' } , exact : true } ) ;
editor . getBody ( ) . innerHTML = '<p><span style="font-size:10px;color:#ff0000">1234</span><span style="font-size:10px;color:#00ff00">1234</span></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'p' ) [ 0 ] , 0 ) ;
rng . setEnd ( editor . dom . select ( 'p' ) [ 0 ] , 2 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' , { color : '#ff0000' } ) ;
equal ( getContent ( ) , '<p><span style="font-size: 10px;">1234</span><span style="color: #00ff00; font-size: 10px;">1234</span></p>' , 'Inline elements on selected text with variables' ) ;
} ) ;
test ( 'Inline elements with functions and variables' , function ( ) {
editor . formatter . register ( 'format' , {
inline : 'span' ,
styles : {
color : function ( vars ) {
return vars . color + "00" ;
}
} ,
exact : true
} ) ;
editor . getBody ( ) . innerHTML = '<p><span style="font-size:10px;color:#ff0000">1234</span><span style="font-size:10px;color:#00ff00">1234</span></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'p' ) [ 0 ] , 0 ) ;
rng . setEnd ( editor . dom . select ( 'p' ) [ 0 ] , 2 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' , {
color : '#ff00'
} ) ;
equal ( getContent ( ) , '<p><span style="font-size: 10px;">1234</span><span style="color: #00ff00; font-size: 10px;">1234</span></p>' , 'Inline elements with functions and variables' ) ;
} ) ;
test ( 'End within start element' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . getBody ( ) . innerHTML = '<p><b>1234<b>5678</b></b></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'p' ) [ 0 ] , 0 ) ;
rng . setEnd ( editor . dom . select ( 'b' ) [ 0 ] , 2 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p>12345678</p>' , 'End within start element' ) ;
} ) ;
test ( 'Start and end within similar format 1' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . getBody ( ) . innerHTML = '<p><b><em><b>1234<b>5678</b></b></em></b></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'em' ) [ 0 ] , 0 ) ;
rng . setEnd ( editor . dom . select ( 'b' ) [ 1 ] , 2 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><em>12345678</em></p>' , 'Start and end within similar format 1' ) ;
} ) ;
test ( 'Start and end within similar format 2' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . getBody ( ) . innerHTML = '<p><b><em><b>1234</b><b>5678</b></em></b></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'em' ) [ 0 ] , 0 ) ;
rng . setEnd ( editor . dom . select ( 'em' ) [ 0 ] , 1 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><em>1234</em><b><em><b>5678</b></em></b></p>' , 'Start and end within similar format 2' ) ;
} ) ;
test ( 'Start and end within similar format 3' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . getBody ( ) . innerHTML = '<p><b><em><b>1234</b></em></b></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'em' ) [ 0 ] , 0 ) ;
rng . setEnd ( editor . dom . select ( 'em' ) [ 0 ] , 1 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><em>1234</em></p>' , 'Start and end within similar format 3' ) ;
} ) ;
test ( 'End within start' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . getBody ( ) . innerHTML = '<p><b><em>x<b>abc</b>y</em></b></p>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'p' ) [ 0 ] , 0 ) ;
rng . setEnd ( editor . dom . select ( 'b' ) [ 1 ] . firstChild , 3 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><em>x</em><em>abc</em><b><em>y</em></b></p>' , 'End within start' ) ;
} ) ;
test ( 'Remove block format' , function ( ) {
editor . formatter . register ( 'format' , { block : 'h1' } ) ;
editor . getBody ( ) . innerHTML = '<h1>text</h1>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'h1' ) [ 0 ] . firstChild , 0 ) ;
rng . setEnd ( editor . dom . select ( 'h1' ) [ 0 ] . firstChild , 4 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p>text</p>' , 'Remove block format' ) ;
} ) ;
test ( 'Remove wrapper block format' , function ( ) {
editor . formatter . register ( 'format' , { block : 'blockquote' , wrapper : true } ) ;
editor . getBody ( ) . innerHTML = '<blockquote><p>text</p></blockquote>' ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'p' ) [ 0 ] . firstChild , 0 ) ;
rng . setEnd ( editor . dom . select ( 'p' ) [ 0 ] . firstChild , 4 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p>text</p>' , 'Remove wrapper block format' ) ;
} ) ;
test ( 'Remove span format within block with style' , function ( ) {
editor . formatter . register ( 'format' , { selector : 'span' , attributes : [ 'style' , 'class' ] , remove : 'empty' , split : true , expand : false , deep : true } ) ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
editor . getBody ( ) . innerHTML = '<p style="color:#ff0000"><span style="color:#00ff00">text</span></p>' ;
rng . setStart ( editor . dom . select ( 'span' ) [ 0 ] . firstChild , 1 ) ;
rng . setEnd ( editor . dom . select ( 'span' ) [ 0 ] . firstChild , 3 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p style="color: #ff0000;"><span style="color: #00ff00;">t</span>ex<span style="color: #00ff00;">t</span></p>' , 'Remove span format within block with style' ) ;
} ) ;
test ( 'Remove and verify start element' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
editor . getBody ( ) . innerHTML = '<p><b>text</b></p>' ;
rng . setStart ( editor . dom . select ( 'b' ) [ 0 ] . firstChild , 1 ) ;
rng . setEnd ( editor . dom . select ( 'b' ) [ 0 ] . firstChild , 3 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , '<p><b>t</b>ex<b>t</b></p>' ) ;
equal ( editor . selection . getStart ( ) . nodeName , 'P' ) ;
} ) ;
test ( 'Remove with selection collapsed ensure correct caret position' , function ( ) {
var content = '<p>test</p><p>testing</p>' ;
editor . formatter . register ( 'format' , { block : 'p' } ) ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
editor . getBody ( ) . innerHTML = content ;
rng . setStart ( editor . dom . select ( 'p' ) [ 0 ] . firstChild , 4 ) ;
rng . setEnd ( editor . dom . select ( 'p' ) [ 0 ] . firstChild , 4 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( getContent ( ) , content ) ;
equal ( editor . selection . getStart ( ) , editor . dom . select ( 'p' ) [ 0 ] ) ;
} ) ;
test ( 'Caret format at middle of text' , function ( ) {
editor . setContent ( '<p><b>abc</b></p>' ) ;
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
2014-03-24 06:59:45 +01:00
Utils . setSelection ( 'b' , 1 , 'b' , 1 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
equal ( editor . getContent ( ) , '<p>abc</p>' ) ;
} ) ;
test ( 'Caret format at end of text' , function ( ) {
editor . setContent ( '<p><b>abc</b></p>' ) ;
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
2014-03-24 06:59:45 +01:00
Utils . setSelection ( 'b' , 3 , 'b' , 3 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
2014-03-24 06:59:45 +01:00
Utils . type ( 'd' ) ;
2014-02-10 02:11:25 +01:00
equal ( editor . getContent ( ) , '<p><b>abc</b>d</p>' ) ;
} ) ;
test ( 'Caret format at end of text inside other format' , function ( ) {
editor . setContent ( '<p><em><b>abc</b></em></p>' ) ;
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
2014-03-24 06:59:45 +01:00
Utils . setSelection ( 'b' , 3 , 'b' , 3 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
2014-03-24 06:59:45 +01:00
Utils . type ( 'd' ) ;
2014-02-10 02:11:25 +01:00
equal ( editor . getContent ( ) , '<p><em><b>abc</b>d</em></p>' ) ;
} ) ;
test ( 'Caret format at end of text inside other format with text after 1' , function ( ) {
editor . setContent ( '<p><em><b>abc</b></em>e</p>' ) ;
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
2014-03-24 06:59:45 +01:00
Utils . setSelection ( 'b' , 3 , 'b' , 3 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
2014-03-24 06:59:45 +01:00
Utils . type ( 'd' ) ;
2014-02-10 02:11:25 +01:00
equal ( editor . getContent ( ) , '<p><em><b>abc</b>d</em>e</p>' ) ;
} ) ;
test ( 'Caret format at end of text inside other format with text after 2' , function ( ) {
editor . setContent ( '<p><em><b>abc</b></em>e</p>' ) ;
editor . formatter . register ( 'format' , { inline : 'em' } ) ;
2014-03-24 06:59:45 +01:00
Utils . setSelection ( 'b' , 3 , 'b' , 3 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
2014-03-24 06:59:45 +01:00
Utils . type ( 'd' ) ;
2014-02-10 02:11:25 +01:00
equal ( editor . getContent ( ) , '<p><em><b>abc</b></em><b>d</b>e</p>' ) ;
} ) ;
2014-06-18 01:49:00 +02:00
test ( 'Toggle styles at the end of the content don\' removes the format where it is not needed.' , function ( ) {
editor . setContent ( '<p><em><b>abce</b></em></p>' ) ;
editor . formatter . register ( 'b' , { inline : 'b' } ) ;
editor . formatter . register ( 'em' , { inline : 'em' } ) ;
Utils . setSelection ( 'b' , 4 , 'b' , 4 ) ;
editor . formatter . remove ( 'b' ) ;
editor . formatter . remove ( 'em' ) ;
equal ( editor . getContent ( ) , '<p><em><b>abce</b></em></p>' ) ;
} ) ;
2014-02-10 02:11:25 +01:00
test ( 'Caret format on second word in table cell' , function ( ) {
editor . setContent ( '<table><tbody><tr><td>one <b>two</b></td></tr></tbody></table>' ) ;
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
2014-03-24 06:59:45 +01:00
Utils . setSelection ( 'b' , 2 , 'b' , 2 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
equal ( editor . getContent ( ) , '<table><tbody><tr><td>one two</td></tr></tbody></table>' ) ;
} ) ;
test ( 'contentEditable: false on start and contentEditable: true on end' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . setContent ( '<p>abc</p><p contenteditable="false"><b>def</b></p><p><b>ghj</b></p>' ) ;
2014-03-24 06:59:45 +01:00
var rng = editor . dom . createRng ( ) ;
2014-02-10 02:11:25 +01:00
rng . setStart ( editor . dom . select ( 'b' ) [ 0 ] . firstChild , 0 ) ;
rng . setEnd ( editor . dom . select ( 'b' ) [ 1 ] . firstChild , 3 ) ;
editor . selection . setRng ( rng ) ;
editor . formatter . remove ( 'format' ) ;
equal ( editor . getContent ( ) , '<p>abc</p><p><b>def</b></p><p>ghj</p>' , 'Text in last paragraph is not bold' ) ;
} ) ;
test ( 'contentEditable: true on start and contentEditable: false on end' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . setContent ( '<p>abc</p><p><b>def</b></p><p contenteditable="false"><b>ghj</b></p>' ) ;
2014-03-24 06:59:45 +01:00
Utils . setSelection ( 'p:nth-child(2) b' , 0 , 'p:last b' , 3 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
equal ( editor . getContent ( ) , '<p>abc</p><p>def</p><p><b>ghj</b></p>' , 'Text in first paragraph is not bold' ) ;
} ) ;
test ( 'contentEditable: true inside contentEditable: false' , function ( ) {
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
editor . setContent ( '<p>abc</p><p contenteditable="false"><span contenteditable="true"><b>def</b></span></p>' ) ;
2014-03-24 06:59:45 +01:00
Utils . setSelection ( 'b' , 0 , 'b' , 3 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
equal ( editor . getContent ( ) , '<p>abc</p><p><span>def</span></p>' , 'Text is not bold' ) ;
} ) ;
test ( 'remove format block on contentEditable: false block' , function ( ) {
editor . formatter . register ( 'format' , { block : 'h1' } ) ;
editor . setContent ( '<p>abc</p><h1 contenteditable="false">def</h1>' ) ;
2014-03-24 06:59:45 +01:00
Utils . setSelection ( 'h1:nth-child(2)' , 0 , 'h1:nth-child(2)' , 3 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
equal ( editor . getContent ( ) , '<p>abc</p><h1>def</h1>' , 'H1 is still not h1' ) ;
} ) ;
2015-03-10 20:19:56 +01:00
test ( 'remove format on del using removeformat format' , function ( ) {
editor . getBody ( ) . innerHTML = '<p><del>abc</del></p>' ;
Utils . setSelection ( 'del' , 0 , 'del' , 3 ) ;
editor . formatter . remove ( 'removeformat' ) ;
equal ( Utils . cleanHtml ( editor . getBody ( ) . innerHTML ) , '<p>abc</p>' ) ;
} ) ;
test ( 'remove format on span with class using removeformat format' , function ( ) {
editor . getBody ( ) . innerHTML = '<p><span class="x">abc</span></p>' ;
Utils . setSelection ( 'span' , 0 , 'span' , 3 ) ;
editor . formatter . remove ( 'removeformat' ) ;
equal ( Utils . cleanHtml ( editor . getBody ( ) . innerHTML ) , '<p>abc</p>' ) ;
} ) ;
test ( 'remove format on span with internal class using removeformat format' , function ( ) {
editor . getBody ( ) . innerHTML = '<p><span class="mce-item-internal">abc</span></p>' ;
Utils . setSelection ( 'span' , 0 , 'span' , 3 ) ;
editor . formatter . remove ( 'removeformat' ) ;
equal ( Utils . normalizeHtml ( Utils . cleanHtml ( editor . getBody ( ) . innerHTML ) ) , '<p><span class="mce-item-internal">abc</span></p>' ) ;
} ) ;
2014-02-10 02:11:25 +01:00
test ( 'Remove format bug 1' , function ( ) {
2015-07-01 02:51:22 +02:00
editor . setContent ( '<p><b><i>ab</i>c</b></p>' ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
2015-07-01 02:51:22 +02:00
Utils . setSelection ( 'i' , 1 , 'i' , 2 ) ;
2014-02-10 02:11:25 +01:00
editor . formatter . remove ( 'format' ) ;
2015-07-01 02:51:22 +02:00
equal ( editor . getContent ( ) , '<p><b><i>a</i></b><i>b</i><b>c</b></p>' ) ;
} ) ;
test ( 'Remove format bug 2' , function ( ) {
editor . setContent ( '<p>ab<b>c</b></p>' ) ;
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
Utils . setSelection ( 'b' , 0 , 'b' , 1 ) ;
editor . formatter . remove ( 'format' ) ;
equal ( editor . getContent ( ) , '<p>abc</p>' ) ;
} ) ;
test ( 'Remove format bug 3' , function ( ) {
editor . setContent ( '<p><b><i>ab</i></b></p>' ) ;
editor . formatter . register ( 'format' , { inline : 'b' } ) ;
Utils . setSelection ( 'i' , 1 , 'i' , 2 ) ;
editor . formatter . remove ( 'format' ) ;
equal ( editor . getContent ( ) , '<p><b><i>a</i></b><i>b</i></p>' ) ;
2014-02-10 02:11:25 +01:00
} ) ;