1
0
mirror of https://github.com/gorhill/uBlock.git synced 2024-11-07 03:12:33 +01:00
This commit is contained in:
gorhill 2016-07-01 08:09:48 -04:00
parent eabeedcd04
commit 7f9c01d38f
4 changed files with 48 additions and 78 deletions

View File

@ -387,13 +387,18 @@ vAPI.domFilterer = {
return function(node) { return function(node) {
this.hiddenNodeCount += 1; this.hiddenNodeCount += 1;
node.setAttribute(this.hiddenId, ''); node.setAttribute(this.hiddenId, '');
var shadow = node.shadowRoot; if ( this.enabled === false ) {
return;
}
// https://github.com/gorhill/uBlock/issues/762
// https://github.com/gorhill/uBlock/issues/769#issuecomment-229873048
// Always enforce `display: none`.
node.style.setProperty('display', 'none', 'important');
// https://www.chromestatus.com/features/4668884095336448 // https://www.chromestatus.com/features/4668884095336448
// "Multiple shadow roots is being deprecated." // "Multiple shadow roots is being deprecated."
if ( shadow !== null ) { var shadow = node.shadowRoot;
if ( shadow.className !== this.shadowId ) { if ( shadow ) {
node.style.setProperty('display', 'none', 'important'); if ( shadow.className === this.shadowId && shadow.firstElementChild !== null ) {
} else if ( shadow.firstElementChild !== null ) {
shadow.removeChild(shadow.firstElementChild); shadow.removeChild(shadow.firstElementChild);
} }
return; return;
@ -401,19 +406,25 @@ vAPI.domFilterer = {
// https://github.com/gorhill/uBlock/pull/555 // https://github.com/gorhill/uBlock/pull/555
// Not all nodes can be shadowed: // Not all nodes can be shadowed:
// https://github.com/w3c/webcomponents/issues/102 // https://github.com/w3c/webcomponents/issues/102
// https://github.com/gorhill/uBlock/issues/762
// Remove display style that might get in the way of the shadow
// node doing its magic.
try { try {
shadow = node.createShadowRoot(); shadow = node.createShadowRoot();
shadow.className = this.shadowId; shadow.className = this.shadowId;
node.style.removeProperty('display');
} catch (ex) { } catch (ex) {
node.style.setProperty('display', 'none', 'important');
} }
}; };
})(), })(),
showNode: function(node) {
node.style.removeProperty('display');
var shadow = node.shadowRoot;
if ( shadow && shadow.className === this.shadowId ) {
if ( shadow.firstElementChild !== null ) {
shadow.removeChild(shadow.firstElementChild);
}
shadow.appendChild(document.createElement('content'));
}
},
toggleOff: function() { toggleOff: function() {
this.enabled = false; this.enabled = false;
}, },
@ -425,16 +436,27 @@ vAPI.domFilterer = {
unhideNode: function(node) { unhideNode: function(node) {
this.hiddenNodeCount--; this.hiddenNodeCount--;
node.removeAttribute(this.hiddenId); node.removeAttribute(this.hiddenId);
node.style.removeProperty('display');
var shadow = node.shadowRoot; var shadow = node.shadowRoot;
if ( shadow && shadow.className === this.shadowId ) { if ( shadow && shadow.className === this.shadowId ) {
if ( shadow.firstElementChild !== null ) { if ( shadow.firstElementChild !== null ) {
shadow.removeChild(shadow.firstElementChild); shadow.removeChild(shadow.firstElementChild);
} }
shadow.appendChild(document.createElement('content')); shadow.appendChild(document.createElement('content'));
} else {
node.style.removeProperty('display');
} }
},
unshowNode: function(node) {
node.style.setProperty('display', 'none', 'important');
var shadow = node.shadowRoot;
if (
shadow &&
shadow.className === this.shadowId &&
shadow.firstElementChild !== null
) {
shadow.removeChild(shadow.firstElementChild);
} }
},
}; };

View File

@ -47,22 +47,7 @@
} }
i = elems.length; i = elems.length;
while ( i-- ) { while ( i-- ) {
var elem = elems[i]; vAPI.domFilterer.showNode(elems[i]);
var shadow = elem.shadowRoot;
if ( shadow === undefined ) {
style = elem.style;
if ( typeof style === 'object' || typeof style.removeProperty === 'function' ) {
style.removeProperty('display');
}
continue;
}
if (
shadow !== null &&
shadow.className === vAPI.domFilterer.shadowId &&
shadow.firstElementChild === null
) {
shadow.appendChild(document.createElement('content'));
}
} }
vAPI.domFilterer.toggleOff(); vAPI.domFilterer.toggleOff();

View File

