0
Fork 0
mirror of https://github.com/fastmail/Squire.git synced 2025-01-18 04:32:28 -05:00

Allow contents of unknown tags in.

Clean functions were removing contents of any unknown tag. This was, it turned
out, a bit too strict.
This commit is contained in:
Neil Jenkins 2011-11-15 21:46:47 +11:00
parent 143eea15cb
commit 3068c496c9

View file

@ -641,6 +641,8 @@
} }
if ( mutates ) { if ( mutates ) {
setSelection( range );
// Path may have changed // Path may have changed
updatePath( 0, true ); updatePath( 0, true );
@ -898,6 +900,15 @@
parent.replaceChild( el, node ); parent.replaceChild( el, node );
el.appendChild( node.empty() ); el.appendChild( node.empty() );
return el; return el;
},
TT: function ( node, parent ) {
var el = createElement( 'SPAN', {
'class': 'font',
style: 'font-family:menlo,consolas,"courier new",monospace'
});
parent.replaceChild( el, node );
el.appendChild( node.empty() );
return el;
} }
}; };
@ -910,29 +921,36 @@
*/ */
var cleanTree = function ( node, allowStyles ) { var cleanTree = function ( node, allowStyles ) {
var children = node.childNodes, var children = node.childNodes,
i, l, child, nodeName, nodeType, rewriter, parent; i, l, child, nodeName, nodeType, rewriter, childLength;
for ( i = 0, l = children.length; i < l; i += 1 ) { for ( i = 0, l = children.length; i < l; i += 1 ) {
child = children[i]; child = children[i];
nodeName = child.nodeName; nodeName = child.nodeName;
nodeType = child.nodeType; nodeType = child.nodeType;
rewriter = stylesRewriters[ nodeName ]; rewriter = stylesRewriters[ nodeName ];
if ( rewriter ) {
child = rewriter( child, node );
} else if (
( !allowedBlock.test( nodeName ) && !child.isInline() ) ||
( nodeType === TEXT_NODE && !( /\S/.test( child.data ) ) ) ) {
node.removeChild( child );
i -= 1;
l -= 1;
continue;
}
if ( nodeType === ELEMENT_NODE ) { if ( nodeType === ELEMENT_NODE ) {
childLength = child.childNodes.length;
if ( rewriter ) {
child = rewriter( child, node );
} else if ( !allowedBlock.test( nodeName ) &&
!child.isInline() ) {
i -= 1;
l += childLength - 1;
node.replaceChild( child.empty(), child );
continue;
}
if ( !allowStyles && child.style.cssText ) { if ( !allowStyles && child.style.cssText ) {
child.removeAttribute( 'style' ); child.removeAttribute( 'style' );
} }
if ( child.childNodes.length ) { if ( childLength ) {
cleanTree( child, allowStyles ); cleanTree( child, allowStyles );
} }
} else {
if ( ( nodeType !== TEXT_NODE ) ||
!( /\S/.test( child.data ) ) ) {
node.removeChild( child );
i -= 1;
l -= 1;
}
} }
} }
return node; return node;
@ -1575,4 +1593,9 @@
body.setAttribute( 'contenteditable', 'true' ); body.setAttribute( 'contenteditable', 'true' );
win.editor.setHTML( '' ); win.editor.setHTML( '' );
if ( win.onEditorLoad ) {
win.onEditorLoad( win.editor );
delete win.onEditorLoad;
}
}( document ) ); }( document ) );