Skip to content

Commit

Permalink
[mv3] Improve remove-attr.js scriptlet
Browse files Browse the repository at this point in the history
  • Loading branch information
gorhill committed Aug 6, 2024
1 parent 417dab5 commit fb037e9
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 9 deletions.
31 changes: 23 additions & 8 deletions assets/resources/scriptlets.js
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,12 @@ function safeSelf() {
}
return self.requestAnimationFrame(fn);
},
offIdle(id) {
if ( self.requestIdleCallback ) {
return self.cancelIdleCallback(id);
}
return self.cancelAnimationFrame(id);
}
};
scriptletGlobals.safeSelf = safe;
if ( scriptletGlobals.bcSecret === undefined ) { return safe; }
Expand Down Expand Up @@ -258,7 +264,7 @@ builtinScriptlets.push({
function runAt(fn, when) {
const intFromReadyState = state => {
const targets = {
'loading': 1,
'loading': 1, 'asap': 1,
'interactive': 2, 'end': 2, '2': 2,
'complete': 3, 'idle': 3, '3': 3,
};
Expand Down Expand Up @@ -2266,9 +2272,20 @@ function removeAttr(
if ( safe.logLevel > 1 ) {
safe.uboLog(logPrefix, `Target selector:\n\t${selector}`);
}
let timer;
const asap = /\basap\b/.test(behavior);
let timerId;
const rmattrAsync = ( ) => {
if ( timerId !== undefined ) { return; }
timerId = safe.onIdle(( ) => {
timerId = undefined;
rmattr();
}, { timeout: 17 });
};
const rmattr = ( ) => {
timer = undefined;
if ( timerId !== undefined ) {
safe.offIdle(timerId);
timerId = undefined;
}
try {
const nodes = document.querySelectorAll(selector);
for ( const node of nodes ) {
Expand All @@ -2282,7 +2299,7 @@ function removeAttr(
}
};
const mutationHandler = mutations => {
if ( timer !== undefined ) { return; }
if ( timerId !== undefined ) { return; }
let skip = true;
for ( let i = 0; i < mutations.length && skip; i++ ) {
const { type, addedNodes, removedNodes } = mutations[i];
Expand All @@ -2295,7 +2312,7 @@ function removeAttr(
}
}
if ( skip ) { return; }
timer = safe.onIdle(rmattr, { timeout: 67 });
asap ? rmattr() : rmattrAsync();
};
const start = ( ) => {
rmattr();
Expand All @@ -2308,9 +2325,7 @@ function removeAttr(
subtree: true,
});
};
runAt(( ) => {
start();
}, /\bcomplete\b/.test(behavior) ? 'idle' : 'interactive');
runAt(( ) => { start(); }, behavior.split(/\s+/));
}

/******************************************************************************/
Expand Down
4 changes: 3 additions & 1 deletion platform/mv3/extension/js/popup.js
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,9 @@ async function commitFilteringMode() {
setFilteringMode(actualLevel);
}
if ( actualLevel !== beforeLevel && popupPanelData.autoReload ) {
browser.tabs.reload(currentTab.id);
self.setTimeout(( ) => {
browser.tabs.reload(currentTab.id);
}, 437);
}
}

Expand Down

0 comments on commit fb037e9

Please sign in to comment.