@ -47,22 +47,7 @@
} }
i = elems.length; i = elems.length;
while ( i-- ) { while ( i-- ) {
var elem = elems[i]; vAPI.domFilterer.unshowNode(elems[i]);
var shadow = elem.shadowRoot;
if ( shadow === undefined ) {
style = elems[i].style;
if ( typeof style === 'object' || typeof style.removeProperty === 'function' ) {
style.setProperty('display', 'none', 'important');
}
continue;
}
if (
shadow !== null &&
shadow.className === vAPI.domFilterer.shadowId &&
shadow.firstElementChild !== null
) {
shadow.removeChild(shadow.firstElementChild);
}
} }
vAPI.domFilterer.toggleOn(); vAPI.domFilterer.toggleOn();

View File

@ -35,7 +35,6 @@ if ( typeof vAPI !== 'object' || typeof vAPI.domFilterer !== 'object' ) {
/******************************************************************************/ /******************************************************************************/
var sessionId = vAPI.sessionId; var sessionId = vAPI.sessionId;
var shadowId = vAPI.domFilterer.shadowId;
if ( document.querySelector('iframe.dom-inspector.' + sessionId) !== null ) { if ( document.querySelector('iframe.dom-inspector.' + sessionId) !== null ) {
return; return;
@ -736,7 +735,7 @@ var cosmeticFilterMapper = (function() {
i = entries.length; i = entries.length;
while ( i-- ) { while ( i-- ) {
entry = entries[i]; entry = entries[i];
selector = entries.a + ':has(' + entries.b + ')'; selector = entry.a + ':has(' + entry.b + ')';
if ( if (
filterMap.has(rootNode) === false && filterMap.has(rootNode) === false &&
rootNode[matchesFnName](entry.a) && rootNode[matchesFnName](entry.a) &&
@ -744,7 +743,7 @@ var cosmeticFilterMapper = (function() {
) { ) {
filterMap.set(rootNode, selector); filterMap.set(rootNode, selector);
} }
nodes = rootNode.querySelectorAll(entries.a); nodes = rootNode.querySelectorAll(entry.a);
j = nodes.length; j = nodes.length;
while ( j-- ) { while ( j-- ) {
node = nodes[j]; node = nodes[j];
@ -762,8 +761,8 @@ var cosmeticFilterMapper = (function() {
i = entries.length; i = entries.length;
while ( i-- ) { while ( i-- ) {
entry = entries[i]; entry = entries[i];
selector = entries.a + ':has(' + entries.b + ')'; selector = entry.a + ':has(' + entry.b + ')';
nodes = document.querySelectorAll(entries.a); nodes = document.querySelectorAll(entry.a);
j = nodes.length; j = nodes.length;
while ( j-- ) { while ( j-- ) {
node = nodes[j]; node = nodes[j];
@ -864,7 +863,7 @@ var elementsFromSpecialSelector = function(selector) {
var out = [], i; var out = [], i;
var matches = /^(.+?):has\((.+?)\)$/.exec(selector); var matches = /^(.+?):has\((.+?)\)$/.exec(selector);
if ( matches !== null ) { if ( matches !== null ) {
var nodes = document.querySelector(matches[1]); var nodes = document.querySelectorAll(matches[1]);
i = nodes.length; i = nodes.length;
while ( i-- ) { while ( i-- ) {
var node = nodes[i]; var node = nodes[i];
@ -1086,39 +1085,18 @@ var toggleNodes = function(nodes, originalState, targetState) {
/******************************************************************************/ /******************************************************************************/
var showNode = function(node, v1, v2) { var showNode = function(node, v1, v2) {
var shadow = node.shadowRoot; vAPI.domFilterer.showNode(node);
if ( shadow === undefined ) {
if ( !v1 ) { if ( !v1 ) {
node.style.removeProperty('display'); node.style.removeProperty('display');
} else { } else {
node.style.setProperty('display', v1, v2); node.style.setProperty('display', v1, v2);
} }
} else if ( shadow !== null && shadow.className === shadowId && shadow.firstElementChild === null ) {
shadow.appendChild(document.createElement('content'));
}
}; };
/******************************************************************************/ /******************************************************************************/
var hideNode = function(node) { var hideNode = function(node) {
var shadow = node.shadowRoot; vAPI.domFilterer.unshowNode(node);
if ( shadow === undefined ) {
node.style.setProperty('display', 'none', 'important');
return;
}
if ( shadow !== null && shadow.className === shadowId ) {
if ( shadow.firstElementChild !== null ) {
shadow.removeChild(shadow.firstElementChild);
}
return;
}
// not all nodes can be shadowed
try {
shadow = node.createShadowRoot();
} catch (ex) {
return;
}
shadow.className = shadowId;
}; };
/******************************************************************************/ /******************************************************************************/