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

Make TreeWalker filter argument optional

This commit is contained in:
Neil Jenkins 2018-07-27 09:21:50 +10:00
parent e3e7c17315
commit 2d5114c669
5 changed files with 24 additions and 26 deletions

View file

@ -84,10 +84,14 @@ var typeToBitArray = {
11: 1024 11: 1024
}; };
var always = function () {
return true;
};
function TreeWalker ( root, nodeType, filter ) { function TreeWalker ( root, nodeType, filter ) {
this.root = this.currentNode = root; this.root = this.currentNode = root;
this.nodeType = nodeType; this.nodeType = nodeType;
this.filter = filter; this.filter = filter || always;
} }
TreeWalker.prototype.nextNode = function () { TreeWalker.prototype.nextNode = function () {
@ -1955,9 +1959,7 @@ var allowedBlock = /^(?:A(?:DDRESS|RTICLE|SIDE|UDIO)|BLOCKQUOTE|CAPTION|D(?:[DLT
var blacklist = /^(?:HEAD|META|STYLE)/; var blacklist = /^(?:HEAD|META|STYLE)/;
var walker = new TreeWalker( null, SHOW_TEXT|SHOW_ELEMENT, function () { var walker = new TreeWalker( null, SHOW_TEXT|SHOW_ELEMENT );
return true;
});
/* /*
Two purposes: Two purposes:
@ -3040,10 +3042,8 @@ proto.getPath = function () {
// the bottom of the tree so the block can be selected. Define that node as the // the bottom of the tree so the block can be selected. Define that node as the
// keepNode. // keepNode.
var removeZWS = function ( root, keepNode ) { var removeZWS = function ( root, keepNode ) {
var walker = new TreeWalker( root, SHOW_TEXT, function () { var walker = new TreeWalker( root, SHOW_TEXT );
return true; var parent, node, index;
}, false ),
parent, node, index;
while ( node = walker.nextNode() ) { while ( node = walker.nextNode() ) {
while ( ( index = node.data.indexOf( ZWS ) ) > -1 && while ( ( index = node.data.indexOf( ZWS ) ) > -1 &&
( !keepNode || node.parentNode !== keepNode ) ) { ( !keepNode || node.parentNode !== keepNode ) ) {
@ -3399,7 +3399,7 @@ proto.hasFormat = function ( tag, attributes, range ) {
// the selection and make sure all of them have the format we want. // the selection and make sure all of them have the format we want.
walker = new TreeWalker( common, SHOW_TEXT, function ( node ) { walker = new TreeWalker( common, SHOW_TEXT, function ( node ) {
return isNodeContainedInRange( range, node, true ); return isNodeContainedInRange( range, node, true );
}, false ); });
var seenNode = false; var seenNode = false;
while ( node = walker.nextNode() ) { while ( node = walker.nextNode() ) {
@ -3503,8 +3503,7 @@ proto._addFormat = function ( tag, attributes, range ) {
node.nodeName === 'BR' || node.nodeName === 'BR' ||
node.nodeName === 'IMG' node.nodeName === 'IMG'
) && isNodeContainedInRange( range, node, true ); ) && isNodeContainedInRange( range, node, true );
}, }
false
); );
// Start at the beginning node of the range and iterate through // Start at the beginning node of the range and iterate through
@ -4262,7 +4261,7 @@ var addLinks = function ( frag, root, self ) {
walker = new TreeWalker( frag, SHOW_TEXT, walker = new TreeWalker( frag, SHOW_TEXT,
function ( node ) { function ( node ) {
return !getNearest( node, root, 'A' ); return !getNearest( node, root, 'A' );
}, false ), }),
defaultAttributes = self._config.tagAttributes.a, defaultAttributes = self._config.tagAttributes.a,
node, data, parent, match, index, endIndex, child; node, data, parent, match, index, endIndex, child;
while ( node = walker.nextNode() ) { while ( node = walker.nextNode() ) {

File diff suppressed because one or more lines are too long

View file

@ -183,9 +183,7 @@ var allowedBlock = /^(?:A(?:DDRESS|RTICLE|SIDE|UDIO)|BLOCKQUOTE|CAPTION|D(?:[DLT
var blacklist = /^(?:HEAD|META|STYLE)/; var blacklist = /^(?:HEAD|META|STYLE)/;
var walker = new TreeWalker( null, SHOW_TEXT|SHOW_ELEMENT, function () { var walker = new TreeWalker( null, SHOW_TEXT|SHOW_ELEMENT );
return true;
});
/* /*
Two purposes: Two purposes:

View file

@ -574,10 +574,8 @@ proto.getPath = function () {
// the bottom of the tree so the block can be selected. Define that node as the // the bottom of the tree so the block can be selected. Define that node as the
// keepNode. // keepNode.
var removeZWS = function ( root, keepNode ) { var removeZWS = function ( root, keepNode ) {
var walker = new TreeWalker( root, SHOW_TEXT, function () { var walker = new TreeWalker( root, SHOW_TEXT );
return true; var parent, node, index;
}, false ),
parent, node, index;
while ( node = walker.nextNode() ) { while ( node = walker.nextNode() ) {
while ( ( index = node.data.indexOf( ZWS ) ) > -1 && while ( ( index = node.data.indexOf( ZWS ) ) > -1 &&
( !keepNode || node.parentNode !== keepNode ) ) { ( !keepNode || node.parentNode !== keepNode ) ) {
@ -933,7 +931,7 @@ proto.hasFormat = function ( tag, attributes, range ) {
// the selection and make sure all of them have the format we want. // the selection and make sure all of them have the format we want.
walker = new TreeWalker( common, SHOW_TEXT, function ( node ) { walker = new TreeWalker( common, SHOW_TEXT, function ( node ) {
return isNodeContainedInRange( range, node, true ); return isNodeContainedInRange( range, node, true );
}, false ); });
var seenNode = false; var seenNode = false;
while ( node = walker.nextNode() ) { while ( node = walker.nextNode() ) {
@ -1037,8 +1035,7 @@ proto._addFormat = function ( tag, attributes, range ) {
node.nodeName === 'BR' || node.nodeName === 'BR' ||
node.nodeName === 'IMG' node.nodeName === 'IMG'
) && isNodeContainedInRange( range, node, true ); ) && isNodeContainedInRange( range, node, true );
}, }
false
); );
// Start at the beginning node of the range and iterate through // Start at the beginning node of the range and iterate through
@ -1796,7 +1793,7 @@ var addLinks = function ( frag, root, self ) {
walker = new TreeWalker( frag, SHOW_TEXT, walker = new TreeWalker( frag, SHOW_TEXT,
function ( node ) { function ( node ) {
return !getNearest( node, root, 'A' ); return !getNearest( node, root, 'A' );
}, false ), }),
defaultAttributes = self._config.tagAttributes.a, defaultAttributes = self._config.tagAttributes.a,
node, data, parent, match, index, endIndex, child; node, data, parent, match, index, endIndex, child;
while ( node = walker.nextNode() ) { while ( node = walker.nextNode() ) {

View file

@ -26,10 +26,14 @@ var typeToBitArray = {
11: 1024 11: 1024
}; };
var always = function () {
return true;
};
function TreeWalker ( root, nodeType, filter ) { function TreeWalker ( root, nodeType, filter ) {
this.root = this.currentNode = root; this.root = this.currentNode = root;
this.nodeType = nodeType; this.nodeType = nodeType;
this.filter = filter; this.filter = filter || always;
} }
TreeWalker.prototype.nextNode = function () { TreeWalker.prototype.nextNode = function () {