Inject Stylus into shadowRoots

inject styles of stylus-addon in shadowRoot

От 29.06.2025. Виж последната версия.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey, Greasemonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Userscripts.

За да инсталирате скрипта, трябва да инсталирате разширение като Tampermonkey.

За да инсталирате този скрипт, трябва да имате инсталиран скриптов мениджър.

(Вече имам скриптов мениджър, искам да го инсталирам!)

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

(Вече имам инсталиран мениджър на стиловете, искам да го инсталирам!)

// ==UserScript==
// @name                Inject Stylus into shadowRoots
// @name:pt-BR          Injetar Stylus em shadowRoots
// @namespace           https://greatest.deepsurf.us/users/821661
// @version             1.1
// @description         inject styles of stylus-addon in shadowRoot
// @description:pt-BR   injeta estilos do stylus-addon em shadowRoot
// @author              hdyzen
// @run-at              document-start
// @match               https://*/*
// @grant               none
// @license             GPL-3.0-only
// ==/UserScript==

const sheet = new CSSStyleSheet();
const originalShadowRootDescriptor = Object.getOwnPropertyDescriptor(ShadowRoot.prototype, "adoptedStyleSheets");
const originalAttachShadow = Element.prototype.attachShadow;

function syncStyles() {
	const css = [...document.querySelectorAll("html > style.stylus")].map((s) => s.textContent).join("\n");
	sheet.replaceSync(css);
}

Element.prototype.attachShadow = function (init) {
	const shadowRoot = originalAttachShadow.call(this, init);

	shadowRoot.adoptedStyleSheets = [...shadowRoot.adoptedStyleSheets, sheet];

	return shadowRoot;
};

Object.defineProperty(ShadowRoot.prototype, "adoptedStyleSheets", {
	get() {
		return originalShadowRootDescriptor.get.call(this);
	},
	set(newSheets) {
		const sheets = [...newSheets];

		if (!sheets.includes(sheet)) {
			sheets.push(sheet);
		}

		originalShadowRootDescriptor.set.call(this, sheets);
	},
	configurable: true,
	enumerable: true,
});

new MutationObserver(syncStyles).observe(document.documentElement, {
	childList: true,
	subtree: true,
	characterData: true,
});