stylus/content/install-hook-userstylesworld.js
Gusted 47c2576258
Add USw hook to remove get stylus button
This patch add an hook into the https://userstyles.world/style/* pages to watch for the Get Stylus button and removes it.

As user's who already have stylus installed don't need to see this again.
2021-04-30 12:57:53 +02:00

42 lines
1.2 KiB
JavaScript

/* global API */// msg.js
'use strict';
(() => {
function watchForStylusButton() {
// Use 1 function so we won't have duplicate code around.
const stylusQuery = () => document.querySelector("a#stylus");
if (!stylusQuery()) {
const stylusButtonObserver = new MutationObserver(() => {
if (stylusQuery()) {
stylusButtonObserver.disconnect();
stylusQuery().remove();
}
});
stylusButtonObserver.observe(document.body, {childList: true, subtree: true});
} else {
stylusQuery().remove();
}
}
// Some trickery to make sure that the DOM is ready(document.body/document.head).
// And can possibly observe it for a stylus button.
function isDOMReady() {
return document.readyState === 'complete' || document.readyState === 'interactive';
}
if (!isDOMReady()) {
const onReadyStateChange = () => {
if (isDOMReady()) {
document.removeEventListener('readystatechange', onReadyStateChange);
watchForStylusButton();
}
};
document.addEventListener('readystatechange', onReadyStateChange);
} else {
watchForStylusButton();
}
})()