0
Fork 0
mirror of https://github.com/fastmail/Squire.git synced 2025-01-08 16:00:06 -05:00

Rewrite <s> to <strike> in cleanTree fn.

This commit is contained in:
Neil Jenkins 2014-02-03 17:57:20 +11:00
parent db82ba1217
commit a875d20f12
3 changed files with 56 additions and 33 deletions

View file

@ -1058,7 +1058,7 @@ var expandRangeToBlockBoundaries = function ( range ) {
isIOS, isIOS,
isMac, isMac,
isGecko, isGecko,
isIE, isIE8or9or10,
isIE8, isIE8,
isOpera, isOpera,
ctrlKey, ctrlKey,
@ -1106,7 +1106,6 @@ var expandRangeToBlockBoundaries = function ( range ) {
rangeDoesEndAtBlockBoundary, rangeDoesEndAtBlockBoundary,
expandRangeToBlockBoundaries, expandRangeToBlockBoundaries,
Range,
top, top,
console, console,
setTimeout setTimeout
@ -2210,6 +2209,15 @@ var spanToSemantic = {
} }
}; };
var replaceWithTag = function ( tag ) {
return function ( node, parent ) {
var el = createElement( node.ownerDocument, tag );
parent.replaceChild( el, node );
el.appendChild( empty( node ) );
return el;
};
};
var stylesRewriters = { var stylesRewriters = {
SPAN: function ( span, parent ) { SPAN: function ( span, parent ) {
var style = span.style, var style = span.style,
@ -2238,41 +2246,56 @@ var stylesRewriters = {
return newTreeBottom || span; return newTreeBottom || span;
}, },
STRONG: function ( node, parent ) { STRONG: replaceWithTag( 'B' ),
var el = createElement( node.ownerDocument, 'B' ); EM: replaceWithTag( 'I' ),
parent.replaceChild( el, node ); S: replaceWithTag( 'STRIKE' ),
el.appendChild( empty( node ) );
return el;
},
EM: function ( node, parent ) {
var el = createElement( node.ownerDocument, 'I' );
parent.replaceChild( el, node );
el.appendChild( empty( node ) );
return el;
},
FONT: function ( node, parent ) { FONT: function ( node, parent ) {
var face = node.face, var face = node.face,
size = node.size, size = node.size,
colour = node.color,
doc = node.ownerDocument, doc = node.ownerDocument,
fontSpan, sizeSpan, fontSpan, sizeSpan, colourSpan,
newTreeBottom, newTreeTop; newTreeBottom, newTreeTop;
if ( face ) { if ( face ) {
fontSpan = createElement( doc, 'SPAN', { fontSpan = createElement( doc, 'SPAN', {
'class': 'font', 'class': 'font',
style: 'font-family:' + face style: 'font-family:' + face
}); });
newTreeTop = fontSpan;
newTreeBottom = fontSpan;
} }
if ( size ) { if ( size ) {
sizeSpan = createElement( doc, 'SPAN', { sizeSpan = createElement( doc, 'SPAN', {
'class': 'size', 'class': 'size',
style: 'font-size:' + fontSizes[ size ] + 'px' style: 'font-size:' + fontSizes[ size ] + 'px'
}); });
if ( fontSpan ) { if ( !newTreeTop ) {
fontSpan.appendChild( sizeSpan ); newTreeTop = sizeSpan;
} }
if ( newTreeBottom ) {
newTreeBottom.appendChild( sizeSpan );
}
newTreeBottom = sizeSpan;
}
if ( colour && /^#?([\dA-F]{3}){1,2}$/i.test( colour ) ) {
if ( colour.charAt( 0 ) !== '#' ) {
colour = '#' + colour;
}
colourSpan = createElement( doc, 'SPAN', {
'class': 'colour',
style: 'color:' + colour
});
if ( !newTreeTop ) {
newTreeTop = colourSpan;
}
if ( newTreeBottom ) {
newTreeBottom.appendChild( colourSpan );
}
newTreeBottom = colourSpan;
}
if ( !newTreeTop ) {
newTreeTop = newTreeBottom = createElement( doc, 'SPAN' );
} }
newTreeTop = fontSpan || sizeSpan || createElement( doc, 'SPAN' );
newTreeBottom = sizeSpan || fontSpan || newTreeTop;
parent.replaceChild( newTreeTop, node ); parent.replaceChild( newTreeTop, node );
newTreeBottom.appendChild( empty( node ) ); newTreeBottom.appendChild( empty( node ) );
return newTreeBottom; return newTreeBottom;

File diff suppressed because one or more lines are too long

View file

@ -1161,6 +1161,15 @@ var spanToSemantic = {
} }
}; };
var replaceWithTag = function ( tag ) {
return function ( node, parent ) {
var el = createElement( node.ownerDocument, tag );
parent.replaceChild( el, node );
el.appendChild( empty( node ) );
return el;
};
};
var stylesRewriters = { var stylesRewriters = {
SPAN: function ( span, parent ) { SPAN: function ( span, parent ) {
var style = span.style, var style = span.style,
@ -1189,18 +1198,9 @@ var stylesRewriters = {
return newTreeBottom || span; return newTreeBottom || span;
}, },
STRONG: function ( node, parent ) { STRONG: replaceWithTag( 'B' ),
var el = createElement( node.ownerDocument, 'B' ); EM: replaceWithTag( 'I' ),
parent.replaceChild( el, node ); S: replaceWithTag( 'STRIKE' ),
el.appendChild( empty( node ) );
return el;
},
EM: function ( node, parent ) {
var el = createElement( node.ownerDocument, 'I' );
parent.replaceChild( el, node );
el.appendChild( empty( node ) );
return el;
},
FONT: function ( node, parent ) { FONT: function ( node, parent ) {
var face = node.face, var face = node.face,
size = node.size, size = node.size,