-
-
Notifications
You must be signed in to change notification settings - Fork 1k
How to execute a user script before a page is saved
-
Enable the hidden option
userScriptEnabled
by exporting the settings from the options page, editing the JSON file, replacinguserScriptEnabled: false
withuserScriptEnabled: true
, and importing the modified file in SingleFile. -
Dispatch the custom event
single-file-user-script-init
in the user script.
dispatchEvent(new CustomEvent("single-file-user-script-init"));
- Listen to the custom event
single-file-on-before-capture-request
in the user script. The listener function is called just before the page is saved.
addEventListener("single-file-on-before-capture-request", () => {
console.log("The page will be saved by SingleFile");
});
If the listener function has to be async
, call event.preventDefault()
and dispatch the custom event single-file-on-before-capture-response
once the asynchronous tasks are terminated.
addEventListener("single-file-on-before-capture-request", async event => {
event.preventDefault();
try {
await ...
} finally {
dispatchEvent(new CustomEvent("single-file-on-before-capture-response"));
}
});
- Listen to the custom event
single-file-on-after-capture-request
in the user script to execute a script after the page is processed by SingleFile.
addEventListener("single-file-on-after-capture-request", () => {
console.log("The page has been processed by SingleFile");
});
Like single-file-on-before-capture-request
, you can call event.preventDefault()
and dispatch the custom event single-file-on-after-capture-response
if the listener is an async
function.
- The complete example below shows how to remove images from the page just before saving it.
// ==UserScript==
// @name Remove images
// @namespace http://tampermonkey.net/
// @version 0.1
// @description [SingleFile] Remove all the images
// @author Gildas Lormeau
// @match *://*/*
// @grant none
// ==/UserScript==
(() => {
dispatchEvent(new CustomEvent("single-file-user-script-init"));
const images = new WeakMap();
addEventListener("single-file-on-before-capture-request", () => {
document.querySelectorAll("img").forEach(imageElement => {
const placeHolderElement = document.createElement("img");
images.set(placeHolderElement, imageElement);
imageElement.parentElement.replaceChild(placeHolderElement, imageElement);
});
});
addEventListener("single-file-on-after-capture-request", () => {
document.querySelectorAll("img").forEach(imageElement => {
imageElement.parentElement.replaceChild(images.get(imageElement), imageElement);
});
});
})();
Note: To use this feature with SingleFileZ, use single-filez-
instead of single-file-
as a prefix for event names (e.g. single-filez-user-script-init
).