Photopea No Ads Sidebar

Remove the gap of ads Sidebar

当前为 2024-08-14 提交的版本,查看 最新版本

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name        Photopea No Ads Sidebar
// @namespace   imxitiz's-Scripts
// @version     0.1
// @grant       unsafeWindow
// @license     GNU GPLv3
// @author      imxitiz
// @match       https://www.photopea.com/*
// @description Remove the gap of ads Sidebar
// @run-at      document-idle
// ==/UserScript==

function resize() {
    const adWidth =
        document.querySelector(".app").offsetWidth -
        document.querySelector(".app > div").offsetWidth;
    Object.defineProperty(window, "innerWidth", {
        get() {
            return parseInt(document.documentElement.offsetWidth) + adWidth;
        },
    });
    window.dispatchEvent(new Event("resize"));
}

const observer = new MutationObserver((mutations) => {
    for (const mutation of mutations) {
        for (const node of mutation.addedNodes) {
            if (node.nodeType === 1 && node.matches(".app *")) {
                observer.disconnect();
                resize();
                return;
            }
        }
    }
});

observer.observe(document.body, {
    childList: true,
    subtree: true,
});